MacroInfo.h revision 3c7f4134603d04b44f997b43c0a9def270f25386
15f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//===--- MacroInfo.h - Information about #defined identifiers ---*- 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//
105f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer// This file defines the MacroInfo interface.
115f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//
125f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//===----------------------------------------------------------------------===//
135f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
145f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer#ifndef LLVM_CLANG_MACROINFO_H
155f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer#define LLVM_CLANG_MACROINFO_H
165f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
17d217773f106856a11879ec79dc468efefaf2ee75Chris Lattner#include "clang/Lex/Token.h"
18f46f68b5587b6933a92260220567ea7c36924a80Chris Lattner#include "llvm/ADT/SmallVector.h"
19685befeb5f6472585bae473a6389e47cab9eac67Chris Lattner#include "llvm/Support/Allocator.h"
205f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer#include <vector>
219dc62f044a6ba21f503bd56607d94b32704e7945Chris Lattner#include <cassert>
225f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
235f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencernamespace clang {
245f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  class Preprocessor;
251eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
265f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// MacroInfo - Each identifier that is #define'd has an instance of this class
275f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// associated with it, used to implement macro expansion.
285f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencerclass MacroInfo {
295f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  //===--------------------------------------------------------------------===//
305f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  // State set when the macro is defined.
315f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
325f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// Location - This is the place the macro is defined.
335f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  SourceLocation Location;
342451b528fe114595d0f10ef2c05047928558ab0fChris Lattner  /// EndLocation - The location of the last token in the macro.
352451b528fe114595d0f10ef2c05047928558ab0fChris Lattner  SourceLocation EndLocation;
365f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
375f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// Arguments - The list of arguments for a function-like macro.  This can be
385f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// empty, for, e.g. "#define X()".  In a C99-style variadic macro, this
395f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// includes the __VA_ARGS__ identifier on the list.
4025c9648909193d380a4e135d2e3d25394ba12922Chris Lattner  IdentifierInfo **ArgumentList;
4125c9648909193d380a4e135d2e3d25394ba12922Chris Lattner  unsigned NumArguments;
421eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
435f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// ReplacementTokens - This is the list of tokens that the macro is defined
445f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// to.
45d217773f106856a11879ec79dc468efefaf2ee75Chris Lattner  llvm::SmallVector<Token, 8> ReplacementTokens;
465f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
475f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// IsFunctionLike - True if this macro is a function-like macro, false if it
485f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// is an object-like macro.
495f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  bool IsFunctionLike : 1;
501eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
515f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// IsC99Varargs - True if this macro is of the form "#define X(...)" or
525f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// "#define X(Y,Z,...)".  The __VA_ARGS__ token should be replaced with the
535f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// contents of "..." in an invocation.
545f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  bool IsC99Varargs : 1;
551eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
565f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// IsGNUVarargs -  True if this macro is of the form "#define X(a...)".  The
5712fe558612303cb2188c321a77a21f7df23b6ae8Chris Lattner  /// "a" identifier in the replacement list will be replaced with all arguments
585f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// of the macro starting with the specified one.
595f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  bool IsGNUVarargs : 1;
601eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
615f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// IsBuiltinMacro - True if this is a builtin macro, such as __LINE__, and if
625f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// it has not yet been redefined or undefined.
635f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  bool IsBuiltinMacro : 1;
641eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
653c7f4134603d04b44f997b43c0a9def270f25386Sebastian Redl  /// IsFromAST - True if this macro was loaded from an AST file.
663c7f4134603d04b44f997b43c0a9def270f25386Sebastian Redl  bool IsFromAST : 1;
67083abdf67f157e9d2ab5a8c9d5e71240479d3c99Sebastian Redl
685f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencerprivate:
695f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  //===--------------------------------------------------------------------===//
705f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  // State that changes as the macro is used.
715f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
725f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// IsDisabled - True if we have started an expansion of this macro already.
735f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// This disbles recursive expansion, which would be quite bad for things like
745f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// #define A A.
755f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  bool IsDisabled : 1;
761eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
775f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// IsUsed - True if this macro is either defined in the main file and has
781eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump  /// been used, or if it is not defined in the main file.  This is used to
795f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// emit -Wunused-macros diagnostics.
805f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  bool IsUsed : 1;
811eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
82f47724bf78299c7a50f008e0443c5f9f9f279ddcChris Lattner  /// AllowRedefinitionsWithoutWarning - True if this macro can be redefined
83f47724bf78299c7a50f008e0443c5f9f9f279ddcChris Lattner  /// without emitting a warning.
84f47724bf78299c7a50f008e0443c5f9f9f279ddcChris Lattner  bool IsAllowRedefinitionsWithoutWarning : 1;
85f47724bf78299c7a50f008e0443c5f9f9f279ddcChris Lattner
86f47724bf78299c7a50f008e0443c5f9f9f279ddcChris Lattner   ~MacroInfo() {
870301b3ff132a4d986c092d161cb77d74b04cd2a6Chris Lattner    assert(ArgumentList == 0 && "Didn't call destroy before dtor!");
880301b3ff132a4d986c092d161cb77d74b04cd2a6Chris Lattner  }
891eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
90cf29e0716bb3ecbbc15b74cd648367d6b075fdf0Chris Lattnerpublic:
91cf29e0716bb3ecbbc15b74cd648367d6b075fdf0Chris Lattner  MacroInfo(SourceLocation DefLoc);
92f47724bf78299c7a50f008e0443c5f9f9f279ddcChris Lattner  MacroInfo(const MacroInfo &MI, llvm::BumpPtrAllocator &PPAllocator);
93f47724bf78299c7a50f008e0443c5f9f9f279ddcChris Lattner
94cf29e0716bb3ecbbc15b74cd648367d6b075fdf0Chris Lattner  /// FreeArgumentList - Free the argument list of the macro, restoring it to a
95cf29e0716bb3ecbbc15b74cd648367d6b075fdf0Chris Lattner  /// state where it can be reused for other devious purposes.
962c1ab9079cb117dc0470ab423fe0bc5177546339Chris Lattner  void FreeArgumentList() {
970301b3ff132a4d986c092d161cb77d74b04cd2a6Chris Lattner    ArgumentList = 0;
98cf29e0716bb3ecbbc15b74cd648367d6b075fdf0Chris Lattner    NumArguments = 0;
99cf29e0716bb3ecbbc15b74cd648367d6b075fdf0Chris Lattner  }
1001eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
101cf29e0716bb3ecbbc15b74cd648367d6b075fdf0Chris Lattner  /// Destroy - destroy this MacroInfo object.
1022c1ab9079cb117dc0470ab423fe0bc5177546339Chris Lattner  void Destroy() {
1032c1ab9079cb117dc0470ab423fe0bc5177546339Chris Lattner    FreeArgumentList();
104cf29e0716bb3ecbbc15b74cd648367d6b075fdf0Chris Lattner    this->~MacroInfo();
10525c9648909193d380a4e135d2e3d25394ba12922Chris Lattner  }
1061eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
1075f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// getDefinitionLoc - Return the location that the macro was defined at.
1085f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  ///
1095f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  SourceLocation getDefinitionLoc() const { return Location; }
1102451b528fe114595d0f10ef2c05047928558ab0fChris Lattner
1112451b528fe114595d0f10ef2c05047928558ab0fChris Lattner  /// setDefinitionEndLoc - Set the location of the last token in the macro.
1122451b528fe114595d0f10ef2c05047928558ab0fChris Lattner  ///
1132451b528fe114595d0f10ef2c05047928558ab0fChris Lattner  void setDefinitionEndLoc(SourceLocation EndLoc) { EndLocation = EndLoc; }
1142451b528fe114595d0f10ef2c05047928558ab0fChris Lattner  /// getDefinitionEndLoc - Return the location of the last token in the macro.
1152451b528fe114595d0f10ef2c05047928558ab0fChris Lattner  ///
1162451b528fe114595d0f10ef2c05047928558ab0fChris Lattner  SourceLocation getDefinitionEndLoc() const { return EndLocation; }
1172451b528fe114595d0f10ef2c05047928558ab0fChris Lattner
1185f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// isIdenticalTo - Return true if the specified macro definition is equal to
1195f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// this macro in spelling, arguments, and whitespace.  This is used to emit
1205f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// duplicate definition warnings.  This implements the rules in C99 6.10.3.
1215f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  bool isIdenticalTo(const MacroInfo &Other, Preprocessor &PP) const;
1221eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
1235f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// setIsBuiltinMacro - Set or clear the isBuiltinMacro flag.
1245f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  ///
1255f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  void setIsBuiltinMacro(bool Val = true) {
1265f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    IsBuiltinMacro = Val;
1275f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  }
1281eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
1295f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// setIsUsed - Set the value of the IsUsed flag.
1305f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  ///
1315f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  void setIsUsed(bool Val) {
1325f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    IsUsed = Val;
1335f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  }
1345f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
135f47724bf78299c7a50f008e0443c5f9f9f279ddcChris Lattner  /// setIsAllowRedefinitionsWithoutWarning - Set the value of the
136f47724bf78299c7a50f008e0443c5f9f9f279ddcChris Lattner  /// IsAllowRedefinitionsWithoutWarning flag.
137f47724bf78299c7a50f008e0443c5f9f9f279ddcChris Lattner  void setIsAllowRedefinitionsWithoutWarning(bool Val) {
138f47724bf78299c7a50f008e0443c5f9f9f279ddcChris Lattner    IsAllowRedefinitionsWithoutWarning = Val;
139f47724bf78299c7a50f008e0443c5f9f9f279ddcChris Lattner  }
140f47724bf78299c7a50f008e0443c5f9f9f279ddcChris Lattner
14125c9648909193d380a4e135d2e3d25394ba12922Chris Lattner  /// setArgumentList - Set the specified list of identifiers as the argument
14225c9648909193d380a4e135d2e3d25394ba12922Chris Lattner  /// list for this macro.
143685befeb5f6472585bae473a6389e47cab9eac67Chris Lattner  void setArgumentList(IdentifierInfo* const *List, unsigned NumArgs,
144685befeb5f6472585bae473a6389e47cab9eac67Chris Lattner                       llvm::BumpPtrAllocator &PPAllocator) {
145cf29e0716bb3ecbbc15b74cd648367d6b075fdf0Chris Lattner    assert(ArgumentList == 0 && NumArguments == 0 &&
146cf29e0716bb3ecbbc15b74cd648367d6b075fdf0Chris Lattner           "Argument list already set!");
14725c9648909193d380a4e135d2e3d25394ba12922Chris Lattner    if (NumArgs == 0) return;
1481eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
14925c9648909193d380a4e135d2e3d25394ba12922Chris Lattner    NumArguments = NumArgs;
150685befeb5f6472585bae473a6389e47cab9eac67Chris Lattner    ArgumentList = PPAllocator.Allocate<IdentifierInfo*>(NumArgs);
151cf29e0716bb3ecbbc15b74cd648367d6b075fdf0Chris Lattner    for (unsigned i = 0; i != NumArgs; ++i)
152cf29e0716bb3ecbbc15b74cd648367d6b075fdf0Chris Lattner      ArgumentList[i] = List[i];
1535f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  }
1541eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
15525c9648909193d380a4e135d2e3d25394ba12922Chris Lattner  /// Arguments - The list of arguments for a function-like macro.  This can be
15625c9648909193d380a4e135d2e3d25394ba12922Chris Lattner  /// empty, for, e.g. "#define X()".
15725c9648909193d380a4e135d2e3d25394ba12922Chris Lattner  typedef IdentifierInfo* const *arg_iterator;
158f73903a1ded46748e1dfda151f5d037b7b3d31f9Chris Lattner  bool arg_empty() const { return NumArguments == 0; }
15925c9648909193d380a4e135d2e3d25394ba12922Chris Lattner  arg_iterator arg_begin() const { return ArgumentList; }
16025c9648909193d380a4e135d2e3d25394ba12922Chris Lattner  arg_iterator arg_end() const { return ArgumentList+NumArguments; }
16125c9648909193d380a4e135d2e3d25394ba12922Chris Lattner  unsigned getNumArgs() const { return NumArguments; }
1621eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
1635f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// getArgumentNum - Return the argument number of the specified identifier,
1645f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// or -1 if the identifier is not a formal argument identifier.
16525c9648909193d380a4e135d2e3d25394ba12922Chris Lattner  int getArgumentNum(IdentifierInfo *Arg) const {
16625c9648909193d380a4e135d2e3d25394ba12922Chris Lattner    for (arg_iterator I = arg_begin(), E = arg_end(); I != E; ++I)
16725c9648909193d380a4e135d2e3d25394ba12922Chris Lattner      if (*I == Arg) return I-arg_begin();
1685f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    return -1;
1695f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  }
1701eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
1715f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// Function/Object-likeness.  Keep track of whether this macro has formal
1725f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// parameters.
1735f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  void setIsFunctionLike() { IsFunctionLike = true; }
1745f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  bool isFunctionLike() const { return IsFunctionLike; }
1755f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  bool isObjectLike() const { return !IsFunctionLike; }
1761eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
1775f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// Varargs querying methods.  This can only be set for function-like macros.
1785f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  void setIsC99Varargs() { IsC99Varargs = true; }
1795f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  void setIsGNUVarargs() { IsGNUVarargs = true; }
1805f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  bool isC99Varargs() const { return IsC99Varargs; }
1815f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  bool isGNUVarargs() const { return IsGNUVarargs; }
1825f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  bool isVariadic() const { return IsC99Varargs | IsGNUVarargs; }
1831eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
1845f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// isBuiltinMacro - Return true if this macro is a builtin macro, such as
1855f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// __LINE__, which requires processing before expansion.
1865f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  bool isBuiltinMacro() const { return IsBuiltinMacro; }
1875f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
1883c7f4134603d04b44f997b43c0a9def270f25386Sebastian Redl  /// isFromAST - Return true if this macro was loaded from an AST file.
1893c7f4134603d04b44f997b43c0a9def270f25386Sebastian Redl  bool isFromAST() const { return IsFromAST; }
190083abdf67f157e9d2ab5a8c9d5e71240479d3c99Sebastian Redl
1913c7f4134603d04b44f997b43c0a9def270f25386Sebastian Redl  /// setIsFromAST - Set whether this macro was loaded from an AST file.
1923c7f4134603d04b44f997b43c0a9def270f25386Sebastian Redl  void setIsFromAST(bool FromAST = true) { IsFromAST = FromAST; }
193083abdf67f157e9d2ab5a8c9d5e71240479d3c99Sebastian Redl
1945f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// isUsed - Return false if this macro is defined in the main file and has
1955f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// not yet been used.
1965f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  bool isUsed() const { return IsUsed; }
1971eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
198f47724bf78299c7a50f008e0443c5f9f9f279ddcChris Lattner  /// isAllowRedefinitionsWithoutWarning - Return true if this macro can be
199f47724bf78299c7a50f008e0443c5f9f9f279ddcChris Lattner  /// redefined without warning.
200f47724bf78299c7a50f008e0443c5f9f9f279ddcChris Lattner  bool isAllowRedefinitionsWithoutWarning() const {
201f47724bf78299c7a50f008e0443c5f9f9f279ddcChris Lattner    return IsAllowRedefinitionsWithoutWarning;
202f47724bf78299c7a50f008e0443c5f9f9f279ddcChris Lattner  }
203f47724bf78299c7a50f008e0443c5f9f9f279ddcChris Lattner
2045f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// getNumTokens - Return the number of tokens that this macro expands to.
2055f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  ///
2065f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  unsigned getNumTokens() const {
2075f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    return ReplacementTokens.size();
2085f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  }
2095f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
210d217773f106856a11879ec79dc468efefaf2ee75Chris Lattner  const Token &getReplacementToken(unsigned Tok) const {
2115f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    assert(Tok < ReplacementTokens.size() && "Invalid token #");
2125f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    return ReplacementTokens[Tok];
2135f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  }
2141eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
215d217773f106856a11879ec79dc468efefaf2ee75Chris Lattner  typedef llvm::SmallVector<Token, 8>::const_iterator tokens_iterator;
216c215bd659d8266a1d6b66ce231a63405a4c61dafChris Lattner  tokens_iterator tokens_begin() const { return ReplacementTokens.begin(); }
217c215bd659d8266a1d6b66ce231a63405a4c61dafChris Lattner  tokens_iterator tokens_end() const { return ReplacementTokens.end(); }
218f73903a1ded46748e1dfda151f5d037b7b3d31f9Chris Lattner  bool tokens_empty() const { return ReplacementTokens.empty(); }
2191eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
2205f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// AddTokenToBody - Add the specified token to the replacement text for the
2215f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// macro.
222d217773f106856a11879ec79dc468efefaf2ee75Chris Lattner  void AddTokenToBody(const Token &Tok) {
2235f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    ReplacementTokens.push_back(Tok);
2245f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  }
2251eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
2265f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// isEnabled - Return true if this macro is enabled: in other words, that we
2275f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  /// are not currently in an expansion of this macro.
2285f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  bool isEnabled() const { return !IsDisabled; }
2291eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
2305f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  void EnableMacro() {
2315f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    assert(IsDisabled && "Cannot enable an already-enabled macro!");
2325f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    IsDisabled = false;
2335f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  }
2345f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
2355f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  void DisableMacro() {
2365f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    assert(!IsDisabled && "Cannot disable an already-disabled macro!");
2375f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    IsDisabled = true;
2385f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  }
2395f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer};
2401eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
2415f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer}  // end namespace clang
2425f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
2435f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer#endif
244