Scopelang.AstSourceAbstract syntax tree of the scope language
type location = | ScopeVar of ScopeVar.t Pos.marked| SubScopeVar of ScopeName.t * SubScopeName.t Pos.marked * ScopeVar.t Pos.markedtype typ = | TLit of Dcalc.Ast.typ_lit| TStruct of StructName.t| TEnum of EnumName.t| TArrow of typ Pos.marked * typ Pos.markedtype expr = | ELocation of location| EVar of expr Bindlib.var Pos.marked| EStruct of StructName.t * expr Pos.marked StructFieldMap.t| EStructAccess of expr Pos.marked * StructFieldName.t * StructName.t| EEnumInj of expr Pos.marked * EnumConstructor.t * EnumName.t| EMatch of expr Pos.marked * EnumName.t * expr Pos.marked EnumConstructorMap.t| ELit of Dcalc.Ast.lit| EAbs of Pos.t * (expr, expr Pos.marked) Bindlib.mbinder * typ Pos.marked list| EApp of expr Pos.marked * expr Pos.marked list| EOp of Dcalc.Ast.operator| EDefault of expr Pos.marked list * expr Pos.marked * expr Pos.marked| EIfThenElse of expr Pos.marked * expr Pos.marked * expr Pos.markedThe expressions use the Bindlib library, based on higher-order abstract syntax
type rule = | Definition of location Pos.marked * typ Pos.marked * expr Pos.marked| Assertion of expr Pos.marked| Call of ScopeName.t * SubScopeName.ttype scope_decl = {scope_decl_name : ScopeName.t;scope_sig : typ Pos.marked ScopeVarMap.t;scope_decl_rules : rule list;}type program = {program_scopes : scope_decl ScopeMap.t;program_enums : enum_ctx;program_structs : struct_ctx;}val make_abs :
vars ->
expr Pos.marked Bindlib.box ->
Pos.t ->
typ Pos.marked list ->
Pos.t ->
expr Pos.marked Bindlib.boxval make_app :
expr Pos.marked Bindlib.box ->
expr Pos.marked Bindlib.box list ->
Pos.t ->
expr Pos.marked Bindlib.box