diff options
| author | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2013-04-04 22:40:59 +0000 |
|---|---|---|
| committer | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2013-04-04 22:40:59 +0000 |
| commit | 0e95fcacdfc305c0323b2a4b45d4fae4e24df954 (patch) | |
| tree | 468f9e6901bd978791b6fc863bb824a704ff7525 | |
| parent | 3903247e487871a3860cd5241da57c4707d506a1 (diff) | |
| download | bcm5719-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.cpp | 8 |
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; } |

