@turnipxenon/pineapple 1.1.2 → 2.1.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 (235) hide show
  1. package/package.json +15 -6
  2. package/src/lib/app.postcss +106 -47
  3. package/src/lib/assets/icons/bitbucket-icon.svg +1 -0
  4. package/src/lib/assets/icons/github-mark.svg +1 -0
  5. package/src/lib/assets/icons/link-icon.svg +1 -0
  6. package/src/lib/assets/icons/linkedin.svg +1 -0
  7. package/src/lib/assets/icons/mail.svg +1 -0
  8. package/src/lib/assets/others/seaweed-showcase.mp4 +0 -0
  9. package/src/lib/assets/others/weaver-footage.gif +0 -0
  10. package/src/lib/assets/others/window-set.png +0 -0
  11. package/src/lib/assets/placeholder/placeholder_circle.png +0 -0
  12. package/src/lib/components/Card.svelte +24 -0
  13. package/src/lib/components/CarouselElement.svelte +23 -0
  14. package/src/lib/components/Chip.svelte +12 -0
  15. package/src/lib/components/ElementVisbilityDetector.svelte +22 -0
  16. package/src/lib/components/OnElementVisbilityChanged.ts +1 -0
  17. package/src/lib/components/RandomizedBackground.svelte +6 -4
  18. package/src/lib/components/RandomizedImage.svelte +23 -14
  19. package/src/lib/components/StickyElement.svelte +40 -0
  20. package/src/lib/components/ToggleableContent.svelte +86 -0
  21. package/src/lib/components/ToggleableContentType.ts +4 -0
  22. package/src/lib/components/layouts/LayoutConstants.ts +1 -0
  23. package/src/lib/components/{PineappleBaseLayout.svelte → layouts/PineappleBaseLayout.svelte} +73 -71
  24. package/src/lib/components/layouts/SeaweedBaseLayout.svelte +109 -0
  25. package/src/lib/consts.ts +2 -0
  26. package/src/lib/index.ts +1 -1
  27. package/src/lib/styles/global.css +1 -0
  28. package/src/lib/template/SeaweedTemplate.svelte +873 -0
  29. package/src/lib/theme.postcss +114 -105
  30. package/src/lib/util/create_go_to_function.ts +5 -0
  31. package/src/routes/+layout.svelte +19 -23
  32. package/src/routes/+page.svelte +9 -12
  33. package/src/routes/personal/+layout.svelte +23 -0
  34. package/src/routes/personal/+page.svelte +37 -0
  35. package/src/routes/portfolio/+page.server.ts +44 -0
  36. package/src/routes/portfolio/+page.svelte +19 -0
  37. package/src/routes/portfolio/SocialSection.svelte +93 -0
  38. package/src/routes/portfolio/actual/+page.svelte +10 -0
  39. package/static/robots.txt +5 -0
  40. package/dist/app.postcss +0 -94
  41. package/dist/assets/bg_tiled/bg_tiled_ares.png +0 -0
  42. package/dist/assets/bg_tiled/bg_tiled_corn.png +0 -0
  43. package/dist/assets/bg_tiled/bg_tiled_pineapple.png +0 -0
  44. package/dist/assets/bg_tiled/bg_tiled_reinhard.png +0 -0
  45. package/dist/assets/bg_tiled/bg_tiled_tomato.png +0 -0
  46. package/dist/assets/bg_tiled/bg_tiled_turnip.png +0 -0
  47. package/dist/assets/characters/ares/ares_blushing.webp +0 -0
  48. package/dist/assets/characters/ares/ares_disappointed.webp +0 -0
  49. package/dist/assets/characters/ares/ares_happy.webp +0 -0
  50. package/dist/assets/characters/ares/ares_lets_go.webp +0 -0
  51. package/dist/assets/characters/ares/ares_logo.webp +0 -0
  52. package/dist/assets/characters/ares/ares_mad.webp +0 -0
  53. package/dist/assets/characters/ares/ares_neutral.webp +0 -0
  54. package/dist/assets/characters/ares/ares_slightly_mad.webp +0 -0
  55. package/dist/assets/characters/ares/ares_surprised.webp +0 -0
  56. package/dist/assets/characters/ares/ares_yay.webp +0 -0
  57. package/dist/assets/game_dev/footage-chef-wings.gif +0 -0
  58. package/dist/assets/game_dev/footage-depreciation.webm +0 -0
  59. package/dist/assets/game_dev/footage-thinking-of-flowers.webm +0 -0
  60. package/dist/assets/game_dev/screenshot-game-jam-mama.png +0 -0
  61. package/dist/assets/game_dev/screenshot-string-hop.png +0 -0
  62. package/dist/assets/game_dev/screenshot-wet-ass-road.png +0 -0
  63. package/dist/assets/temp/background-image.jpg +0 -0
  64. package/dist/assets/temp/bitbucket-logo.png +0 -0
  65. package/dist/assets/temp/github-logo.png +0 -0
  66. package/dist/assets/temp/header-hep-cat.mp4 +0 -0
  67. package/dist/assets/temp/header-hep-cat.ogg +0 -0
  68. package/dist/assets/temp/header-hep-cat.webm +0 -0
  69. package/dist/assets/temp/header-pengi.mp4 +0 -0
  70. package/dist/assets/temp/header-pengi.webm +0 -0
  71. package/dist/assets/temp/header-soulwork.mp4 +0 -0
  72. package/dist/assets/temp/header-soulwork.ogg +0 -0
  73. package/dist/assets/temp/header-soulwork.webm +0 -0
  74. package/dist/components/DialogOverlay.svelte +0 -93
  75. package/dist/components/DialogOverlay.svelte.d.ts +0 -14
  76. package/dist/components/LazyAsset.svelte +0 -96
  77. package/dist/components/LazyAsset.svelte.d.ts +0 -20
  78. package/dist/components/LazyAssetType.d.ts +0 -10
  79. package/dist/components/LazyAssetType.js +0 -12
  80. package/dist/components/PineappleBaseLayout.svelte +0 -186
  81. package/dist/components/PineappleBaseLayout.svelte.d.ts +0 -19
  82. package/dist/components/RandomizedBackground.svelte +0 -62
  83. package/dist/components/RandomizedBackground.svelte.d.ts +0 -16
  84. package/dist/components/RandomizedImage.svelte +0 -29
  85. package/dist/components/RandomizedImage.svelte.d.ts +0 -17
  86. package/dist/components/dialog_manager/DialogManager.d.ts +0 -77
  87. package/dist/components/dialog_manager/DialogManager.js +0 -239
  88. package/dist/components/dialog_manager/DialogManagerStore.d.ts +0 -41
  89. package/dist/components/dialog_manager/DialogManagerStore.js +0 -45
  90. package/dist/components/dialog_manager/DialogProcessor.d.ts +0 -13
  91. package/dist/components/dialog_manager/DialogProcessor.js +0 -62
  92. package/dist/components/dialog_manager/DialogUtils.d.ts +0 -5
  93. package/dist/components/dialog_manager/DialogUtils.js +0 -8
  94. package/dist/components/dialog_manager/behavior_tree/core/BTreeUtils.d.ts +0 -15
  95. package/dist/components/dialog_manager/behavior_tree/core/BTreeUtils.js +0 -34
  96. package/dist/components/dialog_manager/behavior_tree/core/BaseBehaviorResult.d.ts +0 -4
  97. package/dist/components/dialog_manager/behavior_tree/core/BaseBehaviorResult.js +0 -1
  98. package/dist/components/dialog_manager/behavior_tree/core/BehaviorNode.d.ts +0 -3
  99. package/dist/components/dialog_manager/behavior_tree/core/BehaviorNode.js +0 -1
  100. package/dist/components/dialog_manager/behavior_tree/core/BehaviorStatus.d.ts +0 -5
  101. package/dist/components/dialog_manager/behavior_tree/core/BehaviorStatus.js +0 -6
  102. package/dist/components/dialog_manager/behavior_tree/core/SelectorNode.d.ts +0 -12
  103. package/dist/components/dialog_manager/behavior_tree/core/SelectorNode.js +0 -22
  104. package/dist/components/dialog_manager/behavior_tree/expression/ExpressionArguments.d.ts +0 -5
  105. package/dist/components/dialog_manager/behavior_tree/expression/ExpressionArguments.js +0 -1
  106. package/dist/components/dialog_manager/behavior_tree/expression/ExpressionBehaviorNode.d.ts +0 -4
  107. package/dist/components/dialog_manager/behavior_tree/expression/ExpressionBehaviorNode.js +0 -1
  108. package/dist/components/dialog_manager/behavior_tree/expression/ExpressionEvaluator.d.ts +0 -15
  109. package/dist/components/dialog_manager/behavior_tree/expression/ExpressionEvaluator.js +0 -220
  110. package/dist/components/dialog_manager/behavior_tree/expression/ExpressionResult.d.ts +0 -5
  111. package/dist/components/dialog_manager/behavior_tree/expression/ExpressionResult.js +0 -1
  112. package/dist/components/dialog_manager/behavior_tree/expression/ExpressionSelectorNode.d.ts +0 -8
  113. package/dist/components/dialog_manager/behavior_tree/expression/ExpressionSelectorNode.js +0 -15
  114. package/dist/components/dialog_manager/behavior_tree/expression/ExpressionState.d.ts +0 -3
  115. package/dist/components/dialog_manager/behavior_tree/expression/ExpressionState.js +0 -1
  116. package/dist/components/dialog_manager/behavior_tree/expression/OperandNode.d.ts +0 -10
  117. package/dist/components/dialog_manager/behavior_tree/expression/OperandNode.js +0 -15
  118. package/dist/components/dialog_manager/behavior_tree/expression/OperatorNode.d.ts +0 -11
  119. package/dist/components/dialog_manager/behavior_tree/expression/OperatorNode.js +0 -30
  120. package/dist/components/dialog_manager/behavior_tree/expression/commands/CommandExpressionNode.d.ts +0 -6
  121. package/dist/components/dialog_manager/behavior_tree/expression/commands/CommandExpressionNode.js +0 -21
  122. package/dist/components/dialog_manager/behavior_tree/expression/commands/CommandLogicNode.d.ts +0 -9
  123. package/dist/components/dialog_manager/behavior_tree/expression/commands/CommandLogicNode.js +0 -19
  124. package/dist/components/dialog_manager/behavior_tree/expression/commands/CommandMap.d.ts +0 -9
  125. package/dist/components/dialog_manager/behavior_tree/expression/commands/CommandMap.js +0 -18
  126. package/dist/components/dialog_manager/behavior_tree/expression/commands/RandomRangeCommand.d.ts +0 -15
  127. package/dist/components/dialog_manager/behavior_tree/expression/commands/RandomRangeCommand.js +0 -24
  128. package/dist/components/dialog_manager/behavior_tree/expression/commands/VisitedCommand.d.ts +0 -20
  129. package/dist/components/dialog_manager/behavior_tree/expression/commands/VisitedCommand.js +0 -32
  130. package/dist/components/dialog_manager/behavior_tree/expression/commands/VisitedCountCommand.d.ts +0 -13
  131. package/dist/components/dialog_manager/behavior_tree/expression/commands/VisitedCountCommand.js +0 -25
  132. package/dist/components/dialog_manager/behavior_tree/expression/operators/AndOperator.d.ts +0 -7
  133. package/dist/components/dialog_manager/behavior_tree/expression/operators/AndOperator.js +0 -15
  134. package/dist/components/dialog_manager/behavior_tree/expression/operators/EqualityOperator.d.ts +0 -7
  135. package/dist/components/dialog_manager/behavior_tree/expression/operators/EqualityOperator.js +0 -14
  136. package/dist/components/dialog_manager/behavior_tree/expression/operators/GreaterThanEqualOperator.d.ts +0 -7
  137. package/dist/components/dialog_manager/behavior_tree/expression/operators/GreaterThanEqualOperator.js +0 -12
  138. package/dist/components/dialog_manager/behavior_tree/expression/operators/GreaterThanOperator.d.ts +0 -7
  139. package/dist/components/dialog_manager/behavior_tree/expression/operators/GreaterThanOperator.js +0 -12
  140. package/dist/components/dialog_manager/behavior_tree/expression/operators/InequalityOperator.d.ts +0 -7
  141. package/dist/components/dialog_manager/behavior_tree/expression/operators/InequalityOperator.js +0 -12
  142. package/dist/components/dialog_manager/behavior_tree/expression/operators/LessThanEqualOperator.d.ts +0 -7
  143. package/dist/components/dialog_manager/behavior_tree/expression/operators/LessThanEqualOperator.js +0 -12
  144. package/dist/components/dialog_manager/behavior_tree/expression/operators/LessThanOperator.d.ts +0 -7
  145. package/dist/components/dialog_manager/behavior_tree/expression/operators/LessThanOperator.js +0 -12
  146. package/dist/components/dialog_manager/behavior_tree/expression/operators/NegationOperator.d.ts +0 -7
  147. package/dist/components/dialog_manager/behavior_tree/expression/operators/NegationOperator.js +0 -13
  148. package/dist/components/dialog_manager/behavior_tree/expression/operators/OperatorLogicNode.d.ts +0 -17
  149. package/dist/components/dialog_manager/behavior_tree/expression/operators/OperatorLogicNode.js +0 -32
  150. package/dist/components/dialog_manager/behavior_tree/expression/operators/OperatorMap.d.ts +0 -9
  151. package/dist/components/dialog_manager/behavior_tree/expression/operators/OperatorMap.js +0 -47
  152. package/dist/components/dialog_manager/behavior_tree/expression/operators/OrOperator.d.ts +0 -7
  153. package/dist/components/dialog_manager/behavior_tree/expression/operators/OrOperator.js +0 -13
  154. package/dist/components/dialog_manager/behavior_tree/expression/operators/XorOperator.d.ts +0 -7
  155. package/dist/components/dialog_manager/behavior_tree/expression/operators/XorOperator.js +0 -17
  156. package/dist/components/dialog_manager/behavior_tree/expression/operators/arithmetic/DivisionOperator.d.ts +0 -7
  157. package/dist/components/dialog_manager/behavior_tree/expression/operators/arithmetic/DivisionOperator.js +0 -14
  158. package/dist/components/dialog_manager/behavior_tree/expression/operators/arithmetic/MinusOperator.d.ts +0 -7
  159. package/dist/components/dialog_manager/behavior_tree/expression/operators/arithmetic/MinusOperator.js +0 -14
  160. package/dist/components/dialog_manager/behavior_tree/expression/operators/arithmetic/MultiplicationOperator.d.ts +0 -7
  161. package/dist/components/dialog_manager/behavior_tree/expression/operators/arithmetic/MultiplicationOperator.js +0 -12
  162. package/dist/components/dialog_manager/behavior_tree/expression/operators/arithmetic/PlusOperator.d.ts +0 -7
  163. package/dist/components/dialog_manager/behavior_tree/expression/operators/arithmetic/PlusOperator.js +0 -14
  164. package/dist/components/dialog_manager/behavior_tree/expression/operators/arithmetic/RemainderDivisionOperator.d.ts +0 -7
  165. package/dist/components/dialog_manager/behavior_tree/expression/operators/arithmetic/RemainderDivisionOperator.js +0 -14
  166. package/dist/components/dialog_manager/behavior_tree/line_core/LineBehaviorNode.d.ts +0 -4
  167. package/dist/components/dialog_manager/behavior_tree/line_core/LineBehaviorNode.js +0 -1
  168. package/dist/components/dialog_manager/behavior_tree/line_core/LineBehaviorResult.d.ts +0 -6
  169. package/dist/components/dialog_manager/behavior_tree/line_core/LineBehaviorResult.js +0 -1
  170. package/dist/components/dialog_manager/behavior_tree/line_core/LineNodeArguments.d.ts +0 -6
  171. package/dist/components/dialog_manager/behavior_tree/line_core/LineNodeArguments.js +0 -1
  172. package/dist/components/dialog_manager/behavior_tree/line_core/LineSelectorNode.d.ts +0 -8
  173. package/dist/components/dialog_manager/behavior_tree/line_core/LineSelectorNode.js +0 -15
  174. package/dist/components/dialog_manager/behavior_tree/line_processors/BehaviorState.d.ts +0 -5
  175. package/dist/components/dialog_manager/behavior_tree/line_processors/BehaviorState.js +0 -5
  176. package/dist/components/dialog_manager/behavior_tree/line_processors/ElseIfNode.d.ts +0 -11
  177. package/dist/components/dialog_manager/behavior_tree/line_processors/ElseIfNode.js +0 -53
  178. package/dist/components/dialog_manager/behavior_tree/line_processors/ElseNode.d.ts +0 -11
  179. package/dist/components/dialog_manager/behavior_tree/line_processors/ElseNode.js +0 -49
  180. package/dist/components/dialog_manager/behavior_tree/line_processors/EndIfNode.d.ts +0 -11
  181. package/dist/components/dialog_manager/behavior_tree/line_processors/EndIfNode.js +0 -23
  182. package/dist/components/dialog_manager/behavior_tree/line_processors/IfMode.d.ts +0 -6
  183. package/dist/components/dialog_manager/behavior_tree/line_processors/IfMode.js +0 -8
  184. package/dist/components/dialog_manager/behavior_tree/line_processors/IfNode.d.ts +0 -12
  185. package/dist/components/dialog_manager/behavior_tree/line_processors/IfNode.js +0 -43
  186. package/dist/components/dialog_manager/behavior_tree/line_processors/IgnoreGuardNode.d.ts +0 -11
  187. package/dist/components/dialog_manager/behavior_tree/line_processors/IgnoreGuardNode.js +0 -25
  188. package/dist/components/dialog_manager/behavior_tree/line_processors/IgnoreJumpNode.d.ts +0 -6
  189. package/dist/components/dialog_manager/behavior_tree/line_processors/IgnoreJumpNode.js +0 -18
  190. package/dist/components/dialog_manager/behavior_tree/line_processors/LineCommentNode.d.ts +0 -6
  191. package/dist/components/dialog_manager/behavior_tree/line_processors/LineCommentNode.js +0 -17
  192. package/dist/components/dialog_manager/behavior_tree/line_processors/NormalLineProcessorNode.d.ts +0 -10
  193. package/dist/components/dialog_manager/behavior_tree/line_processors/NormalLineProcessorNode.js +0 -38
  194. package/dist/components/dialog_manager/behavior_tree/line_processors/SetVariableNode.d.ts +0 -11
  195. package/dist/components/dialog_manager/behavior_tree/line_processors/SetVariableNode.js +0 -31
  196. package/dist/components/dialog_manager/behavior_tree/line_processors/commands/DeclareCommand.d.ts +0 -8
  197. package/dist/components/dialog_manager/behavior_tree/line_processors/commands/DeclareCommand.js +0 -39
  198. package/dist/components/dialog_manager/behavior_tree/line_processors/commands/JumpCommand.d.ts +0 -8
  199. package/dist/components/dialog_manager/behavior_tree/line_processors/commands/JumpCommand.js +0 -40
  200. package/dist/components/dialog_manager/behavior_tree/line_processors/commands/UnvisitCommand.d.ts +0 -9
  201. package/dist/components/dialog_manager/behavior_tree/line_processors/commands/UnvisitCommand.js +0 -28
  202. package/dist/index.d.ts +0 -8
  203. package/dist/index.js +0 -8
  204. package/dist/scripts/SetDefaultEnvironment.d.ts +0 -1
  205. package/dist/scripts/SetDefaultEnvironment.js +0 -41
  206. package/dist/scripts/pineapple_fiber/PineappleWeaver.d.ts +0 -9
  207. package/dist/scripts/pineapple_fiber/PineappleWeaver.js +0 -201
  208. package/dist/scripts/util/FileManagement.d.ts +0 -7
  209. package/dist/scripts/util/FileManagement.js +0 -35
  210. package/dist/scripts/util/ManualCheck.d.ts +0 -1
  211. package/dist/scripts/util/ManualCheck.js +0 -28
  212. package/dist/scripts/util/ManualCheckRun.d.ts +0 -1
  213. package/dist/scripts/util/ManualCheckRun.js +0 -6
  214. package/dist/store.d.ts +0 -17
  215. package/dist/store.js +0 -17
  216. package/dist/styles/DefaultGridContainer.css +0 -61
  217. package/dist/theme.postcss +0 -107
  218. package/dist/types/BlogBlurbMeta.d.ts +0 -11
  219. package/dist/types/BlogBlurbMeta.js +0 -16
  220. package/dist/types/BreadcrumbData.d.ts +0 -4
  221. package/dist/types/BreadcrumbData.js +0 -1
  222. package/dist/types/pineapple_fiber/DialogDetail.d.ts +0 -6
  223. package/dist/types/pineapple_fiber/DialogDetail.js +0 -1
  224. package/dist/types/pineapple_fiber/DialogState.d.ts +0 -5
  225. package/dist/types/pineapple_fiber/DialogState.js +0 -6
  226. package/dist/types/pineapple_fiber/DialogVariableStore.d.ts +0 -2
  227. package/dist/types/pineapple_fiber/DialogVariableStore.js +0 -20
  228. package/dist/types/pineapple_fiber/PortraitType.d.ts +0 -11
  229. package/dist/types/pineapple_fiber/PortraitType.js +0 -12
  230. package/dist/util/stable_random.d.ts +0 -2
  231. package/dist/util/stable_random.js +0 -15
  232. package/src/lib/assets/icons/chat_cursor.svg +0 -47
  233. package/src/lib/assets/icons/external_link.svg +0 -50
  234. /package/{dist/assets/icons/chat_cursor.svg → src/lib/assets/icons/chat-cursor.svg} +0 -0
  235. /package/{dist/assets/icons/external_link.svg → src/lib/assets/icons/external-link.svg} +0 -0
