yukigo 0.1.0 → 0.2.0

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 (144) hide show
  1. package/.mocharc.json +3 -3
  2. package/CHANGELOG.md +26 -0
  3. package/README.md +193 -199
  4. package/dist/analyzer/GraphBuilder.d.ts +29 -0
  5. package/dist/analyzer/GraphBuilder.js +99 -0
  6. package/dist/analyzer/index.d.ts +11 -23
  7. package/dist/analyzer/index.js +100 -58
  8. package/dist/analyzer/inspections/functional/functional.d.ts +44 -0
  9. package/dist/analyzer/inspections/functional/functional.js +149 -0
  10. package/dist/analyzer/inspections/functional/smells.d.ts +16 -0
  11. package/dist/analyzer/inspections/functional/smells.js +98 -0
  12. package/dist/analyzer/inspections/{generic.d.ts → generic/generic.d.ts} +70 -43
  13. package/dist/analyzer/inspections/generic/generic.js +604 -0
  14. package/dist/analyzer/inspections/generic/smells.d.ts +61 -0
  15. package/dist/analyzer/inspections/generic/smells.js +349 -0
  16. package/dist/analyzer/inspections/imperative/imperative.d.ts +35 -0
  17. package/dist/analyzer/inspections/imperative/imperative.js +109 -0
  18. package/dist/analyzer/inspections/imperative/smells.d.ts +16 -0
  19. package/dist/analyzer/inspections/imperative/smells.js +58 -0
  20. package/dist/analyzer/inspections/logic/logic.d.ts +32 -0
  21. package/dist/analyzer/inspections/logic/logic.js +96 -0
  22. package/dist/analyzer/inspections/logic/smells.d.ts +15 -0
  23. package/dist/analyzer/inspections/logic/smells.js +60 -0
  24. package/dist/analyzer/inspections/object/object.d.ts +88 -0
  25. package/dist/analyzer/inspections/object/object.js +319 -0
  26. package/dist/analyzer/inspections/object/smells.d.ts +30 -0
  27. package/dist/analyzer/inspections/object/smells.js +135 -0
  28. package/dist/analyzer/utils.d.ts +26 -4
  29. package/dist/analyzer/utils.js +71 -13
  30. package/dist/index.d.ts +1 -0
  31. package/dist/index.js +1 -0
  32. package/dist/interpreter/components/EnvBuilder.d.ts +9 -5
  33. package/dist/interpreter/components/EnvBuilder.js +100 -30
  34. package/dist/interpreter/components/Operations.d.ts +4 -4
  35. package/dist/interpreter/components/Operations.js +17 -2
  36. package/dist/interpreter/components/PatternMatcher.d.ts +47 -17
  37. package/dist/interpreter/components/PatternMatcher.js +264 -119
  38. package/dist/interpreter/components/RuntimeContext.d.ts +35 -0
  39. package/dist/interpreter/components/RuntimeContext.js +93 -0
  40. package/dist/interpreter/components/TestRunner.d.ts +18 -0
  41. package/dist/interpreter/components/TestRunner.js +103 -0
  42. package/dist/interpreter/components/Visitor.d.ts +63 -57
  43. package/dist/interpreter/components/Visitor.js +508 -173
  44. package/dist/interpreter/components/logic/LogicEngine.d.ts +29 -0
  45. package/dist/interpreter/components/logic/LogicEngine.js +259 -0
  46. package/dist/interpreter/components/logic/LogicResolver.d.ts +53 -0
  47. package/dist/interpreter/components/logic/LogicResolver.js +471 -0
  48. package/dist/interpreter/components/logic/LogicTranslator.d.ts +14 -0
  49. package/dist/interpreter/components/logic/LogicTranslator.js +99 -0
  50. package/dist/interpreter/components/runtimes/FunctionRuntime.d.ts +12 -0
  51. package/dist/interpreter/components/runtimes/FunctionRuntime.js +147 -0
  52. package/dist/interpreter/components/runtimes/LazyRuntime.d.ts +19 -0
  53. package/dist/interpreter/components/runtimes/LazyRuntime.js +269 -0
  54. package/dist/interpreter/components/runtimes/ObjectRuntime.d.ts +35 -0
  55. package/dist/interpreter/components/runtimes/ObjectRuntime.js +126 -0
  56. package/dist/interpreter/entities.d.ts +105 -0
  57. package/dist/interpreter/entities.js +96 -0
  58. package/dist/interpreter/errors.d.ts +1 -1
  59. package/dist/interpreter/index.d.ts +4 -12
  60. package/dist/interpreter/index.js +10 -13
  61. package/dist/interpreter/trampoline.d.ts +17 -0
  62. package/dist/interpreter/trampoline.js +38 -0
  63. package/dist/interpreter/utils.d.ts +4 -7
  64. package/dist/interpreter/utils.js +25 -17
  65. package/dist/tester/index.d.ts +25 -0
  66. package/dist/tester/index.js +108 -0
  67. package/dist/utils/helpers.d.ts +0 -4
  68. package/dist/utils/helpers.js +20 -24
  69. package/package.json +2 -2
  70. package/src/analyzer/GraphBuilder.ts +142 -0
  71. package/src/analyzer/index.ts +185 -132
  72. package/src/analyzer/inspections/functional/functional.ts +121 -0
  73. package/src/analyzer/inspections/functional/smells.ts +102 -0
  74. package/src/analyzer/inspections/{generic.ts → generic/generic.ts} +581 -499
  75. package/src/analyzer/inspections/generic/smells.ts +365 -0
  76. package/src/analyzer/inspections/imperative/imperative.ts +101 -0
  77. package/src/analyzer/inspections/imperative/smells.ts +54 -0
  78. package/src/analyzer/inspections/logic/logic.ts +90 -0
  79. package/src/analyzer/inspections/logic/smells.ts +54 -0
  80. package/src/analyzer/inspections/{object.ts → object/object.ts} +264 -282
  81. package/src/analyzer/inspections/object/smells.ts +144 -0
  82. package/src/analyzer/utils.ts +109 -26
  83. package/src/index.ts +3 -2
  84. package/src/interpreter/components/EnvBuilder.ts +202 -97
  85. package/src/interpreter/components/Operations.ts +99 -81
  86. package/src/interpreter/components/PatternMatcher.ts +475 -254
  87. package/src/interpreter/components/RuntimeContext.ts +119 -0
  88. package/src/interpreter/components/TestRunner.ts +151 -0
  89. package/src/interpreter/components/Visitor.ts +1065 -493
  90. package/src/interpreter/components/logic/LogicEngine.ts +519 -0
  91. package/src/interpreter/components/logic/LogicResolver.ts +858 -0
  92. package/src/interpreter/components/logic/LogicTranslator.ts +149 -0
  93. package/src/interpreter/components/runtimes/FunctionRuntime.ts +227 -0
  94. package/src/interpreter/components/runtimes/LazyRuntime.ts +334 -0
  95. package/src/interpreter/components/runtimes/ObjectRuntime.ts +224 -0
  96. package/src/interpreter/errors.ts +47 -47
  97. package/src/interpreter/index.ts +52 -59
  98. package/src/interpreter/trampoline.ts +71 -0
  99. package/src/interpreter/utils.ts +84 -79
  100. package/src/tester/index.ts +128 -0
  101. package/src/utils/helpers.ts +67 -73
  102. package/tests/analyzer/functional.spec.ts +207 -221
  103. package/tests/analyzer/generic.spec.ts +178 -100
  104. package/tests/analyzer/helpers.spec.ts +83 -83
  105. package/tests/analyzer/logic.spec.ts +237 -292
  106. package/tests/analyzer/oop.spec.ts +323 -338
  107. package/tests/analyzer/transitive.spec.ts +166 -0
  108. package/tests/interpreter/EnvBuilder.spec.ts +183 -178
  109. package/tests/interpreter/FunctionRuntime.spec.ts +223 -234
  110. package/tests/interpreter/LazyRuntime.spec.ts +225 -190
  111. package/tests/interpreter/LogicEngine.spec.ts +327 -194
  112. package/tests/interpreter/LogicSubstitution.spec.ts +80 -0
  113. package/tests/interpreter/ObjectRuntime.spec.ts +606 -0
  114. package/tests/interpreter/Operations.spec.ts +220 -220
  115. package/tests/interpreter/PatternSystem.spec.ts +213 -189
  116. package/tests/interpreter/Tests.spec.ts +122 -0
  117. package/tests/interpreter/interpreter.spec.ts +991 -937
  118. package/tests/tester/Tester.spec.ts +153 -0
  119. package/tsconfig.build.json +15 -7
  120. package/tsconfig.json +25 -17
  121. package/dist/analyzer/inspections/functional.d.ts +0 -46
  122. package/dist/analyzer/inspections/functional.js +0 -123
  123. package/dist/analyzer/inspections/generic.js +0 -427
  124. package/dist/analyzer/inspections/imperative.d.ts +0 -37
  125. package/dist/analyzer/inspections/imperative.js +0 -105
  126. package/dist/analyzer/inspections/logic.d.ts +0 -49
  127. package/dist/analyzer/inspections/logic.js +0 -140
  128. package/dist/analyzer/inspections/object.d.ts +0 -83
  129. package/dist/analyzer/inspections/object.js +0 -235
  130. package/dist/interpreter/components/FunctionRuntime.d.ts +0 -8
  131. package/dist/interpreter/components/FunctionRuntime.js +0 -52
  132. package/dist/interpreter/components/LazyRuntime.d.ts +0 -7
  133. package/dist/interpreter/components/LazyRuntime.js +0 -75
  134. package/dist/interpreter/components/LogicEngine.d.ts +0 -21
  135. package/dist/interpreter/components/LogicEngine.js +0 -152
  136. package/dist/interpreter/components/LogicResolver.d.ts +0 -11
  137. package/dist/interpreter/components/LogicResolver.js +0 -87
  138. package/src/analyzer/inspections/functional.ts +0 -159
  139. package/src/analyzer/inspections/imperative.ts +0 -129
  140. package/src/analyzer/inspections/logic.ts +0 -166
  141. package/src/interpreter/components/FunctionRuntime.ts +0 -79
  142. package/src/interpreter/components/LazyRuntime.ts +0 -97
  143. package/src/interpreter/components/LogicEngine.ts +0 -227
  144. package/src/interpreter/components/LogicResolver.ts +0 -130
