summaryrefslogtreecommitdiff
path: root/utils/TableGen/ClangDiagnosticsEmitter.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2009-04-15 20:13:18 +0000
committerChris Lattner <sabre@nondot.org>2009-04-15 20:13:18 +0000
commit457cde4d45816b3db7649c5faabd70a524963b1f (patch)
tree07fdbdd633b78597e5bdfb4e4a4f6afaa8b2681d /utils/TableGen/ClangDiagnosticsEmitter.cpp
parentd7fd2126c248f5887954cfd5ee6628f3a4cf4a9b (diff)
downloadllvm-457cde4d45816b3db7649c5faabd70a524963b1f.tar.gz
llvm-457cde4d45816b3db7649c5faabd70a524963b1f.tar.bz2
llvm-457cde4d45816b3db7649c5faabd70a524963b1f.tar.xz
use escape string.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@69212 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'utils/TableGen/ClangDiagnosticsEmitter.cpp')
-rw-r--r--utils/TableGen/ClangDiagnosticsEmitter.cpp19
1 files changed, 6 insertions, 13 deletions
diff --git a/utils/TableGen/ClangDiagnosticsEmitter.cpp b/utils/TableGen/ClangDiagnosticsEmitter.cpp
index 38c4eeb39d..5a5f4795c2 100644
--- a/utils/TableGen/ClangDiagnosticsEmitter.cpp
+++ b/utils/TableGen/ClangDiagnosticsEmitter.cpp
@@ -16,8 +16,9 @@
#include "llvm/Support/Debug.h"
#include "llvm/Support/Compiler.h"
#include "llvm/Support/Streams.h"
-#include "llvm/ADT/VectorExtras.h"
#include "llvm/ADT/DenseSet.h"
+#include "llvm/ADT/StringExtras.h"
+#include "llvm/ADT/VectorExtras.h"
#include <set>
#include <map>
using namespace llvm;
@@ -39,15 +40,6 @@ static const RecordVal* findRecordVal(const Record& R, const std::string &key) {
return 0;
}
-static void EmitEscaped(std::ostream& OS, const std::string &s) {
- for (std::string::const_iterator I=s.begin(), E=s.end(); I!=E; ++I)
- switch (*I) {
- default: OS << *I; break;
- case '\"': OS << "\\" << *I; break;
- case '\\': OS << "\\\\"; break;
- }
-}
-
static void EmitAllCaps(std::ostream& OS, const std::string &s) {
for (std::string::const_iterator I=s.begin(), E=s.end(); I!=E; ++I)
OS << char(toupper(*I));
@@ -63,8 +55,9 @@ static void ProcessDiag(std::ostream &OS, const Record *DiagClass,
OS << R.getValueAsDef("Class")->getName();
OS << ", diag::" << R.getValueAsDef("DefaultMapping")->getName();
OS << ", \"";
- EmitEscaped(OS, R.getValueAsString("Text"));
- OS << "\")\n";
+ std::string S = R.getValueAsString("Text");
+ EscapeString(S);
+ OS << S << "\")\n";
}
void ClangDiagsDefsEmitter::run(std::ostream &OS) {
@@ -168,7 +161,7 @@ static void BuildGroup(DiagnosticSet& DS, VisitedLists &Visited,
void ClangDiagGroupsEmitter::run(std::ostream &OS) {
// Build up a map from options to controlled diagnostics.
OptionMap OM;
-
+
const RecordVector &Opts = Records.getAllDerivedDefinitions("Option");
for (RecordVector::const_iterator I=Opts.begin(), E=Opts.end(); I != E; ++I)
if (const RecordVal* V = findRecordVal(**I, "Members"))