@@ -1,32 +0,0 @@
1
- import { CommandLogicNode } from "./CommandLogicNode";
2
- import { VisitedCountCommand } from "./VisitedCountCommand";
3
- /**
4
- * Used for command like
5
- * visited("node name here");
6
- *
7
- * Pushes a boolean in the operand stack
8
- *
9
- * Some design decision note:
10
- * I opted for composition over inheritance.
11
- * This may look like a good case for composition but my philosophy is if they both are equally
12
- * viable, always prefer composition. It will help in the long run if we do refactoring
13
- */
14
- export class VisitedCommand extends CommandLogicNode {
15
- visitedCountCommand = new VisitedCountCommand();
16
- doOperation = (currentOperands, nodeArgs) => {
17
- this.visitedCountCommand.process(nodeArgs);
18
- const value = Number(nodeArgs.initState.operandStack.pop());
19
- if (isNaN(value) || value === 0) {
20
- nodeArgs.initState.operandStack.push("false");
21
- }
22
- else {
23
- nodeArgs.initState.operandStack.push("true");
24
- }
25
- };
26
- getArgumentCount = () => {
27
- return 0; // let the child work; this is only a decorator
28
- };
29
- getToken = () => {
30
- return "#visited";
31
- };
32
- }
@@ -1,13 +0,0 @@
1
- import { CommandLogicNode } from "./CommandLogicNode";
2
- import type { ExpressionArguments } from "../ExpressionArguments";
3
- /**
4
- * Used for command like
5
- * visited_count("node name here");
6
- *
7
- * Pushed a number in the operand stack
8
- */
9
- export declare class VisitedCountCommand extends CommandLogicNode {
10
- doOperation: (currentOperands: string[], nodeArgs: ExpressionArguments) => void;
11
- getArgumentCount: () => number;
12
- getToken: () => string;
13
- }
@@ -1,25 +0,0 @@
1
- import { CommandLogicNode } from "./CommandLogicNode";
2
- import { dialogVariableStore } from "../../../DialogManagerStore";
3
- /**
4
- * Used for command like
5
- * visited_count("node name here");
6
- *
7
- * Pushed a number in the operand stack
8
- */
9
- export class VisitedCountCommand extends CommandLogicNode {
10
- doOperation = (currentOperands, nodeArgs) => {
11
- const value = Number(dialogVariableStore.getItem(`+${currentOperands[0]}`));
12
- if (isNaN(value) || value === 0) {
13
- nodeArgs.initState.operandStack.push("0");
14
- }
15
- else {
16
- nodeArgs.initState.operandStack.push(String(value));
17
- }
18
- };
19
- getArgumentCount = () => {
20
- return 1;
21
- };
22
- getToken = () => {
23
- return "#visited_count";
24
- };
25
- }
@@ -1,7 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "./OperatorLogicNode";
2
- import type { ExpressionArguments } from "../ExpressionArguments";
3
- export declare class AndOperator extends OperatorLogicNode {
4
- doOperation: (currentOperands: string[], nodeArgs: ExpressionArguments) => void;
5
- getOperatorType: () => OperatorType;
6
- getToken: () => string;
7
- }
@@ -1,15 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "./OperatorLogicNode";
2
- import { btreeUtils } from "../../core/BTreeUtils";
3
- export class AndOperator extends OperatorLogicNode {
4
- doOperation = (currentOperands, nodeArgs) => {
5
- // todo: evaluate possible weird cases when doing number comparisons
6
- // ISSUE #88 https://github.com/TurnipXenon/pineapple/issues/88
7
- nodeArgs.initState.operandStack.push(String(btreeUtils.isTrue(currentOperands[0]) && btreeUtils.isTrue(currentOperands[1])));
8
- };
9
- getOperatorType = () => {
10
- return OperatorType.Binary;
11
- };
12
- getToken = () => {
13
- return "&&";
14
- };
15
- }
@@ -1,7 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "./OperatorLogicNode";
2
- import type { ExpressionArguments } from "../ExpressionArguments";
3
- export declare class EqualityOperator extends OperatorLogicNode {
4
- doOperation: (currentOperands: string[], nodeArgs: ExpressionArguments) => void;
5
- getOperatorType: () => OperatorType;
6
- getToken: () => string;
7
- }
@@ -1,14 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "./OperatorLogicNode";
2
- export class EqualityOperator extends OperatorLogicNode {
3
- doOperation = (currentOperands, nodeArgs) => {
4
- // todo: evaluate possible weird cases when doing number comparisons
5
- // ISSUE #88 https://github.com/TurnipXenon/pineapple/issues/88
6
- nodeArgs.initState.operandStack.push(String(currentOperands[0] === currentOperands[1]));
7
- };
8
- getOperatorType = () => {
9
- return OperatorType.Binary;
10
- };
11
- getToken = () => {
12
- return "==";
13
- };
14
- }
@@ -1,7 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "./OperatorLogicNode";
2
- import type { ExpressionArguments } from "../ExpressionArguments";
3
- export declare class GreaterThanEqualOperator extends OperatorLogicNode {
4
- doOperation: (currentOperands: string[], nodeArgs: ExpressionArguments) => void;
5
- getOperatorType: () => OperatorType;
6
- getToken: () => string;
7
- }
@@ -1,12 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "./OperatorLogicNode";
2
- export class GreaterThanEqualOperator extends OperatorLogicNode {
3
- doOperation = (currentOperands, nodeArgs) => {
4
- nodeArgs.initState.operandStack.push(String(Number(currentOperands[0]) >= Number(currentOperands[1])));
5
- };
6
- getOperatorType = () => {
7
- return OperatorType.Binary;
8
- };
9
- getToken = () => {
10
- return ">=";
11
- };
12
- }
@@ -1,7 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "./OperatorLogicNode";
2
- import type { ExpressionArguments } from "../ExpressionArguments";
3
- export declare class GreaterThanOperator extends OperatorLogicNode {
4
- doOperation: (currentOperands: string[], nodeArgs: ExpressionArguments) => void;
5
- getOperatorType: () => OperatorType;
6
- getToken: () => string;
7
- }
@@ -1,12 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "./OperatorLogicNode";
2
- export class GreaterThanOperator extends OperatorLogicNode {
3
- doOperation = (currentOperands, nodeArgs) => {
4
- nodeArgs.initState.operandStack.push(String(Number(currentOperands[0]) > Number(currentOperands[1])));
5
- };
6
- getOperatorType = () => {
7
- return OperatorType.Binary;
8
- };
9
- getToken = () => {
10
- return ">";
11
- };
12
- }
@@ -1,7 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "./OperatorLogicNode";
2
- import type { ExpressionArguments } from "../ExpressionArguments";
3
- export declare class InequalityOperator extends OperatorLogicNode {
4
- doOperation: (currentOperands: string[], nodeArgs: ExpressionArguments) => void;
5
- getOperatorType: () => OperatorType;
6
- getToken: () => string;
7
- }
@@ -1,12 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "./OperatorLogicNode";
2
- export class InequalityOperator extends OperatorLogicNode {
3
- doOperation = (currentOperands, nodeArgs) => {
4
- nodeArgs.initState.operandStack.push(String(currentOperands[0] !== currentOperands[1]));
5
- };
6
- getOperatorType = () => {
7
- return OperatorType.Binary;
8
- };
9
- getToken = () => {
10
- return "!=";
11
- };
12
- }
@@ -1,7 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "./OperatorLogicNode";
2
- import type { ExpressionArguments } from "../ExpressionArguments";
3
- export declare class LessThanEqualOperator extends OperatorLogicNode {
4
- doOperation: (currentOperands: string[], nodeArgs: ExpressionArguments) => void;
5
- getOperatorType: () => OperatorType;
6
- getToken: () => string;
7
- }
@@ -1,12 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "./OperatorLogicNode";
2
- export class LessThanEqualOperator extends OperatorLogicNode {
3
- doOperation = (currentOperands, nodeArgs) => {
4
- nodeArgs.initState.operandStack.push(String(Number(currentOperands[0]) <= Number(currentOperands[1])));
5
- };
6
- getOperatorType = () => {
7
- return OperatorType.Binary;
8
- };
9
- getToken = () => {
10
- return "<=";
11
- };
12
- }
@@ -1,7 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "./OperatorLogicNode";
2
- import type { ExpressionArguments } from "../ExpressionArguments";
3
- export declare class LessThanOperator extends OperatorLogicNode {
4
- doOperation: (currentOperands: string[], nodeArgs: ExpressionArguments) => void;
5
- getOperatorType: () => OperatorType;
6
- getToken: () => string;
7
- }
@@ -1,12 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "./OperatorLogicNode";
2
- export class LessThanOperator extends OperatorLogicNode {
3
- doOperation = (currentOperands, nodeArgs) => {
4
- nodeArgs.initState.operandStack.push(String(Number(currentOperands[0]) < Number(currentOperands[1])));
5
- };
6
- getOperatorType = () => {
7
- return OperatorType.Binary;
8
- };
9
- getToken = () => {
10
- return "<";
11
- };
12
- }
@@ -1,7 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "./OperatorLogicNode";
2
- import type { ExpressionArguments } from "../ExpressionArguments";
3
- export declare class NegationOperator extends OperatorLogicNode {
4
- doOperation: (currentOperands: string[], nodeArgs: ExpressionArguments) => void;
5
- getOperatorType: () => OperatorType;
6
- getToken: () => string;
7
- }
@@ -1,13 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "./OperatorLogicNode";
2
- import { btreeUtils } from "../../core/BTreeUtils";
3
- export class NegationOperator extends OperatorLogicNode {
4
- doOperation = (currentOperands, nodeArgs) => {
5
- nodeArgs.initState.operandStack.push(String(!btreeUtils.isTrue(currentOperands[0])));
6
- };
7
- getOperatorType = () => {
8
- return OperatorType.Unary;
9
- };
10
- getToken = () => {
11
- return "!";
12
- };
13
- }
@@ -1,17 +0,0 @@
1
- import type { ExpressionBehaviorNode } from "../ExpressionBehaviorNode";
2
- import type { ExpressionArguments } from "../ExpressionArguments";
3
- import type { ExpressionResult } from "../ExpressionResult";
4
- export declare enum OperatorType {
5
- Unary = 0,
6
- Binary = 1
7
- }
8
- /**
9
- * a leaf node that will always run success
10
- * do the processing outside comparing with getToken
11
- */
12
- export declare abstract class OperatorLogicNode implements ExpressionBehaviorNode {
13
- abstract getToken: () => string;
14
- abstract getOperatorType: () => OperatorType;
15
- abstract doOperation: (currentOperands: string[], nodeArgs: ExpressionArguments) => void;
16
- process(nodeArgs: ExpressionArguments): ExpressionResult;
17
- }
@@ -1,32 +0,0 @@
1
- import { BehaviorStatus } from "../../core/BehaviorStatus";
2
- export var OperatorType;
3
- (function (OperatorType) {
4
- OperatorType[OperatorType["Unary"] = 0] = "Unary";
5
- OperatorType[OperatorType["Binary"] = 1] = "Binary";
6
- })(OperatorType || (OperatorType = {}));
7
- /**
8
- * a leaf node that will always run success
9
- * do the processing outside comparing with getToken
10
- */
11
- export class OperatorLogicNode {
12
- process(nodeArgs) {
13
- const currentOperands = [];
14
- switch (this.getOperatorType()) {
15
- case OperatorType.Unary:
16
- currentOperands.unshift(nodeArgs.initState.operandStack.pop());
17
- break;
18
- case OperatorType.Binary:
19
- currentOperands.unshift(nodeArgs.initState.operandStack.pop());
20
- currentOperands.unshift(nodeArgs.initState.operandStack.pop());
21
- break;
22
- default:
23
- console.error(`Unimplemented operator type: ${this.getOperatorType()}`);
24
- break;
25
- }
26
- this.doOperation(currentOperands, nodeArgs);
27
- return {
28
- nextState: nodeArgs.initState,
29
- status: BehaviorStatus.Success
30
- };
31
- }
32
- }
@@ -1,9 +0,0 @@
1
- import type { OperatorLogicNode } from "./OperatorLogicNode";
2
- declare class OperatorMap {
3
- _operatorLogicMap: Map<string, OperatorLogicNode>;
4
- constructor();
5
- get: (operator: string) => OperatorLogicNode | undefined;
6
- exists: (operator: string) => boolean;
7
- }
8
- export declare const operatorMap: OperatorMap;
9
- export {};
@@ -1,47 +0,0 @@
1
- import { EqualityOperator } from "./EqualityOperator";
2
- import { InequalityOperator } from "./InequalityOperator";
3
- import { GreaterThanOperator } from "./GreaterThanOperator";
4
- import { GreaterThanEqualOperator } from "./GreaterThanEqualOperator";
5
- import { LessThanOperator } from "./LessThanOperator";
6
- import { LessThanEqualOperator } from "./LessThanEqualOperator";
7
- import { NegationOperator } from "./NegationOperator";
8
- import { AndOperator } from "./AndOperator";
9
- import { OrOperator } from "./OrOperator";
10
- import { XorOperator } from "./XorOperator";
11
- import { AddOperator } from "./arithmetic/PlusOperator";
12
- import { MinusOperator } from "./arithmetic/MinusOperator";
13
- import { MultiplicationOperator } from "./arithmetic/MultiplicationOperator";
14
- import { DivisionOperator } from "./arithmetic/DivisionOperator";
15
- import { RemainderDivisionOperator } from "./arithmetic/RemainderDivisionOperator";
16
- class OperatorMap {
17
- _operatorLogicMap = new Map();
18
- constructor() {
19
- // set up operator logic
20
- [
21
- new EqualityOperator(),
22
- new InequalityOperator(),
23
- new GreaterThanOperator(),
24
- new GreaterThanEqualOperator(),
25
- new LessThanOperator(),
26
- new LessThanEqualOperator(),
27
- new NegationOperator(),
28
- new AndOperator(),
29
- new OrOperator(),
30
- new XorOperator(),
31
- new AddOperator(),
32
- new MinusOperator(),
33
- new MultiplicationOperator(),
34
- new DivisionOperator(),
35
- new RemainderDivisionOperator()
36
- ].forEach((operatorLogic) => {
37
- this._operatorLogicMap.set(operatorLogic.getToken(), operatorLogic);
38
- });
39
- }
40
- get = (operator) => {
41
- return this._operatorLogicMap.get(operator);
42
- };
43
- exists = (operator) => {
44
- return this.get(operator) !== undefined;
45
- };
46
- }
47
- export const operatorMap = new OperatorMap();
@@ -1,7 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "./OperatorLogicNode";
2
- import type { ExpressionArguments } from "../ExpressionArguments";
3
- export declare class OrOperator extends OperatorLogicNode {
4
- doOperation: (currentOperands: string[], nodeArgs: ExpressionArguments) => void;
5
- getOperatorType: () => OperatorType;
6
- getToken: () => string;
7
- }
@@ -1,13 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "./OperatorLogicNode";
2
- import { btreeUtils } from "../../core/BTreeUtils";
3
- export class OrOperator extends OperatorLogicNode {
4
- doOperation = (currentOperands, nodeArgs) => {
5
- nodeArgs.initState.operandStack.push(String(btreeUtils.isTrue(currentOperands[0]) || btreeUtils.isTrue(currentOperands[1])));
6
- };
7
- getOperatorType = () => {
8
- return OperatorType.Binary;
9
- };
10
- getToken = () => {
11
- return "||";
12
- };
13
- }
@@ -1,7 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "./OperatorLogicNode";
2
- import type { ExpressionArguments } from "../ExpressionArguments";
3
- export declare class XorOperator extends OperatorLogicNode {
4
- doOperation: (currentOperands: string[], nodeArgs: ExpressionArguments) => void;
5
- getOperatorType: () => OperatorType;
6
- getToken: () => string;
7
- }
@@ -1,17 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "./OperatorLogicNode";
2
- import { btreeUtils } from "../../core/BTreeUtils";
3
- export class XorOperator extends OperatorLogicNode {
4
- doOperation = (currentOperands, nodeArgs) => {
5
- // todo: evaluate possible weird cases when doing number comparisons
6
- // ISSUE #88 https://github.com/TurnipXenon/pineapple/issues/88
7
- const A = btreeUtils.isTrue(currentOperands[0]);
8
- const B = btreeUtils.isTrue(currentOperands[1]);
9
- nodeArgs.initState.operandStack.push(String(!((A && B) || A || B)));
10
- };
11
- getOperatorType = () => {
12
- return OperatorType.Binary;
13
- };
14
- getToken = () => {
15
- return "^";
16
- };
17
- }
@@ -1,7 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "../OperatorLogicNode";
2
- import type { ExpressionArguments } from "../../ExpressionArguments";
3
- export declare class DivisionOperator extends OperatorLogicNode {
4
- doOperation: (currentOperands: string[], nodeArgs: ExpressionArguments) => void;
5
- getOperatorType: () => OperatorType;
6
- getToken: () => string;
7
- }
@@ -1,14 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "../OperatorLogicNode";
2
- export class DivisionOperator extends OperatorLogicNode {
3
- doOperation = (currentOperands, nodeArgs) => {
4
- // todo: Add division protection
5
- // ISSUE #96 https://github.com/TurnipXenon/pineapple/issues/96
6
- nodeArgs.initState.operandStack.push(String(Number(currentOperands[0]) / Number(currentOperands[1])));
7
- };
8
- getOperatorType = () => {
9
- return OperatorType.Binary;
10
- };
11
- getToken = () => {
12
- return "/";
13
- };
14
- }
@@ -1,7 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "../OperatorLogicNode";
2
- import type { ExpressionArguments } from "../../ExpressionArguments";
3
- export declare class MinusOperator extends OperatorLogicNode {
4
- doOperation: (currentOperands: string[], nodeArgs: ExpressionArguments) => void;
5
- getOperatorType: () => OperatorType;
6
- getToken: () => string;
7
- }
@@ -1,14 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "../OperatorLogicNode";
2
- export class MinusOperator extends OperatorLogicNode {
3
- doOperation = (currentOperands, nodeArgs) => {
4
- // todo: evaluate possible weird cases when doing number comparisons
5
- // ISSUE #88 https://github.com/TurnipXenon/pineapple/issues/88
6
- nodeArgs.initState.operandStack.push(String(Number(currentOperands[0]) - Number(currentOperands[1])));
7
- };
8
- getOperatorType = () => {
9
- return OperatorType.Binary;
10
- };
11
- getToken = () => {
12
- return "-";
13
- };
14
- }
@@ -1,7 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "../OperatorLogicNode";
2
- import type { ExpressionArguments } from "../../ExpressionArguments";
3
- export declare class MultiplicationOperator extends OperatorLogicNode {
4
- doOperation: (currentOperands: string[], nodeArgs: ExpressionArguments) => void;
5
- getOperatorType: () => OperatorType;
6
- getToken: () => string;
7
- }
@@ -1,12 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "../OperatorLogicNode";
2
- export class MultiplicationOperator extends OperatorLogicNode {
3
- doOperation = (currentOperands, nodeArgs) => {
4
- nodeArgs.initState.operandStack.push(String(Number(currentOperands[0]) * Number(currentOperands[1])));
5
- };
6
- getOperatorType = () => {
7
- return OperatorType.Binary;
8
- };
9
- getToken = () => {
10
- return "*";
11
- };
12
- }
@@ -1,7 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "../OperatorLogicNode";
2
- import type { ExpressionArguments } from "../../ExpressionArguments";
3
- export declare class AddOperator extends OperatorLogicNode {
4
- doOperation: (currentOperands: string[], nodeArgs: ExpressionArguments) => void;
5
- getOperatorType: () => OperatorType;
6
- getToken: () => string;
7
- }
@@ -1,14 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "../OperatorLogicNode";
2
- export class AddOperator extends OperatorLogicNode {
3
- doOperation = (currentOperands, nodeArgs) => {
4
- // todo: evaluate possible weird cases when doing number comparisons
5
- // ISSUE #88 https://github.com/TurnipXenon/pineapple/issues/88
6
- nodeArgs.initState.operandStack.push(String(Number(currentOperands[0]) + Number(currentOperands[1])));
7
- };
8
- getOperatorType = () => {
9
- return OperatorType.Binary;
10
- };
11
- getToken = () => {
12
- return "+";
13
- };
14
- }
@@ -1,7 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "../OperatorLogicNode";
2
- import type { ExpressionArguments } from "../../ExpressionArguments";
3
- export declare class RemainderDivisionOperator extends OperatorLogicNode {
4
- doOperation: (currentOperands: string[], nodeArgs: ExpressionArguments) => void;
5
- getOperatorType: () => OperatorType;
6
- getToken: () => string;
7
- }
@@ -1,14 +0,0 @@
1
- import { OperatorLogicNode, OperatorType } from "../OperatorLogicNode";
2
- export class RemainderDivisionOperator extends OperatorLogicNode {
3
- doOperation = (currentOperands, nodeArgs) => {
4
- // todo: Add division protection
5
- // ISSUE #96 https://github.com/TurnipXenon/pineapple/issues/96
6
- nodeArgs.initState.operandStack.push(String(Number(currentOperands[0]) % Number(currentOperands[1])));
7
- };
8
- getOperatorType = () => {
9
- return OperatorType.Binary;
10
- };
11
- getToken = () => {
12
- return "%";
13
- };
14
- }
@@ -1,4 +0,0 @@
1
- import type { BehaviorNode } from "../core/BehaviorNode";
2
- import type { LineNodeArguments } from "./LineNodeArguments";
3
- import type { LineBehaviorResult } from "./LineBehaviorResult";
4
- export type LineBehaviorNode = BehaviorNode<LineNodeArguments, LineBehaviorResult>;
@@ -1,6 +0,0 @@
1
- import type { BehaviorState } from "../line_processors/BehaviorState";
2
- import type { BaseBehaviorResult } from "../core/BaseBehaviorResult";
3
- export interface LineBehaviorResult extends BaseBehaviorResult {
4
- renderedLine: string;
5
- nextState: BehaviorState;
6
- }
@@ -1,6 +0,0 @@
1
- import type { BehaviorState } from "../line_processors/BehaviorState";
2
- export interface LineNodeArguments {
3
- line: string;
4
- lineIndex: number;
5
- initState: BehaviorState;
6
- }
@@ -1,8 +0,0 @@
1
- import { SelectorNode } from "../core/SelectorNode";
2
- import type { LineNodeArguments } from "./LineNodeArguments";
3
- import type { LineBehaviorResult } from "./LineBehaviorResult";
4
- import type { LineBehaviorNode } from "./LineBehaviorNode";
5
- export declare class LineSelectorNode extends SelectorNode<LineNodeArguments, LineBehaviorResult> {
6
- constructor(nodeList: LineBehaviorNode[]);
7
- defaultResult: () => LineBehaviorResult;
8
- }
@@ -1,15 +0,0 @@
1
- import { SelectorNode } from "../core/SelectorNode";
2
- import { BehaviorState } from "../line_processors/BehaviorState";
3
- import { BehaviorStatus } from "../core/BehaviorStatus";
4
- export class LineSelectorNode extends SelectorNode {
5
- constructor(nodeList) {
6
- super(nodeList);
7
- }
8
- defaultResult = () => {
9
- return {
10
- nextState: new BehaviorState(),
11
- renderedLine: "",
12
- status: BehaviorStatus.Failure
13
- };
14
- };
15
- }
@@ -1,5 +0,0 @@
1
- import { IfMode } from "./IfMode";
2
- export declare class BehaviorState {
3
- ifModeStack: IfMode[];
4
- ignoreJumps: boolean;
5
- }
@@ -1,5 +0,0 @@
1
- import { IfMode } from "./IfMode";
2
- export class BehaviorState {
3
- ifModeStack = [IfMode.Search];
4
- ignoreJumps = false;
5
- }
@@ -1,11 +0,0 @@
1
- import type { LineNodeArguments } from "../line_core/LineNodeArguments";
2
- import type { LineBehaviorResult } from "../line_core/LineBehaviorResult";
3
- import type { LineBehaviorNode } from "../line_core/LineBehaviorNode";
4
- /**
5
- * ElseIfNode is a leaf node that returns:
6
- * - Success if it is an elseif node, and updates the behaviorState
7
- * - Failure if it is not an elseif node
8
- */
9
- export declare class ElseIfNode implements LineBehaviorNode {
10
- process(nodeArgs: LineNodeArguments): LineBehaviorResult;
11
- }