[Date Prev]
| [Thread Prev]
| [Thread Next]
| [Date Next]
--
[Date Index]
| [Thread Index]
Re: [xml-dev] The remarkable similarities between XSLT and Flex/Lex
- From: Michael Kay <mike@saxonica.com>
- To: Roger L Costello <costello@mitre.org>
- Date: Fri, 24 Jun 2022 11:56:56 +0100
The first rule-based language I encountered based on the pattern-action paradigm was SNOBOL, back in the early 70s. One of the most popular was (and is) awk. I'm sure that the people who devised DSSSL and subsequently XSLT will have been aware of this language tradition.
Michael Kay
Saxonica
> On 24 Jun 2022, at 11:46, Roger L Costello <costello@mitre.org> wrote:
>
> Hi Folks,
>
> Flex and Lex are tools to auto-generate lexical analyzers. Flex is a successor to Lex. Lex was created 47 years ago. Flex was created about the same time as XSLT.
>
> There is a remarkable similarity between Flex/Lex and XSLT. One wonders if some members of the XSLT 1.0 Working Group were Lex users and were influenced by its concepts?
>
> Here are some of the similarities between Flex/Lex and XSLT:
>
> - Both are pattern-matching languages, i.e.,
>
> pattern action
> pattern action
> pattern action
>
> - Both allow you to create subsets:
>
> - The XSLT "mode" allows the program to effectively be broken into a set of mini XSLT programs
> - The Flex/Lex "start condition" allows the lexer to effectively be broken into a set of mini lexers
>
> - Both have a default rule that is executed when no other rule matches
>
> There are some differences, of course:
>
> - XSLT is primarily for processing XML but it can process plain text, whereas Flex/Lex is primarily for processing plain text (esp. source code) but it can process XML
>
> - XSLT uses XPath as its pattern-matching language, whereas Flex/Lex uses regular expressions as its pattern-matching language
>
> Pretty interesting, I think!
>
> /Roger
>
> _______________________________________________________________________
>
> XML-DEV is a publicly archived, unmoderated list hosted by OASIS
> to support XML implementation and development. To minimize
> spam in the archives, you must subscribe before posting.
>
> [Un]Subscribe/change address: http://www.oasis-open.org/mlmanage/
> Or unsubscribe: xml-dev-unsubscribe@lists.xml.org
> subscribe: xml-dev-subscribe@lists.xml.org
> List archive: http://lists.xml.org/archives/xml-dev/
> List Guidelines: http://www.oasis-open.org/maillists/guidelines.php
>
[Date Prev]
| [Thread Prev]
| [Thread Next]
| [Date Next]
--
[Date Index]
| [Thread Index]