[llvm-commits] [llvm] r75796 - in /llvm/trunk: include/llvm/Support/SystemUtils.h lib/Support/SystemUtils.cpp

Dan Gohman gohman at apple.com
Wed Jul 15 10:04:51 PDT 2009


Author: djg
Date: Wed Jul 15 12:04:50 2009
New Revision: 75796

URL: http://llvm.org/viewvc/llvm-project?rev=75796&view=rev
Log:
Add a raw_ostream version of CheckBitcodeOutputToConsole.

Modified:
    llvm/trunk/include/llvm/Support/SystemUtils.h
    llvm/trunk/lib/Support/SystemUtils.cpp

Modified: llvm/trunk/include/llvm/Support/SystemUtils.h
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/include/llvm/Support/SystemUtils.h?rev=75796&r1=75795&r2=75796&view=diff

==============================================================================
--- llvm/trunk/include/llvm/Support/SystemUtils.h (original)
+++ llvm/trunk/include/llvm/Support/SystemUtils.h Wed Jul 15 12:04:50 2009
@@ -29,6 +29,16 @@
   bool print_warning = true ///< Control whether warnings are printed
 );
 
+/// Determine if the raw_ostream provided is connected to the outs() and
+/// displayed or not (to a console window). If so, generate a warning message
+/// advising against display of bitcode and return true. Otherwise just return
+/// false
+/// @brief Check for output written to a console
+bool CheckBitcodeOutputToConsole(
+  raw_ostream* stream_to_check, ///< The stream to be checked
+  bool print_warning = true ///< Control whether warnings are printed
+);
+
 /// FindExecutable - Find a named executable, giving the argv[0] of program
 /// being executed. This allows us to find another LLVM tool if it is built into
 /// the same directory, but that directory is neither the current directory, nor

Modified: llvm/trunk/lib/Support/SystemUtils.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Support/SystemUtils.cpp?rev=75796&r1=75795&r2=75796&view=diff

==============================================================================
--- llvm/trunk/lib/Support/SystemUtils.cpp (original)
+++ llvm/trunk/lib/Support/SystemUtils.cpp Wed Jul 15 12:04:50 2009
@@ -19,6 +19,21 @@
 #include <ostream>
 using namespace llvm;
 
+bool llvm::CheckBitcodeOutputToConsole(raw_ostream* stream_to_check,
+                                       bool print_warning) {
+  if (stream_to_check == &outs() &&
+      sys::Process::StandardOutIsDisplayed()) {
+    if (print_warning) {
+      cerr << "WARNING: You're attempting to print out a bitcode file.\n"
+           << "This is inadvisable as it may cause display problems. If\n"
+           << "you REALLY want to taste LLVM bitcode first-hand, you\n"
+           << "can force output with the `-f' option.\n\n";
+    }
+    return true;
+  }
+  return false;
+}
+
 bool llvm::CheckBitcodeOutputToConsole(std::ostream* stream_to_check,
                                        bool print_warning) {
   if (stream_to_check == cout.stream() &&





More information about the llvm-commits mailing list