summaryrefslogtreecommitdiffstats
path: root/clang-tools-extra/clang-query/tool/ClangQuery.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'clang-tools-extra/clang-query/tool/ClangQuery.cpp')
-rw-r--r--clang-tools-extra/clang-query/tool/ClangQuery.cpp31
1 files changed, 19 insertions, 12 deletions
diff --git a/clang-tools-extra/clang-query/tool/ClangQuery.cpp b/clang-tools-extra/clang-query/tool/ClangQuery.cpp
index 669dc40e362..d0a4a80a370 100644
--- a/clang-tools-extra/clang-query/tool/ClangQuery.cpp
+++ b/clang-tools-extra/clang-query/tool/ClangQuery.cpp
@@ -58,6 +58,24 @@ static cl::list<std::string> CommandFiles("f",
cl::value_desc("file"),
cl::cat(ClangQueryCategory));
+bool runCommandsInFile(const char *ExeName, std::string const &FileName,
+ QuerySession &QS) {
+ std::ifstream Input(FileName.c_str());
+ if (!Input.is_open()) {
+ llvm::errs() << ExeName << ": cannot open " << FileName << "\n";
+ return 1;
+ }
+ while (Input.good()) {
+ std::string Line;
+ std::getline(Input, Line);
+
+ QueryRef Q = QueryParser::parse(Line, QS);
+ if (!Q->run(llvm::outs(), QS))
+ return true;
+ }
+ return false;
+}
+
int main(int argc, const char **argv) {
llvm::sys::PrintStackTraceOnErrorSignal(argv[0]);
@@ -84,19 +102,8 @@ int main(int argc, const char **argv) {
}
} else if (!CommandFiles.empty()) {
for (auto I = CommandFiles.begin(), E = CommandFiles.end(); I != E; ++I) {
- std::ifstream Input(I->c_str());
- if (!Input.is_open()) {
- llvm::errs() << argv[0] << ": cannot open " << *I << "\n";
+ if (runCommandsInFile(argv[0], *I, QS))
return 1;
- }
- while (Input.good()) {
- std::string Line;
- std::getline(Input, Line);
-
- QueryRef Q = QueryParser::parse(Line, QS);
- if (!Q->run(llvm::outs(), QS))
- return 1;
- }
}
} else {
LineEditor LE("clang-query");
OpenPOWER on IntegriCloud