This commit is contained in:
Galfour 2019-04-15 11:20:20 +00:00
parent fc544bacf9
commit c2dd795287

View File

@ -104,21 +104,15 @@ let record_access_to_lr : type_value -> type_value AST.type_name_map -> string -
Append_tree.fold_ne leaf node node_tv Append_tree.fold_ne leaf node node_tv
let rec translate_block env (b:AST.block) : block result = let rec translate_block env (b:AST.block) : block result =
let%bind (instructions, env') = let aux = fun (precs, env) instruction ->
let rec aux e acc lst = match lst with let%bind lst = translate_instruction env instruction in
| [] -> ok (acc, e) let env' = List.fold_left (fun _ i -> (snd i).post_environment) env lst in
| hd :: tl -> ok (precs @ lst, env') in
match%bind translate_instruction e hd with let%bind (instructions, env') = bind_fold_list aux ([], env) b in
| Some ((_, e') as i) -> aux e'.post_environment (i :: acc) tl
| None -> aux e acc tl
in
let%bind (lst, e) = aux env [] b in
ok (List.rev lst, e)
in
ok (instructions, environment_wrap env env') ok (instructions, environment_wrap env env')
and translate_instruction (env:Environment.t) (i:AST.instruction) : statement option result = and translate_instruction (env:Environment.t) (i:AST.instruction) : statement list result =
let return ?(env' = env) x : statement option result = ok (Some (x, environment_wrap env env')) in let return ?(env' = env) x : statement list result = ok ([x, environment_wrap env env']) in
match i with match i with
| I_declaration {name;annotated_expression} -> | I_declaration {name;annotated_expression} ->
let%bind (_, t, _) as expression = translate_annotated_expression env annotated_expression in let%bind (_, t, _) as expression = translate_annotated_expression env annotated_expression in
@ -174,7 +168,7 @@ and translate_instruction (env:Environment.t) (i:AST.instruction) : statement op
let env' = Environment.extend env in let env' = Environment.extend env in
let%bind body' = translate_block env' body in let%bind body' = translate_block env' body in
return (S_while (expr', body')) return (S_while (expr', body'))
| I_skip -> ok None | I_skip -> ok []
| I_fail _ -> simple_fail "todo : fail" | I_fail _ -> simple_fail "todo : fail"
and translate_annotated_expression (env:Environment.t) (ae:AST.annotated_expression) : expression result = and translate_annotated_expression (env:Environment.t) (ae:AST.annotated_expression) : expression result =