diff options
author | Daniel Dunbar <daniel@zuster.org> | 2009-12-03 05:11:05 +0000 |
---|---|---|
committer | Daniel Dunbar <daniel@zuster.org> | 2009-12-03 05:11:05 +0000 |
commit | da7a52289fbdd02923e24b21c5b73ab7eef42ae6 (patch) | |
tree | afcdf580a79b9481699dddced35787a743a5afda /clang | |
parent | 4039f35344be462f88d97fac332fc54c95146a8c (diff) | |
download | bcm5719-llvm-da7a52289fbdd02923e24b21c5b73ab7eef42ae6.tar.gz bcm5719-llvm-da7a52289fbdd02923e24b21c5b73ab7eef42ae6.zip |
Add clang -cc1 -load option.
llvm-svn: 90413
Diffstat (limited to 'clang')
-rw-r--r-- | clang/include/clang/Basic/DiagnosticFrontendKinds.td | 2 | ||||
-rw-r--r-- | clang/include/clang/Driver/CC1Options.td | 2 | ||||
-rw-r--r-- | clang/include/clang/Frontend/FrontendOptions.h | 3 | ||||
-rw-r--r-- | clang/lib/Frontend/CompilerInvocation.cpp | 5 | ||||
-rw-r--r-- | clang/tools/clang-cc/clang-cc.cpp | 13 |
5 files changed, 24 insertions, 1 deletions
diff --git a/clang/include/clang/Basic/DiagnosticFrontendKinds.td b/clang/include/clang/Basic/DiagnosticFrontendKinds.td index c36d1c442ba..fa34caccf57 100644 --- a/clang/include/clang/Basic/DiagnosticFrontendKinds.td +++ b/clang/include/clang/Basic/DiagnosticFrontendKinds.td @@ -39,6 +39,8 @@ def err_fe_remap_missing_from_file : Error< "could not remap from missing file '%0'">, DefaultFatal; def err_fe_unable_to_load_pch : Error< "unable to load PCH file">; +def err_fe_unable_to_load_plugin : Error< + "unable to load plugin '%0': '%1'">; def err_verify_bogus_characters : Error< "bogus characters before '{{' in expected string">; diff --git a/clang/include/clang/Driver/CC1Options.td b/clang/include/clang/Driver/CC1Options.td index b34fe0340a5..74aa11b3423 100644 --- a/clang/include/clang/Driver/CC1Options.td +++ b/clang/include/clang/Driver/CC1Options.td @@ -205,6 +205,8 @@ def cxx_inheritance_view : Separate<"-cxx-inheritance-view">, def fixit_at : Separate<"-fixit-at">, MetaVarName<"source-location">, HelpText<"Perform Fix-It modifications at the given source location">; def o : Separate<"-o">, MetaVarName<"path">, HelpText<"Specify output file">; +def load : Separate<"-load">, MetaVarName<"dsopath">, + HelpText<"Load the named plugin (dynamic shared object)">; def plugin : Separate<"-plugin">, HelpText<"Use the named plugin action (use \"help\" to list available options)">; diff --git a/clang/include/clang/Frontend/FrontendOptions.h b/clang/include/clang/Frontend/FrontendOptions.h index c1ec8e70f1c..ce60941534d 100644 --- a/clang/include/clang/Frontend/FrontendOptions.h +++ b/clang/include/clang/Frontend/FrontendOptions.h @@ -105,6 +105,9 @@ public: /// The name of the action to run when using a plugin action. std::string ActionName; + /// The list of plugins to load. + std::vector<std::string> Plugins; + public: FrontendOptions() { DebugCodeCompletionPrinter = 1; diff --git a/clang/lib/Frontend/CompilerInvocation.cpp b/clang/lib/Frontend/CompilerInvocation.cpp index 761bae9e641..3e6f9cbd852 100644 --- a/clang/lib/Frontend/CompilerInvocation.cpp +++ b/clang/lib/Frontend/CompilerInvocation.cpp @@ -345,6 +345,10 @@ static void FrontendOptsToArgs(const FrontendOptions &Opts, Res.push_back("-plugin"); Res.push_back(Opts.ActionName); } + for (unsigned i = 0, e = Opts.Plugins.size(); i != e; ++i) { + Res.push_back("-load"); + Res.push_back(Opts.Plugins[i]); + } } static void HeaderSearchOptsToArgs(const HeaderSearchOptions &Opts, @@ -877,6 +881,7 @@ ParseFrontendArgs(FrontendOptions &Opts, ArgList &Args, Diagnostic &Diags) { } Opts.OutputFile = getLastArgValue(Args, OPT_o); + Opts.Plugins = getAllArgValues(Args, OPT_load); Opts.RelocatablePCH = Args.hasArg(OPT_relocatable_pch); Opts.ShowMacrosInCodeCompletion = Args.hasArg(OPT_code_completion_macros); Opts.ShowStats = Args.hasArg(OPT_print_stats); diff --git a/clang/tools/clang-cc/clang-cc.cpp b/clang/tools/clang-cc/clang-cc.cpp index 2899684284a..b189b4b51d6 100644 --- a/clang/tools/clang-cc/clang-cc.cpp +++ b/clang/tools/clang-cc/clang-cc.cpp @@ -42,6 +42,7 @@ #include "llvm/Support/PrettyStackTrace.h" #include "llvm/Support/Timer.h" #include "llvm/Support/raw_ostream.h" +#include "llvm/System/DynamicLibrary.h" #include "llvm/System/Host.h" #include "llvm/System/Path.h" #include "llvm/System/Signals.h" @@ -299,7 +300,8 @@ int main(int argc, char **argv) { Clang.getDiagnostics(), argv[0])) return 1; #else - // Buffer diagnostics from argument parsing. + // Buffer diagnostics from argument parsing so that we can output them using a + // well formed diagnostic object. TextDiagnosticBuffer DiagsBuffer; Diagnostic Diags(&DiagsBuffer); @@ -321,6 +323,15 @@ int main(int argc, char **argv) { DiagsBuffer.FlushDiagnostics(Clang.getDiagnostics()); + // Load any requested plugins. + for (unsigned i = 0, + e = Clang.getFrontendOpts().Plugins.size(); i != e; ++i) { + const std::string &Path = Clang.getFrontendOpts().Plugins[i]; + std::string Error; + if (llvm::sys::DynamicLibrary::LoadLibraryPermanently(Path.c_str(), &Error)) + Diags.Report(diag::err_fe_unable_to_load_plugin) << Path << Error; + } + // If there were any errors in processing arguments, exit now. if (Clang.getDiagnostics().getNumErrors()) return 1; |