diff options
author | Ted Kremenek <kremenek@apple.com> | 2010-02-11 07:41:25 +0000 |
---|---|---|
committer | Ted Kremenek <kremenek@apple.com> | 2010-02-11 07:41:25 +0000 |
commit | 020a095de30ede5b1e3fc65dae501f225a1c89d3 (patch) | |
tree | 6794f95c535586a84a9a95f0dbd59c01e9f7912f /tools/c-index-test/c-index-test.c | |
parent | 5961611172f1c210fbbaa55b3c692e13b1fc7be4 (diff) |
Attempt to always dispose of the CXIndex object in c-index-test.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@95864 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'tools/c-index-test/c-index-test.c')
-rw-r--r-- | tools/c-index-test/c-index-test.c | 15 |
1 files changed, 12 insertions, 3 deletions
diff --git a/tools/c-index-test/c-index-test.c b/tools/c-index-test/c-index-test.c index 26df528ca6..b33b0f4aa7 100644 --- a/tools/c-index-test/c-index-test.c +++ b/tools/c-index-test/c-index-test.c @@ -493,13 +493,18 @@ int perform_test_load_tu(const char *file, const char *filter, PostVisitTU PV) { CXIndex Idx; CXTranslationUnit TU; + int result; Idx = clang_createIndex(/* excludeDeclsFromPCH */ !strcmp(filter, "local") ? 1 : 0); - if (!CreateTranslationUnit(Idx, file, &TU)) + if (!CreateTranslationUnit(Idx, file, &TU)) { + clang_disposeIndex(Idx); return 1; + } - return perform_test_load(Idx, TU, filter, prefix, Visitor, PV); + result = perform_test_load(Idx, TU, filter, prefix, Visitor, PV); + clang_disposeIndex(Idx); + return result; } int perform_test_load_source(int argc, const char **argv, @@ -519,8 +524,10 @@ int perform_test_load_source(int argc, const char **argv, if (UseExternalASTs && strlen(UseExternalASTs)) clang_setUseExternalASTGeneration(Idx, 1); - if (parse_remapped_files(argc, argv, 0, &unsaved_files, &num_unsaved_files)) + if (parse_remapped_files(argc, argv, 0, &unsaved_files, &num_unsaved_files)) { + clang_disposeIndex(Idx); return -1; + } TU = clang_createTranslationUnitFromSourceFile(Idx, 0, argc - num_unsaved_files, @@ -531,11 +538,13 @@ int perform_test_load_source(int argc, const char **argv, stderr); if (!TU) { fprintf(stderr, "Unable to load translation unit!\n"); + clang_disposeIndex(Idx); return 1; } result = perform_test_load(Idx, TU, filter, NULL, Visitor, PV); free_remapped_files(unsaved_files, num_unsaved_files); + clang_disposeIndex(Idx); return result; } |