diff options
author | Tobias Grosser <grosser@fim.uni-passau.de> | 2012-02-05 11:40:59 +0000 |
---|---|---|
committer | Tobias Grosser <grosser@fim.uni-passau.de> | 2012-02-05 11:40:59 +0000 |
commit | 74858335a1a5205b3e1c89ecf9221cea839c0b0b (patch) | |
tree | c1c829ea395c5d9fb0d758b79ea0ce5236c7d2a5 /bindings/python/tests | |
parent | b919815a0caf836e28c49d7253d8949d7ceb24ad (diff) |
[clang.py] Implement __eq__ and __ne__ on SourceLocation and SourceRange
There is no type checking in __eq__, so ctypes will throw if the wrong
Python type is passed in to the C function. Personally, I feel garbage
in means garbage out and it isn't worth testing for this explicitly.
Contributed by: Gregory Szorc <gregory.szorc@gmail.com>
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@149824 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'bindings/python/tests')
-rw-r--r-- | bindings/python/tests/cindex/test_location.py | 20 |
1 files changed, 19 insertions, 1 deletions
diff --git a/bindings/python/tests/cindex/test_location.py b/bindings/python/tests/cindex/test_location.py index 300136f0cd..1707f01aea 100644 --- a/bindings/python/tests/cindex/test_location.py +++ b/bindings/python/tests/cindex/test_location.py @@ -1,4 +1,4 @@ -from clang.cindex import Index, File, SourceLocation, Cursor +from clang.cindex import Index, File, SourceLocation, SourceRange, Cursor baseInput="int one;\nint two;\n" @@ -47,6 +47,12 @@ def test_location(): if n.spelling == 'one': assert n == cursor + # Ensure locations referring to the same entity are equivalent. + location2 = SourceLocation.from_position(tu, file, 1, 5) + assert location == location2 + location3 = SourceLocation.from_position(tu, file, 1, 4) + assert location2 != location3 + def test_extent(): index = Index.create() tu = index.parse('t.c', unsaved_files = [('t.c',baseInput)]) @@ -60,3 +66,15 @@ def test_extent(): assert_location(n.extent.start,line=2,column=1,offset=9) assert_location(n.extent.end,line=2,column=8,offset=16) assert baseInput[n.extent.start.offset:n.extent.end.offset] == "int two" + + file = File.from_name(tu, 't.c') + location1 = SourceLocation.from_position(tu, file, 1, 1) + location2 = SourceLocation.from_position(tu, file, 1, 8) + + range1 = SourceRange.from_locations(location1, location2) + range2 = SourceRange.from_locations(location1, location2) + assert range1 == range2 + + location3 = SourceLocation.from_position(tu, file, 1, 6) + range3 = SourceRange.from_locations(location1, location3) + assert range1 != range3 |