Abstract
rascal-0.40.17
Synopsis
Abstract syntax for Pico.
Examples
Here is the complete abstract syntax for Pico:
module demo::lang::Pico::Abstract
data TYPE(loc src=|unknown:///|)      ❶  
    = natural() 
    | string()
    ; 
      
alias PicoId = str;      ❷  
      
data PROGRAM(loc src=|unknown:///|)      ❹  
    = program(list[DECL] decls, list[STATEMENT] stats);      ❸   
data DECL(loc src=|unknown:///|)      ❹  
    = decl(PicoId name, TYPE tp);
data EXP(loc src=|unknown:///|)      ❹  
    = id(PicoId name)
    | natCon(int iVal)
    | strCon(str sVal)
    | add(EXP left, EXP right)
    | sub(EXP left, EXP right)
    | conc(EXP left, EXP right)
    ;
    
data STATEMENT(loc src=|unknown:///|)      ❹  
    = asgStat(PicoId name, EXP exp)
    | ifElseStat(EXP exp, list[STATEMENT] thenpart, list[STATEMENT] elsepart)
    | whileStat(EXP exp, list[STATEMENT] body)
    ;
alias Occurrence = tuple[loc src, PicoId name, STATEMENT stat];      ❺  
An abstract syntax specification is not necessary for implementing a programming language in Rascal. However, sometimes it comes in handy and for this reason we demonstrate an AST for Pico here. One reason could be that you are using an external parser for a language, another is that your DSL is only an intermediate format in a longer pipeline.
Notes:
- ❶  The types that may occur in a Pico program are either naturalorstring.
- ❷  Introduce PicoIdas an alias for Rascal'sstrdatatype.
- ❸  Define the various data types that constitute an AST for Pico. Observe that the constructor names match the names used in the concrete syntax, e.g., strCon,add,ifElseStat.
- ❹  Define an annotation with name locationand of typeloc(source code location) for all AST types. This will be used when transforming a parse tree into an abstract syntax tree Implode.
- ❺  Introduce Occurrenceas a generic way of describing the location of various items in the AST.