2020-09-06 21:19:00 +05:30
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
!> @author Martin Diehl, Max-Planck-Institut für Eisenforschung GmbH
|
|
|
|
!> @brief Inflate zlib compressed data
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
module zlib
|
|
|
|
use prec
|
|
|
|
|
2022-06-22 02:16:54 +05:30
|
|
|
implicit none(type,external)
|
2020-09-06 21:19:00 +05:30
|
|
|
private
|
|
|
|
|
|
|
|
public :: &
|
|
|
|
zlib_inflate
|
|
|
|
|
|
|
|
interface
|
|
|
|
|
2022-05-28 02:04:33 +05:30
|
|
|
subroutine inflate_C(s_deflated,s_inflated,deflated,inflated) bind(C)
|
|
|
|
use, intrinsic :: ISO_C_Binding, only: C_SIGNED_CHAR, C_INT64_T
|
2022-06-22 02:16:54 +05:30
|
|
|
implicit none(type,external)
|
2020-09-06 21:19:00 +05:30
|
|
|
|
2022-05-28 02:04:33 +05:30
|
|
|
integer(C_INT64_T), intent(in) :: s_deflated,s_inflated
|
|
|
|
integer(C_SIGNED_CHAR), dimension(s_deflated), intent(in) :: deflated
|
|
|
|
integer(C_SIGNED_CHAR), dimension(s_inflated), intent(out) :: inflated
|
|
|
|
end subroutine inflate_C
|
2020-09-06 21:19:00 +05:30
|
|
|
|
|
|
|
end interface
|
|
|
|
|
|
|
|
contains
|
|
|
|
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
!> @brief Inflate byte-wise representation
|
|
|
|
!--------------------------------------------------------------------------------------------------
|
|
|
|
function zlib_inflate(deflated,size_inflated)
|
|
|
|
|
|
|
|
integer(C_SIGNED_CHAR), dimension(:), intent(in) :: deflated
|
2020-09-12 12:44:33 +05:30
|
|
|
integer(pI64), intent(in) :: size_inflated
|
2020-09-06 21:19:00 +05:30
|
|
|
|
|
|
|
integer(C_SIGNED_CHAR), dimension(size_inflated) :: zlib_inflate
|
|
|
|
|
2022-05-28 02:04:33 +05:30
|
|
|
|
2020-09-06 21:19:00 +05:30
|
|
|
call inflate_C(size(deflated,kind=C_INT64_T),int(size_inflated,C_INT64_T),deflated,zlib_inflate)
|
|
|
|
|
|
|
|
end function zlib_inflate
|
|
|
|
|
|
|
|
end module zlib
|