diff options
Diffstat (limited to 'lib/AsmParser/llvmAsmParser.y.cvs')
| -rw-r--r-- | lib/AsmParser/llvmAsmParser.y.cvs | 16 | 
1 files changed, 13 insertions, 3 deletions
| diff --git a/lib/AsmParser/llvmAsmParser.y.cvs b/lib/AsmParser/llvmAsmParser.y.cvs index 16204cc..57b6f81 100644 --- a/lib/AsmParser/llvmAsmParser.y.cvs +++ b/lib/AsmParser/llvmAsmParser.y.cvs @@ -1046,7 +1046,7 @@ Module *llvm::RunVMAsmParser(llvm::MemoryBuffer *MB) {  %token<StrVal> STRINGCONSTANT ATSTRINGCONSTANT PCTSTRINGCONSTANT  %type <StrVal> LocalName OptLocalName OptLocalAssign  %type <StrVal> GlobalName OptGlobalAssign GlobalAssign -%type <StrVal> OptSection SectionString +%type <StrVal> OptSection SectionString OptGC  %type <UIntVal> OptAlign OptCAlign @@ -1090,7 +1090,7 @@ Module *llvm::RunVMAsmParser(llvm::MemoryBuffer *MB) {  // Function Attributes  %token SIGNEXT ZEROEXT NORETURN INREG SRET NOUNWIND NOALIAS BYVAL NEST -%token READNONE READONLY +%token READNONE READONLY GC  // Visibility Styles  %token DEFAULT HIDDEN PROTECTED @@ -1244,6 +1244,12 @@ OptFuncAttrs  : /* empty */ { $$ = ParamAttr::None; }                }                ; +OptGC         : /* empty */ { $$ = 0; } +              | GC STRINGCONSTANT { +                $$ = $2; +              } +              ; +  // OptAlign/OptCAlign - An optional alignment, and an optional alignment with  // a comma before it.  OptAlign : /*empty*/        { $$ = 0; } | @@ -2225,7 +2231,7 @@ ArgList : ArgListH {    };  FunctionHeaderH : OptCallingConv ResultTypes GlobalName '(' ArgList ')'  -                  OptFuncAttrs OptSection OptAlign { +                  OptFuncAttrs OptSection OptAlign OptGC {    std::string FunctionName(*$3);    delete $3;  // Free strdup'd memory! @@ -2328,6 +2334,10 @@ FunctionHeaderH : OptCallingConv ResultTypes GlobalName '(' ArgList ')'      Fn->setSection(*$8);      delete $8;    } +  if ($10) { +    Fn->setCollector($10->c_str()); +    delete $10; +  }    // Add all of the arguments we parsed to the function...    if ($5) {                     // Is null if empty... | 
