Lex and initial start conditions
Randal Schwartz
merlyn at iwarp.intel.com
Fri Jun 1 02:18:00 AEST 1990
In article <116 at bohra.cpg.oz>, ejp at bohra (Esmond Pitt) writes:
| There are two even simpler ways.
|
| Instead of effectively changing the initial condition to <Text>, either:
|
| 1. Ensure each start-state is equipped with enough rules to handle any
| possible input, and, as the documentation does state, place all the
| unlabelled rules after all the labelled rules, and/or
|
| 2. Label all the rules you only want applied in the INITAL state with
| <INITIAL>, so they won't be applied as defaults in other states.
|
| Placing non-labelled rules before labelled rules is probably the single
| most common error in writing LEX scripts, even after 15 years.
|
| I don't know why.
Because it is insufficient. It's not "first match", but "longest
match" that determines rule triggering. ("first match" applies when
the rules have the same length.)
...
<FOO>a { something; }
...
ab { something_else; }
...
will match the "something_else" clause if "ab" is seen, even in state
"FOO". I know... this bit me once.
Just another lex hacker,
--
/=Randal L. Schwartz, Stonehenge Consulting Services (503)777-0095 ==========\
| on contract to Intel's iWarp project, Beaverton, Oregon, USA, Sol III |
| merlyn at iwarp.intel.com ...!any-MX-mailer-like-uunet!iwarp.intel.com!merlyn |
\=Cute Quote: "Welcome to Portland, Oregon, home of the California Raisins!"=/
More information about the Comp.lang.c
mailing list