brighterscript 1.0.0-alpha.3 → 1.0.0-alpha.31

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 (608) hide show
  1. package/CHANGELOG.md +1249 -285
  2. package/README.md +61 -131
  3. package/bsconfig.schema.json +68 -2
  4. package/dist/ActionPipeline.d.ts +10 -0
  5. package/dist/ActionPipeline.js +40 -0
  6. package/dist/ActionPipeline.js.map +1 -0
  7. package/dist/AstValidationSegmenter.d.ts +42 -0
  8. package/dist/AstValidationSegmenter.js +232 -0
  9. package/dist/AstValidationSegmenter.js.map +1 -0
  10. package/dist/BsConfig.d.ts +51 -6
  11. package/dist/BusyStatusTracker.d.ts +31 -0
  12. package/dist/BusyStatusTracker.js +83 -0
  13. package/dist/BusyStatusTracker.js.map +1 -0
  14. package/dist/Cache.d.ts +5 -6
  15. package/dist/Cache.js +12 -11
  16. package/dist/Cache.js.map +1 -1
  17. package/dist/CacheVerifier.d.ts +7 -0
  18. package/dist/CacheVerifier.js +20 -0
  19. package/dist/CacheVerifier.js.map +1 -0
  20. package/dist/CodeActionUtil.d.ts +11 -2
  21. package/dist/CodeActionUtil.js +17 -3
  22. package/dist/CodeActionUtil.js.map +1 -1
  23. package/dist/CommentFlagProcessor.d.ts +7 -6
  24. package/dist/CommentFlagProcessor.js +10 -7
  25. package/dist/CommentFlagProcessor.js.map +1 -1
  26. package/dist/CrossScopeValidator.d.ts +67 -0
  27. package/dist/CrossScopeValidator.js +625 -0
  28. package/dist/CrossScopeValidator.js.map +1 -0
  29. package/dist/DependencyGraph.d.ts +8 -3
  30. package/dist/DependencyGraph.js +49 -16
  31. package/dist/DependencyGraph.js.map +1 -1
  32. package/dist/DiagnosticCollection.d.ts +5 -3
  33. package/dist/DiagnosticCollection.js +18 -16
  34. package/dist/DiagnosticCollection.js.map +1 -1
  35. package/dist/DiagnosticFilterer.d.ts +8 -4
  36. package/dist/DiagnosticFilterer.js +77 -44
  37. package/dist/DiagnosticFilterer.js.map +1 -1
  38. package/dist/DiagnosticManager.d.ts +56 -0
  39. package/dist/DiagnosticManager.js +218 -0
  40. package/dist/DiagnosticManager.js.map +1 -0
  41. package/dist/DiagnosticMessages.d.ts +187 -20
  42. package/dist/DiagnosticMessages.js +247 -29
  43. package/dist/DiagnosticMessages.js.map +1 -1
  44. package/dist/DiagnosticSeverityAdjuster.d.ts +7 -0
  45. package/dist/DiagnosticSeverityAdjuster.js +41 -0
  46. package/dist/DiagnosticSeverityAdjuster.js.map +1 -0
  47. package/dist/FunctionScope.d.ts +28 -0
  48. package/dist/FunctionScope.js +52 -0
  49. package/dist/FunctionScope.js.map +1 -0
  50. package/dist/KeyedThrottler.d.ts +3 -3
  51. package/dist/KeyedThrottler.js +3 -3
  52. package/dist/KeyedThrottler.js.map +1 -1
  53. package/dist/LanguageServer.d.ts +72 -47
  54. package/dist/LanguageServer.js +544 -312
  55. package/dist/LanguageServer.js.map +1 -1
  56. package/dist/Logger.d.ts +9 -10
  57. package/dist/Logger.js +36 -30
  58. package/dist/Logger.js.map +1 -1
  59. package/dist/PluginInterface.d.ts +29 -7
  60. package/dist/PluginInterface.js +90 -7
  61. package/dist/PluginInterface.js.map +1 -1
  62. package/dist/Program.d.ts +199 -100
  63. package/dist/Program.js +1056 -700
  64. package/dist/Program.js.map +1 -1
  65. package/dist/ProgramBuilder.d.ts +29 -18
  66. package/dist/ProgramBuilder.js +170 -132
  67. package/dist/ProgramBuilder.js.map +1 -1
  68. package/dist/Scope.d.ts +144 -109
  69. package/dist/Scope.js +533 -552
  70. package/dist/Scope.js.map +1 -1
  71. package/dist/SemanticTokenUtils.d.ts +14 -0
  72. package/dist/SemanticTokenUtils.js +85 -0
  73. package/dist/SemanticTokenUtils.js.map +1 -0
  74. package/dist/Stopwatch.d.ts +4 -0
  75. package/dist/Stopwatch.js +8 -1
  76. package/dist/Stopwatch.js.map +1 -1
  77. package/dist/SymbolTable.d.ts +91 -24
  78. package/dist/SymbolTable.js +290 -64
  79. package/dist/SymbolTable.js.map +1 -1
  80. package/dist/SymbolTypeFlag.d.ts +9 -0
  81. package/dist/SymbolTypeFlag.js +14 -0
  82. package/dist/SymbolTypeFlag.js.map +1 -0
  83. package/dist/Throttler.d.ts +12 -0
  84. package/dist/Throttler.js +39 -0
  85. package/dist/Throttler.js.map +1 -1
  86. package/dist/Watcher.d.ts +0 -3
  87. package/dist/Watcher.js +0 -3
  88. package/dist/Watcher.js.map +1 -1
  89. package/dist/XmlScope.d.ts +5 -15
  90. package/dist/XmlScope.js +35 -87
  91. package/dist/XmlScope.js.map +1 -1
  92. package/dist/astUtils/CachedLookups.d.ts +50 -0
  93. package/dist/astUtils/CachedLookups.js +331 -0
  94. package/dist/astUtils/CachedLookups.js.map +1 -0
  95. package/dist/astUtils/Editor.d.ts +69 -0
  96. package/dist/astUtils/Editor.js +245 -0
  97. package/dist/astUtils/Editor.js.map +1 -0
  98. package/dist/astUtils/Editor.spec.js +258 -0
  99. package/dist/astUtils/Editor.spec.js.map +1 -0
  100. package/dist/astUtils/creators.d.ts +33 -10
  101. package/dist/astUtils/creators.js +224 -30
  102. package/dist/astUtils/creators.js.map +1 -1
  103. package/dist/astUtils/creators.spec.js +5 -5
  104. package/dist/astUtils/creators.spec.js.map +1 -1
  105. package/dist/astUtils/reflection.d.ts +146 -82
  106. package/dist/astUtils/reflection.js +308 -132
  107. package/dist/astUtils/reflection.js.map +1 -1
  108. package/dist/astUtils/reflection.spec.js +267 -162
  109. package/dist/astUtils/reflection.spec.js.map +1 -1
  110. package/dist/astUtils/stackedVisitor.js.map +1 -1
  111. package/dist/astUtils/stackedVisitor.spec.js +14 -14
  112. package/dist/astUtils/stackedVisitor.spec.js.map +1 -1
  113. package/dist/astUtils/visitors.d.ts +115 -53
  114. package/dist/astUtils/visitors.js +70 -13
  115. package/dist/astUtils/visitors.js.map +1 -1
  116. package/dist/astUtils/visitors.spec.js +465 -51
  117. package/dist/astUtils/visitors.spec.js.map +1 -1
  118. package/dist/astUtils/xml.d.ts +9 -8
  119. package/dist/astUtils/xml.js +10 -5
  120. package/dist/astUtils/xml.js.map +1 -1
  121. package/dist/bscPlugin/BscPlugin.d.ts +22 -1
  122. package/dist/bscPlugin/BscPlugin.js +88 -0
  123. package/dist/bscPlugin/BscPlugin.js.map +1 -1
  124. package/dist/bscPlugin/CallExpressionInfo.d.ts +36 -0
  125. package/dist/bscPlugin/CallExpressionInfo.js +131 -0
  126. package/dist/bscPlugin/CallExpressionInfo.js.map +1 -0
  127. package/dist/bscPlugin/FileWriter.d.ts +6 -0
  128. package/dist/bscPlugin/FileWriter.js +24 -0
  129. package/dist/bscPlugin/FileWriter.js.map +1 -0
  130. package/dist/bscPlugin/SignatureHelpUtil.d.ts +10 -0
  131. package/dist/bscPlugin/SignatureHelpUtil.js +137 -0
  132. package/dist/bscPlugin/SignatureHelpUtil.js.map +1 -0
  133. package/dist/bscPlugin/codeActions/CodeActionsProcessor.d.ts +1 -1
  134. package/dist/bscPlugin/codeActions/CodeActionsProcessor.js +26 -17
  135. package/dist/bscPlugin/codeActions/CodeActionsProcessor.js.map +1 -1
  136. package/dist/bscPlugin/codeActions/CodeActionsProcessor.spec.js +94 -20
  137. package/dist/bscPlugin/codeActions/CodeActionsProcessor.spec.js.map +1 -1
  138. package/dist/bscPlugin/completions/CompletionsProcessor.d.ts +60 -0
  139. package/dist/bscPlugin/completions/CompletionsProcessor.js +601 -0
  140. package/dist/bscPlugin/completions/CompletionsProcessor.js.map +1 -0
  141. package/dist/bscPlugin/completions/CompletionsProcessor.spec.js +2139 -0
  142. package/dist/bscPlugin/completions/CompletionsProcessor.spec.js.map +1 -0
  143. package/dist/bscPlugin/definition/DefinitionProvider.d.ts +13 -0
  144. package/dist/bscPlugin/definition/DefinitionProvider.js +210 -0
  145. package/dist/bscPlugin/definition/DefinitionProvider.js.map +1 -0
  146. package/dist/bscPlugin/definition/DefinitionProvider.spec.js +88 -0
  147. package/dist/bscPlugin/definition/DefinitionProvider.spec.js.map +1 -0
  148. package/dist/bscPlugin/fileProviders/FileProvider.d.ts +9 -0
  149. package/dist/bscPlugin/fileProviders/FileProvider.js +51 -0
  150. package/dist/bscPlugin/fileProviders/FileProvider.js.map +1 -0
  151. package/dist/bscPlugin/hover/HoverProcessor.d.ts +18 -0
  152. package/dist/bscPlugin/hover/HoverProcessor.js +218 -0
  153. package/dist/bscPlugin/hover/HoverProcessor.js.map +1 -0
  154. package/dist/bscPlugin/hover/HoverProcessor.spec.d.ts +1 -0
  155. package/dist/bscPlugin/hover/HoverProcessor.spec.js +737 -0
  156. package/dist/bscPlugin/hover/HoverProcessor.spec.js.map +1 -0
  157. package/dist/bscPlugin/references/ReferencesProvider.d.ts +12 -0
  158. package/dist/bscPlugin/references/ReferencesProvider.js +56 -0
  159. package/dist/bscPlugin/references/ReferencesProvider.js.map +1 -0
  160. package/dist/bscPlugin/references/ReferencesProvider.spec.d.ts +1 -0
  161. package/dist/bscPlugin/references/ReferencesProvider.spec.js +51 -0
  162. package/dist/bscPlugin/references/ReferencesProvider.spec.js.map +1 -0
  163. package/dist/bscPlugin/semanticTokens/BrsFileSemanticTokensProcessor.d.ts +14 -0
  164. package/dist/bscPlugin/semanticTokens/BrsFileSemanticTokensProcessor.js +144 -0
  165. package/dist/bscPlugin/semanticTokens/BrsFileSemanticTokensProcessor.js.map +1 -0
  166. package/dist/bscPlugin/semanticTokens/BrsFileSemanticTokensProcessor.spec.d.ts +1 -0
  167. package/dist/bscPlugin/semanticTokens/BrsFileSemanticTokensProcessor.spec.js +504 -0
  168. package/dist/bscPlugin/semanticTokens/BrsFileSemanticTokensProcessor.spec.js.map +1 -0
  169. package/dist/bscPlugin/serialize/BslibInjector.spec.d.ts +1 -0
  170. package/dist/bscPlugin/serialize/BslibInjector.spec.js +19 -0
  171. package/dist/bscPlugin/serialize/BslibInjector.spec.js.map +1 -0
  172. package/dist/bscPlugin/serialize/BslibManager.d.ts +9 -0
  173. package/dist/bscPlugin/serialize/BslibManager.js +40 -0
  174. package/dist/bscPlugin/serialize/BslibManager.js.map +1 -0
  175. package/dist/bscPlugin/serialize/FileSerializer.d.ts +9 -0
  176. package/dist/bscPlugin/serialize/FileSerializer.js +72 -0
  177. package/dist/bscPlugin/serialize/FileSerializer.js.map +1 -0
  178. package/dist/bscPlugin/symbols/DocumentSymbolProcessor.d.ts +7 -0
  179. package/dist/bscPlugin/symbols/DocumentSymbolProcessor.js +22 -0
  180. package/dist/bscPlugin/symbols/DocumentSymbolProcessor.js.map +1 -0
  181. package/dist/bscPlugin/symbols/DocumentSymbolProcessor.spec.d.ts +1 -0
  182. package/dist/bscPlugin/symbols/DocumentSymbolProcessor.spec.js +291 -0
  183. package/dist/bscPlugin/symbols/DocumentSymbolProcessor.spec.js.map +1 -0
  184. package/dist/bscPlugin/symbols/WorkspaceSymbolProcessor.d.ts +7 -0
  185. package/dist/bscPlugin/symbols/WorkspaceSymbolProcessor.js +26 -0
  186. package/dist/bscPlugin/symbols/WorkspaceSymbolProcessor.js.map +1 -0
  187. package/dist/bscPlugin/symbols/WorkspaceSymbolProcessor.spec.d.ts +1 -0
  188. package/dist/bscPlugin/symbols/WorkspaceSymbolProcessor.spec.js +245 -0
  189. package/dist/bscPlugin/symbols/WorkspaceSymbolProcessor.spec.js.map +1 -0
  190. package/dist/bscPlugin/symbols/symbolUtils.d.ts +5 -0
  191. package/dist/bscPlugin/symbols/symbolUtils.js +140 -0
  192. package/dist/bscPlugin/symbols/symbolUtils.js.map +1 -0
  193. package/dist/bscPlugin/transpile/BrsFileTranspileProcessor.d.ts +21 -0
  194. package/dist/bscPlugin/transpile/BrsFileTranspileProcessor.js +199 -0
  195. package/dist/bscPlugin/transpile/BrsFileTranspileProcessor.js.map +1 -0
  196. package/dist/bscPlugin/transpile/BrsFileTranspileProcessor.spec.d.ts +1 -0
  197. package/dist/bscPlugin/transpile/BrsFileTranspileProcessor.spec.js +41 -0
  198. package/dist/bscPlugin/transpile/BrsFileTranspileProcessor.spec.js.map +1 -0
  199. package/dist/bscPlugin/transpile/XmlFilePreTranspileProcessor.d.ts +12 -0
  200. package/dist/bscPlugin/transpile/XmlFilePreTranspileProcessor.js +99 -0
  201. package/dist/bscPlugin/transpile/XmlFilePreTranspileProcessor.js.map +1 -0
  202. package/dist/bscPlugin/validation/BrsFileAfterValidator.d.ts +7 -0
  203. package/dist/bscPlugin/validation/BrsFileAfterValidator.js +18 -0
  204. package/dist/bscPlugin/validation/BrsFileAfterValidator.js.map +1 -0
  205. package/dist/bscPlugin/validation/BrsFileValidator.d.ts +34 -0
  206. package/dist/bscPlugin/validation/BrsFileValidator.js +462 -0
  207. package/dist/bscPlugin/validation/BrsFileValidator.js.map +1 -0
  208. package/dist/bscPlugin/validation/BrsFileValidator.spec.d.ts +1 -0
  209. package/dist/bscPlugin/validation/BrsFileValidator.spec.js +758 -0
  210. package/dist/bscPlugin/validation/BrsFileValidator.spec.js.map +1 -0
  211. package/dist/bscPlugin/validation/ProgramValidator.d.ts +11 -0
  212. package/dist/bscPlugin/validation/ProgramValidator.js +33 -0
  213. package/dist/bscPlugin/validation/ProgramValidator.js.map +1 -0
  214. package/dist/bscPlugin/validation/ScopeValidator.d.ts +123 -0
  215. package/dist/bscPlugin/validation/ScopeValidator.js +1026 -0
  216. package/dist/bscPlugin/validation/ScopeValidator.js.map +1 -0
  217. package/dist/bscPlugin/validation/ScopeValidator.spec.d.ts +1 -0
  218. package/dist/bscPlugin/validation/ScopeValidator.spec.js +2897 -0
  219. package/dist/bscPlugin/validation/ScopeValidator.spec.js.map +1 -0
  220. package/dist/bscPlugin/validation/XmlFileValidator.d.ts +8 -0
  221. package/dist/bscPlugin/validation/XmlFileValidator.js +44 -0
  222. package/dist/bscPlugin/validation/XmlFileValidator.js.map +1 -0
  223. package/dist/cli.js +117 -11
  224. package/dist/cli.js.map +1 -1
  225. package/dist/deferred.d.ts +3 -3
  226. package/dist/deferred.js.map +1 -1
  227. package/dist/diagnosticUtils.d.ts +10 -3
  228. package/dist/diagnosticUtils.js +58 -21
  229. package/dist/diagnosticUtils.js.map +1 -1
  230. package/dist/examples/plugins/removePrint.js +8 -12
  231. package/dist/examples/plugins/removePrint.js.map +1 -1
  232. package/dist/files/AssetFile.d.ts +24 -0
  233. package/dist/files/AssetFile.js +25 -0
  234. package/dist/files/AssetFile.js.map +1 -0
  235. package/dist/files/BrsFile.Class.spec.js +858 -153
  236. package/dist/files/BrsFile.Class.spec.js.map +1 -1
  237. package/dist/files/BrsFile.d.ts +147 -82
  238. package/dist/files/BrsFile.js +853 -911
  239. package/dist/files/BrsFile.js.map +1 -1
  240. package/dist/files/BrsFile.spec.js +3056 -836
  241. package/dist/files/BrsFile.spec.js.map +1 -1
  242. package/dist/files/BscFile.d.ts +101 -0
  243. package/dist/files/BscFile.js +15 -0
  244. package/dist/files/BscFile.js.map +1 -0
  245. package/dist/files/Factory.d.ts +25 -0
  246. package/dist/files/Factory.js +22 -0
  247. package/dist/files/Factory.js.map +1 -0
  248. package/dist/files/LazyFileData.d.ts +20 -0
  249. package/dist/files/LazyFileData.js +54 -0
  250. package/dist/files/LazyFileData.js.map +1 -0
  251. package/dist/files/LazyFileData.spec.d.ts +1 -0
  252. package/dist/files/LazyFileData.spec.js +27 -0
  253. package/dist/files/LazyFileData.spec.js.map +1 -0
  254. package/dist/files/XmlFile.d.ts +73 -41
  255. package/dist/files/XmlFile.js +126 -138
  256. package/dist/files/XmlFile.js.map +1 -1
  257. package/dist/files/XmlFile.spec.js +450 -318
  258. package/dist/files/XmlFile.spec.js.map +1 -1
  259. package/dist/files/tests/imports.spec.js +62 -52
  260. package/dist/files/tests/imports.spec.js.map +1 -1
  261. package/dist/files/tests/optionalChaning.spec.d.ts +1 -0
  262. package/dist/files/tests/optionalChaning.spec.js +152 -0
  263. package/dist/files/tests/optionalChaning.spec.js.map +1 -0
  264. package/dist/globalCallables.d.ts +3 -1
  265. package/dist/globalCallables.js +416 -162
  266. package/dist/globalCallables.js.map +1 -1
  267. package/dist/index.d.ts +25 -3
  268. package/dist/index.js +42 -5
  269. package/dist/index.js.map +1 -1
  270. package/dist/interfaces.d.ts +717 -119
  271. package/dist/interfaces.js +21 -0
  272. package/dist/interfaces.js.map +1 -1
  273. package/dist/lexer/Character.spec.js +5 -5
  274. package/dist/lexer/Character.spec.js.map +1 -1
  275. package/dist/lexer/Lexer.d.ts +40 -9
  276. package/dist/lexer/Lexer.js +191 -49
  277. package/dist/lexer/Lexer.js.map +1 -1
  278. package/dist/lexer/Lexer.spec.js +775 -563
  279. package/dist/lexer/Lexer.spec.js.map +1 -1
  280. package/dist/lexer/Token.d.ts +11 -3
  281. package/dist/lexer/Token.js +10 -2
  282. package/dist/lexer/Token.js.map +1 -1
  283. package/dist/lexer/TokenKind.d.ts +27 -1
  284. package/dist/lexer/TokenKind.js +112 -5
  285. package/dist/lexer/TokenKind.js.map +1 -1
  286. package/dist/logging.d.ts +9 -0
  287. package/dist/logging.js +16 -0
  288. package/dist/logging.js.map +1 -0
  289. package/dist/parser/AstNode.d.ts +181 -0
  290. package/dist/parser/AstNode.js +246 -0
  291. package/dist/parser/AstNode.js.map +1 -0
  292. package/dist/parser/AstNode.spec.d.ts +1 -0
  293. package/dist/parser/AstNode.spec.js +165 -0
  294. package/dist/parser/AstNode.spec.js.map +1 -0
  295. package/dist/parser/BrsTranspileState.d.ts +12 -2
  296. package/dist/parser/BrsTranspileState.js +6 -0
  297. package/dist/parser/BrsTranspileState.js.map +1 -1
  298. package/dist/parser/Expression.d.ts +454 -210
  299. package/dist/parser/Expression.js +953 -498
  300. package/dist/parser/Expression.js.map +1 -1
  301. package/dist/parser/Parser.Class.spec.js +200 -95
  302. package/dist/parser/Parser.Class.spec.js.map +1 -1
  303. package/dist/parser/Parser.d.ts +106 -120
  304. package/dist/parser/Parser.js +1432 -931
  305. package/dist/parser/Parser.js.map +1 -1
  306. package/dist/parser/Parser.spec.d.ts +3 -1
  307. package/dist/parser/Parser.spec.js +1383 -456
  308. package/dist/parser/Parser.spec.js.map +1 -1
  309. package/dist/parser/SGParser.d.ts +44 -6
  310. package/dist/parser/SGParser.js +212 -185
  311. package/dist/parser/SGParser.js.map +1 -1
  312. package/dist/parser/SGParser.spec.js +30 -28
  313. package/dist/parser/SGParser.spec.js.map +1 -1
  314. package/dist/parser/SGTypes.d.ts +293 -50
  315. package/dist/parser/SGTypes.js +540 -187
  316. package/dist/parser/SGTypes.js.map +1 -1
  317. package/dist/parser/Statement.d.ts +759 -247
  318. package/dist/parser/Statement.js +1785 -607
  319. package/dist/parser/Statement.js.map +1 -1
  320. package/dist/parser/Statement.spec.js +45 -34
  321. package/dist/parser/Statement.spec.js.map +1 -1
  322. package/dist/parser/TranspileState.d.ts +18 -8
  323. package/dist/parser/TranspileState.js +76 -12
  324. package/dist/parser/TranspileState.js.map +1 -1
  325. package/dist/parser/tests/Parser.spec.d.ts +10 -9
  326. package/dist/parser/tests/Parser.spec.js +18 -14
  327. package/dist/parser/tests/Parser.spec.js.map +1 -1
  328. package/dist/parser/tests/controlFlow/For.spec.js +79 -69
  329. package/dist/parser/tests/controlFlow/For.spec.js.map +1 -1
  330. package/dist/parser/tests/controlFlow/ForEach.spec.js +53 -47
  331. package/dist/parser/tests/controlFlow/ForEach.spec.js.map +1 -1
  332. package/dist/parser/tests/controlFlow/If.spec.js +217 -196
  333. package/dist/parser/tests/controlFlow/If.spec.js.map +1 -1
  334. package/dist/parser/tests/controlFlow/While.spec.js +48 -42
  335. package/dist/parser/tests/controlFlow/While.spec.js.map +1 -1
  336. package/dist/parser/tests/expression/Additive.spec.js +31 -31
  337. package/dist/parser/tests/expression/Additive.spec.js.map +1 -1
  338. package/dist/parser/tests/expression/ArrayLiterals.spec.js +157 -120
  339. package/dist/parser/tests/expression/ArrayLiterals.spec.js.map +1 -1
  340. package/dist/parser/tests/expression/AssociativeArrayLiterals.spec.js +202 -139
  341. package/dist/parser/tests/expression/AssociativeArrayLiterals.spec.js.map +1 -1
  342. package/dist/parser/tests/expression/Boolean.spec.js +25 -25
  343. package/dist/parser/tests/expression/Boolean.spec.js.map +1 -1
  344. package/dist/parser/tests/expression/Call.spec.js +150 -41
  345. package/dist/parser/tests/expression/Call.spec.js.map +1 -1
  346. package/dist/parser/tests/expression/Exponential.spec.js +18 -18
  347. package/dist/parser/tests/expression/Exponential.spec.js.map +1 -1
  348. package/dist/parser/tests/expression/Function.spec.js +257 -257
  349. package/dist/parser/tests/expression/Function.spec.js.map +1 -1
  350. package/dist/parser/tests/expression/Indexing.spec.js +160 -90
  351. package/dist/parser/tests/expression/Indexing.spec.js.map +1 -1
  352. package/dist/parser/tests/expression/Multiplicative.spec.js +38 -38
  353. package/dist/parser/tests/expression/Multiplicative.spec.js.map +1 -1
  354. package/dist/parser/tests/expression/NullCoalescenceExpression.spec.js +196 -98
  355. package/dist/parser/tests/expression/NullCoalescenceExpression.spec.js.map +1 -1
  356. package/dist/parser/tests/expression/PrefixUnary.spec.js +42 -42
  357. package/dist/parser/tests/expression/PrefixUnary.spec.js.map +1 -1
  358. package/dist/parser/tests/expression/Primary.spec.js +42 -42
  359. package/dist/parser/tests/expression/Primary.spec.js.map +1 -1
  360. package/dist/parser/tests/expression/RegexLiteralExpression.spec.d.ts +1 -0
  361. package/dist/parser/tests/expression/RegexLiteralExpression.spec.js +171 -0
  362. package/dist/parser/tests/expression/RegexLiteralExpression.spec.js.map +1 -0
  363. package/dist/parser/tests/expression/Relational.spec.js +44 -44
  364. package/dist/parser/tests/expression/Relational.spec.js.map +1 -1
  365. package/dist/parser/tests/expression/SourceLiteralExpression.spec.js +31 -31
  366. package/dist/parser/tests/expression/SourceLiteralExpression.spec.js.map +1 -1
  367. package/dist/parser/tests/expression/TemplateStringExpression.spec.js +230 -90
  368. package/dist/parser/tests/expression/TemplateStringExpression.spec.js.map +1 -1
  369. package/dist/parser/tests/expression/TernaryExpression.spec.js +377 -148
  370. package/dist/parser/tests/expression/TernaryExpression.spec.js.map +1 -1
  371. package/dist/parser/tests/expression/TypeExpression.spec.d.ts +1 -0
  372. package/dist/parser/tests/expression/TypeExpression.spec.js +126 -0
  373. package/dist/parser/tests/expression/TypeExpression.spec.js.map +1 -0
  374. package/dist/parser/tests/expression/UnaryExpression.spec.d.ts +1 -0
  375. package/dist/parser/tests/expression/UnaryExpression.spec.js +52 -0
  376. package/dist/parser/tests/expression/UnaryExpression.spec.js.map +1 -0
  377. package/dist/parser/tests/statement/AssignmentOperators.spec.js +37 -37
  378. package/dist/parser/tests/statement/AssignmentOperators.spec.js.map +1 -1
  379. package/dist/parser/tests/statement/ConstStatement.spec.d.ts +1 -0
  380. package/dist/parser/tests/statement/ConstStatement.spec.js +262 -0
  381. package/dist/parser/tests/statement/ConstStatement.spec.js.map +1 -0
  382. package/dist/parser/tests/statement/Continue.spec.d.ts +1 -0
  383. package/dist/parser/tests/statement/Continue.spec.js +119 -0
  384. package/dist/parser/tests/statement/Continue.spec.js.map +1 -0
  385. package/dist/parser/tests/statement/Declaration.spec.js +45 -45
  386. package/dist/parser/tests/statement/Declaration.spec.js.map +1 -1
  387. package/dist/parser/tests/statement/Dim.spec.js +22 -22
  388. package/dist/parser/tests/statement/Dim.spec.js.map +1 -1
  389. package/dist/parser/tests/statement/Enum.spec.d.ts +1 -0
  390. package/dist/parser/tests/statement/Enum.spec.js +745 -0
  391. package/dist/parser/tests/statement/Enum.spec.js.map +1 -0
  392. package/dist/parser/tests/statement/For.spec.d.ts +1 -0
  393. package/dist/parser/tests/statement/For.spec.js +45 -0
  394. package/dist/parser/tests/statement/For.spec.js.map +1 -0
  395. package/dist/parser/tests/statement/ForEach.spec.d.ts +1 -0
  396. package/dist/parser/tests/statement/ForEach.spec.js +36 -0
  397. package/dist/parser/tests/statement/ForEach.spec.js.map +1 -0
  398. package/dist/parser/tests/statement/Function.spec.js +208 -198
  399. package/dist/parser/tests/statement/Function.spec.js.map +1 -1
  400. package/dist/parser/tests/statement/Goto.spec.js +16 -15
  401. package/dist/parser/tests/statement/Goto.spec.js.map +1 -1
  402. package/dist/parser/tests/statement/Increment.spec.js +51 -51
  403. package/dist/parser/tests/statement/Increment.spec.js.map +1 -1
  404. package/dist/parser/tests/statement/InterfaceStatement.spec.d.ts +1 -0
  405. package/dist/parser/tests/statement/InterfaceStatement.spec.js +110 -0
  406. package/dist/parser/tests/statement/InterfaceStatement.spec.js.map +1 -0
  407. package/dist/parser/tests/statement/LibraryStatement.spec.js +18 -18
  408. package/dist/parser/tests/statement/LibraryStatement.spec.js.map +1 -1
  409. package/dist/parser/tests/statement/Misc.spec.js +123 -163
  410. package/dist/parser/tests/statement/Misc.spec.js.map +1 -1
  411. package/dist/parser/tests/statement/PrintStatement.spec.js +125 -108
  412. package/dist/parser/tests/statement/PrintStatement.spec.js.map +1 -1
  413. package/dist/parser/tests/statement/ReturnStatement.spec.js +51 -49
  414. package/dist/parser/tests/statement/ReturnStatement.spec.js.map +1 -1
  415. package/dist/parser/tests/statement/Set.spec.js +110 -97
  416. package/dist/parser/tests/statement/Set.spec.js.map +1 -1
  417. package/dist/parser/tests/statement/Stop.spec.js +13 -12
  418. package/dist/parser/tests/statement/Stop.spec.js.map +1 -1
  419. package/dist/parser/tests/statement/Throw.spec.js +6 -6
  420. package/dist/parser/tests/statement/Throw.spec.js.map +1 -1
  421. package/dist/parser/tests/statement/TryCatch.spec.js +26 -15
  422. package/dist/parser/tests/statement/TryCatch.spec.js.map +1 -1
  423. package/dist/preprocessor/Manifest.d.ts +6 -6
  424. package/dist/preprocessor/Manifest.js +17 -38
  425. package/dist/preprocessor/Manifest.js.map +1 -1
  426. package/dist/preprocessor/Manifest.spec.d.ts +1 -0
  427. package/dist/preprocessor/Manifest.spec.js +78 -103
  428. package/dist/preprocessor/Manifest.spec.js.map +1 -1
  429. package/dist/roku-types/data.json +19369 -0
  430. package/dist/roku-types/index.d.ts +5497 -0
  431. package/dist/roku-types/index.js +11 -0
  432. package/dist/roku-types/index.js.map +1 -0
  433. package/dist/types/ArrayType.d.ts +9 -5
  434. package/dist/types/ArrayType.js +68 -24
  435. package/dist/types/ArrayType.js.map +1 -1
  436. package/dist/types/ArrayType.spec.js +39 -11
  437. package/dist/types/ArrayType.spec.js.map +1 -1
  438. package/dist/types/AssociativeArrayType.d.ts +14 -0
  439. package/dist/types/AssociativeArrayType.js +60 -0
  440. package/dist/types/AssociativeArrayType.js.map +1 -0
  441. package/dist/types/BaseFunctionType.d.ts +9 -0
  442. package/dist/types/BaseFunctionType.js +25 -0
  443. package/dist/types/BaseFunctionType.js.map +1 -0
  444. package/dist/types/BooleanType.d.ts +10 -5
  445. package/dist/types/BooleanType.js +21 -9
  446. package/dist/types/BooleanType.js.map +1 -1
  447. package/dist/types/BooleanType.spec.js +10 -4
  448. package/dist/types/BooleanType.spec.js.map +1 -1
  449. package/dist/types/BscType.d.ts +29 -3
  450. package/dist/types/BscType.js +121 -0
  451. package/dist/types/BscType.js.map +1 -1
  452. package/dist/types/BscTypeKind.d.ts +25 -0
  453. package/dist/types/BscTypeKind.js +30 -0
  454. package/dist/types/BscTypeKind.js.map +1 -0
  455. package/dist/types/BuiltInInterfaceAdder.d.ts +25 -0
  456. package/dist/types/BuiltInInterfaceAdder.js +201 -0
  457. package/dist/types/BuiltInInterfaceAdder.js.map +1 -0
  458. package/dist/types/BuiltInInterfaceAdder.spec.d.ts +1 -0
  459. package/dist/types/BuiltInInterfaceAdder.spec.js +115 -0
  460. package/dist/types/BuiltInInterfaceAdder.spec.js.map +1 -0
  461. package/dist/types/ClassType.d.ts +16 -0
  462. package/dist/types/ClassType.js +57 -0
  463. package/dist/types/ClassType.js.map +1 -0
  464. package/dist/types/ClassType.spec.d.ts +1 -0
  465. package/dist/types/ClassType.spec.js +76 -0
  466. package/dist/types/ClassType.spec.js.map +1 -0
  467. package/dist/types/ComponentType.d.ts +27 -0
  468. package/dist/types/ComponentType.js +83 -0
  469. package/dist/types/ComponentType.js.map +1 -0
  470. package/dist/types/DoubleType.d.ts +10 -5
  471. package/dist/types/DoubleType.js +25 -18
  472. package/dist/types/DoubleType.js.map +1 -1
  473. package/dist/types/DoubleType.spec.js +12 -4
  474. package/dist/types/DoubleType.spec.js.map +1 -1
  475. package/dist/types/DynamicType.d.ts +12 -5
  476. package/dist/types/DynamicType.js +22 -6
  477. package/dist/types/DynamicType.js.map +1 -1
  478. package/dist/types/DynamicType.spec.js +16 -5
  479. package/dist/types/DynamicType.spec.js.map +1 -1
  480. package/dist/types/EnumType.d.ts +40 -0
  481. package/dist/types/EnumType.js +80 -0
  482. package/dist/types/EnumType.js.map +1 -0
  483. package/dist/types/EnumType.spec.d.ts +1 -0
  484. package/dist/types/EnumType.spec.js +33 -0
  485. package/dist/types/EnumType.spec.js.map +1 -0
  486. package/dist/types/FloatType.d.ts +10 -5
  487. package/dist/types/FloatType.js +25 -18
  488. package/dist/types/FloatType.js.map +1 -1
  489. package/dist/types/FloatType.spec.js +4 -4
  490. package/dist/types/FloatType.spec.js.map +1 -1
  491. package/dist/types/FunctionType.d.ts +10 -22
  492. package/dist/types/FunctionType.js +26 -63
  493. package/dist/types/FunctionType.js.map +1 -1
  494. package/dist/types/InheritableType.d.ts +28 -0
  495. package/dist/types/InheritableType.js +157 -0
  496. package/dist/types/InheritableType.js.map +1 -0
  497. package/dist/types/IntegerType.d.ts +10 -5
  498. package/dist/types/IntegerType.js +25 -18
  499. package/dist/types/IntegerType.js.map +1 -1
  500. package/dist/types/IntegerType.spec.js +8 -4
  501. package/dist/types/IntegerType.spec.js.map +1 -1
  502. package/dist/types/InterfaceType.d.ts +14 -6
  503. package/dist/types/InterfaceType.js +26 -15
  504. package/dist/types/InterfaceType.js.map +1 -1
  505. package/dist/types/InterfaceType.spec.d.ts +1 -0
  506. package/dist/types/InterfaceType.spec.js +227 -0
  507. package/dist/types/InterfaceType.spec.js.map +1 -0
  508. package/dist/types/InvalidType.d.ts +9 -5
  509. package/dist/types/InvalidType.js +20 -9
  510. package/dist/types/InvalidType.js.map +1 -1
  511. package/dist/types/InvalidType.spec.js +8 -4
  512. package/dist/types/InvalidType.spec.js.map +1 -1
  513. package/dist/types/LongIntegerType.d.ts +10 -5
  514. package/dist/types/LongIntegerType.js +25 -18
  515. package/dist/types/LongIntegerType.js.map +1 -1
  516. package/dist/types/LongIntegerType.spec.js +10 -4
  517. package/dist/types/LongIntegerType.spec.js.map +1 -1
  518. package/dist/types/NamespaceType.d.ts +12 -0
  519. package/dist/types/NamespaceType.js +28 -0
  520. package/dist/types/NamespaceType.js.map +1 -0
  521. package/dist/types/ObjectType.d.ts +10 -5
  522. package/dist/types/ObjectType.js +23 -9
  523. package/dist/types/ObjectType.js.map +1 -1
  524. package/dist/types/ObjectType.spec.js +3 -3
  525. package/dist/types/ObjectType.spec.js.map +1 -1
  526. package/dist/types/ReferenceType.d.ts +79 -0
  527. package/dist/types/ReferenceType.js +522 -0
  528. package/dist/types/ReferenceType.js.map +1 -0
  529. package/dist/types/ReferenceType.spec.d.ts +1 -0
  530. package/dist/types/ReferenceType.spec.js +151 -0
  531. package/dist/types/ReferenceType.spec.js.map +1 -0
  532. package/dist/types/StringType.d.ts +13 -5
  533. package/dist/types/StringType.js +25 -9
  534. package/dist/types/StringType.js.map +1 -1
  535. package/dist/types/StringType.spec.js +3 -3
  536. package/dist/types/StringType.spec.js.map +1 -1
  537. package/dist/types/TypedFunctionType.d.ts +33 -0
  538. package/dist/types/TypedFunctionType.js +106 -0
  539. package/dist/types/TypedFunctionType.js.map +1 -0
  540. package/dist/types/TypedFunctionType.spec.d.ts +1 -0
  541. package/dist/types/TypedFunctionType.spec.js +122 -0
  542. package/dist/types/TypedFunctionType.spec.js.map +1 -0
  543. package/dist/types/UninitializedType.d.ts +8 -6
  544. package/dist/types/UninitializedType.js +15 -9
  545. package/dist/types/UninitializedType.js.map +1 -1
  546. package/dist/types/UnionType.d.ts +20 -0
  547. package/dist/types/UnionType.js +127 -0
  548. package/dist/types/UnionType.js.map +1 -0
  549. package/dist/types/UnionType.spec.d.ts +1 -0
  550. package/dist/types/UnionType.spec.js +129 -0
  551. package/dist/types/UnionType.spec.js.map +1 -0
  552. package/dist/types/VoidType.d.ts +10 -5
  553. package/dist/types/VoidType.js +20 -9
  554. package/dist/types/VoidType.js.map +1 -1
  555. package/dist/types/VoidType.spec.js +3 -3
  556. package/dist/types/VoidType.spec.js.map +1 -1
  557. package/dist/types/helper.spec.d.ts +1 -0
  558. package/dist/types/helper.spec.js +144 -0
  559. package/dist/types/helper.spec.js.map +1 -0
  560. package/dist/types/helpers.d.ts +26 -0
  561. package/dist/types/helpers.js +191 -0
  562. package/dist/types/helpers.js.map +1 -0
  563. package/dist/types/index.d.ts +22 -0
  564. package/dist/types/index.js +39 -0
  565. package/dist/types/index.js.map +1 -0
  566. package/dist/util.d.ts +218 -106
  567. package/dist/util.js +1310 -320
  568. package/dist/util.js.map +1 -1
  569. package/dist/validators/ClassValidator.d.ts +9 -15
  570. package/dist/validators/ClassValidator.js +81 -134
  571. package/dist/validators/ClassValidator.js.map +1 -1
  572. package/package.json +169 -138
  573. package/dist/astUtils/index.d.ts +0 -7
  574. package/dist/astUtils/index.js +0 -26
  575. package/dist/astUtils/index.js.map +0 -1
  576. package/dist/lexer/index.d.ts +0 -3
  577. package/dist/lexer/index.js +0 -17
  578. package/dist/lexer/index.js.map +0 -1
  579. package/dist/parser/index.d.ts +0 -3
  580. package/dist/parser/index.js +0 -16
  581. package/dist/parser/index.js.map +0 -1
  582. package/dist/preprocessor/Chunk.d.ts +0 -82
  583. package/dist/preprocessor/Chunk.js +0 -77
  584. package/dist/preprocessor/Chunk.js.map +0 -1
  585. package/dist/preprocessor/Preprocessor.d.ts +0 -60
  586. package/dist/preprocessor/Preprocessor.js +0 -156
  587. package/dist/preprocessor/Preprocessor.js.map +0 -1
  588. package/dist/preprocessor/Preprocessor.spec.js +0 -152
  589. package/dist/preprocessor/Preprocessor.spec.js.map +0 -1
  590. package/dist/preprocessor/PreprocessorParser.d.ts +0 -61
  591. package/dist/preprocessor/PreprocessorParser.js +0 -194
  592. package/dist/preprocessor/PreprocessorParser.js.map +0 -1
  593. package/dist/preprocessor/PreprocessorParser.spec.js +0 -116
  594. package/dist/preprocessor/PreprocessorParser.spec.js.map +0 -1
  595. package/dist/preprocessor/index.d.ts +0 -3
  596. package/dist/preprocessor/index.js +0 -16
  597. package/dist/preprocessor/index.js.map +0 -1
  598. package/dist/types/CustomType.d.ts +0 -10
  599. package/dist/types/CustomType.js +0 -35
  600. package/dist/types/CustomType.js.map +0 -1
  601. package/dist/types/FunctionType.spec.js +0 -29
  602. package/dist/types/FunctionType.spec.js.map +0 -1
  603. package/dist/types/LazyType.d.ts +0 -15
  604. package/dist/types/LazyType.js +0 -32
  605. package/dist/types/LazyType.js.map +0 -1
  606. /package/dist/{preprocessor/Preprocessor.spec.d.ts → astUtils/Editor.spec.d.ts} +0 -0
  607. /package/dist/{preprocessor/PreprocessorParser.spec.d.ts → bscPlugin/completions/CompletionsProcessor.spec.d.ts} +0 -0
  608. /package/dist/{types/FunctionType.spec.d.ts → bscPlugin/definition/DefinitionProvider.spec.d.ts} +0 -0
