diff options
| author | herbelin | 2002-11-15 14:37:30 +0000 |
|---|---|---|
| committer | herbelin | 2002-11-15 14:37:30 +0000 |
| commit | 5c124fd43ae521ca6427a46af57985f0cf56b1fd (patch) | |
| tree | 39bf9de3dd1a0c4565cec80fd85e7d22a9f42b0e /toplevel/command.ml | |
| parent | 29875632189d531ee57aaa7a4fd0c43ef02e69f7 (diff) | |
Passage à une représentation des fixpoints plus primitive dans constr_expr (càd avec indices)
git-svn-id: svn+ssh://scm.gforge.inria.fr/svn/coq/trunk@3245 85f007b7-540e-0410-9357-904b9bb8a0f7
Diffstat (limited to 'toplevel/command.ml')
| -rw-r--r-- | toplevel/command.ml | 15 |
1 files changed, 5 insertions, 10 deletions
diff --git a/toplevel/command.ml b/toplevel/command.ml index 19842ea627..eb911b4d21 100644 --- a/toplevel/command.ml +++ b/toplevel/command.ml @@ -311,18 +311,13 @@ let build_recursive lnameargsardef = let lrecnames = List.map (fun (f,_,_,_) -> f) lnameargsardef and sigma = Evd.empty and env0 = Global.env() - and nv = Array.of_list - (List.map - (fun (_,la,_,_) -> List.length (List.flatten (List.map fst la)) - 1) - lnameargsardef) - in + and nv = Array.of_list (List.map (fun (_,n,_,_) -> n) lnameargsardef) in let fs = States.freeze() in let (rec_sign,arityl) = try List.fold_left - (fun (env,arl) (recname,lparams,arityc,_) -> - let raw_arity = mkProdCit lparams arityc in - let arity = interp_type sigma env0 raw_arity in + (fun (env,arl) (recname,_,arityc,_) -> + let arity = interp_type sigma env0 arityc in let _ = declare_variable recname (Lib.cwd(),SectionLocalAssum arity, IsAssumption Definitional) in (Environ.push_named (recname,None,arity) env, (arity::arl))) @@ -333,8 +328,8 @@ let build_recursive lnameargsardef = let recdef = try List.map2 - (fun (_,lparams,_,def) arity -> - interp_casted_constr sigma rec_sign (mkLambdaCit lparams def) arity) + (fun (_,_,_,def) arity -> + interp_casted_constr sigma rec_sign def arity) lnameargsardef arityl with e -> States.unfreeze fs; raise e |
