[cfe-commits] r84802 - in /cfe/trunk: include/clang-c/Index.h tools/CIndex/CIndex.cpp
Ted Kremenek
kremenek at apple.com
Wed Oct 21 17:03:57 PDT 2009
Author: kremenek
Date: Wed Oct 21 19:03:57 2009
New Revision: 84802
URL: http://llvm.org/viewvc/llvm-project?rev=84802&view=rev
Log:
Enhance 'clang_createTranslationUnitFromSourceFile()' in two ways:
(1) Allow the source file to be specified in the actual command line arguments by allowing the
caller to set 'source_filename' to NULL.
(2) Automatically strip off the arguments '-emit-ast', '-fsyntax-only', and '-c'.
Modified:
cfe/trunk/include/clang-c/Index.h
cfe/trunk/tools/CIndex/CIndex.cpp
Modified: cfe/trunk/include/clang-c/Index.h
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/include/clang-c/Index.h?rev=84802&r1=84801&r2=84802&view=diff
==============================================================================
--- cfe/trunk/include/clang-c/Index.h (original)
+++ cfe/trunk/include/clang-c/Index.h Wed Oct 21 19:03:57 2009
@@ -159,12 +159,20 @@
* \brief Return the CXTranslationUnit for a given source file and the provided
* command line arguments one would pass to the compiler.
*
- * Note: If provided, this routine will strip the '-o <outputfile>' command
- * line arguments.
+ * Note: The 'source_filename' argument is optional. If the caller provides a NULL pointer,
+ * the name of the source file is expected to reside in the specified command line arguments.
+ *
+ * Note: When encountered in 'clang_command_line_args', the following options are ignored:
+ *
+ * '-c'
+ * '-emit-ast'
+ * '-fsyntax-only'
+ * '-o <output file>' (both '-o' and '<output file>' are ignored)
+ *
*/
CXTranslationUnit clang_createTranslationUnitFromSourceFile(
CXIndex CIdx,
- const char *source_filename,
+ const char *source_filename /* specify NULL if the source file is in clang_command_line_args */,
int num_clang_command_line_args,
const char **clang_command_line_args
);
Modified: cfe/trunk/tools/CIndex/CIndex.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/tools/CIndex/CIndex.cpp?rev=84802&r1=84801&r2=84802&view=diff
==============================================================================
--- cfe/trunk/tools/CIndex/CIndex.cpp (original)
+++ cfe/trunk/tools/CIndex/CIndex.cpp Wed Oct 21 19:03:57 2009
@@ -386,24 +386,45 @@
assert(CIdx && "Passed null CXIndex");
CIndexer *CXXIdx = static_cast<CIndexer *>(CIdx);
- // Build up the arguments for involing clang.
- llvm::sys::Path ClangPath = static_cast<CIndexer *>(CIdx)->getClangPath();
+ // Build up the arguments for invoking 'clang'.
std::vector<const char *> argv;
+
+ // First add the complete path to the 'clang' executable.
+ llvm::sys::Path ClangPath = static_cast<CIndexer *>(CIdx)->getClangPath();
argv.push_back(ClangPath.c_str());
+
+ // Add the '-emit-ast' option as our execution mode for 'clang'.
argv.push_back("-emit-ast");
- argv.push_back(source_filename);
- argv.push_back("-o");
+
+ // The 'source_filename' argument is optional. If the caller does not
+ // specify it then it is assumed that the source file is specified
+ // in the actual argument list.
+ if (source_filename)
+ argv.push_back(source_filename);
+
// Generate a temporary name for the AST file.
+ argv.push_back("-o");
char astTmpFile[L_tmpnam];
argv.push_back(tmpnam(astTmpFile));
- for (int i = 0; i < num_command_line_args; i++) {
- if (command_line_args[i] && strcmp(command_line_args[i], "-o") != 0)
- argv.push_back(command_line_args[i]);
- else {
- if (++i < num_command_line_args) // Skip "-o"...
- i++; // ...and the following argument as well.
+
+ // Process the compiler options, stripping off '-o', '-c', '-fsyntax-only'.
+ for (int i = 0; i < num_command_line_args; ++i)
+ if (const char *arg = command_line_args[i]) {
+ if (strcmp(arg, "-o") == 0) {
+ ++i; // Also skip the matching argument.
+ continue;
+ }
+ if (strcmp(arg, "-emit-ast") == 0 ||
+ strcmp(arg, "-c") == 0 ||
+ strcmp(arg, "-fsyntax-only") == 0) {
+ continue;
+ }
+
+ // Keep the argument.
+ argv.push_back(arg);
}
- }
+
+ // Add the null terminator.
argv.push_back(NULL);
#ifndef LLVM_ON_WIN32
More information about the cfe-commits
mailing list