blob: d8607034ee86d90a81f47d5e87a48d8b81f71066 [file] [log] [blame]
Andrew Scull5e1ddfa2018-08-14 10:06:54 +01001//===- SMLoc.h - Source location for use with diagnostics -------*- C++ -*-===//
2//
Andrew Walbran16937d02019-10-22 13:54:20 +01003// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
Andrew Scull5e1ddfa2018-08-14 10:06:54 +01006//
7//===----------------------------------------------------------------------===//
8//
9// This file declares the SMLoc class. This class encapsulates a location in
10// source code for use in diagnostics.
11//
12//===----------------------------------------------------------------------===//
13
14#ifndef LLVM_SUPPORT_SMLOC_H
15#define LLVM_SUPPORT_SMLOC_H
16
17#include "llvm/ADT/None.h"
18#include <cassert>
19
20namespace llvm {
21
22/// Represents a location in source code.
23class SMLoc {
24 const char *Ptr = nullptr;
25
26public:
27 SMLoc() = default;
28
29 bool isValid() const { return Ptr != nullptr; }
30
31 bool operator==(const SMLoc &RHS) const { return RHS.Ptr == Ptr; }
32 bool operator!=(const SMLoc &RHS) const { return RHS.Ptr != Ptr; }
33
34 const char *getPointer() const { return Ptr; }
35
36 static SMLoc getFromPointer(const char *Ptr) {
37 SMLoc L;
38 L.Ptr = Ptr;
39 return L;
40 }
41};
42
43/// Represents a range in source code.
44///
45/// SMRange is implemented using a half-open range, as is the convention in C++.
Andrew Scullcdfcccc2018-10-05 20:58:37 +010046/// In the string "abc", the range [1,3) represents the substring "bc", and the
47/// range [2,2) represents an empty range between the characters "b" and "c".
Andrew Scull5e1ddfa2018-08-14 10:06:54 +010048class SMRange {
49public:
50 SMLoc Start, End;
51
52 SMRange() = default;
53 SMRange(NoneType) {}
54 SMRange(SMLoc St, SMLoc En) : Start(St), End(En) {
55 assert(Start.isValid() == End.isValid() &&
Andrew Scullcdfcccc2018-10-05 20:58:37 +010056 "Start and End should either both be valid or both be invalid!");
Andrew Scull5e1ddfa2018-08-14 10:06:54 +010057 }
58
59 bool isValid() const { return Start.isValid(); }
60};
61
62} // end namespace llvm
63
64#endif // LLVM_SUPPORT_SMLOC_H