diff options
author | Bob Eldering <eldering@jive.eu> | 2018-03-08 17:25:04 +0100 |
---|---|---|
committer | Bob Eldering <eldering@jive.eu> | 2018-03-08 17:25:04 +0100 |
commit | ac147e6c178976bc86cc9e477ea687ae38cd5b9b (patch) | |
tree | 2447eb5d4b295d267401910b37c6aceebcf0f725 | |
parent | a9cdd90902ed9124dbd6cdd3464706cac513480b (diff) | |
download | python-numpy-ac147e6c178976bc86cc9e477ea687ae38cd5b9b.tar.gz python-numpy-ac147e6c178976bc86cc9e477ea687ae38cd5b9b.tar.bz2 python-numpy-ac147e6c178976bc86cc9e477ea687ae38cd5b9b.zip |
TST: test handling ';' in multiline and enhancement lines, numpy.f2py
Regression tests for bug discussed in pull request #10676.
Lines matching the multiline or f2py enhancement pattern should not be
split by ';'.
-rw-r--r-- | numpy/f2py/tests/test_semicolon_split.py | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/numpy/f2py/tests/test_semicolon_split.py b/numpy/f2py/tests/test_semicolon_split.py new file mode 100644 index 000000000..d844e2eae --- /dev/null +++ b/numpy/f2py/tests/test_semicolon_split.py @@ -0,0 +1,53 @@ +from __future__ import division, absolute_import, print_function + +from . import util +from numpy.testing import assert_equal + +class TestMultiline(util.F2PyTest): + suffix = ".pyf" + module_name = "multiline" + code = """ +python module {module} + usercode ''' +void foo(int* x) {{ + char dummy = ';'; + *x = 42; +}} +''' + interface + subroutine foo(x) + intent(c) foo + integer intent(out) :: x + end subroutine foo + end interface +end python module {module} + """.format(module=module_name) + + def test_multiline(self): + assert_equal(self.module.foo(), 42) + +class TestCallstatement(util.F2PyTest): + suffix = ".pyf" + module_name = "callstatement" + code = """ +python module {module} + usercode ''' +void foo(int* x) {{ +}} +''' + interface + subroutine foo(x) + intent(c) foo + integer intent(out) :: x + callprotoargument int* + callstatement {{ & + ; & + x = 42; & + }} + end subroutine foo + end interface +end python module {module} + """.format(module=module_name) + + def test_callstatement(self): + assert_equal(self.module.foo(), 42) |