bit2 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/bit2.d.ts +229 -0
- package/dist/bit2.js +1 -0
- package/dist/src/bx/biEval.d.ts +6 -0
- package/dist/src/bx/biEval.js +59 -0
- package/dist/src/bx/biEval.js.map +1 -0
- package/dist/src/common/Exp.d.ts +53 -0
- package/dist/src/common/Exp.js +44 -0
- package/dist/src/common/Exp.js.map +1 -0
- package/dist/src/common/PrettyPrint.d.ts +4 -0
- package/dist/src/common/PrettyPrint.js +32 -0
- package/dist/src/common/PrettyPrint.js.map +1 -0
- package/dist/src/common/Print.d.ts +3 -0
- package/dist/src/common/Print.js +73 -0
- package/dist/src/common/Print.js.map +1 -0
- package/dist/src/core/AST.d.ts +92 -0
- package/dist/src/core/AST.js +47 -0
- package/dist/src/core/AST.js.map +1 -0
- package/dist/src/core/PrettyPrint.d.ts +2 -0
- package/dist/src/core/PrettyPrint.js +64 -0
- package/dist/src/core/PrettyPrint.js.map +1 -0
- package/dist/src/core/Print.d.ts +3 -0
- package/dist/src/core/Print.js +77 -0
- package/dist/src/core/Print.js.map +1 -0
- package/dist/src/fuse/Fuse.d.ts +23 -0
- package/dist/src/fuse/Fuse.js +1436 -0
- package/dist/src/fuse/Fuse.js.map +1 -0
- package/dist/src/fuse/Print.d.ts +2 -0
- package/dist/src/fuse/Print.js +22 -0
- package/dist/src/fuse/Print.js.map +1 -0
- package/dist/src/fuse/Update.d.ts +19 -0
- package/dist/src/fuse/Update.js +3 -0
- package/dist/src/fuse/Update.js.map +1 -0
- package/dist/src/lambda/AST.d.ts +23 -0
- package/dist/src/lambda/AST.js +3 -0
- package/dist/src/lambda/AST.js.map +1 -0
- package/dist/src/lambda/Evaluation.d.ts +4 -0
- package/dist/src/lambda/Evaluation.js +98 -0
- package/dist/src/lambda/Evaluation.js.map +1 -0
- package/dist/src/lambda/Print.d.ts +2 -0
- package/dist/src/lambda/Print.js +31 -0
- package/dist/src/lambda/Print.js.map +1 -0
- package/dist/src/lambdalize/lambdalize.d.ts +3 -0
- package/dist/src/lambdalize/lambdalize.js +94 -0
- package/dist/src/lambdalize/lambdalize.js.map +1 -0
- package/dist/src/lambdalize/unLambdalize.d.ts +3 -0
- package/dist/src/lambdalize/unLambdalize.js +59 -0
- package/dist/src/lambdalize/unLambdalize.js.map +1 -0
- package/dist/src/partial/AST.d.ts +86 -0
- package/dist/src/partial/AST.js +3 -0
- package/dist/src/partial/AST.js.map +1 -0
- package/dist/src/partial/Print.d.ts +6 -0
- package/dist/src/partial/Print.js +93 -0
- package/dist/src/partial/Print.js.map +1 -0
- package/dist/src/partialEval/peval.d.ts +11 -0
- package/dist/src/partialEval/peval.js +322 -0
- package/dist/src/partialEval/peval.js.map +1 -0
- package/dist/src/partialEval/unpeval.d.ts +4 -0
- package/dist/src/partialEval/unpeval.js +360 -0
- package/dist/src/partialEval/unpeval.js.map +1 -0
- package/dist/src/surface/AST.d.ts +57 -0
- package/dist/src/surface/AST.js +3 -0
- package/dist/src/surface/AST.js.map +1 -0
- package/dist/src/surface/Parser.d.ts +4 -0
- package/dist/src/surface/Parser.js +314 -0
- package/dist/src/surface/Parser.js.map +1 -0
- package/dist/src/translate/Translate.d.ts +3 -0
- package/dist/src/translate/Translate.js +91 -0
- package/dist/src/translate/Translate.js.map +1 -0
- package/dist/src/utils/Utils.d.ts +2 -0
- package/dist/src/utils/Utils.js +7 -0
- package/dist/src/utils/Utils.js.map +1 -0
- package/dist/test/bx/biEval.test.d.ts +1 -0
- package/dist/test/bx/biEval.test.js +41 -0
- package/dist/test/bx/biEval.test.js.map +1 -0
- package/dist/test/bx/test.d.ts +1 -0
- package/dist/test/bx/test.js +29 -0
- package/dist/test/bx/test.js.map +1 -0
- package/dist/test/core/0.simple.test.d.ts +4 -0
- package/dist/test/core/0.simple.test.js +68 -0
- package/dist/test/core/0.simple.test.js.map +1 -0
- package/dist/test/core/1.core.test.d.ts +2 -0
- package/dist/test/core/1.core.test.js +30 -0
- package/dist/test/core/1.core.test.js.map +1 -0
- package/dist/test/core/core.test.d.ts +1 -0
- package/dist/test/core/core.test.js +28 -0
- package/dist/test/core/core.test.js.map +1 -0
- package/dist/test/fuse/branchnop.test.d.ts +1 -0
- package/dist/test/fuse/branchnop.test.js +47 -0
- package/dist/test/fuse/branchnop.test.js.map +1 -0
- package/dist/test/fuse/bulk.test.d.ts +1 -0
- package/dist/test/fuse/bulk.test.js +111 -0
- package/dist/test/fuse/bulk.test.js.map +1 -0
- package/dist/test/fuse/const.test.d.ts +1 -0
- package/dist/test/fuse/const.test.js +118 -0
- package/dist/test/fuse/const.test.js.map +1 -0
- package/dist/test/fuse/exp.test.d.ts +1 -0
- package/dist/test/fuse/exp.test.js +225 -0
- package/dist/test/fuse/exp.test.js.map +1 -0
- package/dist/test/fuse/lambda.test.d.ts +1 -0
- package/dist/test/fuse/lambda.test.js +139 -0
- package/dist/test/fuse/lambda.test.js.map +1 -0
- package/dist/test/fuse/loop.test.d.ts +1 -0
- package/dist/test/fuse/loop.test.js +39 -0
- package/dist/test/fuse/loop.test.js.map +1 -0
- package/dist/test/fuse/seq.test.d.ts +1 -0
- package/dist/test/fuse/seq.test.js +64 -0
- package/dist/test/fuse/seq.test.js.map +1 -0
- package/dist/test/fuse/space.test.d.ts +1 -0
- package/dist/test/fuse/space.test.js +136 -0
- package/dist/test/fuse/space.test.js.map +1 -0
- package/dist/test/lambda/evaluation.test.d.ts +1 -0
- package/dist/test/lambda/evaluation.test.js +24 -0
- package/dist/test/lambda/evaluation.test.js.map +1 -0
- package/dist/test/lambda/lambda.test.d.ts +1 -0
- package/dist/test/lambda/lambda.test.js +45 -0
- package/dist/test/lambda/lambda.test.js.map +1 -0
- package/dist/test/lambdalize/lambdalize.test.d.ts +1 -0
- package/dist/test/lambdalize/lambdalize.test.js +23 -0
- package/dist/test/lambdalize/lambdalize.test.js.map +1 -0
- package/dist/test/lambdalize/unLambdalize.test.d.ts +1 -0
- package/dist/test/lambdalize/unLambdalize.test.js +35 -0
- package/dist/test/lambdalize/unLambdalize.test.js.map +1 -0
- package/dist/test/partial/partial.test.d.ts +1 -0
- package/dist/test/partial/partial.test.js +35 -0
- package/dist/test/partial/partial.test.js.map +1 -0
- package/dist/test/partialEval/peval.test.d.ts +1 -0
- package/dist/test/partialEval/peval.test.js +29 -0
- package/dist/test/partialEval/peval.test.js.map +1 -0
- package/dist/test/partialEval/unPeval.test.d.ts +1 -0
- package/dist/test/partialEval/unPeval.test.js +40 -0
- package/dist/test/partialEval/unPeval.test.js.map +1 -0
- package/dist/test/surface/AST.test.d.ts +1 -0
- package/dist/test/surface/AST.test.js +41 -0
- package/dist/test/surface/AST.test.js.map +1 -0
- package/dist/test/translate/translate.test.d.ts +1 -0
- package/dist/test/translate/translate.test.js +45 -0
- package/dist/test/translate/translate.test.js.map +1 -0
- package/package.json +49 -0
@@ -0,0 +1,92 @@
|
|
1
|
+
import { Expr, Variable } from "../common/Exp";
|
2
|
+
export type TermNode = ConstNode | SpaceNode | DeclareNode | AssignNode | ExpNode | SeqNode | IfThenElseNode | LoopNode | CallNode | NopNode | BotNode | EndNode | LambdaWithExpr;
|
3
|
+
export interface ConstNode {
|
4
|
+
type: 'const';
|
5
|
+
value: string;
|
6
|
+
}
|
7
|
+
export interface SpaceNode {
|
8
|
+
type: 'space';
|
9
|
+
width: number;
|
10
|
+
}
|
11
|
+
export interface DeclareNode {
|
12
|
+
type: 'declare';
|
13
|
+
name: Variable;
|
14
|
+
value: Expr;
|
15
|
+
}
|
16
|
+
export interface AssignNode {
|
17
|
+
type: 'assign';
|
18
|
+
name: Variable;
|
19
|
+
value: Expr;
|
20
|
+
}
|
21
|
+
export interface ExpNode {
|
22
|
+
type: 'exp';
|
23
|
+
expression: Expr;
|
24
|
+
}
|
25
|
+
export interface SeqNode {
|
26
|
+
type: 'seq';
|
27
|
+
nodes: TermNode[];
|
28
|
+
}
|
29
|
+
export interface IfThenElseNode {
|
30
|
+
type: 'ite';
|
31
|
+
condition: Expr;
|
32
|
+
trueBranch: TermNode;
|
33
|
+
falseBranch: TermNode;
|
34
|
+
}
|
35
|
+
export interface LoopNode {
|
36
|
+
type: 'loop';
|
37
|
+
lst: Expr;
|
38
|
+
separator: SepNode;
|
39
|
+
front: FrontNode;
|
40
|
+
rear: RearNode;
|
41
|
+
body: Lambda;
|
42
|
+
}
|
43
|
+
export interface NopNode {
|
44
|
+
type: 'nop';
|
45
|
+
}
|
46
|
+
export interface BotNode {
|
47
|
+
type: 'bot';
|
48
|
+
}
|
49
|
+
export interface EndNode {
|
50
|
+
type: 'end';
|
51
|
+
}
|
52
|
+
export interface SepNode {
|
53
|
+
type: 'sep';
|
54
|
+
value: string;
|
55
|
+
}
|
56
|
+
export interface FrontNode {
|
57
|
+
type: 'front';
|
58
|
+
value: string;
|
59
|
+
}
|
60
|
+
export interface RearNode {
|
61
|
+
type: 'rear';
|
62
|
+
value: string;
|
63
|
+
}
|
64
|
+
export interface Lambda {
|
65
|
+
type: 'lambda';
|
66
|
+
variable: Variable;
|
67
|
+
body: TermNode;
|
68
|
+
}
|
69
|
+
export interface LambdaWithExpr {
|
70
|
+
type: 'lambdawithexpr';
|
71
|
+
variable: Variable;
|
72
|
+
body: TermNode;
|
73
|
+
exp: Expr;
|
74
|
+
}
|
75
|
+
export interface CallNode {
|
76
|
+
type: 'call';
|
77
|
+
func: TermNode;
|
78
|
+
args: {
|
79
|
+
[key: string]: Expr;
|
80
|
+
};
|
81
|
+
}
|
82
|
+
export declare function seq(...nodes: TermNode[]): SeqNode;
|
83
|
+
export declare function constNode(value: string): ConstNode;
|
84
|
+
export declare function space(width: number): SpaceNode;
|
85
|
+
export declare function declare(name: Variable, value: Expr): DeclareNode;
|
86
|
+
export declare function exp(expression: Expr): ExpNode;
|
87
|
+
export declare function loop(lst: Expr, sep: SepNode, front: FrontNode, rear: RearNode, body: Lambda): LoopNode;
|
88
|
+
export declare function ite(condition: Expr, trueBranch: TermNode, falseBranch: TermNode): IfThenElseNode;
|
89
|
+
export declare function assign(name: Variable, value: Expr): AssignNode;
|
90
|
+
export declare function nop(): NopNode;
|
91
|
+
export declare function bot(): BotNode;
|
92
|
+
export declare function end(): EndNode;
|
@@ -0,0 +1,47 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
function seq(...nodes) {
|
4
|
+
return { type: 'seq', nodes };
|
5
|
+
}
|
6
|
+
exports.seq = seq;
|
7
|
+
function constNode(value) {
|
8
|
+
return { type: 'const', value: value };
|
9
|
+
}
|
10
|
+
exports.constNode = constNode;
|
11
|
+
function space(width) {
|
12
|
+
return { type: 'space', width };
|
13
|
+
}
|
14
|
+
exports.space = space;
|
15
|
+
function declare(name, value) {
|
16
|
+
return { type: 'declare', name, value };
|
17
|
+
}
|
18
|
+
exports.declare = declare;
|
19
|
+
function exp(expression) {
|
20
|
+
return { type: 'exp', expression };
|
21
|
+
}
|
22
|
+
exports.exp = exp;
|
23
|
+
function loop(lst, sep, front, rear, body) {
|
24
|
+
return { type: 'loop', lst, separator: sep, front, rear, body };
|
25
|
+
}
|
26
|
+
exports.loop = loop;
|
27
|
+
function ite(condition, trueBranch, falseBranch) {
|
28
|
+
return { type: 'ite', condition, trueBranch, falseBranch };
|
29
|
+
}
|
30
|
+
exports.ite = ite;
|
31
|
+
function assign(name, value) {
|
32
|
+
return { type: 'assign', name, value };
|
33
|
+
}
|
34
|
+
exports.assign = assign;
|
35
|
+
function nop() {
|
36
|
+
return { type: 'nop' };
|
37
|
+
}
|
38
|
+
exports.nop = nop;
|
39
|
+
function bot() {
|
40
|
+
return { type: 'bot' };
|
41
|
+
}
|
42
|
+
exports.bot = bot;
|
43
|
+
function end() {
|
44
|
+
return { type: 'end' };
|
45
|
+
}
|
46
|
+
exports.end = end;
|
47
|
+
//# sourceMappingURL=AST.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"AST.js","sourceRoot":"","sources":["../../../src/core/AST.ts"],"names":[],"mappings":";;AA2GA,SAAgB,GAAG,CAAC,GAAG,KAAiB;IACtC,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;AAChC,CAAC;AAFD,kBAEC;AAED,SAAgB,SAAS,CAAC,KAAa;IACrC,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAC,KAAK,EAAE,CAAC;AACxC,CAAC;AAFD,8BAEC;AAED,SAAgB,KAAK,CAAC,KAAa;IACjC,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC;AAClC,CAAC;AAFD,sBAEC;AAED,SAAgB,OAAO,CAAC,IAAc,EAAE,KAAW;IACjD,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;AAC1C,CAAC;AAFD,0BAEC;AAED,SAAgB,GAAG,CAAC,UAAgB;IAClC,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,UAAU,EAAE,CAAC;AACrC,CAAC;AAFD,kBAEC;AAED,SAAgB,IAAI,CAAC,GAAS,EAAE,GAAY,EAAE,KAAgB,EAAE,IAAc,EAAE,IAAY;IAC1F,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,EAAE,SAAS,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;AAClE,CAAC;AAFD,oBAEC;AAED,SAAgB,GAAG,CAAC,SAAe,EAAE,UAAoB,EAAE,WAAqB;IAC9E,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,CAAC;AAC7D,CAAC;AAFD,kBAEC;AAED,SAAgB,MAAM,CAAC,IAAc,EAAE,KAAW;IAChD,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;AACzC,CAAC;AAFD,wBAEC;AAED,SAAgB,GAAG;IACjB,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;AACzB,CAAC;AAFD,kBAEC;AAED,SAAgB,GAAG;IACjB,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;AACzB,CAAC;AAFD,kBAEC;AAED,SAAgB,GAAG;IACjB,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;AACzB,CAAC;AAFD,kBAEC"}
|
@@ -0,0 +1,64 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
3
|
+
if (mod && mod.__esModule) return mod;
|
4
|
+
var result = {};
|
5
|
+
if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];
|
6
|
+
result["default"] = mod;
|
7
|
+
return result;
|
8
|
+
};
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
10
|
+
const Exp = __importStar(require("../common/PrettyPrint"));
|
11
|
+
function printToSurface(node) {
|
12
|
+
let str = "";
|
13
|
+
switch (node.type) {
|
14
|
+
case 'const':
|
15
|
+
return node.value;
|
16
|
+
case 'space':
|
17
|
+
return " ".repeat(node.width);
|
18
|
+
case 'declare':
|
19
|
+
str = "«";
|
20
|
+
str += "var ";
|
21
|
+
str += Exp.prettyPrint(node.name);
|
22
|
+
str += "=";
|
23
|
+
str += Exp.prettyPrint(node.value);
|
24
|
+
str += "»";
|
25
|
+
// str += "\n";
|
26
|
+
return str;
|
27
|
+
case 'assign':
|
28
|
+
str = "«";
|
29
|
+
str += Exp.prettyPrint(node.name);
|
30
|
+
str += "=";
|
31
|
+
str += Exp.prettyPrint(node.value);
|
32
|
+
str += "»";
|
33
|
+
// str += "\n"
|
34
|
+
return str;
|
35
|
+
case 'exp':
|
36
|
+
str = "«";
|
37
|
+
str += Exp.prettyPrint(node.expression);
|
38
|
+
str += "»";
|
39
|
+
return str;
|
40
|
+
case 'seq':
|
41
|
+
return node.nodes.map(node => printToSurface(node)).join("");
|
42
|
+
case 'ite':
|
43
|
+
str = "«if " + Exp.prettyPrint(node.condition) + "»\n";
|
44
|
+
str += printToSurface(node.trueBranch);
|
45
|
+
str += "«endif»\n";
|
46
|
+
return str;
|
47
|
+
case 'loop':
|
48
|
+
str = "«for " + Exp.prettyPrint(node.body.variable) + " :" + Exp.prettyPrint(node.lst) + "»\n";
|
49
|
+
str += printToSurface(node.body.body);
|
50
|
+
str += "«endfor»\n";
|
51
|
+
return str;
|
52
|
+
case 'nop':
|
53
|
+
return "";
|
54
|
+
case 'bot':
|
55
|
+
return "";
|
56
|
+
case 'end':
|
57
|
+
return "";
|
58
|
+
default:
|
59
|
+
return "";
|
60
|
+
}
|
61
|
+
return "";
|
62
|
+
}
|
63
|
+
exports.printToSurface = printToSurface;
|
64
|
+
//# sourceMappingURL=PrettyPrint.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"PrettyPrint.js","sourceRoot":"","sources":["../../../src/core/PrettyPrint.ts"],"names":[],"mappings":";;;;;;;;;AACA,2DAA6C;AAE7C,SAAgB,cAAc,CAAC,IAAiB;IAC9C,IAAI,GAAG,GAAG,EAAE,CAAC;IACb,QAAO,IAAI,CAAC,IAAI,EAAE;QAChB,KAAK,OAAO;YACV,OAAO,IAAI,CAAC,KAAK,CAAC;QACpB,KAAK,OAAO;YACV,OAAO,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAChC,KAAK,SAAS;YACZ,GAAG,GAAG,GAAG,CAAC;YACV,GAAG,IAAI,MAAM,CAAC;YACd,GAAG,IAAI,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAClC,GAAG,IAAI,GAAG,CAAC;YACX,GAAG,IAAI,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACnC,GAAG,IAAI,GAAG,CAAC;YACX,eAAe;YACf,OAAO,GAAG,CAAC;QACb,KAAK,QAAQ;YACX,GAAG,GAAG,GAAG,CAAC;YACV,GAAG,IAAI,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAClC,GAAG,IAAI,GAAG,CAAC;YACX,GAAG,IAAI,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACnC,GAAG,IAAI,GAAG,CAAC;YACX,cAAc;YACd,OAAO,GAAG,CAAC;QACb,KAAK,KAAK;YACR,GAAG,GAAG,GAAG,CAAC;YACV,GAAG,IAAI,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACxC,GAAG,IAAI,GAAG,CAAC;YACX,OAAO,GAAG,CAAC;QACb,KAAK,KAAK;YACR,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAC/D,KAAK,KAAK;YACR,GAAG,GAAG,MAAM,GAAG,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,KAAK,CAAC;YACvD,GAAG,IAAI,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACvC,GAAG,IAAI,WAAW,CAAC;YACnB,OAAO,GAAG,CAAC;QACb,KAAK,MAAM;YACT,GAAG,GAAG,OAAO,GAAG,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,IAAI,GAAG,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;YAC/F,GAAG,IAAI,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACtC,GAAG,IAAI,YAAY,CAAC;YACpB,OAAO,GAAG,CAAC;QACb,KAAK,KAAK;YACR,OAAO,EAAE,CAAC;QACZ,KAAK,KAAK;YACR,OAAO,EAAE,CAAC;QACZ,KAAK,KAAK;YACR,OAAO,EAAE,CAAC;QACZ;YACE,OAAO,EAAE,CAAC;KACb;IACD,OAAO,EAAE,CAAC;AACZ,CAAC;AAnDD,wCAmDC"}
|
@@ -0,0 +1,77 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
3
|
+
if (mod && mod.__esModule) return mod;
|
4
|
+
var result = {};
|
5
|
+
if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];
|
6
|
+
result["default"] = mod;
|
7
|
+
return result;
|
8
|
+
};
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
10
|
+
const Print = __importStar(require("../common/Print"));
|
11
|
+
// 测试函数,递归打印AST节点
|
12
|
+
function printAST(node, indent = '') {
|
13
|
+
switch (node.type) {
|
14
|
+
case 'const':
|
15
|
+
console.log(`${indent}Const: ${node.value}`);
|
16
|
+
break;
|
17
|
+
case 'space':
|
18
|
+
console.log(`${indent}Space: ${node.width}`);
|
19
|
+
break;
|
20
|
+
case 'declare':
|
21
|
+
console.log(`${indent}Declare: ${node.name.name} =`);
|
22
|
+
Print.printExpression(node.value, indent + ' ');
|
23
|
+
break;
|
24
|
+
case 'assign':
|
25
|
+
console.log(`${indent}Assign: ${node.name.name} =`);
|
26
|
+
Print.printExpression(node.value, indent + ' ');
|
27
|
+
break;
|
28
|
+
case 'exp':
|
29
|
+
console.log(`${indent}Exp:`);
|
30
|
+
Print.printExpression(node.expression, indent + ' ');
|
31
|
+
break;
|
32
|
+
case 'seq':
|
33
|
+
console.log(`${indent}Seq:`);
|
34
|
+
node.nodes.forEach(n => printAST(n, indent + ' '));
|
35
|
+
break;
|
36
|
+
case 'ite':
|
37
|
+
console.log(`${indent}If-Then-Else: if`);
|
38
|
+
Print.printExpression(node.condition, indent + ' ');
|
39
|
+
console.log(`${indent}Then:`);
|
40
|
+
printAST(node.trueBranch, indent + ' ');
|
41
|
+
console.log(`${indent}Else:`);
|
42
|
+
printAST(node.falseBranch, indent + ' ');
|
43
|
+
break;
|
44
|
+
case 'loop':
|
45
|
+
console.log(`${indent}Loop:`);
|
46
|
+
Print.printExpression(node.lst, indent + ' ');
|
47
|
+
console.log(`${indent}Separator: ${node.separator.value}`);
|
48
|
+
console.log(`${indent}Front: ${node.front.value}`);
|
49
|
+
console.log(`${indent}Rear: ${node.rear.value}`);
|
50
|
+
printLambda(node.body, indent + ' ');
|
51
|
+
break;
|
52
|
+
case 'call':
|
53
|
+
console.log(`${indent}Call:`);
|
54
|
+
printAST(node.func, indent + ' ');
|
55
|
+
Object.keys(node.args).forEach(arg => {
|
56
|
+
console.log(`${indent} ${arg} =`);
|
57
|
+
Print.printExpression(node.args[arg], indent + ' ');
|
58
|
+
});
|
59
|
+
break;
|
60
|
+
case 'nop':
|
61
|
+
console.log(`${indent}Nop`);
|
62
|
+
break;
|
63
|
+
case 'bot':
|
64
|
+
console.log(`${indent}Bot`);
|
65
|
+
break;
|
66
|
+
case 'end':
|
67
|
+
console.log(`${indent}End`);
|
68
|
+
break;
|
69
|
+
}
|
70
|
+
}
|
71
|
+
exports.printAST = printAST;
|
72
|
+
function printLambda(lambda, indent = '') {
|
73
|
+
console.log(`${indent}Lambda: ${lambda.variable.name}`);
|
74
|
+
printAST(lambda.body, indent + ' ');
|
75
|
+
}
|
76
|
+
exports.printLambda = printLambda;
|
77
|
+
//# sourceMappingURL=Print.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"Print.js","sourceRoot":"","sources":["../../../src/core/Print.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,23 @@
|
|
1
|
+
import { Value } from "../partial/AST";
|
2
|
+
import { TermNode } from "../lambda/AST";
|
3
|
+
import { UpdateOperation } from "./Update";
|
4
|
+
import { Expr, Constant } from "../common/Exp";
|
5
|
+
export interface Environment {
|
6
|
+
[variable: string]: [Value, Value[]];
|
7
|
+
}
|
8
|
+
export declare function fuse(env: Environment, operation: UpdateOperation, term: TermNode): {
|
9
|
+
newEnv: Environment;
|
10
|
+
newTermNode: TermNode;
|
11
|
+
remainingOperation: UpdateOperation;
|
12
|
+
}[];
|
13
|
+
export declare function fuseExp(env: Environment, value: Value, exp: Expr): {
|
14
|
+
newEnv: Environment;
|
15
|
+
newExp: Expr;
|
16
|
+
};
|
17
|
+
export declare function valueToConstantExpr(value: Value): Constant;
|
18
|
+
export declare function printEnvironment(env: Environment): void;
|
19
|
+
export declare function fuseBulk(env: Environment, bulkOp: UpdateOperation, term: TermNode): {
|
20
|
+
newEnv: Environment;
|
21
|
+
newTermNode: TermNode;
|
22
|
+
remainingOperation: UpdateOperation;
|
23
|
+
}[];
|