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

In reply to Re: Perl not BNF-able?? by jonadab
in thread Perl not BNF-able?? by anonymized user 468275

Title:
Use:  <p> text here (a paragraph) </p>
and:  <code> code here </code>
to format your post, it's "PerlMonks-approved HTML":



  • Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
  • Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
  • Read Where should I post X? if you're not absolutely sure you're posting in the right place.
  • Please read these before you post! —
  • Posts may use any of the Perl Monks Approved HTML tags:
    a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, details, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
  • You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
            For:     Use:
    & &amp;
    < &lt;
    > &gt;
    [ &#91;
    ] &#93;
  • Link using PerlMonks shortcuts! What shortcuts can I use for linking?
  • See Writeup Formatting Tips and other pages linked from there for more info.