diff options
author | Chris Lattner <sabre@nondot.org> | 2009-03-05 08:00:35 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2009-03-05 08:00:35 +0000 |
commit | eae6cb6154b290c0cb8ce51ed321a4ceade261fc (patch) | |
tree | 77eb3799583bb3afd7cd3bde36912006ad5675c9 /clang/lib/AST/DeclBase.cpp | |
parent | 1d09f6a2212b69be02fc03d818dcd02620fea4d4 (diff) | |
download | bcm5719-llvm-eae6cb6154b290c0cb8ce51ed321a4ceade261fc.tar.gz bcm5719-llvm-eae6cb6154b290c0cb8ce51ed321a4ceade261fc.zip |
rename PrettyStackTraceDecl -> PrettyStackTraceActionsDecl.
Introduce a new PrettyStackTraceDecl.
Use it to add the top level LLVM IR generation stuff in
Backend.cpp to stack traces. We now get crashes like:
Stack dump:
0. Program arguments: clang t.c -emit-llvm
1. <eof> parser at end of file
2. t.c:1:5: LLVM IR generation of declaration 'a'
Abort
for IR generation crashes.
llvm-svn: 66153
Diffstat (limited to 'clang/lib/AST/DeclBase.cpp')
-rw-r--r-- | clang/lib/AST/DeclBase.cpp | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/clang/lib/AST/DeclBase.cpp b/clang/lib/AST/DeclBase.cpp index 3e968c78962..1e7ef549b43 100644 --- a/clang/lib/AST/DeclBase.cpp +++ b/clang/lib/AST/DeclBase.cpp @@ -19,6 +19,7 @@ #include "clang/AST/ASTContext.h" #include "clang/AST/Type.h" #include "llvm/ADT/DenseMap.h" +#include "llvm/Support/raw_ostream.h" #include <algorithm> #include <cstdio> #include <functional> @@ -92,6 +93,27 @@ void Decl::addDeclKind(Kind k) { } //===----------------------------------------------------------------------===// +// PrettyStackTraceDecl Implementation +//===----------------------------------------------------------------------===// + +void PrettyStackTraceDecl::print(llvm::raw_ostream &OS) const { + SourceLocation TheLoc = Loc; + if (TheLoc.isInvalid() && TheDecl) + TheLoc = TheDecl->getLocation(); + + if (TheLoc.isValid()) { + TheLoc.print(OS, SM); + OS << ": "; + } + + OS << Message; + + if (NamedDecl *DN = dyn_cast_or_null<NamedDecl>(TheDecl)) + OS << " '" << DN->getQualifiedNameAsString() << '\''; + OS << '\n'; +} + +//===----------------------------------------------------------------------===// // Decl Implementation //===----------------------------------------------------------------------===// |