|  | /* A Bison parser, made by GNU Bison 2.1.  */ | 
|  |  | 
|  | /* Skeleton parser for Yacc-like parsing with Bison, | 
|  | Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004, 2005 Free Software Foundation, Inc. | 
|  |  | 
|  | This program is free software; you can redistribute it and/or modify | 
|  | it under the terms of the GNU General Public License as published by | 
|  | the Free Software Foundation; either version 2, or (at your option) | 
|  | any later version. | 
|  |  | 
|  | This program is distributed in the hope that it will be useful, | 
|  | but WITHOUT ANY WARRANTY; without even the implied warranty of | 
|  | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
|  | GNU General Public License for more details. | 
|  |  | 
|  | You should have received a copy of the GNU General Public License | 
|  | along with this program; if not, write to the Free Software | 
|  | Foundation, Inc., 51 Franklin Street, Fifth Floor, | 
|  | Boston, MA 02110-1301, USA.  */ | 
|  |  | 
|  | /* As a special exception, when this file is copied by Bison into a | 
|  | Bison output file, you may use that output file without restriction. | 
|  | This special exception was added by the Free Software Foundation | 
|  | in version 1.24 of Bison.  */ | 
|  |  | 
|  | /* Written by Richard Stallman by simplifying the original so called | 
|  | ``semantic'' parser.  */ | 
|  |  | 
|  | /* All symbols defined below should begin with yy or YY, to avoid | 
|  | infringing on user name space.  This should be done even for local | 
|  | variables, as they might otherwise be expanded by user macros. | 
|  | There are some unavoidable exceptions within include files to | 
|  | define necessary library symbols; they are noted "INFRINGES ON | 
|  | USER NAME SPACE" below.  */ | 
|  |  | 
|  | /* Identify Bison output.  */ | 
|  | #define YYBISON 1 | 
|  |  | 
|  | /* Bison version.  */ | 
|  | #define YYBISON_VERSION "2.1" | 
|  |  | 
|  | /* Skeleton name.  */ | 
|  | #define YYSKELETON_NAME "yacc.c" | 
|  |  | 
|  | /* Pure parsers.  */ | 
|  | #define YYPURE 0 | 
|  |  | 
|  | /* Using locations.  */ | 
|  | #define YYLSP_NEEDED 0 | 
|  |  | 
|  | /* Substitute the variable and function names.  */ | 
|  | #define yyparse llvmAsmparse | 
|  | #define yylex   llvmAsmlex | 
|  | #define yyerror llvmAsmerror | 
|  | #define yylval  llvmAsmlval | 
|  | #define yychar  llvmAsmchar | 
|  | #define yydebug llvmAsmdebug | 
|  | #define yynerrs llvmAsmnerrs | 
|  |  | 
|  |  | 
|  | /* Tokens.  */ | 
|  | #ifndef YYTOKENTYPE | 
|  | # define YYTOKENTYPE | 
|  | /* Put the tokens into the symbol table, so that GDB and other debuggers | 
|  | know about them.  */ | 
|  | enum yytokentype { | 
|  | ESINT64VAL = 258, | 
|  | EUINT64VAL = 259, | 
|  | SINTVAL = 260, | 
|  | UINTVAL = 261, | 
|  | FPVAL = 262, | 
|  | VOID = 263, | 
|  | BOOL = 264, | 
|  | INT8 = 265, | 
|  | INT16 = 266, | 
|  | INT32 = 267, | 
|  | INT64 = 268, | 
|  | FLOAT = 269, | 
|  | DOUBLE = 270, | 
|  | LABEL = 271, | 
|  | TYPE = 272, | 
|  | VAR_ID = 273, | 
|  | LABELSTR = 274, | 
|  | STRINGCONSTANT = 275, | 
|  | IMPLEMENTATION = 276, | 
|  | ZEROINITIALIZER = 277, | 
|  | TRUETOK = 278, | 
|  | FALSETOK = 279, | 
|  | BEGINTOK = 280, | 
|  | ENDTOK = 281, | 
|  | DECLARE = 282, | 
|  | DEFINE = 283, | 
|  | GLOBAL = 284, | 
|  | CONSTANT = 285, | 
|  | SECTION = 286, | 
|  | VOLATILE = 287, | 
|  | TO = 288, | 
|  | DOTDOTDOT = 289, | 
|  | NULL_TOK = 290, | 
|  | UNDEF = 291, | 
|  | INTERNAL = 292, | 
|  | LINKONCE = 293, | 
|  | WEAK = 294, | 
|  | APPENDING = 295, | 
|  | DLLIMPORT = 296, | 
|  | DLLEXPORT = 297, | 
|  | EXTERN_WEAK = 298, | 
|  | OPAQUE = 299, | 
|  | NOT = 300, | 
|  | EXTERNAL = 301, | 
|  | TARGET = 302, | 
|  | TRIPLE = 303, | 
|  | ENDIAN = 304, | 
|  | POINTERSIZE = 305, | 
|  | LITTLE = 306, | 
|  | BIG = 307, | 
|  | ALIGN = 308, | 
|  | DEPLIBS = 309, | 
|  | CALL = 310, | 
|  | TAIL = 311, | 
|  | ASM_TOK = 312, | 
|  | MODULE = 313, | 
|  | SIDEEFFECT = 314, | 
|  | CC_TOK = 315, | 
|  | CCC_TOK = 316, | 
|  | CSRETCC_TOK = 317, | 
|  | FASTCC_TOK = 318, | 
|  | COLDCC_TOK = 319, | 
|  | X86_STDCALLCC_TOK = 320, | 
|  | X86_FASTCALLCC_TOK = 321, | 
|  | DATALAYOUT = 322, | 
|  | RET = 323, | 
|  | BR = 324, | 
|  | SWITCH = 325, | 
|  | INVOKE = 326, | 
|  | UNWIND = 327, | 
|  | UNREACHABLE = 328, | 
|  | ADD = 329, | 
|  | SUB = 330, | 
|  | MUL = 331, | 
|  | UDIV = 332, | 
|  | SDIV = 333, | 
|  | FDIV = 334, | 
|  | UREM = 335, | 
|  | SREM = 336, | 
|  | FREM = 337, | 
|  | AND = 338, | 
|  | OR = 339, | 
|  | XOR = 340, | 
|  | ICMP = 341, | 
|  | FCMP = 342, | 
|  | EQ = 343, | 
|  | NE = 344, | 
|  | SLT = 345, | 
|  | SGT = 346, | 
|  | SLE = 347, | 
|  | SGE = 348, | 
|  | ULT = 349, | 
|  | UGT = 350, | 
|  | ULE = 351, | 
|  | UGE = 352, | 
|  | OEQ = 353, | 
|  | ONE = 354, | 
|  | OLT = 355, | 
|  | OGT = 356, | 
|  | OLE = 357, | 
|  | OGE = 358, | 
|  | ORD = 359, | 
|  | UNO = 360, | 
|  | UEQ = 361, | 
|  | UNE = 362, | 
|  | MALLOC = 363, | 
|  | ALLOCA = 364, | 
|  | FREE = 365, | 
|  | LOAD = 366, | 
|  | STORE = 367, | 
|  | GETELEMENTPTR = 368, | 
|  | TRUNC = 369, | 
|  | ZEXT = 370, | 
|  | SEXT = 371, | 
|  | FPTRUNC = 372, | 
|  | FPEXT = 373, | 
|  | BITCAST = 374, | 
|  | UITOFP = 375, | 
|  | SITOFP = 376, | 
|  | FPTOUI = 377, | 
|  | FPTOSI = 378, | 
|  | INTTOPTR = 379, | 
|  | PTRTOINT = 380, | 
|  | PHI_TOK = 381, | 
|  | SELECT = 382, | 
|  | SHL = 383, | 
|  | LSHR = 384, | 
|  | ASHR = 385, | 
|  | VAARG = 386, | 
|  | EXTRACTELEMENT = 387, | 
|  | INSERTELEMENT = 388, | 
|  | SHUFFLEVECTOR = 389 | 
|  | }; | 
|  | #endif | 
|  | /* Tokens.  */ | 
|  | #define ESINT64VAL 258 | 
|  | #define EUINT64VAL 259 | 
|  | #define SINTVAL 260 | 
|  | #define UINTVAL 261 | 
|  | #define FPVAL 262 | 
|  | #define VOID 263 | 
|  | #define BOOL 264 | 
|  | #define INT8 265 | 
|  | #define INT16 266 | 
|  | #define INT32 267 | 
|  | #define INT64 268 | 
|  | #define FLOAT 269 | 
|  | #define DOUBLE 270 | 
|  | #define LABEL 271 | 
|  | #define TYPE 272 | 
|  | #define VAR_ID 273 | 
|  | #define LABELSTR 274 | 
|  | #define STRINGCONSTANT 275 | 
|  | #define IMPLEMENTATION 276 | 
|  | #define ZEROINITIALIZER 277 | 
|  | #define TRUETOK 278 | 
|  | #define FALSETOK 279 | 
|  | #define BEGINTOK 280 | 
|  | #define ENDTOK 281 | 
|  | #define DECLARE 282 | 
|  | #define DEFINE 283 | 
|  | #define GLOBAL 284 | 
|  | #define CONSTANT 285 | 
|  | #define SECTION 286 | 
|  | #define VOLATILE 287 | 
|  | #define TO 288 | 
|  | #define DOTDOTDOT 289 | 
|  | #define NULL_TOK 290 | 
|  | #define UNDEF 291 | 
|  | #define INTERNAL 292 | 
|  | #define LINKONCE 293 | 
|  | #define WEAK 294 | 
|  | #define APPENDING 295 | 
|  | #define DLLIMPORT 296 | 
|  | #define DLLEXPORT 297 | 
|  | #define EXTERN_WEAK 298 | 
|  | #define OPAQUE 299 | 
|  | #define NOT 300 | 
|  | #define EXTERNAL 301 | 
|  | #define TARGET 302 | 
|  | #define TRIPLE 303 | 
|  | #define ENDIAN 304 | 
|  | #define POINTERSIZE 305 | 
|  | #define LITTLE 306 | 
|  | #define BIG 307 | 
|  | #define ALIGN 308 | 
|  | #define DEPLIBS 309 | 
|  | #define CALL 310 | 
|  | #define TAIL 311 | 
|  | #define ASM_TOK 312 | 
|  | #define MODULE 313 | 
|  | #define SIDEEFFECT 314 | 
|  | #define CC_TOK 315 | 
|  | #define CCC_TOK 316 | 
|  | #define CSRETCC_TOK 317 | 
|  | #define FASTCC_TOK 318 | 
|  | #define COLDCC_TOK 319 | 
|  | #define X86_STDCALLCC_TOK 320 | 
|  | #define X86_FASTCALLCC_TOK 321 | 
|  | #define DATALAYOUT 322 | 
|  | #define RET 323 | 
|  | #define BR 324 | 
|  | #define SWITCH 325 | 
|  | #define INVOKE 326 | 
|  | #define UNWIND 327 | 
|  | #define UNREACHABLE 328 | 
|  | #define ADD 329 | 
|  | #define SUB 330 | 
|  | #define MUL 331 | 
|  | #define UDIV 332 | 
|  | #define SDIV 333 | 
|  | #define FDIV 334 | 
|  | #define UREM 335 | 
|  | #define SREM 336 | 
|  | #define FREM 337 | 
|  | #define AND 338 | 
|  | #define OR 339 | 
|  | #define XOR 340 | 
|  | #define ICMP 341 | 
|  | #define FCMP 342 | 
|  | #define EQ 343 | 
|  | #define NE 344 | 
|  | #define SLT 345 | 
|  | #define SGT 346 | 
|  | #define SLE 347 | 
|  | #define SGE 348 | 
|  | #define ULT 349 | 
|  | #define UGT 350 | 
|  | #define ULE 351 | 
|  | #define UGE 352 | 
|  | #define OEQ 353 | 
|  | #define ONE 354 | 
|  | #define OLT 355 | 
|  | #define OGT 356 | 
|  | #define OLE 357 | 
|  | #define OGE 358 | 
|  | #define ORD 359 | 
|  | #define UNO 360 | 
|  | #define UEQ 361 | 
|  | #define UNE 362 | 
|  | #define MALLOC 363 | 
|  | #define ALLOCA 364 | 
|  | #define FREE 365 | 
|  | #define LOAD 366 | 
|  | #define STORE 367 | 
|  | #define GETELEMENTPTR 368 | 
|  | #define TRUNC 369 | 
|  | #define ZEXT 370 | 
|  | #define SEXT 371 | 
|  | #define FPTRUNC 372 | 
|  | #define FPEXT 373 | 
|  | #define BITCAST 374 | 
|  | #define UITOFP 375 | 
|  | #define SITOFP 376 | 
|  | #define FPTOUI 377 | 
|  | #define FPTOSI 378 | 
|  | #define INTTOPTR 379 | 
|  | #define PTRTOINT 380 | 
|  | #define PHI_TOK 381 | 
|  | #define SELECT 382 | 
|  | #define SHL 383 | 
|  | #define LSHR 384 | 
|  | #define ASHR 385 | 
|  | #define VAARG 386 | 
|  | #define EXTRACTELEMENT 387 | 
|  | #define INSERTELEMENT 388 | 
|  | #define SHUFFLEVECTOR 389 | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | /* Copy the first part of user declarations.  */ | 
|  | #line 14 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  |  | 
|  | #include "ParserInternals.h" | 
|  | #include "llvm/CallingConv.h" | 
|  | #include "llvm/InlineAsm.h" | 
|  | #include "llvm/Instructions.h" | 
|  | #include "llvm/Module.h" | 
|  | #include "llvm/SymbolTable.h" | 
|  | #include "llvm/Support/GetElementPtrTypeIterator.h" | 
|  | #include "llvm/Support/CommandLine.h" | 
|  | #include "llvm/ADT/STLExtras.h" | 
|  | #include "llvm/Support/MathExtras.h" | 
|  | #include "llvm/Support/Streams.h" | 
|  | #include <algorithm> | 
|  | #include <list> | 
|  | #include <utility> | 
|  | #ifndef NDEBUG | 
|  | #define YYDEBUG 1 | 
|  | #endif | 
|  |  | 
|  | // The following is a gross hack. In order to rid the libAsmParser library of | 
|  | // exceptions, we have to have a way of getting the yyparse function to go into | 
|  | // an error situation. So, whenever we want an error to occur, the GenerateError | 
|  | // function (see bottom of file) sets TriggerError. Then, at the end of each | 
|  | // production in the grammer we use CHECK_FOR_ERROR which will invoke YYERROR | 
|  | // (a goto) to put YACC in error state. Furthermore, several calls to | 
|  | // GenerateError are made from inside productions and they must simulate the | 
|  | // previous exception behavior by exiting the production immediately. We have | 
|  | // replaced these with the GEN_ERROR macro which calls GeneratError and then | 
|  | // immediately invokes YYERROR. This would be so much cleaner if it was a | 
|  | // recursive descent parser. | 
|  | static bool TriggerError = false; | 
|  | #define CHECK_FOR_ERROR { if (TriggerError) { TriggerError = false; YYABORT; } } | 
|  | #define GEN_ERROR(msg) { GenerateError(msg); YYERROR; } | 
|  |  | 
|  | int yyerror(const char *ErrorMsg); // Forward declarations to prevent "implicit | 
|  | int yylex();                       // declaration" of xxx warnings. | 
|  | int yyparse(); | 
|  |  | 
|  | namespace llvm { | 
|  | std::string CurFilename; | 
|  | #if YYDEBUG | 
|  | static cl::opt<bool> | 
|  | Debug("debug-yacc", cl::desc("Print yacc debug state changes"), | 
|  | cl::Hidden, cl::init(false)); | 
|  | #endif | 
|  | } | 
|  | using namespace llvm; | 
|  |  | 
|  | static Module *ParserResult; | 
|  |  | 
|  | // DEBUG_UPREFS - Define this symbol if you want to enable debugging output | 
|  | // relating to upreferences in the input stream. | 
|  | // | 
|  | //#define DEBUG_UPREFS 1 | 
|  | #ifdef DEBUG_UPREFS | 
|  | #define UR_OUT(X) cerr << X | 
|  | #else | 
|  | #define UR_OUT(X) | 
|  | #endif | 
|  |  | 
|  | #define YYERROR_VERBOSE 1 | 
|  |  | 
|  | static GlobalVariable *CurGV; | 
|  |  | 
|  |  | 
|  | // This contains info used when building the body of a function.  It is | 
|  | // destroyed when the function is completed. | 
|  | // | 
|  | typedef std::vector<Value *> ValueList;           // Numbered defs | 
|  |  | 
|  | static void | 
|  | ResolveDefinitions(std::map<const Type *,ValueList> &LateResolvers, | 
|  | std::map<const Type *,ValueList> *FutureLateResolvers = 0); | 
|  |  | 
|  | static struct PerModuleInfo { | 
|  | Module *CurrentModule; | 
|  | std::map<const Type *, ValueList> Values; // Module level numbered definitions | 
|  | std::map<const Type *,ValueList> LateResolveValues; | 
|  | std::vector<PATypeHolder>    Types; | 
|  | std::map<ValID, PATypeHolder> LateResolveTypes; | 
|  |  | 
|  | /// PlaceHolderInfo - When temporary placeholder objects are created, remember | 
|  | /// how they were referenced and on which line of the input they came from so | 
|  | /// that we can resolve them later and print error messages as appropriate. | 
|  | std::map<Value*, std::pair<ValID, int> > PlaceHolderInfo; | 
|  |  | 
|  | // GlobalRefs - This maintains a mapping between <Type, ValID>'s and forward | 
|  | // references to global values.  Global values may be referenced before they | 
|  | // are defined, and if so, the temporary object that they represent is held | 
|  | // here.  This is used for forward references of GlobalValues. | 
|  | // | 
|  | typedef std::map<std::pair<const PointerType *, | 
|  | ValID>, GlobalValue*> GlobalRefsType; | 
|  | GlobalRefsType GlobalRefs; | 
|  |  | 
|  | void ModuleDone() { | 
|  | // If we could not resolve some functions at function compilation time | 
|  | // (calls to functions before they are defined), resolve them now...  Types | 
|  | // are resolved when the constant pool has been completely parsed. | 
|  | // | 
|  | ResolveDefinitions(LateResolveValues); | 
|  | if (TriggerError) | 
|  | return; | 
|  |  | 
|  | // Check to make sure that all global value forward references have been | 
|  | // resolved! | 
|  | // | 
|  | if (!GlobalRefs.empty()) { | 
|  | std::string UndefinedReferences = "Unresolved global references exist:\n"; | 
|  |  | 
|  | for (GlobalRefsType::iterator I = GlobalRefs.begin(), E =GlobalRefs.end(); | 
|  | I != E; ++I) { | 
|  | UndefinedReferences += "  " + I->first.first->getDescription() + " " + | 
|  | I->first.second.getName() + "\n"; | 
|  | } | 
|  | GenerateError(UndefinedReferences); | 
|  | return; | 
|  | } | 
|  |  | 
|  | Values.clear();         // Clear out function local definitions | 
|  | Types.clear(); | 
|  | CurrentModule = 0; | 
|  | } | 
|  |  | 
|  | // GetForwardRefForGlobal - Check to see if there is a forward reference | 
|  | // for this global.  If so, remove it from the GlobalRefs map and return it. | 
|  | // If not, just return null. | 
|  | GlobalValue *GetForwardRefForGlobal(const PointerType *PTy, ValID ID) { | 
|  | // Check to see if there is a forward reference to this global variable... | 
|  | // if there is, eliminate it and patch the reference to use the new def'n. | 
|  | GlobalRefsType::iterator I = GlobalRefs.find(std::make_pair(PTy, ID)); | 
|  | GlobalValue *Ret = 0; | 
|  | if (I != GlobalRefs.end()) { | 
|  | Ret = I->second; | 
|  | GlobalRefs.erase(I); | 
|  | } | 
|  | return Ret; | 
|  | } | 
|  |  | 
|  | bool TypeIsUnresolved(PATypeHolder* PATy) { | 
|  | // If it isn't abstract, its resolved | 
|  | const Type* Ty = PATy->get(); | 
|  | if (!Ty->isAbstract()) | 
|  | return false; | 
|  | // Traverse the type looking for abstract types. If it isn't abstract then | 
|  | // we don't need to traverse that leg of the type. | 
|  | std::vector<const Type*> WorkList, SeenList; | 
|  | WorkList.push_back(Ty); | 
|  | while (!WorkList.empty()) { | 
|  | const Type* Ty = WorkList.back(); | 
|  | SeenList.push_back(Ty); | 
|  | WorkList.pop_back(); | 
|  | if (const OpaqueType* OpTy = dyn_cast<OpaqueType>(Ty)) { | 
|  | // Check to see if this is an unresolved type | 
|  | std::map<ValID, PATypeHolder>::iterator I = LateResolveTypes.begin(); | 
|  | std::map<ValID, PATypeHolder>::iterator E = LateResolveTypes.end(); | 
|  | for ( ; I != E; ++I) { | 
|  | if (I->second.get() == OpTy) | 
|  | return true; | 
|  | } | 
|  | } else if (const SequentialType* SeqTy = dyn_cast<SequentialType>(Ty)) { | 
|  | const Type* TheTy = SeqTy->getElementType(); | 
|  | if (TheTy->isAbstract() && TheTy != Ty) { | 
|  | std::vector<const Type*>::iterator I = SeenList.begin(), | 
|  | E = SeenList.end(); | 
|  | for ( ; I != E; ++I) | 
|  | if (*I == TheTy) | 
|  | break; | 
|  | if (I == E) | 
|  | WorkList.push_back(TheTy); | 
|  | } | 
|  | } else if (const StructType* StrTy = dyn_cast<StructType>(Ty)) { | 
|  | for (unsigned i = 0; i < StrTy->getNumElements(); ++i) { | 
|  | const Type* TheTy = StrTy->getElementType(i); | 
|  | if (TheTy->isAbstract() && TheTy != Ty) { | 
|  | std::vector<const Type*>::iterator I = SeenList.begin(), | 
|  | E = SeenList.end(); | 
|  | for ( ; I != E; ++I) | 
|  | if (*I == TheTy) | 
|  | break; | 
|  | if (I == E) | 
|  | WorkList.push_back(TheTy); | 
|  | } | 
|  | } | 
|  | } | 
|  | } | 
|  | return false; | 
|  | } | 
|  |  | 
|  |  | 
|  | } CurModule; | 
|  |  | 
|  | static struct PerFunctionInfo { | 
|  | Function *CurrentFunction;     // Pointer to current function being created | 
|  |  | 
|  | std::map<const Type*, ValueList> Values; // Keep track of #'d definitions | 
|  | std::map<const Type*, ValueList> LateResolveValues; | 
|  | bool isDeclare;                    // Is this function a forward declararation? | 
|  | GlobalValue::LinkageTypes Linkage; // Linkage for forward declaration. | 
|  |  | 
|  | /// BBForwardRefs - When we see forward references to basic blocks, keep | 
|  | /// track of them here. | 
|  | std::map<BasicBlock*, std::pair<ValID, int> > BBForwardRefs; | 
|  | std::vector<BasicBlock*> NumberedBlocks; | 
|  | unsigned NextBBNum; | 
|  |  | 
|  | inline PerFunctionInfo() { | 
|  | CurrentFunction = 0; | 
|  | isDeclare = false; | 
|  | Linkage = GlobalValue::ExternalLinkage; | 
|  | } | 
|  |  | 
|  | inline void FunctionStart(Function *M) { | 
|  | CurrentFunction = M; | 
|  | NextBBNum = 0; | 
|  | } | 
|  |  | 
|  | void FunctionDone() { | 
|  | NumberedBlocks.clear(); | 
|  |  | 
|  | // Any forward referenced blocks left? | 
|  | if (!BBForwardRefs.empty()) { | 
|  | GenerateError("Undefined reference to label " + | 
|  | BBForwardRefs.begin()->first->getName()); | 
|  | return; | 
|  | } | 
|  |  | 
|  | // Resolve all forward references now. | 
|  | ResolveDefinitions(LateResolveValues, &CurModule.LateResolveValues); | 
|  |  | 
|  | Values.clear();         // Clear out function local definitions | 
|  | CurrentFunction = 0; | 
|  | isDeclare = false; | 
|  | Linkage = GlobalValue::ExternalLinkage; | 
|  | } | 
|  | } CurFun;  // Info for the current function... | 
|  |  | 
|  | static bool inFunctionScope() { return CurFun.CurrentFunction != 0; } | 
|  |  | 
|  |  | 
|  | //===----------------------------------------------------------------------===// | 
|  | //               Code to handle definitions of all the types | 
|  | //===----------------------------------------------------------------------===// | 
|  |  | 
|  | static int InsertValue(Value *V, | 
|  | std::map<const Type*,ValueList> &ValueTab = CurFun.Values) { | 
|  | if (V->hasName()) return -1;           // Is this a numbered definition? | 
|  |  | 
|  | // Yes, insert the value into the value table... | 
|  | ValueList &List = ValueTab[V->getType()]; | 
|  | List.push_back(V); | 
|  | return List.size()-1; | 
|  | } | 
|  |  | 
|  | static const Type *getTypeVal(const ValID &D, bool DoNotImprovise = false) { | 
|  | switch (D.Type) { | 
|  | case ValID::NumberVal:               // Is it a numbered definition? | 
|  | // Module constants occupy the lowest numbered slots... | 
|  | if ((unsigned)D.Num < CurModule.Types.size()) | 
|  | return CurModule.Types[(unsigned)D.Num]; | 
|  | break; | 
|  | case ValID::NameVal:                 // Is it a named definition? | 
|  | if (const Type *N = CurModule.CurrentModule->getTypeByName(D.Name)) { | 
|  | D.destroy();  // Free old strdup'd memory... | 
|  | return N; | 
|  | } | 
|  | break; | 
|  | default: | 
|  | GenerateError("Internal parser error: Invalid symbol type reference!"); | 
|  | return 0; | 
|  | } | 
|  |  | 
|  | // If we reached here, we referenced either a symbol that we don't know about | 
|  | // or an id number that hasn't been read yet.  We may be referencing something | 
|  | // forward, so just create an entry to be resolved later and get to it... | 
|  | // | 
|  | if (DoNotImprovise) return 0;  // Do we just want a null to be returned? | 
|  |  | 
|  |  | 
|  | if (inFunctionScope()) { | 
|  | if (D.Type == ValID::NameVal) { | 
|  | GenerateError("Reference to an undefined type: '" + D.getName() + "'"); | 
|  | return 0; | 
|  | } else { | 
|  | GenerateError("Reference to an undefined type: #" + itostr(D.Num)); | 
|  | return 0; | 
|  | } | 
|  | } | 
|  |  | 
|  | std::map<ValID, PATypeHolder>::iterator I =CurModule.LateResolveTypes.find(D); | 
|  | if (I != CurModule.LateResolveTypes.end()) | 
|  | return I->second; | 
|  |  | 
|  | Type *Typ = OpaqueType::get(); | 
|  | CurModule.LateResolveTypes.insert(std::make_pair(D, Typ)); | 
|  | return Typ; | 
|  | } | 
|  |  | 
|  | static Value *lookupInSymbolTable(const Type *Ty, const std::string &Name) { | 
|  | SymbolTable &SymTab = | 
|  | inFunctionScope() ? CurFun.CurrentFunction->getSymbolTable() : | 
|  | CurModule.CurrentModule->getSymbolTable(); | 
|  | return SymTab.lookup(Ty, Name); | 
|  | } | 
|  |  | 
|  | // getValNonImprovising - Look up the value specified by the provided type and | 
|  | // the provided ValID.  If the value exists and has already been defined, return | 
|  | // it.  Otherwise return null. | 
|  | // | 
|  | static Value *getValNonImprovising(const Type *Ty, const ValID &D) { | 
|  | if (isa<FunctionType>(Ty)) { | 
|  | GenerateError("Functions are not values and " | 
|  | "must be referenced as pointers"); | 
|  | return 0; | 
|  | } | 
|  |  | 
|  | switch (D.Type) { | 
|  | case ValID::NumberVal: {                 // Is it a numbered definition? | 
|  | unsigned Num = (unsigned)D.Num; | 
|  |  | 
|  | // Module constants occupy the lowest numbered slots... | 
|  | std::map<const Type*,ValueList>::iterator VI = CurModule.Values.find(Ty); | 
|  | if (VI != CurModule.Values.end()) { | 
|  | if (Num < VI->second.size()) | 
|  | return VI->second[Num]; | 
|  | Num -= VI->second.size(); | 
|  | } | 
|  |  | 
|  | // Make sure that our type is within bounds | 
|  | VI = CurFun.Values.find(Ty); | 
|  | if (VI == CurFun.Values.end()) return 0; | 
|  |  | 
|  | // Check that the number is within bounds... | 
|  | if (VI->second.size() <= Num) return 0; | 
|  |  | 
|  | return VI->second[Num]; | 
|  | } | 
|  |  | 
|  | case ValID::NameVal: {                // Is it a named definition? | 
|  | Value *N = lookupInSymbolTable(Ty, std::string(D.Name)); | 
|  | if (N == 0) return 0; | 
|  |  | 
|  | D.destroy();  // Free old strdup'd memory... | 
|  | return N; | 
|  | } | 
|  |  | 
|  | // Check to make sure that "Ty" is an integral type, and that our | 
|  | // value will fit into the specified type... | 
|  | case ValID::ConstSIntVal:    // Is it a constant pool reference?? | 
|  | if (!ConstantInt::isValueValidForType(Ty, D.ConstPool64)) { | 
|  | GenerateError("Signed integral constant '" + | 
|  | itostr(D.ConstPool64) + "' is invalid for type '" + | 
|  | Ty->getDescription() + "'!"); | 
|  | return 0; | 
|  | } | 
|  | return ConstantInt::get(Ty, D.ConstPool64); | 
|  |  | 
|  | case ValID::ConstUIntVal:     // Is it an unsigned const pool reference? | 
|  | if (!ConstantInt::isValueValidForType(Ty, D.UConstPool64)) { | 
|  | if (!ConstantInt::isValueValidForType(Ty, D.ConstPool64)) { | 
|  | GenerateError("Integral constant '" + utostr(D.UConstPool64) + | 
|  | "' is invalid or out of range!"); | 
|  | return 0; | 
|  | } else {     // This is really a signed reference.  Transmogrify. | 
|  | return ConstantInt::get(Ty, D.ConstPool64); | 
|  | } | 
|  | } else { | 
|  | return ConstantInt::get(Ty, D.UConstPool64); | 
|  | } | 
|  |  | 
|  | case ValID::ConstFPVal:        // Is it a floating point const pool reference? | 
|  | if (!ConstantFP::isValueValidForType(Ty, D.ConstPoolFP)) { | 
|  | GenerateError("FP constant invalid for type!!"); | 
|  | return 0; | 
|  | } | 
|  | return ConstantFP::get(Ty, D.ConstPoolFP); | 
|  |  | 
|  | case ValID::ConstNullVal:      // Is it a null value? | 
|  | if (!isa<PointerType>(Ty)) { | 
|  | GenerateError("Cannot create a a non pointer null!"); | 
|  | return 0; | 
|  | } | 
|  | return ConstantPointerNull::get(cast<PointerType>(Ty)); | 
|  |  | 
|  | case ValID::ConstUndefVal:      // Is it an undef value? | 
|  | return UndefValue::get(Ty); | 
|  |  | 
|  | case ValID::ConstZeroVal:      // Is it a zero value? | 
|  | return Constant::getNullValue(Ty); | 
|  |  | 
|  | case ValID::ConstantVal:       // Fully resolved constant? | 
|  | if (D.ConstantValue->getType() != Ty) { | 
|  | GenerateError("Constant expression type different from required type!"); | 
|  | return 0; | 
|  | } | 
|  | return D.ConstantValue; | 
|  |  | 
|  | case ValID::InlineAsmVal: {    // Inline asm expression | 
|  | const PointerType *PTy = dyn_cast<PointerType>(Ty); | 
|  | const FunctionType *FTy = | 
|  | PTy ? dyn_cast<FunctionType>(PTy->getElementType()) : 0; | 
|  | if (!FTy || !InlineAsm::Verify(FTy, D.IAD->Constraints)) { | 
|  | GenerateError("Invalid type for asm constraint string!"); | 
|  | return 0; | 
|  | } | 
|  | InlineAsm *IA = InlineAsm::get(FTy, D.IAD->AsmString, D.IAD->Constraints, | 
|  | D.IAD->HasSideEffects); | 
|  | D.destroy();   // Free InlineAsmDescriptor. | 
|  | return IA; | 
|  | } | 
|  | default: | 
|  | assert(0 && "Unhandled case!"); | 
|  | return 0; | 
|  | }   // End of switch | 
|  |  | 
|  | assert(0 && "Unhandled case!"); | 
|  | return 0; | 
|  | } | 
|  |  | 
|  | // getVal - This function is identical to getValNonImprovising, except that if a | 
|  | // value is not already defined, it "improvises" by creating a placeholder var | 
|  | // that looks and acts just like the requested variable.  When the value is | 
|  | // defined later, all uses of the placeholder variable are replaced with the | 
|  | // real thing. | 
|  | // | 
|  | static Value *getVal(const Type *Ty, const ValID &ID) { | 
|  | if (Ty == Type::LabelTy) { | 
|  | GenerateError("Cannot use a basic block here"); | 
|  | return 0; | 
|  | } | 
|  |  | 
|  | // See if the value has already been defined. | 
|  | Value *V = getValNonImprovising(Ty, ID); | 
|  | if (V) return V; | 
|  | if (TriggerError) return 0; | 
|  |  | 
|  | if (!Ty->isFirstClassType() && !isa<OpaqueType>(Ty)) { | 
|  | GenerateError("Invalid use of a composite type!"); | 
|  | return 0; | 
|  | } | 
|  |  | 
|  | // If we reached here, we referenced either a symbol that we don't know about | 
|  | // or an id number that hasn't been read yet.  We may be referencing something | 
|  | // forward, so just create an entry to be resolved later and get to it... | 
|  | // | 
|  | V = new Argument(Ty); | 
|  |  | 
|  | // Remember where this forward reference came from.  FIXME, shouldn't we try | 
|  | // to recycle these things?? | 
|  | CurModule.PlaceHolderInfo.insert(std::make_pair(V, std::make_pair(ID, | 
|  | llvmAsmlineno))); | 
|  |  | 
|  | if (inFunctionScope()) | 
|  | InsertValue(V, CurFun.LateResolveValues); | 
|  | else | 
|  | InsertValue(V, CurModule.LateResolveValues); | 
|  | return V; | 
|  | } | 
|  |  | 
|  | /// getBBVal - This is used for two purposes: | 
|  | ///  * If isDefinition is true, a new basic block with the specified ID is being | 
|  | ///    defined. | 
|  | ///  * If isDefinition is true, this is a reference to a basic block, which may | 
|  | ///    or may not be a forward reference. | 
|  | /// | 
|  | static BasicBlock *getBBVal(const ValID &ID, bool isDefinition = false) { | 
|  | assert(inFunctionScope() && "Can't get basic block at global scope!"); | 
|  |  | 
|  | std::string Name; | 
|  | BasicBlock *BB = 0; | 
|  | switch (ID.Type) { | 
|  | default: | 
|  | GenerateError("Illegal label reference " + ID.getName()); | 
|  | return 0; | 
|  | case ValID::NumberVal:                // Is it a numbered definition? | 
|  | if (unsigned(ID.Num) >= CurFun.NumberedBlocks.size()) | 
|  | CurFun.NumberedBlocks.resize(ID.Num+1); | 
|  | BB = CurFun.NumberedBlocks[ID.Num]; | 
|  | break; | 
|  | case ValID::NameVal:                  // Is it a named definition? | 
|  | Name = ID.Name; | 
|  | if (Value *N = CurFun.CurrentFunction-> | 
|  | getSymbolTable().lookup(Type::LabelTy, Name)) | 
|  | BB = cast<BasicBlock>(N); | 
|  | break; | 
|  | } | 
|  |  | 
|  | // See if the block has already been defined. | 
|  | if (BB) { | 
|  | // If this is the definition of the block, make sure the existing value was | 
|  | // just a forward reference.  If it was a forward reference, there will be | 
|  | // an entry for it in the PlaceHolderInfo map. | 
|  | if (isDefinition && !CurFun.BBForwardRefs.erase(BB)) { | 
|  | // The existing value was a definition, not a forward reference. | 
|  | GenerateError("Redefinition of label " + ID.getName()); | 
|  | return 0; | 
|  | } | 
|  |  | 
|  | ID.destroy();                       // Free strdup'd memory. | 
|  | return BB; | 
|  | } | 
|  |  | 
|  | // Otherwise this block has not been seen before. | 
|  | BB = new BasicBlock("", CurFun.CurrentFunction); | 
|  | if (ID.Type == ValID::NameVal) { | 
|  | BB->setName(ID.Name); | 
|  | } else { | 
|  | CurFun.NumberedBlocks[ID.Num] = BB; | 
|  | } | 
|  |  | 
|  | // If this is not a definition, keep track of it so we can use it as a forward | 
|  | // reference. | 
|  | if (!isDefinition) { | 
|  | // Remember where this forward reference came from. | 
|  | CurFun.BBForwardRefs[BB] = std::make_pair(ID, llvmAsmlineno); | 
|  | } else { | 
|  | // The forward declaration could have been inserted anywhere in the | 
|  | // function: insert it into the correct place now. | 
|  | CurFun.CurrentFunction->getBasicBlockList().remove(BB); | 
|  | CurFun.CurrentFunction->getBasicBlockList().push_back(BB); | 
|  | } | 
|  | ID.destroy(); | 
|  | return BB; | 
|  | } | 
|  |  | 
|  |  | 
|  | //===----------------------------------------------------------------------===// | 
|  | //              Code to handle forward references in instructions | 
|  | //===----------------------------------------------------------------------===// | 
|  | // | 
|  | // This code handles the late binding needed with statements that reference | 
|  | // values not defined yet... for example, a forward branch, or the PHI node for | 
|  | // a loop body. | 
|  | // | 
|  | // This keeps a table (CurFun.LateResolveValues) of all such forward references | 
|  | // and back patchs after we are done. | 
|  | // | 
|  |  | 
|  | // ResolveDefinitions - If we could not resolve some defs at parsing | 
|  | // time (forward branches, phi functions for loops, etc...) resolve the | 
|  | // defs now... | 
|  | // | 
|  | static void | 
|  | ResolveDefinitions(std::map<const Type*,ValueList> &LateResolvers, | 
|  | std::map<const Type*,ValueList> *FutureLateResolvers) { | 
|  | // Loop over LateResolveDefs fixing up stuff that couldn't be resolved | 
|  | for (std::map<const Type*,ValueList>::iterator LRI = LateResolvers.begin(), | 
|  | E = LateResolvers.end(); LRI != E; ++LRI) { | 
|  | ValueList &List = LRI->second; | 
|  | while (!List.empty()) { | 
|  | Value *V = List.back(); | 
|  | List.pop_back(); | 
|  |  | 
|  | std::map<Value*, std::pair<ValID, int> >::iterator PHI = | 
|  | CurModule.PlaceHolderInfo.find(V); | 
|  | assert(PHI != CurModule.PlaceHolderInfo.end() && "Placeholder error!"); | 
|  |  | 
|  | ValID &DID = PHI->second.first; | 
|  |  | 
|  | Value *TheRealValue = getValNonImprovising(LRI->first, DID); | 
|  | if (TriggerError) | 
|  | return; | 
|  | if (TheRealValue) { | 
|  | V->replaceAllUsesWith(TheRealValue); | 
|  | delete V; | 
|  | CurModule.PlaceHolderInfo.erase(PHI); | 
|  | } else if (FutureLateResolvers) { | 
|  | // Functions have their unresolved items forwarded to the module late | 
|  | // resolver table | 
|  | InsertValue(V, *FutureLateResolvers); | 
|  | } else { | 
|  | if (DID.Type == ValID::NameVal) { | 
|  | GenerateError("Reference to an invalid definition: '" +DID.getName()+ | 
|  | "' of type '" + V->getType()->getDescription() + "'", | 
|  | PHI->second.second); | 
|  | return; | 
|  | } else { | 
|  | GenerateError("Reference to an invalid definition: #" + | 
|  | itostr(DID.Num) + " of type '" + | 
|  | V->getType()->getDescription() + "'", | 
|  | PHI->second.second); | 
|  | return; | 
|  | } | 
|  | } | 
|  | } | 
|  | } | 
|  |  | 
|  | LateResolvers.clear(); | 
|  | } | 
|  |  | 
|  | // ResolveTypeTo - A brand new type was just declared.  This means that (if | 
|  | // name is not null) things referencing Name can be resolved.  Otherwise, things | 
|  | // refering to the number can be resolved.  Do this now. | 
|  | // | 
|  | static void ResolveTypeTo(char *Name, const Type *ToTy) { | 
|  | ValID D; | 
|  | if (Name) D = ValID::create(Name); | 
|  | else      D = ValID::create((int)CurModule.Types.size()); | 
|  |  | 
|  | std::map<ValID, PATypeHolder>::iterator I = | 
|  | CurModule.LateResolveTypes.find(D); | 
|  | if (I != CurModule.LateResolveTypes.end()) { | 
|  | ((DerivedType*)I->second.get())->refineAbstractTypeTo(ToTy); | 
|  | CurModule.LateResolveTypes.erase(I); | 
|  | } | 
|  | } | 
|  |  | 
|  | // setValueName - Set the specified value to the name given.  The name may be | 
|  | // null potentially, in which case this is a noop.  The string passed in is | 
|  | // assumed to be a malloc'd string buffer, and is free'd by this function. | 
|  | // | 
|  | static void setValueName(Value *V, char *NameStr) { | 
|  | if (NameStr) { | 
|  | std::string Name(NameStr);      // Copy string | 
|  | free(NameStr);                  // Free old string | 
|  |  | 
|  | if (V->getType() == Type::VoidTy) { | 
|  | GenerateError("Can't assign name '" + Name+"' to value with void type!"); | 
|  | return; | 
|  | } | 
|  |  | 
|  | assert(inFunctionScope() && "Must be in function scope!"); | 
|  | SymbolTable &ST = CurFun.CurrentFunction->getSymbolTable(); | 
|  | if (ST.lookup(V->getType(), Name)) { | 
|  | GenerateError("Redefinition of value named '" + Name + "' in the '" + | 
|  | V->getType()->getDescription() + "' type plane!"); | 
|  | return; | 
|  | } | 
|  |  | 
|  | // Set the name. | 
|  | V->setName(Name); | 
|  | } | 
|  | } | 
|  |  | 
|  | /// ParseGlobalVariable - Handle parsing of a global.  If Initializer is null, | 
|  | /// this is a declaration, otherwise it is a definition. | 
|  | static GlobalVariable * | 
|  | ParseGlobalVariable(char *NameStr,GlobalValue::LinkageTypes Linkage, | 
|  | bool isConstantGlobal, const Type *Ty, | 
|  | Constant *Initializer) { | 
|  | if (isa<FunctionType>(Ty)) { | 
|  | GenerateError("Cannot declare global vars of function type!"); | 
|  | return 0; | 
|  | } | 
|  |  | 
|  | const PointerType *PTy = PointerType::get(Ty); | 
|  |  | 
|  | std::string Name; | 
|  | if (NameStr) { | 
|  | Name = NameStr;      // Copy string | 
|  | free(NameStr);       // Free old string | 
|  | } | 
|  |  | 
|  | // See if this global value was forward referenced.  If so, recycle the | 
|  | // object. | 
|  | ValID ID; | 
|  | if (!Name.empty()) { | 
|  | ID = ValID::create((char*)Name.c_str()); | 
|  | } else { | 
|  | ID = ValID::create((int)CurModule.Values[PTy].size()); | 
|  | } | 
|  |  | 
|  | if (GlobalValue *FWGV = CurModule.GetForwardRefForGlobal(PTy, ID)) { | 
|  | // Move the global to the end of the list, from whereever it was | 
|  | // previously inserted. | 
|  | GlobalVariable *GV = cast<GlobalVariable>(FWGV); | 
|  | CurModule.CurrentModule->getGlobalList().remove(GV); | 
|  | CurModule.CurrentModule->getGlobalList().push_back(GV); | 
|  | GV->setInitializer(Initializer); | 
|  | GV->setLinkage(Linkage); | 
|  | GV->setConstant(isConstantGlobal); | 
|  | InsertValue(GV, CurModule.Values); | 
|  | return GV; | 
|  | } | 
|  |  | 
|  | // If this global has a name, check to see if there is already a definition | 
|  | // of this global in the module.  If so, merge as appropriate.  Note that | 
|  | // this is really just a hack around problems in the CFE.  :( | 
|  | if (!Name.empty()) { | 
|  | // We are a simple redefinition of a value, check to see if it is defined | 
|  | // the same as the old one. | 
|  | if (GlobalVariable *EGV = | 
|  | CurModule.CurrentModule->getGlobalVariable(Name, Ty)) { | 
|  | // We are allowed to redefine a global variable in two circumstances: | 
|  | // 1. If at least one of the globals is uninitialized or | 
|  | // 2. If both initializers have the same value. | 
|  | // | 
|  | if (!EGV->hasInitializer() || !Initializer || | 
|  | EGV->getInitializer() == Initializer) { | 
|  |  | 
|  | // Make sure the existing global version gets the initializer!  Make | 
|  | // sure that it also gets marked const if the new version is. | 
|  | if (Initializer && !EGV->hasInitializer()) | 
|  | EGV->setInitializer(Initializer); | 
|  | if (isConstantGlobal) | 
|  | EGV->setConstant(true); | 
|  | EGV->setLinkage(Linkage); | 
|  | return EGV; | 
|  | } | 
|  |  | 
|  | GenerateError("Redefinition of global variable named '" + Name + | 
|  | "' in the '" + Ty->getDescription() + "' type plane!"); | 
|  | return 0; | 
|  | } | 
|  | } | 
|  |  | 
|  | // Otherwise there is no existing GV to use, create one now. | 
|  | GlobalVariable *GV = | 
|  | new GlobalVariable(Ty, isConstantGlobal, Linkage, Initializer, Name, | 
|  | CurModule.CurrentModule); | 
|  | InsertValue(GV, CurModule.Values); | 
|  | return GV; | 
|  | } | 
|  |  | 
|  | // setTypeName - Set the specified type to the name given.  The name may be | 
|  | // null potentially, in which case this is a noop.  The string passed in is | 
|  | // assumed to be a malloc'd string buffer, and is freed by this function. | 
|  | // | 
|  | // This function returns true if the type has already been defined, but is | 
|  | // allowed to be redefined in the specified context.  If the name is a new name | 
|  | // for the type plane, it is inserted and false is returned. | 
|  | static bool setTypeName(const Type *T, char *NameStr) { | 
|  | assert(!inFunctionScope() && "Can't give types function-local names!"); | 
|  | if (NameStr == 0) return false; | 
|  |  | 
|  | std::string Name(NameStr);      // Copy string | 
|  | free(NameStr);                  // Free old string | 
|  |  | 
|  | // We don't allow assigning names to void type | 
|  | if (T == Type::VoidTy) { | 
|  | GenerateError("Can't assign name '" + Name + "' to the void type!"); | 
|  | return false; | 
|  | } | 
|  |  | 
|  | // Set the type name, checking for conflicts as we do so. | 
|  | bool AlreadyExists = CurModule.CurrentModule->addTypeName(Name, T); | 
|  |  | 
|  | if (AlreadyExists) {   // Inserting a name that is already defined??? | 
|  | const Type *Existing = CurModule.CurrentModule->getTypeByName(Name); | 
|  | assert(Existing && "Conflict but no matching type?"); | 
|  |  | 
|  | // There is only one case where this is allowed: when we are refining an | 
|  | // opaque type.  In this case, Existing will be an opaque type. | 
|  | if (const OpaqueType *OpTy = dyn_cast<OpaqueType>(Existing)) { | 
|  | // We ARE replacing an opaque type! | 
|  | const_cast<OpaqueType*>(OpTy)->refineAbstractTypeTo(T); | 
|  | return true; | 
|  | } | 
|  |  | 
|  | // Otherwise, this is an attempt to redefine a type. That's okay if | 
|  | // the redefinition is identical to the original. This will be so if | 
|  | // Existing and T point to the same Type object. In this one case we | 
|  | // allow the equivalent redefinition. | 
|  | if (Existing == T) return true;  // Yes, it's equal. | 
|  |  | 
|  | // Any other kind of (non-equivalent) redefinition is an error. | 
|  | GenerateError("Redefinition of type named '" + Name + "' in the '" + | 
|  | T->getDescription() + "' type plane!"); | 
|  | } | 
|  |  | 
|  | return false; | 
|  | } | 
|  |  | 
|  | //===----------------------------------------------------------------------===// | 
|  | // Code for handling upreferences in type names... | 
|  | // | 
|  |  | 
|  | // TypeContains - Returns true if Ty directly contains E in it. | 
|  | // | 
|  | static bool TypeContains(const Type *Ty, const Type *E) { | 
|  | return std::find(Ty->subtype_begin(), Ty->subtype_end(), | 
|  | E) != Ty->subtype_end(); | 
|  | } | 
|  |  | 
|  | namespace { | 
|  | struct UpRefRecord { | 
|  | // NestingLevel - The number of nesting levels that need to be popped before | 
|  | // this type is resolved. | 
|  | unsigned NestingLevel; | 
|  |  | 
|  | // LastContainedTy - This is the type at the current binding level for the | 
|  | // type.  Every time we reduce the nesting level, this gets updated. | 
|  | const Type *LastContainedTy; | 
|  |  | 
|  | // UpRefTy - This is the actual opaque type that the upreference is | 
|  | // represented with. | 
|  | OpaqueType *UpRefTy; | 
|  |  | 
|  | UpRefRecord(unsigned NL, OpaqueType *URTy) | 
|  | : NestingLevel(NL), LastContainedTy(URTy), UpRefTy(URTy) {} | 
|  | }; | 
|  | } | 
|  |  | 
|  | // UpRefs - A list of the outstanding upreferences that need to be resolved. | 
|  | static std::vector<UpRefRecord> UpRefs; | 
|  |  | 
|  | /// HandleUpRefs - Every time we finish a new layer of types, this function is | 
|  | /// called.  It loops through the UpRefs vector, which is a list of the | 
|  | /// currently active types.  For each type, if the up reference is contained in | 
|  | /// the newly completed type, we decrement the level count.  When the level | 
|  | /// count reaches zero, the upreferenced type is the type that is passed in: | 
|  | /// thus we can complete the cycle. | 
|  | /// | 
|  | static PATypeHolder HandleUpRefs(const Type *ty) { | 
|  | // If Ty isn't abstract, or if there are no up-references in it, then there is | 
|  | // nothing to resolve here. | 
|  | if (!ty->isAbstract() || UpRefs.empty()) return ty; | 
|  |  | 
|  | PATypeHolder Ty(ty); | 
|  | UR_OUT("Type '" << Ty->getDescription() << | 
|  | "' newly formed.  Resolving upreferences.\n" << | 
|  | UpRefs.size() << " upreferences active!\n"); | 
|  |  | 
|  | // If we find any resolvable upreferences (i.e., those whose NestingLevel goes | 
|  | // to zero), we resolve them all together before we resolve them to Ty.  At | 
|  | // the end of the loop, if there is anything to resolve to Ty, it will be in | 
|  | // this variable. | 
|  | OpaqueType *TypeToResolve = 0; | 
|  |  | 
|  | for (unsigned i = 0; i != UpRefs.size(); ++i) { | 
|  | UR_OUT("  UR#" << i << " - TypeContains(" << Ty->getDescription() << ", " | 
|  | << UpRefs[i].second->getDescription() << ") = " | 
|  | << (TypeContains(Ty, UpRefs[i].second) ? "true" : "false") << "\n"); | 
|  | if (TypeContains(Ty, UpRefs[i].LastContainedTy)) { | 
|  | // Decrement level of upreference | 
|  | unsigned Level = --UpRefs[i].NestingLevel; | 
|  | UpRefs[i].LastContainedTy = Ty; | 
|  | UR_OUT("  Uplevel Ref Level = " << Level << "\n"); | 
|  | if (Level == 0) {                     // Upreference should be resolved! | 
|  | if (!TypeToResolve) { | 
|  | TypeToResolve = UpRefs[i].UpRefTy; | 
|  | } else { | 
|  | UR_OUT("  * Resolving upreference for " | 
|  | << UpRefs[i].second->getDescription() << "\n"; | 
|  | std::string OldName = UpRefs[i].UpRefTy->getDescription()); | 
|  | UpRefs[i].UpRefTy->refineAbstractTypeTo(TypeToResolve); | 
|  | UR_OUT("  * Type '" << OldName << "' refined upreference to: " | 
|  | << (const void*)Ty << ", " << Ty->getDescription() << "\n"); | 
|  | } | 
|  | UpRefs.erase(UpRefs.begin()+i);     // Remove from upreference list... | 
|  | --i;                                // Do not skip the next element... | 
|  | } | 
|  | } | 
|  | } | 
|  |  | 
|  | if (TypeToResolve) { | 
|  | UR_OUT("  * Resolving upreference for " | 
|  | << UpRefs[i].second->getDescription() << "\n"; | 
|  | std::string OldName = TypeToResolve->getDescription()); | 
|  | TypeToResolve->refineAbstractTypeTo(Ty); | 
|  | } | 
|  |  | 
|  | return Ty; | 
|  | } | 
|  |  | 
|  | //===----------------------------------------------------------------------===// | 
|  | //            RunVMAsmParser - Define an interface to this parser | 
|  | //===----------------------------------------------------------------------===// | 
|  | // | 
|  | static Module* RunParser(Module * M); | 
|  |  | 
|  | Module *llvm::RunVMAsmParser(const std::string &Filename, FILE *F) { | 
|  | set_scan_file(F); | 
|  |  | 
|  | CurFilename = Filename; | 
|  | return RunParser(new Module(CurFilename)); | 
|  | } | 
|  |  | 
|  | Module *llvm::RunVMAsmParser(const char * AsmString, Module * M) { | 
|  | set_scan_string(AsmString); | 
|  |  | 
|  | CurFilename = "from_memory"; | 
|  | if (M == NULL) { | 
|  | return RunParser(new Module (CurFilename)); | 
|  | } else { | 
|  | return RunParser(M); | 
|  | } | 
|  | } | 
|  |  | 
|  |  | 
|  |  | 
|  | /* Enabling traces.  */ | 
|  | #ifndef YYDEBUG | 
|  | # define YYDEBUG 0 | 
|  | #endif | 
|  |  | 
|  | /* Enabling verbose error messages.  */ | 
|  | #ifdef YYERROR_VERBOSE | 
|  | # undef YYERROR_VERBOSE | 
|  | # define YYERROR_VERBOSE 1 | 
|  | #else | 
|  | # define YYERROR_VERBOSE 0 | 
|  | #endif | 
|  |  | 
|  | /* Enabling the token table.  */ | 
|  | #ifndef YYTOKEN_TABLE | 
|  | # define YYTOKEN_TABLE 0 | 
|  | #endif | 
|  |  | 
|  | #if ! defined (YYSTYPE) && ! defined (YYSTYPE_IS_DECLARED) | 
|  | #line 895 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | typedef union YYSTYPE { | 
|  | llvm::Module                           *ModuleVal; | 
|  | llvm::Function                         *FunctionVal; | 
|  | llvm::BasicBlock                       *BasicBlockVal; | 
|  | llvm::TerminatorInst                   *TermInstVal; | 
|  | llvm::Instruction                      *InstVal; | 
|  | llvm::Constant                         *ConstVal; | 
|  |  | 
|  | const llvm::Type                       *PrimType; | 
|  | std::list<llvm::PATypeHolder>          *TypeList; | 
|  | llvm::PATypeHolder                     *TypeVal; | 
|  | llvm::Value                            *ValueVal; | 
|  | std::vector<llvm::Value*>              *ValueList; | 
|  | llvm::ArgListType                      *ArgList; | 
|  | llvm::TypeWithAttrs                     TypeWithAttrs; | 
|  | llvm::TypeWithAttrsList                *TypeWithAttrsList; | 
|  | llvm::ValueRefList                     *ValueRefList; | 
|  |  | 
|  | // Represent the RHS of PHI node | 
|  | std::list<std::pair<llvm::Value*, | 
|  | llvm::BasicBlock*> > *PHIList; | 
|  | std::vector<std::pair<llvm::Constant*, llvm::BasicBlock*> > *JumpTable; | 
|  | std::vector<llvm::Constant*>           *ConstVector; | 
|  |  | 
|  | llvm::GlobalValue::LinkageTypes         Linkage; | 
|  | llvm::FunctionType::ParameterAttributes ParamAttrs; | 
|  | int64_t                           SInt64Val; | 
|  | uint64_t                          UInt64Val; | 
|  | int                               SIntVal; | 
|  | unsigned                          UIntVal; | 
|  | double                            FPVal; | 
|  | bool                              BoolVal; | 
|  |  | 
|  | char                             *StrVal;   // This memory is strdup'd! | 
|  | llvm::ValID                       ValIDVal; // strdup'd memory maybe! | 
|  |  | 
|  | llvm::Instruction::BinaryOps      BinaryOpVal; | 
|  | llvm::Instruction::TermOps        TermOpVal; | 
|  | llvm::Instruction::MemoryOps      MemOpVal; | 
|  | llvm::Instruction::CastOps        CastOpVal; | 
|  | llvm::Instruction::OtherOps       OtherOpVal; | 
|  | llvm::Module::Endianness          Endianness; | 
|  | llvm::ICmpInst::Predicate         IPredicate; | 
|  | llvm::FCmpInst::Predicate         FPredicate; | 
|  | } YYSTYPE; | 
|  | /* Line 196 of yacc.c.  */ | 
|  | #line 1288 "llvmAsmParser.tab.c" | 
|  | # define yystype YYSTYPE /* obsolescent; will be withdrawn */ | 
|  | # define YYSTYPE_IS_DECLARED 1 | 
|  | # define YYSTYPE_IS_TRIVIAL 1 | 
|  | #endif | 
|  |  | 
|  |  | 
|  |  | 
|  | /* Copy the second part of user declarations.  */ | 
|  |  | 
|  |  | 
|  | /* Line 219 of yacc.c.  */ | 
|  | #line 1300 "llvmAsmParser.tab.c" | 
|  |  | 
|  | #if ! defined (YYSIZE_T) && defined (__SIZE_TYPE__) | 
|  | # define YYSIZE_T __SIZE_TYPE__ | 
|  | #endif | 
|  | #if ! defined (YYSIZE_T) && defined (size_t) | 
|  | # define YYSIZE_T size_t | 
|  | #endif | 
|  | #if ! defined (YYSIZE_T) && (defined (__STDC__) || defined (__cplusplus)) | 
|  | # include <stddef.h> /* INFRINGES ON USER NAME SPACE */ | 
|  | # define YYSIZE_T size_t | 
|  | #endif | 
|  | #if ! defined (YYSIZE_T) | 
|  | # define YYSIZE_T unsigned int | 
|  | #endif | 
|  |  | 
|  | #ifndef YY_ | 
|  | # if YYENABLE_NLS | 
|  | #  if ENABLE_NLS | 
|  | #   include <libintl.h> /* INFRINGES ON USER NAME SPACE */ | 
|  | #   define YY_(msgid) dgettext ("bison-runtime", msgid) | 
|  | #  endif | 
|  | # endif | 
|  | # ifndef YY_ | 
|  | #  define YY_(msgid) msgid | 
|  | # endif | 
|  | #endif | 
|  |  | 
|  | #if ! defined (yyoverflow) || YYERROR_VERBOSE | 
|  |  | 
|  | /* The parser invokes alloca or malloc; define the necessary symbols.  */ | 
|  |  | 
|  | # ifdef YYSTACK_USE_ALLOCA | 
|  | #  if YYSTACK_USE_ALLOCA | 
|  | #   ifdef __GNUC__ | 
|  | #    define YYSTACK_ALLOC __builtin_alloca | 
|  | #   else | 
|  | #    define YYSTACK_ALLOC alloca | 
|  | #    if defined (__STDC__) || defined (__cplusplus) | 
|  | #     include <stdlib.h> /* INFRINGES ON USER NAME SPACE */ | 
|  | #     define YYINCLUDED_STDLIB_H | 
|  | #    endif | 
|  | #   endif | 
|  | #  endif | 
|  | # endif | 
|  |  | 
|  | # ifdef YYSTACK_ALLOC | 
|  | /* Pacify GCC's `empty if-body' warning. */ | 
|  | #  define YYSTACK_FREE(Ptr) do { /* empty */; } while (0) | 
|  | #  ifndef YYSTACK_ALLOC_MAXIMUM | 
|  | /* The OS might guarantee only one guard page at the bottom of the stack, | 
|  | and a page size can be as small as 4096 bytes.  So we cannot safely | 
|  | invoke alloca (N) if N exceeds 4096.  Use a slightly smaller number | 
|  | to allow for a few compiler-allocated temporary stack slots.  */ | 
|  | #   define YYSTACK_ALLOC_MAXIMUM 4032 /* reasonable circa 2005 */ | 
|  | #  endif | 
|  | # else | 
|  | #  define YYSTACK_ALLOC YYMALLOC | 
|  | #  define YYSTACK_FREE YYFREE | 
|  | #  ifndef YYSTACK_ALLOC_MAXIMUM | 
|  | #   define YYSTACK_ALLOC_MAXIMUM ((YYSIZE_T) -1) | 
|  | #  endif | 
|  | #  ifdef __cplusplus | 
|  | extern "C" { | 
|  | #  endif | 
|  | #  ifndef YYMALLOC | 
|  | #   define YYMALLOC malloc | 
|  | #   if (! defined (malloc) && ! defined (YYINCLUDED_STDLIB_H) \ | 
|  | && (defined (__STDC__) || defined (__cplusplus))) | 
|  | void *malloc (YYSIZE_T); /* INFRINGES ON USER NAME SPACE */ | 
|  | #   endif | 
|  | #  endif | 
|  | #  ifndef YYFREE | 
|  | #   define YYFREE free | 
|  | #   if (! defined (free) && ! defined (YYINCLUDED_STDLIB_H) \ | 
|  | && (defined (__STDC__) || defined (__cplusplus))) | 
|  | void free (void *); /* INFRINGES ON USER NAME SPACE */ | 
|  | #   endif | 
|  | #  endif | 
|  | #  ifdef __cplusplus | 
|  | } | 
|  | #  endif | 
|  | # endif | 
|  | #endif /* ! defined (yyoverflow) || YYERROR_VERBOSE */ | 
|  |  | 
|  |  | 
|  | #if (! defined (yyoverflow) \ | 
|  | && (! defined (__cplusplus) \ | 
|  | || (defined (YYSTYPE_IS_TRIVIAL) && YYSTYPE_IS_TRIVIAL))) | 
|  |  | 
|  | /* A type that is properly aligned for any stack member.  */ | 
|  | union yyalloc | 
|  | { | 
|  | short int yyss; | 
|  | YYSTYPE yyvs; | 
|  | }; | 
|  |  | 
|  | /* The size of the maximum gap between one aligned stack and the next.  */ | 
|  | # define YYSTACK_GAP_MAXIMUM (sizeof (union yyalloc) - 1) | 
|  |  | 
|  | /* The size of an array large to enough to hold all stacks, each with | 
|  | N elements.  */ | 
|  | # define YYSTACK_BYTES(N) \ | 
|  | ((N) * (sizeof (short int) + sizeof (YYSTYPE))			\ | 
|  | + YYSTACK_GAP_MAXIMUM) | 
|  |  | 
|  | /* Copy COUNT objects from FROM to TO.  The source and destination do | 
|  | not overlap.  */ | 
|  | # ifndef YYCOPY | 
|  | #  if defined (__GNUC__) && 1 < __GNUC__ | 
|  | #   define YYCOPY(To, From, Count) \ | 
|  | __builtin_memcpy (To, From, (Count) * sizeof (*(From))) | 
|  | #  else | 
|  | #   define YYCOPY(To, From, Count)		\ | 
|  | do					\ | 
|  | {					\ | 
|  | YYSIZE_T yyi;				\ | 
|  | for (yyi = 0; yyi < (Count); yyi++)	\ | 
|  | (To)[yyi] = (From)[yyi];		\ | 
|  | }					\ | 
|  | while (0) | 
|  | #  endif | 
|  | # endif | 
|  |  | 
|  | /* Relocate STACK from its old location to the new one.  The | 
|  | local variables YYSIZE and YYSTACKSIZE give the old and new number of | 
|  | elements in the stack, and YYPTR gives the new location of the | 
|  | stack.  Advance YYPTR to a properly aligned location for the next | 
|  | stack.  */ | 
|  | # define YYSTACK_RELOCATE(Stack)					\ | 
|  | do									\ | 
|  | {									\ | 
|  | YYSIZE_T yynewbytes;						\ | 
|  | YYCOPY (&yyptr->Stack, Stack, yysize);				\ | 
|  | Stack = &yyptr->Stack;						\ | 
|  | yynewbytes = yystacksize * sizeof (*Stack) + YYSTACK_GAP_MAXIMUM; \ | 
|  | yyptr += yynewbytes / sizeof (*yyptr);				\ | 
|  | }									\ | 
|  | while (0) | 
|  |  | 
|  | #endif | 
|  |  | 
|  | #if defined (__STDC__) || defined (__cplusplus) | 
|  | typedef signed char yysigned_char; | 
|  | #else | 
|  | typedef short int yysigned_char; | 
|  | #endif | 
|  |  | 
|  | /* YYFINAL -- State number of the termination state. */ | 
|  | #define YYFINAL  37 | 
|  | /* YYLAST -- Last index in YYTABLE.  */ | 
|  | #define YYLAST   1503 | 
|  |  | 
|  | /* YYNTOKENS -- Number of terminals. */ | 
|  | #define YYNTOKENS  150 | 
|  | /* YYNNTS -- Number of nonterminals. */ | 
|  | #define YYNNTS  77 | 
|  | /* YYNRULES -- Number of rules. */ | 
|  | #define YYNRULES  288 | 
|  | /* YYNRULES -- Number of states. */ | 
|  | #define YYNSTATES  572 | 
|  |  | 
|  | /* YYTRANSLATE(YYLEX) -- Bison symbol number corresponding to YYLEX.  */ | 
|  | #define YYUNDEFTOK  2 | 
|  | #define YYMAXUTOK   389 | 
|  |  | 
|  | #define YYTRANSLATE(YYX)						\ | 
|  | ((unsigned int) (YYX) <= YYMAXUTOK ? yytranslate[YYX] : YYUNDEFTOK) | 
|  |  | 
|  | /* YYTRANSLATE[YYLEX] -- Bison symbol number corresponding to YYLEX.  */ | 
|  | static const unsigned char yytranslate[] = | 
|  | { | 
|  | 0,     2,     2,     2,     2,     2,     2,     2,     2,     2, | 
|  | 2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | 
|  | 2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | 
|  | 2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | 
|  | 138,   139,   140,     2,   136,     2,     2,     2,     2,     2, | 
|  | 2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | 
|  | 145,   135,   146,     2,   137,     2,     2,     2,     2,     2, | 
|  | 2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | 
|  | 2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | 
|  | 2,   142,   141,   144,     2,     2,     2,     2,     2,   149, | 
|  | 2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | 
|  | 2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | 
|  | 143,     2,     2,   147,     2,   148,     2,     2,     2,     2, | 
|  | 2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | 
|  | 2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | 
|  | 2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | 
|  | 2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | 
|  | 2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | 
|  | 2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | 
|  | 2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | 
|  | 2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | 
|  | 2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | 
|  | 2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | 
|  | 2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | 
|  | 2,     2,     2,     2,     2,     2,     2,     2,     2,     2, | 
|  | 2,     2,     2,     2,     2,     2,     1,     2,     3,     4, | 
|  | 5,     6,     7,     8,     9,    10,    11,    12,    13,    14, | 
|  | 15,    16,    17,    18,    19,    20,    21,    22,    23,    24, | 
|  | 25,    26,    27,    28,    29,    30,    31,    32,    33,    34, | 
|  | 35,    36,    37,    38,    39,    40,    41,    42,    43,    44, | 
|  | 45,    46,    47,    48,    49,    50,    51,    52,    53,    54, | 
|  | 55,    56,    57,    58,    59,    60,    61,    62,    63,    64, | 
|  | 65,    66,    67,    68,    69,    70,    71,    72,    73,    74, | 
|  | 75,    76,    77,    78,    79,    80,    81,    82,    83,    84, | 
|  | 85,    86,    87,    88,    89,    90,    91,    92,    93,    94, | 
|  | 95,    96,    97,    98,    99,   100,   101,   102,   103,   104, | 
|  | 105,   106,   107,   108,   109,   110,   111,   112,   113,   114, | 
|  | 115,   116,   117,   118,   119,   120,   121,   122,   123,   124, | 
|  | 125,   126,   127,   128,   129,   130,   131,   132,   133,   134 | 
|  | }; | 
|  |  | 
|  | #if YYDEBUG | 
|  | /* YYPRHS[YYN] -- Index of the first RHS symbol of rule number YYN in | 
|  | YYRHS.  */ | 
|  | static const unsigned short int yyprhs[] = | 
|  | { | 
|  | 0,     0,     3,     5,     7,     9,    11,    13,    15,    17, | 
|  | 19,    21,    23,    25,    27,    29,    31,    33,    35,    37, | 
|  | 39,    41,    43,    45,    47,    49,    51,    53,    55,    57, | 
|  | 59,    61,    63,    65,    67,    69,    71,    73,    75,    77, | 
|  | 79,    81,    83,    85,    87,    89,    91,    93,    95,    97, | 
|  | 99,   101,   103,   105,   107,   109,   111,   113,   115,   117, | 
|  | 119,   121,   123,   125,   128,   129,   131,   133,   135,   137, | 
|  | 139,   141,   143,   145,   146,   148,   150,   151,   153,   155, | 
|  | 157,   159,   160,   162,   164,   166,   168,   170,   172,   175, | 
|  | 177,   179,   181,   185,   186,   189,   194,   195,   198,   199, | 
|  | 203,   206,   207,   209,   210,   214,   216,   219,   221,   223, | 
|  | 225,   227,   229,   231,   233,   235,   237,   239,   242,   244, | 
|  | 247,   253,   259,   265,   271,   275,   278,   284,   289,   292, | 
|  | 295,   298,   300,   304,   306,   310,   312,   313,   315,   319, | 
|  | 324,   328,   332,   337,   342,   346,   349,   352,   355,   358, | 
|  | 361,   364,   367,   370,   373,   376,   383,   389,   398,   405, | 
|  | 412,   420,   428,   435,   442,   451,   460,   464,   466,   468, | 
|  | 470,   472,   473,   475,   478,   479,   483,   484,   488,   492, | 
|  | 494,   498,   502,   503,   509,   510,   517,   518,   525,   528, | 
|  | 532,   534,   536,   538,   542,   546,   550,   554,   558,   562, | 
|  | 564,   565,   567,   569,   571,   572,   578,   582,   584,   588, | 
|  | 590,   591,   600,   602,   604,   608,   610,   612,   615,   618, | 
|  | 619,   621,   623,   625,   627,   629,   631,   633,   635,   637, | 
|  | 641,   643,   649,   651,   653,   655,   657,   660,   663,   666, | 
|  | 670,   673,   674,   676,   679,   682,   686,   696,   706,   715, | 
|  | 729,   731,   733,   740,   746,   749,   756,   764,   768,   774, | 
|  | 775,   776,   780,   783,   785,   791,   797,   804,   811,   814, | 
|  | 819,   824,   831,   836,   841,   848,   855,   858,   866,   868, | 
|  | 870,   871,   875,   882,   886,   893,   896,   901,   908 | 
|  | }; | 
|  |  | 
|  | /* YYRHS -- A `-1'-separated list of the rules' RHS. */ | 
|  | static const short int yyrhs[] = | 
|  | { | 
|  | 186,     0,    -1,     5,    -1,     6,    -1,    74,    -1,    75, | 
|  | -1,    76,    -1,    77,    -1,    78,    -1,    79,    -1,    80, | 
|  | -1,    81,    -1,    82,    -1,    83,    -1,    84,    -1,    85, | 
|  | -1,   114,    -1,   115,    -1,   116,    -1,   117,    -1,   118, | 
|  | -1,   119,    -1,   120,    -1,   121,    -1,   122,    -1,   123, | 
|  | -1,   124,    -1,   125,    -1,   128,    -1,   129,    -1,   130, | 
|  | -1,    88,    -1,    89,    -1,    90,    -1,    91,    -1,    92, | 
|  | -1,    93,    -1,    94,    -1,    95,    -1,    96,    -1,    97, | 
|  | -1,    98,    -1,    99,    -1,   100,    -1,   101,    -1,   102, | 
|  | -1,   103,    -1,   104,    -1,   105,    -1,   106,    -1,   107, | 
|  | -1,    94,    -1,    95,    -1,    96,    -1,    97,    -1,    23, | 
|  | -1,    24,    -1,    13,    -1,    12,    -1,    11,    -1,    10, | 
|  | -1,    14,    -1,    15,    -1,   199,   135,    -1,    -1,    37, | 
|  | -1,    39,    -1,    38,    -1,    40,    -1,    42,    -1,    41, | 
|  | -1,    43,    -1,    46,    -1,    -1,    41,    -1,    43,    -1, | 
|  | -1,    37,    -1,    38,    -1,    39,    -1,    42,    -1,    -1, | 
|  | 61,    -1,    62,    -1,    63,    -1,    64,    -1,    65,    -1, | 
|  | 66,    -1,    60,     4,    -1,   115,    -1,   116,    -1,   166, | 
|  | -1,   167,   136,   166,    -1,    -1,   137,   166,    -1,   137, | 
|  | 138,   167,   139,    -1,    -1,    53,     4,    -1,    -1,   136, | 
|  | 53,     4,    -1,    31,    20,    -1,    -1,   171,    -1,    -1, | 
|  | 136,   174,   173,    -1,   171,    -1,    53,     4,    -1,     9, | 
|  | -1,    10,    -1,    11,    -1,    12,    -1,    13,    -1,    14, | 
|  | -1,    15,    -1,    16,    -1,    44,    -1,   175,    -1,   176, | 
|  | 140,    -1,   211,    -1,   141,     4,    -1,   176,   168,   138, | 
|  | 180,   139,    -1,     8,   168,   138,   180,   139,    -1,   142, | 
|  | 4,   143,   176,   144,    -1,   145,     4,   143,   176,   146, | 
|  | -1,   147,   181,   148,    -1,   147,   148,    -1,   145,   147, | 
|  | 181,   148,   146,    -1,   145,   147,   148,   146,    -1,   176, | 
|  | 168,    -1,   176,   168,    -1,     8,   168,    -1,   177,    -1, | 
|  | 179,   136,   177,    -1,   179,    -1,   179,   136,    34,    -1, | 
|  | 34,    -1,    -1,   176,    -1,   181,   136,   176,    -1,   176, | 
|  | 142,   184,   144,    -1,   176,   142,   144,    -1,   176,   149, | 
|  | 20,    -1,   176,   145,   184,   146,    -1,   176,   147,   184, | 
|  | 148,    -1,   176,   147,   148,    -1,   176,    35,    -1,   176, | 
|  | 36,    -1,   176,   211,    -1,   176,   183,    -1,   176,    22, | 
|  | -1,   158,     3,    -1,   158,     4,    -1,     9,    23,    -1, | 
|  | 9,    24,    -1,   159,     7,    -1,   154,   138,   182,    33, | 
|  | 176,   139,    -1,   113,   138,   182,   222,   139,    -1,   127, | 
|  | 138,   182,   136,   182,   136,   182,   139,    -1,   152,   138, | 
|  | 182,   136,   182,   139,    -1,   153,   138,   182,   136,   182, | 
|  | 139,    -1,    86,   156,   138,   182,   136,   182,   139,    -1, | 
|  | 87,   157,   138,   182,   136,   182,   139,    -1,   155,   138, | 
|  | 182,   136,   182,   139,    -1,   132,   138,   182,   136,   182, | 
|  | 139,    -1,   133,   138,   182,   136,   182,   136,   182,   139, | 
|  | -1,   134,   138,   182,   136,   182,   136,   182,   139,    -1, | 
|  | 184,   136,   182,    -1,   182,    -1,    29,    -1,    30,    -1, | 
|  | 187,    -1,    -1,   188,    -1,   187,   188,    -1,    -1,    28, | 
|  | 189,   207,    -1,    -1,    27,   190,   208,    -1,    58,    57, | 
|  | 194,    -1,    21,    -1,   160,    17,   176,    -1,   160,    17, | 
|  | 8,    -1,    -1,   160,   185,   182,   191,   173,    -1,    -1, | 
|  | 160,   161,   185,   182,   192,   173,    -1,    -1,   160,   162, | 
|  | 185,   176,   193,   173,    -1,    47,   196,    -1,    54,   135, | 
|  | 197,    -1,    20,    -1,    52,    -1,    51,    -1,    49,   135, | 
|  | 195,    -1,    50,   135,     4,    -1,    48,   135,    20,    -1, | 
|  | 67,   135,    20,    -1,   142,   198,   144,    -1,   198,   136, | 
|  | 20,    -1,    20,    -1,    -1,    18,    -1,    20,    -1,   199, | 
|  | -1,    -1,   201,   136,   176,   168,   200,    -1,   176,   168, | 
|  | 200,    -1,   201,    -1,   201,   136,    34,    -1,    34,    -1, | 
|  | -1,   165,   178,   199,   138,   202,   139,   172,   169,    -1, | 
|  | 25,    -1,   147,    -1,   164,   203,   204,    -1,    26,    -1, | 
|  | 148,    -1,   214,   206,    -1,   163,   203,    -1,    -1,    59, | 
|  | -1,     3,    -1,     4,    -1,     7,    -1,    23,    -1,    24, | 
|  | -1,    35,    -1,    36,    -1,    22,    -1,   145,   184,   146, | 
|  | -1,   183,    -1,    57,   209,    20,   136,    20,    -1,   151, | 
|  | -1,   199,    -1,   211,    -1,   210,    -1,   176,   212,    -1, | 
|  | 214,   215,    -1,   205,   215,    -1,   216,   160,   217,    -1, | 
|  | 216,   219,    -1,    -1,    19,    -1,    68,   213,    -1,    68, | 
|  | 8,    -1,    69,    16,   212,    -1,    69,     9,   212,   136, | 
|  | 16,   212,   136,    16,   212,    -1,    70,   158,   212,   136, | 
|  | 16,   212,   142,   218,   144,    -1,    70,   158,   212,   136, | 
|  | 16,   212,   142,   144,    -1,    71,   165,   178,   212,   138, | 
|  | 221,   139,    33,    16,   212,    72,    16,   212,    -1,    72, | 
|  | -1,    73,    -1,   218,   158,   210,   136,    16,   212,    -1, | 
|  | 158,   210,   136,    16,   212,    -1,   160,   224,    -1,   176, | 
|  | 142,   212,   136,   212,   144,    -1,   220,   136,   142,   212, | 
|  | 136,   212,   144,    -1,   176,   212,   168,    -1,   221,   136, | 
|  | 176,   212,   168,    -1,    -1,    -1,   222,   136,   213,    -1, | 
|  | 56,    55,    -1,    55,    -1,   152,   176,   212,   136,   212, | 
|  | -1,   153,   176,   212,   136,   212,    -1,    86,   156,   176, | 
|  | 212,   136,   212,    -1,    87,   157,   176,   212,   136,   212, | 
|  | -1,    45,   213,    -1,   155,   213,   136,   213,    -1,   154, | 
|  | 213,    33,   176,    -1,   127,   213,   136,   213,   136,   213, | 
|  | -1,   131,   213,   136,   176,    -1,   132,   213,   136,   213, | 
|  | -1,   133,   213,   136,   213,   136,   213,    -1,   134,   213, | 
|  | 136,   213,   136,   213,    -1,   126,   220,    -1,   223,   165, | 
|  | 178,   212,   138,   221,   139,    -1,   226,    -1,    32,    -1, | 
|  | -1,   108,   176,   170,    -1,   108,   176,   136,    12,   212, | 
|  | 170,    -1,   109,   176,   170,    -1,   109,   176,   136,    12, | 
|  | 212,   170,    -1,   110,   213,    -1,   225,   111,   176,   212, | 
|  | -1,   225,   112,   213,   136,   176,   212,    -1,   113,   176, | 
|  | 212,   222,    -1 | 
|  | }; | 
|  |  | 
|  | /* YYRLINE[YYN] -- source line where rule number YYN was defined.  */ | 
|  | static const unsigned short int yyrline[] = | 
|  | { | 
|  | 0,  1035,  1035,  1036,  1046,  1046,  1046,  1046,  1046,  1046, | 
|  | 1046,  1046,  1046,  1047,  1047,  1047,  1048,  1048,  1048,  1048, | 
|  | 1048,  1048,  1049,  1049,  1049,  1049,  1049,  1049,  1050,  1050, | 
|  | 1050,  1052,  1052,  1053,  1053,  1054,  1054,  1055,  1055,  1056, | 
|  | 1056,  1060,  1060,  1061,  1061,  1062,  1062,  1063,  1063,  1064, | 
|  | 1064,  1065,  1065,  1066,  1066,  1067,  1068,  1073,  1073,  1073, | 
|  | 1073,  1074,  1074,  1077,  1081,  1087,  1088,  1089,  1090,  1091, | 
|  | 1095,  1096,  1097,  1101,  1102,  1103,  1107,  1108,  1109,  1110, | 
|  | 1111,  1114,  1115,  1116,  1117,  1118,  1119,  1120,  1121,  1128, | 
|  | 1129,  1132,  1133,  1138,  1139,  1140,  1145,  1146,  1152,  1153, | 
|  | 1161,  1169,  1170,  1175,  1176,  1177,  1182,  1195,  1195,  1195, | 
|  | 1195,  1195,  1195,  1195,  1195,  1198,  1202,  1206,  1213,  1218, | 
|  | 1226,  1244,  1262,  1267,  1279,  1289,  1293,  1303,  1310,  1317, | 
|  | 1325,  1331,  1336,  1343,  1344,  1351,  1358,  1366,  1371,  1382, | 
|  | 1410,  1426,  1455,  1483,  1504,  1519,  1531,  1538,  1601,  1611, | 
|  | 1621,  1627,  1633,  1637,  1641,  1649,  1663,  1684,  1692,  1698, | 
|  | 1709,  1714,  1719,  1728,  1734,  1740,  1749,  1753,  1761,  1761, | 
|  | 1772,  1777,  1785,  1786,  1790,  1790,  1794,  1794,  1797,  1800, | 
|  | 1812,  1836,  1847,  1847,  1856,  1856,  1864,  1864,  1874,  1877, | 
|  | 1883,  1896,  1897,  1899,  1903,  1912,  1916,  1921,  1923,  1928, | 
|  | 1933,  1942,  1942,  1943,  1943,  1945,  1955,  1966,  1970,  1979, | 
|  | 1988,  1993,  2098,  2098,  2100,  2108,  2108,  2110,  2115,  2126, | 
|  | 2130,  2135,  2139,  2143,  2147,  2151,  2155,  2159,  2163,  2167, | 
|  | 2192,  2196,  2210,  2214,  2220,  2220,  2226,  2235,  2239,  2248, | 
|  | 2259,  2268,  2280,  2293,  2297,  2301,  2306,  2315,  2334,  2343, | 
|  | 2410,  2414,  2421,  2432,  2445,  2454,  2465,  2475,  2483,  2491, | 
|  | 2494,  2495,  2502,  2506,  2511,  2532,  2549,  2560,  2571,  2584, | 
|  | 2593,  2606,  2614,  2621,  2627,  2633,  2639,  2654,  2716,  2721, | 
|  | 2725,  2732,  2739,  2747,  2754,  2762,  2770,  2784,  2801 | 
|  | }; | 
|  | #endif | 
|  |  | 
|  | #if YYDEBUG || YYERROR_VERBOSE || YYTOKEN_TABLE | 
|  | /* YYTNAME[SYMBOL-NUM] -- String name of the symbol SYMBOL-NUM. | 
|  | First, the terminals, then, starting at YYNTOKENS, nonterminals. */ | 
|  | static const char *const yytname[] = | 
|  | { | 
|  | "$end", "error", "$undefined", "ESINT64VAL", "EUINT64VAL", "SINTVAL", | 
|  | "UINTVAL", "FPVAL", "VOID", "BOOL", "INT8", "INT16", "INT32", "INT64", | 
|  | "FLOAT", "DOUBLE", "LABEL", "TYPE", "VAR_ID", "LABELSTR", | 
|  | "STRINGCONSTANT", "IMPLEMENTATION", "ZEROINITIALIZER", "TRUETOK", | 
|  | "FALSETOK", "BEGINTOK", "ENDTOK", "DECLARE", "DEFINE", "GLOBAL", | 
|  | "CONSTANT", "SECTION", "VOLATILE", "TO", "DOTDOTDOT", "NULL_TOK", | 
|  | "UNDEF", "INTERNAL", "LINKONCE", "WEAK", "APPENDING", "DLLIMPORT", | 
|  | "DLLEXPORT", "EXTERN_WEAK", "OPAQUE", "NOT", "EXTERNAL", "TARGET", | 
|  | "TRIPLE", "ENDIAN", "POINTERSIZE", "LITTLE", "BIG", "ALIGN", "DEPLIBS", | 
|  | "CALL", "TAIL", "ASM_TOK", "MODULE", "SIDEEFFECT", "CC_TOK", "CCC_TOK", | 
|  | "CSRETCC_TOK", "FASTCC_TOK", "COLDCC_TOK", "X86_STDCALLCC_TOK", | 
|  | "X86_FASTCALLCC_TOK", "DATALAYOUT", "RET", "BR", "SWITCH", "INVOKE", | 
|  | "UNWIND", "UNREACHABLE", "ADD", "SUB", "MUL", "UDIV", "SDIV", "FDIV", | 
|  | "UREM", "SREM", "FREM", "AND", "OR", "XOR", "ICMP", "FCMP", "EQ", "NE", | 
|  | "SLT", "SGT", "SLE", "SGE", "ULT", "UGT", "ULE", "UGE", "OEQ", "ONE", | 
|  | "OLT", "OGT", "OLE", "OGE", "ORD", "UNO", "UEQ", "UNE", "MALLOC", | 
|  | "ALLOCA", "FREE", "LOAD", "STORE", "GETELEMENTPTR", "TRUNC", "ZEXT", | 
|  | "SEXT", "FPTRUNC", "FPEXT", "BITCAST", "UITOFP", "SITOFP", "FPTOUI", | 
|  | "FPTOSI", "INTTOPTR", "PTRTOINT", "PHI_TOK", "SELECT", "SHL", "LSHR", | 
|  | "ASHR", "VAARG", "EXTRACTELEMENT", "INSERTELEMENT", "SHUFFLEVECTOR", | 
|  | "'='", "','", "'@'", "'('", "')'", "'*'", "'\\\\'", "'['", "'x'", "']'", | 
|  | "'<'", "'>'", "'{'", "'}'", "'c'", "$accept", "INTVAL", "ArithmeticOps", | 
|  | "LogicalOps", "CastOps", "ShiftOps", "IPredicates", "FPredicates", | 
|  | "IntType", "FPType", "OptAssign", "GVInternalLinkage", | 
|  | "GVExternalLinkage", "FunctionDeclareLinkage", "FunctionDefineLinkage", | 
|  | "OptCallingConv", "ParamAttr", "ParamAttrList", "OptParamAttrs", | 
|  | "OptAlign", "OptCAlign", "SectionString", "OptSection", | 
|  | "GlobalVarAttributes", "GlobalVarAttribute", "PrimType", "Types", | 
|  | "ArgType", "ResultType", "ArgTypeList", "ArgTypeListI", "TypeListI", | 
|  | "ConstVal", "ConstExpr", "ConstVector", "GlobalType", "Module", | 
|  | "DefinitionList", "Definition", "@1", "@2", "@3", "@4", "@5", "AsmBlock", | 
|  | "BigOrLittle", "TargetDefinition", "LibrariesDefinition", "LibList", | 
|  | "Name", "OptName", "ArgListH", "ArgList", "FunctionHeaderH", "BEGIN", | 
|  | "FunctionHeader", "END", "Function", "FunctionProto", "OptSideEffect", | 
|  | "ConstValueRef", "SymbolicValueRef", "ValueRef", "ResolvedVal", | 
|  | "BasicBlockList", "BasicBlock", "InstructionList", "BBTerminatorInst", | 
|  | "JumpTable", "Inst", "PHIList", "ValueRefList", "IndexList", | 
|  | "OptTailCall", "InstVal", "OptVolatile", "MemoryInst", 0 | 
|  | }; | 
|  | #endif | 
|  |  | 
|  | # ifdef YYPRINT | 
|  | /* YYTOKNUM[YYLEX-NUM] -- Internal token number corresponding to | 
|  | token YYLEX-NUM.  */ | 
|  | static const unsigned short int yytoknum[] = | 
|  | { | 
|  | 0,   256,   257,   258,   259,   260,   261,   262,   263,   264, | 
|  | 265,   266,   267,   268,   269,   270,   271,   272,   273,   274, | 
|  | 275,   276,   277,   278,   279,   280,   281,   282,   283,   284, | 
|  | 285,   286,   287,   288,   289,   290,   291,   292,   293,   294, | 
|  | 295,   296,   297,   298,   299,   300,   301,   302,   303,   304, | 
|  | 305,   306,   307,   308,   309,   310,   311,   312,   313,   314, | 
|  | 315,   316,   317,   318,   319,   320,   321,   322,   323,   324, | 
|  | 325,   326,   327,   328,   329,   330,   331,   332,   333,   334, | 
|  | 335,   336,   337,   338,   339,   340,   341,   342,   343,   344, | 
|  | 345,   346,   347,   348,   349,   350,   351,   352,   353,   354, | 
|  | 355,   356,   357,   358,   359,   360,   361,   362,   363,   364, | 
|  | 365,   366,   367,   368,   369,   370,   371,   372,   373,   374, | 
|  | 375,   376,   377,   378,   379,   380,   381,   382,   383,   384, | 
|  | 385,   386,   387,   388,   389,    61,    44,    64,    40,    41, | 
|  | 42,    92,    91,   120,    93,    60,    62,   123,   125,    99 | 
|  | }; | 
|  | # endif | 
|  |  | 
|  | /* YYR1[YYN] -- Symbol number of symbol that rule YYN derives.  */ | 
|  | static const unsigned char yyr1[] = | 
|  | { | 
|  | 0,   150,   151,   151,   152,   152,   152,   152,   152,   152, | 
|  | 152,   152,   152,   153,   153,   153,   154,   154,   154,   154, | 
|  | 154,   154,   154,   154,   154,   154,   154,   154,   155,   155, | 
|  | 155,   156,   156,   156,   156,   156,   156,   156,   156,   156, | 
|  | 156,   157,   157,   157,   157,   157,   157,   157,   157,   157, | 
|  | 157,   157,   157,   157,   157,   157,   157,   158,   158,   158, | 
|  | 158,   159,   159,   160,   160,   161,   161,   161,   161,   161, | 
|  | 162,   162,   162,   163,   163,   163,   164,   164,   164,   164, | 
|  | 164,   165,   165,   165,   165,   165,   165,   165,   165,   166, | 
|  | 166,   167,   167,   168,   168,   168,   169,   169,   170,   170, | 
|  | 171,   172,   172,   173,   173,   174,   174,   175,   175,   175, | 
|  | 175,   175,   175,   175,   175,   176,   176,   176,   176,   176, | 
|  | 176,   176,   176,   176,   176,   176,   176,   176,   177,   178, | 
|  | 178,   179,   179,   180,   180,   180,   180,   181,   181,   182, | 
|  | 182,   182,   182,   182,   182,   182,   182,   182,   182,   182, | 
|  | 182,   182,   182,   182,   182,   183,   183,   183,   183,   183, | 
|  | 183,   183,   183,   183,   183,   183,   184,   184,   185,   185, | 
|  | 186,   186,   187,   187,   189,   188,   190,   188,   188,   188, | 
|  | 188,   188,   191,   188,   192,   188,   193,   188,   188,   188, | 
|  | 194,   195,   195,   196,   196,   196,   196,   197,   198,   198, | 
|  | 198,   199,   199,   200,   200,   201,   201,   202,   202,   202, | 
|  | 202,   203,   204,   204,   205,   206,   206,   207,   208,   209, | 
|  | 209,   210,   210,   210,   210,   210,   210,   210,   210,   210, | 
|  | 210,   210,   211,   211,   212,   212,   213,   214,   214,   215, | 
|  | 216,   216,   216,   217,   217,   217,   217,   217,   217,   217, | 
|  | 217,   217,   218,   218,   219,   220,   220,   221,   221,   221, | 
|  | 222,   222,   223,   223,   224,   224,   224,   224,   224,   224, | 
|  | 224,   224,   224,   224,   224,   224,   224,   224,   224,   225, | 
|  | 225,   226,   226,   226,   226,   226,   226,   226,   226 | 
|  | }; | 
|  |  | 
|  | /* YYR2[YYN] -- Number of symbols composing right hand side of rule YYN.  */ | 
|  | static const unsigned char yyr2[] = | 
|  | { | 
|  | 0,     2,     1,     1,     1,     1,     1,     1,     1,     1, | 
|  | 1,     1,     1,     1,     1,     1,     1,     1,     1,     1, | 
|  | 1,     1,     1,     1,     1,     1,     1,     1,     1,     1, | 
|  | 1,     1,     1,     1,     1,     1,     1,     1,     1,     1, | 
|  | 1,     1,     1,     1,     1,     1,     1,     1,     1,     1, | 
|  | 1,     1,     1,     1,     1,     1,     1,     1,     1,     1, | 
|  | 1,     1,     1,     2,     0,     1,     1,     1,     1,     1, | 
|  | 1,     1,     1,     0,     1,     1,     0,     1,     1,     1, | 
|  | 1,     0,     1,     1,     1,     1,     1,     1,     2,     1, | 
|  | 1,     1,     3,     0,     2,     4,     0,     2,     0,     3, | 
|  | 2,     0,     1,     0,     3,     1,     2,     1,     1,     1, | 
|  | 1,     1,     1,     1,     1,     1,     1,     2,     1,     2, | 
|  | 5,     5,     5,     5,     3,     2,     5,     4,     2,     2, | 
|  | 2,     1,     3,     1,     3,     1,     0,     1,     3,     4, | 
|  | 3,     3,     4,     4,     3,     2,     2,     2,     2,     2, | 
|  | 2,     2,     2,     2,     2,     6,     5,     8,     6,     6, | 
|  | 7,     7,     6,     6,     8,     8,     3,     1,     1,     1, | 
|  | 1,     0,     1,     2,     0,     3,     0,     3,     3,     1, | 
|  | 3,     3,     0,     5,     0,     6,     0,     6,     2,     3, | 
|  | 1,     1,     1,     3,     3,     3,     3,     3,     3,     1, | 
|  | 0,     1,     1,     1,     0,     5,     3,     1,     3,     1, | 
|  | 0,     8,     1,     1,     3,     1,     1,     2,     2,     0, | 
|  | 1,     1,     1,     1,     1,     1,     1,     1,     1,     3, | 
|  | 1,     5,     1,     1,     1,     1,     2,     2,     2,     3, | 
|  | 2,     0,     1,     2,     2,     3,     9,     9,     8,    13, | 
|  | 1,     1,     6,     5,     2,     6,     7,     3,     5,     0, | 
|  | 0,     3,     2,     1,     5,     5,     6,     6,     2,     4, | 
|  | 4,     6,     4,     4,     6,     6,     2,     7,     1,     1, | 
|  | 0,     3,     6,     3,     6,     2,     4,     6,     4 | 
|  | }; | 
|  |  | 
|  | /* YYDEFACT[STATE-NAME] -- Default rule to reduce with in state | 
|  | STATE-NUM when YYTABLE doesn't specify something else to do.  Zero | 
|  | means the default is an error.  */ | 
|  | static const unsigned short int yydefact[] = | 
|  | { | 
|  | 64,   201,   202,   179,   176,   174,     0,     0,     0,     0, | 
|  | 0,    64,   172,     0,    73,    76,     0,     0,     0,     0, | 
|  | 188,     0,     0,     0,   168,   169,    65,    67,    66,    68, | 
|  | 70,    69,    71,    72,     0,     0,     0,     1,   173,    63, | 
|  | 74,    75,    81,   177,    77,    78,    79,    80,    81,   241, | 
|  | 175,   241,     0,     0,     0,     0,   200,   189,   190,   178, | 
|  | 2,     3,   181,   107,   108,   109,   110,   111,   112,   113, | 
|  | 114,   115,     0,     0,     0,     0,   232,   116,   180,   233, | 
|  | 118,     0,     0,    93,   107,   108,   109,   110,   111,   112, | 
|  | 113,     0,     0,    93,   182,     0,    82,    83,    84,    85, | 
|  | 86,    87,     0,   218,     0,   242,   238,    64,   215,   216, | 
|  | 217,   237,   195,   192,   191,   193,   194,   196,   199,     0, | 
|  | 0,     0,   119,     0,     0,     0,   125,   137,     0,   117, | 
|  | 0,   184,   186,   152,   153,   150,   151,   154,   149,   145, | 
|  | 146,     4,     5,     6,     7,     8,     9,    10,    11,    12, | 
|  | 13,    14,    15,     0,     0,     0,    16,    17,    18,    19, | 
|  | 20,    21,    22,    23,    24,    25,    26,    27,     0,    28, | 
|  | 29,    30,     0,     0,     0,     0,     0,     0,     0,     0, | 
|  | 0,     0,     0,   148,   147,   103,    88,    93,    93,     0, | 
|  | 212,   213,   214,   280,   240,     0,   197,    89,    90,     0, | 
|  | 94,   136,     0,     0,     0,     0,     0,   124,   136,   103, | 
|  | 103,    31,    32,    33,    34,    35,    36,    37,    38,    39, | 
|  | 40,     0,    55,    56,    51,    52,    53,    54,    41,    42, | 
|  | 43,    44,    45,    46,    47,    48,    49,    50,     0,     0, | 
|  | 0,     0,     0,     0,   140,   167,     0,     0,   144,     0, | 
|  | 141,     0,     0,     0,     0,     0,   183,   130,   129,     0, | 
|  | 279,     0,   263,     0,     0,     0,     0,    81,   250,   251, | 
|  | 0,     0,     0,     0,     0,     0,     0,     0,     0,     0, | 
|  | 0,     0,     0,     0,     0,     0,   239,    81,   254,     0, | 
|  | 278,   198,    91,     0,   135,    93,   131,   133,     0,    93, | 
|  | 93,   127,     0,   138,     0,   185,   187,     0,     0,   260, | 
|  | 0,     0,     0,     0,     0,   139,   142,   143,     0,     0, | 
|  | 0,     0,     0,     0,   105,   103,   210,    93,   268,   262, | 
|  | 244,   243,     0,     0,    60,    59,    58,    57,     0,     0, | 
|  | 0,     0,    98,    98,   285,    93,    93,   276,     0,     0, | 
|  | 0,     0,     0,    93,    93,     0,     0,     0,     0,     0, | 
|  | 0,    95,   128,     0,   121,   122,   123,   126,   120,     0, | 
|  | 0,     0,     0,     0,     0,     0,   166,     0,     0,     0, | 
|  | 0,   100,   106,   104,   209,    93,   207,     0,   221,   222, | 
|  | 223,   228,   224,   225,   226,   227,   219,     0,   230,   235, | 
|  | 234,   236,     0,   245,     0,     0,    93,    93,     0,   281, | 
|  | 0,   283,   260,     0,     0,     0,     0,     0,     0,     0, | 
|  | 0,     0,     0,     0,     0,    93,     0,    92,   134,   132, | 
|  | 0,     0,     0,   156,     0,     0,     0,     0,     0,     0, | 
|  | 93,     0,   204,     0,   101,   220,     0,     0,     0,     0, | 
|  | 0,     0,     0,     0,     0,     0,   288,     0,     0,     0, | 
|  | 272,   273,     0,     0,     0,     0,   270,   269,     0,   286, | 
|  | 0,     0,     0,   261,     0,   163,     0,     0,   158,   159, | 
|  | 155,   162,   203,   206,   208,    93,   102,    96,     0,   229, | 
|  | 0,     0,   259,     0,     0,    98,    99,    98,     0,     0, | 
|  | 0,     0,     0,   264,   265,   259,    93,   160,   161,     0, | 
|  | 0,     0,   204,     0,   211,     0,     0,     0,    93,     0, | 
|  | 266,   267,     0,   282,   284,     0,     0,   271,   274,   275, | 
|  | 0,   287,   157,   164,   165,   205,    97,   231,     0,     0, | 
|  | 93,     0,     0,   255,     0,   277,     0,   248,     0,     0, | 
|  | 257,    93,     0,   256,   246,     0,   247,     0,    93,     0, | 
|  | 0,     0,   258,     0,     0,     0,     0,   253,     0,     0, | 
|  | 252,   249 | 
|  | }; | 
|  |  | 
|  | /* YYDEFGOTO[NTERM-NUM]. */ | 
|  | static const short int yydefgoto[] = | 
|  | { | 
|  | -1,    76,   179,   180,   181,   182,   221,   238,    91,    92, | 
|  | 9,    34,    35,    42,    48,   102,   200,   293,   130,   514, | 
|  | 409,   324,   487,   256,   325,    77,    93,   296,   189,   297, | 
|  | 298,   128,   245,   398,   246,    36,    10,    11,    12,    15, | 
|  | 14,   185,   209,   210,    59,   115,    20,    57,   119,    79, | 
|  | 483,   386,   387,   103,   192,    49,   110,    50,    43,   446, | 
|  | 399,    80,   401,   328,    51,   106,   107,   286,   549,   194, | 
|  | 347,   519,   371,   287,   288,   289,   290 | 
|  | }; | 
|  |  | 
|  | /* YYPACT[STATE-NUM] -- Index in YYTABLE of the portion describing | 
|  | STATE-NUM.  */ | 
|  | #define YYPACT_NINF -444 | 
|  | static const short int yypact[] = | 
|  | { | 
|  | 76,  -444,  -444,  -444,  -444,  -444,   -14,   -77,    12,   548, | 
|  | 89,    91,  -444,   -40,    79,   116,   -36,   -29,   -11,    -3, | 
|  | -444,    14,   119,   949,  -444,  -444,  -444,  -444,  -444,  -444, | 
|  | -444,  -444,  -444,  -444,    15,    15,  1230,  -444,  -444,  -444, | 
|  | -444,  -444,   131,  -444,  -444,  -444,  -444,  -444,   131,   124, | 
|  | -444,    -2,   130,   -12,   173,   179,   188,  -444,  -444,  -444, | 
|  | -444,  -444,    25,  -444,  -444,  -444,  -444,  -444,  -444,  -444, | 
|  | -444,  -444,   212,   214,     4,    72,  -444,  -444,    44,  -444, | 
|  | -444,  1230,  1271,   103,   152,   207,   225,   243,   260,   230, | 
|  | 241,   262,   269,   575,  -444,   263,  -444,  -444,  -444,  -444, | 
|  | -444,  -444,  1288,  -444,   -16,  -444,  -444,   117,  -444,  -444, | 
|  | -444,  -444,  -444,  -444,  -444,  -444,  -444,  -444,  -444,   -19, | 
|  | -84,   140,  -444,   136,   139,   539,  -444,    44,   -99,  -444, | 
|  | 150,  -444,    44,  -444,  -444,  -444,  -444,  -444,  -444,  -444, | 
|  | -444,  -444,  -444,  -444,  -444,  -444,  -444,  -444,  -444,  -444, | 
|  | -444,  -444,  -444,    77,   283,   151,  -444,  -444,  -444,  -444, | 
|  | -444,  -444,  -444,  -444,  -444,  -444,  -444,  -444,   154,  -444, | 
|  | -444,  -444,   156,   157,   158,   806,  1230,   720,   270,   159, | 
|  | 162,   166,   170,  -444,  -444,   155,  -444,   103,    20,   117, | 
|  | -444,  -444,  -444,  1369,  -444,   289,  -444,  -444,  -444,   153, | 
|  | -444,  1123,  1271,  1271,   164,   -98,  1271,  -444,  1123,   155, | 
|  | 155,  -444,  -444,  -444,  -444,  -444,  -444,  -444,  -444,  -444, | 
|  | -444,   174,  -444,  -444,  -444,  -444,  -444,  -444,  -444,  -444, | 
|  | -444,  -444,  -444,  -444,  -444,  -444,  -444,  -444,   175,  1230, | 
|  | 1230,  1230,  1230,  1230,  -444,  -444,   -15,   -90,  -444,   -93, | 
|  | -444,  1230,  1230,  1230,  1230,    -5,  -444,   140,   150,   177, | 
|  | -444,  1271,  -444,   256,  1329,    84,   176,   131,  -444,  -444, | 
|  | 77,   283,  1271,  1271,  1271,  1271,  1271,  1271,  1271,  1271, | 
|  | 1271,  1271,  1271,  1271,  1271,  1271,  -444,   131,  -444,   160, | 
|  | -444,  -444,  -444,     5,  -444,    20,  -444,   178,   180,    -4, | 
|  | -39,  -444,   181,    44,   182,  -444,  -444,  1230,  1230,  -444, | 
|  | 184,   186,   187,   190,  1230,  -444,  -444,  -444,   192,   193, | 
|  | 291,   194,   311,   328,  -444,   155,  1169,   756,  -444,  -444, | 
|  | 25,  -444,   899,   899,  -444,  -444,  -444,  -444,   899,  1288, | 
|  | 1271,  1271,    67,    85,  -444,   756,   -27,   197,   201,   202, | 
|  | 203,   205,   206,   756,   756,   310,   208,  1288,  1271,  1271, | 
|  | 153,  -444,   150,  1186,  -444,  -444,  -444,  -444,  -444,   209, | 
|  | 210,    73,  1230,  1230,  1230,  1230,  -444,  1230,  1230,  1271, | 
|  | 1230,  -444,  -444,  -444,  -444,    20,   211,   213,  -444,  -444, | 
|  | -444,  -444,  -444,  -444,  -444,  -444,   290,  1230,  -444,  -444, | 
|  | -444,  -444,   215,  -444,   221,   899,   756,   756,    13,  -444, | 
|  | 17,  -444,  -444,   899,   216,  1271,  1271,  1271,  1271,  1271, | 
|  | 223,   224,  1271,  1271,   899,   756,   226,  -444,  -444,  -444, | 
|  | 1230,  1230,  1271,  -444,   231,   235,   234,   240,   236,   252, | 
|  | -66,   258,    10,  1213,   317,  -444,   330,   -71,   382,   386, | 
|  | 266,   271,   272,   899,   401,   899,   278,   279,   899,   281, | 
|  | 44,  -444,   282,   288,   899,   899,    44,  -444,   292,  -444, | 
|  | 1271,   280,   287,  -444,  1230,  -444,  1230,  1230,  -444,  -444, | 
|  | -444,  -444,  -444,  -444,  -444,    20,  -444,   374,   293,  -444, | 
|  | 899,   899,  1271,   899,   899,   297,  -444,   297,   899,   298, | 
|  | 1271,  1271,  1271,  -444,  -444,  1271,   756,  -444,  -444,   296, | 
|  | 301,   305,    10,   424,  -444,   416,   309,   295,   756,    88, | 
|  | -444,  -444,   395,  -444,  -444,   306,   899,  -444,  -444,  -444, | 
|  | 100,  -444,  -444,  -444,  -444,  -444,  -444,  -444,   433,     3, | 
|  | 103,  1271,   418,  -444,   308,  -444,   899,  -444,  1031,     8, | 
|  | -444,   756,   437,  -444,  -444,   319,  -444,  1031,   103,   899, | 
|  | 440,   321,  -444,   387,   899,   442,   444,  -444,   899,   899, | 
|  | -444,  -444 | 
|  | }; | 
|  |  | 
|  | /* YYPGOTO[NTERM-NUM].  */ | 
|  | static const short int yypgoto[] = | 
|  | { | 
|  | -444,  -444,   268,   277,   294,   299,   218,   191,  -262,  -444, | 
|  | 356,  -444,  -444,  -444,  -444,  -245,  -196,  -444,   -60,  -444, | 
|  | -336,    27,  -444,  -199,  -444,  -444,   -23,   101,  -306,  -444, | 
|  | 264,   348,    -9,   383,  -171,   239,  -444,  -444,   464,  -444, | 
|  | -444,  -444,  -444,  -444,  -444,  -444,  -444,  -444,  -444,     1, | 
|  | -31,  -444,  -444,   438,  -444,  -444,  -444,  -444,  -444,  -444, | 
|  | -443,   -52,    78,  -217,  -444,   439,  -444,  -444,  -444,  -444, | 
|  | -444,   -10,    81,  -444,  -444,  -444,  -444 | 
|  | }; | 
|  |  | 
|  | /* YYTABLE[YYPACT[STATE-NUM]].  What to do in state STATE-NUM.  If | 
|  | positive, shift that token.  If negative, reduce the rule which | 
|  | number is the opposite.  If zero, do what YYDEFACT says. | 
|  | If YYTABLE_NINF, syntax error.  */ | 
|  | #define YYTABLE_NINF -172 | 
|  | static const short int yytable[] = | 
|  | { | 
|  | 78,    13,   121,   292,   338,   247,   249,   411,   124,   190, | 
|  | 305,   306,    13,   334,   335,   336,   337,   105,   334,   335, | 
|  | 336,   337,   339,   121,   108,   453,   322,    94,     1,   455, | 
|  | 2,   197,   198,   405,    16,    17,    18,   206,   206,   113, | 
|  | 114,   184,   357,   314,    24,    25,   314,   331,   323,   207, | 
|  | 302,   424,   127,    19,   199,   317,   316,   344,    21,   132, | 
|  | 348,   349,   350,   351,   352,   314,   454,   355,   356,    22, | 
|  | 454,   120,   131,   480,   129,   489,  -171,    60,    61,   188, | 
|  | 83,    63,    64,    65,    66,    67,    68,    69,    70,    37, | 
|  | 1,  -170,     2,   332,     1,    39,     2,     3,   120,    52, | 
|  | 333,   129,   127,     4,     5,   555,    53,   366,    13,     1, | 
|  | 120,     2,     3,   129,   561,   413,    71,   195,     4,     5, | 
|  | 40,   314,    41,     6,    54,   196,   383,   257,   258,   315, | 
|  | 7,   191,    55,   120,     8,     1,   129,     2,     6,    58, | 
|  | 365,   360,   426,   105,   361,     7,   109,   547,   208,     8, | 
|  | 112,   125,   556,    44,    45,    46,    56,   120,    47,   523, | 
|  | 129,   524,   120,   -93,   427,   211,   212,   213,   214,   215, | 
|  | 216,   217,   218,   219,   220,   133,   134,   116,   295,   299, | 
|  | 300,   120,   -93,   303,   129,   295,   334,   335,   336,   337, | 
|  | 259,    95,    96,    97,    98,    99,   100,   101,   459,   117, | 
|  | 461,   462,   463,   408,   120,   -93,   467,   129,   118,   432, | 
|  | -60,   -60,   433,    72,    73,   473,   122,    74,   123,    75, | 
|  | 126,   410,   120,   -93,   541,   129,   447,   542,   -59,   -59, | 
|  | 309,   310,   311,   312,   313,   362,   541,   -61,   327,   545, | 
|  | 120,   327,   318,   319,   320,   321,   -58,   -58,   -62,   342, | 
|  | 343,   327,   345,   346,   327,   327,   327,   327,   327,   353, | 
|  | 354,   327,   327,   -57,   -57,   135,   136,   186,   197,   198, | 
|  | 121,   358,   359,    81,    82,   400,   137,   548,   201,   202, | 
|  | 400,   400,   203,   527,   528,   529,   400,   557,   208,   239, | 
|  | 250,   255,   240,   400,   241,   242,   243,   251,   369,   370, | 
|  | 252,   400,   400,   385,   253,   376,   222,   223,   254,   291, | 
|  | 301,   329,   307,   308,   363,   326,   188,   406,   407,   364, | 
|  | 372,   368,   373,   374,   379,   442,   375,   367,   377,   378, | 
|  | 380,   381,   382,   414,   188,   425,   327,   415,   416,   417, | 
|  | 295,   418,   419,   422,   423,   430,   431,   443,   322,   445, | 
|  | 488,   448,   444,   400,   400,   400,   440,   449,   458,   464, | 
|  | 465,   400,   470,   434,   435,   436,   437,   474,   438,   439, | 
|  | 476,   441,   400,   400,   475,   478,   477,   224,   225,   226, | 
|  | 227,   228,   229,   230,   231,   232,   233,   234,   235,   236, | 
|  | 237,   479,   327,   460,   327,   327,   327,   481,   490,   466, | 
|  | 327,   400,   491,   400,   492,   496,   400,   493,   494,   327, | 
|  | 402,   403,   400,   400,   432,   498,   404,   500,   501,   507, | 
|  | 485,   471,   472,   412,   502,   512,   508,   513,   536,   515, | 
|  | 505,   420,   421,   522,   526,   532,   537,   539,   400,   400, | 
|  | 533,   400,   400,   482,   534,   538,   400,   506,   454,   546, | 
|  | 543,   552,   553,   559,   400,   560,   564,   565,   568,   566, | 
|  | 569,   282,   341,   193,   429,   509,   400,   510,   511,   518, | 
|  | 283,   486,   304,   205,   400,    38,   183,   327,   327,   327, | 
|  | 550,   535,   518,   450,   451,   452,   104,   284,   340,     0, | 
|  | 111,   457,   285,   456,   400,   530,     0,     0,   562,   400, | 
|  | 0,     0,   468,   469,     0,     0,     0,   400,     0,     0, | 
|  | 0,     0,   400,   482,     0,     0,   400,   400,   551,     0, | 
|  | 0,     0,     0,     0,     0,     0,     0,     0,     0,     0, | 
|  | 0,   495,     0,   497,     0,     0,   499,     0,     0,     0, | 
|  | 0,     0,   503,   504,    60,    61,     0,    83,    63,    64, | 
|  | 65,    66,    67,    68,    69,    70,     0,     1,     0,     2, | 
|  | 0,     0,     0,     0,     0,    23,     0,     0,   516,   517, | 
|  | 0,   520,   521,     0,     0,     0,   525,    24,    25,     0, | 
|  | 60,    61,     0,    71,   531,    26,    27,    28,    29,    30, | 
|  | 31,    32,     0,     1,    33,     2,   540,   138,     0,     0, | 
|  | 0,     0,     0,     0,   544,     0,     0,     0,     0,     0, | 
|  | 139,   140,     0,     0,     0,     0,     0,     0,     0,     0, | 
|  | 0,     0,     0,     0,   554,     0,     0,     0,     0,   558, | 
|  | 0,     0,     0,     0,     0,     0,     0,   563,     0,     0, | 
|  | 0,     0,   567,     0,     0,     0,   570,   571,     0,   141, | 
|  | 142,   143,   144,   145,   146,   147,   148,   149,   150,   151, | 
|  | 152,   153,   154,     0,     0,     0,     0,     0,     0,     0, | 
|  | 0,     0,     0,     0,     0,     0,     0,     0,     0,     0, | 
|  | 72,    73,     0,     0,    74,     0,    75,   204,   155,   156, | 
|  | 157,   158,   159,   160,   161,   162,   163,   164,   165,   166, | 
|  | 167,     0,   168,   169,   170,   171,     0,   172,   173,   174, | 
|  | 0,     0,   120,     0,     0,   129,     0,   175,     0,     0, | 
|  | 176,     0,   177,     0,   178,    60,    61,     0,    83,    84, | 
|  | 85,    86,    87,    88,    89,    90,    70,     0,     1,     0, | 
|  | 2,     0,     0,     0,     0,     0,     0,     0,     0,     0, | 
|  | 0,     0,     0,     0,     0,     0,     0,     0,     0,   388, | 
|  | 389,    60,    61,   390,    71,     0,     0,     0,     0,     0, | 
|  | 0,     0,     0,     0,     1,     0,     2,     0,   391,   392, | 
|  | 393,     0,     0,     0,     0,     0,     0,     0,     0,     0, | 
|  | 0,   394,   395,     0,     0,     0,     0,     0,     0,     0, | 
|  | 0,     0,     0,     0,     0,     0,     0,     0,     0,     0, | 
|  | 0,    60,    61,   396,    83,    84,    85,    86,    87,    88, | 
|  | 89,    90,    70,     0,     1,     0,     2,     0,     0,     0, | 
|  | 141,   142,   143,   144,   145,   146,   147,   148,   149,   150, | 
|  | 151,   152,   153,   154,     0,     0,     0,     0,     0,     0, | 
|  | 71,     0,     0,     0,     0,     0,     0,     0,     0,     0, | 
|  | 0,    72,    73,     0,     0,    74,     0,    75,   248,   155, | 
|  | 156,   157,   158,   159,   160,   161,   162,   163,   164,   165, | 
|  | 166,   167,     0,   168,   169,   170,   171,     0,   172,   173, | 
|  | 174,     0,     0,   120,     0,     0,   129,     0,     0,     0, | 
|  | 0,   397,   388,   389,    60,    61,   390,     0,     0,     0, | 
|  | 0,     0,     0,     0,     0,     0,     0,     1,     0,     2, | 
|  | 0,   391,   392,   393,     0,     0,     0,     0,     0,     0, | 
|  | 0,     0,     0,     0,   394,   395,     0,     0,     0,     0, | 
|  | 0,     0,     0,     0,     0,     0,     0,    72,    73,     0, | 
|  | 244,    74,     0,    75,    60,    61,   396,    62,    63,    64, | 
|  | 65,    66,    67,    68,    69,    70,     0,     1,     0,     2, | 
|  | 0,     0,     0,   141,   142,   143,   144,   145,   146,   147, | 
|  | 148,   149,   150,   151,   152,   153,   154,     0,     0,     0, | 
|  | 0,     0,     0,    71,     0,     0,     0,     0,     0,     0, | 
|  | 0,     0,     0,     0,     0,     0,     0,     0,     0,     0, | 
|  | 0,     0,   155,   156,   157,   158,   159,   160,   161,   162, | 
|  | 163,   164,   165,   166,   167,     0,   168,   169,   170,   171, | 
|  | 0,   172,   173,   174,   388,   389,     0,     0,   390,     0, | 
|  | 0,     0,     0,     0,   397,     0,     0,     0,     0,     0, | 
|  | 0,     0,     0,   391,   392,   393,     0,     0,     0,     0, | 
|  | 0,     0,     0,     0,     0,     0,   394,   395,     0,     0, | 
|  | 0,     0,     0,     0,     0,     0,     0,     0,     0,     0, | 
|  | 0,     0,     0,     0,     0,     0,     0,     0,   396,     0, | 
|  | 72,    73,     0,     0,    74,     0,    75,     0,     0,     0, | 
|  | 0,     0,     0,     0,     0,   141,   142,   143,   144,   145, | 
|  | 146,   147,   148,   149,   150,   151,   152,   153,   154,     0, | 
|  | 0,     0,     0,     0,     0,     0,     0,     0,    60,    61, | 
|  | 0,    83,    63,    64,    65,    66,    67,    68,    69,    70, | 
|  | 0,     1,     0,     2,   155,   156,   157,   158,   159,   160, | 
|  | 161,   162,   163,   164,   165,   166,   167,   294,   168,   169, | 
|  | 170,   171,     0,   172,   173,   174,     0,    71,     0,     0, | 
|  | 0,     0,     0,     0,    60,    61,   397,    83,    63,    64, | 
|  | 65,    66,    67,    68,    69,    70,     0,     1,     0,     2, | 
|  | 0,    60,    61,     0,    83,    63,    64,    65,    66,    67, | 
|  | 68,    69,    70,   384,     1,     0,     2,     0,     0,     0, | 
|  | 0,     0,     0,    71,     0,     0,     0,     0,    60,    61, | 
|  | 428,    83,    63,    64,    65,    66,    67,    68,    69,    70, | 
|  | 71,     1,     0,     2,     0,    60,    61,     0,    83,    84, | 
|  | 85,    86,    87,    88,    89,    90,    70,   484,     1,     0, | 
|  | 2,     0,     0,     0,     0,     0,     0,    71,     0,     0, | 
|  | 0,     0,     0,     0,    72,    73,     0,     0,    74,     0, | 
|  | 75,     0,     0,     0,    71,     0,    60,    61,     0,    83, | 
|  | 63,    64,    65,    66,    67,    68,    69,    70,     0,     1, | 
|  | 0,     2,     0,    60,    61,     0,   187,    63,    64,    65, | 
|  | 66,    67,    68,    69,    70,     0,     1,     0,     2,     0, | 
|  | 72,    73,     0,     0,    74,    71,    75,     0,     0,     0, | 
|  | 0,     0,     0,     0,     0,     0,     0,    72,    73,     0, | 
|  | 0,    74,    71,    75,    60,    61,     0,   330,    63,    64, | 
|  | 65,    66,    67,    68,    69,    70,     0,     1,     0,     2, | 
|  | 0,     0,     0,     0,    72,    73,     0,     0,    74,     0, | 
|  | 75,     0,     0,     0,     0,     0,     0,     0,     0,     0, | 
|  | 0,    72,    73,    71,     0,    74,     0,    75,     0,     0, | 
|  | 0,     0,     0,     0,     0,     0,     0,     0,     0,     0, | 
|  | 0,     0,     0,     0,     0,     0,     0,     0,     0,     0, | 
|  | 0,   260,     0,     0,     0,     0,     0,     0,     0,     0, | 
|  | 0,     0,    72,    73,   261,     0,    74,     0,    75,     0, | 
|  | 0,     0,     0,     0,   262,   263,     0,     0,     0,    72, | 
|  | 73,     0,     0,    74,     0,    75,     0,   264,   265,   266, | 
|  | 267,   268,   269,   141,   142,   143,   144,   145,   146,   147, | 
|  | 148,   149,   150,   151,   152,   270,   271,     0,     0,     0, | 
|  | 0,     0,     0,     0,     0,     0,     0,     0,     0,     0, | 
|  | 72,    73,     0,     0,    74,     0,    75,   272,   273,   274, | 
|  | 0,     0,   275,   156,   157,   158,   159,   160,   161,   162, | 
|  | 163,   164,   165,   166,   167,   276,   277,   169,   170,   171, | 
|  | 278,   279,   280,   281 | 
|  | }; | 
|  |  | 
|  | static const short int yycheck[] = | 
|  | { | 
|  | 23,     0,    62,   199,   266,   176,   177,   343,     4,    25, | 
|  | 209,   210,    11,    10,    11,    12,    13,    19,    10,    11, | 
|  | 12,    13,   267,    83,    26,    12,    31,    36,    18,    12, | 
|  | 20,   115,   116,   339,    48,    49,    50,   136,   136,    51, | 
|  | 52,    93,   287,   136,    29,    30,   136,   264,    53,   148, | 
|  | 148,   357,    75,    67,   138,   148,   146,   274,   135,    82, | 
|  | 277,   278,   279,   280,   281,   136,    53,   284,   285,    57, | 
|  | 53,   137,    81,   139,   140,   146,     0,     5,     6,   102, | 
|  | 8,     9,    10,    11,    12,    13,    14,    15,    16,     0, | 
|  | 18,     0,    20,     9,    18,   135,    20,    21,   137,   135, | 
|  | 16,   140,   125,    27,    28,   548,   135,   146,   107,    18, | 
|  | 137,    20,    21,   140,   557,   142,    44,   136,    27,    28, | 
|  | 41,   136,    43,    47,   135,   144,   325,   187,   188,   144, | 
|  | 54,   147,   135,   137,    58,    18,   140,    20,    47,    20, | 
|  | 144,   136,   359,    19,   139,    54,   148,   144,   138,    58, | 
|  | 20,   147,   144,    37,    38,    39,   142,   137,    42,   495, | 
|  | 140,   497,   137,   138,   360,    88,    89,    90,    91,    92, | 
|  | 93,    94,    95,    96,    97,    23,    24,     4,   201,   202, | 
|  | 203,   137,   138,   206,   140,   208,    10,    11,    12,    13, | 
|  | 189,    60,    61,    62,    63,    64,    65,    66,   415,    20, | 
|  | 417,   418,   419,   136,   137,   138,   423,   140,    20,   136, | 
|  | 3,     4,   139,   141,   142,   432,     4,   145,     4,   147, | 
|  | 148,   136,   137,   138,   136,   140,   397,   139,     3,     4, | 
|  | 239,   240,   241,   242,   243,   295,   136,     7,   261,   139, | 
|  | 137,   264,   251,   252,   253,   254,     3,     4,     7,   272, | 
|  | 273,   274,   275,   276,   277,   278,   279,   280,   281,   282, | 
|  | 283,   284,   285,     3,     4,     3,     4,     4,   115,   116, | 
|  | 330,   111,   112,    34,    35,   327,     7,   539,   138,   143, | 
|  | 332,   333,   143,   500,   501,   502,   338,   549,   138,   138, | 
|  | 20,   136,   138,   345,   138,   138,   138,   138,   307,   308, | 
|  | 138,   353,   354,   326,   138,   314,    23,    24,   138,    20, | 
|  | 146,    55,   138,   138,   136,   138,   339,   340,   341,   139, | 
|  | 136,   139,   136,   136,    33,   385,   136,   146,   136,   136, | 
|  | 136,    20,     4,   136,   357,   358,   359,   136,   136,   136, | 
|  | 363,   136,   136,    33,   136,   136,   136,   136,    31,    59, | 
|  | 20,   136,   139,   405,   406,   407,   379,   136,   142,   136, | 
|  | 136,   413,   136,   372,   373,   374,   375,   136,   377,   378, | 
|  | 136,   380,   424,   425,   139,   139,   136,    94,    95,    96, | 
|  | 97,    98,    99,   100,   101,   102,   103,   104,   105,   106, | 
|  | 107,   139,   415,   416,   417,   418,   419,   139,    16,   422, | 
|  | 423,   453,    16,   455,   138,     4,   458,   136,   136,   432, | 
|  | 332,   333,   464,   465,   136,   136,   338,   136,   136,   139, | 
|  | 443,   430,   431,   345,   136,   485,   139,    53,     4,   136, | 
|  | 138,   353,   354,   136,   136,   139,    20,   142,   490,   491, | 
|  | 139,   493,   494,   442,   139,   136,   498,   470,    53,    16, | 
|  | 144,    33,   144,    16,   506,   136,    16,   136,    16,    72, | 
|  | 16,   193,   271,   107,   363,   474,   518,   476,   477,   492, | 
|  | 193,   444,   208,   125,   526,    11,    93,   500,   501,   502, | 
|  | 540,   512,   505,   405,   406,   407,    48,   193,   270,    -1, | 
|  | 51,   413,   193,   412,   546,   505,    -1,    -1,   558,   551, | 
|  | -1,    -1,   424,   425,    -1,    -1,    -1,   559,    -1,    -1, | 
|  | -1,    -1,   564,   512,    -1,    -1,   568,   569,   541,    -1, | 
|  | -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1, | 
|  | -1,   453,    -1,   455,    -1,    -1,   458,    -1,    -1,    -1, | 
|  | -1,    -1,   464,   465,     5,     6,    -1,     8,     9,    10, | 
|  | 11,    12,    13,    14,    15,    16,    -1,    18,    -1,    20, | 
|  | -1,    -1,    -1,    -1,    -1,    17,    -1,    -1,   490,   491, | 
|  | -1,   493,   494,    -1,    -1,    -1,   498,    29,    30,    -1, | 
|  | 5,     6,    -1,    44,   506,    37,    38,    39,    40,    41, | 
|  | 42,    43,    -1,    18,    46,    20,   518,    22,    -1,    -1, | 
|  | -1,    -1,    -1,    -1,   526,    -1,    -1,    -1,    -1,    -1, | 
|  | 35,    36,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1, | 
|  | -1,    -1,    -1,    -1,   546,    -1,    -1,    -1,    -1,   551, | 
|  | -1,    -1,    -1,    -1,    -1,    -1,    -1,   559,    -1,    -1, | 
|  | -1,    -1,   564,    -1,    -1,    -1,   568,   569,    -1,    74, | 
|  | 75,    76,    77,    78,    79,    80,    81,    82,    83,    84, | 
|  | 85,    86,    87,    -1,    -1,    -1,    -1,    -1,    -1,    -1, | 
|  | -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1, | 
|  | 141,   142,    -1,    -1,   145,    -1,   147,   148,   113,   114, | 
|  | 115,   116,   117,   118,   119,   120,   121,   122,   123,   124, | 
|  | 125,    -1,   127,   128,   129,   130,    -1,   132,   133,   134, | 
|  | -1,    -1,   137,    -1,    -1,   140,    -1,   142,    -1,    -1, | 
|  | 145,    -1,   147,    -1,   149,     5,     6,    -1,     8,     9, | 
|  | 10,    11,    12,    13,    14,    15,    16,    -1,    18,    -1, | 
|  | 20,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1, | 
|  | -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,     3, | 
|  | 4,     5,     6,     7,    44,    -1,    -1,    -1,    -1,    -1, | 
|  | -1,    -1,    -1,    -1,    18,    -1,    20,    -1,    22,    23, | 
|  | 24,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1, | 
|  | -1,    35,    36,    -1,    -1,    -1,    -1,    -1,    -1,    -1, | 
|  | -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1, | 
|  | -1,     5,     6,    57,     8,     9,    10,    11,    12,    13, | 
|  | 14,    15,    16,    -1,    18,    -1,    20,    -1,    -1,    -1, | 
|  | 74,    75,    76,    77,    78,    79,    80,    81,    82,    83, | 
|  | 84,    85,    86,    87,    -1,    -1,    -1,    -1,    -1,    -1, | 
|  | 44,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1, | 
|  | -1,   141,   142,    -1,    -1,   145,    -1,   147,   148,   113, | 
|  | 114,   115,   116,   117,   118,   119,   120,   121,   122,   123, | 
|  | 124,   125,    -1,   127,   128,   129,   130,    -1,   132,   133, | 
|  | 134,    -1,    -1,   137,    -1,    -1,   140,    -1,    -1,    -1, | 
|  | -1,   145,     3,     4,     5,     6,     7,    -1,    -1,    -1, | 
|  | -1,    -1,    -1,    -1,    -1,    -1,    -1,    18,    -1,    20, | 
|  | -1,    22,    23,    24,    -1,    -1,    -1,    -1,    -1,    -1, | 
|  | -1,    -1,    -1,    -1,    35,    36,    -1,    -1,    -1,    -1, | 
|  | -1,    -1,    -1,    -1,    -1,    -1,    -1,   141,   142,    -1, | 
|  | 144,   145,    -1,   147,     5,     6,    57,     8,     9,    10, | 
|  | 11,    12,    13,    14,    15,    16,    -1,    18,    -1,    20, | 
|  | -1,    -1,    -1,    74,    75,    76,    77,    78,    79,    80, | 
|  | 81,    82,    83,    84,    85,    86,    87,    -1,    -1,    -1, | 
|  | -1,    -1,    -1,    44,    -1,    -1,    -1,    -1,    -1,    -1, | 
|  | -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1, | 
|  | -1,    -1,   113,   114,   115,   116,   117,   118,   119,   120, | 
|  | 121,   122,   123,   124,   125,    -1,   127,   128,   129,   130, | 
|  | -1,   132,   133,   134,     3,     4,    -1,    -1,     7,    -1, | 
|  | -1,    -1,    -1,    -1,   145,    -1,    -1,    -1,    -1,    -1, | 
|  | -1,    -1,    -1,    22,    23,    24,    -1,    -1,    -1,    -1, | 
|  | -1,    -1,    -1,    -1,    -1,    -1,    35,    36,    -1,    -1, | 
|  | -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1, | 
|  | -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    57,    -1, | 
|  | 141,   142,    -1,    -1,   145,    -1,   147,    -1,    -1,    -1, | 
|  | -1,    -1,    -1,    -1,    -1,    74,    75,    76,    77,    78, | 
|  | 79,    80,    81,    82,    83,    84,    85,    86,    87,    -1, | 
|  | -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,     5,     6, | 
|  | -1,     8,     9,    10,    11,    12,    13,    14,    15,    16, | 
|  | -1,    18,    -1,    20,   113,   114,   115,   116,   117,   118, | 
|  | 119,   120,   121,   122,   123,   124,   125,    34,   127,   128, | 
|  | 129,   130,    -1,   132,   133,   134,    -1,    44,    -1,    -1, | 
|  | -1,    -1,    -1,    -1,     5,     6,   145,     8,     9,    10, | 
|  | 11,    12,    13,    14,    15,    16,    -1,    18,    -1,    20, | 
|  | -1,     5,     6,    -1,     8,     9,    10,    11,    12,    13, | 
|  | 14,    15,    16,    34,    18,    -1,    20,    -1,    -1,    -1, | 
|  | -1,    -1,    -1,    44,    -1,    -1,    -1,    -1,     5,     6, | 
|  | 34,     8,     9,    10,    11,    12,    13,    14,    15,    16, | 
|  | 44,    18,    -1,    20,    -1,     5,     6,    -1,     8,     9, | 
|  | 10,    11,    12,    13,    14,    15,    16,    34,    18,    -1, | 
|  | 20,    -1,    -1,    -1,    -1,    -1,    -1,    44,    -1,    -1, | 
|  | -1,    -1,    -1,    -1,   141,   142,    -1,    -1,   145,    -1, | 
|  | 147,    -1,    -1,    -1,    44,    -1,     5,     6,    -1,     8, | 
|  | 9,    10,    11,    12,    13,    14,    15,    16,    -1,    18, | 
|  | -1,    20,    -1,     5,     6,    -1,     8,     9,    10,    11, | 
|  | 12,    13,    14,    15,    16,    -1,    18,    -1,    20,    -1, | 
|  | 141,   142,    -1,    -1,   145,    44,   147,    -1,    -1,    -1, | 
|  | -1,    -1,    -1,    -1,    -1,    -1,    -1,   141,   142,    -1, | 
|  | -1,   145,    44,   147,     5,     6,    -1,     8,     9,    10, | 
|  | 11,    12,    13,    14,    15,    16,    -1,    18,    -1,    20, | 
|  | -1,    -1,    -1,    -1,   141,   142,    -1,    -1,   145,    -1, | 
|  | 147,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1, | 
|  | -1,   141,   142,    44,    -1,   145,    -1,   147,    -1,    -1, | 
|  | -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1, | 
|  | -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1, | 
|  | -1,    32,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1, | 
|  | -1,    -1,   141,   142,    45,    -1,   145,    -1,   147,    -1, | 
|  | -1,    -1,    -1,    -1,    55,    56,    -1,    -1,    -1,   141, | 
|  | 142,    -1,    -1,   145,    -1,   147,    -1,    68,    69,    70, | 
|  | 71,    72,    73,    74,    75,    76,    77,    78,    79,    80, | 
|  | 81,    82,    83,    84,    85,    86,    87,    -1,    -1,    -1, | 
|  | -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1,    -1, | 
|  | 141,   142,    -1,    -1,   145,    -1,   147,   108,   109,   110, | 
|  | -1,    -1,   113,   114,   115,   116,   117,   118,   119,   120, | 
|  | 121,   122,   123,   124,   125,   126,   127,   128,   129,   130, | 
|  | 131,   132,   133,   134 | 
|  | }; | 
|  |  | 
|  | /* YYSTOS[STATE-NUM] -- The (internal number of the) accessing | 
|  | symbol of state STATE-NUM.  */ | 
|  | static const unsigned char yystos[] = | 
|  | { | 
|  | 0,    18,    20,    21,    27,    28,    47,    54,    58,   160, | 
|  | 186,   187,   188,   199,   190,   189,    48,    49,    50,    67, | 
|  | 196,   135,    57,    17,    29,    30,    37,    38,    39,    40, | 
|  | 41,    42,    43,    46,   161,   162,   185,     0,   188,   135, | 
|  | 41,    43,   163,   208,    37,    38,    39,    42,   164,   205, | 
|  | 207,   214,   135,   135,   135,   135,   142,   197,    20,   194, | 
|  | 5,     6,     8,     9,    10,    11,    12,    13,    14,    15, | 
|  | 16,    44,   141,   142,   145,   147,   151,   175,   176,   199, | 
|  | 211,   185,   185,     8,     9,    10,    11,    12,    13,    14, | 
|  | 15,   158,   159,   176,   182,    60,    61,    62,    63,    64, | 
|  | 65,    66,   165,   203,   203,    19,   215,   216,    26,   148, | 
|  | 206,   215,    20,    51,    52,   195,     4,    20,    20,   198, | 
|  | 137,   168,     4,     4,     4,   147,   148,   176,   181,   140, | 
|  | 168,   182,   176,    23,    24,     3,     4,     7,    22,    35, | 
|  | 36,    74,    75,    76,    77,    78,    79,    80,    81,    82, | 
|  | 83,    84,    85,    86,    87,   113,   114,   115,   116,   117, | 
|  | 118,   119,   120,   121,   122,   123,   124,   125,   127,   128, | 
|  | 129,   130,   132,   133,   134,   142,   145,   147,   149,   152, | 
|  | 153,   154,   155,   183,   211,   191,     4,     8,   176,   178, | 
|  | 25,   147,   204,   160,   219,   136,   144,   115,   116,   138, | 
|  | 166,   138,   143,   143,   148,   181,   136,   148,   138,   192, | 
|  | 193,    88,    89,    90,    91,    92,    93,    94,    95,    96, | 
|  | 97,   156,    23,    24,    94,    95,    96,    97,    98,    99, | 
|  | 100,   101,   102,   103,   104,   105,   106,   107,   157,   138, | 
|  | 138,   138,   138,   138,   144,   182,   184,   184,   148,   184, | 
|  | 20,   138,   138,   138,   138,   136,   173,   168,   168,   199, | 
|  | 32,    45,    55,    56,    68,    69,    70,    71,    72,    73, | 
|  | 86,    87,   108,   109,   110,   113,   126,   127,   131,   132, | 
|  | 133,   134,   152,   153,   154,   155,   217,   223,   224,   225, | 
|  | 226,    20,   166,   167,    34,   176,   177,   179,   180,   176, | 
|  | 176,   146,   148,   176,   180,   173,   173,   138,   138,   182, | 
|  | 182,   182,   182,   182,   136,   144,   146,   148,   182,   182, | 
|  | 182,   182,    31,    53,   171,   174,   138,   176,   213,    55, | 
|  | 8,   213,     9,    16,    10,    11,    12,    13,   158,   165, | 
|  | 156,   157,   176,   176,   213,   176,   176,   220,   213,   213, | 
|  | 213,   213,   213,   176,   176,   213,   213,   165,   111,   112, | 
|  | 136,   139,   168,   136,   139,   144,   146,   146,   139,   182, | 
|  | 182,   222,   136,   136,   136,   136,   182,   136,   136,    33, | 
|  | 136,    20,     4,   173,    34,   176,   201,   202,     3,     4, | 
|  | 7,    22,    23,    24,    35,    36,    57,   145,   183,   210, | 
|  | 211,   212,   212,   212,   212,   178,   176,   176,   136,   170, | 
|  | 136,   170,   212,   142,   136,   136,   136,   136,   136,   136, | 
|  | 212,   212,    33,   136,   178,   176,   213,   166,    34,   177, | 
|  | 136,   136,   136,   139,   182,   182,   182,   182,   182,   182, | 
|  | 176,   182,   168,   136,   139,    59,   209,   184,   136,   136, | 
|  | 212,   212,   212,    12,    53,    12,   222,   212,   142,   213, | 
|  | 176,   213,   213,   213,   136,   136,   176,   213,   212,   212, | 
|  | 136,   182,   182,   213,   136,   139,   136,   136,   139,   139, | 
|  | 139,   139,   199,   200,    34,   176,   171,   172,    20,   146, | 
|  | 16,    16,   138,   136,   136,   212,     4,   212,   136,   212, | 
|  | 136,   136,   136,   212,   212,   138,   176,   139,   139,   182, | 
|  | 182,   182,   168,    53,   169,   136,   212,   212,   176,   221, | 
|  | 212,   212,   136,   170,   170,   212,   136,   213,   213,   213, | 
|  | 221,   212,   139,   139,   139,   200,     4,    20,   136,   142, | 
|  | 212,   136,   139,   144,   212,   139,    16,   144,   158,   218, | 
|  | 168,   176,    33,   144,   212,   210,   144,   158,   212,    16, | 
|  | 136,   210,   168,   212,    16,   136,    72,   212,    16,    16, | 
|  | 212,   212 | 
|  | }; | 
|  |  | 
|  | #define yyerrok		(yyerrstatus = 0) | 
|  | #define yyclearin	(yychar = YYEMPTY) | 
|  | #define YYEMPTY		(-2) | 
|  | #define YYEOF		0 | 
|  |  | 
|  | #define YYACCEPT	goto yyacceptlab | 
|  | #define YYABORT		goto yyabortlab | 
|  | #define YYERROR		goto yyerrorlab | 
|  |  | 
|  |  | 
|  | /* Like YYERROR except do call yyerror.  This remains here temporarily | 
|  | to ease the transition to the new meaning of YYERROR, for GCC. | 
|  | Once GCC version 2 has supplanted version 1, this can go.  */ | 
|  |  | 
|  | #define YYFAIL		goto yyerrlab | 
|  |  | 
|  | #define YYRECOVERING()  (!!yyerrstatus) | 
|  |  | 
|  | #define YYBACKUP(Token, Value)					\ | 
|  | do								\ | 
|  | if (yychar == YYEMPTY && yylen == 1)				\ | 
|  | {								\ | 
|  | yychar = (Token);						\ | 
|  | yylval = (Value);						\ | 
|  | yytoken = YYTRANSLATE (yychar);				\ | 
|  | YYPOPSTACK;						\ | 
|  | goto yybackup;						\ | 
|  | }								\ | 
|  | else								\ | 
|  | {								\ | 
|  | yyerror (YY_("syntax error: cannot back up")); \ | 
|  | YYERROR;							\ | 
|  | }								\ | 
|  | while (0) | 
|  |  | 
|  |  | 
|  | #define YYTERROR	1 | 
|  | #define YYERRCODE	256 | 
|  |  | 
|  |  | 
|  | /* YYLLOC_DEFAULT -- Set CURRENT to span from RHS[1] to RHS[N]. | 
|  | If N is 0, then set CURRENT to the empty location which ends | 
|  | the previous symbol: RHS[0] (always defined).  */ | 
|  |  | 
|  | #define YYRHSLOC(Rhs, K) ((Rhs)[K]) | 
|  | #ifndef YYLLOC_DEFAULT | 
|  | # define YYLLOC_DEFAULT(Current, Rhs, N)				\ | 
|  | do									\ | 
|  | if (N)								\ | 
|  | {								\ | 
|  | (Current).first_line   = YYRHSLOC (Rhs, 1).first_line;	\ | 
|  | (Current).first_column = YYRHSLOC (Rhs, 1).first_column;	\ | 
|  | (Current).last_line    = YYRHSLOC (Rhs, N).last_line;		\ | 
|  | (Current).last_column  = YYRHSLOC (Rhs, N).last_column;	\ | 
|  | }								\ | 
|  | else								\ | 
|  | {								\ | 
|  | (Current).first_line   = (Current).last_line   =		\ | 
|  | YYRHSLOC (Rhs, 0).last_line;				\ | 
|  | (Current).first_column = (Current).last_column =		\ | 
|  | YYRHSLOC (Rhs, 0).last_column;				\ | 
|  | }								\ | 
|  | while (0) | 
|  | #endif | 
|  |  | 
|  |  | 
|  | /* YY_LOCATION_PRINT -- Print the location on the stream. | 
|  | This macro was not mandated originally: define only if we know | 
|  | we won't break user code: when these are the locations we know.  */ | 
|  |  | 
|  | #ifndef YY_LOCATION_PRINT | 
|  | # if YYLTYPE_IS_TRIVIAL | 
|  | #  define YY_LOCATION_PRINT(File, Loc)			\ | 
|  | fprintf (File, "%d.%d-%d.%d",			\ | 
|  | (Loc).first_line, (Loc).first_column,	\ | 
|  | (Loc).last_line,  (Loc).last_column) | 
|  | # else | 
|  | #  define YY_LOCATION_PRINT(File, Loc) ((void) 0) | 
|  | # endif | 
|  | #endif | 
|  |  | 
|  |  | 
|  | /* YYLEX -- calling `yylex' with the right arguments.  */ | 
|  |  | 
|  | #ifdef YYLEX_PARAM | 
|  | # define YYLEX yylex (YYLEX_PARAM) | 
|  | #else | 
|  | # define YYLEX yylex () | 
|  | #endif | 
|  |  | 
|  | /* Enable debugging if requested.  */ | 
|  | #if YYDEBUG | 
|  |  | 
|  | # ifndef YYFPRINTF | 
|  | #  include <stdio.h> /* INFRINGES ON USER NAME SPACE */ | 
|  | #  define YYFPRINTF fprintf | 
|  | # endif | 
|  |  | 
|  | # define YYDPRINTF(Args)			\ | 
|  | do {						\ | 
|  | if (yydebug)					\ | 
|  | YYFPRINTF Args;				\ | 
|  | } while (0) | 
|  |  | 
|  | # define YY_SYMBOL_PRINT(Title, Type, Value, Location)		\ | 
|  | do {								\ | 
|  | if (yydebug)							\ | 
|  | {								\ | 
|  | YYFPRINTF (stderr, "%s ", Title);				\ | 
|  | yysymprint (stderr,					\ | 
|  | Type, Value);	\ | 
|  | YYFPRINTF (stderr, "\n");					\ | 
|  | }								\ | 
|  | } while (0) | 
|  |  | 
|  | /*------------------------------------------------------------------. | 
|  | | yy_stack_print -- Print the state stack from its BOTTOM up to its | | 
|  | | TOP (included).                                                   | | 
|  | `------------------------------------------------------------------*/ | 
|  |  | 
|  | #if defined (__STDC__) || defined (__cplusplus) | 
|  | static void | 
|  | yy_stack_print (short int *bottom, short int *top) | 
|  | #else | 
|  | static void | 
|  | yy_stack_print (bottom, top) | 
|  | short int *bottom; | 
|  | short int *top; | 
|  | #endif | 
|  | { | 
|  | YYFPRINTF (stderr, "Stack now"); | 
|  | for (/* Nothing. */; bottom <= top; ++bottom) | 
|  | YYFPRINTF (stderr, " %d", *bottom); | 
|  | YYFPRINTF (stderr, "\n"); | 
|  | } | 
|  |  | 
|  | # define YY_STACK_PRINT(Bottom, Top)				\ | 
|  | do {								\ | 
|  | if (yydebug)							\ | 
|  | yy_stack_print ((Bottom), (Top));				\ | 
|  | } while (0) | 
|  |  | 
|  |  | 
|  | /*------------------------------------------------. | 
|  | | Report that the YYRULE is going to be reduced.  | | 
|  | `------------------------------------------------*/ | 
|  |  | 
|  | #if defined (__STDC__) || defined (__cplusplus) | 
|  | static void | 
|  | yy_reduce_print (int yyrule) | 
|  | #else | 
|  | static void | 
|  | yy_reduce_print (yyrule) | 
|  | int yyrule; | 
|  | #endif | 
|  | { | 
|  | int yyi; | 
|  | unsigned long int yylno = yyrline[yyrule]; | 
|  | YYFPRINTF (stderr, "Reducing stack by rule %d (line %lu), ", | 
|  | yyrule - 1, yylno); | 
|  | /* Print the symbols being reduced, and their result.  */ | 
|  | for (yyi = yyprhs[yyrule]; 0 <= yyrhs[yyi]; yyi++) | 
|  | YYFPRINTF (stderr, "%s ", yytname[yyrhs[yyi]]); | 
|  | YYFPRINTF (stderr, "-> %s\n", yytname[yyr1[yyrule]]); | 
|  | } | 
|  |  | 
|  | # define YY_REDUCE_PRINT(Rule)		\ | 
|  | do {					\ | 
|  | if (yydebug)				\ | 
|  | yy_reduce_print (Rule);		\ | 
|  | } while (0) | 
|  |  | 
|  | /* Nonzero means print parse trace.  It is left uninitialized so that | 
|  | multiple parsers can coexist.  */ | 
|  | int yydebug; | 
|  | #else /* !YYDEBUG */ | 
|  | # define YYDPRINTF(Args) | 
|  | # define YY_SYMBOL_PRINT(Title, Type, Value, Location) | 
|  | # define YY_STACK_PRINT(Bottom, Top) | 
|  | # define YY_REDUCE_PRINT(Rule) | 
|  | #endif /* !YYDEBUG */ | 
|  |  | 
|  |  | 
|  | /* YYINITDEPTH -- initial size of the parser's stacks.  */ | 
|  | #ifndef	YYINITDEPTH | 
|  | # define YYINITDEPTH 200 | 
|  | #endif | 
|  |  | 
|  | /* YYMAXDEPTH -- maximum size the stacks can grow to (effective only | 
|  | if the built-in stack extension method is used). | 
|  |  | 
|  | Do not make this value too large; the results are undefined if | 
|  | YYSTACK_ALLOC_MAXIMUM < YYSTACK_BYTES (YYMAXDEPTH) | 
|  | evaluated with infinite-precision integer arithmetic.  */ | 
|  |  | 
|  | #ifndef YYMAXDEPTH | 
|  | # define YYMAXDEPTH 10000 | 
|  | #endif | 
|  |  | 
|  |  | 
|  |  | 
|  | #if YYERROR_VERBOSE | 
|  |  | 
|  | # ifndef yystrlen | 
|  | #  if defined (__GLIBC__) && defined (_STRING_H) | 
|  | #   define yystrlen strlen | 
|  | #  else | 
|  | /* Return the length of YYSTR.  */ | 
|  | static YYSIZE_T | 
|  | #   if defined (__STDC__) || defined (__cplusplus) | 
|  | yystrlen (const char *yystr) | 
|  | #   else | 
|  | yystrlen (yystr) | 
|  | const char *yystr; | 
|  | #   endif | 
|  | { | 
|  | const char *yys = yystr; | 
|  |  | 
|  | while (*yys++ != '\0') | 
|  | continue; | 
|  |  | 
|  | return yys - yystr - 1; | 
|  | } | 
|  | #  endif | 
|  | # endif | 
|  |  | 
|  | # ifndef yystpcpy | 
|  | #  if defined (__GLIBC__) && defined (_STRING_H) && defined (_GNU_SOURCE) | 
|  | #   define yystpcpy stpcpy | 
|  | #  else | 
|  | /* Copy YYSRC to YYDEST, returning the address of the terminating '\0' in | 
|  | YYDEST.  */ | 
|  | static char * | 
|  | #   if defined (__STDC__) || defined (__cplusplus) | 
|  | yystpcpy (char *yydest, const char *yysrc) | 
|  | #   else | 
|  | yystpcpy (yydest, yysrc) | 
|  | char *yydest; | 
|  | const char *yysrc; | 
|  | #   endif | 
|  | { | 
|  | char *yyd = yydest; | 
|  | const char *yys = yysrc; | 
|  |  | 
|  | while ((*yyd++ = *yys++) != '\0') | 
|  | continue; | 
|  |  | 
|  | return yyd - 1; | 
|  | } | 
|  | #  endif | 
|  | # endif | 
|  |  | 
|  | # ifndef yytnamerr | 
|  | /* Copy to YYRES the contents of YYSTR after stripping away unnecessary | 
|  | quotes and backslashes, so that it's suitable for yyerror.  The | 
|  | heuristic is that double-quoting is unnecessary unless the string | 
|  | contains an apostrophe, a comma, or backslash (other than | 
|  | backslash-backslash).  YYSTR is taken from yytname.  If YYRES is | 
|  | null, do not copy; instead, return the length of what the result | 
|  | would have been.  */ | 
|  | static YYSIZE_T | 
|  | yytnamerr (char *yyres, const char *yystr) | 
|  | { | 
|  | if (*yystr == '"') | 
|  | { | 
|  | size_t yyn = 0; | 
|  | char const *yyp = yystr; | 
|  |  | 
|  | for (;;) | 
|  | switch (*++yyp) | 
|  | { | 
|  | case '\'': | 
|  | case ',': | 
|  | goto do_not_strip_quotes; | 
|  |  | 
|  | case '\\': | 
|  | if (*++yyp != '\\') | 
|  | goto do_not_strip_quotes; | 
|  | /* Fall through.  */ | 
|  | default: | 
|  | if (yyres) | 
|  | yyres[yyn] = *yyp; | 
|  | yyn++; | 
|  | break; | 
|  |  | 
|  | case '"': | 
|  | if (yyres) | 
|  | yyres[yyn] = '\0'; | 
|  | return yyn; | 
|  | } | 
|  | do_not_strip_quotes: ; | 
|  | } | 
|  |  | 
|  | if (! yyres) | 
|  | return yystrlen (yystr); | 
|  |  | 
|  | return yystpcpy (yyres, yystr) - yyres; | 
|  | } | 
|  | # endif | 
|  |  | 
|  | #endif /* YYERROR_VERBOSE */ | 
|  |  | 
|  |  | 
|  |  | 
|  | #if YYDEBUG | 
|  | /*--------------------------------. | 
|  | | Print this symbol on YYOUTPUT.  | | 
|  | `--------------------------------*/ | 
|  |  | 
|  | #if defined (__STDC__) || defined (__cplusplus) | 
|  | static void | 
|  | yysymprint (FILE *yyoutput, int yytype, YYSTYPE *yyvaluep) | 
|  | #else | 
|  | static void | 
|  | yysymprint (yyoutput, yytype, yyvaluep) | 
|  | FILE *yyoutput; | 
|  | int yytype; | 
|  | YYSTYPE *yyvaluep; | 
|  | #endif | 
|  | { | 
|  | /* Pacify ``unused variable'' warnings.  */ | 
|  | (void) yyvaluep; | 
|  |  | 
|  | if (yytype < YYNTOKENS) | 
|  | YYFPRINTF (yyoutput, "token %s (", yytname[yytype]); | 
|  | else | 
|  | YYFPRINTF (yyoutput, "nterm %s (", yytname[yytype]); | 
|  |  | 
|  |  | 
|  | # ifdef YYPRINT | 
|  | if (yytype < YYNTOKENS) | 
|  | YYPRINT (yyoutput, yytoknum[yytype], *yyvaluep); | 
|  | # endif | 
|  | switch (yytype) | 
|  | { | 
|  | default: | 
|  | break; | 
|  | } | 
|  | YYFPRINTF (yyoutput, ")"); | 
|  | } | 
|  |  | 
|  | #endif /* ! YYDEBUG */ | 
|  | /*-----------------------------------------------. | 
|  | | Release the memory associated to this symbol.  | | 
|  | `-----------------------------------------------*/ | 
|  |  | 
|  | #if defined (__STDC__) || defined (__cplusplus) | 
|  | static void | 
|  | yydestruct (const char *yymsg, int yytype, YYSTYPE *yyvaluep) | 
|  | #else | 
|  | static void | 
|  | yydestruct (yymsg, yytype, yyvaluep) | 
|  | const char *yymsg; | 
|  | int yytype; | 
|  | YYSTYPE *yyvaluep; | 
|  | #endif | 
|  | { | 
|  | /* Pacify ``unused variable'' warnings.  */ | 
|  | (void) yyvaluep; | 
|  |  | 
|  | if (!yymsg) | 
|  | yymsg = "Deleting"; | 
|  | YY_SYMBOL_PRINT (yymsg, yytype, yyvaluep, yylocationp); | 
|  |  | 
|  | switch (yytype) | 
|  | { | 
|  |  | 
|  | default: | 
|  | break; | 
|  | } | 
|  | } | 
|  |  | 
|  |  | 
|  | /* Prevent warnings from -Wmissing-prototypes.  */ | 
|  |  | 
|  | #ifdef YYPARSE_PARAM | 
|  | # if defined (__STDC__) || defined (__cplusplus) | 
|  | int yyparse (void *YYPARSE_PARAM); | 
|  | # else | 
|  | int yyparse (); | 
|  | # endif | 
|  | #else /* ! YYPARSE_PARAM */ | 
|  | #if defined (__STDC__) || defined (__cplusplus) | 
|  | int yyparse (void); | 
|  | #else | 
|  | int yyparse (); | 
|  | #endif | 
|  | #endif /* ! YYPARSE_PARAM */ | 
|  |  | 
|  |  | 
|  |  | 
|  | /* The look-ahead symbol.  */ | 
|  | int yychar; | 
|  |  | 
|  | /* The semantic value of the look-ahead symbol.  */ | 
|  | YYSTYPE yylval; | 
|  |  | 
|  | /* Number of syntax errors so far.  */ | 
|  | int yynerrs; | 
|  |  | 
|  |  | 
|  |  | 
|  | /*----------. | 
|  | | yyparse.  | | 
|  | `----------*/ | 
|  |  | 
|  | #ifdef YYPARSE_PARAM | 
|  | # if defined (__STDC__) || defined (__cplusplus) | 
|  | int yyparse (void *YYPARSE_PARAM) | 
|  | # else | 
|  | int yyparse (YYPARSE_PARAM) | 
|  | void *YYPARSE_PARAM; | 
|  | # endif | 
|  | #else /* ! YYPARSE_PARAM */ | 
|  | #if defined (__STDC__) || defined (__cplusplus) | 
|  | int | 
|  | yyparse (void) | 
|  | #else | 
|  | int | 
|  | yyparse () | 
|  |  | 
|  | #endif | 
|  | #endif | 
|  | { | 
|  |  | 
|  | int yystate; | 
|  | int yyn; | 
|  | int yyresult; | 
|  | /* Number of tokens to shift before error messages enabled.  */ | 
|  | int yyerrstatus; | 
|  | /* Look-ahead token as an internal (translated) token number.  */ | 
|  | int yytoken = 0; | 
|  |  | 
|  | /* Three stacks and their tools: | 
|  | `yyss': related to states, | 
|  | `yyvs': related to semantic values, | 
|  | `yyls': related to locations. | 
|  |  | 
|  | Refer to the stacks thru separate pointers, to allow yyoverflow | 
|  | to reallocate them elsewhere.  */ | 
|  |  | 
|  | /* The state stack.  */ | 
|  | short int yyssa[YYINITDEPTH]; | 
|  | short int *yyss = yyssa; | 
|  | short int *yyssp; | 
|  |  | 
|  | /* The semantic value stack.  */ | 
|  | YYSTYPE yyvsa[YYINITDEPTH]; | 
|  | YYSTYPE *yyvs = yyvsa; | 
|  | YYSTYPE *yyvsp; | 
|  |  | 
|  |  | 
|  |  | 
|  | #define YYPOPSTACK   (yyvsp--, yyssp--) | 
|  |  | 
|  | YYSIZE_T yystacksize = YYINITDEPTH; | 
|  |  | 
|  | /* The variables used to return semantic value and location from the | 
|  | action routines.  */ | 
|  | YYSTYPE yyval; | 
|  |  | 
|  |  | 
|  | /* When reducing, the number of symbols on the RHS of the reduced | 
|  | rule.  */ | 
|  | int yylen; | 
|  |  | 
|  | YYDPRINTF ((stderr, "Starting parse\n")); | 
|  |  | 
|  | yystate = 0; | 
|  | yyerrstatus = 0; | 
|  | yynerrs = 0; | 
|  | yychar = YYEMPTY;		/* Cause a token to be read.  */ | 
|  |  | 
|  | /* Initialize stack pointers. | 
|  | Waste one element of value and location stack | 
|  | so that they stay on the same level as the state stack. | 
|  | The wasted elements are never initialized.  */ | 
|  |  | 
|  | yyssp = yyss; | 
|  | yyvsp = yyvs; | 
|  |  | 
|  | goto yysetstate; | 
|  |  | 
|  | /*------------------------------------------------------------. | 
|  | | yynewstate -- Push a new state, which is found in yystate.  | | 
|  | `------------------------------------------------------------*/ | 
|  | yynewstate: | 
|  | /* In all cases, when you get here, the value and location stacks | 
|  | have just been pushed. so pushing a state here evens the stacks. | 
|  | */ | 
|  | yyssp++; | 
|  |  | 
|  | yysetstate: | 
|  | *yyssp = yystate; | 
|  |  | 
|  | if (yyss + yystacksize - 1 <= yyssp) | 
|  | { | 
|  | /* Get the current used size of the three stacks, in elements.  */ | 
|  | YYSIZE_T yysize = yyssp - yyss + 1; | 
|  |  | 
|  | #ifdef yyoverflow | 
|  | { | 
|  | /* Give user a chance to reallocate the stack. Use copies of | 
|  | these so that the &'s don't force the real ones into | 
|  | memory.  */ | 
|  | YYSTYPE *yyvs1 = yyvs; | 
|  | short int *yyss1 = yyss; | 
|  |  | 
|  |  | 
|  | /* Each stack pointer address is followed by the size of the | 
|  | data in use in that stack, in bytes.  This used to be a | 
|  | conditional around just the two extra args, but that might | 
|  | be undefined if yyoverflow is a macro.  */ | 
|  | yyoverflow (YY_("memory exhausted"), | 
|  | &yyss1, yysize * sizeof (*yyssp), | 
|  | &yyvs1, yysize * sizeof (*yyvsp), | 
|  |  | 
|  | &yystacksize); | 
|  |  | 
|  | yyss = yyss1; | 
|  | yyvs = yyvs1; | 
|  | } | 
|  | #else /* no yyoverflow */ | 
|  | # ifndef YYSTACK_RELOCATE | 
|  | goto yyexhaustedlab; | 
|  | # else | 
|  | /* Extend the stack our own way.  */ | 
|  | if (YYMAXDEPTH <= yystacksize) | 
|  | goto yyexhaustedlab; | 
|  | yystacksize *= 2; | 
|  | if (YYMAXDEPTH < yystacksize) | 
|  | yystacksize = YYMAXDEPTH; | 
|  |  | 
|  | { | 
|  | short int *yyss1 = yyss; | 
|  | union yyalloc *yyptr = | 
|  | (union yyalloc *) YYSTACK_ALLOC (YYSTACK_BYTES (yystacksize)); | 
|  | if (! yyptr) | 
|  | goto yyexhaustedlab; | 
|  | YYSTACK_RELOCATE (yyss); | 
|  | YYSTACK_RELOCATE (yyvs); | 
|  |  | 
|  | #  undef YYSTACK_RELOCATE | 
|  | if (yyss1 != yyssa) | 
|  | YYSTACK_FREE (yyss1); | 
|  | } | 
|  | # endif | 
|  | #endif /* no yyoverflow */ | 
|  |  | 
|  | yyssp = yyss + yysize - 1; | 
|  | yyvsp = yyvs + yysize - 1; | 
|  |  | 
|  |  | 
|  | YYDPRINTF ((stderr, "Stack size increased to %lu\n", | 
|  | (unsigned long int) yystacksize)); | 
|  |  | 
|  | if (yyss + yystacksize - 1 <= yyssp) | 
|  | YYABORT; | 
|  | } | 
|  |  | 
|  | YYDPRINTF ((stderr, "Entering state %d\n", yystate)); | 
|  |  | 
|  | goto yybackup; | 
|  |  | 
|  | /*-----------. | 
|  | | yybackup.  | | 
|  | `-----------*/ | 
|  | yybackup: | 
|  |  | 
|  | /* Do appropriate processing given the current state.  */ | 
|  | /* Read a look-ahead token if we need one and don't already have one.  */ | 
|  | /* yyresume: */ | 
|  |  | 
|  | /* First try to decide what to do without reference to look-ahead token.  */ | 
|  |  | 
|  | yyn = yypact[yystate]; | 
|  | if (yyn == YYPACT_NINF) | 
|  | goto yydefault; | 
|  |  | 
|  | /* Not known => get a look-ahead token if don't already have one.  */ | 
|  |  | 
|  | /* YYCHAR is either YYEMPTY or YYEOF or a valid look-ahead symbol.  */ | 
|  | if (yychar == YYEMPTY) | 
|  | { | 
|  | YYDPRINTF ((stderr, "Reading a token: ")); | 
|  | yychar = YYLEX; | 
|  | } | 
|  |  | 
|  | if (yychar <= YYEOF) | 
|  | { | 
|  | yychar = yytoken = YYEOF; | 
|  | YYDPRINTF ((stderr, "Now at end of input.\n")); | 
|  | } | 
|  | else | 
|  | { | 
|  | yytoken = YYTRANSLATE (yychar); | 
|  | YY_SYMBOL_PRINT ("Next token is", yytoken, &yylval, &yylloc); | 
|  | } | 
|  |  | 
|  | /* If the proper action on seeing token YYTOKEN is to reduce or to | 
|  | detect an error, take that action.  */ | 
|  | yyn += yytoken; | 
|  | if (yyn < 0 || YYLAST < yyn || yycheck[yyn] != yytoken) | 
|  | goto yydefault; | 
|  | yyn = yytable[yyn]; | 
|  | if (yyn <= 0) | 
|  | { | 
|  | if (yyn == 0 || yyn == YYTABLE_NINF) | 
|  | goto yyerrlab; | 
|  | yyn = -yyn; | 
|  | goto yyreduce; | 
|  | } | 
|  |  | 
|  | if (yyn == YYFINAL) | 
|  | YYACCEPT; | 
|  |  | 
|  | /* Shift the look-ahead token.  */ | 
|  | YY_SYMBOL_PRINT ("Shifting", yytoken, &yylval, &yylloc); | 
|  |  | 
|  | /* Discard the token being shifted unless it is eof.  */ | 
|  | if (yychar != YYEOF) | 
|  | yychar = YYEMPTY; | 
|  |  | 
|  | *++yyvsp = yylval; | 
|  |  | 
|  |  | 
|  | /* Count tokens shifted since error; after three, turn off error | 
|  | status.  */ | 
|  | if (yyerrstatus) | 
|  | yyerrstatus--; | 
|  |  | 
|  | yystate = yyn; | 
|  | goto yynewstate; | 
|  |  | 
|  |  | 
|  | /*-----------------------------------------------------------. | 
|  | | yydefault -- do the default action for the current state.  | | 
|  | `-----------------------------------------------------------*/ | 
|  | yydefault: | 
|  | yyn = yydefact[yystate]; | 
|  | if (yyn == 0) | 
|  | goto yyerrlab; | 
|  | goto yyreduce; | 
|  |  | 
|  |  | 
|  | /*-----------------------------. | 
|  | | yyreduce -- Do a reduction.  | | 
|  | `-----------------------------*/ | 
|  | yyreduce: | 
|  | /* yyn is the number of a rule to reduce with.  */ | 
|  | yylen = yyr2[yyn]; | 
|  |  | 
|  | /* If YYLEN is nonzero, implement the default value of the action: | 
|  | `$$ = $1'. | 
|  |  | 
|  | Otherwise, the following line sets YYVAL to garbage. | 
|  | This behavior is undocumented and Bison | 
|  | users should not rely upon it.  Assigning to YYVAL | 
|  | unconditionally makes the parser a bit smaller, and it avoids a | 
|  | GCC warning that YYVAL may be used uninitialized.  */ | 
|  | yyval = yyvsp[1-yylen]; | 
|  |  | 
|  |  | 
|  | YY_REDUCE_PRINT (yyn); | 
|  | switch (yyn) | 
|  | { | 
|  | case 3: | 
|  | #line 1036 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if ((yyvsp[0].UIntVal) > (uint32_t)INT32_MAX)     // Outside of my range! | 
|  | GEN_ERROR("Value too large for type!"); | 
|  | (yyval.SIntVal) = (int32_t)(yyvsp[0].UIntVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 31: | 
|  | #line 1052 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.IPredicate) = ICmpInst::ICMP_EQ; ;} | 
|  | break; | 
|  |  | 
|  | case 32: | 
|  | #line 1052 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.IPredicate) = ICmpInst::ICMP_NE; ;} | 
|  | break; | 
|  |  | 
|  | case 33: | 
|  | #line 1053 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.IPredicate) = ICmpInst::ICMP_SLT; ;} | 
|  | break; | 
|  |  | 
|  | case 34: | 
|  | #line 1053 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.IPredicate) = ICmpInst::ICMP_SGT; ;} | 
|  | break; | 
|  |  | 
|  | case 35: | 
|  | #line 1054 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.IPredicate) = ICmpInst::ICMP_SLE; ;} | 
|  | break; | 
|  |  | 
|  | case 36: | 
|  | #line 1054 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.IPredicate) = ICmpInst::ICMP_SGE; ;} | 
|  | break; | 
|  |  | 
|  | case 37: | 
|  | #line 1055 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.IPredicate) = ICmpInst::ICMP_ULT; ;} | 
|  | break; | 
|  |  | 
|  | case 38: | 
|  | #line 1055 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.IPredicate) = ICmpInst::ICMP_UGT; ;} | 
|  | break; | 
|  |  | 
|  | case 39: | 
|  | #line 1056 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.IPredicate) = ICmpInst::ICMP_ULE; ;} | 
|  | break; | 
|  |  | 
|  | case 40: | 
|  | #line 1056 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.IPredicate) = ICmpInst::ICMP_UGE; ;} | 
|  | break; | 
|  |  | 
|  | case 41: | 
|  | #line 1060 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.FPredicate) = FCmpInst::FCMP_OEQ; ;} | 
|  | break; | 
|  |  | 
|  | case 42: | 
|  | #line 1060 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.FPredicate) = FCmpInst::FCMP_ONE; ;} | 
|  | break; | 
|  |  | 
|  | case 43: | 
|  | #line 1061 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.FPredicate) = FCmpInst::FCMP_OLT; ;} | 
|  | break; | 
|  |  | 
|  | case 44: | 
|  | #line 1061 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.FPredicate) = FCmpInst::FCMP_OGT; ;} | 
|  | break; | 
|  |  | 
|  | case 45: | 
|  | #line 1062 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.FPredicate) = FCmpInst::FCMP_OLE; ;} | 
|  | break; | 
|  |  | 
|  | case 46: | 
|  | #line 1062 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.FPredicate) = FCmpInst::FCMP_OGE; ;} | 
|  | break; | 
|  |  | 
|  | case 47: | 
|  | #line 1063 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.FPredicate) = FCmpInst::FCMP_ORD; ;} | 
|  | break; | 
|  |  | 
|  | case 48: | 
|  | #line 1063 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.FPredicate) = FCmpInst::FCMP_UNO; ;} | 
|  | break; | 
|  |  | 
|  | case 49: | 
|  | #line 1064 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.FPredicate) = FCmpInst::FCMP_UEQ; ;} | 
|  | break; | 
|  |  | 
|  | case 50: | 
|  | #line 1064 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.FPredicate) = FCmpInst::FCMP_UNE; ;} | 
|  | break; | 
|  |  | 
|  | case 51: | 
|  | #line 1065 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.FPredicate) = FCmpInst::FCMP_ULT; ;} | 
|  | break; | 
|  |  | 
|  | case 52: | 
|  | #line 1065 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.FPredicate) = FCmpInst::FCMP_UGT; ;} | 
|  | break; | 
|  |  | 
|  | case 53: | 
|  | #line 1066 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.FPredicate) = FCmpInst::FCMP_ULE; ;} | 
|  | break; | 
|  |  | 
|  | case 54: | 
|  | #line 1066 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.FPredicate) = FCmpInst::FCMP_UGE; ;} | 
|  | break; | 
|  |  | 
|  | case 55: | 
|  | #line 1067 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.FPredicate) = FCmpInst::FCMP_TRUE; ;} | 
|  | break; | 
|  |  | 
|  | case 56: | 
|  | #line 1068 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.FPredicate) = FCmpInst::FCMP_FALSE; ;} | 
|  | break; | 
|  |  | 
|  | case 63: | 
|  | #line 1077 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.StrVal) = (yyvsp[-1].StrVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 64: | 
|  | #line 1081 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.StrVal) = 0; | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 65: | 
|  | #line 1087 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.Linkage) = GlobalValue::InternalLinkage; ;} | 
|  | break; | 
|  |  | 
|  | case 66: | 
|  | #line 1088 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.Linkage) = GlobalValue::WeakLinkage; ;} | 
|  | break; | 
|  |  | 
|  | case 67: | 
|  | #line 1089 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.Linkage) = GlobalValue::LinkOnceLinkage; ;} | 
|  | break; | 
|  |  | 
|  | case 68: | 
|  | #line 1090 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.Linkage) = GlobalValue::AppendingLinkage; ;} | 
|  | break; | 
|  |  | 
|  | case 69: | 
|  | #line 1091 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.Linkage) = GlobalValue::DLLExportLinkage; ;} | 
|  | break; | 
|  |  | 
|  | case 70: | 
|  | #line 1095 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.Linkage) = GlobalValue::DLLImportLinkage; ;} | 
|  | break; | 
|  |  | 
|  | case 71: | 
|  | #line 1096 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.Linkage) = GlobalValue::ExternalWeakLinkage; ;} | 
|  | break; | 
|  |  | 
|  | case 72: | 
|  | #line 1097 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.Linkage) = GlobalValue::ExternalLinkage; ;} | 
|  | break; | 
|  |  | 
|  | case 73: | 
|  | #line 1101 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.Linkage) = GlobalValue::ExternalLinkage; ;} | 
|  | break; | 
|  |  | 
|  | case 74: | 
|  | #line 1102 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.Linkage) = GlobalValue::DLLImportLinkage; ;} | 
|  | break; | 
|  |  | 
|  | case 75: | 
|  | #line 1103 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.Linkage) = GlobalValue::ExternalWeakLinkage; ;} | 
|  | break; | 
|  |  | 
|  | case 76: | 
|  | #line 1107 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.Linkage) = GlobalValue::ExternalLinkage; ;} | 
|  | break; | 
|  |  | 
|  | case 77: | 
|  | #line 1108 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.Linkage) = GlobalValue::InternalLinkage; ;} | 
|  | break; | 
|  |  | 
|  | case 78: | 
|  | #line 1109 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.Linkage) = GlobalValue::LinkOnceLinkage; ;} | 
|  | break; | 
|  |  | 
|  | case 79: | 
|  | #line 1110 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.Linkage) = GlobalValue::WeakLinkage; ;} | 
|  | break; | 
|  |  | 
|  | case 80: | 
|  | #line 1111 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.Linkage) = GlobalValue::DLLExportLinkage; ;} | 
|  | break; | 
|  |  | 
|  | case 81: | 
|  | #line 1114 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.UIntVal) = CallingConv::C; ;} | 
|  | break; | 
|  |  | 
|  | case 82: | 
|  | #line 1115 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.UIntVal) = CallingConv::C; ;} | 
|  | break; | 
|  |  | 
|  | case 83: | 
|  | #line 1116 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.UIntVal) = CallingConv::CSRet; ;} | 
|  | break; | 
|  |  | 
|  | case 84: | 
|  | #line 1117 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.UIntVal) = CallingConv::Fast; ;} | 
|  | break; | 
|  |  | 
|  | case 85: | 
|  | #line 1118 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.UIntVal) = CallingConv::Cold; ;} | 
|  | break; | 
|  |  | 
|  | case 86: | 
|  | #line 1119 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.UIntVal) = CallingConv::X86_StdCall; ;} | 
|  | break; | 
|  |  | 
|  | case 87: | 
|  | #line 1120 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.UIntVal) = CallingConv::X86_FastCall; ;} | 
|  | break; | 
|  |  | 
|  | case 88: | 
|  | #line 1121 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if ((unsigned)(yyvsp[0].UInt64Val) != (yyvsp[0].UInt64Val)) | 
|  | GEN_ERROR("Calling conv too large!"); | 
|  | (yyval.UIntVal) = (yyvsp[0].UInt64Val); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 89: | 
|  | #line 1128 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.ParamAttrs) = FunctionType::ZExtAttribute; ;} | 
|  | break; | 
|  |  | 
|  | case 90: | 
|  | #line 1129 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.ParamAttrs) = FunctionType::SExtAttribute; ;} | 
|  | break; | 
|  |  | 
|  | case 91: | 
|  | #line 1132 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.ParamAttrs) = (yyvsp[0].ParamAttrs); ;} | 
|  | break; | 
|  |  | 
|  | case 92: | 
|  | #line 1133 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.ParamAttrs) = FunctionType::ParameterAttributes((yyvsp[-2].ParamAttrs) | (yyvsp[0].ParamAttrs)); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 93: | 
|  | #line 1138 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.ParamAttrs) = FunctionType::NoAttributeSet; ;} | 
|  | break; | 
|  |  | 
|  | case 94: | 
|  | #line 1139 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.ParamAttrs) = (yyvsp[0].ParamAttrs); ;} | 
|  | break; | 
|  |  | 
|  | case 95: | 
|  | #line 1140 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.ParamAttrs) = (yyvsp[-1].ParamAttrs); ;} | 
|  | break; | 
|  |  | 
|  | case 96: | 
|  | #line 1145 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.UIntVal) = 0; ;} | 
|  | break; | 
|  |  | 
|  | case 97: | 
|  | #line 1146 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.UIntVal) = (yyvsp[0].UInt64Val); | 
|  | if ((yyval.UIntVal) != 0 && !isPowerOf2_32((yyval.UIntVal))) | 
|  | GEN_ERROR("Alignment must be a power of two!"); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 98: | 
|  | #line 1152 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.UIntVal) = 0; ;} | 
|  | break; | 
|  |  | 
|  | case 99: | 
|  | #line 1153 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.UIntVal) = (yyvsp[0].UInt64Val); | 
|  | if ((yyval.UIntVal) != 0 && !isPowerOf2_32((yyval.UIntVal))) | 
|  | GEN_ERROR("Alignment must be a power of two!"); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 100: | 
|  | #line 1161 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | for (unsigned i = 0, e = strlen((yyvsp[0].StrVal)); i != e; ++i) | 
|  | if ((yyvsp[0].StrVal)[i] == '"' || (yyvsp[0].StrVal)[i] == '\\') | 
|  | GEN_ERROR("Invalid character in section name!"); | 
|  | (yyval.StrVal) = (yyvsp[0].StrVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 101: | 
|  | #line 1169 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.StrVal) = 0; ;} | 
|  | break; | 
|  |  | 
|  | case 102: | 
|  | #line 1170 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.StrVal) = (yyvsp[0].StrVal); ;} | 
|  | break; | 
|  |  | 
|  | case 103: | 
|  | #line 1175 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | {;} | 
|  | break; | 
|  |  | 
|  | case 104: | 
|  | #line 1176 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | {;} | 
|  | break; | 
|  |  | 
|  | case 105: | 
|  | #line 1177 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | CurGV->setSection((yyvsp[0].StrVal)); | 
|  | free((yyvsp[0].StrVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 106: | 
|  | #line 1182 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if ((yyvsp[0].UInt64Val) != 0 && !isPowerOf2_32((yyvsp[0].UInt64Val))) | 
|  | GEN_ERROR("Alignment must be a power of two!"); | 
|  | CurGV->setAlignment((yyvsp[0].UInt64Val)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 115: | 
|  | #line 1198 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.TypeVal) = new PATypeHolder(OpaqueType::get()); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 116: | 
|  | #line 1202 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.TypeVal) = new PATypeHolder((yyvsp[0].PrimType)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 117: | 
|  | #line 1206 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | {                             // Pointer type? | 
|  | if (*(yyvsp[-1].TypeVal) == Type::LabelTy) | 
|  | GEN_ERROR("Cannot form a pointer to a basic block"); | 
|  | (yyval.TypeVal) = new PATypeHolder(HandleUpRefs(PointerType::get(*(yyvsp[-1].TypeVal)))); | 
|  | delete (yyvsp[-1].TypeVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 118: | 
|  | #line 1213 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | {            // Named types are also simple types... | 
|  | const Type* tmp = getTypeVal((yyvsp[0].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | (yyval.TypeVal) = new PATypeHolder(tmp); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 119: | 
|  | #line 1218 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | {                   // Type UpReference | 
|  | if ((yyvsp[0].UInt64Val) > (uint64_t)~0U) GEN_ERROR("Value out of range!"); | 
|  | OpaqueType *OT = OpaqueType::get();        // Use temporary placeholder | 
|  | UpRefs.push_back(UpRefRecord((unsigned)(yyvsp[0].UInt64Val), OT));  // Add to vector... | 
|  | (yyval.TypeVal) = new PATypeHolder(OT); | 
|  | UR_OUT("New Upreference!\n"); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 120: | 
|  | #line 1226 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | std::vector<const Type*> Params; | 
|  | std::vector<FunctionType::ParameterAttributes> Attrs; | 
|  | Attrs.push_back((yyvsp[-3].ParamAttrs)); | 
|  | for (TypeWithAttrsList::iterator I=(yyvsp[-1].TypeWithAttrsList)->begin(), E=(yyvsp[-1].TypeWithAttrsList)->end(); I != E; ++I) { | 
|  | Params.push_back(I->Ty->get()); | 
|  | if (I->Ty->get() != Type::VoidTy) | 
|  | Attrs.push_back(I->Attrs); | 
|  | } | 
|  | bool isVarArg = Params.size() && Params.back() == Type::VoidTy; | 
|  | if (isVarArg) Params.pop_back(); | 
|  |  | 
|  | FunctionType *FT = FunctionType::get(*(yyvsp[-4].TypeVal), Params, isVarArg, Attrs); | 
|  | delete (yyvsp[-1].TypeWithAttrsList);      // Delete the argument list | 
|  | delete (yyvsp[-4].TypeVal);   // Delete the return type handle | 
|  | (yyval.TypeVal) = new PATypeHolder(HandleUpRefs(FT)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 121: | 
|  | #line 1244 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | std::vector<const Type*> Params; | 
|  | std::vector<FunctionType::ParameterAttributes> Attrs; | 
|  | Attrs.push_back((yyvsp[-3].ParamAttrs)); | 
|  | for (TypeWithAttrsList::iterator I=(yyvsp[-1].TypeWithAttrsList)->begin(), E=(yyvsp[-1].TypeWithAttrsList)->end(); I != E; ++I) { | 
|  | Params.push_back(I->Ty->get()); | 
|  | if (I->Ty->get() != Type::VoidTy) | 
|  | Attrs.push_back(I->Attrs); | 
|  | } | 
|  | bool isVarArg = Params.size() && Params.back() == Type::VoidTy; | 
|  | if (isVarArg) Params.pop_back(); | 
|  |  | 
|  | FunctionType *FT = FunctionType::get((yyvsp[-4].PrimType), Params, isVarArg, Attrs); | 
|  | delete (yyvsp[-1].TypeWithAttrsList);      // Delete the argument list | 
|  | (yyval.TypeVal) = new PATypeHolder(HandleUpRefs(FT)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 122: | 
|  | #line 1262 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | {          // Sized array type? | 
|  | (yyval.TypeVal) = new PATypeHolder(HandleUpRefs(ArrayType::get(*(yyvsp[-1].TypeVal), (unsigned)(yyvsp[-3].UInt64Val)))); | 
|  | delete (yyvsp[-1].TypeVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 123: | 
|  | #line 1267 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | {          // Packed array type? | 
|  | const llvm::Type* ElemTy = (yyvsp[-1].TypeVal)->get(); | 
|  | if ((unsigned)(yyvsp[-3].UInt64Val) != (yyvsp[-3].UInt64Val)) | 
|  | GEN_ERROR("Unsigned result not equal to signed result"); | 
|  | if (!ElemTy->isPrimitiveType()) | 
|  | GEN_ERROR("Elemental type of a PackedType must be primitive"); | 
|  | if (!isPowerOf2_32((yyvsp[-3].UInt64Val))) | 
|  | GEN_ERROR("Vector length should be a power of 2!"); | 
|  | (yyval.TypeVal) = new PATypeHolder(HandleUpRefs(PackedType::get(*(yyvsp[-1].TypeVal), (unsigned)(yyvsp[-3].UInt64Val)))); | 
|  | delete (yyvsp[-1].TypeVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 124: | 
|  | #line 1279 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | {                        // Structure type? | 
|  | std::vector<const Type*> Elements; | 
|  | for (std::list<llvm::PATypeHolder>::iterator I = (yyvsp[-1].TypeList)->begin(), | 
|  | E = (yyvsp[-1].TypeList)->end(); I != E; ++I) | 
|  | Elements.push_back(*I); | 
|  |  | 
|  | (yyval.TypeVal) = new PATypeHolder(HandleUpRefs(StructType::get(Elements))); | 
|  | delete (yyvsp[-1].TypeList); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 125: | 
|  | #line 1289 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | {                                  // Empty structure type? | 
|  | (yyval.TypeVal) = new PATypeHolder(StructType::get(std::vector<const Type*>())); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 126: | 
|  | #line 1293 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | std::vector<const Type*> Elements; | 
|  | for (std::list<llvm::PATypeHolder>::iterator I = (yyvsp[-2].TypeList)->begin(), | 
|  | E = (yyvsp[-2].TypeList)->end(); I != E; ++I) | 
|  | Elements.push_back(*I); | 
|  |  | 
|  | (yyval.TypeVal) = new PATypeHolder(HandleUpRefs(StructType::get(Elements, true))); | 
|  | delete (yyvsp[-2].TypeList); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 127: | 
|  | #line 1303 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | {                         // Empty structure type? | 
|  | (yyval.TypeVal) = new PATypeHolder(StructType::get(std::vector<const Type*>(), true)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 128: | 
|  | #line 1310 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.TypeWithAttrs).Ty = (yyvsp[-1].TypeVal); | 
|  | (yyval.TypeWithAttrs).Attrs = (yyvsp[0].ParamAttrs); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 129: | 
|  | #line 1317 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-1].TypeVal))->getDescription()); | 
|  | if (!(*(yyvsp[-1].TypeVal))->isFirstClassType()) | 
|  | GEN_ERROR("LLVM functions cannot return aggregate types!"); | 
|  | (yyval.TypeWithAttrs).Ty = (yyvsp[-1].TypeVal); | 
|  | (yyval.TypeWithAttrs).Attrs = (yyvsp[0].ParamAttrs); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 130: | 
|  | #line 1325 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.TypeWithAttrs).Ty = new PATypeHolder(Type::VoidTy); | 
|  | (yyval.TypeWithAttrs).Attrs = (yyvsp[0].ParamAttrs); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 131: | 
|  | #line 1331 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.TypeWithAttrsList) = new TypeWithAttrsList(); | 
|  | (yyval.TypeWithAttrsList)->push_back((yyvsp[0].TypeWithAttrs)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 132: | 
|  | #line 1336 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | ((yyval.TypeWithAttrsList)=(yyvsp[-2].TypeWithAttrsList))->push_back((yyvsp[0].TypeWithAttrs)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 134: | 
|  | #line 1344 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.TypeWithAttrsList)=(yyvsp[-2].TypeWithAttrsList); | 
|  | TypeWithAttrs TWA; TWA.Attrs = FunctionType::NoAttributeSet; | 
|  | TWA.Ty = new PATypeHolder(Type::VoidTy); | 
|  | (yyval.TypeWithAttrsList)->push_back(TWA); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 135: | 
|  | #line 1351 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.TypeWithAttrsList) = new TypeWithAttrsList; | 
|  | TypeWithAttrs TWA; TWA.Attrs = FunctionType::NoAttributeSet; | 
|  | TWA.Ty = new PATypeHolder(Type::VoidTy); | 
|  | (yyval.TypeWithAttrsList)->push_back(TWA); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 136: | 
|  | #line 1358 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.TypeWithAttrsList) = new TypeWithAttrsList(); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 137: | 
|  | #line 1366 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.TypeList) = new std::list<PATypeHolder>(); | 
|  | (yyval.TypeList)->push_back(*(yyvsp[0].TypeVal)); delete (yyvsp[0].TypeVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 138: | 
|  | #line 1371 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | ((yyval.TypeList)=(yyvsp[-2].TypeList))->push_back(*(yyvsp[0].TypeVal)); delete (yyvsp[0].TypeVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 139: | 
|  | #line 1382 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { // Nonempty unsized arr | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-3].TypeVal))->getDescription()); | 
|  | const ArrayType *ATy = dyn_cast<ArrayType>((yyvsp[-3].TypeVal)->get()); | 
|  | if (ATy == 0) | 
|  | GEN_ERROR("Cannot make array constant with type: '" + | 
|  | (*(yyvsp[-3].TypeVal))->getDescription() + "'!"); | 
|  | const Type *ETy = ATy->getElementType(); | 
|  | int NumElements = ATy->getNumElements(); | 
|  |  | 
|  | // Verify that we have the correct size... | 
|  | if (NumElements != -1 && NumElements != (int)(yyvsp[-1].ConstVector)->size()) | 
|  | GEN_ERROR("Type mismatch: constant sized array initialized with " + | 
|  | utostr((yyvsp[-1].ConstVector)->size()) +  " arguments, but has size of " + | 
|  | itostr(NumElements) + "!"); | 
|  |  | 
|  | // Verify all elements are correct type! | 
|  | for (unsigned i = 0; i < (yyvsp[-1].ConstVector)->size(); i++) { | 
|  | if (ETy != (*(yyvsp[-1].ConstVector))[i]->getType()) | 
|  | GEN_ERROR("Element #" + utostr(i) + " is not of type '" + | 
|  | ETy->getDescription() +"' as required!\nIt is of type '"+ | 
|  | (*(yyvsp[-1].ConstVector))[i]->getType()->getDescription() + "'."); | 
|  | } | 
|  |  | 
|  | (yyval.ConstVal) = ConstantArray::get(ATy, *(yyvsp[-1].ConstVector)); | 
|  | delete (yyvsp[-3].TypeVal); delete (yyvsp[-1].ConstVector); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 140: | 
|  | #line 1410 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-2].TypeVal))->getDescription()); | 
|  | const ArrayType *ATy = dyn_cast<ArrayType>((yyvsp[-2].TypeVal)->get()); | 
|  | if (ATy == 0) | 
|  | GEN_ERROR("Cannot make array constant with type: '" + | 
|  | (*(yyvsp[-2].TypeVal))->getDescription() + "'!"); | 
|  |  | 
|  | int NumElements = ATy->getNumElements(); | 
|  | if (NumElements != -1 && NumElements != 0) | 
|  | GEN_ERROR("Type mismatch: constant sized array initialized with 0" | 
|  | " arguments, but has size of " + itostr(NumElements) +"!"); | 
|  | (yyval.ConstVal) = ConstantArray::get(ATy, std::vector<Constant*>()); | 
|  | delete (yyvsp[-2].TypeVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 141: | 
|  | #line 1426 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-2].TypeVal))->getDescription()); | 
|  | const ArrayType *ATy = dyn_cast<ArrayType>((yyvsp[-2].TypeVal)->get()); | 
|  | if (ATy == 0) | 
|  | GEN_ERROR("Cannot make array constant with type: '" + | 
|  | (*(yyvsp[-2].TypeVal))->getDescription() + "'!"); | 
|  |  | 
|  | int NumElements = ATy->getNumElements(); | 
|  | const Type *ETy = ATy->getElementType(); | 
|  | char *EndStr = UnEscapeLexed((yyvsp[0].StrVal), true); | 
|  | if (NumElements != -1 && NumElements != (EndStr-(yyvsp[0].StrVal))) | 
|  | GEN_ERROR("Can't build string constant of size " + | 
|  | itostr((int)(EndStr-(yyvsp[0].StrVal))) + | 
|  | " when array has size " + itostr(NumElements) + "!"); | 
|  | std::vector<Constant*> Vals; | 
|  | if (ETy == Type::Int8Ty) { | 
|  | for (unsigned char *C = (unsigned char *)(yyvsp[0].StrVal); | 
|  | C != (unsigned char*)EndStr; ++C) | 
|  | Vals.push_back(ConstantInt::get(ETy, *C)); | 
|  | } else { | 
|  | free((yyvsp[0].StrVal)); | 
|  | GEN_ERROR("Cannot build string arrays of non byte sized elements!"); | 
|  | } | 
|  | free((yyvsp[0].StrVal)); | 
|  | (yyval.ConstVal) = ConstantArray::get(ATy, Vals); | 
|  | delete (yyvsp[-2].TypeVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 142: | 
|  | #line 1455 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { // Nonempty unsized arr | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-3].TypeVal))->getDescription()); | 
|  | const PackedType *PTy = dyn_cast<PackedType>((yyvsp[-3].TypeVal)->get()); | 
|  | if (PTy == 0) | 
|  | GEN_ERROR("Cannot make packed constant with type: '" + | 
|  | (*(yyvsp[-3].TypeVal))->getDescription() + "'!"); | 
|  | const Type *ETy = PTy->getElementType(); | 
|  | int NumElements = PTy->getNumElements(); | 
|  |  | 
|  | // Verify that we have the correct size... | 
|  | if (NumElements != -1 && NumElements != (int)(yyvsp[-1].ConstVector)->size()) | 
|  | GEN_ERROR("Type mismatch: constant sized packed initialized with " + | 
|  | utostr((yyvsp[-1].ConstVector)->size()) +  " arguments, but has size of " + | 
|  | itostr(NumElements) + "!"); | 
|  |  | 
|  | // Verify all elements are correct type! | 
|  | for (unsigned i = 0; i < (yyvsp[-1].ConstVector)->size(); i++) { | 
|  | if (ETy != (*(yyvsp[-1].ConstVector))[i]->getType()) | 
|  | GEN_ERROR("Element #" + utostr(i) + " is not of type '" + | 
|  | ETy->getDescription() +"' as required!\nIt is of type '"+ | 
|  | (*(yyvsp[-1].ConstVector))[i]->getType()->getDescription() + "'."); | 
|  | } | 
|  |  | 
|  | (yyval.ConstVal) = ConstantPacked::get(PTy, *(yyvsp[-1].ConstVector)); | 
|  | delete (yyvsp[-3].TypeVal); delete (yyvsp[-1].ConstVector); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 143: | 
|  | #line 1483 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | const StructType *STy = dyn_cast<StructType>((yyvsp[-3].TypeVal)->get()); | 
|  | if (STy == 0) | 
|  | GEN_ERROR("Cannot make struct constant with type: '" + | 
|  | (*(yyvsp[-3].TypeVal))->getDescription() + "'!"); | 
|  |  | 
|  | if ((yyvsp[-1].ConstVector)->size() != STy->getNumContainedTypes()) | 
|  | GEN_ERROR("Illegal number of initializers for structure type!"); | 
|  |  | 
|  | // Check to ensure that constants are compatible with the type initializer! | 
|  | for (unsigned i = 0, e = (yyvsp[-1].ConstVector)->size(); i != e; ++i) | 
|  | if ((*(yyvsp[-1].ConstVector))[i]->getType() != STy->getElementType(i)) | 
|  | GEN_ERROR("Expected type '" + | 
|  | STy->getElementType(i)->getDescription() + | 
|  | "' for element #" + utostr(i) + | 
|  | " of structure initializer!"); | 
|  |  | 
|  | (yyval.ConstVal) = ConstantStruct::get(STy, *(yyvsp[-1].ConstVector)); | 
|  | delete (yyvsp[-3].TypeVal); delete (yyvsp[-1].ConstVector); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 144: | 
|  | #line 1504 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-2].TypeVal))->getDescription()); | 
|  | const StructType *STy = dyn_cast<StructType>((yyvsp[-2].TypeVal)->get()); | 
|  | if (STy == 0) | 
|  | GEN_ERROR("Cannot make struct constant with type: '" + | 
|  | (*(yyvsp[-2].TypeVal))->getDescription() + "'!"); | 
|  |  | 
|  | if (STy->getNumContainedTypes() != 0) | 
|  | GEN_ERROR("Illegal number of initializers for structure type!"); | 
|  |  | 
|  | (yyval.ConstVal) = ConstantStruct::get(STy, std::vector<Constant*>()); | 
|  | delete (yyvsp[-2].TypeVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 145: | 
|  | #line 1519 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-1].TypeVal))->getDescription()); | 
|  | const PointerType *PTy = dyn_cast<PointerType>((yyvsp[-1].TypeVal)->get()); | 
|  | if (PTy == 0) | 
|  | GEN_ERROR("Cannot make null pointer constant with type: '" + | 
|  | (*(yyvsp[-1].TypeVal))->getDescription() + "'!"); | 
|  |  | 
|  | (yyval.ConstVal) = ConstantPointerNull::get(PTy); | 
|  | delete (yyvsp[-1].TypeVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 146: | 
|  | #line 1531 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-1].TypeVal))->getDescription()); | 
|  | (yyval.ConstVal) = UndefValue::get((yyvsp[-1].TypeVal)->get()); | 
|  | delete (yyvsp[-1].TypeVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 147: | 
|  | #line 1538 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-1].TypeVal))->getDescription()); | 
|  | const PointerType *Ty = dyn_cast<PointerType>((yyvsp[-1].TypeVal)->get()); | 
|  | if (Ty == 0) | 
|  | GEN_ERROR("Global const reference must be a pointer type!"); | 
|  |  | 
|  | // ConstExprs can exist in the body of a function, thus creating | 
|  | // GlobalValues whenever they refer to a variable.  Because we are in | 
|  | // the context of a function, getValNonImprovising will search the functions | 
|  | // symbol table instead of the module symbol table for the global symbol, | 
|  | // which throws things all off.  To get around this, we just tell | 
|  | // getValNonImprovising that we are at global scope here. | 
|  | // | 
|  | Function *SavedCurFn = CurFun.CurrentFunction; | 
|  | CurFun.CurrentFunction = 0; | 
|  |  | 
|  | Value *V = getValNonImprovising(Ty, (yyvsp[0].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  |  | 
|  | CurFun.CurrentFunction = SavedCurFn; | 
|  |  | 
|  | // If this is an initializer for a constant pointer, which is referencing a | 
|  | // (currently) undefined variable, create a stub now that shall be replaced | 
|  | // in the future with the right type of variable. | 
|  | // | 
|  | if (V == 0) { | 
|  | assert(isa<PointerType>(Ty) && "Globals may only be used as pointers!"); | 
|  | const PointerType *PT = cast<PointerType>(Ty); | 
|  |  | 
|  | // First check to see if the forward references value is already created! | 
|  | PerModuleInfo::GlobalRefsType::iterator I = | 
|  | CurModule.GlobalRefs.find(std::make_pair(PT, (yyvsp[0].ValIDVal))); | 
|  |  | 
|  | if (I != CurModule.GlobalRefs.end()) { | 
|  | V = I->second;             // Placeholder already exists, use it... | 
|  | (yyvsp[0].ValIDVal).destroy(); | 
|  | } else { | 
|  | std::string Name; | 
|  | if ((yyvsp[0].ValIDVal).Type == ValID::NameVal) Name = (yyvsp[0].ValIDVal).Name; | 
|  |  | 
|  | // Create the forward referenced global. | 
|  | GlobalValue *GV; | 
|  | if (const FunctionType *FTy = | 
|  | dyn_cast<FunctionType>(PT->getElementType())) { | 
|  | GV = new Function(FTy, GlobalValue::ExternalLinkage, Name, | 
|  | CurModule.CurrentModule); | 
|  | } else { | 
|  | GV = new GlobalVariable(PT->getElementType(), false, | 
|  | GlobalValue::ExternalLinkage, 0, | 
|  | Name, CurModule.CurrentModule); | 
|  | } | 
|  |  | 
|  | // Keep track of the fact that we have a forward ref to recycle it | 
|  | CurModule.GlobalRefs.insert(std::make_pair(std::make_pair(PT, (yyvsp[0].ValIDVal)), GV)); | 
|  | V = GV; | 
|  | } | 
|  | } | 
|  |  | 
|  | (yyval.ConstVal) = cast<GlobalValue>(V); | 
|  | delete (yyvsp[-1].TypeVal);            // Free the type handle | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 148: | 
|  | #line 1601 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-1].TypeVal))->getDescription()); | 
|  | if ((yyvsp[-1].TypeVal)->get() != (yyvsp[0].ConstVal)->getType()) | 
|  | GEN_ERROR("Mismatched types for constant expression: " + | 
|  | (*(yyvsp[-1].TypeVal))->getDescription() + " and " + (yyvsp[0].ConstVal)->getType()->getDescription()); | 
|  | (yyval.ConstVal) = (yyvsp[0].ConstVal); | 
|  | delete (yyvsp[-1].TypeVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 149: | 
|  | #line 1611 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-1].TypeVal))->getDescription()); | 
|  | const Type *Ty = (yyvsp[-1].TypeVal)->get(); | 
|  | if (isa<FunctionType>(Ty) || Ty == Type::LabelTy || isa<OpaqueType>(Ty)) | 
|  | GEN_ERROR("Cannot create a null initialized value of this type!"); | 
|  | (yyval.ConstVal) = Constant::getNullValue(Ty); | 
|  | delete (yyvsp[-1].TypeVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 150: | 
|  | #line 1621 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | {      // integral constants | 
|  | if (!ConstantInt::isValueValidForType((yyvsp[-1].PrimType), (yyvsp[0].SInt64Val))) | 
|  | GEN_ERROR("Constant value doesn't fit in type!"); | 
|  | (yyval.ConstVal) = ConstantInt::get((yyvsp[-1].PrimType), (yyvsp[0].SInt64Val)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 151: | 
|  | #line 1627 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | {      // integral constants | 
|  | if (!ConstantInt::isValueValidForType((yyvsp[-1].PrimType), (yyvsp[0].UInt64Val))) | 
|  | GEN_ERROR("Constant value doesn't fit in type!"); | 
|  | (yyval.ConstVal) = ConstantInt::get((yyvsp[-1].PrimType), (yyvsp[0].UInt64Val)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 152: | 
|  | #line 1633 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | {                      // Boolean constants | 
|  | (yyval.ConstVal) = ConstantBool::getTrue(); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 153: | 
|  | #line 1637 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | {                     // Boolean constants | 
|  | (yyval.ConstVal) = ConstantBool::getFalse(); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 154: | 
|  | #line 1641 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | {                   // Float & Double constants | 
|  | if (!ConstantFP::isValueValidForType((yyvsp[-1].PrimType), (yyvsp[0].FPVal))) | 
|  | GEN_ERROR("Floating point constant invalid for type!!"); | 
|  | (yyval.ConstVal) = ConstantFP::get((yyvsp[-1].PrimType), (yyvsp[0].FPVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 155: | 
|  | #line 1649 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-1].TypeVal))->getDescription()); | 
|  | Constant *Val = (yyvsp[-3].ConstVal); | 
|  | const Type *Ty = (yyvsp[-1].TypeVal)->get(); | 
|  | if (!Val->getType()->isFirstClassType()) | 
|  | GEN_ERROR("cast constant expression from a non-primitive type: '" + | 
|  | Val->getType()->getDescription() + "'!"); | 
|  | if (!Ty->isFirstClassType()) | 
|  | GEN_ERROR("cast constant expression to a non-primitive type: '" + | 
|  | Ty->getDescription() + "'!"); | 
|  | (yyval.ConstVal) = ConstantExpr::getCast((yyvsp[-5].CastOpVal), (yyvsp[-3].ConstVal), (yyvsp[-1].TypeVal)->get()); | 
|  | delete (yyvsp[-1].TypeVal); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 156: | 
|  | #line 1663 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!isa<PointerType>((yyvsp[-2].ConstVal)->getType())) | 
|  | GEN_ERROR("GetElementPtr requires a pointer operand!"); | 
|  |  | 
|  | const Type *IdxTy = | 
|  | GetElementPtrInst::getIndexedType((yyvsp[-2].ConstVal)->getType(), *(yyvsp[-1].ValueList), true); | 
|  | if (!IdxTy) | 
|  | GEN_ERROR("Index list invalid for constant getelementptr!"); | 
|  |  | 
|  | std::vector<Constant*> IdxVec; | 
|  | for (unsigned i = 0, e = (yyvsp[-1].ValueList)->size(); i != e; ++i) | 
|  | if (Constant *C = dyn_cast<Constant>((*(yyvsp[-1].ValueList))[i])) | 
|  | IdxVec.push_back(C); | 
|  | else | 
|  | GEN_ERROR("Indices to constant getelementptr must be constants!"); | 
|  |  | 
|  | delete (yyvsp[-1].ValueList); | 
|  |  | 
|  | (yyval.ConstVal) = ConstantExpr::getGetElementPtr((yyvsp[-2].ConstVal), IdxVec); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 157: | 
|  | #line 1684 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if ((yyvsp[-5].ConstVal)->getType() != Type::BoolTy) | 
|  | GEN_ERROR("Select condition must be of boolean type!"); | 
|  | if ((yyvsp[-3].ConstVal)->getType() != (yyvsp[-1].ConstVal)->getType()) | 
|  | GEN_ERROR("Select operand types must match!"); | 
|  | (yyval.ConstVal) = ConstantExpr::getSelect((yyvsp[-5].ConstVal), (yyvsp[-3].ConstVal), (yyvsp[-1].ConstVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 158: | 
|  | #line 1692 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if ((yyvsp[-3].ConstVal)->getType() != (yyvsp[-1].ConstVal)->getType()) | 
|  | GEN_ERROR("Binary operator types must match!"); | 
|  | CHECK_FOR_ERROR; | 
|  | (yyval.ConstVal) = ConstantExpr::get((yyvsp[-5].BinaryOpVal), (yyvsp[-3].ConstVal), (yyvsp[-1].ConstVal)); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 159: | 
|  | #line 1698 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if ((yyvsp[-3].ConstVal)->getType() != (yyvsp[-1].ConstVal)->getType()) | 
|  | GEN_ERROR("Logical operator types must match!"); | 
|  | if (!(yyvsp[-3].ConstVal)->getType()->isIntegral()) { | 
|  | if (!isa<PackedType>((yyvsp[-3].ConstVal)->getType()) || | 
|  | !cast<PackedType>((yyvsp[-3].ConstVal)->getType())->getElementType()->isIntegral()) | 
|  | GEN_ERROR("Logical operator requires integral operands!"); | 
|  | } | 
|  | (yyval.ConstVal) = ConstantExpr::get((yyvsp[-5].BinaryOpVal), (yyvsp[-3].ConstVal), (yyvsp[-1].ConstVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 160: | 
|  | #line 1709 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if ((yyvsp[-3].ConstVal)->getType() != (yyvsp[-1].ConstVal)->getType()) | 
|  | GEN_ERROR("icmp operand types must match!"); | 
|  | (yyval.ConstVal) = ConstantExpr::getICmp((yyvsp[-5].IPredicate), (yyvsp[-3].ConstVal), (yyvsp[-1].ConstVal)); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 161: | 
|  | #line 1714 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if ((yyvsp[-3].ConstVal)->getType() != (yyvsp[-1].ConstVal)->getType()) | 
|  | GEN_ERROR("fcmp operand types must match!"); | 
|  | (yyval.ConstVal) = ConstantExpr::getFCmp((yyvsp[-5].FPredicate), (yyvsp[-3].ConstVal), (yyvsp[-1].ConstVal)); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 162: | 
|  | #line 1719 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if ((yyvsp[-1].ConstVal)->getType() != Type::Int8Ty) | 
|  | GEN_ERROR("Shift count for shift constant must be i8 type!"); | 
|  | if (!(yyvsp[-3].ConstVal)->getType()->isInteger()) | 
|  | GEN_ERROR("Shift constant expression requires integer operand!"); | 
|  | CHECK_FOR_ERROR; | 
|  | (yyval.ConstVal) = ConstantExpr::get((yyvsp[-5].OtherOpVal), (yyvsp[-3].ConstVal), (yyvsp[-1].ConstVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 163: | 
|  | #line 1728 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!ExtractElementInst::isValidOperands((yyvsp[-3].ConstVal), (yyvsp[-1].ConstVal))) | 
|  | GEN_ERROR("Invalid extractelement operands!"); | 
|  | (yyval.ConstVal) = ConstantExpr::getExtractElement((yyvsp[-3].ConstVal), (yyvsp[-1].ConstVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 164: | 
|  | #line 1734 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!InsertElementInst::isValidOperands((yyvsp[-5].ConstVal), (yyvsp[-3].ConstVal), (yyvsp[-1].ConstVal))) | 
|  | GEN_ERROR("Invalid insertelement operands!"); | 
|  | (yyval.ConstVal) = ConstantExpr::getInsertElement((yyvsp[-5].ConstVal), (yyvsp[-3].ConstVal), (yyvsp[-1].ConstVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 165: | 
|  | #line 1740 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!ShuffleVectorInst::isValidOperands((yyvsp[-5].ConstVal), (yyvsp[-3].ConstVal), (yyvsp[-1].ConstVal))) | 
|  | GEN_ERROR("Invalid shufflevector operands!"); | 
|  | (yyval.ConstVal) = ConstantExpr::getShuffleVector((yyvsp[-5].ConstVal), (yyvsp[-3].ConstVal), (yyvsp[-1].ConstVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 166: | 
|  | #line 1749 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | ((yyval.ConstVector) = (yyvsp[-2].ConstVector))->push_back((yyvsp[0].ConstVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 167: | 
|  | #line 1753 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.ConstVector) = new std::vector<Constant*>(); | 
|  | (yyval.ConstVector)->push_back((yyvsp[0].ConstVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 168: | 
|  | #line 1761 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.BoolVal) = false; ;} | 
|  | break; | 
|  |  | 
|  | case 169: | 
|  | #line 1761 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.BoolVal) = true; ;} | 
|  | break; | 
|  |  | 
|  | case 170: | 
|  | #line 1772 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.ModuleVal) = ParserResult = CurModule.CurrentModule; | 
|  | CurModule.ModuleDone(); | 
|  | CHECK_FOR_ERROR; | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 171: | 
|  | #line 1777 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.ModuleVal) = ParserResult = CurModule.CurrentModule; | 
|  | CurModule.ModuleDone(); | 
|  | CHECK_FOR_ERROR; | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 174: | 
|  | #line 1790 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { CurFun.isDeclare = false ;} | 
|  | break; | 
|  |  | 
|  | case 175: | 
|  | #line 1790 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | CurFun.FunctionDone(); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 176: | 
|  | #line 1794 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { CurFun.isDeclare = true; ;} | 
|  | break; | 
|  |  | 
|  | case 177: | 
|  | #line 1794 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 178: | 
|  | #line 1797 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 179: | 
|  | #line 1800 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | // Emit an error if there are any unresolved types left. | 
|  | if (!CurModule.LateResolveTypes.empty()) { | 
|  | const ValID &DID = CurModule.LateResolveTypes.begin()->first; | 
|  | if (DID.Type == ValID::NameVal) { | 
|  | GEN_ERROR("Reference to an undefined type: '"+DID.getName() + "'"); | 
|  | } else { | 
|  | GEN_ERROR("Reference to an undefined type: #" + itostr(DID.Num)); | 
|  | } | 
|  | } | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 180: | 
|  | #line 1812 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[0].TypeVal))->getDescription()); | 
|  | // Eagerly resolve types.  This is not an optimization, this is a | 
|  | // requirement that is due to the fact that we could have this: | 
|  | // | 
|  | // %list = type { %list * } | 
|  | // %list = type { %list * }    ; repeated type decl | 
|  | // | 
|  | // If types are not resolved eagerly, then the two types will not be | 
|  | // determined to be the same type! | 
|  | // | 
|  | ResolveTypeTo((yyvsp[-2].StrVal), *(yyvsp[0].TypeVal)); | 
|  |  | 
|  | if (!setTypeName(*(yyvsp[0].TypeVal), (yyvsp[-2].StrVal)) && !(yyvsp[-2].StrVal)) { | 
|  | CHECK_FOR_ERROR | 
|  | // If this is a named type that is not a redefinition, add it to the slot | 
|  | // table. | 
|  | CurModule.Types.push_back(*(yyvsp[0].TypeVal)); | 
|  | } | 
|  |  | 
|  | delete (yyvsp[0].TypeVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 181: | 
|  | #line 1836 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | ResolveTypeTo((yyvsp[-2].StrVal), (yyvsp[0].PrimType)); | 
|  |  | 
|  | if (!setTypeName((yyvsp[0].PrimType), (yyvsp[-2].StrVal)) && !(yyvsp[-2].StrVal)) { | 
|  | CHECK_FOR_ERROR | 
|  | // If this is a named type that is not a redefinition, add it to the slot | 
|  | // table. | 
|  | CurModule.Types.push_back((yyvsp[0].PrimType)); | 
|  | } | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 182: | 
|  | #line 1847 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { /* "Externally Visible" Linkage */ | 
|  | if ((yyvsp[0].ConstVal) == 0) | 
|  | GEN_ERROR("Global value initializer is not a constant!"); | 
|  | CurGV = ParseGlobalVariable((yyvsp[-2].StrVal), GlobalValue::ExternalLinkage, (yyvsp[-1].BoolVal), | 
|  | (yyvsp[0].ConstVal)->getType(), (yyvsp[0].ConstVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 183: | 
|  | #line 1853 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | CurGV = 0; | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 184: | 
|  | #line 1856 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if ((yyvsp[0].ConstVal) == 0) | 
|  | GEN_ERROR("Global value initializer is not a constant!"); | 
|  | CurGV = ParseGlobalVariable((yyvsp[-3].StrVal), (yyvsp[-2].Linkage), (yyvsp[-1].BoolVal), (yyvsp[0].ConstVal)->getType(), (yyvsp[0].ConstVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 185: | 
|  | #line 1861 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | CurGV = 0; | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 186: | 
|  | #line 1864 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[0].TypeVal))->getDescription()); | 
|  | CurGV = ParseGlobalVariable((yyvsp[-3].StrVal), (yyvsp[-2].Linkage), (yyvsp[-1].BoolVal), *(yyvsp[0].TypeVal), 0); | 
|  | CHECK_FOR_ERROR | 
|  | delete (yyvsp[0].TypeVal); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 187: | 
|  | #line 1870 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | CurGV = 0; | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 188: | 
|  | #line 1874 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 189: | 
|  | #line 1877 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 190: | 
|  | #line 1883 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | const std::string &AsmSoFar = CurModule.CurrentModule->getModuleInlineAsm(); | 
|  | char *EndStr = UnEscapeLexed((yyvsp[0].StrVal), true); | 
|  | std::string NewAsm((yyvsp[0].StrVal), EndStr); | 
|  | free((yyvsp[0].StrVal)); | 
|  |  | 
|  | if (AsmSoFar.empty()) | 
|  | CurModule.CurrentModule->setModuleInlineAsm(NewAsm); | 
|  | else | 
|  | CurModule.CurrentModule->setModuleInlineAsm(AsmSoFar+"\n"+NewAsm); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 191: | 
|  | #line 1896 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.Endianness) = Module::BigEndian; ;} | 
|  | break; | 
|  |  | 
|  | case 192: | 
|  | #line 1897 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.Endianness) = Module::LittleEndian; ;} | 
|  | break; | 
|  |  | 
|  | case 193: | 
|  | #line 1899 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | CurModule.CurrentModule->setEndianness((yyvsp[0].Endianness)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 194: | 
|  | #line 1903 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if ((yyvsp[0].UInt64Val) == 32) | 
|  | CurModule.CurrentModule->setPointerSize(Module::Pointer32); | 
|  | else if ((yyvsp[0].UInt64Val) == 64) | 
|  | CurModule.CurrentModule->setPointerSize(Module::Pointer64); | 
|  | else | 
|  | GEN_ERROR("Invalid pointer size: '" + utostr((yyvsp[0].UInt64Val)) + "'!"); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 195: | 
|  | #line 1912 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | CurModule.CurrentModule->setTargetTriple((yyvsp[0].StrVal)); | 
|  | free((yyvsp[0].StrVal)); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 196: | 
|  | #line 1916 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | CurModule.CurrentModule->setDataLayout((yyvsp[0].StrVal)); | 
|  | free((yyvsp[0].StrVal)); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 198: | 
|  | #line 1923 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | CurModule.CurrentModule->addLibrary((yyvsp[0].StrVal)); | 
|  | free((yyvsp[0].StrVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 199: | 
|  | #line 1928 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | CurModule.CurrentModule->addLibrary((yyvsp[0].StrVal)); | 
|  | free((yyvsp[0].StrVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 200: | 
|  | #line 1933 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 204: | 
|  | #line 1943 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.StrVal) = 0; ;} | 
|  | break; | 
|  |  | 
|  | case 205: | 
|  | #line 1945 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-2].TypeVal))->getDescription()); | 
|  | if (*(yyvsp[-2].TypeVal) == Type::VoidTy) | 
|  | GEN_ERROR("void typed arguments are invalid!"); | 
|  | ArgListEntry E; E.Attrs = (yyvsp[-1].ParamAttrs); E.Ty = (yyvsp[-2].TypeVal); E.Name = (yyvsp[0].StrVal); | 
|  | (yyval.ArgList) = (yyvsp[-4].ArgList); | 
|  | (yyvsp[-4].ArgList)->push_back(E); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 206: | 
|  | #line 1955 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-2].TypeVal))->getDescription()); | 
|  | if (*(yyvsp[-2].TypeVal) == Type::VoidTy) | 
|  | GEN_ERROR("void typed arguments are invalid!"); | 
|  | ArgListEntry E; E.Attrs = (yyvsp[-1].ParamAttrs); E.Ty = (yyvsp[-2].TypeVal); E.Name = (yyvsp[0].StrVal); | 
|  | (yyval.ArgList) = new ArgListType; | 
|  | (yyval.ArgList)->push_back(E); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 207: | 
|  | #line 1966 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.ArgList) = (yyvsp[0].ArgList); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 208: | 
|  | #line 1970 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.ArgList) = (yyvsp[-2].ArgList); | 
|  | struct ArgListEntry E; | 
|  | E.Ty = new PATypeHolder(Type::VoidTy); | 
|  | E.Name = 0; | 
|  | E.Attrs = FunctionType::NoAttributeSet; | 
|  | (yyval.ArgList)->push_back(E); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 209: | 
|  | #line 1979 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.ArgList) = new ArgListType; | 
|  | struct ArgListEntry E; | 
|  | E.Ty = new PATypeHolder(Type::VoidTy); | 
|  | E.Name = 0; | 
|  | E.Attrs = FunctionType::NoAttributeSet; | 
|  | (yyval.ArgList)->push_back(E); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 210: | 
|  | #line 1988 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.ArgList) = 0; | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 211: | 
|  | #line 1994 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | UnEscapeLexed((yyvsp[-5].StrVal)); | 
|  | std::string FunctionName((yyvsp[-5].StrVal)); | 
|  | free((yyvsp[-5].StrVal));  // Free strdup'd memory! | 
|  |  | 
|  | // Check the function result for abstractness if this is a define. We should | 
|  | // have no abstract types at this point | 
|  | if (!CurFun.isDeclare && CurModule.TypeIsUnresolved((yyvsp[-6].TypeWithAttrs).Ty)) | 
|  | GEN_ERROR("Reference to abstract result: "+ (yyvsp[-6].TypeWithAttrs).Ty->get()->getDescription()); | 
|  |  | 
|  | std::vector<const Type*> ParamTypeList; | 
|  | std::vector<FunctionType::ParameterAttributes> ParamAttrs; | 
|  | ParamAttrs.push_back((yyvsp[-6].TypeWithAttrs).Attrs); | 
|  | if ((yyvsp[-3].ArgList)) {   // If there are arguments... | 
|  | for (ArgListType::iterator I = (yyvsp[-3].ArgList)->begin(); I != (yyvsp[-3].ArgList)->end(); ++I) { | 
|  | const Type* Ty = I->Ty->get(); | 
|  | if (!CurFun.isDeclare && CurModule.TypeIsUnresolved(I->Ty)) | 
|  | GEN_ERROR("Reference to abstract argument: " + Ty->getDescription()); | 
|  | ParamTypeList.push_back(Ty); | 
|  | if (Ty != Type::VoidTy) | 
|  | ParamAttrs.push_back(I->Attrs); | 
|  | } | 
|  | } | 
|  |  | 
|  | bool isVarArg = ParamTypeList.size() && ParamTypeList.back() == Type::VoidTy; | 
|  | if (isVarArg) ParamTypeList.pop_back(); | 
|  |  | 
|  | FunctionType *FT = FunctionType::get(*(yyvsp[-6].TypeWithAttrs).Ty, ParamTypeList, isVarArg, | 
|  | ParamAttrs); | 
|  | const PointerType *PFT = PointerType::get(FT); | 
|  | delete (yyvsp[-6].TypeWithAttrs).Ty; | 
|  |  | 
|  | ValID ID; | 
|  | if (!FunctionName.empty()) { | 
|  | ID = ValID::create((char*)FunctionName.c_str()); | 
|  | } else { | 
|  | ID = ValID::create((int)CurModule.Values[PFT].size()); | 
|  | } | 
|  |  | 
|  | Function *Fn = 0; | 
|  | // See if this function was forward referenced.  If so, recycle the object. | 
|  | if (GlobalValue *FWRef = CurModule.GetForwardRefForGlobal(PFT, ID)) { | 
|  | // Move the function to the end of the list, from whereever it was | 
|  | // previously inserted. | 
|  | Fn = cast<Function>(FWRef); | 
|  | CurModule.CurrentModule->getFunctionList().remove(Fn); | 
|  | CurModule.CurrentModule->getFunctionList().push_back(Fn); | 
|  | } else if (!FunctionName.empty() &&     // Merge with an earlier prototype? | 
|  | (Fn = CurModule.CurrentModule->getFunction(FunctionName, FT))) { | 
|  | // If this is the case, either we need to be a forward decl, or it needs | 
|  | // to be. | 
|  | if (!CurFun.isDeclare && !Fn->isExternal()) | 
|  | GEN_ERROR("Redefinition of function '" + FunctionName + "'!"); | 
|  |  | 
|  | // Make sure to strip off any argument names so we can't get conflicts. | 
|  | if (Fn->isExternal()) | 
|  | for (Function::arg_iterator AI = Fn->arg_begin(), AE = Fn->arg_end(); | 
|  | AI != AE; ++AI) | 
|  | AI->setName(""); | 
|  | } else  {  // Not already defined? | 
|  | Fn = new Function(FT, GlobalValue::ExternalLinkage, FunctionName, | 
|  | CurModule.CurrentModule); | 
|  |  | 
|  | InsertValue(Fn, CurModule.Values); | 
|  | } | 
|  |  | 
|  | CurFun.FunctionStart(Fn); | 
|  |  | 
|  | if (CurFun.isDeclare) { | 
|  | // If we have declaration, always overwrite linkage.  This will allow us to | 
|  | // correctly handle cases, when pointer to function is passed as argument to | 
|  | // another function. | 
|  | Fn->setLinkage(CurFun.Linkage); | 
|  | } | 
|  | Fn->setCallingConv((yyvsp[-7].UIntVal)); | 
|  | Fn->setAlignment((yyvsp[0].UIntVal)); | 
|  | if ((yyvsp[-1].StrVal)) { | 
|  | Fn->setSection((yyvsp[-1].StrVal)); | 
|  | free((yyvsp[-1].StrVal)); | 
|  | } | 
|  |  | 
|  | // Add all of the arguments we parsed to the function... | 
|  | if ((yyvsp[-3].ArgList)) {                     // Is null if empty... | 
|  | if (isVarArg) {  // Nuke the last entry | 
|  | assert((yyvsp[-3].ArgList)->back().Ty->get() == Type::VoidTy && (yyvsp[-3].ArgList)->back().Name == 0&& | 
|  | "Not a varargs marker!"); | 
|  | delete (yyvsp[-3].ArgList)->back().Ty; | 
|  | (yyvsp[-3].ArgList)->pop_back();  // Delete the last entry | 
|  | } | 
|  | Function::arg_iterator ArgIt = Fn->arg_begin(); | 
|  | unsigned Idx = 1; | 
|  | for (ArgListType::iterator I = (yyvsp[-3].ArgList)->begin(); I != (yyvsp[-3].ArgList)->end(); ++I, ++ArgIt) { | 
|  | delete I->Ty;                          // Delete the typeholder... | 
|  | setValueName(ArgIt, I->Name);           // Insert arg into symtab... | 
|  | CHECK_FOR_ERROR | 
|  | InsertValue(ArgIt); | 
|  | Idx++; | 
|  | } | 
|  |  | 
|  | delete (yyvsp[-3].ArgList);                     // We're now done with the argument list | 
|  | } | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 214: | 
|  | #line 2100 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.FunctionVal) = CurFun.CurrentFunction; | 
|  |  | 
|  | // Make sure that we keep track of the linkage type even if there was a | 
|  | // previous "declare". | 
|  | (yyval.FunctionVal)->setLinkage((yyvsp[-2].Linkage)); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 217: | 
|  | #line 2110 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.FunctionVal) = (yyvsp[-1].FunctionVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 218: | 
|  | #line 2115 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | CurFun.CurrentFunction->setLinkage((yyvsp[-1].Linkage)); | 
|  | (yyval.FunctionVal) = CurFun.CurrentFunction; | 
|  | CurFun.FunctionDone(); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 219: | 
|  | #line 2126 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.BoolVal) = false; | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 220: | 
|  | #line 2130 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.BoolVal) = true; | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 221: | 
|  | #line 2135 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | {    // A reference to a direct constant | 
|  | (yyval.ValIDVal) = ValID::create((yyvsp[0].SInt64Val)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 222: | 
|  | #line 2139 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.ValIDVal) = ValID::create((yyvsp[0].UInt64Val)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 223: | 
|  | #line 2143 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | {                     // Perhaps it's an FP constant? | 
|  | (yyval.ValIDVal) = ValID::create((yyvsp[0].FPVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 224: | 
|  | #line 2147 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.ValIDVal) = ValID::create(ConstantBool::getTrue()); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 225: | 
|  | #line 2151 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.ValIDVal) = ValID::create(ConstantBool::getFalse()); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 226: | 
|  | #line 2155 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.ValIDVal) = ValID::createNull(); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 227: | 
|  | #line 2159 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.ValIDVal) = ValID::createUndef(); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 228: | 
|  | #line 2163 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | {     // A vector zero constant. | 
|  | (yyval.ValIDVal) = ValID::createZeroInit(); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 229: | 
|  | #line 2167 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { // Nonempty unsized packed vector | 
|  | const Type *ETy = (*(yyvsp[-1].ConstVector))[0]->getType(); | 
|  | int NumElements = (yyvsp[-1].ConstVector)->size(); | 
|  |  | 
|  | PackedType* pt = PackedType::get(ETy, NumElements); | 
|  | PATypeHolder* PTy = new PATypeHolder( | 
|  | HandleUpRefs( | 
|  | PackedType::get( | 
|  | ETy, | 
|  | NumElements) | 
|  | ) | 
|  | ); | 
|  |  | 
|  | // Verify all elements are correct type! | 
|  | for (unsigned i = 0; i < (yyvsp[-1].ConstVector)->size(); i++) { | 
|  | if (ETy != (*(yyvsp[-1].ConstVector))[i]->getType()) | 
|  | GEN_ERROR("Element #" + utostr(i) + " is not of type '" + | 
|  | ETy->getDescription() +"' as required!\nIt is of type '" + | 
|  | (*(yyvsp[-1].ConstVector))[i]->getType()->getDescription() + "'."); | 
|  | } | 
|  |  | 
|  | (yyval.ValIDVal) = ValID::create(ConstantPacked::get(pt, *(yyvsp[-1].ConstVector))); | 
|  | delete PTy; delete (yyvsp[-1].ConstVector); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 230: | 
|  | #line 2192 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.ValIDVal) = ValID::create((yyvsp[0].ConstVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 231: | 
|  | #line 2196 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | char *End = UnEscapeLexed((yyvsp[-2].StrVal), true); | 
|  | std::string AsmStr = std::string((yyvsp[-2].StrVal), End); | 
|  | End = UnEscapeLexed((yyvsp[0].StrVal), true); | 
|  | std::string Constraints = std::string((yyvsp[0].StrVal), End); | 
|  | (yyval.ValIDVal) = ValID::createInlineAsm(AsmStr, Constraints, (yyvsp[-3].BoolVal)); | 
|  | free((yyvsp[-2].StrVal)); | 
|  | free((yyvsp[0].StrVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 232: | 
|  | #line 2210 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | {  // Is it an integer reference...? | 
|  | (yyval.ValIDVal) = ValID::create((yyvsp[0].SIntVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 233: | 
|  | #line 2214 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | {                   // Is it a named reference...? | 
|  | (yyval.ValIDVal) = ValID::create((yyvsp[0].StrVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 236: | 
|  | #line 2226 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-1].TypeVal))->getDescription()); | 
|  | (yyval.ValueVal) = getVal(*(yyvsp[-1].TypeVal), (yyvsp[0].ValIDVal)); | 
|  | delete (yyvsp[-1].TypeVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 237: | 
|  | #line 2235 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.FunctionVal) = (yyvsp[-1].FunctionVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 238: | 
|  | #line 2239 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { // Do not allow functions with 0 basic blocks | 
|  | (yyval.FunctionVal) = (yyvsp[-1].FunctionVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 239: | 
|  | #line 2248 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | setValueName((yyvsp[0].TermInstVal), (yyvsp[-1].StrVal)); | 
|  | CHECK_FOR_ERROR | 
|  | InsertValue((yyvsp[0].TermInstVal)); | 
|  |  | 
|  | (yyvsp[-2].BasicBlockVal)->getInstList().push_back((yyvsp[0].TermInstVal)); | 
|  | InsertValue((yyvsp[-2].BasicBlockVal)); | 
|  | (yyval.BasicBlockVal) = (yyvsp[-2].BasicBlockVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 240: | 
|  | #line 2259 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (CastInst *CI1 = dyn_cast<CastInst>((yyvsp[0].InstVal))) | 
|  | if (CastInst *CI2 = dyn_cast<CastInst>(CI1->getOperand(0))) | 
|  | if (CI2->getParent() == 0) | 
|  | (yyvsp[-1].BasicBlockVal)->getInstList().push_back(CI2); | 
|  | (yyvsp[-1].BasicBlockVal)->getInstList().push_back((yyvsp[0].InstVal)); | 
|  | (yyval.BasicBlockVal) = (yyvsp[-1].BasicBlockVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 241: | 
|  | #line 2268 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.BasicBlockVal) = getBBVal(ValID::create((int)CurFun.NextBBNum++), true); | 
|  | CHECK_FOR_ERROR | 
|  |  | 
|  | // Make sure to move the basic block to the correct location in the | 
|  | // function, instead of leaving it inserted wherever it was first | 
|  | // referenced. | 
|  | Function::BasicBlockListType &BBL = | 
|  | CurFun.CurrentFunction->getBasicBlockList(); | 
|  | BBL.splice(BBL.end(), BBL, (yyval.BasicBlockVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 242: | 
|  | #line 2280 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.BasicBlockVal) = getBBVal(ValID::create((yyvsp[0].StrVal)), true); | 
|  | CHECK_FOR_ERROR | 
|  |  | 
|  | // Make sure to move the basic block to the correct location in the | 
|  | // function, instead of leaving it inserted wherever it was first | 
|  | // referenced. | 
|  | Function::BasicBlockListType &BBL = | 
|  | CurFun.CurrentFunction->getBasicBlockList(); | 
|  | BBL.splice(BBL.end(), BBL, (yyval.BasicBlockVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 243: | 
|  | #line 2293 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | {              // Return with a result... | 
|  | (yyval.TermInstVal) = new ReturnInst((yyvsp[0].ValueVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 244: | 
|  | #line 2297 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | {                                       // Return with no result... | 
|  | (yyval.TermInstVal) = new ReturnInst(); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 245: | 
|  | #line 2301 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | {                         // Unconditional Branch... | 
|  | BasicBlock* tmpBB = getBBVal((yyvsp[0].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | (yyval.TermInstVal) = new BranchInst(tmpBB); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 246: | 
|  | #line 2306 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | BasicBlock* tmpBBA = getBBVal((yyvsp[-3].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | BasicBlock* tmpBBB = getBBVal((yyvsp[0].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | Value* tmpVal = getVal(Type::BoolTy, (yyvsp[-6].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | (yyval.TermInstVal) = new BranchInst(tmpBBA, tmpBBB, tmpVal); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 247: | 
|  | #line 2315 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | Value* tmpVal = getVal((yyvsp[-7].PrimType), (yyvsp[-6].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | BasicBlock* tmpBB = getBBVal((yyvsp[-3].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | SwitchInst *S = new SwitchInst(tmpVal, tmpBB, (yyvsp[-1].JumpTable)->size()); | 
|  | (yyval.TermInstVal) = S; | 
|  |  | 
|  | std::vector<std::pair<Constant*,BasicBlock*> >::iterator I = (yyvsp[-1].JumpTable)->begin(), | 
|  | E = (yyvsp[-1].JumpTable)->end(); | 
|  | for (; I != E; ++I) { | 
|  | if (ConstantInt *CI = dyn_cast<ConstantInt>(I->first)) | 
|  | S->addCase(CI, I->second); | 
|  | else | 
|  | GEN_ERROR("Switch case is constant, but not a simple integer!"); | 
|  | } | 
|  | delete (yyvsp[-1].JumpTable); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 248: | 
|  | #line 2334 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | Value* tmpVal = getVal((yyvsp[-6].PrimType), (yyvsp[-5].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | BasicBlock* tmpBB = getBBVal((yyvsp[-2].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | SwitchInst *S = new SwitchInst(tmpVal, tmpBB, 0); | 
|  | (yyval.TermInstVal) = S; | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 249: | 
|  | #line 2344 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  |  | 
|  | // Handle the short syntax | 
|  | const PointerType *PFTy = 0; | 
|  | const FunctionType *Ty = 0; | 
|  | if (!(PFTy = dyn_cast<PointerType>((yyvsp[-10].TypeWithAttrs).Ty->get())) || | 
|  | !(Ty = dyn_cast<FunctionType>(PFTy->getElementType()))) { | 
|  | // Pull out the types of all of the arguments... | 
|  | std::vector<const Type*> ParamTypes; | 
|  | FunctionType::ParamAttrsList ParamAttrs; | 
|  | ParamAttrs.push_back((yyvsp[-10].TypeWithAttrs).Attrs); | 
|  | for (ValueRefList::iterator I = (yyvsp[-7].ValueRefList)->begin(), E = (yyvsp[-7].ValueRefList)->end(); I != E; ++I) { | 
|  | const Type *Ty = I->Val->getType(); | 
|  | if (Ty == Type::VoidTy) | 
|  | GEN_ERROR("Short call syntax cannot be used with varargs"); | 
|  | ParamTypes.push_back(Ty); | 
|  | ParamAttrs.push_back(I->Attrs); | 
|  | } | 
|  |  | 
|  | Ty = FunctionType::get((yyvsp[-10].TypeWithAttrs).Ty->get(), ParamTypes, false, ParamAttrs); | 
|  | PFTy = PointerType::get(Ty); | 
|  | } | 
|  |  | 
|  | Value *V = getVal(PFTy, (yyvsp[-9].ValIDVal));   // Get the function we're calling... | 
|  | CHECK_FOR_ERROR | 
|  | BasicBlock *Normal = getBBVal((yyvsp[-3].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | BasicBlock *Except = getBBVal((yyvsp[0].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  |  | 
|  | // Check the arguments | 
|  | ValueList Args; | 
|  | if ((yyvsp[-7].ValueRefList)->empty()) {                                   // Has no arguments? | 
|  | // Make sure no arguments is a good thing! | 
|  | if (Ty->getNumParams() != 0) | 
|  | GEN_ERROR("No arguments passed to a function that " | 
|  | "expects arguments!"); | 
|  | } else {                                     // Has arguments? | 
|  | // Loop through FunctionType's arguments and ensure they are specified | 
|  | // correctly! | 
|  | FunctionType::param_iterator I = Ty->param_begin(); | 
|  | FunctionType::param_iterator E = Ty->param_end(); | 
|  | ValueRefList::iterator ArgI = (yyvsp[-7].ValueRefList)->begin(), ArgE = (yyvsp[-7].ValueRefList)->end(); | 
|  |  | 
|  | for (; ArgI != ArgE && I != E; ++ArgI, ++I) { | 
|  | if (ArgI->Val->getType() != *I) | 
|  | GEN_ERROR("Parameter " + ArgI->Val->getName()+ " is not of type '" + | 
|  | (*I)->getDescription() + "'!"); | 
|  | Args.push_back(ArgI->Val); | 
|  | } | 
|  |  | 
|  | if (Ty->isVarArg()) { | 
|  | if (I == E) | 
|  | for (; ArgI != ArgE; ++ArgI) | 
|  | Args.push_back(ArgI->Val); // push the remaining varargs | 
|  | } else if (I != E || ArgI != ArgE) | 
|  | GEN_ERROR("Invalid number of parameters detected!"); | 
|  | } | 
|  |  | 
|  | // Create the InvokeInst | 
|  | InvokeInst *II = new InvokeInst(V, Normal, Except, Args); | 
|  | II->setCallingConv((yyvsp[-11].UIntVal)); | 
|  | (yyval.TermInstVal) = II; | 
|  | delete (yyvsp[-7].ValueRefList); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 250: | 
|  | #line 2410 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.TermInstVal) = new UnwindInst(); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 251: | 
|  | #line 2414 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.TermInstVal) = new UnreachableInst(); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 252: | 
|  | #line 2421 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.JumpTable) = (yyvsp[-5].JumpTable); | 
|  | Constant *V = cast<Constant>(getValNonImprovising((yyvsp[-4].PrimType), (yyvsp[-3].ValIDVal))); | 
|  | CHECK_FOR_ERROR | 
|  | if (V == 0) | 
|  | GEN_ERROR("May only switch on a constant pool value!"); | 
|  |  | 
|  | BasicBlock* tmpBB = getBBVal((yyvsp[0].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | (yyval.JumpTable)->push_back(std::make_pair(V, tmpBB)); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 253: | 
|  | #line 2432 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.JumpTable) = new std::vector<std::pair<Constant*, BasicBlock*> >(); | 
|  | Constant *V = cast<Constant>(getValNonImprovising((yyvsp[-4].PrimType), (yyvsp[-3].ValIDVal))); | 
|  | CHECK_FOR_ERROR | 
|  |  | 
|  | if (V == 0) | 
|  | GEN_ERROR("May only switch on a constant pool value!"); | 
|  |  | 
|  | BasicBlock* tmpBB = getBBVal((yyvsp[0].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | (yyval.JumpTable)->push_back(std::make_pair(V, tmpBB)); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 254: | 
|  | #line 2445 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | // Is this definition named?? if so, assign the name... | 
|  | setValueName((yyvsp[0].InstVal), (yyvsp[-1].StrVal)); | 
|  | CHECK_FOR_ERROR | 
|  | InsertValue((yyvsp[0].InstVal)); | 
|  | (yyval.InstVal) = (yyvsp[0].InstVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 255: | 
|  | #line 2454 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | {    // Used for PHI nodes | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-5].TypeVal))->getDescription()); | 
|  | (yyval.PHIList) = new std::list<std::pair<Value*, BasicBlock*> >(); | 
|  | Value* tmpVal = getVal(*(yyvsp[-5].TypeVal), (yyvsp[-3].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | BasicBlock* tmpBB = getBBVal((yyvsp[-1].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | (yyval.PHIList)->push_back(std::make_pair(tmpVal, tmpBB)); | 
|  | delete (yyvsp[-5].TypeVal); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 256: | 
|  | #line 2465 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.PHIList) = (yyvsp[-6].PHIList); | 
|  | Value* tmpVal = getVal((yyvsp[-6].PHIList)->front().first->getType(), (yyvsp[-3].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | BasicBlock* tmpBB = getBBVal((yyvsp[-1].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | (yyvsp[-6].PHIList)->push_back(std::make_pair(tmpVal, tmpBB)); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 257: | 
|  | #line 2475 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-2].TypeVal))->getDescription()); | 
|  | // Used for call and invoke instructions | 
|  | (yyval.ValueRefList) = new ValueRefList(); | 
|  | ValueRefListEntry E; E.Attrs = (yyvsp[0].ParamAttrs); E.Val = getVal((yyvsp[-2].TypeVal)->get(), (yyvsp[-1].ValIDVal)); | 
|  | (yyval.ValueRefList)->push_back(E); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 258: | 
|  | #line 2483 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-2].TypeVal))->getDescription()); | 
|  | (yyval.ValueRefList) = (yyvsp[-4].ValueRefList); | 
|  | ValueRefListEntry E; E.Attrs = (yyvsp[0].ParamAttrs); E.Val = getVal((yyvsp[-2].TypeVal)->get(), (yyvsp[-1].ValIDVal)); | 
|  | (yyval.ValueRefList)->push_back(E); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 259: | 
|  | #line 2491 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.ValueRefList) = new ValueRefList(); ;} | 
|  | break; | 
|  |  | 
|  | case 260: | 
|  | #line 2494 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { (yyval.ValueList) = new std::vector<Value*>(); ;} | 
|  | break; | 
|  |  | 
|  | case 261: | 
|  | #line 2495 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.ValueList) = (yyvsp[-2].ValueList); | 
|  | (yyval.ValueList)->push_back((yyvsp[0].ValueVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 262: | 
|  | #line 2502 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.BoolVal) = true; | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 263: | 
|  | #line 2506 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.BoolVal) = false; | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 264: | 
|  | #line 2511 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-3].TypeVal))->getDescription()); | 
|  | if (!(*(yyvsp[-3].TypeVal))->isInteger() && !(*(yyvsp[-3].TypeVal))->isFloatingPoint() && | 
|  | !isa<PackedType>((*(yyvsp[-3].TypeVal)).get())) | 
|  | GEN_ERROR( | 
|  | "Arithmetic operator requires integer, FP, or packed operands!"); | 
|  | if (isa<PackedType>((*(yyvsp[-3].TypeVal)).get()) && | 
|  | ((yyvsp[-4].BinaryOpVal) == Instruction::URem || | 
|  | (yyvsp[-4].BinaryOpVal) == Instruction::SRem || | 
|  | (yyvsp[-4].BinaryOpVal) == Instruction::FRem)) | 
|  | GEN_ERROR("U/S/FRem not supported on packed types!"); | 
|  | Value* val1 = getVal(*(yyvsp[-3].TypeVal), (yyvsp[-2].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | Value* val2 = getVal(*(yyvsp[-3].TypeVal), (yyvsp[0].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | (yyval.InstVal) = BinaryOperator::create((yyvsp[-4].BinaryOpVal), val1, val2); | 
|  | if ((yyval.InstVal) == 0) | 
|  | GEN_ERROR("binary operator returned null!"); | 
|  | delete (yyvsp[-3].TypeVal); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 265: | 
|  | #line 2532 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-3].TypeVal))->getDescription()); | 
|  | if (!(*(yyvsp[-3].TypeVal))->isIntegral()) { | 
|  | if (!isa<PackedType>((yyvsp[-3].TypeVal)->get()) || | 
|  | !cast<PackedType>((yyvsp[-3].TypeVal)->get())->getElementType()->isIntegral()) | 
|  | GEN_ERROR("Logical operator requires integral operands!"); | 
|  | } | 
|  | Value* tmpVal1 = getVal(*(yyvsp[-3].TypeVal), (yyvsp[-2].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | Value* tmpVal2 = getVal(*(yyvsp[-3].TypeVal), (yyvsp[0].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | (yyval.InstVal) = BinaryOperator::create((yyvsp[-4].BinaryOpVal), tmpVal1, tmpVal2); | 
|  | if ((yyval.InstVal) == 0) | 
|  | GEN_ERROR("binary operator returned null!"); | 
|  | delete (yyvsp[-3].TypeVal); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 266: | 
|  | #line 2549 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-3].TypeVal))->getDescription()); | 
|  | Value* tmpVal1 = getVal(*(yyvsp[-3].TypeVal), (yyvsp[-2].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | Value* tmpVal2 = getVal(*(yyvsp[-3].TypeVal), (yyvsp[0].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | (yyval.InstVal) = CmpInst::create((yyvsp[-5].OtherOpVal), (yyvsp[-4].IPredicate), tmpVal1, tmpVal2); | 
|  | if ((yyval.InstVal) == 0) | 
|  | GEN_ERROR("icmp operator returned null!"); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 267: | 
|  | #line 2560 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-3].TypeVal))->getDescription()); | 
|  | Value* tmpVal1 = getVal(*(yyvsp[-3].TypeVal), (yyvsp[-2].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | Value* tmpVal2 = getVal(*(yyvsp[-3].TypeVal), (yyvsp[0].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | (yyval.InstVal) = CmpInst::create((yyvsp[-5].OtherOpVal), (yyvsp[-4].FPredicate), tmpVal1, tmpVal2); | 
|  | if ((yyval.InstVal) == 0) | 
|  | GEN_ERROR("fcmp operator returned null!"); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 268: | 
|  | #line 2571 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | cerr << "WARNING: Use of eliminated 'not' instruction:" | 
|  | << " Replacing with 'xor'.\n"; | 
|  |  | 
|  | Value *Ones = ConstantIntegral::getAllOnesValue((yyvsp[0].ValueVal)->getType()); | 
|  | if (Ones == 0) | 
|  | GEN_ERROR("Expected integral type for not instruction!"); | 
|  |  | 
|  | (yyval.InstVal) = BinaryOperator::create(Instruction::Xor, (yyvsp[0].ValueVal), Ones); | 
|  | if ((yyval.InstVal) == 0) | 
|  | GEN_ERROR("Could not create a xor instruction!"); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 269: | 
|  | #line 2584 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if ((yyvsp[0].ValueVal)->getType() != Type::Int8Ty) | 
|  | GEN_ERROR("Shift amount must be i8 type!"); | 
|  | if (!(yyvsp[-2].ValueVal)->getType()->isInteger()) | 
|  | GEN_ERROR("Shift constant expression requires integer operand!"); | 
|  | CHECK_FOR_ERROR; | 
|  | (yyval.InstVal) = new ShiftInst((yyvsp[-3].OtherOpVal), (yyvsp[-2].ValueVal), (yyvsp[0].ValueVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 270: | 
|  | #line 2593 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[0].TypeVal))->getDescription()); | 
|  | Value* Val = (yyvsp[-2].ValueVal); | 
|  | const Type* Ty = (yyvsp[0].TypeVal)->get(); | 
|  | if (!Val->getType()->isFirstClassType()) | 
|  | GEN_ERROR("cast from a non-primitive type: '" + | 
|  | Val->getType()->getDescription() + "'!"); | 
|  | if (!Ty->isFirstClassType()) | 
|  | GEN_ERROR("cast to a non-primitive type: '" + Ty->getDescription() +"'!"); | 
|  | (yyval.InstVal) = CastInst::create((yyvsp[-3].CastOpVal), Val, (yyvsp[0].TypeVal)->get()); | 
|  | delete (yyvsp[0].TypeVal); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 271: | 
|  | #line 2606 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if ((yyvsp[-4].ValueVal)->getType() != Type::BoolTy) | 
|  | GEN_ERROR("select condition must be boolean!"); | 
|  | if ((yyvsp[-2].ValueVal)->getType() != (yyvsp[0].ValueVal)->getType()) | 
|  | GEN_ERROR("select value types should match!"); | 
|  | (yyval.InstVal) = new SelectInst((yyvsp[-4].ValueVal), (yyvsp[-2].ValueVal), (yyvsp[0].ValueVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 272: | 
|  | #line 2614 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[0].TypeVal))->getDescription()); | 
|  | (yyval.InstVal) = new VAArgInst((yyvsp[-2].ValueVal), *(yyvsp[0].TypeVal)); | 
|  | delete (yyvsp[0].TypeVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 273: | 
|  | #line 2621 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!ExtractElementInst::isValidOperands((yyvsp[-2].ValueVal), (yyvsp[0].ValueVal))) | 
|  | GEN_ERROR("Invalid extractelement operands!"); | 
|  | (yyval.InstVal) = new ExtractElementInst((yyvsp[-2].ValueVal), (yyvsp[0].ValueVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 274: | 
|  | #line 2627 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!InsertElementInst::isValidOperands((yyvsp[-4].ValueVal), (yyvsp[-2].ValueVal), (yyvsp[0].ValueVal))) | 
|  | GEN_ERROR("Invalid insertelement operands!"); | 
|  | (yyval.InstVal) = new InsertElementInst((yyvsp[-4].ValueVal), (yyvsp[-2].ValueVal), (yyvsp[0].ValueVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 275: | 
|  | #line 2633 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!ShuffleVectorInst::isValidOperands((yyvsp[-4].ValueVal), (yyvsp[-2].ValueVal), (yyvsp[0].ValueVal))) | 
|  | GEN_ERROR("Invalid shufflevector operands!"); | 
|  | (yyval.InstVal) = new ShuffleVectorInst((yyvsp[-4].ValueVal), (yyvsp[-2].ValueVal), (yyvsp[0].ValueVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 276: | 
|  | #line 2639 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | const Type *Ty = (yyvsp[0].PHIList)->front().first->getType(); | 
|  | if (!Ty->isFirstClassType()) | 
|  | GEN_ERROR("PHI node operands must be of first class type!"); | 
|  | (yyval.InstVal) = new PHINode(Ty); | 
|  | ((PHINode*)(yyval.InstVal))->reserveOperandSpace((yyvsp[0].PHIList)->size()); | 
|  | while ((yyvsp[0].PHIList)->begin() != (yyvsp[0].PHIList)->end()) { | 
|  | if ((yyvsp[0].PHIList)->front().first->getType() != Ty) | 
|  | GEN_ERROR("All elements of a PHI node must be of the same type!"); | 
|  | cast<PHINode>((yyval.InstVal))->addIncoming((yyvsp[0].PHIList)->front().first, (yyvsp[0].PHIList)->front().second); | 
|  | (yyvsp[0].PHIList)->pop_front(); | 
|  | } | 
|  | delete (yyvsp[0].PHIList);  // Free the list... | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 277: | 
|  | #line 2654 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  |  | 
|  | // Handle the short syntax | 
|  | const PointerType *PFTy = 0; | 
|  | const FunctionType *Ty = 0; | 
|  | if (!(PFTy = dyn_cast<PointerType>((yyvsp[-4].TypeWithAttrs).Ty->get())) || | 
|  | !(Ty = dyn_cast<FunctionType>(PFTy->getElementType()))) { | 
|  | // Pull out the types of all of the arguments... | 
|  | std::vector<const Type*> ParamTypes; | 
|  | FunctionType::ParamAttrsList ParamAttrs; | 
|  | ParamAttrs.push_back((yyvsp[-4].TypeWithAttrs).Attrs); | 
|  | for (ValueRefList::iterator I = (yyvsp[-1].ValueRefList)->begin(), E = (yyvsp[-1].ValueRefList)->end(); I != E; ++I) { | 
|  | const Type *Ty = I->Val->getType(); | 
|  | if (Ty == Type::VoidTy) | 
|  | GEN_ERROR("Short call syntax cannot be used with varargs"); | 
|  | ParamTypes.push_back(Ty); | 
|  | ParamAttrs.push_back(I->Attrs); | 
|  | } | 
|  |  | 
|  | Ty = FunctionType::get((yyvsp[-4].TypeWithAttrs).Ty->get(), ParamTypes, false, ParamAttrs); | 
|  | PFTy = PointerType::get(Ty); | 
|  | } | 
|  |  | 
|  | Value *V = getVal(PFTy, (yyvsp[-3].ValIDVal));   // Get the function we're calling... | 
|  | CHECK_FOR_ERROR | 
|  |  | 
|  | // Check the arguments | 
|  | ValueList Args; | 
|  | if ((yyvsp[-1].ValueRefList)->empty()) {                                   // Has no arguments? | 
|  | // Make sure no arguments is a good thing! | 
|  | if (Ty->getNumParams() != 0) | 
|  | GEN_ERROR("No arguments passed to a function that " | 
|  | "expects arguments!"); | 
|  | } else {                                     // Has arguments? | 
|  | // Loop through FunctionType's arguments and ensure they are specified | 
|  | // correctly! | 
|  | // | 
|  | FunctionType::param_iterator I = Ty->param_begin(); | 
|  | FunctionType::param_iterator E = Ty->param_end(); | 
|  | ValueRefList::iterator ArgI = (yyvsp[-1].ValueRefList)->begin(), ArgE = (yyvsp[-1].ValueRefList)->end(); | 
|  |  | 
|  | for (; ArgI != ArgE && I != E; ++ArgI, ++I) { | 
|  | if (ArgI->Val->getType() != *I) | 
|  | GEN_ERROR("Parameter " + ArgI->Val->getName()+ " is not of type '" + | 
|  | (*I)->getDescription() + "'!"); | 
|  | Args.push_back(ArgI->Val); | 
|  | } | 
|  | if (Ty->isVarArg()) { | 
|  | if (I == E) | 
|  | for (; ArgI != ArgE; ++ArgI) | 
|  | Args.push_back(ArgI->Val); // push the remaining varargs | 
|  | } else if (I != E || ArgI != ArgE) | 
|  | GEN_ERROR("Invalid number of parameters detected!"); | 
|  | } | 
|  | // Create the call node | 
|  | CallInst *CI = new CallInst(V, Args); | 
|  | CI->setTailCall((yyvsp[-6].BoolVal)); | 
|  | CI->setCallingConv((yyvsp[-5].UIntVal)); | 
|  | (yyval.InstVal) = CI; | 
|  | delete (yyvsp[-1].ValueRefList); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 278: | 
|  | #line 2716 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.InstVal) = (yyvsp[0].InstVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 279: | 
|  | #line 2721 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.BoolVal) = true; | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 280: | 
|  | #line 2725 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | (yyval.BoolVal) = false; | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 281: | 
|  | #line 2732 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-1].TypeVal))->getDescription()); | 
|  | (yyval.InstVal) = new MallocInst(*(yyvsp[-1].TypeVal), 0, (yyvsp[0].UIntVal)); | 
|  | delete (yyvsp[-1].TypeVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 282: | 
|  | #line 2739 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-4].TypeVal))->getDescription()); | 
|  | Value* tmpVal = getVal((yyvsp[-2].PrimType), (yyvsp[-1].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | (yyval.InstVal) = new MallocInst(*(yyvsp[-4].TypeVal), tmpVal, (yyvsp[0].UIntVal)); | 
|  | delete (yyvsp[-4].TypeVal); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 283: | 
|  | #line 2747 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-1].TypeVal))->getDescription()); | 
|  | (yyval.InstVal) = new AllocaInst(*(yyvsp[-1].TypeVal), 0, (yyvsp[0].UIntVal)); | 
|  | delete (yyvsp[-1].TypeVal); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 284: | 
|  | #line 2754 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-4].TypeVal))->getDescription()); | 
|  | Value* tmpVal = getVal((yyvsp[-2].PrimType), (yyvsp[-1].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | (yyval.InstVal) = new AllocaInst(*(yyvsp[-4].TypeVal), tmpVal, (yyvsp[0].UIntVal)); | 
|  | delete (yyvsp[-4].TypeVal); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 285: | 
|  | #line 2762 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!isa<PointerType>((yyvsp[0].ValueVal)->getType())) | 
|  | GEN_ERROR("Trying to free nonpointer type " + | 
|  | (yyvsp[0].ValueVal)->getType()->getDescription() + "!"); | 
|  | (yyval.InstVal) = new FreeInst((yyvsp[0].ValueVal)); | 
|  | CHECK_FOR_ERROR | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 286: | 
|  | #line 2770 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-1].TypeVal))->getDescription()); | 
|  | if (!isa<PointerType>((yyvsp[-1].TypeVal)->get())) | 
|  | GEN_ERROR("Can't load from nonpointer type: " + | 
|  | (*(yyvsp[-1].TypeVal))->getDescription()); | 
|  | if (!cast<PointerType>((yyvsp[-1].TypeVal)->get())->getElementType()->isFirstClassType()) | 
|  | GEN_ERROR("Can't load from pointer of non-first-class type: " + | 
|  | (*(yyvsp[-1].TypeVal))->getDescription()); | 
|  | Value* tmpVal = getVal(*(yyvsp[-1].TypeVal), (yyvsp[0].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | (yyval.InstVal) = new LoadInst(tmpVal, "", (yyvsp[-3].BoolVal)); | 
|  | delete (yyvsp[-1].TypeVal); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 287: | 
|  | #line 2784 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-1].TypeVal))->getDescription()); | 
|  | const PointerType *PT = dyn_cast<PointerType>((yyvsp[-1].TypeVal)->get()); | 
|  | if (!PT) | 
|  | GEN_ERROR("Can't store to a nonpointer type: " + | 
|  | (*(yyvsp[-1].TypeVal))->getDescription()); | 
|  | const Type *ElTy = PT->getElementType(); | 
|  | if (ElTy != (yyvsp[-3].ValueVal)->getType()) | 
|  | GEN_ERROR("Can't store '" + (yyvsp[-3].ValueVal)->getType()->getDescription() + | 
|  | "' into space of type '" + ElTy->getDescription() + "'!"); | 
|  |  | 
|  | Value* tmpVal = getVal(*(yyvsp[-1].TypeVal), (yyvsp[0].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | (yyval.InstVal) = new StoreInst((yyvsp[-3].ValueVal), tmpVal, (yyvsp[-5].BoolVal)); | 
|  | delete (yyvsp[-1].TypeVal); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  | case 288: | 
|  | #line 2801 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  | { | 
|  | if (!UpRefs.empty()) | 
|  | GEN_ERROR("Invalid upreference in type: " + (*(yyvsp[-2].TypeVal))->getDescription()); | 
|  | if (!isa<PointerType>((yyvsp[-2].TypeVal)->get())) | 
|  | GEN_ERROR("getelementptr insn requires pointer operand!"); | 
|  |  | 
|  | if (!GetElementPtrInst::getIndexedType(*(yyvsp[-2].TypeVal), *(yyvsp[0].ValueList), true)) | 
|  | GEN_ERROR("Invalid getelementptr indices for type '" + | 
|  | (*(yyvsp[-2].TypeVal))->getDescription()+ "'!"); | 
|  | Value* tmpVal = getVal(*(yyvsp[-2].TypeVal), (yyvsp[-1].ValIDVal)); | 
|  | CHECK_FOR_ERROR | 
|  | (yyval.InstVal) = new GetElementPtrInst(tmpVal, *(yyvsp[0].ValueList)); | 
|  | delete (yyvsp[-2].TypeVal); | 
|  | delete (yyvsp[0].ValueList); | 
|  | ;} | 
|  | break; | 
|  |  | 
|  |  | 
|  | default: break; | 
|  | } | 
|  |  | 
|  | /* Line 1126 of yacc.c.  */ | 
|  | #line 5569 "llvmAsmParser.tab.c" | 
|  |  | 
|  | yyvsp -= yylen; | 
|  | yyssp -= yylen; | 
|  |  | 
|  |  | 
|  | YY_STACK_PRINT (yyss, yyssp); | 
|  |  | 
|  | *++yyvsp = yyval; | 
|  |  | 
|  |  | 
|  | /* Now `shift' the result of the reduction.  Determine what state | 
|  | that goes to, based on the state we popped back to and the rule | 
|  | number reduced by.  */ | 
|  |  | 
|  | yyn = yyr1[yyn]; | 
|  |  | 
|  | yystate = yypgoto[yyn - YYNTOKENS] + *yyssp; | 
|  | if (0 <= yystate && yystate <= YYLAST && yycheck[yystate] == *yyssp) | 
|  | yystate = yytable[yystate]; | 
|  | else | 
|  | yystate = yydefgoto[yyn - YYNTOKENS]; | 
|  |  | 
|  | goto yynewstate; | 
|  |  | 
|  |  | 
|  | /*------------------------------------. | 
|  | | yyerrlab -- here on detecting error | | 
|  | `------------------------------------*/ | 
|  | yyerrlab: | 
|  | /* If not already recovering from an error, report this error.  */ | 
|  | if (!yyerrstatus) | 
|  | { | 
|  | ++yynerrs; | 
|  | #if YYERROR_VERBOSE | 
|  | yyn = yypact[yystate]; | 
|  |  | 
|  | if (YYPACT_NINF < yyn && yyn < YYLAST) | 
|  | { | 
|  | int yytype = YYTRANSLATE (yychar); | 
|  | YYSIZE_T yysize0 = yytnamerr (0, yytname[yytype]); | 
|  | YYSIZE_T yysize = yysize0; | 
|  | YYSIZE_T yysize1; | 
|  | int yysize_overflow = 0; | 
|  | char *yymsg = 0; | 
|  | #	  define YYERROR_VERBOSE_ARGS_MAXIMUM 5 | 
|  | char const *yyarg[YYERROR_VERBOSE_ARGS_MAXIMUM]; | 
|  | int yyx; | 
|  |  | 
|  | #if 0 | 
|  | /* This is so xgettext sees the translatable formats that are | 
|  | constructed on the fly.  */ | 
|  | YY_("syntax error, unexpected %s"); | 
|  | YY_("syntax error, unexpected %s, expecting %s"); | 
|  | YY_("syntax error, unexpected %s, expecting %s or %s"); | 
|  | YY_("syntax error, unexpected %s, expecting %s or %s or %s"); | 
|  | YY_("syntax error, unexpected %s, expecting %s or %s or %s or %s"); | 
|  | #endif | 
|  | char *yyfmt; | 
|  | char const *yyf; | 
|  | static char const yyunexpected[] = "syntax error, unexpected %s"; | 
|  | static char const yyexpecting[] = ", expecting %s"; | 
|  | static char const yyor[] = " or %s"; | 
|  | char yyformat[sizeof yyunexpected | 
|  | + sizeof yyexpecting - 1 | 
|  | + ((YYERROR_VERBOSE_ARGS_MAXIMUM - 2) | 
|  | * (sizeof yyor - 1))]; | 
|  | char const *yyprefix = yyexpecting; | 
|  |  | 
|  | /* Start YYX at -YYN if negative to avoid negative indexes in | 
|  | YYCHECK.  */ | 
|  | int yyxbegin = yyn < 0 ? -yyn : 0; | 
|  |  | 
|  | /* Stay within bounds of both yycheck and yytname.  */ | 
|  | int yychecklim = YYLAST - yyn; | 
|  | int yyxend = yychecklim < YYNTOKENS ? yychecklim : YYNTOKENS; | 
|  | int yycount = 1; | 
|  |  | 
|  | yyarg[0] = yytname[yytype]; | 
|  | yyfmt = yystpcpy (yyformat, yyunexpected); | 
|  |  | 
|  | for (yyx = yyxbegin; yyx < yyxend; ++yyx) | 
|  | if (yycheck[yyx + yyn] == yyx && yyx != YYTERROR) | 
|  | { | 
|  | if (yycount == YYERROR_VERBOSE_ARGS_MAXIMUM) | 
|  | { | 
|  | yycount = 1; | 
|  | yysize = yysize0; | 
|  | yyformat[sizeof yyunexpected - 1] = '\0'; | 
|  | break; | 
|  | } | 
|  | yyarg[yycount++] = yytname[yyx]; | 
|  | yysize1 = yysize + yytnamerr (0, yytname[yyx]); | 
|  | yysize_overflow |= yysize1 < yysize; | 
|  | yysize = yysize1; | 
|  | yyfmt = yystpcpy (yyfmt, yyprefix); | 
|  | yyprefix = yyor; | 
|  | } | 
|  |  | 
|  | yyf = YY_(yyformat); | 
|  | yysize1 = yysize + yystrlen (yyf); | 
|  | yysize_overflow |= yysize1 < yysize; | 
|  | yysize = yysize1; | 
|  |  | 
|  | if (!yysize_overflow && yysize <= YYSTACK_ALLOC_MAXIMUM) | 
|  | yymsg = (char *) YYSTACK_ALLOC (yysize); | 
|  | if (yymsg) | 
|  | { | 
|  | /* Avoid sprintf, as that infringes on the user's name space. | 
|  | Don't have undefined behavior even if the translation | 
|  | produced a string with the wrong number of "%s"s.  */ | 
|  | char *yyp = yymsg; | 
|  | int yyi = 0; | 
|  | while ((*yyp = *yyf)) | 
|  | { | 
|  | if (*yyp == '%' && yyf[1] == 's' && yyi < yycount) | 
|  | { | 
|  | yyp += yytnamerr (yyp, yyarg[yyi++]); | 
|  | yyf += 2; | 
|  | } | 
|  | else | 
|  | { | 
|  | yyp++; | 
|  | yyf++; | 
|  | } | 
|  | } | 
|  | yyerror (yymsg); | 
|  | YYSTACK_FREE (yymsg); | 
|  | } | 
|  | else | 
|  | { | 
|  | yyerror (YY_("syntax error")); | 
|  | goto yyexhaustedlab; | 
|  | } | 
|  | } | 
|  | else | 
|  | #endif /* YYERROR_VERBOSE */ | 
|  | yyerror (YY_("syntax error")); | 
|  | } | 
|  |  | 
|  |  | 
|  |  | 
|  | if (yyerrstatus == 3) | 
|  | { | 
|  | /* If just tried and failed to reuse look-ahead token after an | 
|  | error, discard it.  */ | 
|  |  | 
|  | if (yychar <= YYEOF) | 
|  | { | 
|  | /* Return failure if at end of input.  */ | 
|  | if (yychar == YYEOF) | 
|  | YYABORT; | 
|  | } | 
|  | else | 
|  | { | 
|  | yydestruct ("Error: discarding", yytoken, &yylval); | 
|  | yychar = YYEMPTY; | 
|  | } | 
|  | } | 
|  |  | 
|  | /* Else will try to reuse look-ahead token after shifting the error | 
|  | token.  */ | 
|  | goto yyerrlab1; | 
|  |  | 
|  |  | 
|  | /*---------------------------------------------------. | 
|  | | yyerrorlab -- error raised explicitly by YYERROR.  | | 
|  | `---------------------------------------------------*/ | 
|  | yyerrorlab: | 
|  |  | 
|  | /* Pacify compilers like GCC when the user code never invokes | 
|  | YYERROR and the label yyerrorlab therefore never appears in user | 
|  | code.  */ | 
|  | if (0) | 
|  | goto yyerrorlab; | 
|  |  | 
|  | yyvsp -= yylen; | 
|  | yyssp -= yylen; | 
|  | yystate = *yyssp; | 
|  | goto yyerrlab1; | 
|  |  | 
|  |  | 
|  | /*-------------------------------------------------------------. | 
|  | | yyerrlab1 -- common code for both syntax error and YYERROR.  | | 
|  | `-------------------------------------------------------------*/ | 
|  | yyerrlab1: | 
|  | yyerrstatus = 3;	/* Each real token shifted decrements this.  */ | 
|  |  | 
|  | for (;;) | 
|  | { | 
|  | yyn = yypact[yystate]; | 
|  | if (yyn != YYPACT_NINF) | 
|  | { | 
|  | yyn += YYTERROR; | 
|  | if (0 <= yyn && yyn <= YYLAST && yycheck[yyn] == YYTERROR) | 
|  | { | 
|  | yyn = yytable[yyn]; | 
|  | if (0 < yyn) | 
|  | break; | 
|  | } | 
|  | } | 
|  |  | 
|  | /* Pop the current state because it cannot handle the error token.  */ | 
|  | if (yyssp == yyss) | 
|  | YYABORT; | 
|  |  | 
|  |  | 
|  | yydestruct ("Error: popping", yystos[yystate], yyvsp); | 
|  | YYPOPSTACK; | 
|  | yystate = *yyssp; | 
|  | YY_STACK_PRINT (yyss, yyssp); | 
|  | } | 
|  |  | 
|  | if (yyn == YYFINAL) | 
|  | YYACCEPT; | 
|  |  | 
|  | *++yyvsp = yylval; | 
|  |  | 
|  |  | 
|  | /* Shift the error token. */ | 
|  | YY_SYMBOL_PRINT ("Shifting", yystos[yyn], yyvsp, yylsp); | 
|  |  | 
|  | yystate = yyn; | 
|  | goto yynewstate; | 
|  |  | 
|  |  | 
|  | /*-------------------------------------. | 
|  | | yyacceptlab -- YYACCEPT comes here.  | | 
|  | `-------------------------------------*/ | 
|  | yyacceptlab: | 
|  | yyresult = 0; | 
|  | goto yyreturn; | 
|  |  | 
|  | /*-----------------------------------. | 
|  | | yyabortlab -- YYABORT comes here.  | | 
|  | `-----------------------------------*/ | 
|  | yyabortlab: | 
|  | yyresult = 1; | 
|  | goto yyreturn; | 
|  |  | 
|  | #ifndef yyoverflow | 
|  | /*-------------------------------------------------. | 
|  | | yyexhaustedlab -- memory exhaustion comes here.  | | 
|  | `-------------------------------------------------*/ | 
|  | yyexhaustedlab: | 
|  | yyerror (YY_("memory exhausted")); | 
|  | yyresult = 2; | 
|  | /* Fall through.  */ | 
|  | #endif | 
|  |  | 
|  | yyreturn: | 
|  | if (yychar != YYEOF && yychar != YYEMPTY) | 
|  | yydestruct ("Cleanup: discarding lookahead", | 
|  | yytoken, &yylval); | 
|  | while (yyssp != yyss) | 
|  | { | 
|  | yydestruct ("Cleanup: popping", | 
|  | yystos[*yyssp], yyvsp); | 
|  | YYPOPSTACK; | 
|  | } | 
|  | #ifndef yyoverflow | 
|  | if (yyss != yyssa) | 
|  | YYSTACK_FREE (yyss); | 
|  | #endif | 
|  | return yyresult; | 
|  | } | 
|  |  | 
|  |  | 
|  | #line 2818 "/proj/llvm/llvm-3/lib/AsmParser/llvmAsmParser.y" | 
|  |  | 
|  |  | 
|  | // common code from the two 'RunVMAsmParser' functions | 
|  | static Module* RunParser(Module * M) { | 
|  |  | 
|  | llvmAsmlineno = 1;      // Reset the current line number... | 
|  | CurModule.CurrentModule = M; | 
|  | #if YYDEBUG | 
|  | yydebug = Debug; | 
|  | #endif | 
|  |  | 
|  | // Check to make sure the parser succeeded | 
|  | if (yyparse()) { | 
|  | if (ParserResult) | 
|  | delete ParserResult; | 
|  | return 0; | 
|  | } | 
|  |  | 
|  | // Check to make sure that parsing produced a result | 
|  | if (!ParserResult) | 
|  | return 0; | 
|  |  | 
|  | // Reset ParserResult variable while saving its value for the result. | 
|  | Module *Result = ParserResult; | 
|  | ParserResult = 0; | 
|  |  | 
|  | return Result; | 
|  | } | 
|  |  | 
|  | void llvm::GenerateError(const std::string &message, int LineNo) { | 
|  | if (LineNo == -1) LineNo = llvmAsmlineno; | 
|  | // TODO: column number in exception | 
|  | if (TheParseError) | 
|  | TheParseError->setError(CurFilename, message, LineNo); | 
|  | TriggerError = 1; | 
|  | } | 
|  |  | 
|  | int yyerror(const char *ErrorMsg) { | 
|  | std::string where | 
|  | = std::string((CurFilename == "-") ? std::string("<stdin>") : CurFilename) | 
|  | + ":" + utostr((unsigned) llvmAsmlineno) + ": "; | 
|  | std::string errMsg = std::string(ErrorMsg) + "\n" + where + " while reading "; | 
|  | if (yychar == YYEMPTY || yychar == 0) | 
|  | errMsg += "end-of-file."; | 
|  | else | 
|  | errMsg += "token: '" + std::string(llvmAsmtext, llvmAsmleng) + "'"; | 
|  | GenerateError(errMsg); | 
|  | return 0; | 
|  | } | 
|  |  |