Token.h revision 014e88d94ff83e3aad4e33b16413a2d1817ec208
1d217773f106856a11879ec79dc468efefaf2ee75Chris Lattner//===--- Token.h - Token interface ------------------------------*- C++ -*-===//
25f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//
35f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//                     The LLVM Compiler Infrastructure
45f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//
50bc735ffcfb223c0186419547abaa5c84482663eChris Lattner// This file is distributed under the University of Illinois Open Source
60bc735ffcfb223c0186419547abaa5c84482663eChris Lattner// License. See LICENSE.TXT for details.
75f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//
85f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//===----------------------------------------------------------------------===//
95f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//
10d217773f106856a11879ec79dc468efefaf2ee75Chris Lattner//  This file defines the Token interface.
115f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//
125f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//===----------------------------------------------------------------------===//
135f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
14d217773f106856a11879ec79dc468efefaf2ee75Chris Lattner#ifndef LLVM_CLANG_TOKEN_H
15d217773f106856a11879ec79dc468efefaf2ee75Chris Lattner#define LLVM_CLANG_TOKEN_H
165f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
1739a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor#include "clang/Basic/TemplateKinds.h"
185f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer#include "clang/Basic/TokenKinds.h"
195f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer#include "clang/Basic/SourceLocation.h"
20014e88d94ff83e3aad4e33b16413a2d1817ec208Douglas Gregor#include "clang/Basic/OperatorKinds.h"
21ac1afdc58e6ad5c969f45fd2ff6d140d3b4dd862Douglas Gregor#include <cstdlib>
225f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
235f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencernamespace clang {
245f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
255f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencerclass IdentifierInfo;
265f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
27d217773f106856a11879ec79dc468efefaf2ee75Chris Lattner/// Token - This structure provides full information about a lexed token.
285f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// It is not intended to be space efficient, it is intended to return as much
295f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// information as possible about each returned token.  This is expected to be
305f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// compressed into a smaller form if memory footprint is important.
313604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis///
323604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis/// The parser can create a special "annotation token" representing a stream of
333604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis/// tokens that were parsed and semantically resolved, e.g.: "foo::MyClass<int>"
343604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis/// can be represented by a single typename annotation token that carries
353604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis/// information about the SourceRange of the tokens and the type object.
36d217773f106856a11879ec79dc468efefaf2ee75Chris Lattnerclass Token {
373604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis  /// The location of the token.
385f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  SourceLocation Loc;
393604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis
4047246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  // Conceptually these next two fields could be in a union.  However, this
4147246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  // causes gcc 4.2 to pessimize LexTokenInternal, a very performance critical
4247246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  // routine. Keeping as separate members with casts until a more beautiful fix
4347246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  // presents itself.
44b28d6de75e0cb27ce3106ce6052f87ad0ab276d7Daniel Dunbar
45b28d6de75e0cb27ce3106ce6052f87ad0ab276d7Daniel Dunbar  /// UintData - This holds either the length of the token text, when
46b28d6de75e0cb27ce3106ce6052f87ad0ab276d7Daniel Dunbar  /// a normal token, or the end of the SourceRange when an annotation
47b28d6de75e0cb27ce3106ce6052f87ad0ab276d7Daniel Dunbar  /// token.
48b28d6de75e0cb27ce3106ce6052f87ad0ab276d7Daniel Dunbar  unsigned UintData;
49b28d6de75e0cb27ce3106ce6052f87ad0ab276d7Daniel Dunbar
5047246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  /// PtrData - This is a union of four different pointer types, which depends
5147246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  /// on what type of token this is:
5247246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  ///  Identifiers, keywords, etc:
5347246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  ///    This is an IdentifierInfo*, which contains the uniqued identifier
5447246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  ///    spelling.
5547246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  ///  Literals:  isLiteral() returns true.
5647246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  ///    This is a pointer to the start of the token in a text buffer, which
5747246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  ///    may be dirty (have trigraphs / escaped newlines).
5847246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  ///  Annotations (resolved type names, C++ scopes, etc): isAnnotation().
5947246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  ///    This is a pointer to sema-specific data for the annotation token.
6047246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  ///  Other:
6147246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  ///    This is null.
62b28d6de75e0cb27ce3106ce6052f87ad0ab276d7Daniel Dunbar  void *PtrData;
635f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
645f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// Kind - The actual flavor of token this is.
655f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  ///
661eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump  unsigned Kind : 8;  // DON'T make Kind a 'tok::TokenKind';
678e748ab52395328f2905855b295a22e33dc800b2Ted Kremenek                      // MSVC will treat it as a signed char and
688e748ab52395328f2905855b295a22e33dc800b2Ted Kremenek                      // TokenKinds > 127 won't be handled correctly.
691eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
705f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// Flags - Bits we track about this token, members of the TokenFlags enum.
715f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  unsigned Flags : 8;
725f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencerpublic:
731eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
745f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  // Various flags set per token:
755f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  enum TokenFlags {
765f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    StartOfLine   = 0x01,  // At start of line or only after whitespace.
775f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    LeadingSpace  = 0x02,  // Whitespace exists before this token.
785f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    DisableExpand = 0x04,  // This identifier may never be macro expanded.
795f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    NeedsCleaning = 0x08   // Contained an escaped newline or trigraph.
805f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  };
815f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
828e748ab52395328f2905855b295a22e33dc800b2Ted Kremenek  tok::TokenKind getKind() const { return (tok::TokenKind)Kind; }
835f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  void setKind(tok::TokenKind K) { Kind = K; }
841eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
85000732226610650837478cba97843d19b75f648eChris Lattner  /// is/isNot - Predicates to check if this token is a specific kind, as in
86000732226610650837478cba97843d19b75f648eChris Lattner  /// "if (Tok.is(tok::l_brace)) {...}".
878e748ab52395328f2905855b295a22e33dc800b2Ted Kremenek  bool is(tok::TokenKind K) const { return Kind == (unsigned) K; }
888e748ab52395328f2905855b295a22e33dc800b2Ted Kremenek  bool isNot(tok::TokenKind K) const { return Kind != (unsigned) K; }
895f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
9047246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  /// isLiteral - Return true if this is a "literal", like a numeric
9147246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  /// constant, string, etc.
9247246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  bool isLiteral() const {
9347246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner    return is(tok::numeric_constant) || is(tok::char_constant) ||
9447246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner           is(tok::string_literal) || is(tok::wide_string_literal) ||
9547246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner           is(tok::angle_string_literal);
9647246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  }
9747246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner
981eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump  bool isAnnotation() const {
991eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump    return is(tok::annot_typename) ||
100d6fb7ef028d9aa0b3e8943b7bc049c524437b407Douglas Gregor           is(tok::annot_cxxscope) ||
101d6fb7ef028d9aa0b3e8943b7bc049c524437b407Douglas Gregor           is(tok::annot_template_id);
1023604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis  }
1031eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
1045f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// getLocation - Return a source location identifier for the specified
1055f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// offset in the current file.
1065f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  SourceLocation getLocation() const { return Loc; }
1073604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis  unsigned getLength() const {
10847246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner    assert(!isAnnotation() && "Annotation tokens have no length field");
109b28d6de75e0cb27ce3106ce6052f87ad0ab276d7Daniel Dunbar    return UintData;
1103604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis  }
1115f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
1125f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  void setLocation(SourceLocation L) { Loc = L; }
11379ed16e2e605d67a12cccdcf9ad1b231175da1a6Chris Lattner  void setLength(unsigned Len) {
11447246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner    assert(!isAnnotation() && "Annotation tokens have no length field");
11579ed16e2e605d67a12cccdcf9ad1b231175da1a6Chris Lattner    UintData = Len;
11679ed16e2e605d67a12cccdcf9ad1b231175da1a6Chris Lattner  }
1173604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis
1183604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis  SourceLocation getAnnotationEndLoc() const {
11947246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner    assert(isAnnotation() && "Used AnnotEndLocID on non-annotation token");
120b28d6de75e0cb27ce3106ce6052f87ad0ab276d7Daniel Dunbar    return SourceLocation::getFromRawEncoding(UintData);
1213604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis  }
1223604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis  void setAnnotationEndLoc(SourceLocation L) {
12347246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner    assert(isAnnotation() && "Used AnnotEndLocID on non-annotation token");
124b28d6de75e0cb27ce3106ce6052f87ad0ab276d7Daniel Dunbar    UintData = L.getRawEncoding();
1253604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis  }
1263604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis
1273604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis  /// getAnnotationRange - SourceRange of the group of tokens that this
1283604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis  /// annotation token represents.
1293604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis  SourceRange getAnnotationRange() const {
1303604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis    return SourceRange(getLocation(), getAnnotationEndLoc());
1313604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis  }
1323604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis  void setAnnotationRange(SourceRange R) {
1333604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis    setLocation(R.getBegin());
1343604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis    setAnnotationEndLoc(R.getEnd());
1353604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis  }
1361eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
1378e748ab52395328f2905855b295a22e33dc800b2Ted Kremenek  const char *getName() const {
1388e748ab52395328f2905855b295a22e33dc800b2Ted Kremenek    return tok::getTokenName( (tok::TokenKind) Kind);
1398e748ab52395328f2905855b295a22e33dc800b2Ted Kremenek  }
1401eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
1415f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// startToken - Reset all flags to cleared.
1425f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  ///
1435f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  void startToken() {
14479ed16e2e605d67a12cccdcf9ad1b231175da1a6Chris Lattner    Kind = tok::unknown;
1455f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    Flags = 0;
146b28d6de75e0cb27ce3106ce6052f87ad0ab276d7Daniel Dunbar    PtrData = 0;
1475f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    Loc = SourceLocation();
1485f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  }
1491eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
1503604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis  IdentifierInfo *getIdentifierInfo() const {
15147246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner    assert(!isAnnotation() && "Used IdentInfo on annotation token!");
15247246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner    if (isLiteral()) return 0;
153b28d6de75e0cb27ce3106ce6052f87ad0ab276d7Daniel Dunbar    return (IdentifierInfo*) PtrData;
1543604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis  }
1555f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  void setIdentifierInfo(IdentifierInfo *II) {
156b28d6de75e0cb27ce3106ce6052f87ad0ab276d7Daniel Dunbar    PtrData = (void*) II;
1575f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  }
1581eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
15947246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  /// getLiteralData - For a literal token (numeric constant, string, etc), this
16047246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  /// returns a pointer to the start of it in the text buffer if known, null
16147246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  /// otherwise.
16247246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  const char *getLiteralData() const {
16347246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner    assert(isLiteral() && "Cannot get literal data of non-literal");
16447246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner    return reinterpret_cast<const char*>(PtrData);
16547246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  }
16647246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  void setLiteralData(const char *Ptr) {
16747246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner    assert(isLiteral() && "Cannot set literal data of non-literal");
16847246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner    PtrData = (void*)Ptr;
16947246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner  }
1701eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
1713604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis  void *getAnnotationValue() const {
17247246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner    assert(isAnnotation() && "Used AnnotVal on non-annotation token");
173b28d6de75e0cb27ce3106ce6052f87ad0ab276d7Daniel Dunbar    return PtrData;
1743604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis  }
1753604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis  void setAnnotationValue(void *val) {
17647246be8ac5b0ddde6c402b8fc6946b6135487b5Chris Lattner    assert(isAnnotation() && "Used AnnotVal on non-annotation token");
177b28d6de75e0cb27ce3106ce6052f87ad0ab276d7Daniel Dunbar    PtrData = val;
1783604e3895ecd850291b518e5a82246c888ce9d0fArgyrios Kyrtzidis  }
1791eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
1805f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// setFlag - Set the specified flag.
1815f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  void setFlag(TokenFlags Flag) {
1825f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    Flags |= Flag;
1835f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  }
1841eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
1855f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// clearFlag - Unset the specified flag.
1865f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  void clearFlag(TokenFlags Flag) {
1875f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    Flags &= ~Flag;
1885f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  }
1891eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
190ef3b215c946d4813408b5fe872fe2baa3b246b00Ted Kremenek  /// getFlags - Return the internal represtation of the flags.
191ef3b215c946d4813408b5fe872fe2baa3b246b00Ted Kremenek  ///  Only intended for low-level operations such as writing tokens to
192ef3b215c946d4813408b5fe872fe2baa3b246b00Ted Kremenek  //   disk.
193ef3b215c946d4813408b5fe872fe2baa3b246b00Ted Kremenek  unsigned getFlags() const {
194ef3b215c946d4813408b5fe872fe2baa3b246b00Ted Kremenek    return Flags;
195ef3b215c946d4813408b5fe872fe2baa3b246b00Ted Kremenek  }
1965f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
1975f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// setFlagValue - Set a flag to either true or false.
1985f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  void setFlagValue(TokenFlags Flag, bool Val) {
1991eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump    if (Val)
2005f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      setFlag(Flag);
2015f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    else
2025f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      clearFlag(Flag);
2035f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  }
2041eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
2055f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// isAtStartOfLine - Return true if this token is at the start of a line.
2065f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  ///
207b8128140956c6f8f0ab143818775a81f4b4aa477Chris Lattner  bool isAtStartOfLine() const { return (Flags & StartOfLine) ? true : false; }
2081eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
2095f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// hasLeadingSpace - Return true if this token has whitespace before it.
2105f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  ///
211b8128140956c6f8f0ab143818775a81f4b4aa477Chris Lattner  bool hasLeadingSpace() const { return (Flags & LeadingSpace) ? true : false; }
2121eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
2135f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// isExpandDisabled - Return true if this identifier token should never
2145f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// be expanded in the future, due to C99 6.10.3.4p2.
2158e748ab52395328f2905855b295a22e33dc800b2Ted Kremenek  bool isExpandDisabled() const {
2168e748ab52395328f2905855b295a22e33dc800b2Ted Kremenek    return (Flags & DisableExpand) ? true : false;
2178e748ab52395328f2905855b295a22e33dc800b2Ted Kremenek  }
2181eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
2191eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump  /// isObjCAtKeyword - Return true if we have an ObjC keyword identifier.
220861cf3effdc0fbc97d401539bc3050da76b2476fSteve Naroff  bool isObjCAtKeyword(tok::ObjCKeywordKind objcKey) const;
2211eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
222861cf3effdc0fbc97d401539bc3050da76b2476fSteve Naroff  /// getObjCKeywordID - Return the ObjC keyword kind.
223861cf3effdc0fbc97d401539bc3050da76b2476fSteve Naroff  tok::ObjCKeywordKind getObjCKeywordID() const;
2241eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
2255f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// needsCleaning - Return true if this token has trigraphs or escaped
2265f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// newlines in it.
2275f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  ///
228b8128140956c6f8f0ab143818775a81f4b4aa477Chris Lattner  bool needsCleaning() const { return (Flags & NeedsCleaning) ? true : false; }
2295f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer};
2305f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
2315f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// PPConditionalInfo - Information about the conditional stack (#if directives)
2325f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// currently active.
2335f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencerstruct PPConditionalInfo {
2345f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// IfLoc - Location where the conditional started.
2355f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  ///
2365f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  SourceLocation IfLoc;
2371eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
2385f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// WasSkipping - True if this was contained in a skipping directive, e.g.
2395f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// in a "#if 0" block.
2405f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  bool WasSkipping;
2411eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
2425f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// FoundNonSkip - True if we have emitted tokens already, and now we're in
2435f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// an #else block or something.  Only useful in Skipping blocks.
2445f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  bool FoundNonSkip;
2451eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
2465f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// FoundElse - True if we've seen a #else in this block.  If so,
2475f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// #elif/#else directives are not allowed.
2485f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  bool FoundElse;
2495f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer};
2505f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
251d6fb7ef028d9aa0b3e8943b7bc049c524437b407Douglas Gregor/// TemplateIdAnnotation - Information about a template-id annotation
252d6fb7ef028d9aa0b3e8943b7bc049c524437b407Douglas Gregor/// token, which contains the template declaration, template
25339a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor/// arguments, whether those template arguments were types or
25439a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor/// expressions, and the source locations for important tokens. All of
25539a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor/// the information about template arguments is allocated directly
25639a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor/// after this structure.
257d6fb7ef028d9aa0b3e8943b7bc049c524437b407Douglas Gregorstruct TemplateIdAnnotation {
258d6fb7ef028d9aa0b3e8943b7bc049c524437b407Douglas Gregor  /// TemplateNameLoc - The location of the template name within the
259d6fb7ef028d9aa0b3e8943b7bc049c524437b407Douglas Gregor  /// source.
260d6fb7ef028d9aa0b3e8943b7bc049c524437b407Douglas Gregor  SourceLocation TemplateNameLoc;
261d6fb7ef028d9aa0b3e8943b7bc049c524437b407Douglas Gregor
26239a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor  /// FIXME: Temporarily stores the name of a specialization
26339a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor  IdentifierInfo *Name;
26439a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor
265014e88d94ff83e3aad4e33b16413a2d1817ec208Douglas Gregor  /// FIXME: Temporarily stores the overloaded operator kind.
266014e88d94ff83e3aad4e33b16413a2d1817ec208Douglas Gregor  OverloadedOperatorKind Operator;
267014e88d94ff83e3aad4e33b16413a2d1817ec208Douglas Gregor
26839a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor  /// The declaration of the template corresponding to the
269d6fb7ef028d9aa0b3e8943b7bc049c524437b407Douglas Gregor  /// template-name. This is an Action::DeclTy*.
2701eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump  void *Template;
271d6fb7ef028d9aa0b3e8943b7bc049c524437b407Douglas Gregor
27239a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor  /// The kind of template that Template refers to.
27339a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor  TemplateNameKind Kind;
27439a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor
27539a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor  /// The location of the '<' before the template argument
2761eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump  /// list.
277d6fb7ef028d9aa0b3e8943b7bc049c524437b407Douglas Gregor  SourceLocation LAngleLoc;
278d6fb7ef028d9aa0b3e8943b7bc049c524437b407Douglas Gregor
27939a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor  /// The location of the '>' after the template argument
2801eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump  /// list.
28139a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor  SourceLocation RAngleLoc;
28239a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor
28339a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor  /// NumArgs - The number of template arguments.
2841eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump  unsigned NumArgs;
28539a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor
28639a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor  /// \brief Retrieves a pointer to the template arguments
28739a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor  void **getTemplateArgs() { return (void **)(this + 1); }
28839a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor
28939a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor  /// \brief Retrieves a pointer to the array of template argument
29039a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor  /// locations.
2911eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump  SourceLocation *getTemplateArgLocations() {
29239a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor    return (SourceLocation *)(getTemplateArgs() + NumArgs);
29339a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor  }
29439a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor
29539a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor  /// \brief Retrieves a pointer to the array of flags that states
29639a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor  /// whether the template arguments are types.
2971eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump  bool *getTemplateArgIsType() {
29839a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor    return (bool *)(getTemplateArgLocations() + NumArgs);
29939a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor  }
30039a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor
30139a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor  static TemplateIdAnnotation* Allocate(unsigned NumArgs) {
3021eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump    TemplateIdAnnotation *TemplateId
3031eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump      = (TemplateIdAnnotation *)std::malloc(sizeof(TemplateIdAnnotation) +
3041eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump                                            sizeof(void*) * NumArgs +
305ac1afdc58e6ad5c969f45fd2ff6d140d3b4dd862Douglas Gregor                                            sizeof(SourceLocation) * NumArgs +
306ac1afdc58e6ad5c969f45fd2ff6d140d3b4dd862Douglas Gregor                                            sizeof(bool) * NumArgs);
30739a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor    TemplateId->NumArgs = NumArgs;
30839a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor    return TemplateId;
30939a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor  }
31039a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor
31139a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor  void Destroy() { free(this); }
312d6fb7ef028d9aa0b3e8943b7bc049c524437b407Douglas Gregor};
313d6fb7ef028d9aa0b3e8943b7bc049c524437b407Douglas Gregor
3145f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer}  // end namespace clang
3155f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
3165f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer#endif
317