Skip to content

How to Generate a Stratego Signature

It is tedious to write a signature that is in sync with a syntax definition. Therefore, Spoofax automatically generates a signature from a syntax definition for the abstract syntax trees that the parser for that syntax definition produces.

Write a Syntax Definition

In the /syntax/ directory in your language project for language lang write a syntax definition in file lang.sdf3.

Possibly write additional syntax defininitions modules and import the in lang.sdf3.

Example. Consider the following SDF3 syntax definition:

module lang
imports Base

lexical sorts IntConst
lexical syntax
  IntConst = [0-9]+
sorts Exp
context-free syntax
  Exp.Int     = IntConst  
  Exp.Plus    = [[Exp] + [Exp]]   {left}
  Exp.Minus   = [[Exp] - [Exp]]   {left}
  Exp         = [([Exp])] {bracket}
context-free priorities
  {left : Exp.Plus Exp.Minus}

Generate Signature

The build for your language project will invoke the SDF3 compiler to generate a signature file for each SDF3 file in your project in directory /src-gen/signatures/ with suffix -sig and extension .str.

The build should be invoked as soon as you save a file.

Thus lang.sdf3 generates /src-gen/signatures/lang-sig.str.

Example. For the SDF3 file above, the following signature is automatically generated:

module signatures/lang-sig
imports signatures/Base-sig

signature
  sorts IntConst
  sorts Exp
  constructors
                   : string -> IntConst
    Int            : IntConst -> Exp
    Plus           : Exp * Exp -> Exp
    Minus          : Exp * Exp -> Exp
    IntConst-Plhdr : IntConst
    Exp-Plhdr      : Exp
    IntConst-Plhdr : COMPLETION-INSERTION -> IntConst
    Exp-Plhdr      : COMPLETION-INSERTION -> Exp

The injection from strings into the lexical IntConst sort reflects the fact that tokens are represented as strings in ASTs. The placeholder constructors generated for the sorts are used to represent incomplete programs and syntactic code completion1.

Use Signature

To use the signature, import it into the Stratego module that uses its constructors.

Example. To use the signature for the example import it as follows:

module desugar
imports signatures/lang-sig
rules
  // ...

References


  1. Luis Eduardo de Souza Amorim, Sebastian Erdweg, Guido Wachsmuth, and Eelco Visser. Principled syntactic code completion using placeholders. In Tijs van der Storm, Emilie Balland, and Dániel Varró, editors, Proceedings of the 2016 ACM SIGPLAN International Conference on Software Language Engineering, Amsterdam, The Netherlands, October 31 - November 1, 2016, 163–175. ACM, 2016. URL: http://dx.doi.org/10.1145/2997364.2997374, doi:10.1145/2997364.2997374


Last update: July 30, 2024
Created: July 30, 2024