vtm/quelldatein/aufbau/aktoren/erzeuger.ts

164 lines
3.2 KiB
TypeScript
Raw Normal View History

2017-11-09 14:06:35 +01:00
/*
* Verrückte Turing-Maschinen A turing complete game
* Copyright (C) 2016 Christian Fraß <vidofnir@folksprak.org>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
module mod_vtm_aufbau
{
/**
* @author kcf <vidofnir@folksprak.org>
*/
2018-03-26 00:41:10 +02:00
export type typ_erzeuger =
2017-11-09 14:06:35 +01:00
{
richtung : typ_richtung;
}
;
/**
* @author kcf <vidofnir@folksprak.org>
*/
2018-03-26 00:41:10 +02:00
function erzeuger_erstellen
(
2018-03-26 00:41:10 +02:00
richtung : typ_richtung
)
2018-03-26 00:41:10 +02:00
: typ_erzeuger
{
return {
"richtung": richtung,
};
}
/**
* @author kcf <vidofnir@folksprak.org>
*/
2018-03-26 00:41:10 +02:00
export function erzeuger_erstellen_aktor
(
2018-03-26 00:41:10 +02:00
richtung : typ_richtung
)
: typ_aktor
{
return {"art": "erzeuger", "angaben": erzeuger_erstellen(richtung)};
}
/**
* @author kcf <vidofnir@folksprak.org>
*/
function erzeuger_beispiel
(
)
: typ_erzeuger
{
return erzeuger_erstellen(0);
}
/**
* @author kcf <vidofnir@folksprak.org>
*/
export function erzeuger_richtung_lesen
(
erzeuger : typ_erzeuger
)
: typ_richtung
{
2018-03-26 00:41:10 +02:00
return erzeuger.richtung;
}
/**
* @author kcf <vidofnir@folksprak.org>
*/
2018-03-26 00:41:10 +02:00
function erzeuger_drehen
(
2018-03-26 00:41:10 +02:00
erzeuger : typ_erzeuger,
inkrement : int = +1
)
: void
{
2018-03-26 00:41:10 +02:00
erzeuger.richtung = richtung_addieren(erzeuger.richtung, inkrement);
}
/**
* @author kcf <vidofnir@folksprak.org>
*/
2018-03-26 00:41:10 +02:00
function erzeuger_verwenden
(
2018-03-26 00:41:10 +02:00
erzeuger : typ_erzeuger,
figur : typ_figur
)
: void
{
2018-03-26 00:41:10 +02:00
figur_bewegen(figur, erzeuger.richtung);
}
/**
* @author kcf <vidofnir@folksprak.org>
*/
2018-03-26 00:41:10 +02:00
function erzeuger_exportieren
(
2018-03-26 00:41:10 +02:00
erzeuger : typ_erzeuger
)
: any
{
return {
2018-03-26 00:41:10 +02:00
"richtung": richtung_exportieren(erzeuger.richtung),
};
}
/**
* @author kcf <vidofnir@folksprak.org>
*/
2018-03-26 00:41:10 +02:00
function erzeuger_importieren
(
roh : any
)
2018-03-26 00:41:10 +02:00
: typ_erzeuger
{
return (
2018-03-26 00:41:10 +02:00
erzeuger_erstellen
(
richtung_importieren(roh["richtung"])
)
);
2017-11-09 14:06:35 +01:00
}
2018-03-26 00:41:10 +02:00
/**
* @author kcf <vidofnir@folksprak.org>
*/
let wrap = (angaben => ({"art": "erzeuger", "angaben": angaben}));
let unwrap = (aktor => aktor.angaben);
implementierung_aktor["erzeuger"] =
{
"beispiel": () => wrap(erzeuger_beispiel()),
"drehen": (aktor, inkrement) => erzeuger_drehen(unwrap(aktor), inkrement),
"verwenden": (aktor, figur) => erzeuger_verwenden(unwrap(aktor), figur),
"exportieren": (aktor) => ({"art": "erzeuger", "angaben": erzeuger_exportieren(aktor.angaben)}),
"importieren": (roh) => wrap(erzeuger_importieren(roh)),
}
;
2017-11-09 14:06:35 +01:00
}