Skip to content

Commit

Permalink
Merge branch 'dev' into prevent-unnecessary-fixpoints
Browse files Browse the repository at this point in the history
  • Loading branch information
pigumar1 authored May 4, 2024
2 parents 4033abc + a263747 commit 7fdf9c3
Show file tree
Hide file tree
Showing 2 changed files with 16 additions and 10 deletions.
5 changes: 4 additions & 1 deletion src/haz3lcore/lang/Form.re
Original file line number Diff line number Diff line change
Expand Up @@ -302,7 +302,10 @@ let forms: list((string, t)) = [
("ap_exp", mk(ii, ["(", ")"], mk_post(P.ap, Exp, [Exp]))),
("ap_pat", mk(ii, ["(", ")"], mk_post(P.ap, Pat, [Pat]))),
("ap_typ", mk(ii, ["(", ")"], mk_post(P.ap, Typ, [Typ]))),
("ap_exp_typ", mk(ii, ["@<", ">"], mk_post(P.ap, Exp, [Typ]))),
(
"ap_exp_typ",
mk((Instant, Static), ["@<", ">"], mk_post(P.ap, Exp, [Typ])),
),
("at_sign", mk_nul_infix("@", P.eqs)), // HACK: SUBSTRING REQ
("case", mk(ds, ["case", "end"], mk_op(Exp, [Rul]))),
("test", mk(ds, ["test", "end"], mk_op(Exp, [Exp]))),
Expand Down
21 changes: 12 additions & 9 deletions src/haz3lcore/statics/Statics.re
Original file line number Diff line number Diff line change
Expand Up @@ -64,21 +64,23 @@ let map_m = (f, xs, m: Map.t) =>
let add_info = (ids: list(Id.t), info: Info.t, m: Map.t): Map.t =>
ids |> List.fold_left((m, id) => Id.Map.add(id, info, m), m);

let rec is_arrow_like = (t: Typ.t) => {
switch (t) {
| Unknown(_) => true
| Arrow(_) => true
| Forall(_, t) => is_arrow_like(t)
| _ => false
};
};

let is_recursive = (ctx, p, def, syn: Typ.t) => {
switch (Term.UPat.get_num_of_vars(p), Term.UExp.get_num_of_functions(def)) {
| (Some(num_vars), Some(num_fns))
when num_vars != 0 && num_vars == num_fns =>
switch (Typ.normalize(ctx, syn)) {
| Unknown(_)
| Arrow(_) => num_vars == 1
| Prod(syns) when List.length(syns) == num_vars =>
syns
|> List.for_all(
fun
| Typ.Unknown(_)
| Arrow(_) => true
| _ => false,
)
syns |> List.for_all(is_arrow_like)
| t when is_arrow_like(t) => num_vars == 1
| _ => false
}
| _ => false
Expand Down Expand Up @@ -237,6 +239,7 @@ and uexp_to_info_map =
m,
);
| ListConcat(e1, e2) =>
let mode = Mode.of_list_concat(ctx, mode);
let ids = List.map(Term.UExp.rep_id, [e1, e2]);
let (e1, m) = go(~mode, e1, m);
let (e2, m) = go(~mode, e2, m);
Expand Down

0 comments on commit 7fdf9c3

Please sign in to comment.