Module ErgoSpec.Translation.CTOtoErgo


Translates a CTO to an Ergo module

Require Import String.
Require Import List.

Require Import ErgoSpec.Backend.ErgoBackend.
Require Import ErgoSpec.Common.Utils.Names.
Require Import ErgoSpec.Common.Utils.Result.
Require Import ErgoSpec.Common.Utils.Ast.
Require Import ErgoSpec.Common.CTO.CTO.
Require Import ErgoSpec.Common.Types.ErgoType.
Require Import ErgoSpec.Ergo.Lang.Ergo.

Section CTOtoErgo.

  Fixpoint cto_type_to_ergo_type (ctd:lrcto_type) : lrergo_type :=
    match ctd with
    | CTOBoolean loc => ErgoTypeBoolean loc
    | CTOString loc => ErgoTypeString loc
    | CTODouble loc => ErgoTypeDouble loc
    | CTOLong loc => ErgoTypeLong loc
    | CTOInteger loc => ErgoTypeInteger loc
    | CTODateTime loc => ErgoTypeDateTime loc
    | CTOClassRef loc n => ErgoTypeClassRef loc n
    | CTOOption loc ct1 => ErgoTypeOption loc (cto_type_to_ergo_type ct1)
    | CTOArray loc ct1 => ErgoTypeArray loc (cto_type_to_ergo_type ct1)
    end.

  Definition cto_declaration_desc_to_ergo_type_declaration_desc
             (dk:lrcto_declaration_desc) : lrergo_type_declaration_desc :=
    match dk with
    | CTOEnum ls => ErgoTypeEnum ls
    | CTOTransaction on isabs crec =>
      ErgoTypeTransaction on isabs (map (fun xy => (fst xy, cto_type_to_ergo_type (snd xy))) crec)
    | CTOConcept on isabs crec =>
      ErgoTypeConcept on isabs (map (fun xy => (fst xy, cto_type_to_ergo_type (snd xy))) crec)
    | CTOEvent on isabs crec =>
      ErgoTypeEvent on isabs (map (fun xy => (fst xy, cto_type_to_ergo_type (snd xy))) crec)
    | CTOAsset on isabs crec =>
      ErgoTypeAsset on isabs (map (fun xy => (fst xy, cto_type_to_ergo_type (snd xy))) crec)
    | CTOParticipant on isabs crec =>
      ErgoTypeParticipant on isabs (map (fun xy => (fst xy, cto_type_to_ergo_type (snd xy))) crec)
    end.

  Definition cto_declaration_to_ergo_type_declaration (d:lrcto_declaration) : lrergo_type_declaration :=
    mkErgoTypeDeclaration
      d.(cto_declaration_annot)
      d.(cto_declaration_name)
      (cto_declaration_desc_to_ergo_type_declaration_desc d.(cto_declaration_type)).

  Definition cto_declaration_to_ergo_declaration (d:lrcto_declaration) : lrergo_declaration :=
    DType d.(cto_declaration_annot) (cto_declaration_to_ergo_type_declaration d).
  Definition cto_import_to_ergo_declaration (d:import_decl) : lrergo_declaration :=
    DImport (import_annot d) d.

  Definition cto_package_to_ergo_module (p:lrcto_package) : lrergo_module :=
    mkModule
      p.(cto_package_annot)
      p.(cto_package_file)
      p.(cto_package_namespace)
      ((map cto_import_to_ergo_declaration p.(cto_package_imports))
       ++ (map cto_declaration_to_ergo_declaration p.(cto_package_declarations))).

End CTOtoErgo.