Clean unused values from pattern matching
This commit is contained in:
parent
89e4cde17f
commit
2e551ab2c7
1 changed files with 2 additions and 10 deletions
12
src/CPS.ml
12
src/CPS.ml
|
@ -35,16 +35,8 @@ let rec has_calls (t: S.term): bool = match t with
|
||||||
(* A lambda itself may contain calls, but this call is not evaluated at
|
(* A lambda itself may contain calls, but this call is not evaluated at
|
||||||
* declaration time *)
|
* declaration time *)
|
||||||
| S.App _ -> true
|
| S.App _ -> true
|
||||||
| S.IfZero (cond, tIf, tElse) ->
|
| S.IfZero _ -> true (* Cannot optimize that with the current languages *)
|
||||||
(* Cannot optimize continuation creation
|
| S.Print _ -> true (* Cannot optimize that with the current languages *)
|
||||||
List.exists has_calls [cond; tIf; tElse]
|
|
||||||
*)
|
|
||||||
true
|
|
||||||
| S.Print value ->
|
|
||||||
(* Cannot optimize continuation creation
|
|
||||||
has_calls value
|
|
||||||
*)
|
|
||||||
true
|
|
||||||
| S.Let (_, value, next) ->
|
| S.Let (_, value, next) ->
|
||||||
List.exists has_calls [value; next]
|
List.exists has_calls [value; next]
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue