Fix a parser bug on labeled inline asm stmts, allowing us

to parse stuff like:

asm volatile("1:  rex64/fxrstor (%[fx])\n\t"
       "2:\n"
       ".section .fixup,\"ax\"\n"
       "3:  movl $-1,%[err]\n"
       "    jmp  2b\n"
       ".previous\n"
       ".section __ex_table,\"a\"\n"
       "   .align 8\n"
       "   .quad  1b,3b\n"
       ".previous"
       : [err] "=r" (err)
       : [fx] "cdaSDb" (fx), "m" (*fx), "0" (0));

This reduces # diagnostics on PR1750 from 49 to 37.




git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@43434 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Chris Lattner 2007-10-29 04:06:22 +00:00
Родитель fe79595619
Коммит 69efba74cf
1 изменённых файлов: 4 добавлений и 0 удалений

Просмотреть файл

@ -985,6 +985,10 @@ void Parser::ParseAsmOperandsOpt() {
SkipUntil(tok::r_paren);
return;
}
// Eat the identifier, FIXME: capture it.
ConsumeToken();
MatchRHSPunctuation(tok::r_square, Loc);
}