[cfe-commits] r76107 - in /cfe/trunk: test/Driver/qa_override.c tools/driver/driver.cpp

Daniel Dunbar daniel at zuster.org
Thu Jul 16 14:32:52 PDT 2009


Author: ddunbar
Date: Thu Jul 16 16:32:51 2009
New Revision: 76107

URL: http://llvm.org/viewvc/llvm-project?rev=76107&view=rev
Log:
[llvm up] Add support for '#' component of QA_OVERRIDE_GCC3_OPTIONS.
 - This silences the output about how command line arguments are being changed.

Modified:
    cfe/trunk/test/Driver/qa_override.c
    cfe/trunk/tools/driver/driver.cpp

Modified: cfe/trunk/test/Driver/qa_override.c
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/Driver/qa_override.c?rev=76107&r1=76106&r2=76107&view=diff

==============================================================================
--- cfe/trunk/test/Driver/qa_override.c (original)
+++ cfe/trunk/test/Driver/qa_override.c Thu Jul 16 16:32:51 2009
@@ -1,4 +1,5 @@
-// RUN: env QA_OVERRIDE_GCC3_OPTIONS="+-Os +-Oz +-O +-O3 +-Oignore +a +b +c xb Xa Omagic ^-ccc-print-options  " clang x -O2 b -O3 2> %t &&
+// RUN: env QA_OVERRIDE_GCC3_OPTIONS="#+-Os +-Oz +-O +-O3 +-Oignore +a +b +c xb Xa Omagic ^-ccc-print-options  " clang x -O2 b -O3 2> %t &&
+// RUN: grep '### ' %t | count 0 &&
 // RUN: grep -F 'Option 0 - Name: "<input>", Values: {"x"}' %t &&
 // RUN: grep -F 'Option 1 - Name: "-O", Values: {"ignore"}' %t &&
 // RUN: grep -F 'Option 2 - Name: "-O", Values: {"magic"}' %t &&

Modified: cfe/trunk/tools/driver/driver.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/tools/driver/driver.cpp?rev=76107&r1=76106&r2=76107&view=diff

==============================================================================
--- cfe/trunk/tools/driver/driver.cpp (original)
+++ cfe/trunk/tools/driver/driver.cpp Thu Jul 16 16:32:51 2009
@@ -79,6 +79,8 @@
 /// they are applied in order to the input argument lists. Edits
 /// should be one of the following forms:
 ///
+///  '#': Silence information about the changes to the command line arguments.
+///
 ///  '^': Add FOO as a new argument at the beginning of the command line.
 ///
 ///  '+': Add FOO as a new argument at the end of the command line.
@@ -93,7 +95,13 @@
 ///
 ///  'Ox': Removes all flags matching 'O' or 'O[sz0-9]' and adds 'Ox'
 ///  at the end of the command line.
-void ApplyOneQAOverride(std::vector<const char*> &Args, 
+///
+/// \param OS - The stream to write edit information to.
+/// \param Args - The vector of command line arguments.
+/// \param Edit - The override command to perform.
+/// \param SavedStrings - Set to use for storing string representations.
+void ApplyOneQAOverride(llvm::raw_ostream &OS,
+                        std::vector<const char*> &Args, 
                         const std::string &Edit,
                         std::set<std::string> &SavedStrings) {
   // This does not need to be efficient.
@@ -101,25 +109,25 @@
    if (Edit[0] == '^') {
      const char *Str = 
        SaveStringInSet(SavedStrings, Edit.substr(1, std::string::npos));
-     llvm::errs() << "### Adding argument " << Str << " at beginning\n";
+     OS << "### Adding argument " << Str << " at beginning\n";
      Args.insert(Args.begin() + 1, Str);
    } else if (Edit[0] == '+') {
      const char *Str = 
        SaveStringInSet(SavedStrings, Edit.substr(1, std::string::npos));
-     llvm::errs() << "### Adding argument " << Str << " at end\n";
+     OS << "### Adding argument " << Str << " at end\n";
      Args.push_back(Str);
    } else if (Edit[0] == 'x' || Edit[0] == 'X') {
      std::string Option = Edit.substr(1, std::string::npos);
      for (unsigned i = 1; i < Args.size();) {
        if (Option == Args[i]) {
-         llvm::errs() << "### Deleting argument " << Args[i] << '\n';
+         OS << "### Deleting argument " << Args[i] << '\n';
          Args.erase(Args.begin() + i);
          if (Edit[0] == 'X') {
            if (i < Args.size()) {
-             llvm::errs() << "### Deleting argument " << Args[i] << '\n';
+             OS << "### Deleting argument " << Args[i] << '\n';
              Args.erase(Args.begin() + i);
            } else
-             llvm::errs() << "### Invalid X edit, end of command line!\n";
+             OS << "### Invalid X edit, end of command line!\n";
          }
        } else
          ++i;
@@ -131,15 +139,15 @@
            (A[2] == '\0' || 
             (A[3] == '\0' && (A[2] == 's' || A[2] == 'z' ||
                               ('0' <= A[2] && A[2] <= '9'))))) {
-         llvm::errs() << "### Deleting argument " << Args[i] << '\n';
+         OS << "### Deleting argument " << Args[i] << '\n';
          Args.erase(Args.begin() + i);
        } else
          ++i;
      }     
-     llvm::errs() << "### Adding argument " << Edit << " at end\n";
+     OS << "### Adding argument " << Edit << " at end\n";
      Args.push_back(SaveStringInSet(SavedStrings, '-' + Edit));
    } else {
-     llvm::errs() << "### Unrecognized edit: " << Edit << "\n";
+     OS << "### Unrecognized edit: " << Edit << "\n";
    }
 }
 
@@ -147,7 +155,14 @@
 /// input argument lists. See ApplyOneQAOverride.
 void ApplyQAOverride(std::vector<const char*> &Args, const char *OverrideStr,
                      std::set<std::string> &SavedStrings) {
-  llvm::errs() << "### QA_OVERRIDE_GCC3_OPTIONS: " << OverrideStr << "\n";
+  llvm::raw_ostream *OS = &llvm::errs();
+  
+  if (OverrideStr[0] == '#') {
+    ++OverrideStr;
+    OS = &llvm::nulls();
+  }
+
+  *OS << "### QA_OVERRIDE_GCC3_OPTIONS: " << OverrideStr << "\n";
 
   // This does not need to be efficient.
 
@@ -157,7 +172,7 @@
     if (!End)
       End = S + strlen(S);
     if (End != S)
-      ApplyOneQAOverride(Args, std::string(S, End), SavedStrings);
+      ApplyOneQAOverride(*OS, Args, std::string(S, End), SavedStrings);
     S = End;
     if (*S != '\0')
       ++S;





More information about the cfe-commits mailing list