89 lines
2.7 KiB
Python
89 lines
2.7 KiB
Python
|
import numpy as np
|
||
|
from numpy.testing import assert_array_equal
|
||
|
from . import util
|
||
|
from numpy.f2py import crackfortran
|
||
|
import tempfile
|
||
|
import textwrap
|
||
|
|
||
|
|
||
|
class TestNoSpace(util.F2PyTest):
|
||
|
# issue gh-15035: add handling for endsubroutine, endfunction with no space
|
||
|
# between "end" and the block name
|
||
|
code = """
|
||
|
subroutine subb(k)
|
||
|
real(8), intent(inout) :: k(:)
|
||
|
k=k+1
|
||
|
endsubroutine
|
||
|
|
||
|
subroutine subc(w,k)
|
||
|
real(8), intent(in) :: w(:)
|
||
|
real(8), intent(out) :: k(size(w))
|
||
|
k=w+1
|
||
|
endsubroutine
|
||
|
|
||
|
function t0(value)
|
||
|
character value
|
||
|
character t0
|
||
|
t0 = value
|
||
|
endfunction
|
||
|
"""
|
||
|
|
||
|
def test_module(self):
|
||
|
k = np.array([1, 2, 3], dtype=np.float64)
|
||
|
w = np.array([1, 2, 3], dtype=np.float64)
|
||
|
self.module.subb(k)
|
||
|
assert_array_equal(k, w + 1)
|
||
|
self.module.subc([w, k])
|
||
|
assert_array_equal(k, w + 1)
|
||
|
assert self.module.t0(23) == b'2'
|
||
|
|
||
|
class TestPublicPrivate():
|
||
|
def test_defaultPrivate(self, tmp_path):
|
||
|
f_path = tmp_path / "mod.f90"
|
||
|
with f_path.open('w') as ff:
|
||
|
ff.write(textwrap.dedent("""\
|
||
|
module foo
|
||
|
private
|
||
|
integer :: a
|
||
|
public :: setA
|
||
|
integer :: b
|
||
|
contains
|
||
|
subroutine setA(v)
|
||
|
integer, intent(in) :: v
|
||
|
a = v
|
||
|
end subroutine setA
|
||
|
end module foo
|
||
|
"""))
|
||
|
mod = crackfortran.crackfortran([str(f_path)])
|
||
|
assert len(mod) == 1
|
||
|
mod = mod[0]
|
||
|
assert 'private' in mod['vars']['a']['attrspec']
|
||
|
assert 'public' not in mod['vars']['a']['attrspec']
|
||
|
assert 'private' in mod['vars']['b']['attrspec']
|
||
|
assert 'public' not in mod['vars']['b']['attrspec']
|
||
|
assert 'private' not in mod['vars']['seta']['attrspec']
|
||
|
assert 'public' in mod['vars']['seta']['attrspec']
|
||
|
|
||
|
def test_defaultPublic(self, tmp_path):
|
||
|
f_path = tmp_path / "mod.f90"
|
||
|
with f_path.open('w') as ff:
|
||
|
ff.write(textwrap.dedent("""\
|
||
|
module foo
|
||
|
public
|
||
|
integer, private :: a
|
||
|
public :: setA
|
||
|
contains
|
||
|
subroutine setA(v)
|
||
|
integer, intent(in) :: v
|
||
|
a = v
|
||
|
end subroutine setA
|
||
|
end module foo
|
||
|
"""))
|
||
|
mod = crackfortran.crackfortran([str(f_path)])
|
||
|
assert len(mod) == 1
|
||
|
mod = mod[0]
|
||
|
assert 'private' in mod['vars']['a']['attrspec']
|
||
|
assert 'public' not in mod['vars']['a']['attrspec']
|
||
|
assert 'private' not in mod['vars']['seta']['attrspec']
|
||
|
assert 'public' in mod['vars']['seta']['attrspec']
|