From e2d4d33d973f9790d9a1543b63f9d67233f946f0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?C=C3=A9dric=20Pasteur?= Date: Mon, 17 Oct 2011 11:52:36 +0200 Subject: [PATCH] Fixed linear typing with args that are tuples --- compiler/heptagon/analysis/linear_typing.ml | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/compiler/heptagon/analysis/linear_typing.ml b/compiler/heptagon/analysis/linear_typing.ml index f2d4956..6a4711b 100644 --- a/compiler/heptagon/analysis/linear_typing.ml +++ b/compiler/heptagon/analysis/linear_typing.ml @@ -130,6 +130,10 @@ struct UnifyFailed -> find_candidate c lins end +let flatten_lin_list l = + List.fold_right + (fun arg args -> match arg with Ltuple l -> l@args | a -> a::args ) l [] + let lin_of_ident x (env, _, _) = Env.find x env @@ -573,6 +577,7 @@ and expect_app env expected_lin op e_list = match op with (* and check that it works *) (* type the inputs *) let result_lins, env = expect_args env inputs_lins e_list in + let result_lins = flatten_lin_list result_lins in (* and apply the result to the outputs *) let m = snd ( List.fold_left2 subst_from_lin (NamesSet.empty, NamesEnv.empty) inputs_lins result_lins) in