in reply to Re^4: I wrote an expression parser for PPI
in thread I wrote an expression parser for PPI

I'm not sure how or if PPI handles prototyped subs.

But I bet you need to take care in your project to handle them manually when they are exported. PPI as static parser might not attempt to recognize try {} beeing exported by use Try::Tiny ...

Good luck with that.

Cheers Rolf
(addicted to the Perl Programming Language :)
see Wikisyntax for the Monastery

Replies are listed 'Best First'.
Re^6: I wrote an expression parser for PPI
by BerntB (Deacon) on Jan 09, 2026 at 07:15 UTC
    Yep, PPI worked. Prototypes are half done. The definitions of constants and prototypes are collected and sent in as a parameter to the expression parser.(When e.g. parsing lists, you of course need to know if a sub is declared to use n parameters.)
      > Yep, PPI worked

      Not sure if you got my point.

      PPI is a static parser, this (should?) mean if it sees at "compile" time something like ...

      • use Try::Tiny;
      • it won't try to search @INC
      • to require the first .../Try/Tiny.pm
      • run Try::Tiny->import()
      • "export" try (&) {...} (among others)
      • with an accurate prototype

      to keep on parsing correctly if it encounters a try {...}

      I haven't tested this, but I bet you will need to patch PPI to handle this.°

      At least if you want to construct a decent Perl dialect and not just some interesting demos.

      I say dialect because it's very hard to achieve full compatibility.

      OTOH once your parser and compiler really work, you can try to transpile it into your target languages to bootstrap a stand-alone dialect which is consistent in all those languages.

      At least in theory...

      Cheers Rolf
      (addicted to the Perl Programming Language :)
      see Wikisyntax for the Monastery

      updates

      °) There is a whole bunch of more things happening at compile-time...

        Sorry, I was unclear. Yes, the use dependencies are loaded and prototypes (like in Try::Tiny) etc are extracted.

        I had a problem with this by the way, and realized why Perl don't cache its byte code. I wanted to do a cache of compiled code, with key from the hash of the file content. But it just seems too fragile. You would need a cache of used files (so they could be loaded) and everything would need a recompile if a file further down in the stack was changed. I put on the todo to compile a program with dependencies to a standalone code file, instead.

        Edit: If you tell me that Try::Tiny works with require, then I am totally wrong. :-) That should only work with use right? (I had to read the code, there was some claim that it was slow so I never Try:ed.)