X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Flexer.ll;h=b444704ea5890bd5b26d26d335a66a4c6a55baa2;hb=23093de8c16965c17ef06ada9949cfaa14933dff;hp=9ce0da012d5faf14f5eff0fc00beb63e5cd3d6fd;hpb=711cf44d0ab28f3159230c84d63c0b19199408b0;p=lilypond.git diff --git a/lily/lexer.ll b/lily/lexer.ll index 9ce0da012d..b444704ea5 100644 --- a/lily/lexer.ll +++ b/lily/lexer.ll @@ -4,7 +4,7 @@ source file of the LilyPond music typesetter - (c) 1996--2006 Han-Wen Nienhuys + (c) 1996--2007 Han-Wen Nienhuys Jan Nieuwenhuizen */ @@ -62,6 +62,7 @@ void strip_trailing_white (string&); void strip_leading_white (string&); string lyric_fudge (string s); SCM lookup_markup_command (string s); +SCM lookup_markup_list_command (string s); bool is_valid_version (string s); @@ -170,7 +171,9 @@ BOM_UTF8 \357\273\277 return type; } -{BOM_UTF8} { + /* Use the trailing context feature. Otherwise, the BOM will not be + found if the file starts with an identifier definition. */ +{BOM_UTF8}/.* { if (this->lexloc->line_number () != 1 || this->lexloc->column_number () != 0) { LexerError (_ ("stray UTF-8 BOM encountered").c_str ()); @@ -516,7 +519,7 @@ BOM_UTF8 \357\273\277 {MARKUPCOMMAND} { string str (YYText () + 1); SCM s = lookup_markup_command (str); - + SCM s2 = lookup_markup_list_command (str); if (scm_is_pair (s) && scm_is_symbol (scm_cdr (s)) ) { yylval.scm = scm_car(s); SCM tag = scm_cdr(s); @@ -536,6 +539,8 @@ BOM_UTF8 \357\273\277 return MARKUP_HEAD_SCM0_MARKUP1; else if (tag == ly_symbol2scm ("scheme0-scheme1-markup2")) return MARKUP_HEAD_SCM0_SCM1_MARKUP2; + else if (tag == ly_symbol2scm ("scheme0-markup1-markup2")) + return MARKUP_HEAD_SCM0_MARKUP1_MARKUP2; else if (tag == ly_symbol2scm ("scheme0-scheme1-scheme2")) return MARKUP_HEAD_SCM0_SCM1_SCM2; else { @@ -543,6 +548,24 @@ BOM_UTF8 \357\273\277 ly_display_scm (s); assert(false); } + } else if (scm_is_pair (s2) && scm_is_symbol (scm_cdr (s2))) { + yylval.scm = scm_car(s2); + SCM tag = scm_cdr(s2); + if (tag == ly_symbol2scm("empty")) + return MARKUP_LIST_HEAD_EMPTY; + else if (tag == ly_symbol2scm ("scheme0")) + return MARKUP_LIST_HEAD_SCM0; + else if (tag == ly_symbol2scm ("markup-list0")) + return MARKUP_LIST_HEAD_LIST0; + else if (tag == ly_symbol2scm ("scheme0-markup-list1")) + return MARKUP_LIST_HEAD_SCM0_LIST1; + else if (tag == ly_symbol2scm ("scheme0-scheme1-markup-list2")) + return MARKUP_LIST_HEAD_SCM0_SCM1_LIST2; + else { + programming_error ("no parser tag defined for this markup list signature"); + ly_display_scm (s); + assert(false); + } } else return scan_escaped_word (str); } @@ -944,6 +967,13 @@ lookup_markup_command (string s) return scm_call_1 (proc, ly_string2scm (s)); } +SCM +lookup_markup_list_command (string s) +{ + SCM proc = ly_lily_module_constant ("lookup-markup-list-command"); + return scm_call_1 (proc, ly_string2scm (s)); +} + /* Shut up lexer warnings. */ #if YY_STACK_USED