@@ -1,81 +1,99 @@
1
- import { PrimitiveValue } from "yukigo-ast";
2
- import { isArrayOfNumbers } from "../utils.js";
3
-
4
- export type UnaryOp<T, R = T> = (x: T) => R;
5
- export type BinaryOp<T, R = T> = (x: T, y: T) => R;
6
- export type OperatorTable<T> = Record<string, T>;
7
-
8
- export const ArithmeticBinaryTable: OperatorTable<BinaryOp<number>> = {
9
- Plus: (a, b) => a + b,
10
- Minus: (a, b) => a - b,
11
- Multiply: (a, b) => a * b,
12
- Divide: (a, b) => a / b,
13
- Modulo: (a, b) => a % b,
14
- Power: (a, b) => a ** b,
15
- Min: (a, b) => Math.min(a, b),
16
- Max: (a, b) => Math.max(a, b),
17
- };
18
-
19
- export const ComparisonOperationTable: OperatorTable<BinaryOp<boolean>> = {
20
- Equal: (a, b) => a == b,
21
- NotEqual: (a, b) => a != b,
22
- Same: (a, b) => a === b,
23
- NotSame: (a, b) => a !== b,
24
- //Similar: (a, b) => ,
25
- //NotSimilar: (a, b) => ,
26
- GreaterOrEqualThan: (a, b) => a >= b,
27
- GreaterThan: (a, b) => a > b,
28
- LessOrEqualThan: (a, b) => a <= b,
29
- LessThan: (a, b) => a < b,
30
- };
31
- export const LogicalBinaryTable: OperatorTable<
32
- (l: boolean, r: () => boolean) => boolean
33
- > = {
34
- And: (left: boolean, rightThunk: () => boolean) => left && rightThunk(),
35
- Or: (left: boolean, rightThunk: () => boolean) => left || rightThunk(),
36
- };
37
-
38
- export const BitwiseBinaryTable: OperatorTable<BinaryOp<number>> = {
39
- BitwiseOr: (a, b) => a | b,
40
- BitwiseAnd: (a, b) => a & b,
41
- BitwiseLeftShift: (a, b) => a << b,
42
- BitwiseRightShift: (a, b) => a >> b,
43
- BitwiseUnsignedRightShift: (a, b) => a >>> b,
44
- BitwiseXor: (a, b) => a ^ b,
45
- };
46
-
47
- export const StringOperationTable: OperatorTable<BinaryOp<string>> = {
48
- Concat: (a, b) => `${a + b}`,
49
- };
50
-
51
- export const BitwiseUnaryTable: OperatorTable<UnaryOp<number>> = {
52
- BitwiseNot: (a) => ~a,
53
- };
54
- export const LogicalUnaryTable: OperatorTable<UnaryOp<boolean>> = {
55
- Negation: (a: boolean) => !a,
56
- };
57
- export const ListBinaryTable: OperatorTable<BinaryOp<PrimitiveValue[]>> = {
58
- Concat: (a, b) => a.concat(b),
59
- };
60
- export const ListUnaryTable: OperatorTable<UnaryOp<PrimitiveValue[], PrimitiveValue>> = {
61
- Size: (a: PrimitiveValue[]) => a.length,
62
- DetectMax: (a: PrimitiveValue[]) => {
63
- if (!isArrayOfNumbers(a))
64
- throw new Error("Operand of DetectMax must be Array of numbers");
65
- return Math.max(...a);
66
- },
67
- DetectMin: (a: PrimitiveValue[]) => {
68
- if (!isArrayOfNumbers(a))
69
- throw new Error("Operand of DetectMin must be Array of numbers");
70
- return Math.min(...a);
71
- },
72
- Flatten: (a: PrimitiveValue[]) => a.flat(),
73
- };
74
- export const ArithmeticUnaryTable: OperatorTable<UnaryOp<number>> = {
75
- Round: (a) => Math.round(a),
76
- Absolute: (a) => Math.abs(a),
77
- Ceil: (a) => Math.ceil(a),
78
- Floor: (a) => Math.floor(a),
79
- Negation: (a) => a * -1,
80
- Sqrt: (a) => Math.sqrt(a),
81
- };
1
+ import { PrimitiveValue } from "yukigo-ast";
2
+ import { isArrayOfNumbers } from "../utils.js";
3
+
4
+ export type UnaryOp<T, R = T> = (x: T) => R;
5
+ export type BinaryOp<T, R = T> = (x: T, y: T) => R;
6
+ export type OperatorTable<T> = Record<string, T>;
7
+
8
+ export const ArithmeticBinaryTable: OperatorTable<BinaryOp<number>> = {
9
+ Plus: (a, b) => a + b,
10
+ Minus: (a, b) => a - b,
11
+ Multiply: (a, b) => a * b,
12
+ Divide: (a, b) => a / b,
13
+ Modulo: (a, b) => a % b,
14
+ Power: (a, b) => a ** b,
15
+ Min: (a, b) => Math.min(a, b),
16
+ Max: (a, b) => Math.max(a, b),
17
+ };
18
+
19
+ export const ComparisonOperationTable: OperatorTable<BinaryOp<boolean>> = {
20
+ Equal: (a, b) => a == b,
21
+ NotEqual: (a, b) => a != b,
22
+ Same: (a, b) => a === b,
23
+ NotSame: (a, b) => a !== b,
24
+ //Similar: (a, b) => ,
25
+ //NotSimilar: (a, b) => ,
26
+ GreaterOrEqualThan: (a, b) => a >= b,
27
+ GreaterThan: (a, b) => a > b,
28
+ LessOrEqualThan: (a, b) => a <= b,
29
+ LessThan: (a, b) => a < b,
30
+ };
31
+ export const LogicalBinaryTable: OperatorTable<
32
+ (l: boolean, r: () => boolean) => boolean
33
+ > = {
34
+ And: (left: boolean, rightThunk: () => boolean) => left && rightThunk(),
35
+ Or: (left: boolean, rightThunk: () => boolean) => left || rightThunk(),
36
+ };
37
+
38
+ export const BitwiseBinaryTable: OperatorTable<BinaryOp<number>> = {
39
+ BitwiseOr: (a, b) => a | b,
40
+ BitwiseAnd: (a, b) => a & b,
41
+ BitwiseLeftShift: (a, b) => a << b,
42
+ BitwiseRightShift: (a, b) => a >> b,
43
+ BitwiseUnsignedRightShift: (a, b) => a >>> b,
44
+ BitwiseXor: (a, b) => a ^ b,
45
+ };
46
+
47
+ export const StringOperationTable: OperatorTable<BinaryOp<any, string>> = {
48
+ Concat: (a, b) => {
49
+ if (
50
+ (typeof a !== "string" && typeof a !== "number") ||
51
+ (typeof b !== "string" && typeof b !== "number")
52
+ ) {
53
+ throw new Error(
54
+ `String Concatenation: operands must be strings or numbers, got ${typeof a} and ${typeof b}`,
55
+ );
56
+ }
57
+ return String(a) + String(b);
58
+ },
59
+ };
60
+
61
+ export const BitwiseUnaryTable: OperatorTable<UnaryOp<number>> = {
62
+ BitwiseNot: (a) => ~a,
63
+ };
64
+ export const LogicalUnaryTable: OperatorTable<UnaryOp<boolean>> = {
65
+ Negation: (a: boolean) => !a,
66
+ };
67
+ export const ListBinaryTable: OperatorTable<BinaryOp<any, PrimitiveValue>> = {
68
+ Concat: (a, b) => {
69
+ const res = a.concat(b);
70
+ if (typeof a === "string" && typeof b === "string") {
71
+ const hasNonString = res.some((c: any) => typeof c !== "string");
72
+ if (!hasNonString) return res.join("");
73
+ }
74
+ return res;
75
+ },
76
+ };
77
+ export const ListUnaryTable: OperatorTable<UnaryOp<PrimitiveValue[], PrimitiveValue>> = {
78
+ Size: (a: PrimitiveValue[]) => a.length,
79
+ DetectMax: (a: PrimitiveValue[]) => {
80
+ if (!isArrayOfNumbers(a))
81
+ throw new Error("Operand of DetectMax must be Array of numbers");
82
+ return Math.max(...a);
83
+ },
84
+ DetectMin: (a: PrimitiveValue[]) => {
85
+ if (!isArrayOfNumbers(a))
86
+ throw new Error("Operand of DetectMin must be Array of numbers");
87
+ return Math.min(...a);
88
+ },
89
+ Flatten: (a: PrimitiveValue[]) => a.flat(),
90
+ };
91
+ export const ArithmeticUnaryTable: OperatorTable<UnaryOp<number, number | string>> = {
92
+ Round: (a) => Math.round(a),
93
+ Absolute: (a) => Math.abs(a),
94
+ Ceil: (a) => Math.ceil(a),
95
+ Floor: (a) => Math.floor(a),
96
+ Negation: (a) => a * -1,
97
+ Sqrt: (a) => Math.sqrt(a),
98
+ ToString: (a) => String(a),
99
+ };