-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathvarlist_mod.f90
131 lines (110 loc) · 4.68 KB
/
varlist_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
module libvarlist
use, intrinsic :: iso_c_binding
use libvarlistitem
use libvarlistitem_c
private
public :: varlist
include "varlist_def.f90"
type varlist
private
type(c_ptr) :: varlist_ptr
contains
final :: varlist_delete
procedure :: delete => varlist_delete_polymorph ! TODO: ???
procedure :: append => varlist_append
procedure :: finalize => varlist_finalize
procedure :: search => varlist_search
procedure :: getId => varlist_getId
procedure :: getName => varlist_getName
procedure :: getListLength => varlist_getListLength
procedure :: getFirstVariable => varlist_getFirstVariable
procedure :: getNextVariable => varlist_getNextVariable
end type varlist
interface varlist
procedure varlist_create ! TODO: why not in contains section above?
end interface
contains
function varlist_create(str)
implicit none
type(varlist) :: varlist_create
character(len=*), intent(in) :: str
character(len=1, kind=C_CHAR) :: c_str(len_trim(str) + 1)
integer :: N, i
! Converting Fortran string to C string
N = len_trim(str)
do i = 1, N
c_str(i) = str(i:i)
end do
c_str(N + 1) = C_NULL_CHAR
varlist_create%varlist_ptr = varlist_create_c(c_str)
end function varlist_create
subroutine varlist_delete(this)
implicit none
type(varlist) :: this
call varlist_delete_c(this%varlist_ptr)
end subroutine varlist_delete
! TODO: I don't understand why we need this one
subroutine varlist_delete_polymorph(this)
implicit none
class(varlist) :: this
call varlist_delete_c(this%varlist_ptr)
end subroutine varlist_delete_polymorph
subroutine varlist_append(this, name, val)
implicit none
class(varlist), intent(in) :: this
integer(c_int), intent(in) :: name
real(c_double), intent(in) :: val
call varlist_append_c(this%varlist_ptr, name, val)
end subroutine varlist_append
function varlist_search(this, name)
implicit none
real(c_double), pointer :: varlist_search
class(varlist), intent(in) :: this
integer(c_int), intent(in) :: name
call c_f_pointer(varlist_search_c(this%varlist_ptr, name), varlist_search)
end function varlist_search
subroutine varlist_finalize(this)
implicit none
class(varlist) :: this
call varlist_finalize_c(this%varlist_ptr)
end subroutine varlist_finalize
integer function varlist_getId(this)
implicit none
class(varlist), intent(in) :: this
varlist_getId = varlist_getId_c(this%varlist_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), intent(in) :: this
call varlist_getName_c(this%varlist_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), intent(in) :: this
varlist_getListLength = varlist_getListLength_c(this%varlist_ptr)
end function varlist_getListLength
function varlist_getFirstVariable(this) result(varlist_first_variable)
implicit none
class(varlist), 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_ptr)
varlist_first_variable = varlist_item(varlist_first_variable_c%name, varlist_first_variable_c%value_ptr)
end function varlist_getFirstVariable
function varlist_getNextVariable(this, current_variable) result(varlist_next_variable)
implicit none
class(varlist), intent(in) :: this
class(varlist_item), intent(in) :: current_variable ! TODO: only the key is needed
type(varlist_item) :: varlist_next_variable
type(varlist_item_c) :: varlist_next_variable_c
varlist_next_variable_c = varlist_getNextVariable_c(this%varlist_ptr, current_variable%getName())
varlist_next_variable = varlist_item(varlist_next_variable_c%name, varlist_next_variable_c%value_ptr)
end function varlist_getNextVariable
end module libvarlist