source: XIOS/trunk/src/interface/fortran_attr/ivariable_attr.F90 @ 903

Last change on this file since 903 was 581, checked in by rlacroix, 9 years ago

Fix the Fortran interface generation to avoid generating dead code that caused a timer not to be stopped.

  • Property copyright set to
    Software name : XIOS (Xml I/O Server)
    http://forge.ipsl.jussieu.fr/ioserver
    Creation date : January 2009
    Licence : CeCCIL version2
    see license file in root directory : Licence_CeCILL_V2-en.txt
    or http://www.cecill.info/licences/Licence_CeCILL_V2-en.html
    Holder : CEA/LSCE (Laboratoire des Sciences du CLimat et de l'Environnement)
    CNRS/IPSL (Institut Pierre Simon Laplace)
    Project Manager : Yann Meurdesoif
    yann.meurdesoif@cea.fr
File size: 4.9 KB
Line 
1! * ************************************************************************** *
2! *               Interface auto generated - do not modify                     *
3! * ************************************************************************** *
4#include "xios_fortran_prefix.hpp"
5
6MODULE ivariable_attr
7  USE, INTRINSIC :: ISO_C_BINDING
8  USE ivariable
9  USE variable_interface_attr
10
11CONTAINS
12
13  SUBROUTINE xios(set_variable_attr)  &
14    ( variable_id, name, type )
15
16    IMPLICIT NONE
17      TYPE(txios(variable))  :: variable_hdl
18      CHARACTER(LEN=*), INTENT(IN) ::variable_id
19      CHARACTER(len = *) , OPTIONAL, INTENT(IN) :: name
20      CHARACTER(len = *) , OPTIONAL, INTENT(IN) :: type
21
22      CALL xios(get_variable_handle)(variable_id,variable_hdl)
23      CALL xios(set_variable_attr_hdl_)   &
24      ( variable_hdl, name, type )
25
26  END SUBROUTINE xios(set_variable_attr)
27
28  SUBROUTINE xios(set_variable_attr_hdl)  &
29    ( variable_hdl, name, type )
30
31    IMPLICIT NONE
32      TYPE(txios(variable)) , INTENT(IN) :: variable_hdl
33      CHARACTER(len = *) , OPTIONAL, INTENT(IN) :: name
34      CHARACTER(len = *) , OPTIONAL, INTENT(IN) :: type
35
36      CALL xios(set_variable_attr_hdl_)  &
37      ( variable_hdl, name, type )
38
39  END SUBROUTINE xios(set_variable_attr_hdl)
40
41  SUBROUTINE xios(set_variable_attr_hdl_)   &
42    ( variable_hdl, name_, type_ )
43
44    IMPLICIT NONE
45      TYPE(txios(variable)) , INTENT(IN) :: variable_hdl
46      CHARACTER(len = *) , OPTIONAL, INTENT(IN) :: name_
47      CHARACTER(len = *) , OPTIONAL, INTENT(IN) :: type_
48
49      IF (PRESENT(name_)) THEN
50        CALL cxios_set_variable_name(variable_hdl%daddr, name_, len(name_))
51      ENDIF
52
53      IF (PRESENT(type_)) THEN
54        CALL cxios_set_variable_type(variable_hdl%daddr, type_, len(type_))
55      ENDIF
56
57  END SUBROUTINE xios(set_variable_attr_hdl_)
58
59  SUBROUTINE xios(get_variable_attr)  &
60    ( variable_id, name, type )
61
62    IMPLICIT NONE
63      TYPE(txios(variable))  :: variable_hdl
64      CHARACTER(LEN=*), INTENT(IN) ::variable_id
65      CHARACTER(len = *) , OPTIONAL, INTENT(OUT) :: name
66      CHARACTER(len = *) , OPTIONAL, INTENT(OUT) :: type
67
68      CALL xios(get_variable_handle)(variable_id,variable_hdl)
69      CALL xios(get_variable_attr_hdl_)   &
70      ( variable_hdl, name, type )
71
72  END SUBROUTINE xios(get_variable_attr)
73
74  SUBROUTINE xios(get_variable_attr_hdl)  &
75    ( variable_hdl, name, type )
76
77    IMPLICIT NONE
78      TYPE(txios(variable)) , INTENT(IN) :: variable_hdl
79      CHARACTER(len = *) , OPTIONAL, INTENT(OUT) :: name
80      CHARACTER(len = *) , OPTIONAL, INTENT(OUT) :: type
81
82      CALL xios(get_variable_attr_hdl_)  &
83      ( variable_hdl, name, type )
84
85  END SUBROUTINE xios(get_variable_attr_hdl)
86
87  SUBROUTINE xios(get_variable_attr_hdl_)   &
88    ( variable_hdl, name_, type_ )
89
90    IMPLICIT NONE
91      TYPE(txios(variable)) , INTENT(IN) :: variable_hdl
92      CHARACTER(len = *) , OPTIONAL, INTENT(OUT) :: name_
93      CHARACTER(len = *) , OPTIONAL, INTENT(OUT) :: type_
94
95      IF (PRESENT(name_)) THEN
96        CALL cxios_get_variable_name(variable_hdl%daddr, name_, len(name_))
97      ENDIF
98
99      IF (PRESENT(type_)) THEN
100        CALL cxios_get_variable_type(variable_hdl%daddr, type_, len(type_))
101      ENDIF
102
103  END SUBROUTINE xios(get_variable_attr_hdl_)
104
105  SUBROUTINE xios(is_defined_variable_attr)  &
106    ( variable_id, name, type )
107
108    IMPLICIT NONE
109      TYPE(txios(variable))  :: variable_hdl
110      CHARACTER(LEN=*), INTENT(IN) ::variable_id
111      LOGICAL, OPTIONAL, INTENT(OUT) :: name
112      LOGICAL(KIND=C_BOOL) :: name_tmp
113      LOGICAL, OPTIONAL, INTENT(OUT) :: type
114      LOGICAL(KIND=C_BOOL) :: type_tmp
115
116      CALL xios(get_variable_handle)(variable_id,variable_hdl)
117      CALL xios(is_defined_variable_attr_hdl_)   &
118      ( variable_hdl, name, type )
119
120  END SUBROUTINE xios(is_defined_variable_attr)
121
122  SUBROUTINE xios(is_defined_variable_attr_hdl)  &
123    ( variable_hdl, name, type )
124
125    IMPLICIT NONE
126      TYPE(txios(variable)) , INTENT(IN) :: variable_hdl
127      LOGICAL, OPTIONAL, INTENT(OUT) :: name
128      LOGICAL(KIND=C_BOOL) :: name_tmp
129      LOGICAL, OPTIONAL, INTENT(OUT) :: type
130      LOGICAL(KIND=C_BOOL) :: type_tmp
131
132      CALL xios(is_defined_variable_attr_hdl_)  &
133      ( variable_hdl, name, type )
134
135  END SUBROUTINE xios(is_defined_variable_attr_hdl)
136
137  SUBROUTINE xios(is_defined_variable_attr_hdl_)   &
138    ( variable_hdl, name_, type_ )
139
140    IMPLICIT NONE
141      TYPE(txios(variable)) , INTENT(IN) :: variable_hdl
142      LOGICAL, OPTIONAL, INTENT(OUT) :: name_
143      LOGICAL(KIND=C_BOOL) :: name__tmp
144      LOGICAL, OPTIONAL, INTENT(OUT) :: type_
145      LOGICAL(KIND=C_BOOL) :: type__tmp
146
147      IF (PRESENT(name_)) THEN
148        name__tmp = cxios_is_defined_variable_name(variable_hdl%daddr)
149        name_ = name__tmp
150      ENDIF
151
152      IF (PRESENT(type_)) THEN
153        type__tmp = cxios_is_defined_variable_type(variable_hdl%daddr)
154        type_ = type__tmp
155      ENDIF
156
157  END SUBROUTINE xios(is_defined_variable_attr_hdl_)
158
159END MODULE ivariable_attr
Note: See TracBrowser for help on using the repository browser.