Skip to content

Commit

Permalink
assign delta steps to the context with the unfolded ref
Browse files Browse the repository at this point in the history
so unfolding "foo" in "bar" is assigned to "foo in bar" instead of just "bar"

this should provide strictly more information
  • Loading branch information
SkySkimmer committed Dec 16, 2024
1 parent 0b9364e commit dd0bb4b
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 9 deletions.
2 changes: 1 addition & 1 deletion kernel/cClosure.ml
Original file line number Diff line number Diff line change
Expand Up @@ -2016,8 +2016,8 @@ let rec knr : 'a. _ -> _ -> pat_state: 'a depth -> _ -> _ -> 'a =
(* TODO missing record_step for non-Def definitions *)
(match Table.lookup info tab.tab fl with
| Def (v, _) ->
record_step tab Delta m.ctx;
push_context tab fl m.ctx v;
record_step tab Delta v.ctx;
kni info tab ~pat_state v stk
| Primitive op ->
if check_native_args op stk then
Expand Down
16 changes: 8 additions & 8 deletions kernel/conversion.ml
Original file line number Diff line number Diff line change
Expand Up @@ -460,20 +460,20 @@ and eqappr cv_pb l2r infos (lft1,st1) (lft2,st2) cuniv =
| RelKey _ -> None
in
if Conv_oracle.oracle_order oracle l2r (to_er fl1) (to_er fl2) then begin
record_delta infos.lft_tab hd1;
record_delta infos.lft_tab (fst t1);
eqappr cv_pb l2r infos (lft1, t1) appr2 cuniv
end
else begin
record_delta infos.rgt_tab hd2;
record_delta infos.rgt_tab (fst t2);
eqappr cv_pb l2r infos appr1 (lft2, t2) cuniv
end
| Some (t1, v1), None ->
record_delta infos.lft_tab hd1;
record_delta infos.lft_tab t1;
let all = RedFlags.(red_add_transparent all (red_transparent (info_flags infos.cnv_inf))) in
let t1 = whd_stack (infos_with_reds infos.cnv_inf all) infos.lft_tab t1 v1 in
eqappr cv_pb l2r infos (lft1, t1) appr2 cuniv
| None, Some (t2, v2) ->
record_delta infos.rgt_tab hd2;
record_delta infos.rgt_tab t2;
let all = RedFlags.(red_add_transparent all (red_transparent (info_flags infos.cnv_inf))) in
let t2 = whd_stack (infos_with_reds infos.cnv_inf all) infos.rgt_tab t2 v2 in
eqappr cv_pb l2r infos appr1 (lft2, t2) cuniv
Expand Down Expand Up @@ -509,7 +509,7 @@ and eqappr cv_pb l2r infos (lft1,st1) (lft2,st2) cuniv =
| FFlex _ ->
begin match unfold_ref_with_args infos.cnv_inf infos.rgt_tab hd2 v2 with
| Some t2 ->
record_delta infos.rgt_tab hd2;
record_delta infos.rgt_tab (fst t2);
eqappr cv_pb l2r infos appr1 (lft2, t2) cuniv
| None -> raise NotConvertible
end
Expand All @@ -526,7 +526,7 @@ and eqappr cv_pb l2r infos (lft1,st1) (lft2,st2) cuniv =
| FFlex _ ->
begin match unfold_ref_with_args infos.cnv_inf infos.lft_tab hd1 v1 with
| Some t1 ->
record_delta infos.lft_tab hd1;
record_delta infos.lft_tab (fst t1);
eqappr cv_pb l2r infos (lft1, t1) appr2 cuniv
| None -> raise NotConvertible
end
Expand Down Expand Up @@ -589,7 +589,7 @@ and eqappr cv_pb l2r infos (lft1,st1) (lft2,st2) cuniv =
Conversion check to rigid terms eventually implies full weak-head
reduction, so instead of repeatedly performing small-step
unfoldings, we perform reduction with all flags on. *)
record_delta infos.lft_tab hd1;
record_delta infos.lft_tab def1;
let all = RedFlags.(red_add_transparent all (red_transparent (info_flags infos.cnv_inf))) in
let r1 = whd_stack (infos_with_reds infos.cnv_inf all) infos.lft_tab def1 v1 in
eqappr cv_pb l2r infos (lft1, r1) appr2 cuniv
Expand All @@ -608,7 +608,7 @@ and eqappr cv_pb l2r infos (lft1,st1) (lft2,st2) cuniv =
begin match unfold_ref_with_args infos.cnv_inf infos.rgt_tab hd2 v2 with
| Some (def2, v2) ->
(** Symmetrical case of above. *)
record_delta infos.rgt_tab hd2;
record_delta infos.rgt_tab def2;
let all = RedFlags.(red_add_transparent all (red_transparent (info_flags infos.cnv_inf))) in
let r2 = whd_stack (infos_with_reds infos.cnv_inf all) infos.rgt_tab def2 v2 in
eqappr cv_pb l2r infos appr1 (lft2, r2) cuniv
Expand Down

0 comments on commit dd0bb4b

Please sign in to comment.