diff options
| author | ppedrot | 2013-06-18 19:48:50 +0000 |
|---|---|---|
| committer | ppedrot | 2013-06-18 19:48:50 +0000 |
| commit | a3b4bde65a350bf3dc54ccec8f7608355c6a008a (patch) | |
| tree | 46107f5a916af73f9c0051097ce73f2bdd3455b8 /printing | |
| parent | 7a2701e6741fcf1e800e35b7721fc89abe40cbba (diff) | |
Proof-of-concept: moved four easy-to-handle generic arguments to
their own file, Stdarg.
This required a little trick to correctly handle wit_* naming. We
use a dynamic table to remember exactly where those arguments come
from.
git-svn-id: svn+ssh://scm.gforge.inria.fr/svn/coq/trunk@16587 85f007b7-540e-0410-9357-904b9bb8a0f7
Diffstat (limited to 'printing')
| -rw-r--r-- | printing/pptactic.ml | 18 |
1 files changed, 3 insertions, 15 deletions
diff --git a/printing/pptactic.ml b/printing/pptactic.ml index 350d96142d..241d728131 100644 --- a/printing/pptactic.ml +++ b/printing/pptactic.ml @@ -141,11 +141,7 @@ let if_pattern_ident b pr c = (if b then str "?" else mt()) ++ pr c let rec pr_raw_generic prc prlc prtac prpat prref (x:Genarg.rlevel Genarg.generic_argument) = match Genarg.genarg_tag x with - | BoolArgType -> str (if out_gen (rawwit wit_bool) x then "true" else "false") - | IntArgType -> int (out_gen (rawwit wit_int) x) | IntOrVarArgType -> pr_or_var int (out_gen (rawwit wit_int_or_var) x) - | StringArgType -> str "\"" ++ str (out_gen (rawwit wit_string) x) ++ str "\"" - | PreIdentArgType -> str (out_gen (rawwit wit_pre_ident) x) | IntroPatternArgType -> pr_intro_pattern (out_gen (rawwit wit_intro_pattern) x) | IdentArgType b -> if_pattern_ident b pr_id (out_gen (rawwit wit_ident) x) | VarArgType -> pr_located pr_id (out_gen (rawwit wit_var) x) @@ -180,16 +176,12 @@ let rec pr_raw_generic prc prlc prtac prpat prref (x:Genarg.rlevel Genarg.generi x) | ExtraArgType s -> try pi1 (String.Map.find s !genarg_pprule) prc prlc prtac x - with Not_found -> str "[no printer for " ++ str s ++ str "]" + with Not_found -> Genarg.raw_print x let rec pr_glob_generic prc prlc prtac prpat x = match Genarg.genarg_tag x with - | BoolArgType -> str (if out_gen (glbwit wit_bool) x then "true" else "false") - | IntArgType -> int (out_gen (glbwit wit_int) x) | IntOrVarArgType -> pr_or_var int (out_gen (glbwit wit_int_or_var) x) - | StringArgType -> str "\"" ++ str (out_gen (glbwit wit_string) x) ++ str "\"" - | PreIdentArgType -> str (out_gen (glbwit wit_pre_ident) x) | IntroPatternArgType -> pr_intro_pattern (out_gen (glbwit wit_intro_pattern) x) | IdentArgType b -> if_pattern_ident b pr_id (out_gen (glbwit wit_ident) x) | VarArgType -> pr_located pr_id (out_gen (glbwit wit_var) x) @@ -226,15 +218,11 @@ let rec pr_glob_generic prc prlc prtac prpat x = x) | ExtraArgType s -> try pi2 (String.Map.find s !genarg_pprule) prc prlc prtac x - with Not_found -> str "[no printer for " ++ str s ++ str "]" + with Not_found -> Genarg.glb_print x let rec pr_generic prc prlc prtac prpat x = match Genarg.genarg_tag x with - | BoolArgType -> str (if out_gen (topwit wit_bool) x then "true" else "false") - | IntArgType -> int (out_gen (topwit wit_int) x) | IntOrVarArgType -> pr_or_var int (out_gen (topwit wit_int_or_var) x) - | StringArgType -> str "\"" ++ str (out_gen (topwit wit_string) x) ++ str "\"" - | PreIdentArgType -> str (out_gen (topwit wit_pre_ident) x) | IntroPatternArgType -> pr_intro_pattern (out_gen (topwit wit_intro_pattern) x) | IdentArgType b -> if_pattern_ident b pr_id (out_gen (topwit wit_ident) x) | VarArgType -> pr_id (out_gen (topwit wit_var) x) @@ -267,7 +255,7 @@ let rec pr_generic prc prlc prtac prpat x = x) | ExtraArgType s -> try pi3 (String.Map.find s !genarg_pprule) prc prlc prtac x - with Not_found -> str "[no printer for " ++ str s ++ str "]" + with Not_found -> Genarg.top_print x let rec tacarg_using_rule_token pr_gen = function | Some s :: l, al -> str s :: tacarg_using_rule_token pr_gen (l,al) |
