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
.