Archive

Posts Tagged ‘grammar’

GLR parsing is the future

August 27th, 2009 Derek-Jones No comments

Traditionally parser generators have required that their input grammar be LALR(1) or some close variant (I would include LL(1) in this set). Back when 64k was an unimaginably large amount of memory being able to squeeze parser tables in a few kilobytes was very important; people received PhDs on parser table compression.

There is still a market for compact, fast parsers. Formal language grammars abound in communication protocols and vendors of communications hardware are very interested in keeping down costs by using minimizing the storage needed by their devices.

The trouble with LALR(1) is that value 1. It means that the parser only looks ahead one token in the input stream. This often means that a grammar is flagged as being ambiguous (i.e., it contains shift/reduce or reduce/reduce conflicts) when it is actually just locally ambiguous, i.e., reading tokens further head on the input stream would provide sufficient context to unambiguously specify the appropriate grammar production.

Restructuring a grammar to make it LALR(1) requires a lot of thought and skill and inexperienced users often give up. I once spent a month trying to remove the conflicts in the SQL/2 grammar specified by the SQL ISO standard; I managed to get the number down from over 1,000 to a small number that I decided I could live with.

It has taken a long time for parser generators to break out of the 64k mentality, but over the last few years it has started to happen. There have been two main approaches: 1) LR(n) provides a mechanism to look further ahead than one token, ie, n tokens, and 2) GLR parsing.

I think that GLR parsing is the future for two reasons:

  • It is supported by the most widely used parser generator, bison.
  • It enables working parsers to be created with much less thought and effort than a LALR(1) parser. (I don’t know how it compares against LR(n)).

GLR parsers resolve any language ambiguities by effectively delaying decisions until runtime in the hope that reading enough tokens will resolve local ambiguities. If an ambiguity in the token stream cannot be resolved a runtime error occurs (this is the one big downside of a GLR parser, the parser generated by a LALR(1) parser generator may produce lots of build time warnings but never produces errors when the parser is executed).

One example of a truly ambiguous construct (discussed here a while ago) is:

x * y;

which in C/C++ could be a declaration of y to be a pointer to x, or an expression that multiplies x and y.

Tools that can detect these global ambiguities in a grammar are starting to appear, e.g., DTWA is a bison extension.

I reviewed an early draft of the new O’Reilly book “flex & bison” and tried to get the author to be more upbeat on GLR support in bison; I think I got him to be a bit less cautious.

Finding the ‘minimum’ faulty program

March 17th, 2009 Derek-Jones No comments

A few weeks ago I received an inquiry about running a course/workshop on compiler writing. This does not does not happen very often and it reminded me that many years ago the ACCU asked if I would run a mentored group on compiler writing, I was busy writing a book at the time. The inquiry got me thinking it would be fun to run a compiler writing mentored group over a 6-9 month period and I emailed the general ACCU reflector asking if anybody was interested in joining such a group (any reader wanting to join the group has to be a member of the ACCU).

Over the weekend I had a brainwave for a project, automatic compiler test generation coupled with a program source code minimizer (I need a better name for this bit). Automatic test generation sounds great in theory but in practice whittling down the source code of those programs that result in a fault being exhibited, to create a usable sized test case that is practical for debugging purposes can be a major effort. What is needed is a tool to automatically do the whittling, i.e., a test case minimizer.

A simple algorithm for whittling down the source of a large test program is to continually throw away that half/third/quarter of the code that is not needed for the fault to manifest itself. A compiler project that took as input source code, removed half/third/quarter of the code and generated output that could be compiled and executed is realistic. The input/reduce/output process could be repeated until the generated source was considered to have reached some minima. Ok, this will soak up some cpu time, but computers are cheap and people are expensive.

Where does the test source code come from? Easy, it is generated from the same yacc grammar that the compiler, written by the mentored group member, uses to parse its input. Fortunately such a generation tool is available and ready to use.

The beauty is using the same grammar to generate tests and parse input. This means there is no need to worry about which language subset to use initially and support for additional language syntax can be added incrementally.

Experience shows that automatically generated test programs quickly uncover faults in production compilers, even when working with language subsets. Compiler implementors are loath to spend time cutting down a large program to find the statement/expression where the fault lies, this project will produce a tool that does the job for them.

So to recap, the mentored group is going to write one or more automatic source code generators that will be used to stress test compilers written by other people (e.g., gcc and Microsoft). Group members will also write their own compiler that reads in this automatically generated source code, throws some of it away and writes out syntactically/semantically correct source code. Various scripts will be be written to glue this all together.

Group members can pick the language they want to work with. The initial subset could just include supports for integer types, if-statements and binary operators.

If you had trouble making any sense all this, don’t join the group.

www.wenn.com
FireStats icon Powered by FireStatswww.tinynibbles.com cialis pharmacy

best price propecia

online pharmacy propecia renova

mail order levitra

buy viagra china

order viagra or levitra

cheap levitra prescription

generic levitra vardenafil

best price for propecia

cialis headaches

cialis 100 mg

lowest priced propecia

generic cialis next day shipping

cheap prescription propecia

canadian online pharmacy cialis

canada online pharmacy propecia

cialis en mexico

discount levitra purchase

discount propecia online

cialis woman

best price cialis

50 mg cialis

mail order propecia

fda levitra

cialis strenght mg

cheapest viagra usa

internet pharmacy propecia

getting cialis from canada

levitra where to buy

get levitra

cost of viagra

cialis professional 20 mg

buy cialis once daily

buy viagra online cheap us

cheap propecia uk

cialis next day delivery

buying generic propecia

generic viagra canadian

buy now propecia

levitra mg

generic cialis from india

low cost canadian viagra

