12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788 |
- 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']
|