Beefy Boxes and Bandwidth Generously Provided by pair Networks
Syntactic Confectionery Delight
 
PerlMonks  

Re: Perl not BNF-able??

by jonadab (Parson)
on Jul 01, 2005 at 10:00 UTC ( [id://471632]=note: print w/replies, xml ) Need Help??


in reply to Perl not BNF-able??

Anyone know what aspects of perl should make it impossible to define it in BNF?

Perl's grammar is overall just too general for BNF. I don't think there's an exhaustive list of all the linguistic features in Perl that make it too general for BNF, but I can tell you that it's not just a couple of things, syntactically. If there's one overall general thing to blame, it's context. To parse Perl, you have to keep track of what context any given bit of code that you're parsing is in. A given syntactic construct can have a different semantic meaning (and possibly different syntactic implications for the surrounding code) if it is encountered in a different context. BNF doesn't deal well with that.

FWIW, many overly simplistic syntax highlighting engines can't handle Perl, either, for roughly the same reason: Perl is very expressive, and therefore very complicated to parse. Not as complicated (or as expressive) as, say, English, but complicated nonetheless.


"In adjectives, with the addition of inflectional endings, a changeable long vowel (Qamets or Tsere) in an open, propretonic syllable will reduce to Vocal Shewa. This type of change occurs when the open, pretonic syllable of the masculine singular adjective becomes propretonic with the addition of inflectional endings."  — Pratico & Van Pelt, BBHG, p68

Log In?
Username:
Password:

What's my password?
Create A New User
Domain Nodelet?
Node Status?
node history
Node Type: note [id://471632]
help
Chatterbox?
and the web crawler heard nothing...

How do I use this?Last hourOther CB clients
Other Users?
Others chilling in the Monastery: (2)
As of 2024-04-26 06:30 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?

    No recent polls found