summaryrefslogtreecommitdiff
path: root/src/SymbolicToPure.ml
diff options
context:
space:
mode:
Diffstat (limited to 'src/SymbolicToPure.ml')
-rw-r--r--src/SymbolicToPure.ml82
1 files changed, 82 insertions, 0 deletions
diff --git a/src/SymbolicToPure.ml b/src/SymbolicToPure.ml
index 7792db4b..8980361a 100644
--- a/src/SymbolicToPure.ml
+++ b/src/SymbolicToPure.ml
@@ -4,7 +4,9 @@ module T = Types
module V = Values
module E = Expressions
module A = CfimAst
+module M = Modules
module S = SymbolicAst
+open Pure
type name =
| FunName of A.FunDefId.id * V.BackwardFunctionId.id option
@@ -89,3 +91,83 @@ let fun_to_name (fdef : A.fun_def) (bid : V.BackwardFunctionId.id option) :
| x :: n -> x :: add_to_last n
in
add_to_last fdef.name
+
+(** Generates a name for a type (simply reuses the name in the definition) *)
+let type_to_name (def : T.type_def) : Id.name = def.T.name
+
+type type_context = { type_defs : type_def TypeDefId.Map.t }
+
+type fun_context = unit
+(** TODO *)
+
+type synth_ctx = {
+ names : NameMap.t;
+ type_context : type_context;
+ fun_context : fun_context;
+ declarations : M.declaration_group list;
+}
+
+let rec translate_sty (ctx : synth_ctx) (ty : T.sty) : ty =
+ let translate = translate_sty ctx in
+ match ty with
+ | T.Adt (type_id, regions, tys) ->
+ assert (regions = []);
+ let tys = List.map translate tys in
+ Adt (type_id, tys)
+ | TypeVar vid -> TypeVar vid
+ | Bool -> Bool
+ | Char -> Char
+ | Never -> failwith "Unreachable"
+ | Integer int_ty -> Integer int_ty
+ | Str -> Str
+ | Array ty -> Array (translate ty)
+ | Slice ty -> Slice (translate ty)
+ | Ref (_, rty, _) -> translate rty
+
+let translate_field (ctx : synth_ctx) (f : T.field) : field =
+ let field_name = f.field_name in
+ let field_ty = translate_sty ctx f.field_ty in
+ { field_name; field_ty }
+
+let translate_fields (ctx : synth_ctx) (fl : T.field list) : field list =
+ List.map (translate_field ctx) fl
+
+let translate_variant (ctx : synth_ctx) (v : T.variant) : variant =
+ let variant_name = v.variant_name in
+ let fields = translate_fields ctx v.fields in
+ { variant_name; fields }
+
+let translate_variants (ctx : synth_ctx) (vl : T.variant list) : variant list =
+ List.map (translate_variant ctx) vl
+
+(** Translate a type def kind to IM *)
+let translate_type_def_kind (ctx : synth_ctx) (kind : T.type_def_kind) :
+ type_def_kind =
+ match kind with
+ | T.Struct fields -> Struct (translate_fields ctx fields)
+ | T.Enum variants -> Enum (translate_variants ctx variants)
+
+(** Translate a type definition from IM
+
+ TODO: this is not symbolic to pure but IM to pure. Still, I don't see the
+ point of moving this definition for now.
+ *)
+let translate_type_def (ctx : synth_ctx) (def : T.type_def) :
+ synth_ctx * type_def =
+ (* Translate *)
+ let def_id = def.T.def_id in
+ let name = type_to_name def in
+ let type_params = def.type_params in
+ let kind = translate_type_def_kind ctx def.T.kind in
+ let def = { def_id; name; type_params; kind } in
+ (* Insert in the context *)
+ (* type context *)
+ let type_context = ctx.type_context in
+ let type_defs = type_context.type_defs in
+ let type_defs = TypeDefId.Map.add def_id def type_defs in
+ let type_context = { type_defs } in
+ (* names map *)
+ let names = NameMap.add (TypeName def_id) name ctx.names in
+ (* update the fields *)
+ let ctx = { ctx with type_context; names } in
+ (ctx, def)