aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMatthieu Sozeau2014-09-27 19:21:46 +0200
committerMatthieu Sozeau2014-09-27 20:41:05 +0200
commit02b66da78e766a0eb8a1ec82a03ec9ce5418a0f0 (patch)
tree1d157ece2d488deaa419fbd12901ad56a2f807aa
parent8c32ecc205aebaf9a4da95e24463286aee1a571d (diff)
Fix bug #3672, application of primitive projections as coercions.
-rw-r--r--pretyping/coercion.ml21
-rw-r--r--test-suite/bugs/closed/3672.v27
2 files changed, 41 insertions, 7 deletions
diff --git a/pretyping/coercion.ml b/pretyping/coercion.ml
index 0ae8736433..0ec25d402b 100644
--- a/pretyping/coercion.ml
+++ b/pretyping/coercion.ml
@@ -47,11 +47,21 @@ exception NoCoercion
exception NoCoercionNoUnifier of evar_map * unification_error
(* Here, funj is a coercion therefore already typed in global context *)
-let apply_coercion_args env evd check argl funj =
+let apply_coercion_args env evd check isproj argl funj =
let evdref = ref evd in
let rec apply_rec acc typ = function
- | [] -> { uj_val = applist (j_val funj,argl);
- uj_type = typ }
+ | [] ->
+ if isproj then
+ let cst = fst (destConst (j_val funj)) in
+ let p = Projection.make cst false in
+ let pb = lookup_projection p env in
+ let args = List.skipn pb.Declarations.proj_npars argl in
+ let hd, tl = match args with hd :: tl -> hd, tl | [] -> assert false in
+ { uj_val = applist (mkProj (p, hd), tl);
+ uj_type = typ }
+ else
+ { uj_val = applist (j_val funj,argl);
+ uj_type = typ }
| h::restl -> (* On devrait pouvoir s'arranger pour qu'on n'ait pas a faire hnf_constr *)
match kind_of_term (whd_betadeltaiota env evd typ) with
| Prod (_,c1,c2) ->
@@ -345,13 +355,10 @@ let apply_coercion env sigma p hj typ_cl =
let sigma = Evd.merge_context_set Evd.univ_flexible sigma ctx in
let argl = (class_args_of env sigma typ_cl)@[ja.uj_val] in
let sigma, jres =
- apply_coercion_args env sigma true argl fv
+ apply_coercion_args env sigma true isproj argl fv
in
(if isid then
{ uj_val = ja.uj_val; uj_type = jres.uj_type }
- else if isproj then
- { uj_val = mkProj (Projection.make (fst (destConst fv.uj_val)) false, ja.uj_val);
- uj_type = jres.uj_type }
else
jres),
jres.uj_type,sigma)
diff --git a/test-suite/bugs/closed/3672.v b/test-suite/bugs/closed/3672.v
new file mode 100644
index 0000000000..283be49587
--- /dev/null
+++ b/test-suite/bugs/closed/3672.v
@@ -0,0 +1,27 @@
+Set Primitive Projections. (* No failures without this option. *)
+
+Record AT :=
+{ atype :> Type
+; coerce : atype -> Type
+}.
+Coercion coerce : atype >-> Sortclass.
+
+Record Ar C (A:AT) := { ar : forall (X Y : C), A }.
+
+Definition t := forall C A a X, coerce _ (ar C A a X X).
+Definition t' := forall C A a X, ar C A a X X.
+
+(* The command has indeed failed with message:
+=> Error: The term "ar C A a X X" has type "atype A" which is not a (co-)inductive type.
+*)
+
+Record Ar2 C (A:AT) :=
+{ ar2 : forall (X Y : C), A
+; id2 : forall X, coerce _ (ar2 X X) }.
+
+Record Ar3 C (A:AT) :=
+{ ar3 : forall (X Y : C), A
+; id3 : forall X, ar3 X X }.
+(* The command has indeed failed with message:
+=> Anomaly: Bad recursive type. Please report.
+*) \ No newline at end of file