Groups | Search | Server Info | Keyboard shortcuts | Login | Register [http] [https] [nntp] [nntps]
Groups > comp.compilers > #2768 > unrolled thread
| Started by | Fernando <pronesto@gmail.com> |
|---|---|
| First post | 2021-12-27 03:56 -0800 |
| Last post | 2021-12-27 03:56 -0800 |
| Articles | 1 — 1 participant |
Back to article view | Back to comp.compilers
This discussion starts older than the indexed window; earlier articles aren't shown. The article labeled Started by
below is the oldest one visible, not the original post.
Re: Why are ambiguous grammars usually a bad idea? Why are languages usually defined and implemented with ambiguous grammars? Fernando <pronesto@gmail.com> - 2021-12-27 03:56 -0800
| From | Fernando <pronesto@gmail.com> |
|---|---|
| Date | 2021-12-27 03:56 -0800 |
| Subject | Re: Why are ambiguous grammars usually a bad idea? Why are languages usually defined and implemented with ambiguous grammars? |
| Message-ID | <21-12-006@comp.compilers> |
Hi Roger,
One problem with ambiguous grammars is that ambiguities might confuse the
semantics of the programming language. One example is with the associativity
and precedence of operators. Concerning associativity, the ambiguous grammar
below does not specify if subtraction is left or right associative:
E ::= E - E | num
And, there is this classic example from C-like languages involving conditional
statements:
<cmd> ::= if <bool_expr> then <cmd>
| if <bool_expr> then <cmd> else <cmd>
What would be the meaning of a statement like the one below? Depending on how
you fix the ambiguity, it's possible to make the else refer to the innermost
or the outermost conditional.
if (a > b) then if (c > d) then print(1) else print(2)
Regards,
Fernando
Back to top | Article view | comp.compilers
csiph-web