open Types let scopes : Format.formatter -> scopes -> unit = fun f s -> let pp_scope f (s:scope) = let pp_list f = List.iter (fun (k,_) -> Format.fprintf f "%s " k ) in let a = Def_map.to_kv_list s.env in Format.fprintf f "[ %a] %a" pp_list a Location.pp s.range in let pp_scopes f = List.iter (Format.fprintf f "@[%a@ @]" pp_scope) in Format.fprintf f "@[Scopes:@ %a@]" pp_scopes s let definitions : Format.formatter -> def_map -> unit = fun f dm -> let kvl = Def_map.to_kv_list dm in let (variables,types) = List.partition (fun (_,def) -> match def with Type _ -> false | Variable _ -> true) kvl in let pp_def f = List.iter (fun (k,v) -> Format.fprintf f "(%s -> %s) %a@ " k (get_def_name v) Location.pp (get_range v)) in Format.fprintf f "@[Variable definitions:@ %aType definitions:@ %a@]" pp_def variables pp_def types let def_to_json : def -> Yojson.t = function | Variable { name ; range ; body_range ; t ; references=_ } -> `Assoc [ ("name", `String name); ("range", Location.pp_json range); ("body_range", Location.pp_json body_range); ("t", match t with None -> `Null | Some t -> Ast_typed.PP_json.Yojson.type_expression t ); ("references", `Null); ] | Type { name ; range ; body_range ; content=_ } -> `Assoc [ ("name", `String name); ("range", Location.pp_json range); ("body_range", Location.pp_json body_range); ("content", `String "TODO" ); ] let defs_json d : Yojson.t = let get_defs d = let (v,tv) = List.partition (fun (_,def) -> match def with Variable _ -> true | Type _ -> false) (Def_map.to_kv_list d) in [ ("variables", `Assoc (List.map (fun (def_id,def) -> (def_id,def_to_json def)) v)); ("types", `Assoc (List.map (fun (def_id,def) -> (def_id,def_to_json def)) tv)) ] in `Assoc (get_defs d) let scopes_json s : Yojson.t = `List ( List.map (fun scope -> let sd = Def_map.to_kv_list scope.env in let (variables,types) = List.partition (fun (_,def) -> match def with Type _ -> false | Variable _ -> true) sd in let v = List.map (fun (k,_) -> `String k) variables in let t = List.map (fun (k,_) -> `String k) types in (`Assoc [("range", Location.pp_json scope.range) ; ("expression_environment", `List v) ; ("type_environment", `List t)]) ) s ) let to_json (d,s) = `Assoc [("definitions", (defs_json d)) ; ("scopes", (scopes_json s))]