-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathvarlist_cfi_mod.f90
188 lines (162 loc) · 7.46 KB
/
varlist_cfi_mod.f90
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
module libvarlistcfi
use, intrinsic :: iso_c_binding
use libvarlistcfiitem
use libvarlistitem_c
private
public :: varlist_cfi
include "varlist_cfi_def.f90"
type varlist_cfi
private
type(c_ptr) :: varlist_cfi_ptr
contains
final :: varlist_delete
procedure :: delete => varlist_delete_polymorph ! TODO: ???
procedure :: append => varlist_append
procedure :: append_2D => varlist_append_2D
procedure :: append_scalar => varlist_append_scalar
procedure :: finalize => varlist_finalize
procedure :: search => varlist_search
procedure :: search_2D => varlist_search_2D
procedure :: search_scalar => varlist_search_scalar
procedure :: getId => varlist_getId
procedure :: getName => varlist_getName
procedure :: getListLength => varlist_getListLength
! procedure :: getFirstVariable => varlist_getFirstVariable
! procedure :: getNextVariable => varlist_getNextVariable
end type varlist_cfi
interface varlist_cfi
procedure varlist_create ! TODO: why not in contains section above?
end interface varlist_cfi
contains
function varlist_create(str)
implicit none
type(varlist_cfi) :: varlist_create
character(len=*), intent(in) :: str
character(len=1, kind=C_CHAR) :: c_str(len_trim(str) + 1)
call convertToCString(str,c_str)
varlist_create%varlist_cfi_ptr = varlist_create_c(c_str)
end function varlist_create
subroutine varlist_delete(this)
implicit none
type(varlist_cfi) :: this
call varlist_delete_c(this%varlist_cfi_ptr)
end subroutine varlist_delete
! TODO: I don't understand why we need this one
subroutine varlist_delete_polymorph(this)
implicit none
class(varlist_cfi) :: this
call varlist_delete_c(this%varlist_cfi_ptr)
end subroutine varlist_delete_polymorph
subroutine varlist_append(this, name, val)
implicit none
class(varlist_cfi), intent(in) :: this
character(len=*), intent(in) :: name
real*8, intent(in) :: val(:)
character(len=1, kind=C_CHAR) :: c_name(len_trim(name) + 1)
call convertToCString(name,c_name)
call varlist_append_c(this%varlist_cfi_ptr, c_name, val)
end subroutine varlist_append
subroutine varlist_append_2D(this, name, val)
implicit none
class(varlist_cfi), intent(in) :: this
character(len=*), intent(in) :: name
real*8, intent(in) :: val(:,:)
character(len=1, kind=C_CHAR) :: c_name(len_trim(name) + 1)
call convertToCString(name,c_name)
call varlist_append_2D_c(this%varlist_cfi_ptr, c_name, val)
end subroutine varlist_append_2D
subroutine varlist_append_scalar(this, name, val)
implicit none
class(varlist_cfi), intent(in) :: this
character(len=*), intent(in) :: name
real*8, intent(in) :: val
character(len=1, kind=C_CHAR) :: c_name(len_trim(name) + 1)
call convertToCString(name,c_name)
call varlist_append_scalar_c(this%varlist_cfi_ptr, c_name, val)
end subroutine varlist_append_scalar
function varlist_search(this, name)
implicit none
real*8, pointer :: varlist_search(:)
class(varlist_cfi), intent(in) :: this
character(len=*), intent(in) :: name
character(len=1, kind=C_CHAR) :: c_name(len_trim(name) + 1)
call convertToCString(name,c_name)
call varlist_search_c(this%varlist_cfi_ptr, c_name, varlist_search)
end function varlist_search
function varlist_search_2D(this, name)
implicit none
real*8, pointer :: varlist_search_2D(:,:)
class(varlist_cfi), intent(in) :: this
character(len=*), intent(in) :: name
character(len=1, kind=C_CHAR) :: c_name(len_trim(name) + 1)
call convertToCString(name,c_name)
call varlist_search_2D_c(this%varlist_cfi_ptr, c_name, varlist_search_2D)
end function varlist_search_2D
function varlist_search_scalar(this, name)
implicit none
real*8 :: varlist_search_scalar
class(varlist_cfi), intent(in) :: this
character(len=*), intent(in) :: name
character(len=1, kind=C_CHAR) :: c_name(len_trim(name) + 1)
call convertToCString(name,c_name)
call varlist_search_scalar_c(this%varlist_cfi_ptr, c_name, varlist_search_scalar)
end function varlist_search_scalar
subroutine varlist_finalize(this)
implicit none
class(varlist_cfi) :: this
call varlist_finalize_c(this%varlist_cfi_ptr)
end subroutine varlist_finalize
integer function varlist_getId(this)
implicit none
class(varlist_cfi), intent(in) :: this
varlist_getId = varlist_getId_c(this%varlist_cfi_ptr)
end function varlist_getId
!! TODO: "strongly inspired" by the following link..
!! https://stackoverflow.com/questions/9972743/creating-a-fortran-interface-to-a-c-function-that-returns-a-char
function varlist_getName(this) ! TODO: I'm not sure of signature and implementation
use, intrinsic :: iso_c_binding
implicit none
character*255 :: varlist_getName
character*255 list_name
integer name_length
class(varlist_cfi), intent(in) :: this
call varlist_getName_c(this%varlist_cfi_ptr, list_name, name_length)
varlist_getName = list_name(1:name_length)
end function varlist_getName
integer function varlist_getListLength(this)
implicit none
class(varlist_cfi), intent(in) :: this
varlist_getListLength = varlist_getListLength_c(this%varlist_cfi_ptr)
end function varlist_getListLength
! function varlist_getFirstVariable(this) result(varlist_first_variable)
! implicit none
! class(varlist_cfi), intent(in) :: this
! type(varlist_item) :: varlist_first_variable
! type(varlist_item_c) :: varlist_first_variable_c
! varlist_first_variable_c = varlist_getFirstVariable_c(this%varlist_cfi_ptr)
! varlist_first_variable = varlist_item(varlist_first_variable_c%name, varlist_first_variable_c%value_cfi_ptr)
! end function varlist_getFirstVariable
! function varlist_getNextVariable(this, current_variable) result(varlist_next_variable)
! implicit none
! class(varlist_cfi), intent(in) :: this
! class(varlist_cfi_item), intent(in) :: current_variable ! TODO: only the key is needed
! type(varlist_cfi_item) :: varlist_next_variable
! type(varlist_item_c) :: varlist_next_variable_c
! varlist_next_variable_c = varlist_getNextVariable_c(this%varlist_cfi_ptr, current_variable%getName())
! varlist_next_variable = varlist_item(varlist_next_variable_c%name, varlist_next_variable_c%value_cfi_ptr)
! end function varlist_getNextVariable
! TODO: buggy subroutine? Do I need to allocate io_cstring outside with the correct lenght?
subroutine convertToCString(i_fstring, io_cstring)
implicit none
character(len=*), intent(in) :: i_fstring
character(len=1, kind=C_CHAR) :: io_cstring(len_trim(i_fstring) + 1)
integer :: N, i
! TODO: check for code duplication
! Converting Fortran string to C string
N = len_trim(i_fstring)
do i = 1, N
io_cstring(i) = i_fstring(i:i) ! TODO: this line or the entire subroutine is buggy! Memory access issue?
end do
io_cstring(N + 1) = C_NULL_CHAR
end subroutine convertToCString
end module libvarlistcfi