summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorArgyrios Kyrtzidis <akyrtzi@gmail.com>2013-04-04 22:40:59 +0000
committerArgyrios Kyrtzidis <akyrtzi@gmail.com>2013-04-04 22:40:59 +0000
commit0e95fcacdfc305c0323b2a4b45d4fae4e24df954 (patch)
tree468f9e6901bd978791b6fc863bb824a704ff7525
parent3903247e487871a3860cd5241da57c4707d506a1 (diff)
downloadbcm5719-llvm-0e95fcacdfc305c0323b2a4b45d4fae4e24df954.tar.gz
bcm5719-llvm-0e95fcacdfc305c0323b2a4b45d4fae4e24df954.zip
[libclang] Add some checks to make sure the given CXTranslationUnit is not null, before using it.
llvm-svn: 178800
-rw-r--r--clang/tools/libclang/CIndex.cpp8
1 files changed, 7 insertions, 1 deletions
diff --git a/clang/tools/libclang/CIndex.cpp b/clang/tools/libclang/CIndex.cpp
index 59a7e8d1125..a81f1e437d2 100644
--- a/clang/tools/libclang/CIndex.cpp
+++ b/clang/tools/libclang/CIndex.cpp
@@ -2927,6 +2927,9 @@ CXString clang_getTranslationUnitSpelling(CXTranslationUnit CTUnit) {
}
CXCursor clang_getTranslationUnitCursor(CXTranslationUnit TU) {
+ if (!TU)
+ return clang_getNullCursor();
+
ASTUnit *CXXUnit = cxtu::getASTUnit(TU);
return MakeCXCursor(CXXUnit->getASTContext().getTranslationUnitDecl(), TU);
}
@@ -4914,6 +4917,9 @@ void clang_tokenize(CXTranslationUnit TU, CXSourceRange Range,
if (NumTokens)
*NumTokens = 0;
+ if (!TU)
+ return;
+
ASTUnit *CXXUnit = cxtu::getASTUnit(TU);
if (!CXXUnit || !Tokens || !NumTokens)
return;
@@ -5610,7 +5616,7 @@ extern "C" {
void clang_annotateTokens(CXTranslationUnit TU,
CXToken *Tokens, unsigned NumTokens,
CXCursor *Cursors) {
- if (NumTokens == 0 || !Tokens || !Cursors) {
+ if (!TU || NumTokens == 0 || !Tokens || !Cursors) {
LOG_FUNC_SECTION { *Log << "<null input>"; }
return;
}
OpenPOWER on IntegriCloud