diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2015-01-18 16:23:48 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2015-01-18 16:23:48 +0000 | 
| commit | 06d4ba388873e6d1cfa9cd715a8935ecc8cd2097 (patch) | |
| tree | 3eb853da77d46cc77c4b017525a422f9ddb1385b /bindings/python/tests/cindex/test_cursor.py | |
| parent | 30d791273d07fac9c0c1641a0731191bca6e8606 (diff) | |
Diffstat (limited to 'bindings/python/tests/cindex/test_cursor.py')
| -rw-r--r-- | bindings/python/tests/cindex/test_cursor.py | 58 | 
1 files changed, 58 insertions, 0 deletions
| diff --git a/bindings/python/tests/cindex/test_cursor.py b/bindings/python/tests/cindex/test_cursor.py index 431504502245..a5224aafabc1 100644 --- a/bindings/python/tests/cindex/test_cursor.py +++ b/bindings/python/tests/cindex/test_cursor.py @@ -1,6 +1,8 @@ +import ctypes  import gc  from clang.cindex import CursorKind +from clang.cindex import TemplateArgumentKind  from clang.cindex import TranslationUnit  from clang.cindex import TypeKind  from .util import get_cursor @@ -244,6 +246,48 @@ def test_get_arguments():      assert arguments[0].spelling == "i"      assert arguments[1].spelling == "j" +kTemplateArgTest = """\ +        template <int kInt, typename T, bool kBool> +        void foo(); + +        template<> +        void foo<-7, float, true>(); +    """ + +def test_get_num_template_arguments(): +    tu = get_tu(kTemplateArgTest, lang='cpp') +    foos = get_cursors(tu, 'foo') + +    assert foos[1].get_num_template_arguments() == 3 + +def test_get_template_argument_kind(): +    tu = get_tu(kTemplateArgTest, lang='cpp') +    foos = get_cursors(tu, 'foo') + +    assert foos[1].get_template_argument_kind(0) == TemplateArgumentKind.INTEGRAL +    assert foos[1].get_template_argument_kind(1) == TemplateArgumentKind.TYPE +    assert foos[1].get_template_argument_kind(2) == TemplateArgumentKind.INTEGRAL + +def test_get_template_argument_type(): +    tu = get_tu(kTemplateArgTest, lang='cpp') +    foos = get_cursors(tu, 'foo') + +    assert foos[1].get_template_argument_type(1).kind == TypeKind.FLOAT + +def test_get_template_argument_value(): +    tu = get_tu(kTemplateArgTest, lang='cpp') +    foos = get_cursors(tu, 'foo') + +    assert foos[1].get_template_argument_value(0) == -7 +    assert foos[1].get_template_argument_value(2) == True + +def test_get_template_argument_unsigned_value(): +    tu = get_tu(kTemplateArgTest, lang='cpp') +    foos = get_cursors(tu, 'foo') + +    assert foos[1].get_template_argument_unsigned_value(0) == 2 ** 32 - 7 +    assert foos[1].get_template_argument_unsigned_value(2) == True +  def test_referenced():      tu = get_tu('void foo(); void bar() { foo(); }')      foo = get_cursor(tu, 'foo') @@ -252,3 +296,17 @@ def test_referenced():          if c.kind == CursorKind.CALL_EXPR:              assert c.referenced.spelling == foo.spelling              break + +def test_mangled_name(): +    kInputForMangling = """\ +    int foo(int, int); +    """ +    tu = get_tu(kInputForMangling, lang='cpp') +    foo = get_cursor(tu, 'foo') + +    # Since libclang does not link in targets, we cannot pass a triple to it +    # and force the target. To enable this test to pass on all platforms, accept +    # all valid manglings. +    # [c-index-test handles this by running the source through clang, emitting +    #  an AST file and running libclang on that AST file] +    assert foo.mangled_name in ('_Z3fooii', '__Z3fooii', '?foo@@YAHHH') | 
