diff options
-rw-r--r-- | include/clang/AST/Decl.h | 9 | ||||
-rw-r--r-- | lib/AST/Decl.cpp | 5 |
2 files changed, 13 insertions, 1 deletions
diff --git a/include/clang/AST/Decl.h b/include/clang/AST/Decl.h index 0de85dcefc..d033c24046 100644 --- a/include/clang/AST/Decl.h +++ b/include/clang/AST/Decl.h @@ -1150,7 +1150,9 @@ private: /// TypedefForAnonDecl - If a TagDecl is anonymous and part of a typedef, /// this points to the TypedefDecl. Used for mangling. TypedefDecl *TypedefForAnonDecl; - + + SourceLocation RBraceLoc; + protected: TagDecl(Kind DK, TagKind TK, DeclContext *DC, SourceLocation L, IdentifierInfo *Id) @@ -1161,6 +1163,11 @@ protected: } public: + SourceLocation getRBraceLoc() const { return RBraceLoc; } + void setRBraceLoc(SourceLocation L) { RBraceLoc = L; } + + virtual SourceRange getSourceRange() const; + /// isDefinition - Return true if this decl has its body specified. bool isDefinition() const { return IsDefinition; diff --git a/lib/AST/Decl.cpp b/lib/AST/Decl.cpp index 40aa030ab3..fe9885ef26 100644 --- a/lib/AST/Decl.cpp +++ b/lib/AST/Decl.cpp @@ -658,6 +658,11 @@ void FunctionDecl::setExplicitSpecialization(bool ES) { // TagDecl Implementation //===----------------------------------------------------------------------===// +SourceRange TagDecl::getSourceRange() const { + SourceLocation E = RBraceLoc.isValid() ? RBraceLoc : getLocation(); + return SourceRange(getLocation(), E); +} + void TagDecl::startDefinition() { TagType *TagT = const_cast<TagType *>(TypeForDecl->getAsTagType()); TagT->decl.setPointer(this); |