diff options
author | 2003-02-05 16:43:53 +0000 | |
---|---|---|
committer | 2003-02-05 16:43:53 +0000 | |
commit | d75311dbe4ae6db12e98c7837a01347a05ef08c1 (patch) | |
tree | 55cc39b4203340a5d6103e3f2ab754b126c2bfa8 /translate | |
parent | 7da87c68444558218bca2a3b070086712d727bcc (diff) |
update
git-svn-id: svn+ssh://scm.gforge.inria.fr/svn/coq/trunk@3665 85f007b7-540e-0410-9357-904b9bb8a0f7
Diffstat (limited to 'translate')
-rw-r--r-- | translate/ppconstrnew.ml | 18 |
1 files changed, 9 insertions, 9 deletions
diff --git a/translate/ppconstrnew.ml b/translate/ppconstrnew.ml index 7d6899f77..07bd444f8 100644 --- a/translate/ppconstrnew.ml +++ b/translate/ppconstrnew.ml @@ -86,24 +86,24 @@ let prec_less child (parent,assoc) = match assoc with | E -> (<=) child parent | L -> (<) child parent - | Any | Prec _ -> false + | Prec n -> child<=n + | Any -> true let env_assoc_value v env = - try List.assoc v env - with Not_found -> - anomaly ("Printing metavariable "^(string_of_id v)^" is unbound") + try List.nth env (v-1) + with Not_found -> anomaly ("Inconsistent environment for pretty-print rule") open Symbols -let rec print_hunk pr env = function - | UnpMetaVar (e,prec) -> str "TODO" (* pr prec (env_assoc_value e env) *) +let rec print_hunk n pr env = function + | UnpMetaVar (e,prec) -> pr (n,prec) (env_assoc_value e env) | UnpTerminal s -> str s - | UnpBox (b,sub) -> ppcmd_of_box b (prlist (print_hunk pr env) sub) + | UnpBox (b,sub) -> ppcmd_of_box b (prlist (print_hunk n pr env) sub) | UnpCut cut -> ppcmd_of_cut cut let pr_notation pr s env = let unpl, level = find_notation_printing_rule s in - prlist (print_hunk pr env) unpl, level + prlist (print_hunk level pr env) unpl, level let pr_delimiters key strm = let left = "`"^key^":" and right = "`" in @@ -287,7 +287,7 @@ let rec pr inherited a = if prec_less prec inherited then strm else str"(" ++ strm ++ str")" -let pr_constr = pr ltop +let pr_constr c = pr ltop (Constrextern.extern_rawconstr (Constrintern.for_grammar (Constrintern.interp_rawconstr Evd.empty (Global.env())) c)) let pr_pattern = pr_constr let pr_occurrences prc (nl,c) = prlist (fun n -> int n ++ spc ()) nl ++ prc c |