diff options
author | Dmitri Gribenko <gribozavr@gmail.com> | 2014-02-11 14:34:14 +0000 |
---|---|---|
committer | Dmitri Gribenko <gribozavr@gmail.com> | 2014-02-11 14:34:14 +0000 |
commit | 256454fdaa4d3d044a80c2991b210ca3d2bf2a24 (patch) | |
tree | 9b5b2b53a26df69747a82bf429ba63abd5332635 /clang/tools/libclang/CIndexDiagnostic.cpp | |
parent | e5a447d947ebbd622757fb19e424c0ee5445bbcb (diff) | |
download | bcm5719-llvm-256454fdaa4d3d044a80c2991b210ca3d2bf2a24.tar.gz bcm5719-llvm-256454fdaa4d3d044a80c2991b210ca3d2bf2a24.zip |
libclang: audit all APIs that accept a CXTranslationUnit to make sure that
checks for invalid translation unit are in place. Also, while there, add log
output for this case.
llvm-svn: 201155
Diffstat (limited to 'clang/tools/libclang/CIndexDiagnostic.cpp')
-rw-r--r-- | clang/tools/libclang/CIndexDiagnostic.cpp | 15 |
1 files changed, 14 insertions, 1 deletions
diff --git a/clang/tools/libclang/CIndexDiagnostic.cpp b/clang/tools/libclang/CIndexDiagnostic.cpp index 0e9dde8d1ed..dec32285158 100644 --- a/clang/tools/libclang/CIndexDiagnostic.cpp +++ b/clang/tools/libclang/CIndexDiagnostic.cpp @@ -208,12 +208,21 @@ CXDiagnosticSetImpl *cxdiag::lazyCreateDiags(CXTranslationUnit TU, extern "C" { unsigned clang_getNumDiagnostics(CXTranslationUnit Unit) { + if (cxtu::isNotUseableTU(Unit)) { + LOG_BAD_TU(Unit); + return 0; + } if (!cxtu::getASTUnit(Unit)) return 0; return lazyCreateDiags(Unit, /*checkIfChanged=*/true)->getNumDiagnostics(); } CXDiagnostic clang_getDiagnostic(CXTranslationUnit Unit, unsigned Index) { + if (cxtu::isNotUseableTU(Unit)) { + LOG_BAD_TU(Unit); + return 0; + } + CXDiagnosticSet D = clang_getDiagnosticSetFromTU(Unit); if (!D) return 0; @@ -224,8 +233,12 @@ CXDiagnostic clang_getDiagnostic(CXTranslationUnit Unit, unsigned Index) { return Diags->getDiagnostic(Index); } - + CXDiagnosticSet clang_getDiagnosticSetFromTU(CXTranslationUnit Unit) { + if (cxtu::isNotUseableTU(Unit)) { + LOG_BAD_TU(Unit); + return 0; + } if (!cxtu::getASTUnit(Unit)) return 0; return static_cast<CXDiagnostic>(lazyCreateDiags(Unit)); |