diff options
author | Abramo Bagnara <abramo.bagnara@gmail.com> | 2010-05-21 21:12:12 +0000 |
---|---|---|
committer | Abramo Bagnara <abramo.bagnara@gmail.com> | 2010-05-21 21:12:12 +0000 |
commit | e4aec0eae303e926643c7239cf7b0197ea9f63e2 (patch) | |
tree | 50d7d4f89fcd404596a043a87c7ecf6833fa2fd6 | |
parent | a4b46ccb04ea24d17eaeecdcff149e4eb664d000 (diff) |
Improved TypeLoc::getSourceRange().
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@104382 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | include/clang/AST/TypeLoc.h | 15 | ||||
-rw-r--r-- | lib/AST/TypeLoc.cpp | 36 |
2 files changed, 43 insertions, 8 deletions
diff --git a/include/clang/AST/TypeLoc.h b/include/clang/AST/TypeLoc.h index 0a3a5d45a5..f988f0e33b 100644 --- a/include/clang/AST/TypeLoc.h +++ b/include/clang/AST/TypeLoc.h @@ -85,16 +85,15 @@ public: return Data; } + /// \brief Get the begin source location. + SourceLocation getBeginLoc() const; + + /// \brief Get the end source location. + SourceLocation getEndLoc() const; + /// \brief Get the full source range. SourceRange getSourceRange() const { - SourceLocation End = getLocalSourceRange().getEnd(); - TypeLoc Cur = *this; - while (true) { - TypeLoc Next = Cur.getNextTypeLoc(); - if (Next.isNull()) break; - Cur = Next; - } - return SourceRange(Cur.getLocalSourceRange().getBegin(), End); + return SourceRange(getBeginLoc(), getEndLoc()); } /// \brief Get the local source range. diff --git a/lib/AST/TypeLoc.cpp b/lib/AST/TypeLoc.cpp index 678a0f0475..4893b384dd 100644 --- a/lib/AST/TypeLoc.cpp +++ b/lib/AST/TypeLoc.cpp @@ -108,6 +108,42 @@ void TypeLoc::initializeImpl(TypeLoc TL, SourceLocation Loc) { } } +SourceLocation TypeLoc::getBeginLoc() const { + TypeLoc Cur = *this; + while (true) { + switch (Cur.getTypeLocClass()) { + // FIXME: Currently QualifiedTypeLoc does not have a source range + // case Qualified: + case Elaborated: + break; + default: + TypeLoc Next = Cur.getNextTypeLoc(); + if (Next.isNull()) break; + Cur = Next; + continue; + } + break; + } + return Cur.getLocalSourceRange().getBegin(); +} + +SourceLocation TypeLoc::getEndLoc() const { + TypeLoc Cur = *this; + while (true) { + switch (Cur.getTypeLocClass()) { + default: + break; + case Qualified: + case Elaborated: + Cur = Cur.getNextTypeLoc(); + continue; + } + break; + } + return Cur.getLocalSourceRange().getEnd(); +} + + namespace { struct TSTChecker : public TypeLocVisitor<TSTChecker, bool> { // Overload resolution does the real work for us. |