Flatten the aligned-char-array utility template to be a directly
[oota-llvm.git] / include / llvm / Support / SMLoc.h
index fb86ee79b2e09b04896d66cae527306e312f288b..1bf810b4aaf2f2e03ed30e4d28c7988b22592654 100644 (file)
@@ -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
 //
 #ifndef SUPPORT_SMLOC_H
 #define SUPPORT_SMLOC_H
 
+#include <cassert>
+
 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