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.
Files changed (138) hide show
  1. package/dist/bit2.d.ts +229 -0
  2. package/dist/bit2.js +1 -0
  3. package/dist/src/bx/biEval.d.ts +6 -0
  4. package/dist/src/bx/biEval.js +59 -0
  5. package/dist/src/bx/biEval.js.map +1 -0
  6. package/dist/src/common/Exp.d.ts +53 -0
  7. package/dist/src/common/Exp.js +44 -0
  8. package/dist/src/common/Exp.js.map +1 -0
  9. package/dist/src/common/PrettyPrint.d.ts +4 -0
  10. package/dist/src/common/PrettyPrint.js +32 -0
  11. package/dist/src/common/PrettyPrint.js.map +1 -0
  12. package/dist/src/common/Print.d.ts +3 -0
  13. package/dist/src/common/Print.js +73 -0
  14. package/dist/src/common/Print.js.map +1 -0
  15. package/dist/src/core/AST.d.ts +92 -0
  16. package/dist/src/core/AST.js +47 -0
  17. package/dist/src/core/AST.js.map +1 -0
  18. package/dist/src/core/PrettyPrint.d.ts +2 -0
  19. package/dist/src/core/PrettyPrint.js +64 -0
  20. package/dist/src/core/PrettyPrint.js.map +1 -0
  21. package/dist/src/core/Print.d.ts +3 -0
  22. package/dist/src/core/Print.js +77 -0
  23. package/dist/src/core/Print.js.map +1 -0
  24. package/dist/src/fuse/Fuse.d.ts +23 -0
  25. package/dist/src/fuse/Fuse.js +1436 -0
  26. package/dist/src/fuse/Fuse.js.map +1 -0
  27. package/dist/src/fuse/Print.d.ts +2 -0
  28. package/dist/src/fuse/Print.js +22 -0
  29. package/dist/src/fuse/Print.js.map +1 -0
  30. package/dist/src/fuse/Update.d.ts +19 -0
  31. package/dist/src/fuse/Update.js +3 -0
  32. package/dist/src/fuse/Update.js.map +1 -0
  33. package/dist/src/lambda/AST.d.ts +23 -0
  34. package/dist/src/lambda/AST.js +3 -0
  35. package/dist/src/lambda/AST.js.map +1 -0
  36. package/dist/src/lambda/Evaluation.d.ts +4 -0
  37. package/dist/src/lambda/Evaluation.js +98 -0
  38. package/dist/src/lambda/Evaluation.js.map +1 -0
  39. package/dist/src/lambda/Print.d.ts +2 -0
  40. package/dist/src/lambda/Print.js +31 -0
  41. package/dist/src/lambda/Print.js.map +1 -0
  42. package/dist/src/lambdalize/lambdalize.d.ts +3 -0
  43. package/dist/src/lambdalize/lambdalize.js +94 -0
  44. package/dist/src/lambdalize/lambdalize.js.map +1 -0
  45. package/dist/src/lambdalize/unLambdalize.d.ts +3 -0
  46. package/dist/src/lambdalize/unLambdalize.js +59 -0
  47. package/dist/src/lambdalize/unLambdalize.js.map +1 -0
  48. package/dist/src/partial/AST.d.ts +86 -0
  49. package/dist/src/partial/AST.js +3 -0
  50. package/dist/src/partial/AST.js.map +1 -0
  51. package/dist/src/partial/Print.d.ts +6 -0
  52. package/dist/src/partial/Print.js +93 -0
  53. package/dist/src/partial/Print.js.map +1 -0
  54. package/dist/src/partialEval/peval.d.ts +11 -0
  55. package/dist/src/partialEval/peval.js +322 -0
  56. package/dist/src/partialEval/peval.js.map +1 -0
  57. package/dist/src/partialEval/unpeval.d.ts +4 -0
  58. package/dist/src/partialEval/unpeval.js +360 -0
  59. package/dist/src/partialEval/unpeval.js.map +1 -0
  60. package/dist/src/surface/AST.d.ts +57 -0
  61. package/dist/src/surface/AST.js +3 -0
  62. package/dist/src/surface/AST.js.map +1 -0
  63. package/dist/src/surface/Parser.d.ts +4 -0
  64. package/dist/src/surface/Parser.js +314 -0
  65. package/dist/src/surface/Parser.js.map +1 -0
  66. package/dist/src/translate/Translate.d.ts +3 -0
  67. package/dist/src/translate/Translate.js +91 -0
  68. package/dist/src/translate/Translate.js.map +1 -0
  69. package/dist/src/utils/Utils.d.ts +2 -0
  70. package/dist/src/utils/Utils.js +7 -0
  71. package/dist/src/utils/Utils.js.map +1 -0
  72. package/dist/test/bx/biEval.test.d.ts +1 -0
  73. package/dist/test/bx/biEval.test.js +41 -0
  74. package/dist/test/bx/biEval.test.js.map +1 -0
  75. package/dist/test/bx/test.d.ts +1 -0
  76. package/dist/test/bx/test.js +29 -0
  77. package/dist/test/bx/test.js.map +1 -0
  78. package/dist/test/core/0.simple.test.d.ts +4 -0
  79. package/dist/test/core/0.simple.test.js +68 -0
  80. package/dist/test/core/0.simple.test.js.map +1 -0
  81. package/dist/test/core/1.core.test.d.ts +2 -0
  82. package/dist/test/core/1.core.test.js +30 -0
  83. package/dist/test/core/1.core.test.js.map +1 -0
  84. package/dist/test/core/core.test.d.ts +1 -0
  85. package/dist/test/core/core.test.js +28 -0
  86. package/dist/test/core/core.test.js.map +1 -0
  87. package/dist/test/fuse/branchnop.test.d.ts +1 -0
  88. package/dist/test/fuse/branchnop.test.js +47 -0
  89. package/dist/test/fuse/branchnop.test.js.map +1 -0
  90. package/dist/test/fuse/bulk.test.d.ts +1 -0
  91. package/dist/test/fuse/bulk.test.js +111 -0
  92. package/dist/test/fuse/bulk.test.js.map +1 -0
  93. package/dist/test/fuse/const.test.d.ts +1 -0
  94. package/dist/test/fuse/const.test.js +118 -0
  95. package/dist/test/fuse/const.test.js.map +1 -0
  96. package/dist/test/fuse/exp.test.d.ts +1 -0
  97. package/dist/test/fuse/exp.test.js +225 -0
  98. package/dist/test/fuse/exp.test.js.map +1 -0
  99. package/dist/test/fuse/lambda.test.d.ts +1 -0
  100. package/dist/test/fuse/lambda.test.js +139 -0
  101. package/dist/test/fuse/lambda.test.js.map +1 -0
  102. package/dist/test/fuse/loop.test.d.ts +1 -0
  103. package/dist/test/fuse/loop.test.js +39 -0
  104. package/dist/test/fuse/loop.test.js.map +1 -0
  105. package/dist/test/fuse/seq.test.d.ts +1 -0
  106. package/dist/test/fuse/seq.test.js +64 -0
  107. package/dist/test/fuse/seq.test.js.map +1 -0
  108. package/dist/test/fuse/space.test.d.ts +1 -0
  109. package/dist/test/fuse/space.test.js +136 -0
  110. package/dist/test/fuse/space.test.js.map +1 -0
  111. package/dist/test/lambda/evaluation.test.d.ts +1 -0
  112. package/dist/test/lambda/evaluation.test.js +24 -0
  113. package/dist/test/lambda/evaluation.test.js.map +1 -0
  114. package/dist/test/lambda/lambda.test.d.ts +1 -0
  115. package/dist/test/lambda/lambda.test.js +45 -0
  116. package/dist/test/lambda/lambda.test.js.map +1 -0
  117. package/dist/test/lambdalize/lambdalize.test.d.ts +1 -0
  118. package/dist/test/lambdalize/lambdalize.test.js +23 -0
  119. package/dist/test/lambdalize/lambdalize.test.js.map +1 -0
  120. package/dist/test/lambdalize/unLambdalize.test.d.ts +1 -0
  121. package/dist/test/lambdalize/unLambdalize.test.js +35 -0
  122. package/dist/test/lambdalize/unLambdalize.test.js.map +1 -0
  123. package/dist/test/partial/partial.test.d.ts +1 -0
  124. package/dist/test/partial/partial.test.js +35 -0
  125. package/dist/test/partial/partial.test.js.map +1 -0
  126. package/dist/test/partialEval/peval.test.d.ts +1 -0
  127. package/dist/test/partialEval/peval.test.js +29 -0
  128. package/dist/test/partialEval/peval.test.js.map +1 -0
  129. package/dist/test/partialEval/unPeval.test.d.ts +1 -0
  130. package/dist/test/partialEval/unPeval.test.js +40 -0
  131. package/dist/test/partialEval/unPeval.test.js.map +1 -0
  132. package/dist/test/surface/AST.test.d.ts +1 -0
  133. package/dist/test/surface/AST.test.js +41 -0
  134. package/dist/test/surface/AST.test.js.map +1 -0
  135. package/dist/test/translate/translate.test.d.ts +1 -0
  136. package/dist/test/translate/translate.test.js +45 -0
  137. package/dist/test/translate/translate.test.js.map +1 -0
  138. 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,2 @@
1
+ import * as AST from "./AST";
2
+ export declare function printToSurface(node: AST.TermNode): string;
@@ -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,3 @@
1
+ import { TermNode, Lambda } from "./AST";
2
+ export declare function printAST(node: TermNode, indent?: string): void;
3
+ export declare function printLambda(lambda: Lambda, indent?: string): void;
@@ -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
+ }[];