info levitra

5 mg daily cialis

online ordering propecia

cialis on women

cheapest viagra online

canadian healthcare

brand name cialis overnight

cheap viagra from uk

generic levitra online

cialis one a day

generic propecia finasteride

buy propecia where

buy viagra on line

cheap order prescription propecia

discount propecia propecia

online generic cialis 100 mg

cheap propecia online

levitra viagra online

healthcare canadian pharmacy

lowest price on non generic levitra

cialis discount

buy cialis online uk

cheap propecia online prescription

generic cialis soft tabs

get propecia online pharmacy

mail online order propecia

buying levitra online

generic propecia fda approved

generic propecia effective

buy propecia prescriptions online

get levitra online

drug generic propecia

once daily cialis

cialis price 100 mg

levitra cost

levitra prescription

online levitra

buy 5 mg cialis

buy cialis 5 mg

cialis and diarrhea

cialis fast delivery usa

buy cialis without prescription

order prescription propecia

levitra online no prescription

buy viagra

canadian viagra india

canada propecia prescription

cialis refractory

buy cheap generic levitra

order cheap propecia

cialis tablets foreign

buy cialis canada

combine cialis and levitra

for sale levitra

brand name cialis

buy viagra mexico

indian viagra

lowest cost levitra

get cialis

buy propecia online pharmacy

levitra mail order

ganeric cialis

discount us propecia

discount levitra online

levitra cheap fast

buy levitra online from canada

generic propecia online pharmacy

buy viagra without prescription

cialis 5 mg buy

online cialis

buy can from i propecia who

cialis professional 100 mg

cialis prescription

lowest propecia prices in canada

canada generic propecia

obtain viagra without prescription

cialis price in canada

lowest price propecia best

cialis buy overnight

cialis online

generic viagra india

levitra canadian

buy viagra online

buy branded viagra

mexico pharmacy cialis

cialis alternative

ordering cialis gel

buy generic levitra

can i get viagra in mexico

generic viagra made in india

brand viagra over the net

generic propecia for sale

cialis price

canadian propecia rx

brand viagra professional

how much to buy viagra in pounds

cialis and ketoconazole

levitra online us

buy cialis online canada

bio viagra herbal

cialis professional no prescription

cost levitra low

canada viagra

cialis 5 mg

buy online prescription propecia

buy cialis in usa

buy real viagra online

low price levitra

cheapest propecia uk

cialis cheap us pharmacy

how much does cialis cost

cheapest price propecia cheap

order cheapest propecia online

buy propecia generic

low cost levitra

buy cialis for daily use

how to get viagra

cialis from canada

next day delivery cialis

cialis next day

buy propecia online from usa pharmacy

canadian healthcare viagra

buying generic cialis mexico rx

buy generic viagra india rx

cialis 20 mg

levitra for sale

cheapest prices for viagra

levitra pill

best price for generic cialis

buy propecia in the uk

best price levitra

cialis daily in canada

levitra online prescription

cheap viagra canada or india

discount drug propecia

buy levitra overnight

levitra from canadian pharmacy

buying propecia

buy generic propecia

buy prescription propecia without

buy levitra online viagra

buy cheap generic propecia

cialis tablets

buying viagra in canada

cialis for woman

levitra next day delivery

cheap discount levitra

buy levitra us

cheap cialis soft

generic viagra canada

how much cialis

canadian drugs propecia

buy cialis usa

canadian pharmacy discount code viagra

online propecia prescriptions

cheap canadian viagra

best viagra

mexico levitra

levitra discount

best price generic propecia

canadian viagra

cost of daily cialis

levitra online overnight delivery

buy dosages levitra

cialis vs levitra

cialis by mail

canadian pharmacies cialis

levitra tabs

discount generic propecia

generic levitra overnight delivery

cialis delivered overnight

indian cialis

cheap levitra uk

cheapest propecia prescription

genuine cialis pills

cialis 50 mg

levitra low price

cialis daily dosage pharmacy

canada meds viagra

buy generic cialis

online propecia uk

cialis dosage mg

levitra 10mg

buy levitra online no prescription

buy propecia cheap

how much is viagra

levitra online sales

brand cialis for sale

generic propecia sale

cialis generic 100 mg

buying cialis next day delivery

how to buy cialis in canada

gele viagra

canadian pharmacy viagra

order propecia

cost of propecia

buy fast propecia

cialis 100 mg generic

cialis transdermal

canada viagra pharmacies scam

buy viagra germany canadian meds

natural viagra

cialis purchase

buy levitra uk

cheap propecia no prescription

cheap viagra online

buy propecia now

buy cheap levitra

canada viagra generic

cheap levitra without prescription

best way to use cialis

china viagra

cialis quick shipment

lowest price for propecia

cialis soft pills

buy cheapest propecia

cheap propecia 5mg

generic viagra online

canada cheap propecia

cialis overnight

buying cialis soft tabs 100 mg

cialis and canada custom

cialis in mexico

low cost propecia

generic levitra cheap

next day viagra

cialis 5 mg italia

buy cialis cannada

name brand cialis

herbal propecia

buy cheap levitra online

cheap levitra

levitra viagra cialis

buying online propecia

cheapest propecia sale uk

indian generic levitra

discount levitra rx

lowest price propecia

order levitra online

buy propecia canada

cialis to buy

levitra in canada

cheap levitra tablets

lowest propecia 1 mg

canadian pharmacy cialis

online viagra gel to buy

cheapest viagra

5 mg original brand cialis

cialis discounts

order cheap levitra

buy real cialis

generic levitra purchase

cialis profesional

buy propecia on line

overnight delivery cialis

indian cialis generic

cheap fast levitra

buying cialis