blob: 88986c288ab8aed2631193a68d639bcfecf9d481 [file] [log] [blame]
Chris Lattner00950542001-06-06 20:29:01 +00001//===-- ParserInternals.h - Definitions internal to the parser ---*- C++ -*--=//
2//
3// This header file defines the various variables that are shared among the
4// different components of the parser...
5//
6//===----------------------------------------------------------------------===//
7
8#ifndef PARSER_INTERNALS_H
9#define PARSER_INTERNALS_H
10
11#include <stdio.h>
12#define __STDC_LIMIT_MACROS
13
14#include "llvm/InstrTypes.h"
15#include "llvm/BasicBlock.h"
16#include "llvm/ConstPoolVals.h"
17#include "llvm/iOther.h"
18#include "llvm/Method.h"
Chris Lattnereb5ff8d2001-09-07 16:33:01 +000019#include "llvm/DerivedTypes.h"
Chris Lattner00950542001-06-06 20:29:01 +000020#include "llvm/Assembly/Parser.h"
Chris Lattner57dbb3a2001-07-23 17:46:59 +000021#include "llvm/Support/StringExtras.h"
Chris Lattner00950542001-06-06 20:29:01 +000022
23class Module;
24
25// Global variables exported from the lexer...
26extern FILE *llvmAsmin;
27extern int llvmAsmlineno;
28
29// Globals exported by the parser...
Chris Lattnera2850432001-07-22 18:36:00 +000030extern string CurFilename;
31Module *RunVMAsmParser(const string &Filename, FILE *F);
Chris Lattner00950542001-06-06 20:29:01 +000032
33
Chris Lattner93750fa2001-07-28 17:48:55 +000034// UnEscapeLexed - Run through the specified buffer and change \xx codes to the
35// appropriate character. If AllowNull is set to false, a \00 value will cause
36// an exception to be thrown.
37//
38// If AllowNull is set to true, the return value of the function points to the
39// last character of the string in memory.
40//
41char *UnEscapeLexed(char *Buffer, bool AllowNull = false);
42
43
Chris Lattner00950542001-06-06 20:29:01 +000044// ThrowException - Wrapper around the ParseException class that automatically
45// fills in file line number and column number and options info.
46//
47// This also helps me because I keep typing 'throw new ParseException' instead
48// of just 'throw ParseException'... sigh...
49//
Chris Lattner93750fa2001-07-28 17:48:55 +000050static inline void ThrowException(const string &message,
51 int LineNo = -1) {
52 if (LineNo == -1) LineNo = llvmAsmlineno;
Chris Lattner00950542001-06-06 20:29:01 +000053 // TODO: column number in exception
Chris Lattner93750fa2001-07-28 17:48:55 +000054 throw ParseException(CurFilename, message, LineNo);
Chris Lattner00950542001-06-06 20:29:01 +000055}
56
57// ValID - Represents a reference of a definition of some sort. This may either
58// be a numeric reference or a symbolic (%var) reference. This is just a
59// discriminated union.
60//
61// Note that I can't implement this class in a straight forward manner with
62// constructors and stuff because it goes in a union, and GCC doesn't like
63// putting classes with ctor's in unions. :(
64//
65struct ValID {
Chris Lattner1a1cb112001-09-30 22:46:54 +000066 enum {
67 NumberVal, NameVal, ConstSIntVal, ConstUIntVal, ConstStringVal,
68 ConstFPVal, ConstNullVal
69 } Type;
70
Chris Lattner00950542001-06-06 20:29:01 +000071 union {
72 int Num; // If it's a numeric reference
73 char *Name; // If it's a named reference. Memory must be free'd.
74 int64_t ConstPool64; // Constant pool reference. This is the value
75 uint64_t UConstPool64;// Unsigned constant pool reference.
Chris Lattner3d52b2f2001-07-15 00:17:01 +000076 double ConstPoolFP; // Floating point constant pool reference
Chris Lattner00950542001-06-06 20:29:01 +000077 };
78
79 static ValID create(int Num) {
Chris Lattner1a1cb112001-09-30 22:46:54 +000080 ValID D; D.Type = NumberVal; D.Num = Num; return D;
Chris Lattner00950542001-06-06 20:29:01 +000081 }
82
83 static ValID create(char *Name) {
Chris Lattner1a1cb112001-09-30 22:46:54 +000084 ValID D; D.Type = NameVal; D.Name = Name; return D;
Chris Lattner00950542001-06-06 20:29:01 +000085 }
86
87 static ValID create(int64_t Val) {
Chris Lattner1a1cb112001-09-30 22:46:54 +000088 ValID D; D.Type = ConstSIntVal; D.ConstPool64 = Val; return D;
Chris Lattner00950542001-06-06 20:29:01 +000089 }
90
91 static ValID create(uint64_t Val) {
Chris Lattner1a1cb112001-09-30 22:46:54 +000092 ValID D; D.Type = ConstUIntVal; D.UConstPool64 = Val; return D;
Chris Lattner00950542001-06-06 20:29:01 +000093 }
94
95 static ValID create_conststr(char *Name) {
Chris Lattner1a1cb112001-09-30 22:46:54 +000096 ValID D; D.Type = ConstStringVal; D.Name = Name; return D;
Chris Lattner00950542001-06-06 20:29:01 +000097 }
98
Chris Lattner3d52b2f2001-07-15 00:17:01 +000099 static ValID create(double Val) {
Chris Lattner1a1cb112001-09-30 22:46:54 +0000100 ValID D; D.Type = ConstFPVal; D.ConstPoolFP = Val; return D;
101 }
102
103 static ValID createNull() {
104 ValID D; D.Type = ConstNullVal; return D;
Chris Lattner3d52b2f2001-07-15 00:17:01 +0000105 }
106
Chris Lattnerbcbf6ba2001-07-26 16:29:15 +0000107 inline void destroy() const {
Chris Lattner1a1cb112001-09-30 22:46:54 +0000108 if (Type == NameVal || Type == ConstStringVal)
109 free(Name); // Free this strdup'd memory...
Chris Lattner00950542001-06-06 20:29:01 +0000110 }
111
112 inline ValID copy() const {
Chris Lattner1a1cb112001-09-30 22:46:54 +0000113 if (Type != NameVal && Type != ConstStringVal) return *this;
Chris Lattner00950542001-06-06 20:29:01 +0000114 ValID Result = *this;
115 Result.Name = strdup(Name);
116 return Result;
117 }
118
119 inline string getName() const {
120 switch (Type) {
Chris Lattner1a1cb112001-09-30 22:46:54 +0000121 case NumberVal : return string("#") + itostr(Num);
122 case NameVal : return Name;
123 case ConstStringVal: return string("\"") + Name + string("\"");
124 case ConstFPVal : return ftostr(ConstPoolFP);
125 case ConstNullVal : return "null";
126 case ConstUIntVal :
127 case ConstSIntVal : return string("%") + itostr(ConstPool64);
128 default:
129 assert(0 && "Unknown value!");
130 abort();
Chris Lattner00950542001-06-06 20:29:01 +0000131 }
132 }
133};
134
135
136
137template<class SuperType>
Chris Lattner93750fa2001-07-28 17:48:55 +0000138class PlaceholderValue : public SuperType {
Chris Lattner00950542001-06-06 20:29:01 +0000139 ValID D;
Chris Lattner93750fa2001-07-28 17:48:55 +0000140 int LineNum;
Chris Lattner00950542001-06-06 20:29:01 +0000141public:
Chris Lattner93750fa2001-07-28 17:48:55 +0000142 PlaceholderValue(const Type *Ty, const ValID &d) : SuperType(Ty), D(d) {
143 LineNum = llvmAsmlineno;
144 }
Chris Lattner00950542001-06-06 20:29:01 +0000145 ValID &getDef() { return D; }
Chris Lattner93750fa2001-07-28 17:48:55 +0000146 int getLineNum() const { return LineNum; }
Chris Lattner00950542001-06-06 20:29:01 +0000147};
148
Chris Lattnereb5ff8d2001-09-07 16:33:01 +0000149struct TypePlaceHolderHelper : public OpaqueType {
150 TypePlaceHolderHelper(const Type *Ty) : OpaqueType() {
151 assert(Ty == Type::TypeTy);
152 }
153};
154
155
Chris Lattner00950542001-06-06 20:29:01 +0000156struct InstPlaceHolderHelper : public Instruction {
157 InstPlaceHolderHelper(const Type *Ty) : Instruction(Ty, UserOp1, "") {}
158
159 virtual Instruction *clone() const { abort(); }
Chris Lattnera41f50d2001-07-07 19:24:15 +0000160 virtual const char *getOpcodeName() const { return "placeholder"; }
Chris Lattner00950542001-06-06 20:29:01 +0000161};
162
163struct BBPlaceHolderHelper : public BasicBlock {
164 BBPlaceHolderHelper(const Type *Ty) : BasicBlock() {
165 assert(Ty->isLabelType());
166 }
167};
168
169struct MethPlaceHolderHelper : public Method {
170 MethPlaceHolderHelper(const Type *Ty)
171 : Method((const MethodType*)Ty) {
172 assert(Ty->isMethodType() && "Method placeholders must be method types!");
173 }
174};
175
Chris Lattnereb5ff8d2001-09-07 16:33:01 +0000176typedef PlaceholderValue<TypePlaceHolderHelper> TypePlaceHolder;
Chris Lattner93750fa2001-07-28 17:48:55 +0000177typedef PlaceholderValue<InstPlaceHolderHelper> ValuePlaceHolder;
178typedef PlaceholderValue<BBPlaceHolderHelper> BBPlaceHolder;
179typedef PlaceholderValue<MethPlaceHolderHelper> MethPlaceHolder;
Chris Lattner00950542001-06-06 20:29:01 +0000180
Chris Lattnereb5ff8d2001-09-07 16:33:01 +0000181static inline ValID &getValIDFromPlaceHolder(const Value *Val) {
Chris Lattner93750fa2001-07-28 17:48:55 +0000182 switch (Val->getType()->getPrimitiveID()) {
Chris Lattnereb5ff8d2001-09-07 16:33:01 +0000183 case Type::TypeTyID: return ((TypePlaceHolder*)Val)->getDef();
Chris Lattner93750fa2001-07-28 17:48:55 +0000184 case Type::LabelTyID: return ((BBPlaceHolder*)Val)->getDef();
185 case Type::MethodTyID: return ((MethPlaceHolder*)Val)->getDef();
186 default: return ((ValuePlaceHolder*)Val)->getDef();
187 }
188}
189
Chris Lattnereb5ff8d2001-09-07 16:33:01 +0000190static inline int getLineNumFromPlaceHolder(const Value *Val) {
Chris Lattner93750fa2001-07-28 17:48:55 +0000191 switch (Val->getType()->getPrimitiveID()) {
Chris Lattnereb5ff8d2001-09-07 16:33:01 +0000192 case Type::TypeTyID: return ((TypePlaceHolder*)Val)->getLineNum();
Chris Lattner93750fa2001-07-28 17:48:55 +0000193 case Type::LabelTyID: return ((BBPlaceHolder*)Val)->getLineNum();
194 case Type::MethodTyID: return ((MethPlaceHolder*)Val)->getLineNum();
195 default: return ((ValuePlaceHolder*)Val)->getLineNum();
Chris Lattner00950542001-06-06 20:29:01 +0000196 }
197}
198
199#endif