LATEX-L Archives

Mailing list for the LaTeX3 project

LATEX-L@LISTSERV.UNI-HEIDELBERG.DE

Options: Use Classic View

Use Monospaced Font
Show Text 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: Mon, 10 Oct 2011 23:40:29 +0200
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: 8bit
In-Reply-To: <[log in to unmask]>
Content-Type: text/plain; charset=ISO-8859-1; format=flowed
From: Lars Hellström <[log in to unmask]>
Parts/Attachments: text/plain (52 lines)
Bruno Le Floch skrev 2011-10-10 17.07:
> Hello all,
>
> We just added on CTAN two related modules:

Did you by any chance mean SVN rather than CTAN? (Or maybe there is a delay 
in changes becoming visible.)

[snip]
> The l3regex module allows for testing if a string matches a given
> regular expression, counting matches, extracting submatches, splitting
> at occurrences of a regular expression,

Sometimes one goes the other way, and returns all matches of a string. I 
wouldn't go so far as saying that this is more useful than splitting at 
things that match, however.

>and doing replacement (see
> documentation for function names).
>
> Speed requirements forbid a back-tracking approach, hence
> back-references cannot be supported. Only "truly regular" features are
> implemented.

Having browsed the code now, I see that you execute the automaton in general 
NFA form. Have you considered executing it in epsilon-free NFA form instead? 
Getting rid of epsilons does not increase the number of states (it can even 
reduce the number of reachable states), but I'm not sure how it would 
interact with match path priority...

[snip]
> - Newlines. Currently, "." matches every character; in perl and PCRE
> it should not match new lines. As you know, the situation with new
> lines in TeX is a little bit odd, since they are converted to the
> \endlinechar upon reading, and normally not tokenized, simply giving
> rise to a space or a \par. Should we still decide that "." does not
> match the CR nor LF characters? Or should it simply no match the
> \endlinechar?

The way I'm used to regexps, you can control using "metasyntax" whether . 
matches newline or not, and likewise how ^ behaves with respect to 
beginning-of-line, so I wouldn't find it wrong if ^ and \A are synonyms.

> - Same question for caseless matching, and for look-ahead/look-behind
> assertions.

Can you even do assertions without exploding the number of states? (Whenever 
I've thought about it, I tend to end up with the conclusion that one cannot, 
but I might be missing something.)

Lars Hellström

ATOM RSS1 RSS2