summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBob Eldering <eldering@jive.eu>2018-03-08 17:25:04 +0100
committerBob Eldering <eldering@jive.eu>2018-03-08 17:25:04 +0100
commitac147e6c178976bc86cc9e477ea687ae38cd5b9b (patch)
tree2447eb5d4b295d267401910b37c6aceebcf0f725
parenta9cdd90902ed9124dbd6cdd3464706cac513480b (diff)
downloadpython-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.py53
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)