]> matita.cs.unibo.it Git - helm.git/blobdiff - helm/ocaml/cic_notation/cicNotationParser.mli
ocaml 3.09 transition
[helm.git] / helm / ocaml / cic_notation / cicNotationParser.mli
index 32ba0a318acff4c93b0692cd7cecc598149ac6df..d614c68bca4b1dedd997677480fefe15ccf748bd 100644 (file)
@@ -29,32 +29,37 @@ exception Level_not_found of int
 (** {2 Parsing functions} *)
 
   (** concrete syntax pattern: notation level 1 *)
-val parse_syntax_pattern: char Stream.t -> CicNotationPt.term
+val parse_level1_pattern: Ulexing.lexbuf -> CicNotationPt.term
 
   (** AST pattern: notation level 2 *)
-val parse_ast_pattern:    char Stream.t -> CicNotationPt.term
-
-  (** interpretation: notation level 3 *)
-val parse_interpretation: char Stream.t -> CicNotationPt.cic_appl_pattern
+val parse_level2_ast: Ulexing.lexbuf -> CicNotationPt.term
+val parse_level2_meta: Ulexing.lexbuf -> CicNotationPt.term
 
 (** {2 Grammar extension} *)
 
-type env_type = (string * (CicNotationPt.value_type * CicNotationPt.value)) list
-
 type rule_id
 
 val extend:
-  CicNotationPt.term ->
-  ?precedence:int ->
-  ?associativity:Gramext.g_assoc ->
-  (env_type -> CicNotationPt.location -> CicNotationPt.term) ->
+  CicNotationPt.term -> (* level 1 pattern *)
+  precedence:int ->
+  associativity:Gramext.g_assoc ->
+  (CicNotationEnv.t -> CicNotationPt.location -> CicNotationPt.term) ->
     rule_id
 
 val delete: rule_id -> unit
 
-(** {2 Debugging} *)
+(** {2 Grammar entries}
+ * needed by grafite parser *)
+
+val level2_ast_grammar: Grammar.g
 
-val pp_env: env_type -> string
+val term : CicNotationPt.term Grammar.Entry.e
+
+val let_defs :
+  (CicNotationPt.capture_variable * CicNotationPt.term * int) list
+    Grammar.Entry.e
+
+(** {2 Debugging} *)
 
   (** print "level2_pattern" entry on stdout, flushing afterwards *)
 val print_l2_pattern: unit -> unit