X-Git-Url: http://demsky.eecs.uci.edu/git/?a=blobdiff_plain;f=include%2Fllvm%2FSupport%2FSMLoc.h;h=1bf810b4aaf2f2e03ed30e4d28c7988b22592654;hb=cbeb8d9869aafec3c2c1ee0922f0a4d5bb4a916a;hp=fb86ee79b2e09b04896d66cae527306e312f288b;hpb=1ae486a4a06a5132c094b9ce66836ff081fea3a6;p=oota-llvm.git diff --git a/include/llvm/Support/SMLoc.h b/include/llvm/Support/SMLoc.h index fb86ee79b2e..1bf810b4aaf 100644 --- a/include/llvm/Support/SMLoc.h +++ b/include/llvm/Support/SMLoc.h @@ -1,4 +1,4 @@ -//===- SMLoc.h - Manager for Source Buffers & Diagnostics -------*- C++ -*-===// +//===- SMLoc.h - Source location for use with diagnostics -------*- C++ -*-===// // // The LLVM Compiler Infrastructure // @@ -15,22 +15,23 @@ #ifndef SUPPORT_SMLOC_H #define SUPPORT_SMLOC_H +#include + namespace llvm { -// SMLoc - Represents a location in source code. -class SMLoc { +/// SMLoc - Represents a location in source code. +class SMLoc { const char *Ptr; public: SMLoc() : Ptr(0) {} - SMLoc(const SMLoc &RHS) : Ptr(RHS.Ptr) {} - + bool isValid() const { return Ptr != 0; } - + bool operator==(const SMLoc &RHS) const { return RHS.Ptr == Ptr; } bool operator!=(const SMLoc &RHS) const { return RHS.Ptr != Ptr; } - + const char *getPointer() const { return Ptr; } - + static SMLoc getFromPointer(const char *Ptr) { SMLoc L; L.Ptr = Ptr; @@ -38,6 +39,23 @@ public: } }; -} +/// SMRange - Represents a range in source code. Note that unlike standard STL +/// ranges, the locations specified are considered to be *inclusive*. For +/// example, [X,X] *does* include X, it isn't an empty range. +class SMRange { +public: + SMLoc Start, End; + + SMRange() {} + SMRange(SMLoc St, SMLoc En) : Start(St), End(En) { + assert(Start.isValid() == End.isValid() && + "Start and end should either both be valid or both be invalid!"); + } + + bool isValid() const { return Start.isValid(); } +}; + +} // end namespace llvm + +#endif -#endif \ No newline at end of file