diff options
Diffstat (limited to 'appl/alphabet/abc/autoconvert.b')
| -rw-r--r-- | appl/alphabet/abc/autoconvert.b | 80 |
1 files changed, 80 insertions, 0 deletions
diff --git a/appl/alphabet/abc/autoconvert.b b/appl/alphabet/abc/autoconvert.b new file mode 100644 index 00000000..5e542c80 --- /dev/null +++ b/appl/alphabet/abc/autoconvert.b @@ -0,0 +1,80 @@ +implement Autoconvert, Abcmodule; +include "sys.m"; + sys: Sys; +include "draw.m"; +include "sh.m"; + Cmd, + n_BLOCK, n_WORD, n_SEQ, n_LIST, n_ADJ, n_VAR: import Sh; +include "alphabet/reports.m"; + reports: Reports; + report: import reports; +include "alphabet.m"; +include "alphabet/abc.m"; + abc: Abc; + Value: import abc; + +Autoconvert: module {}; +types(): string +{ + return "AAssc"; +} + +init() +{ + sys = load Sys Sys->PATH; + reports = checkload(load Reports Reports->PATH, Reports->PATH); + abc = checkload(load Abc Abc->PATH, Abc->PATH); + abc->init(); +} + +quit() +{ +} + +run(errorc: chan of string, nil: ref Reports->Report, + nil: list of (int, list of ref Value), + args: list of ref Value + ): ref Value +{ + a := (hd args).A().i.alphabet; + src := (hd tl args).s().i; + dst := (hd tl tl args).s().i; + c := (hd tl tl tl args).c().i; + + # {word} -> {(src); word $1} + if(c.ntype == n_BLOCK && c.left.ntype == n_WORD){ + c = mk(n_BLOCK, + mk(n_SEQ, + mk(n_LIST, mkw(src), nil), + mk(n_ADJ, + c.left, + mk(n_VAR, mkw("1"), nil) + ) + ), + nil + ); + } + + err := a->autoconvert(src, dst, c, errorc); + if(err != nil){ + report(errorc, "abcautoconvert: "+err); + return nil; + } + return (hd args).dup(); +} + +checkload[T](m: T, path: string): T +{ + if(m != nil) + return m; + raise sys->sprint("fail:cannot load %s: %r", path); +} + +mk(ntype: int, left, right: ref Cmd): ref Cmd +{ + return ref Cmd(ntype, left, right, nil, nil); +} +mkw(w: string): ref Cmd +{ + return ref Cmd(n_WORD, nil, nil, w, nil); +} |
