X-Git-Url: http://git.annexia.org/?a=blobdiff_plain;f=src%2Fast.mli;h=225e42975f75bf66431ad746e19026f865778206;hb=5e13f1e2a3dc1237fcf2fa141d8379bdd36bde61;hp=f8b88f073bbba6710265a03e9708f0f071e3c65b;hpb=976bb1b35d77f3058df3c25c1e2a4767147d606b;p=goals.git diff --git a/src/ast.mli b/src/ast.mli index f8b88f0..225e429 100644 --- a/src/ast.mli +++ b/src/ast.mli @@ -41,58 +41,58 @@ val string_loc : unit -> loc -> string variable or goal name -> expression. *) type env = expr Env.t and pattern = - (** match tactic such as *file ("filename") *) - | PTactic of loc * id * substs list + | PPred of loc * id * substs list + (** match predicate such as is-file ("filename") *) and expr = - (** goal (params) = patterns : exprs code *) | EGoalDefn of loc * goal - (** function (params) = code *) + (** goal (params) = patterns : exprs code *) | EFuncDefn of loc * func - (** tactic (params) = code *) - | ETacticDefn of loc * tactic - (** call goal (params) or function (params) *) + (** function (params) = code *) + | EPredDefn of loc * pred + (** predicate (params) = code *) | ECall of loc * id * expr list - (** call *tactic (params) etc. *) - | ETacticCtor of loc * id * expr list - (** variable, or goal call with no parameters *) + (** call goal (params) or function (params) *) + | EPredCtor of loc * id * expr list + (** constructor is-predicate (params) *) | EVar of loc * id - (** list *) + (** variable, or goal call with no parameters *) | EList of loc * expr list - (** string with %-substitutions *) + (** list *) | ESubsts of loc * substs - (** constant expression, such as a plain string, int, boolean, etc. *) + (** string with %-substitutions *) | EConstant of loc * constant + (** constant expression, such as a plain string, int, boolean, etc. *) and constant = | CString of string and goal = param_decl list * pattern list * expr list * code option -and func = param_decl list * code -and tactic = param_decl list * code - (** Goal/func/tactic parameter. *) -and param_decl = id +and func = param_decl list * returning * bool * code +and pred = param_decl list * code +and param_decl = id (** goal/func/pred parameter. *) and id = string -and code = substs +and code = substs * bool (** code + quiet flag *) +and returning = RetExpr | RetStrings | RetString and substs = subst list and subst = - (** String literal part. *) | SString of string - (** %-substitution. *) + (** String literal part. *) | SVar of id + (** %-substitution. *) +val getvar : env -> loc -> id -> expr (** Look up a variable in the environment. Raise [Failure _] if not found. *) -val getvar : env -> loc -> id -> expr +val getgoal : env -> loc -> id -> goal (** Look up a goal in the environment. Raise [Failure _] if not found or if the named variable is not a goal. *) -val getgoal : env -> loc -> id -> goal +val getfunc : env -> loc -> id -> func (** Look up a function in the environment. Raise [Failure _] if not found or if the named variable is not a function. *) -val getfunc : env -> loc -> id -> func -(** Look up a tactic in the environment. Raise [Failure _] if not - found or if the named variable is not a tactic. *) -val gettactic : env -> loc -> id -> tactic +val getpred : env -> loc -> id -> pred +(** Look up a predicate in the environment. Raise [Failure _] if not + found or if the named variable is not a predicate. *) (** This is used for incrementally building Ast.substs in the parser. *) module Substs : sig