LATEX-L Archives

Mailing list for the LaTeX3 project

LATEX-L@LISTSERV.UNI-HEIDELBERG.DE

Options: Use Classic View

Use Proportional Font
Show HTML Part by Default
Condense Mail Headers

Topic: [<< First] [< Prev] [Next >] [Last >>]

Print Reply
Sender: Mailing list for the LaTeX3 project <[log in to unmask]>
Date: Wed, 19 Feb 2020 12:27:31 +0100
Reply-To: Mailing list for the LaTeX3 project <[log in to unmask]>
Message-ID: <[log in to unmask]>
MIME-Version: 1.0
Content-Transfer-Encoding: 7bit
In-Reply-To: <20200219092511.GG10540@thinkarch>
Content-Type: text/plain; charset=utf-8
From: Bruno Le Floch <[log in to unmask]>
Parts/Attachments: text/plain (27 lines)
On 2/19/20 10:25 AM, Jonathan Spratte wrote:
> Hi,
> 
>> - Defining an environment that sets up active characters to emulate
>>   traditional BNF syntax is very concise, but comes at the cost of
>>   delimited arguments and catcode madness.
> 
> You could as well use a letter-by-letter parser that doesn't need altered
> category codes. Take a look at the pgf module `parser`. That's not `expl3`
> but could give you an idea on what's possible.
> 
> Best,
> Jonathan
> 

I've been *toying* for a long time (haven't gone very far) with the idea
of writing a parser generator, but I couldn't decide how powerful to
make it.  One option would be to support "parsing expression grammars"
(PEGs), which can be parsed in linear time using a packrat parser (but
use a lot of memory, possibly problematic).  Another option would be to
stick with more traditional things like LL or LR parser.  To be honest,
I don't know enough about parsers and what useful languages they cover
to decide.  Thoughts welcome.

Best,
Bruno

ATOM RSS1 RSS2