@@ -1,9 +1,9 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  /* eslint-disable @typescript-eslint/no-for-in-array */
4
- const chai_1 = require("chai");
4
+ const chai_config_spec_1 = require("../../../chai-config.spec");
5
5
  const DiagnosticMessages_1 = require("../../../DiagnosticMessages");
6
- const lexer_1 = require("../../../lexer");
6
+ const TokenKind_1 = require("../../../lexer/TokenKind");
7
7
  const Parser_1 = require("../../Parser");
8
8
  const Parser_spec_1 = require("../Parser.spec");
9
9
  const Statement_1 = require("../../Statement");
@@ -14,77 +14,77 @@ describe('ternary expressions', () => {
14
14
  it('throws exception when used in brightscript scope', () => {
15
15
  var _a;
16
16
  let { diagnostics } = Parser_1.Parser.parse(`a = true ? "human" : "Zombie"`, { mode: Parser_1.ParseMode.BrightScript });
17
- chai_1.expect((_a = diagnostics[0]) === null || _a === void 0 ? void 0 : _a.message).to.equal(DiagnosticMessages_1.DiagnosticMessages.bsFeatureNotSupportedInBrsFiles('ternary operator').message);
17
+ (0, chai_config_spec_1.expect)((_a = diagnostics[0]) === null || _a === void 0 ? void 0 : _a.message).to.equal(DiagnosticMessages_1.DiagnosticMessages.bsFeatureNotSupportedInBrsFiles('ternary operator').message);
18
18
  });
19
19
  it('cannot be used as a statement', () => {
20
20
  let { diagnostics } = Parser_1.Parser.parse([
21
- Parser_spec_1.token(lexer_1.TokenKind.True, 'true'),
22
- Parser_spec_1.token(lexer_1.TokenKind.Question, '?'),
23
- Parser_spec_1.token(lexer_1.TokenKind.StringLiteral, 'Human'),
24
- Parser_spec_1.token(lexer_1.TokenKind.Colon, ':'),
25
- Parser_spec_1.token(lexer_1.TokenKind.StringLiteral, 'Zombie'),
21
+ (0, Parser_spec_1.token)(TokenKind_1.TokenKind.True, 'true'),
22
+ (0, Parser_spec_1.token)(TokenKind_1.TokenKind.Question, '?'),
23
+ (0, Parser_spec_1.token)(TokenKind_1.TokenKind.StringLiteral, 'Human'),
24
+ (0, Parser_spec_1.token)(TokenKind_1.TokenKind.Colon, ':'),
25
+ (0, Parser_spec_1.token)(TokenKind_1.TokenKind.StringLiteral, 'Zombie'),
26
26
  Parser_spec_1.EOF
27
27
  ], { mode: Parser_1.ParseMode.BrighterScript });
28
- chai_1.expect(diagnostics).not.to.be.empty;
28
+ (0, chai_config_spec_1.expect)(diagnostics).not.to.be.empty;
29
29
  });
30
30
  it(`cannot be used as a statement`, () => {
31
- chai_1.expect(parseBs(`true ? true : "zombie"`).diagnostics).not.to.be.empty;
32
- chai_1.expect(parseBs(`false ? true : "zombie"`).diagnostics).not.to.be.empty;
33
- chai_1.expect(parseBs(`len("person") = 10 ? true : "zombie"`).diagnostics).not.to.be.empty;
34
- chai_1.expect(parseBs(`m.getResponse() ? true : "zombie"`).diagnostics).not.to.be.empty;
31
+ (0, chai_config_spec_1.expect)(parseBs(`true ? true : "zombie"`).diagnostics).not.to.be.empty;
32
+ (0, chai_config_spec_1.expect)(parseBs(`false ? true : "zombie"`).diagnostics).not.to.be.empty;
33
+ (0, chai_config_spec_1.expect)(parseBs(`len("person") = 10 ? true : "zombie"`).diagnostics).not.to.be.empty;
34
+ (0, chai_config_spec_1.expect)(parseBs(`m.getResponse() ? true : "zombie"`).diagnostics).not.to.be.empty;
35
35
  });
36
36
  it(`supports boolean expression condition`, () => {
37
37
  let { statements, diagnostics } = parseBs(`being = isZombie = false ? "human" : "zombie"`);
38
- chai_1.expect(statements[0]).to.be.instanceof(Statement_1.AssignmentStatement);
39
- chai_1.expect(statements[0].value).to.be.instanceof(Expression_1.TernaryExpression);
40
- testHelpers_spec_1.expectZeroDiagnostics(diagnostics);
38
+ (0, chai_config_spec_1.expect)(statements[0]).to.be.instanceof(Statement_1.AssignmentStatement);
39
+ (0, chai_config_spec_1.expect)(statements[0].value).to.be.instanceof(Expression_1.TernaryExpression);
40
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(diagnostics);
41
41
  });
42
42
  it(`supports function condition`, () => {
43
43
  let { statements, diagnostics } = parseBs(`a = user.getAccount() ? "logged in" : "not logged in"`);
44
- chai_1.expect(statements[0]).to.be.instanceof(Statement_1.AssignmentStatement);
45
- chai_1.expect(statements[0].value).to.be.instanceof(Expression_1.TernaryExpression);
46
- testHelpers_spec_1.expectZeroDiagnostics(diagnostics);
44
+ (0, chai_config_spec_1.expect)(statements[0]).to.be.instanceof(Statement_1.AssignmentStatement);
45
+ (0, chai_config_spec_1.expect)(statements[0].value).to.be.instanceof(Expression_1.TernaryExpression);
46
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(diagnostics);
47
47
  });
48
48
  it(`supports various tests with primitive values:`, () => {
49
- testHelpers_spec_1.expectZeroDiagnostics(parseBs(`result = true ? "human" : "zombie"`));
50
- testHelpers_spec_1.expectZeroDiagnostics(parseBs(`result = false ? "human" : "zombie"`));
51
- testHelpers_spec_1.expectZeroDiagnostics(parseBs(`result = len("person") = 10 ? "human" : "zombie"`));
52
- testHelpers_spec_1.expectZeroDiagnostics(parseBs(`result = m.getResponse() ? "human" : "zombie"`));
53
- testHelpers_spec_1.expectZeroDiagnostics(parseBs(`result = m.myZombies[3].hasEaten = true ? "human" : "zombie"`));
49
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(parseBs(`result = true ? "human" : "zombie"`));
50
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(parseBs(`result = false ? "human" : "zombie"`));
51
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(parseBs(`result = len("person") = 10 ? "human" : "zombie"`));
52
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(parseBs(`result = m.getResponse() ? "human" : "zombie"`));
53
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(parseBs(`result = m.myZombies[3].hasEaten = true ? "human" : "zombie"`));
54
54
  });
55
55
  it(`supports simple consequents`, () => {
56
- testHelpers_spec_1.expectZeroDiagnostics(parseBs(`result = true ? true : "zombie"`));
57
- testHelpers_spec_1.expectZeroDiagnostics(parseBs(`result = true ? false : "zombie"`));
58
- testHelpers_spec_1.expectZeroDiagnostics(parseBs(`result = true ? len("person") = 10 : "zombie"`));
59
- testHelpers_spec_1.expectZeroDiagnostics(parseBs(`result = true ? m.getResponse() : "zombie"`));
60
- testHelpers_spec_1.expectZeroDiagnostics(parseBs(`result = true ? m.myZombies[3].hasEaten = true : "zombie"`));
61
- testHelpers_spec_1.expectZeroDiagnostics(parseBs(`result = true ? getZombieName : "zombie"`));
56
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(parseBs(`result = true ? true : "zombie"`));
57
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(parseBs(`result = true ? false : "zombie"`));
58
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(parseBs(`result = true ? len("person") = 10 : "zombie"`));
59
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(parseBs(`result = true ? m.getResponse() : "zombie"`));
60
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(parseBs(`result = true ? m.myZombies[3].hasEaten = true : "zombie"`));
61
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(parseBs(`result = true ? getZombieName : "zombie"`));
62
62
  });
63
63
  it(`supports simple alternates`, () => {
64
- testHelpers_spec_1.expectZeroDiagnostics(parseBs(`result = true ? "zombie": true`));
65
- testHelpers_spec_1.expectZeroDiagnostics(parseBs(`result = true ? "zombie": false`));
66
- testHelpers_spec_1.expectZeroDiagnostics(parseBs(`result = true ? "zombie": len("person") = 10`));
67
- testHelpers_spec_1.expectZeroDiagnostics(parseBs(`result = true ? "zombie": m.getResponse()`));
68
- testHelpers_spec_1.expectZeroDiagnostics(parseBs(`result = true ? "zombie": m.myZombies[3].hasEaten = true`));
69
- testHelpers_spec_1.expectZeroDiagnostics(parseBs(`result = true ? "zombie": getZombieName`));
70
- testHelpers_spec_1.expectZeroDiagnostics(parseBs(`result = true ? "zombie": true`));
64
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(parseBs(`result = true ? "zombie": true`));
65
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(parseBs(`result = true ? "zombie": false`));
66
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(parseBs(`result = true ? "zombie": len("person") = 10`));
67
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(parseBs(`result = true ? "zombie": m.getResponse()`));
68
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(parseBs(`result = true ? "zombie": m.myZombies[3].hasEaten = true`));
69
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(parseBs(`result = true ? "zombie": getZombieName`));
70
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(parseBs(`result = true ? "zombie": true`));
71
71
  });
72
72
  it('supports multi-line and comments', () => {
73
- testHelpers_spec_1.expectZeroDiagnostics(parseBs(`result = true ? \n"zombie"\n: \ntrue`));
74
- testHelpers_spec_1.expectZeroDiagnostics(parseBs(`result = true ? "zombie"\n: \ntrue`));
75
- testHelpers_spec_1.expectZeroDiagnostics(parseBs(`result = true ? \n"zombie": \ntrue`));
76
- testHelpers_spec_1.expectZeroDiagnostics(parseBs(`result = true ? \n"zombie"\n: true`));
77
- testHelpers_spec_1.expectZeroDiagnostics(parseBs(`result = true ? "zombie"\n: \ntrue`));
78
- testHelpers_spec_1.expectZeroDiagnostics(parseBs(`result = true ? "zombie": \ntrue`));
79
- testHelpers_spec_1.expectZeroDiagnostics(parseBs(`result = true ? \n\n\n"zombie": \n\n\n\ntrue`));
73
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(parseBs(`result = true ? \n"zombie"\n: \ntrue`));
74
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(parseBs(`result = true ? "zombie"\n: \ntrue`));
75
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(parseBs(`result = true ? \n"zombie": \ntrue`));
76
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(parseBs(`result = true ? \n"zombie"\n: true`));
77
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(parseBs(`result = true ? "zombie"\n: \ntrue`));
78
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(parseBs(`result = true ? "zombie": \ntrue`));
79
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(parseBs(`result = true ? \n\n\n"zombie": \n\n\n\ntrue`));
80
80
  //with comments
81
- testHelpers_spec_1.expectZeroDiagnostics(parseBs(`result = true ?'comment\n"zombie"'comment\n:'comment\nntrue`));
81
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(parseBs(`result = true ?'comment\n"zombie"'comment\n:'comment\nntrue`));
82
82
  });
83
83
  describe('in assignment', () => {
84
84
  it(`simple case`, () => {
85
85
  let { statements, diagnostics } = parseBs(`a = true ? "human" : "zombie"`);
86
- testHelpers_spec_1.expectZeroDiagnostics(diagnostics);
87
- chai_1.expect(statements[0]).instanceof(Statement_1.AssignmentStatement);
86
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(diagnostics);
87
+ (0, chai_config_spec_1.expect)(statements[0]).instanceof(Statement_1.AssignmentStatement);
88
88
  });
89
89
  it(`multi line arrays case`, () => {
90
90
  let { statements, diagnostics } = parseBs(`
@@ -98,21 +98,21 @@ describe('ternary expressions', () => {
98
98
  "three"
99
99
  ]
100
100
  `);
101
- testHelpers_spec_1.expectZeroDiagnostics(diagnostics);
102
- chai_1.expect(statements[0]).instanceof(Statement_1.AssignmentStatement);
101
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(diagnostics);
102
+ (0, chai_config_spec_1.expect)(statements[0]).instanceof(Statement_1.AssignmentStatement);
103
103
  });
104
104
  it(`single line assoc array`, () => {
105
105
  let { statements, diagnostics } = parseBs(`a = true ? {"a":"a"} : {}`);
106
- testHelpers_spec_1.expectZeroDiagnostics(diagnostics);
107
- chai_1.expect(statements[0]).instanceof(Statement_1.AssignmentStatement);
106
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(diagnostics);
107
+ (0, chai_config_spec_1.expect)(statements[0]).instanceof(Statement_1.AssignmentStatement);
108
108
  });
109
109
  it(`multi line assoc array`, () => {
110
110
  let { statements, diagnostics } = parseBs(`
111
111
  a = true ? {"a":"a"} : {
112
112
  "b": "test"
113
113
  }`);
114
- testHelpers_spec_1.expectZeroDiagnostics(diagnostics);
115
- chai_1.expect(statements[0]).instanceof(Statement_1.AssignmentStatement);
114
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(diagnostics);
115
+ (0, chai_config_spec_1.expect)(statements[0]).instanceof(Statement_1.AssignmentStatement);
116
116
  });
117
117
  it(`multi line assoc array - both sides`, () => {
118
118
  let { statements, diagnostics } = parseBs(`
@@ -123,136 +123,283 @@ describe('ternary expressions', () => {
123
123
  "b": "test"
124
124
  }
125
125
  `);
126
- testHelpers_spec_1.expectZeroDiagnostics(diagnostics);
127
- chai_1.expect(statements[0]).instanceof(Statement_1.AssignmentStatement);
126
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(diagnostics);
127
+ (0, chai_config_spec_1.expect)(statements[0]).instanceof(Statement_1.AssignmentStatement);
128
128
  });
129
129
  it(`in func call with array args`, () => {
130
130
  let { statements, diagnostics } = parseBs(`m.eatBrains(a.count() > 10 ? ["a","B"] : ["c", "d"])`);
131
- testHelpers_spec_1.expectZeroDiagnostics(diagnostics);
132
- chai_1.expect(statements[0]).instanceof(Statement_1.ExpressionStatement);
133
- chai_1.expect(statements[0].expression).instanceof(Expression_1.CallExpression);
131
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(diagnostics);
132
+ (0, chai_config_spec_1.expect)(statements[0]).instanceof(Statement_1.ExpressionStatement);
133
+ (0, chai_config_spec_1.expect)(statements[0].expression).instanceof(Expression_1.CallExpression);
134
134
  let callExpression = statements[0].expression;
135
- chai_1.expect(callExpression.args.length).to.equal(1);
136
- chai_1.expect(callExpression.args[0]).instanceof(Expression_1.TernaryExpression);
135
+ (0, chai_config_spec_1.expect)(callExpression.args.length).to.equal(1);
136
+ (0, chai_config_spec_1.expect)(callExpression.args[0]).instanceof(Expression_1.TernaryExpression);
137
137
  });
138
138
  it(`in func call with aa args`, () => {
139
139
  let { statements, diagnostics } = parseBs(`m.eatBrains(a.count() > 10 ? {"a":1} : {"b": ["c", "d"]})`);
140
- testHelpers_spec_1.expectZeroDiagnostics(diagnostics);
141
- chai_1.expect(statements[0]).instanceof(Statement_1.ExpressionStatement);
142
- chai_1.expect(statements[0].expression).instanceof(Expression_1.CallExpression);
140
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(diagnostics);
141
+ (0, chai_config_spec_1.expect)(statements[0]).instanceof(Statement_1.ExpressionStatement);
142
+ (0, chai_config_spec_1.expect)(statements[0].expression).instanceof(Expression_1.CallExpression);
143
143
  let callExpression = statements[0].expression;
144
- chai_1.expect(callExpression.args.length).to.equal(1);
145
- chai_1.expect(callExpression.args[0]).instanceof(Expression_1.TernaryExpression);
144
+ (0, chai_config_spec_1.expect)(callExpression.args.length).to.equal(1);
145
+ (0, chai_config_spec_1.expect)(callExpression.args[0]).instanceof(Expression_1.TernaryExpression);
146
146
  });
147
147
  it(`in simple func call`, () => {
148
148
  let { statements, diagnostics } = parseBs(`m.eatBrains(a = true ? "a" : "b")`);
149
- testHelpers_spec_1.expectZeroDiagnostics(diagnostics);
150
- chai_1.expect(statements[0]).instanceof(Statement_1.ExpressionStatement);
151
- chai_1.expect(statements[0].expression).instanceof(Expression_1.CallExpression);
149
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(diagnostics);
150
+ (0, chai_config_spec_1.expect)(statements[0]).instanceof(Statement_1.ExpressionStatement);
151
+ (0, chai_config_spec_1.expect)(statements[0].expression).instanceof(Expression_1.CallExpression);
152
152
  let callExpression = statements[0].expression;
153
- chai_1.expect(callExpression.args.length).to.equal(1);
154
- chai_1.expect(callExpression.args[0]).instanceof(Expression_1.TernaryExpression);
153
+ (0, chai_config_spec_1.expect)(callExpression.args.length).to.equal(1);
154
+ (0, chai_config_spec_1.expect)(callExpression.args[0]).instanceof(Expression_1.TernaryExpression);
155
155
  });
156
156
  it(`in func call with more args`, () => {
157
157
  let { statements, diagnostics } = parseBs(`m.eatBrains(a = true ? "a" : "b", true, 12)`);
158
- testHelpers_spec_1.expectZeroDiagnostics(diagnostics);
159
- chai_1.expect(statements[0]).instanceof(Statement_1.ExpressionStatement);
160
- chai_1.expect(statements[0].expression).instanceof(Expression_1.CallExpression);
158
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(diagnostics);
159
+ (0, chai_config_spec_1.expect)(statements[0]).instanceof(Statement_1.ExpressionStatement);
160
+ (0, chai_config_spec_1.expect)(statements[0].expression).instanceof(Expression_1.CallExpression);
161
161
  let callExpression = statements[0].expression;
162
- chai_1.expect(callExpression.args.length).to.equal(3);
163
- chai_1.expect(callExpression.args[0]).instanceof(Expression_1.TernaryExpression);
162
+ (0, chai_config_spec_1.expect)(callExpression.args.length).to.equal(3);
163
+ (0, chai_config_spec_1.expect)(callExpression.args[0]).instanceof(Expression_1.TernaryExpression);
164
164
  });
165
165
  it(`in func call with more args, and comparing value`, () => {
166
166
  let { statements, diagnostics } = parseBs(`m.eatBrains((a = true ? "a" : "b").count() = 3, true, 12)`);
167
- testHelpers_spec_1.expectZeroDiagnostics(diagnostics);
168
- chai_1.expect(statements[0]).instanceof(Statement_1.ExpressionStatement);
169
- chai_1.expect(statements[0].expression).instanceof(Expression_1.CallExpression);
167
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(diagnostics);
168
+ (0, chai_config_spec_1.expect)(statements[0]).instanceof(Statement_1.ExpressionStatement);
169
+ (0, chai_config_spec_1.expect)(statements[0].expression).instanceof(Expression_1.CallExpression);
170
170
  let callExpression = statements[0].expression;
171
- chai_1.expect(callExpression.args.length).to.equal(3);
171
+ (0, chai_config_spec_1.expect)(callExpression.args.length).to.equal(3);
172
172
  });
173
173
  it(`in array`, () => {
174
174
  let { statements, diagnostics } = parseBs(`a = [a = true ? {"a":"a"} : {"b":"b"}, "c"]`);
175
- testHelpers_spec_1.expectZeroDiagnostics(diagnostics);
176
- chai_1.expect(statements[0]).instanceof(Statement_1.AssignmentStatement);
177
- chai_1.expect(statements[0].value).instanceof(Expression_1.ArrayLiteralExpression);
175
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(diagnostics);
176
+ (0, chai_config_spec_1.expect)(statements[0]).instanceof(Statement_1.AssignmentStatement);
177
+ (0, chai_config_spec_1.expect)(statements[0].value).instanceof(Expression_1.ArrayLiteralExpression);
178
178
  let literalExpression = statements[0].value;
179
- chai_1.expect(literalExpression.elements[0]).instanceOf(Expression_1.TernaryExpression);
180
- chai_1.expect(literalExpression.elements[1]).instanceOf(Expression_1.LiteralExpression);
179
+ (0, chai_config_spec_1.expect)(literalExpression.elements[0]).instanceOf(Expression_1.TernaryExpression);
180
+ (0, chai_config_spec_1.expect)(literalExpression.elements[1]).instanceOf(Expression_1.LiteralExpression);
181
181
  });
182
182
  it(`in aa`, () => {
183
183
  let { statements, diagnostics } = parseBs(`a = {"v1": a = true ? {"a":"a"} : {"b":"b"}, "v2": "c"}`);
184
- testHelpers_spec_1.expectZeroDiagnostics(diagnostics);
185
- chai_1.expect(statements[0]).instanceof(Statement_1.AssignmentStatement);
186
- chai_1.expect(statements[0].value).instanceof(Expression_1.AALiteralExpression);
184
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(diagnostics);
185
+ (0, chai_config_spec_1.expect)(statements[0]).instanceof(Statement_1.AssignmentStatement);
186
+ (0, chai_config_spec_1.expect)(statements[0].value).instanceof(Expression_1.AALiteralExpression);
187
187
  let literalExpression = statements[0].value;
188
- chai_1.expect(literalExpression.elements[0].keyToken.text).is.equal('"v1"');
189
- chai_1.expect(literalExpression.elements[0].value).instanceOf(Expression_1.TernaryExpression);
190
- chai_1.expect(literalExpression.elements[1].keyToken.text).is.equal('"v2"');
191
- chai_1.expect(literalExpression.elements[1].value).instanceOf(Expression_1.LiteralExpression);
188
+ (0, chai_config_spec_1.expect)(literalExpression.elements[0].tokens.key.text).is.equal('"v1"');
189
+ (0, chai_config_spec_1.expect)(literalExpression.elements[0].value).instanceOf(Expression_1.TernaryExpression);
190
+ (0, chai_config_spec_1.expect)(literalExpression.elements[1].tokens.key.text).is.equal('"v2"');
191
+ (0, chai_config_spec_1.expect)(literalExpression.elements[1].value).instanceOf(Expression_1.LiteralExpression);
192
192
  });
193
193
  it(`in for each`, () => {
194
194
  let { statements, diagnostics } = parseBs(`for each person in isZombieMode ? zombies : humans
195
195
  ? "person is " ; person
196
196
  end for
197
197
  `);
198
- testHelpers_spec_1.expectZeroDiagnostics(diagnostics);
199
- chai_1.expect(statements[0]).instanceof(Statement_1.ForEachStatement);
200
- chai_1.expect(statements[0].target).instanceof(Expression_1.TernaryExpression);
198
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(diagnostics);
199
+ (0, chai_config_spec_1.expect)(statements[0]).instanceof(Statement_1.ForEachStatement);
200
+ (0, chai_config_spec_1.expect)(statements[0].target).instanceof(Expression_1.TernaryExpression);
201
201
  });
202
202
  it('creates TernaryExpression with missing alternate', () => {
203
203
  const { statements } = parseBs(`
204
204
  print name = "bob" ? "human":
205
205
  `);
206
206
  const expr = statements[0].expressions[0];
207
- chai_1.expect(expr).to.be.instanceof(Expression_1.TernaryExpression);
208
- chai_1.expect(expr).property('alternate').to.be.undefined;
209
- chai_1.expect(expr).property('consequent').not.to.be.undefined;
207
+ (0, chai_config_spec_1.expect)(expr).to.be.instanceof(Expression_1.TernaryExpression);
208
+ (0, chai_config_spec_1.expect)(expr).property('alternate').to.be.undefined;
209
+ (0, chai_config_spec_1.expect)(expr).property('consequent').not.to.be.undefined;
210
210
  });
211
211
  it('creates TernaryExpression with missing consequent', () => {
212
212
  const { statements } = parseBs(`
213
213
  print name = "bob" ? : "human"
214
214
  `);
215
215
  const expr = statements[0].expressions[0];
216
- chai_1.expect(expr).to.be.instanceof(Expression_1.TernaryExpression);
217
- chai_1.expect(expr).property('consequent').to.be.undefined;
218
- chai_1.expect(expr).property('alternate').not.to.be.undefined;
216
+ (0, chai_config_spec_1.expect)(expr).to.be.instanceof(Expression_1.TernaryExpression);
217
+ (0, chai_config_spec_1.expect)(expr).property('consequent').to.be.undefined;
218
+ (0, chai_config_spec_1.expect)(expr).property('alternate').not.to.be.undefined;
219
219
  });
220
220
  });
221
221
  describe('transpilation', () => {
222
222
  let rootDir = process.cwd();
223
223
  let program;
224
- let testTranspile = testHelpers_spec_1.getTestTranspile(() => [program, rootDir]);
224
+ let testTranspile = (0, testHelpers_spec_1.getTestTranspile)(() => [program, rootDir]);
225
225
  beforeEach(() => {
226
226
  program = new Program_1.Program({ rootDir: rootDir });
227
227
  });
228
228
  afterEach(() => {
229
229
  program.dispose();
230
230
  });
231
- it('uses the proper prefix when aliased package is installed', () => {
231
+ it('uses the proper prefix when aliased package is installed', async () => {
232
232
  program.setFile('source/roku_modules/rokucommunity_bslib/bslib.brs', '');
233
- testTranspile(`a = user = invalid ? "no user" : "logged in"`, `a = rokucommunity_bslib_ternary(user = invalid, "no user", "logged in")`);
233
+ await testTranspile(`
234
+ sub main()
235
+ user = {}
236
+ a = user = invalid ? "no user" : "logged in"
237
+ end sub
238
+ `, `
239
+ sub main()
240
+ user = {}
241
+ a = rokucommunity_bslib_ternary(user = invalid, "no user", "logged in")
242
+ end sub
243
+ `);
234
244
  });
235
- it('simple consequents', () => {
236
- testTranspile(`a = user = invalid ? "no user" : "logged in"`, `a = bslib_ternary(user = invalid, "no user", "logged in")`);
237
- testTranspile(`a = user = invalid ? 1 : "logged in"`, `a = bslib_ternary(user = invalid, 1, "logged in")`);
238
- testTranspile(`a = user = invalid ? 1.2 : "logged in"`, `a = bslib_ternary(user = invalid, 1.2, "logged in")`);
239
- testTranspile(`a = user = invalid ? [] : "logged in"`, `a = bslib_ternary(user = invalid, [], "logged in")`);
240
- testTranspile(`a = user = invalid ? {} : "logged in"`, `a = bslib_ternary(user = invalid, {}, "logged in")`);
245
+ it('simple consequents', async () => {
246
+ await testTranspile(`
247
+ sub main()
248
+ user = {}
249
+ a = user = invalid ? "no user" : "logged in"
250
+ end sub
251
+ `, `
252
+ sub main()
253
+ user = {}
254
+ a = bslib_ternary(user = invalid, "no user", "logged in")
255
+ end sub
256
+ `);
257
+ await testTranspile(`
258
+ sub main()
259
+ user = {}
260
+ a = user = invalid ? 1 : "logged in"
261
+ end sub
262
+ `, `
263
+ sub main()
264
+ user = {}
265
+ a = bslib_ternary(user = invalid, 1, "logged in")
266
+ end sub
267
+ `);
268
+ await testTranspile(`
269
+ sub main()
270
+ user = {}
271
+ a = user = invalid ? 1.2 : "logged in"
272
+ end sub
273
+ `, `
274
+ sub main()
275
+ user = {}
276
+ a = bslib_ternary(user = invalid, 1.2, "logged in")
277
+ end sub
278
+ `);
279
+ await testTranspile(`
280
+ sub main()
281
+ user = {}
282
+ a = user = invalid ? {} : "logged in"
283
+ end sub
284
+ `, `
285
+ sub main()
286
+ user = {}
287
+ a = bslib_ternary(user = invalid, {}, "logged in")
288
+ end sub
289
+ `);
290
+ await testTranspile(`
291
+ sub main()
292
+ user = {}
293
+ a = user = invalid ? [] : "logged in"
294
+ end sub
295
+ `, `
296
+ sub main()
297
+ user = {}
298
+ a = bslib_ternary(user = invalid, [], "logged in")
299
+ end sub
300
+ `);
241
301
  });
242
- it('simple alternates', () => {
243
- testTranspile(`a = user = invalid ? "logged in" : "no user" `, `a = bslib_ternary(user = invalid, "logged in", "no user")`);
244
- testTranspile(`a = user = invalid ? "logged in" : 1 `, `a = bslib_ternary(user = invalid, "logged in", 1)`);
245
- testTranspile(`a = user = invalid ? "logged in" : 1.2 `, `a = bslib_ternary(user = invalid, "logged in", 1.2)`);
246
- testTranspile(`a = user = invalid ? "logged in" : [] `, `a = bslib_ternary(user = invalid, "logged in", [])`);
247
- testTranspile(`a = user = invalid ? "logged in" : {} `, `a = bslib_ternary(user = invalid, "logged in", {})`);
302
+ it('simple alternates', async () => {
303
+ await testTranspile(`
304
+ sub main()
305
+ user = {}
306
+ a = user = invalid ? "logged in" : "no user"
307
+ end sub
308
+ `, `
309
+ sub main()
310
+ user = {}
311
+ a = bslib_ternary(user = invalid, "logged in", "no user")
312
+ end sub
313
+ `);
314
+ await testTranspile(`
315
+ sub main()
316
+ user = {}
317
+ a = user = invalid ? "logged in" : 1
318
+ end sub
319
+ `, `
320
+ sub main()
321
+ user = {}
322
+ a = bslib_ternary(user = invalid, "logged in", 1)
323
+ end sub
324
+ `);
325
+ await testTranspile(`
326
+ sub main()
327
+ user = {}
328
+ a = user = invalid ? "logged in" : 1.2
329
+ end sub
330
+ `, `
331
+ sub main()
332
+ user = {}
333
+ a = bslib_ternary(user = invalid, "logged in", 1.2)
334
+ end sub
335
+ `);
336
+ await testTranspile(`
337
+ sub main()
338
+ user = {}
339
+ a = user = invalid ? "logged in" : []
340
+ end sub
341
+ `, `
342
+ sub main()
343
+ user = {}
344
+ a = bslib_ternary(user = invalid, "logged in", [])
345
+ end sub
346
+ `);
347
+ await testTranspile(`
348
+ sub main()
349
+ user = {}
350
+ a = user = invalid ? "logged in" : {}
351
+ end sub
352
+ `, `
353
+ sub main()
354
+ user = {}
355
+ a = bslib_ternary(user = invalid, "logged in", {})
356
+ end sub
357
+ `);
248
358
  });
249
- it('complex conditions do not cause scope capture', () => {
250
- testTranspile(`a = IsTrue() = true ? true : false `, `a = bslib_ternary(IsTrue() = true, true, false)`);
251
- testTranspile(`a = m.top.service.IsTrue() ? true : false `, `a = bslib_ternary(m.top.service.IsTrue(), true, false)`);
252
- testTranspile(`a = First(second(third(fourth(m.fifth()[123].truthy(1))))) ? true : false `, `a = bslib_ternary(First(second(third(fourth(m.fifth()[123].truthy(1))))), true, false)`);
359
+ it('complex conditions do not cause scope capture', async () => {
360
+ await testTranspile(`
361
+ sub main()
362
+ a = str(123) = "123" ? true : false
363
+ end sub
364
+ `, `
365
+ sub main()
366
+ a = bslib_ternary(str(123) = "123", true, false)
367
+ end sub
368
+ `);
369
+ await testTranspile(`
370
+ sub main()
371
+ a = m.top.service.IsTrue() ? true : false
372
+ end sub
373
+ `, `
374
+ sub main()
375
+ a = bslib_ternary(m.top.service.IsTrue(), true, false)
376
+ end sub
377
+ `);
378
+ await testTranspile(`
379
+ sub test(param1)
380
+ end sub
381
+
382
+ sub main()
383
+ a = test(test(test(test(m.fifth()[123].truthy(1))))) ? true : false
384
+ end sub
385
+ `, `
386
+ sub test(param1)
387
+ end sub
388
+
389
+ sub main()
390
+ a = bslib_ternary(test(test(test(test(m.fifth()[123].truthy(1))))), true, false)
391
+ end sub
392
+ `);
253
393
  });
254
- it('captures scope for function call conseqent', () => {
255
- testTranspile(`name = zombie.getName() <> invalid ? zombie.GetName() : "zombie"`, `
394
+ it('captures scope for function call conseqent', async () => {
395
+ await testTranspile(`
396
+ sub main()
397
+ zombie = {}
398
+ name = zombie.getName() <> invalid ? zombie.GetName() : "zombie"
399
+ end sub
400
+ `, `
401
+ sub main()
402
+ zombie = {}
256
403
  name = (function(__bsCondition, zombie)
257
404
  if __bsCondition then
258
405
  return zombie.GetName()
@@ -260,10 +407,18 @@ describe('ternary expressions', () => {
260
407
  return "zombie"
261
408
  end if
262
409
  end function)(zombie.getName() <> invalid, zombie)
263
- `);
410
+ end sub
411
+ `);
264
412
  });
265
- it('captures scope for function call alternate', () => {
266
- testTranspile(`name = zombie.getName() = invalid ? "zombie" : zombie.GetName()`, `
413
+ it('captures scope for function call alternate', async () => {
414
+ await testTranspile(`
415
+ sub main()
416
+ zombie = {}
417
+ name = zombie.getName() = invalid ? "zombie" : zombie.GetName()
418
+ end sub
419
+ `, `
420
+ sub main()
421
+ zombie = {}
267
422
  name = (function(__bsCondition, zombie)
268
423
  if __bsCondition then
269
424
  return "zombie"
@@ -271,49 +426,123 @@ describe('ternary expressions', () => {
271
426
  return zombie.GetName()
272
427
  end if
273
428
  end function)(zombie.getName() = invalid, zombie)
274
- `);
429
+ end sub
430
+ `);
275
431
  });
276
- it('captures scope for complex consequent', () => {
277
- testTranspile(`name = isLoggedIn ? m.defaults.getAccount(settings.name) : "no"`, `
432
+ it('captures scope for complex consequent', async () => {
433
+ await testTranspile(`
434
+ sub main()
435
+ settings = {}
436
+ name = {} ? m.defaults.getAccount(settings.name) : "no"
437
+ end sub
438
+ `, `
439
+ sub main()
440
+ settings = {}
278
441
  name = (function(__bsCondition, m, settings)
279
442
  if __bsCondition then
280
443
  return m.defaults.getAccount(settings.name)
281
444
  else
282
445
  return "no"
283
446
  end if
284
- end function)(isLoggedIn, m, settings)
285
- `);
447
+ end function)({}, m, settings)
448
+ end sub
449
+ `);
286
450
  });
287
- it('supports scope-captured outer, and simple inner', () => {
288
- testTranspile(`name = zombie <> invalid ? zombie.Attack(human <> invalid ? human: zombie) : "zombie"`, `
289
- name = (function(__bsCondition, human, zombie)
451
+ it('ignores enum variable names', async () => {
452
+ await testTranspile(`
453
+ enum Direction
454
+ up = "up"
455
+ down = "down"
456
+ end enum
457
+ sub main()
458
+ d = Direction.up
459
+ theDir = d = Direction.up ? Direction.up : false
460
+ end sub
461
+ `, `
462
+ sub main()
463
+ d = "up"
464
+ theDir = (function(__bsCondition)
290
465
  if __bsCondition then
291
- return zombie.Attack(bslib_ternary(human <> invalid, human, zombie))
466
+ return "up"
292
467
  else
293
- return "zombie"
468
+ return false
294
469
  end if
295
- end function)(zombie <> invalid, human, zombie)
296
- `);
470
+ end function)(d = "up")
471
+ end sub
472
+ `);
297
473
  });
298
- it('uses scope capture for property access', () => {
299
- testTranspile(`name = person <> invalid ? person.name : "John Doe"`, `
300
- name = (function(__bsCondition, person)
474
+ it('ignores const variable names', async () => {
475
+ await testTranspile(`
476
+ enum Direction
477
+ up = "up"
478
+ down = "down"
479
+ end enum
480
+ const UP = "up"
481
+ sub main()
482
+ d = Direction.up
483
+ theDir = d = Direction.up ? UP : Direction.down
484
+ end sub
485
+ `, `
486
+ sub main()
487
+ d = "up"
488
+ theDir = (function(__bsCondition)
301
489
  if __bsCondition then
302
- return person.name
490
+ return "up"
303
491
  else
304
- return "John Doe"
492
+ return "down"
305
493
  end if
306
- end function)(person <> invalid, person)
494
+ end function)(d = "up")
495
+ end sub
496
+ `);
497
+ });
498
+ it('supports scope-captured outer, and simple inner', async () => {
499
+ await testTranspile(`
500
+ sub main()
501
+ zombie = {}
502
+ human = {}
503
+ name = zombie <> invalid ? zombie.Attack(human <> invalid ? human: zombie) : "zombie"
504
+ end sub
505
+ `, `
506
+ sub main()
507
+ zombie = {}
508
+ human = {}
509
+ name = (function(__bsCondition, human, zombie)
510
+ if __bsCondition then
511
+ return zombie.Attack(bslib_ternary(human <> invalid, human, zombie))
512
+ else
513
+ return "zombie"
514
+ end if
515
+ end function)(zombie <> invalid, human, zombie)
516
+ end sub
517
+ `);
518
+ });
519
+ it('uses scope capture for property access', async () => {
520
+ await testTranspile(`
521
+ sub main()
522
+ person = {}
523
+ name = person <> invalid ? person.name : "John Doe"
524
+ end sub
525
+ `, `
526
+ sub main()
527
+ person = {}
528
+ name = (function(__bsCondition, person)
529
+ if __bsCondition then
530
+ return person.name
531
+ else
532
+ return "John Doe"
533
+ end if
534
+ end function)(person <> invalid, person)
535
+ end sub
307
536
  `);
308
537
  });
309
- it('uses `invalid` in place of missing consequent ', () => {
310
- testTranspile(`print name = "bob" ? :"zombie"`, `print bslib_ternary(name = "bob", invalid, "zombie")`, 'none', undefined, false);
538
+ it('uses `invalid` in place of missing consequent ', async () => {
539
+ await testTranspile(`print name = "bob" ? :"zombie"`, `print bslib_ternary(name = "bob", invalid, "zombie")`, 'none', undefined, false);
311
540
  });
312
- it('uses `invalid` in place of missing alternate ', () => {
313
- testTranspile(`print name = "bob" ? "human"`, `print bslib_ternary(name = "bob", "human", invalid)`, 'none', undefined, false);
541
+ it('uses `invalid` in place of missing alternate ', async () => {
542
+ await testTranspile(`print name = "bob" ? "human"`, `print bslib_ternary(name = "bob", "human", invalid)`, 'none', undefined, false);
314
543
  });
315
- it('uses `invalid` in place of missing alternate and consequent ', () => {
316
- testTranspile(`print name = "bob" ?:`, `print bslib_ternary(name = "bob", invalid, invalid)`, 'none', undefined, false);
544
+ it('uses `invalid` in place of missing alternate and consequent ', async () => {
545
+ await testTranspile(`print name = "bob" ?:`, `print bslib_ternary(name = "bob", invalid, invalid)`, 'none', undefined, false);
317
546
  });
318
547
  });
319
548
  });