summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDaniel Dunbar <daniel@zuster.org>2010-02-13 18:33:03 +0000
committerDaniel Dunbar <daniel@zuster.org>2010-02-13 18:33:03 +0000
commit2037d4e4ea3bcd6201dd4019ea10fb85abb9e365 (patch)
tree69125843f939e6cc58f00e09c6f15efacb0a6ae0
parent4ea31ab3698e9fae8d27f5ddc9e9aff6efd5f2d0 (diff)
downloadbcm5719-llvm-2037d4e4ea3bcd6201dd4019ea10fb85abb9e365.tar.gz
bcm5719-llvm-2037d4e4ea3bcd6201dd4019ea10fb85abb9e365.zip
cindex/Python: Update for clang_getDiagnosticRange... API changes.
llvm-svn: 96105
-rw-r--r--clang/bindings/python/clang/cindex.py27
1 files changed, 9 insertions, 18 deletions
diff --git a/clang/bindings/python/clang/cindex.py b/clang/bindings/python/clang/cindex.py
index 45a75b44c44..b6383fb2286 100644
--- a/clang/bindings/python/clang/cindex.py
+++ b/clang/bindings/python/clang/cindex.py
@@ -555,15 +555,13 @@ _clang_getDiagnosticSpelling.argtypes = [c_object_p]
_clang_getDiagnosticSpelling.restype = _CXString
_clang_getDiagnosticSpelling.errcheck = _CXString.from_result
-_clang_getDiagnosticRanges = lib.clang_getDiagnosticRanges
-_clang_getDiagnosticRanges.argtypes = [c_object_p,
- POINTER(POINTER(SourceRange)),
- POINTER(c_uint)]
-_clang_getDiagnosticRanges.restype = None
+_clang_getDiagnosticNumRanges = lib.clang_getDiagnosticNumRanges
+_clang_getDiagnosticNumRanges.argtypes = [c_object_p]
+_clang_getDiagnosticNumRanges.restype = c_uint
-_clang_disposeDiagnosticRanges = lib.clang_disposeDiagnosticRanges
-_clang_disposeDiagnosticRanges.argtypes = [POINTER(SourceRange), c_uint]
-_clang_disposeDiagnosticRanges.restype = None
+_clang_getDiagnosticRange = lib.clang_getDiagnosticRange
+_clang_getDiagnosticRange.argtypes = [c_object_p, c_uint]
+_clang_getDiagnosticRange.restype = SourceRange
_clang_getDiagnosticNumFixIts = lib.clang_getDiagnosticNumFixIts
_clang_getDiagnosticNumFixIts.argtypes = [c_object_p]
@@ -622,16 +620,9 @@ def _convert_diag(diag_ptr, diag_list):
spelling = _clang_getDiagnosticSpelling(diag_ptr)
# Diagnostic ranges.
- #
- # FIXME: Use getNum... based API?
- num_ranges = c_uint()
- ranges_array = POINTER(SourceRange)()
- _clang_getDiagnosticRanges(diag_ptr, byref(ranges_array), byref(num_ranges))
-
- # Copy the ranges array so we can dispose the original.
- ranges = [SourceRange.from_buffer_copy(ranges_array[i])
- for i in range(num_ranges.value)]
- _clang_disposeDiagnosticRanges(ranges_array, num_ranges)
+ num_ranges = _clang_getDiagnosticNumRanges(diag_ptr)
+ ranges = [_clang_getDiagnosticRange(diag_ptr, i)
+ for i in range(num_ranges)]
fixits = [_convert_fixit(diag_ptr, i)
for i in range(_clang_getDiagnosticNumFixIts(diag_ptr))]
OpenPOWER on IntegriCloud