SURFEX v8.1
General documentation of Surfex
Surfex_Git2
src
LIB
FM
fmreadl1.F90
Go to the documentation of this file.
1
! ######spl
2
SUBROUTINE
fmreadl1
(HFILEM,HRECFM,HFIPRI,KLENG,OFIELD,KGRID,&
3
KLENCH,HCOMMENT,KRESP)
4
USE
parkind1
, ONLY
:
jprb
5
USE
yomhook
, ONLY
:
lhook
,
dr_hook
6
! #############################################################
7
!
8
!!**** *FMREADL1* - routine to read a logical array into a "FM"-file
9
!!
10
!! PURPOSE
11
!! -------
12
!
13
! The purpose of FMREADN0 is to convert the integer into integer(kind=8)
14
! by calling FM_READ without interface module
15
!
16
!!** METHOD
17
!! ------
18
!!
19
!! EXTERNAL
20
!! --------
21
!!
22
!! FM_READ
23
!!
24
!! IMPLICIT ARGUMENTS
25
!! ------------------
26
!!
27
!!
28
!! REFERENCE
29
!! ---------
30
!!
31
!!
32
!! AUTHOR
33
!! ------
34
!!
35
!! V. MASSON *METEO-FRANCE*
36
!!
37
!! MODIFICATIONS
38
!! -------------
39
!!
40
!! original 06/08/97
41
!----------------------------------------------------------------------------
42
!
43
!* 0. DECLARATIONS
44
! ------------
45
!
46
USE
modd_fmdeclar
47
IMPLICIT NONE
48
!
49
!* 0.1 Declarations of arguments
50
!
51
CHARACTER(LEN=*) ,INTENT(IN) ::HFILEM ! file name
52
CHARACTER(LEN=*) ,INTENT(IN) ::HRECFM ! name of the article to be written
53
54
CHARACTER(LEN=*) ,INTENT(IN) ::HFIPRI ! file for prints in FM
55
56
INTEGER
,
INTENT(IN)
::KLENG
! length of the data field
57
LOGICAL
,
DIMENSION(:)
, &
58
INTENT(OUT)
::OFIELD
! array containing the data field
59
INTEGER
,
INTENT(OUT)
::KGRID
! C-grid indicator (u,v,w,T)
60
INTEGER
,
INTENT(OUT)
::KLENCH
! length of comment string
61
62
CHARACTER(LEN=*) ,INTENT(OUT)::HCOMMENT ! comment string
63
64
INTEGER
,
INTENT(OUT)
::KRESP
! return-code if problems araised
65
!
66
!* 0.2 Declarations of local variables
67
!
68
CHARACTER(LEN=JPXKRK) ::YCOMMENT
69
INTEGER(KIND=8)
,
DIMENSION(SIZE(OFIELD))
:: IFIELD
70
!-------------------------------------------------------------------------------
71
!
72
REAL(KIND=JPRB)
:: ZHOOK_HANDLE
73
IF
(
lhook
)
CALL
dr_hook
(
'FMREADL1'
,0,zhook_handle)
74
CALL FM_READ(HFILEM,HRECFM,HFIPRI,SIZE(IFIELD),IFIELD,KGRID,KLENCH,YCOMMENT,KRESP)
75
!
76
IF
(kresp==0)
THEN
77
WHERE
(ifield==1)
78
ofield=.true.
79
ELSEWHERE
80
ofield=.false.
81
END WHERE
82
hcomment = ycomment
83
END IF
84
!-------------------------------------------------------------------------------
85
IF
(
lhook
)
CALL
dr_hook
(
'FMREADL1'
,1,zhook_handle)
86
END SUBROUTINE
fmreadl1
yomhook::dr_hook
Definition:
yomhook.F90:20
modd_fmdeclar
Definition:
modd_fmdeclar.F90:2
parkind1::jprb
integer, parameter jprb
Definition:
parkind1.F90:32
fmreadl1
subroutine fmreadl1(HFILEM, HRECFM, HFIPRI, KLENG, OFIELD, KGRID, KLENCH, HCOMMENT, KRESP)
Definition:
fmreadl1.F90:4
yomhook::lhook
logical lhook
Definition:
yomhook.F90:15
parkind1
Definition:
parkind1.F90:1
yomhook
Definition:
yomhook.F90:1
Generated on Tue Jan 16 2018 16:23:20 for SURFEX v8.1 by
1.8.13