brighterscript 1.0.0-alpha.4 → 1.0.0-alpha.41

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 (620) hide show
  1. package/CHANGELOG.md +1393 -291
  2. package/README.md +72 -131
  3. package/bsconfig.schema.json +85 -1
  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 +237 -0
  9. package/dist/AstValidationSegmenter.js.map +1 -0
  10. package/dist/BsConfig.d.ts +56 -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 +6 -3
  21. package/dist/CodeActionUtil.js +19 -5
  22. package/dist/CodeActionUtil.js.map +1 -1
  23. package/dist/CommentFlagProcessor.d.ts +7 -6
  24. package/dist/CommentFlagProcessor.js +11 -8
  25. package/dist/CommentFlagProcessor.js.map +1 -1
  26. package/dist/CrossScopeValidator.d.ts +67 -0
  27. package/dist/CrossScopeValidator.js +617 -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 +21 -16
  34. package/dist/DiagnosticCollection.js.map +1 -1
  35. package/dist/DiagnosticFilterer.d.ts +8 -4
  36. package/dist/DiagnosticFilterer.js +90 -54
  37. package/dist/DiagnosticFilterer.js.map +1 -1
  38. package/dist/DiagnosticManager.d.ts +61 -0
  39. package/dist/DiagnosticManager.js +238 -0
  40. package/dist/DiagnosticManager.js.map +1 -0
  41. package/dist/DiagnosticMessages.d.ts +204 -24
  42. package/dist/DiagnosticMessages.js +266 -33
  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 +545 -314
  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 +201 -100
  63. package/dist/Program.js +1079 -700
  64. package/dist/Program.js.map +1 -1
  65. package/dist/ProgramBuilder.d.ts +29 -18
  66. package/dist/ProgramBuilder.js +178 -141
  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 +291 -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 +335 -0
  94. package/dist/astUtils/CachedLookups.js.map +1 -0
  95. package/dist/astUtils/CachedLookups.spec.js +39 -0
  96. package/dist/astUtils/CachedLookups.spec.js.map +1 -0
  97. package/dist/astUtils/Editor.d.ts +69 -0
  98. package/dist/astUtils/Editor.js +245 -0
  99. package/dist/astUtils/Editor.js.map +1 -0
  100. package/dist/astUtils/Editor.spec.js +258 -0
  101. package/dist/astUtils/Editor.spec.js.map +1 -0
  102. package/dist/astUtils/creators.d.ts +36 -19
  103. package/dist/astUtils/creators.js +222 -43
  104. package/dist/astUtils/creators.js.map +1 -1
  105. package/dist/astUtils/creators.spec.js +5 -5
  106. package/dist/astUtils/creators.spec.js.map +1 -1
  107. package/dist/astUtils/reflection.d.ts +148 -82
  108. package/dist/astUtils/reflection.js +324 -137
  109. package/dist/astUtils/reflection.js.map +1 -1
  110. package/dist/astUtils/reflection.spec.js +267 -167
  111. package/dist/astUtils/reflection.spec.js.map +1 -1
  112. package/dist/astUtils/stackedVisitor.js.map +1 -1
  113. package/dist/astUtils/stackedVisitor.spec.js +14 -14
  114. package/dist/astUtils/stackedVisitor.spec.js.map +1 -1
  115. package/dist/astUtils/visitors.d.ts +114 -53
  116. package/dist/astUtils/visitors.js +70 -13
  117. package/dist/astUtils/visitors.js.map +1 -1
  118. package/dist/astUtils/visitors.spec.js +463 -51
  119. package/dist/astUtils/visitors.spec.js.map +1 -1
  120. package/dist/astUtils/xml.d.ts +9 -8
  121. package/dist/astUtils/xml.js +10 -5
  122. package/dist/astUtils/xml.js.map +1 -1
  123. package/dist/bscPlugin/BscPlugin.d.ts +22 -1
  124. package/dist/bscPlugin/BscPlugin.js +88 -0
  125. package/dist/bscPlugin/BscPlugin.js.map +1 -1
  126. package/dist/bscPlugin/CallExpressionInfo.d.ts +36 -0
  127. package/dist/bscPlugin/CallExpressionInfo.js +135 -0
  128. package/dist/bscPlugin/CallExpressionInfo.js.map +1 -0
  129. package/dist/bscPlugin/FileWriter.d.ts +6 -0
  130. package/dist/bscPlugin/FileWriter.js +24 -0
  131. package/dist/bscPlugin/FileWriter.js.map +1 -0
  132. package/dist/bscPlugin/SignatureHelpUtil.d.ts +10 -0
  133. package/dist/bscPlugin/SignatureHelpUtil.js +137 -0
  134. package/dist/bscPlugin/SignatureHelpUtil.js.map +1 -0
  135. package/dist/bscPlugin/codeActions/CodeActionsProcessor.d.ts +1 -1
  136. package/dist/bscPlugin/codeActions/CodeActionsProcessor.js +30 -18
  137. package/dist/bscPlugin/codeActions/CodeActionsProcessor.js.map +1 -1
  138. package/dist/bscPlugin/codeActions/CodeActionsProcessor.spec.js +94 -21
  139. package/dist/bscPlugin/codeActions/CodeActionsProcessor.spec.js.map +1 -1
  140. package/dist/bscPlugin/completions/CompletionsProcessor.d.ts +64 -0
  141. package/dist/bscPlugin/completions/CompletionsProcessor.js +626 -0
  142. package/dist/bscPlugin/completions/CompletionsProcessor.js.map +1 -0
  143. package/dist/bscPlugin/completions/CompletionsProcessor.spec.js +2188 -0
  144. package/dist/bscPlugin/completions/CompletionsProcessor.spec.js.map +1 -0
  145. package/dist/bscPlugin/definition/DefinitionProvider.d.ts +13 -0
  146. package/dist/bscPlugin/definition/DefinitionProvider.js +212 -0
  147. package/dist/bscPlugin/definition/DefinitionProvider.js.map +1 -0
  148. package/dist/bscPlugin/definition/DefinitionProvider.spec.d.ts +1 -0
  149. package/dist/bscPlugin/definition/DefinitionProvider.spec.js +87 -0
  150. package/dist/bscPlugin/definition/DefinitionProvider.spec.js.map +1 -0
  151. package/dist/bscPlugin/fileProviders/FileProvider.d.ts +9 -0
  152. package/dist/bscPlugin/fileProviders/FileProvider.js +51 -0
  153. package/dist/bscPlugin/fileProviders/FileProvider.js.map +1 -0
  154. package/dist/bscPlugin/hover/HoverProcessor.d.ts +18 -0
  155. package/dist/bscPlugin/hover/HoverProcessor.js +218 -0
  156. package/dist/bscPlugin/hover/HoverProcessor.js.map +1 -0
  157. package/dist/bscPlugin/hover/HoverProcessor.spec.d.ts +1 -0
  158. package/dist/bscPlugin/hover/HoverProcessor.spec.js +786 -0
  159. package/dist/bscPlugin/hover/HoverProcessor.spec.js.map +1 -0
  160. package/dist/bscPlugin/references/ReferencesProvider.d.ts +12 -0
  161. package/dist/bscPlugin/references/ReferencesProvider.js +57 -0
  162. package/dist/bscPlugin/references/ReferencesProvider.js.map +1 -0
  163. package/dist/bscPlugin/references/ReferencesProvider.spec.d.ts +1 -0
  164. package/dist/bscPlugin/references/ReferencesProvider.spec.js +51 -0
  165. package/dist/bscPlugin/references/ReferencesProvider.spec.js.map +1 -0
  166. package/dist/bscPlugin/semanticTokens/BrsFileSemanticTokensProcessor.d.ts +14 -0
  167. package/dist/bscPlugin/semanticTokens/BrsFileSemanticTokensProcessor.js +154 -0
  168. package/dist/bscPlugin/semanticTokens/BrsFileSemanticTokensProcessor.js.map +1 -0
  169. package/dist/bscPlugin/semanticTokens/BrsFileSemanticTokensProcessor.spec.d.ts +1 -0
  170. package/dist/bscPlugin/semanticTokens/BrsFileSemanticTokensProcessor.spec.js +530 -0
  171. package/dist/bscPlugin/semanticTokens/BrsFileSemanticTokensProcessor.spec.js.map +1 -0
  172. package/dist/bscPlugin/serialize/BslibInjector.spec.d.ts +1 -0
  173. package/dist/bscPlugin/serialize/BslibInjector.spec.js +33 -0
  174. package/dist/bscPlugin/serialize/BslibInjector.spec.js.map +1 -0
  175. package/dist/bscPlugin/serialize/BslibManager.d.ts +12 -0
  176. package/dist/bscPlugin/serialize/BslibManager.js +46 -0
  177. package/dist/bscPlugin/serialize/BslibManager.js.map +1 -0
  178. package/dist/bscPlugin/serialize/FileSerializer.d.ts +9 -0
  179. package/dist/bscPlugin/serialize/FileSerializer.js +75 -0
  180. package/dist/bscPlugin/serialize/FileSerializer.js.map +1 -0
  181. package/dist/bscPlugin/symbols/DocumentSymbolProcessor.d.ts +7 -0
  182. package/dist/bscPlugin/symbols/DocumentSymbolProcessor.js +22 -0
  183. package/dist/bscPlugin/symbols/DocumentSymbolProcessor.js.map +1 -0
  184. package/dist/bscPlugin/symbols/DocumentSymbolProcessor.spec.d.ts +1 -0
  185. package/dist/bscPlugin/symbols/DocumentSymbolProcessor.spec.js +291 -0
  186. package/dist/bscPlugin/symbols/DocumentSymbolProcessor.spec.js.map +1 -0
  187. package/dist/bscPlugin/symbols/WorkspaceSymbolProcessor.d.ts +7 -0
  188. package/dist/bscPlugin/symbols/WorkspaceSymbolProcessor.js +26 -0
  189. package/dist/bscPlugin/symbols/WorkspaceSymbolProcessor.js.map +1 -0
  190. package/dist/bscPlugin/symbols/WorkspaceSymbolProcessor.spec.d.ts +1 -0
  191. package/dist/bscPlugin/symbols/WorkspaceSymbolProcessor.spec.js +245 -0
  192. package/dist/bscPlugin/symbols/WorkspaceSymbolProcessor.spec.js.map +1 -0
  193. package/dist/bscPlugin/symbols/symbolUtils.d.ts +5 -0
  194. package/dist/bscPlugin/symbols/symbolUtils.js +141 -0
  195. package/dist/bscPlugin/symbols/symbolUtils.js.map +1 -0
  196. package/dist/bscPlugin/transpile/BrsFileTranspileProcessor.d.ts +21 -0
  197. package/dist/bscPlugin/transpile/BrsFileTranspileProcessor.js +201 -0
  198. package/dist/bscPlugin/transpile/BrsFileTranspileProcessor.js.map +1 -0
  199. package/dist/bscPlugin/transpile/BrsFileTranspileProcessor.spec.d.ts +1 -0
  200. package/dist/bscPlugin/transpile/BrsFileTranspileProcessor.spec.js +75 -0
  201. package/dist/bscPlugin/transpile/BrsFileTranspileProcessor.spec.js.map +1 -0
  202. package/dist/bscPlugin/transpile/XmlFilePreTranspileProcessor.d.ts +12 -0
  203. package/dist/bscPlugin/transpile/XmlFilePreTranspileProcessor.js +99 -0
  204. package/dist/bscPlugin/transpile/XmlFilePreTranspileProcessor.js.map +1 -0
  205. package/dist/bscPlugin/validation/BrsFileAfterValidator.d.ts +7 -0
  206. package/dist/bscPlugin/validation/BrsFileAfterValidator.js +18 -0
  207. package/dist/bscPlugin/validation/BrsFileAfterValidator.js.map +1 -0
  208. package/dist/bscPlugin/validation/BrsFileValidator.d.ts +36 -0
  209. package/dist/bscPlugin/validation/BrsFileValidator.js +534 -0
  210. package/dist/bscPlugin/validation/BrsFileValidator.js.map +1 -0
  211. package/dist/bscPlugin/validation/BrsFileValidator.spec.d.ts +1 -0
  212. package/dist/bscPlugin/validation/BrsFileValidator.spec.js +1118 -0
  213. package/dist/bscPlugin/validation/BrsFileValidator.spec.js.map +1 -0
  214. package/dist/bscPlugin/validation/ProgramValidator.d.ts +11 -0
  215. package/dist/bscPlugin/validation/ProgramValidator.js +33 -0
  216. package/dist/bscPlugin/validation/ProgramValidator.js.map +1 -0
  217. package/dist/bscPlugin/validation/ScopeValidator.d.ts +128 -0
  218. package/dist/bscPlugin/validation/ScopeValidator.js +1045 -0
  219. package/dist/bscPlugin/validation/ScopeValidator.js.map +1 -0
  220. package/dist/bscPlugin/validation/ScopeValidator.spec.d.ts +1 -0
  221. package/dist/bscPlugin/validation/ScopeValidator.spec.js +3380 -0
  222. package/dist/bscPlugin/validation/ScopeValidator.spec.js.map +1 -0
  223. package/dist/bscPlugin/validation/XmlFileValidator.d.ts +8 -0
  224. package/dist/bscPlugin/validation/XmlFileValidator.js +44 -0
  225. package/dist/bscPlugin/validation/XmlFileValidator.js.map +1 -0
  226. package/dist/cli.js +117 -11
  227. package/dist/cli.js.map +1 -1
  228. package/dist/deferred.d.ts +3 -3
  229. package/dist/deferred.js.map +1 -1
  230. package/dist/diagnosticUtils.d.ts +10 -3
  231. package/dist/diagnosticUtils.js +62 -24
  232. package/dist/diagnosticUtils.js.map +1 -1
  233. package/dist/examples/plugins/removePrint.js +8 -12
  234. package/dist/examples/plugins/removePrint.js.map +1 -1
  235. package/dist/files/AssetFile.d.ts +24 -0
  236. package/dist/files/AssetFile.js +25 -0
  237. package/dist/files/AssetFile.js.map +1 -0
  238. package/dist/files/BrsFile.Class.spec.js +912 -153
  239. package/dist/files/BrsFile.Class.spec.js.map +1 -1
  240. package/dist/files/BrsFile.d.ts +142 -85
  241. package/dist/files/BrsFile.js +845 -935
  242. package/dist/files/BrsFile.js.map +1 -1
  243. package/dist/files/BrsFile.spec.js +3778 -862
  244. package/dist/files/BrsFile.spec.js.map +1 -1
  245. package/dist/files/BscFile.d.ts +101 -0
  246. package/dist/files/BscFile.js +15 -0
  247. package/dist/files/BscFile.js.map +1 -0
  248. package/dist/files/Factory.d.ts +25 -0
  249. package/dist/files/Factory.js +22 -0
  250. package/dist/files/Factory.js.map +1 -0
  251. package/dist/files/LazyFileData.d.ts +20 -0
  252. package/dist/files/LazyFileData.js +54 -0
  253. package/dist/files/LazyFileData.js.map +1 -0
  254. package/dist/files/LazyFileData.spec.d.ts +1 -0
  255. package/dist/files/LazyFileData.spec.js +27 -0
  256. package/dist/files/LazyFileData.spec.js.map +1 -0
  257. package/dist/files/XmlFile.d.ts +73 -41
  258. package/dist/files/XmlFile.js +128 -138
  259. package/dist/files/XmlFile.js.map +1 -1
  260. package/dist/files/XmlFile.spec.js +451 -324
  261. package/dist/files/XmlFile.spec.js.map +1 -1
  262. package/dist/files/tests/imports.spec.js +62 -52
  263. package/dist/files/tests/imports.spec.js.map +1 -1
  264. package/dist/files/tests/optionalChaning.spec.d.ts +1 -0
  265. package/dist/files/tests/optionalChaning.spec.js +152 -0
  266. package/dist/files/tests/optionalChaning.spec.js.map +1 -0
  267. package/dist/globalCallables.d.ts +3 -1
  268. package/dist/globalCallables.js +417 -163
  269. package/dist/globalCallables.js.map +1 -1
  270. package/dist/index.d.ts +26 -3
  271. package/dist/index.js +44 -5
  272. package/dist/index.js.map +1 -1
  273. package/dist/interfaces.d.ts +783 -122
  274. package/dist/interfaces.js +21 -0
  275. package/dist/interfaces.js.map +1 -1
  276. package/dist/lexer/Character.spec.js +5 -5
  277. package/dist/lexer/Character.spec.js.map +1 -1
  278. package/dist/lexer/Lexer.d.ts +51 -12
  279. package/dist/lexer/Lexer.js +201 -57
  280. package/dist/lexer/Lexer.js.map +1 -1
  281. package/dist/lexer/Lexer.spec.js +781 -565
  282. package/dist/lexer/Lexer.spec.js.map +1 -1
  283. package/dist/lexer/Token.d.ts +27 -11
  284. package/dist/lexer/Token.js +10 -2
  285. package/dist/lexer/Token.js.map +1 -1
  286. package/dist/lexer/TokenKind.d.ts +31 -2
  287. package/dist/lexer/TokenKind.js +134 -10
  288. package/dist/lexer/TokenKind.js.map +1 -1
  289. package/dist/logging.d.ts +9 -0
  290. package/dist/logging.js +16 -0
  291. package/dist/logging.js.map +1 -0
  292. package/dist/parser/AstNode.d.ts +191 -0
  293. package/dist/parser/AstNode.js +269 -0
  294. package/dist/parser/AstNode.js.map +1 -0
  295. package/dist/parser/AstNode.spec.d.ts +1 -0
  296. package/dist/parser/AstNode.spec.js +1455 -0
  297. package/dist/parser/AstNode.spec.js.map +1 -0
  298. package/dist/parser/BrightScriptDocParser.d.ts +56 -0
  299. package/dist/parser/BrightScriptDocParser.js +294 -0
  300. package/dist/parser/BrightScriptDocParser.js.map +1 -0
  301. package/dist/parser/BrightScriptDocParser.spec.d.ts +1 -0
  302. package/dist/parser/BrightScriptDocParser.spec.js +310 -0
  303. package/dist/parser/BrightScriptDocParser.spec.js.map +1 -0
  304. package/dist/parser/BrsTranspileState.d.ts +22 -3
  305. package/dist/parser/BrsTranspileState.js +19 -0
  306. package/dist/parser/BrsTranspileState.js.map +1 -1
  307. package/dist/parser/Expression.d.ts +489 -221
  308. package/dist/parser/Expression.js +1206 -506
  309. package/dist/parser/Expression.js.map +1 -1
  310. package/dist/parser/Expression.spec.d.ts +1 -0
  311. package/dist/parser/Expression.spec.js +40 -0
  312. package/dist/parser/Expression.spec.js.map +1 -0
  313. package/dist/parser/Parser.Class.spec.js +230 -125
  314. package/dist/parser/Parser.Class.spec.js.map +1 -1
  315. package/dist/parser/Parser.d.ts +113 -124
  316. package/dist/parser/Parser.js +1510 -983
  317. package/dist/parser/Parser.js.map +1 -1
  318. package/dist/parser/Parser.spec.d.ts +3 -1
  319. package/dist/parser/Parser.spec.js +1533 -517
  320. package/dist/parser/Parser.spec.js.map +1 -1
  321. package/dist/parser/SGParser.d.ts +60 -7
  322. package/dist/parser/SGParser.js +225 -185
  323. package/dist/parser/SGParser.js.map +1 -1
  324. package/dist/parser/SGParser.spec.js +29 -32
  325. package/dist/parser/SGParser.spec.js.map +1 -1
  326. package/dist/parser/SGTypes.d.ts +295 -52
  327. package/dist/parser/SGTypes.js +540 -187
  328. package/dist/parser/SGTypes.js.map +1 -1
  329. package/dist/parser/Statement.d.ts +808 -261
  330. package/dist/parser/Statement.js +2232 -588
  331. package/dist/parser/Statement.js.map +1 -1
  332. package/dist/parser/Statement.spec.js +133 -36
  333. package/dist/parser/Statement.spec.js.map +1 -1
  334. package/dist/parser/TranspileState.d.ts +26 -12
  335. package/dist/parser/TranspileState.js +114 -15
  336. package/dist/parser/TranspileState.js.map +1 -1
  337. package/dist/parser/tests/Parser.spec.d.ts +3 -9
  338. package/dist/parser/tests/Parser.spec.js +7 -13
  339. package/dist/parser/tests/Parser.spec.js.map +1 -1
  340. package/dist/parser/tests/controlFlow/For.spec.js +83 -75
  341. package/dist/parser/tests/controlFlow/For.spec.js.map +1 -1
  342. package/dist/parser/tests/controlFlow/ForEach.spec.js +58 -51
  343. package/dist/parser/tests/controlFlow/ForEach.spec.js.map +1 -1
  344. package/dist/parser/tests/controlFlow/If.spec.js +382 -239
  345. package/dist/parser/tests/controlFlow/If.spec.js.map +1 -1
  346. package/dist/parser/tests/controlFlow/While.spec.js +52 -45
  347. package/dist/parser/tests/controlFlow/While.spec.js.map +1 -1
  348. package/dist/parser/tests/expression/Additive.spec.js +51 -43
  349. package/dist/parser/tests/expression/Additive.spec.js.map +1 -1
  350. package/dist/parser/tests/expression/ArrayLiterals.spec.js +192 -142
  351. package/dist/parser/tests/expression/ArrayLiterals.spec.js.map +1 -1
  352. package/dist/parser/tests/expression/AssociativeArrayLiterals.spec.js +236 -160
  353. package/dist/parser/tests/expression/AssociativeArrayLiterals.spec.js.map +1 -1
  354. package/dist/parser/tests/expression/Boolean.spec.js +41 -34
  355. package/dist/parser/tests/expression/Boolean.spec.js.map +1 -1
  356. package/dist/parser/tests/expression/Call.spec.js +173 -55
  357. package/dist/parser/tests/expression/Call.spec.js.map +1 -1
  358. package/dist/parser/tests/expression/Exponential.spec.js +20 -20
  359. package/dist/parser/tests/expression/Exponential.spec.js.map +1 -1
  360. package/dist/parser/tests/expression/Function.spec.js +291 -282
  361. package/dist/parser/tests/expression/Function.spec.js.map +1 -1
  362. package/dist/parser/tests/expression/Indexing.spec.js +193 -110
  363. package/dist/parser/tests/expression/Indexing.spec.js.map +1 -1
  364. package/dist/parser/tests/expression/Multiplicative.spec.js +42 -42
  365. package/dist/parser/tests/expression/Multiplicative.spec.js.map +1 -1
  366. package/dist/parser/tests/expression/NullCoalescenceExpression.spec.js +213 -115
  367. package/dist/parser/tests/expression/NullCoalescenceExpression.spec.js.map +1 -1
  368. package/dist/parser/tests/expression/PrefixUnary.spec.js +58 -52
  369. package/dist/parser/tests/expression/PrefixUnary.spec.js.map +1 -1
  370. package/dist/parser/tests/expression/Primary.spec.js +76 -60
  371. package/dist/parser/tests/expression/Primary.spec.js.map +1 -1
  372. package/dist/parser/tests/expression/RegexLiteralExpression.spec.d.ts +1 -0
  373. package/dist/parser/tests/expression/RegexLiteralExpression.spec.js +171 -0
  374. package/dist/parser/tests/expression/RegexLiteralExpression.spec.js.map +1 -0
  375. package/dist/parser/tests/expression/Relational.spec.js +50 -50
  376. package/dist/parser/tests/expression/Relational.spec.js.map +1 -1
  377. package/dist/parser/tests/expression/SourceLiteralExpression.spec.js +31 -31
  378. package/dist/parser/tests/expression/SourceLiteralExpression.spec.js.map +1 -1
  379. package/dist/parser/tests/expression/TemplateStringExpression.spec.js +235 -94
  380. package/dist/parser/tests/expression/TemplateStringExpression.spec.js.map +1 -1
  381. package/dist/parser/tests/expression/TernaryExpression.spec.js +403 -174
  382. package/dist/parser/tests/expression/TernaryExpression.spec.js.map +1 -1
  383. package/dist/parser/tests/expression/TypeExpression.spec.d.ts +1 -0
  384. package/dist/parser/tests/expression/TypeExpression.spec.js +126 -0
  385. package/dist/parser/tests/expression/TypeExpression.spec.js.map +1 -0
  386. package/dist/parser/tests/expression/UnaryExpression.spec.d.ts +1 -0
  387. package/dist/parser/tests/expression/UnaryExpression.spec.js +52 -0
  388. package/dist/parser/tests/expression/UnaryExpression.spec.js.map +1 -0
  389. package/dist/parser/tests/statement/AssignmentOperators.spec.js +44 -44
  390. package/dist/parser/tests/statement/AssignmentOperators.spec.js.map +1 -1
  391. package/dist/parser/tests/statement/ConstStatement.spec.d.ts +1 -0
  392. package/dist/parser/tests/statement/ConstStatement.spec.js +262 -0
  393. package/dist/parser/tests/statement/ConstStatement.spec.js.map +1 -0
  394. package/dist/parser/tests/statement/Continue.spec.d.ts +1 -0
  395. package/dist/parser/tests/statement/Continue.spec.js +119 -0
  396. package/dist/parser/tests/statement/Continue.spec.js.map +1 -0
  397. package/dist/parser/tests/statement/Declaration.spec.js +61 -55
  398. package/dist/parser/tests/statement/Declaration.spec.js.map +1 -1
  399. package/dist/parser/tests/statement/Dim.spec.js +22 -22
  400. package/dist/parser/tests/statement/Dim.spec.js.map +1 -1
  401. package/dist/parser/tests/statement/Enum.spec.d.ts +1 -0
  402. package/dist/parser/tests/statement/Enum.spec.js +744 -0
  403. package/dist/parser/tests/statement/Enum.spec.js.map +1 -0
  404. package/dist/parser/tests/statement/For.spec.d.ts +1 -0
  405. package/dist/parser/tests/statement/For.spec.js +45 -0
  406. package/dist/parser/tests/statement/For.spec.js.map +1 -0
  407. package/dist/parser/tests/statement/ForEach.spec.d.ts +1 -0
  408. package/dist/parser/tests/statement/ForEach.spec.js +36 -0
  409. package/dist/parser/tests/statement/ForEach.spec.js.map +1 -0
  410. package/dist/parser/tests/statement/Function.spec.js +226 -215
  411. package/dist/parser/tests/statement/Function.spec.js.map +1 -1
  412. package/dist/parser/tests/statement/Goto.spec.js +16 -15
  413. package/dist/parser/tests/statement/Goto.spec.js.map +1 -1
  414. package/dist/parser/tests/statement/Increment.spec.js +64 -59
  415. package/dist/parser/tests/statement/Increment.spec.js.map +1 -1
  416. package/dist/parser/tests/statement/InterfaceStatement.spec.d.ts +1 -0
  417. package/dist/parser/tests/statement/InterfaceStatement.spec.js +110 -0
  418. package/dist/parser/tests/statement/InterfaceStatement.spec.js.map +1 -0
  419. package/dist/parser/tests/statement/LibraryStatement.spec.js +22 -22
  420. package/dist/parser/tests/statement/LibraryStatement.spec.js.map +1 -1
  421. package/dist/parser/tests/statement/Misc.spec.js +127 -168
  422. package/dist/parser/tests/statement/Misc.spec.js.map +1 -1
  423. package/dist/parser/tests/statement/PrintStatement.spec.js +133 -114
  424. package/dist/parser/tests/statement/PrintStatement.spec.js.map +1 -1
  425. package/dist/parser/tests/statement/ReturnStatement.spec.js +57 -54
  426. package/dist/parser/tests/statement/ReturnStatement.spec.js.map +1 -1
  427. package/dist/parser/tests/statement/Set.spec.js +131 -117
  428. package/dist/parser/tests/statement/Set.spec.js.map +1 -1
  429. package/dist/parser/tests/statement/Stop.spec.js +14 -13
  430. package/dist/parser/tests/statement/Stop.spec.js.map +1 -1
  431. package/dist/parser/tests/statement/Throw.spec.js +11 -8
  432. package/dist/parser/tests/statement/Throw.spec.js.map +1 -1
  433. package/dist/parser/tests/statement/TryCatch.spec.js +26 -15
  434. package/dist/parser/tests/statement/TryCatch.spec.js.map +1 -1
  435. package/dist/preprocessor/Manifest.d.ts +6 -6
  436. package/dist/preprocessor/Manifest.js +17 -38
  437. package/dist/preprocessor/Manifest.js.map +1 -1
  438. package/dist/preprocessor/Manifest.spec.d.ts +1 -0
  439. package/dist/preprocessor/Manifest.spec.js +78 -103
  440. package/dist/preprocessor/Manifest.spec.js.map +1 -1
  441. package/dist/roku-types/data.json +19452 -0
  442. package/dist/roku-types/index.d.ts +5533 -0
  443. package/dist/roku-types/index.js +11 -0
  444. package/dist/roku-types/index.js.map +1 -0
  445. package/dist/types/ArrayType.d.ts +9 -5
  446. package/dist/types/ArrayType.js +73 -24
  447. package/dist/types/ArrayType.js.map +1 -1
  448. package/dist/types/ArrayType.spec.js +39 -11
  449. package/dist/types/ArrayType.spec.js.map +1 -1
  450. package/dist/types/AssociativeArrayType.d.ts +14 -0
  451. package/dist/types/AssociativeArrayType.js +60 -0
  452. package/dist/types/AssociativeArrayType.js.map +1 -0
  453. package/dist/types/BaseFunctionType.d.ts +9 -0
  454. package/dist/types/BaseFunctionType.js +25 -0
  455. package/dist/types/BaseFunctionType.js.map +1 -0
  456. package/dist/types/BooleanType.d.ts +10 -5
  457. package/dist/types/BooleanType.js +21 -9
  458. package/dist/types/BooleanType.js.map +1 -1
  459. package/dist/types/BooleanType.spec.js +10 -4
  460. package/dist/types/BooleanType.spec.js.map +1 -1
  461. package/dist/types/BscType.d.ts +29 -3
  462. package/dist/types/BscType.js +121 -0
  463. package/dist/types/BscType.js.map +1 -1
  464. package/dist/types/BscTypeKind.d.ts +25 -0
  465. package/dist/types/BscTypeKind.js +30 -0
  466. package/dist/types/BscTypeKind.js.map +1 -0
  467. package/dist/types/BuiltInInterfaceAdder.d.ts +25 -0
  468. package/dist/types/BuiltInInterfaceAdder.js +201 -0
  469. package/dist/types/BuiltInInterfaceAdder.js.map +1 -0
  470. package/dist/types/BuiltInInterfaceAdder.spec.d.ts +1 -0
  471. package/dist/types/BuiltInInterfaceAdder.spec.js +115 -0
  472. package/dist/types/BuiltInInterfaceAdder.spec.js.map +1 -0
  473. package/dist/types/ClassType.d.ts +16 -0
  474. package/dist/types/ClassType.js +57 -0
  475. package/dist/types/ClassType.js.map +1 -0
  476. package/dist/types/ClassType.spec.d.ts +1 -0
  477. package/dist/types/ClassType.spec.js +76 -0
  478. package/dist/types/ClassType.spec.js.map +1 -0
  479. package/dist/types/ComponentType.d.ts +27 -0
  480. package/dist/types/ComponentType.js +83 -0
  481. package/dist/types/ComponentType.js.map +1 -0
  482. package/dist/types/DoubleType.d.ts +10 -5
  483. package/dist/types/DoubleType.js +25 -18
  484. package/dist/types/DoubleType.js.map +1 -1
  485. package/dist/types/DoubleType.spec.js +12 -4
  486. package/dist/types/DoubleType.spec.js.map +1 -1
  487. package/dist/types/DynamicType.d.ts +12 -5
  488. package/dist/types/DynamicType.js +22 -6
  489. package/dist/types/DynamicType.js.map +1 -1
  490. package/dist/types/DynamicType.spec.js +16 -5
  491. package/dist/types/DynamicType.spec.js.map +1 -1
  492. package/dist/types/EnumType.d.ts +40 -0
  493. package/dist/types/EnumType.js +80 -0
  494. package/dist/types/EnumType.js.map +1 -0
  495. package/dist/types/EnumType.spec.d.ts +1 -0
  496. package/dist/types/EnumType.spec.js +33 -0
  497. package/dist/types/EnumType.spec.js.map +1 -0
  498. package/dist/types/FloatType.d.ts +10 -5
  499. package/dist/types/FloatType.js +25 -18
  500. package/dist/types/FloatType.js.map +1 -1
  501. package/dist/types/FloatType.spec.js +4 -4
  502. package/dist/types/FloatType.spec.js.map +1 -1
  503. package/dist/types/FunctionType.d.ts +10 -22
  504. package/dist/types/FunctionType.js +26 -63
  505. package/dist/types/FunctionType.js.map +1 -1
  506. package/dist/types/InheritableType.d.ts +29 -0
  507. package/dist/types/InheritableType.js +162 -0
  508. package/dist/types/InheritableType.js.map +1 -0
  509. package/dist/types/IntegerType.d.ts +10 -5
  510. package/dist/types/IntegerType.js +25 -18
  511. package/dist/types/IntegerType.js.map +1 -1
  512. package/dist/types/IntegerType.spec.js +8 -4
  513. package/dist/types/IntegerType.spec.js.map +1 -1
  514. package/dist/types/InterfaceType.d.ts +14 -6
  515. package/dist/types/InterfaceType.js +26 -15
  516. package/dist/types/InterfaceType.js.map +1 -1
  517. package/dist/types/InterfaceType.spec.d.ts +1 -0
  518. package/dist/types/InterfaceType.spec.js +227 -0
  519. package/dist/types/InterfaceType.spec.js.map +1 -0
  520. package/dist/types/InvalidType.d.ts +9 -5
  521. package/dist/types/InvalidType.js +20 -9
  522. package/dist/types/InvalidType.js.map +1 -1
  523. package/dist/types/InvalidType.spec.js +8 -4
  524. package/dist/types/InvalidType.spec.js.map +1 -1
  525. package/dist/types/LongIntegerType.d.ts +10 -5
  526. package/dist/types/LongIntegerType.js +25 -18
  527. package/dist/types/LongIntegerType.js.map +1 -1
  528. package/dist/types/LongIntegerType.spec.js +10 -4
  529. package/dist/types/LongIntegerType.spec.js.map +1 -1
  530. package/dist/types/NamespaceType.d.ts +12 -0
  531. package/dist/types/NamespaceType.js +28 -0
  532. package/dist/types/NamespaceType.js.map +1 -0
  533. package/dist/types/ObjectType.d.ts +10 -5
  534. package/dist/types/ObjectType.js +23 -9
  535. package/dist/types/ObjectType.js.map +1 -1
  536. package/dist/types/ObjectType.spec.js +3 -3
  537. package/dist/types/ObjectType.spec.js.map +1 -1
  538. package/dist/types/ReferenceType.d.ts +79 -0
  539. package/dist/types/ReferenceType.js +522 -0
  540. package/dist/types/ReferenceType.js.map +1 -0
  541. package/dist/types/ReferenceType.spec.d.ts +1 -0
  542. package/dist/types/ReferenceType.spec.js +151 -0
  543. package/dist/types/ReferenceType.spec.js.map +1 -0
  544. package/dist/types/StringType.d.ts +13 -5
  545. package/dist/types/StringType.js +25 -9
  546. package/dist/types/StringType.js.map +1 -1
  547. package/dist/types/StringType.spec.js +3 -3
  548. package/dist/types/StringType.spec.js.map +1 -1
  549. package/dist/types/TypedFunctionType.d.ts +33 -0
  550. package/dist/types/TypedFunctionType.js +106 -0
  551. package/dist/types/TypedFunctionType.js.map +1 -0
  552. package/dist/types/TypedFunctionType.spec.d.ts +1 -0
  553. package/dist/types/TypedFunctionType.spec.js +122 -0
  554. package/dist/types/TypedFunctionType.spec.js.map +1 -0
  555. package/dist/types/UninitializedType.d.ts +8 -6
  556. package/dist/types/UninitializedType.js +15 -9
  557. package/dist/types/UninitializedType.js.map +1 -1
  558. package/dist/types/UnionType.d.ts +20 -0
  559. package/dist/types/UnionType.js +127 -0
  560. package/dist/types/UnionType.js.map +1 -0
  561. package/dist/types/UnionType.spec.d.ts +1 -0
  562. package/dist/types/UnionType.spec.js +129 -0
  563. package/dist/types/UnionType.spec.js.map +1 -0
  564. package/dist/types/VoidType.d.ts +10 -5
  565. package/dist/types/VoidType.js +20 -9
  566. package/dist/types/VoidType.js.map +1 -1
  567. package/dist/types/VoidType.spec.js +3 -3
  568. package/dist/types/VoidType.spec.js.map +1 -1
  569. package/dist/types/helper.spec.d.ts +1 -0
  570. package/dist/types/helper.spec.js +144 -0
  571. package/dist/types/helper.spec.js.map +1 -0
  572. package/dist/types/helpers.d.ts +26 -0
  573. package/dist/types/helpers.js +191 -0
  574. package/dist/types/helpers.js.map +1 -0
  575. package/dist/types/index.d.ts +22 -0
  576. package/dist/types/index.js +39 -0
  577. package/dist/types/index.js.map +1 -0
  578. package/dist/util.d.ts +272 -117
  579. package/dist/util.js +1583 -343
  580. package/dist/util.js.map +1 -1
  581. package/dist/validators/ClassValidator.d.ts +9 -15
  582. package/dist/validators/ClassValidator.js +85 -138
  583. package/dist/validators/ClassValidator.js.map +1 -1
  584. package/package.json +174 -138
  585. package/dist/astUtils/index.d.ts +0 -7
  586. package/dist/astUtils/index.js +0 -26
  587. package/dist/astUtils/index.js.map +0 -1
  588. package/dist/lexer/index.d.ts +0 -3
  589. package/dist/lexer/index.js +0 -17
  590. package/dist/lexer/index.js.map +0 -1
  591. package/dist/parser/index.d.ts +0 -3
  592. package/dist/parser/index.js +0 -16
  593. package/dist/parser/index.js.map +0 -1
  594. package/dist/preprocessor/Chunk.d.ts +0 -82
  595. package/dist/preprocessor/Chunk.js +0 -77
  596. package/dist/preprocessor/Chunk.js.map +0 -1
  597. package/dist/preprocessor/Preprocessor.d.ts +0 -60
  598. package/dist/preprocessor/Preprocessor.js +0 -156
  599. package/dist/preprocessor/Preprocessor.js.map +0 -1
  600. package/dist/preprocessor/Preprocessor.spec.js +0 -152
  601. package/dist/preprocessor/Preprocessor.spec.js.map +0 -1
  602. package/dist/preprocessor/PreprocessorParser.d.ts +0 -61
  603. package/dist/preprocessor/PreprocessorParser.js +0 -194
  604. package/dist/preprocessor/PreprocessorParser.js.map +0 -1
  605. package/dist/preprocessor/PreprocessorParser.spec.js +0 -116
  606. package/dist/preprocessor/PreprocessorParser.spec.js.map +0 -1
  607. package/dist/preprocessor/index.d.ts +0 -3
  608. package/dist/preprocessor/index.js +0 -16
  609. package/dist/preprocessor/index.js.map +0 -1
  610. package/dist/types/CustomType.d.ts +0 -10
  611. package/dist/types/CustomType.js +0 -35
  612. package/dist/types/CustomType.js.map +0 -1
  613. package/dist/types/FunctionType.spec.js +0 -29
  614. package/dist/types/FunctionType.spec.js.map +0 -1
  615. package/dist/types/LazyType.d.ts +0 -15
  616. package/dist/types/LazyType.js +0 -32
  617. package/dist/types/LazyType.js.map +0 -1
  618. /package/dist/{preprocessor/Preprocessor.spec.d.ts → astUtils/CachedLookups.spec.d.ts} +0 -0
  619. /package/dist/{preprocessor/PreprocessorParser.spec.d.ts → astUtils/Editor.spec.d.ts} +0 -0
  620. /package/dist/{types/FunctionType.spec.d.ts → bscPlugin/completions/CompletionsProcessor.spec.d.ts} +0 -0
@@ -1,69 +1,73 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- const chai_1 = require("chai");
3
+ const chai_config_spec_1 = require("../chai-config.spec");
4
4
  const DiagnosticMessages_1 = require("../DiagnosticMessages");
5
- const lexer_1 = require("../lexer");
5
+ const TokenKind_1 = require("../lexer/TokenKind");
6
+ const Lexer_1 = require("../lexer/Lexer");
6
7
  const Parser_1 = require("./Parser");
7
8
  const Statement_1 = require("./Statement");
8
9
  const Expression_1 = require("./Expression");
10
+ const testHelpers_spec_1 = require("../testHelpers.spec");
11
+ const reflection_1 = require("../astUtils/reflection");
12
+ const StringType_1 = require("../types/StringType");
9
13
  describe('parser class', () => {
10
14
  it('throws exception when used in brightscript scope', () => {
11
15
  var _a;
12
- let { tokens } = lexer_1.Lexer.scan(`
16
+ let { tokens } = Lexer_1.Lexer.scan(`
13
17
  class Person
14
18
  end class
15
19
  `);
16
20
  let { diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrightScript });
17
- chai_1.expect((_a = diagnostics[0]) === null || _a === void 0 ? void 0 : _a.code).to.equal(DiagnosticMessages_1.DiagnosticMessages.bsFeatureNotSupportedInBrsFiles('').code);
21
+ (0, chai_config_spec_1.expect)((_a = diagnostics[0]) === null || _a === void 0 ? void 0 : _a.code).to.equal(DiagnosticMessages_1.DiagnosticMessages.bsFeatureNotSupportedInBrsFiles('').code);
18
22
  });
19
- for (let keyword of lexer_1.AllowedProperties) {
23
+ for (let keyword of TokenKind_1.AllowedProperties) {
20
24
  //skip a few of the class-specific keywords that are not allowed as field/method names
21
25
  if ([
22
- lexer_1.TokenKind.Function,
23
- lexer_1.TokenKind.Rem,
24
- lexer_1.TokenKind.Sub,
25
- lexer_1.TokenKind.Public,
26
- lexer_1.TokenKind.Protected,
27
- lexer_1.TokenKind.Private,
28
- lexer_1.TokenKind.Override
26
+ TokenKind_1.TokenKind.Function,
27
+ TokenKind_1.TokenKind.Rem,
28
+ TokenKind_1.TokenKind.Sub,
29
+ TokenKind_1.TokenKind.Public,
30
+ TokenKind_1.TokenKind.Protected,
31
+ TokenKind_1.TokenKind.Private,
32
+ TokenKind_1.TokenKind.Override
29
33
  ].includes(keyword)) {
30
34
  continue;
31
35
  }
32
36
  it(`supports ${keyword} as property name`, () => {
33
37
  //test as property
34
- let { tokens } = lexer_1.Lexer.scan(`
38
+ let { tokens } = Lexer_1.Lexer.scan(`
35
39
  class Person
36
40
  ${keyword} as string
37
41
  end class
38
42
  `);
39
- let { statements, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
40
- chai_1.expect(diagnostics).to.be.lengthOf(0);
41
- chai_1.expect(statements[0]).instanceof(Statement_1.ClassStatement);
43
+ let { ast, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
44
+ (0, chai_config_spec_1.expect)(diagnostics).to.be.lengthOf(0);
45
+ (0, chai_config_spec_1.expect)(ast.statements[0]).instanceof(Statement_1.ClassStatement);
42
46
  });
43
47
  it(`supports ${keyword} as method name`, () => {
44
48
  var _a;
45
49
  //test as property
46
- let { tokens } = lexer_1.Lexer.scan(`
50
+ let { tokens } = Lexer_1.Lexer.scan(`
47
51
  class Person
48
52
  sub ${keyword}()
49
53
  end sub
50
54
  end class
51
55
  `);
52
- let { statements, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
53
- chai_1.expect((_a = diagnostics[0]) === null || _a === void 0 ? void 0 : _a.message).not.to.exist;
54
- chai_1.expect(statements[0]).instanceof(Statement_1.ClassStatement);
56
+ let { ast, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
57
+ (0, chai_config_spec_1.expect)((_a = diagnostics[0]) === null || _a === void 0 ? void 0 : _a.message).not.to.exist;
58
+ (0, chai_config_spec_1.expect)(ast.statements[0]).instanceof(Statement_1.ClassStatement);
55
59
  });
56
60
  }
57
- for (let keyword of lexer_1.AllowedLocalIdentifiers) {
61
+ for (let keyword of TokenKind_1.AllowedLocalIdentifiers) {
58
62
  it(`supports ${keyword} as class name`, () => {
59
63
  //test as property
60
- let { tokens } = lexer_1.Lexer.scan(`
64
+ let { tokens } = Lexer_1.Lexer.scan(`
61
65
  class ${keyword}
62
66
  end class
63
67
  `);
64
- let { statements, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
65
- chai_1.expect(diagnostics).to.be.lengthOf(0);
66
- chai_1.expect(statements[0]).instanceof(Statement_1.ClassStatement);
68
+ let { ast, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
69
+ (0, chai_config_spec_1.expect)(diagnostics).to.be.lengthOf(0);
70
+ (0, chai_config_spec_1.expect)(ast.statements[0]).instanceof(Statement_1.ClassStatement);
67
71
  });
68
72
  }
69
73
  it('does not allow "throw" to be defined as a local var', () => {
@@ -74,7 +78,7 @@ describe('parser class', () => {
74
78
  throw = true
75
79
  end sub
76
80
  `);
77
- chai_1.expect((_a = parser.diagnostics[0]) === null || _a === void 0 ? void 0 : _a.message).to.eql(DiagnosticMessages_1.DiagnosticMessages.foundUnexpectedToken('=').message);
81
+ (0, chai_config_spec_1.expect)((_a = parser.diagnostics[0]) === null || _a === void 0 ? void 0 : _a.message).to.eql(DiagnosticMessages_1.DiagnosticMessages.unexpectedToken('=').message);
78
82
  });
79
83
  it('does not allow function named "throw"', () => {
80
84
  var _a;
@@ -83,7 +87,7 @@ describe('parser class', () => {
83
87
  sub throw()
84
88
  end sub
85
89
  `);
86
- chai_1.expect((_a = parser.diagnostics[0]) === null || _a === void 0 ? void 0 : _a.message).to.eql(DiagnosticMessages_1.DiagnosticMessages.cannotUseReservedWordAsIdentifier('throw').message);
90
+ (0, chai_config_spec_1.expect)((_a = parser.diagnostics[0]) === null || _a === void 0 ? void 0 : _a.message).to.eql(DiagnosticMessages_1.DiagnosticMessages.cannotUseReservedWordAsIdentifier('throw').message);
87
91
  });
88
92
  it('supports the try/catch keywords in various places', () => {
89
93
  var _a;
@@ -129,161 +133,161 @@ describe('parser class', () => {
129
133
  ' sub throw()
130
134
  ' end sub
131
135
  `);
132
- chai_1.expect((_a = parser.diagnostics[0]) === null || _a === void 0 ? void 0 : _a.message).not.to.exist;
136
+ (0, chai_config_spec_1.expect)((_a = parser.diagnostics[0]) === null || _a === void 0 ? void 0 : _a.message).not.to.exist;
133
137
  });
134
138
  it('parses empty class', () => {
135
- let { tokens } = lexer_1.Lexer.scan(`
139
+ let { tokens } = Lexer_1.Lexer.scan(`
136
140
  class Person
137
141
  end class
138
142
  `);
139
- let { statements, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
140
- chai_1.expect(diagnostics).to.be.lengthOf(0);
141
- chai_1.expect(statements[0]).instanceof(Statement_1.ClassStatement);
143
+ let { ast, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
144
+ (0, chai_config_spec_1.expect)(diagnostics).to.be.lengthOf(0);
145
+ (0, chai_config_spec_1.expect)(ast.statements[0]).instanceof(Statement_1.ClassStatement);
142
146
  });
143
147
  it('bad property does not invalidate next sibling method', () => {
144
- let { tokens } = lexer_1.Lexer.scan(`
148
+ let { tokens } = Lexer_1.Lexer.scan(`
145
149
  class Person
146
150
  public firstname =
147
151
  public sub new()
148
152
  end sub
149
153
  end class
150
154
  `);
151
- let { statements } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
152
- let classStatement = statements[0];
153
- chai_1.expect(classStatement.methods[0]).to.exist;
154
- chai_1.expect(classStatement.methods[0].name.text).to.equal('new');
155
+ let { ast } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
156
+ let classStatement = ast.statements[0];
157
+ (0, chai_config_spec_1.expect)(classStatement.methods[0]).to.exist;
158
+ (0, chai_config_spec_1.expect)(classStatement.methods[0].tokens.name.text).to.equal('new');
155
159
  });
156
160
  it('catches class without name', () => {
157
- let { tokens } = lexer_1.Lexer.scan(`
161
+ let { tokens } = Lexer_1.Lexer.scan(`
158
162
  class
159
163
  end class
160
164
  `);
161
- let { statements, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
162
- chai_1.expect(diagnostics).length.to.be.greaterThan(0);
163
- chai_1.expect(diagnostics[0].code).to.equal(DiagnosticMessages_1.DiagnosticMessages.expectedIdentifierAfterKeyword('class').code);
164
- chai_1.expect(statements[0]).instanceof(Statement_1.ClassStatement);
165
+ let { ast, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
166
+ (0, chai_config_spec_1.expect)(diagnostics).length.to.be.greaterThan(0);
167
+ (0, chai_config_spec_1.expect)(diagnostics[0].code).to.equal(DiagnosticMessages_1.DiagnosticMessages.expectedIdentifierAfterKeyword('class').code);
168
+ (0, chai_config_spec_1.expect)(ast.statements[0]).instanceof(Statement_1.ClassStatement);
165
169
  });
166
170
  it('catches malformed class', () => {
167
- let { tokens } = lexer_1.Lexer.scan(`
171
+ let { tokens } = Lexer_1.Lexer.scan(`
168
172
  class Person
169
173
  `);
170
- let { statements, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
171
- chai_1.expect(diagnostics).length.to.be.greaterThan(0);
172
- chai_1.expect(statements[0]).instanceof(Statement_1.ClassStatement);
174
+ let { ast, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
175
+ (0, chai_config_spec_1.expect)(diagnostics).length.to.be.greaterThan(0);
176
+ (0, chai_config_spec_1.expect)(ast.statements[0]).instanceof(Statement_1.ClassStatement);
173
177
  });
174
178
  describe('fields', () => {
175
179
  it('identifies perfect syntax', () => {
176
- let { tokens } = lexer_1.Lexer.scan(`
180
+ let { tokens } = Lexer_1.Lexer.scan(`
177
181
  class Person
178
182
  public firstName as string
179
183
  end class
180
184
  `);
181
- let { statements, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
182
- chai_1.expect(diagnostics).to.be.empty;
183
- chai_1.expect(statements[0]).instanceof(Statement_1.ClassStatement);
184
- let field = statements[0].body[0];
185
- chai_1.expect(field.accessModifier.kind).to.equal(lexer_1.TokenKind.Public);
186
- chai_1.expect(field.name.text).to.equal('firstName');
187
- chai_1.expect(field.as.text).to.equal('as');
188
- chai_1.expect(field.type.text).to.equal('string');
185
+ let { ast, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
186
+ (0, chai_config_spec_1.expect)(diagnostics).to.be.empty;
187
+ (0, chai_config_spec_1.expect)(ast.statements[0]).instanceof(Statement_1.ClassStatement);
188
+ let field = ast.statements[0].body[0];
189
+ (0, chai_config_spec_1.expect)(field.tokens.accessModifier.kind).to.equal(TokenKind_1.TokenKind.Public);
190
+ (0, chai_config_spec_1.expect)(field.tokens.name.text).to.equal('firstName');
191
+ (0, chai_config_spec_1.expect)(field.tokens.as.text).to.equal('as');
192
+ (0, chai_config_spec_1.expect)(field.getType({ flags: 2 /* SymbolTypeFlag.typetime */ })).to.be.instanceOf(StringType_1.StringType);
189
193
  });
190
194
  it('can be solely an identifier', () => {
191
- let { tokens } = lexer_1.Lexer.scan(`
195
+ let { tokens } = Lexer_1.Lexer.scan(`
192
196
  class Person
193
197
  firstName
194
198
  end class
195
199
  `);
196
- let { statements, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
197
- chai_1.expect(diagnostics).to.be.lengthOf(0);
198
- let cls = statements[0];
199
- chai_1.expect(cls.fields[0].name.text).to.equal('firstName');
200
+ let { ast, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
201
+ (0, chai_config_spec_1.expect)(diagnostics).to.be.lengthOf(0);
202
+ let cls = ast.statements[0];
203
+ (0, chai_config_spec_1.expect)(cls.fields[0].tokens.name.text).to.equal('firstName');
200
204
  });
201
205
  it('malformed field does not impact leading and trailing fields', () => {
202
- let { tokens } = lexer_1.Lexer.scan(`
206
+ let { tokens } = Lexer_1.Lexer.scan(`
203
207
  class Person
204
208
  firstName as string
205
209
  middleName asdf asdf asdf
206
210
  lastName as string
207
211
  end class
208
212
  `);
209
- let { statements } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
210
- let cls = statements[0];
211
- chai_1.expect(cls.fields[0].name.text).to.equal('firstName');
212
- chai_1.expect(cls.fields[cls.fields.length - 1].name.text).to.equal('lastName');
213
+ let { ast } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
214
+ let cls = ast.statements[0];
215
+ (0, chai_config_spec_1.expect)(cls.fields[0].tokens.name.text).to.equal('firstName');
216
+ (0, chai_config_spec_1.expect)(cls.fields[cls.fields.length - 1].tokens.name.text).to.equal('lastName');
213
217
  });
214
218
  it(`detects missing type after 'as' keyword`, () => {
215
- let { tokens } = lexer_1.Lexer.scan(`
216
- class Person
217
- middleName as
218
- end class
219
- `);
220
- let { diagnostics, statements } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
221
- chai_1.expect(diagnostics.length).to.be.greaterThan(0);
222
- let cls = statements[0];
223
- chai_1.expect(cls.fields[0].name.text).to.equal('middleName');
224
- chai_1.expect(diagnostics[0].code).to.equal(DiagnosticMessages_1.DiagnosticMessages.expectedIdentifierAfterKeyword('as').code);
219
+ let { tokens } = Lexer_1.Lexer.scan(`
220
+ class Person
221
+ middleName as
222
+ end class
223
+ `);
224
+ let { ast, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
225
+ (0, chai_config_spec_1.expect)(diagnostics.length).to.be.greaterThan(0);
226
+ let cls = ast.statements[0];
227
+ (0, chai_config_spec_1.expect)(cls.fields[0].tokens.name.text).to.equal('middleName');
228
+ (0, testHelpers_spec_1.expectDiagnosticsIncludes)(diagnostics, DiagnosticMessages_1.DiagnosticMessages.expectedIdentifierAfterKeyword('as'));
225
229
  });
226
230
  it('field access modifier defaults to undefined when omitted', () => {
227
- let { tokens } = lexer_1.Lexer.scan(`
231
+ let { tokens } = Lexer_1.Lexer.scan(`
228
232
  class Person
229
233
  firstName as string
230
234
  end class
231
235
  `);
232
- let { statements, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
233
- chai_1.expect(diagnostics).to.be.lengthOf(0);
234
- let cls = statements[0];
235
- chai_1.expect(cls.fields[0].accessModifier).to.be.undefined;
236
+ let { ast, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
237
+ (0, chai_config_spec_1.expect)(diagnostics).to.be.lengthOf(0);
238
+ let cls = ast.statements[0];
239
+ (0, chai_config_spec_1.expect)(cls.fields[0].tokens.accessModifier).to.be.undefined;
236
240
  });
237
241
  });
238
242
  describe('methods', () => {
239
243
  it('recognizes perfect syntax', () => {
240
- let { tokens } = lexer_1.Lexer.scan(`
244
+ let { tokens } = Lexer_1.Lexer.scan(`
241
245
  class Person
242
246
  public function getName() as string
243
247
  return "name"
244
248
  end function
245
249
  end class
246
250
  `);
247
- let { statements, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
248
- chai_1.expect(diagnostics).to.be.lengthOf(0);
249
- let theClass = statements[0];
250
- chai_1.expect(theClass).to.be.instanceof(Statement_1.ClassStatement);
251
+ let { ast, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
252
+ (0, chai_config_spec_1.expect)(diagnostics).to.be.lengthOf(0);
253
+ let theClass = ast.statements[0];
254
+ (0, chai_config_spec_1.expect)(theClass).to.be.instanceof(Statement_1.ClassStatement);
251
255
  let method = theClass.methods[0];
252
- chai_1.expect(method.name.text).to.equal('getName');
253
- chai_1.expect(method.accessModifier.text).to.equal('public');
254
- chai_1.expect(method.func).to.exist;
256
+ (0, chai_config_spec_1.expect)(method.tokens.name.text).to.equal('getName');
257
+ (0, chai_config_spec_1.expect)(method.accessModifier.text).to.equal('public');
258
+ (0, chai_config_spec_1.expect)(method.func).to.exist;
255
259
  });
256
260
  it('supports omitting method return type', () => {
257
- let { tokens } = lexer_1.Lexer.scan(`
261
+ let { tokens } = Lexer_1.Lexer.scan(`
258
262
  class Person
259
263
  public function getName()
260
264
  return "name"
261
265
  end function
262
266
  end class
263
267
  `);
264
- let { statements, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
265
- chai_1.expect(diagnostics).to.be.lengthOf(0);
266
- let theClass = statements[0];
268
+ let { ast, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
269
+ (0, chai_config_spec_1.expect)(diagnostics).to.be.lengthOf(0);
270
+ let theClass = ast.statements[0];
267
271
  let method = theClass.methods[0];
268
- chai_1.expect(method.accessModifier.text).to.equal('public');
269
- chai_1.expect(method.func).to.exist;
272
+ (0, chai_config_spec_1.expect)(method.accessModifier.text).to.equal('public');
273
+ (0, chai_config_spec_1.expect)(method.func).to.exist;
270
274
  });
271
275
  it('method access modifier is undefined when omitted', () => {
272
- let { tokens } = lexer_1.Lexer.scan(`
276
+ let { tokens } = Lexer_1.Lexer.scan(`
273
277
  class Person
274
278
  function getName() as string
275
279
  return "name"
276
280
  end function
277
281
  end class
278
282
  `);
279
- let { statements, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
280
- chai_1.expect(diagnostics).to.be.lengthOf(0);
281
- let cls = statements[0];
282
- chai_1.expect(cls.methods[0].accessModifier).to.be.undefined;
283
+ let { ast, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
284
+ (0, chai_config_spec_1.expect)(diagnostics).to.be.lengthOf(0);
285
+ let cls = ast.statements[0];
286
+ (0, chai_config_spec_1.expect)(cls.methods[0].accessModifier).to.be.undefined;
283
287
  });
284
- it('supports primative field initializers', () => {
288
+ it('supports primitive field initializers', () => {
285
289
  var _a;
286
- let { tokens } = lexer_1.Lexer.scan(`
290
+ let { tokens } = Lexer_1.Lexer.scan(`
287
291
  class Person
288
292
  name = "Bob"
289
293
  age = 20
@@ -293,16 +297,16 @@ describe('parser class', () => {
293
297
  end sub
294
298
  end class
295
299
  `);
296
- let { statements, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
297
- chai_1.expect((_a = diagnostics[0]) === null || _a === void 0 ? void 0 : _a.message).not.to.exist;
298
- let cls = statements[0];
299
- chai_1.expect(cls.memberMap['name'].initialValue).to.exist;
300
- chai_1.expect(cls.memberMap['age'].initialValue).to.exist;
301
- chai_1.expect(cls.memberMap['isalive'].initialValue).to.exist;
302
- chai_1.expect(cls.memberMap['callback'].initialValue).to.exist;
300
+ let { ast, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
301
+ (0, chai_config_spec_1.expect)((_a = diagnostics[0]) === null || _a === void 0 ? void 0 : _a.message).not.to.exist;
302
+ let cls = ast.statements[0];
303
+ (0, chai_config_spec_1.expect)(cls.memberMap['name'].initialValue).to.exist;
304
+ (0, chai_config_spec_1.expect)(cls.memberMap['age'].initialValue).to.exist;
305
+ (0, chai_config_spec_1.expect)(cls.memberMap['isalive'].initialValue).to.exist;
306
+ (0, chai_config_spec_1.expect)(cls.memberMap['callback'].initialValue).to.exist;
303
307
  });
304
308
  it('detects missing function keyword', () => {
305
- let { tokens } = lexer_1.Lexer.scan(`
309
+ let { tokens } = Lexer_1.Lexer.scan(`
306
310
  class Person
307
311
  public getName() as string
308
312
  return "name"
@@ -310,8 +314,8 @@ describe('parser class', () => {
310
314
  end class
311
315
  `);
312
316
  let { diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
313
- chai_1.expect(diagnostics).to.have.lengthOf(1);
314
- chai_1.expect(diagnostics[0].code).to.equal(DiagnosticMessages_1.DiagnosticMessages.missingCallableKeyword().code);
317
+ (0, chai_config_spec_1.expect)(diagnostics).to.have.lengthOf(1);
318
+ (0, chai_config_spec_1.expect)(diagnostics[0].code).to.equal(DiagnosticMessages_1.DiagnosticMessages.missingCallableKeyword().code);
315
319
  });
316
320
  });
317
321
  it('supports comments in various locations', () => {
@@ -326,11 +330,11 @@ describe('parser class', () => {
326
330
  'comment
327
331
  end class 'comment
328
332
  `, { mode: Parser_1.ParseMode.BrighterScript });
329
- chai_1.expect((_a = diagnostics[0]) === null || _a === void 0 ? void 0 : _a.message).to.not.exist;
333
+ (0, chai_config_spec_1.expect)((_a = diagnostics[0]) === null || _a === void 0 ? void 0 : _a.message).to.not.exist;
330
334
  });
331
335
  it('recognizes the "extends" keyword', () => {
332
336
  var _a;
333
- let { tokens } = lexer_1.Lexer.scan(`
337
+ let { tokens } = Lexer_1.Lexer.scan(`
334
338
  class Person
335
339
  public sub sayHi()
336
340
  print "hi"
@@ -340,14 +344,14 @@ describe('parser class', () => {
340
344
  class Toddler extends Person
341
345
  end class
342
346
  `);
343
- let { statements, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
344
- chai_1.expect((_a = diagnostics[0]) === null || _a === void 0 ? void 0 : _a.message).to.not.exist;
345
- let stmt = statements[1];
346
- chai_1.expect(stmt.extendsKeyword.text).to.equal('extends');
347
- chai_1.expect(stmt.parentClassName.getName(Parser_1.ParseMode.BrighterScript)).to.equal('Person');
347
+ let { ast, diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
348
+ (0, chai_config_spec_1.expect)((_a = diagnostics[0]) === null || _a === void 0 ? void 0 : _a.message).to.not.exist;
349
+ let stmt = ast.statements[1];
350
+ (0, chai_config_spec_1.expect)(stmt.tokens.extends.text).to.equal('extends');
351
+ (0, chai_config_spec_1.expect)(stmt.parentClassName.getName()).to.equal('Person');
348
352
  });
349
353
  it('catches missing identifier after "extends" keyword', () => {
350
- let { tokens } = lexer_1.Lexer.scan(`
354
+ let { tokens } = Lexer_1.Lexer.scan(`
351
355
  class Person
352
356
  public sub sayHi()
353
357
  print "hi"
@@ -358,22 +362,22 @@ describe('parser class', () => {
358
362
  end class
359
363
  `);
360
364
  let { diagnostics } = Parser_1.Parser.parse(tokens, { mode: Parser_1.ParseMode.BrighterScript });
361
- chai_1.expect(diagnostics[0].code).to.equal(DiagnosticMessages_1.DiagnosticMessages.expectedIdentifierAfterKeyword('extends').code);
365
+ (0, chai_config_spec_1.expect)(diagnostics[0].code).to.equal(DiagnosticMessages_1.DiagnosticMessages.expectedIdentifierAfterKeyword('extends').code);
362
366
  });
363
367
  describe('new keyword', () => {
364
368
  it('parses properly', () => {
365
369
  var _a;
366
- let { statements, diagnostics } = Parser_1.Parser.parse(`
370
+ let { ast, diagnostics } = Parser_1.Parser.parse(`
367
371
  sub main()
368
372
  a = new Animal()
369
373
  end sub
370
374
  class Animal
371
375
  end class
372
376
  `, { mode: Parser_1.ParseMode.BrighterScript });
373
- chai_1.expect((_a = diagnostics[0]) === null || _a === void 0 ? void 0 : _a.message).to.not.exist;
374
- let body = statements[0].func.body;
377
+ (0, chai_config_spec_1.expect)((_a = diagnostics[0]) === null || _a === void 0 ? void 0 : _a.message).to.not.exist;
378
+ let body = ast.statements[0].func.body;
375
379
  let stmt = body.statements[0];
376
- chai_1.expect(stmt.value).to.be.instanceof(Expression_1.NewExpression);
380
+ (0, chai_config_spec_1.expect)(stmt.value).to.be.instanceof(Expression_1.NewExpression);
377
381
  });
378
382
  it('is allowed to be used as a local variable in brs files', () => {
379
383
  var _a;
@@ -383,7 +387,108 @@ describe('parser class', () => {
383
387
  old = new
384
388
  end sub
385
389
  `, { mode: Parser_1.ParseMode.BrightScript });
386
- chai_1.expect((_a = diagnostics[0]) === null || _a === void 0 ? void 0 : _a.message).to.not.exist;
390
+ (0, chai_config_spec_1.expect)((_a = diagnostics[0]) === null || _a === void 0 ? void 0 : _a.message).to.not.exist;
391
+ });
392
+ });
393
+ describe('optional members', () => {
394
+ it('allows optional fields', () => {
395
+ let { ast, diagnostics } = Parser_1.Parser.parse(`
396
+ class HasOptional
397
+ optional name as string
398
+ optional height
399
+ end class
400
+ `, { mode: Parser_1.ParseMode.BrighterScript });
401
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(diagnostics);
402
+ (0, chai_config_spec_1.expect)(ast.statements.length).to.eq(1);
403
+ (0, chai_config_spec_1.expect)((0, reflection_1.isClassStatement)(ast.statements[0])).to.be.true;
404
+ const klass = ast.statements[0];
405
+ klass.fields.forEach(f => (0, chai_config_spec_1.expect)(f.isOptional).to.be.true);
406
+ const klassType = klass.getType({ flags: 2 /* SymbolTypeFlag.typetime */ });
407
+ // eslint-disable-next-line no-bitwise
408
+ klassType.getMemberTable().getAllSymbols(1 /* SymbolTypeFlag.runtime */).forEach(sym => (0, chai_config_spec_1.expect)(sym.flags & 4 /* SymbolTypeFlag.optional */).to.eq(4 /* SymbolTypeFlag.optional */));
409
+ });
410
+ it('allows fields named optional', () => {
411
+ let { ast, diagnostics } = Parser_1.Parser.parse(`
412
+ class IsJustOptional
413
+ optional
414
+ someThingElse
415
+ end class
416
+ `, { mode: Parser_1.ParseMode.BrighterScript });
417
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(diagnostics);
418
+ (0, chai_config_spec_1.expect)(ast.statements.length).to.eq(1);
419
+ (0, chai_config_spec_1.expect)((0, reflection_1.isClassStatement)(ast.statements[0])).to.be.true;
420
+ const klass = ast.statements[0];
421
+ klass.fields.forEach(f => (0, chai_config_spec_1.expect)(f.isOptional).to.be.false);
422
+ const klassType = klass.getType({ flags: 2 /* SymbolTypeFlag.typetime */ });
423
+ const klassMembers = klassType.getMemberTable().getAllSymbols(1 /* SymbolTypeFlag.runtime */);
424
+ (0, chai_config_spec_1.expect)(klassMembers.length).to.eq(2);
425
+ // eslint-disable-next-line no-bitwise
426
+ klassMembers.forEach(sym => (0, chai_config_spec_1.expect)(sym.flags & 4 /* SymbolTypeFlag.optional */).to.eq(0));
427
+ });
428
+ it('allows typed fields named optional', () => {
429
+ let { ast, diagnostics } = Parser_1.Parser.parse(`
430
+ class IsJustOptional
431
+ optional as string
432
+ end class
433
+ `, { mode: Parser_1.ParseMode.BrighterScript });
434
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(diagnostics);
435
+ (0, chai_config_spec_1.expect)(ast.statements.length).to.eq(1);
436
+ (0, chai_config_spec_1.expect)((0, reflection_1.isClassStatement)(ast.statements[0])).to.be.true;
437
+ const klass = ast.statements[0];
438
+ klass.fields.forEach(f => (0, chai_config_spec_1.expect)(f.isOptional).to.be.false);
439
+ const klassType = klass.getType({ flags: 2 /* SymbolTypeFlag.typetime */ });
440
+ const klassMembers = klassType.getMemberTable().getAllSymbols(1 /* SymbolTypeFlag.runtime */);
441
+ (0, chai_config_spec_1.expect)(klassMembers.length).to.eq(1);
442
+ // eslint-disable-next-line no-bitwise
443
+ klassMembers.forEach(sym => (0, chai_config_spec_1.expect)(sym.flags & 4 /* SymbolTypeFlag.optional */).to.eq(0));
444
+ });
445
+ it('allows fields named optional that are also optional', () => {
446
+ let { ast, diagnostics } = Parser_1.Parser.parse(`
447
+ class IsJustOptional
448
+ optional optional
449
+ end class
450
+ `, { mode: Parser_1.ParseMode.BrighterScript });
451
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(diagnostics);
452
+ (0, chai_config_spec_1.expect)(ast.statements.length).to.eq(1);
453
+ (0, chai_config_spec_1.expect)((0, reflection_1.isClassStatement)(ast.statements[0])).to.be.true;
454
+ const klass = ast.statements[0];
455
+ klass.fields.forEach(f => (0, chai_config_spec_1.expect)(f.isOptional).to.be.true);
456
+ const klassType = klass.getType({ flags: 2 /* SymbolTypeFlag.typetime */ });
457
+ const klassMembers = klassType.getMemberTable().getAllSymbols(1 /* SymbolTypeFlag.runtime */);
458
+ (0, chai_config_spec_1.expect)(klassMembers.length).to.eq(1);
459
+ // eslint-disable-next-line no-bitwise
460
+ klassMembers.forEach(sym => (0, chai_config_spec_1.expect)(sym.flags & 4 /* SymbolTypeFlag.optional */).to.eq(4 /* SymbolTypeFlag.optional */));
461
+ });
462
+ it('disallows optional methods', () => {
463
+ let { ast, diagnostics } = Parser_1.Parser.parse(`
464
+ class HasOptional
465
+
466
+ optional function getValue() as boolean
467
+ return false
468
+ end function
469
+ end class
470
+ `, { mode: Parser_1.ParseMode.BrighterScript });
471
+ (0, testHelpers_spec_1.expectDiagnosticsIncludes)(diagnostics, [
472
+ DiagnosticMessages_1.DiagnosticMessages.expectedNewlineOrColon().message
473
+ ]);
474
+ (0, chai_config_spec_1.expect)(ast.statements.length).to.eq(1);
475
+ });
476
+ it('allows fields named `as` that are also optional', () => {
477
+ let { ast, diagnostics } = Parser_1.Parser.parse(`
478
+ class IsJustOptional
479
+ optional as
480
+ end class
481
+ `, { mode: Parser_1.ParseMode.BrighterScript });
482
+ (0, testHelpers_spec_1.expectZeroDiagnostics)(diagnostics);
483
+ (0, chai_config_spec_1.expect)(ast.statements.length).to.eq(1);
484
+ (0, chai_config_spec_1.expect)((0, reflection_1.isClassStatement)(ast.statements[0])).to.be.true;
485
+ const klass = ast.statements[0];
486
+ klass.fields.forEach(f => (0, chai_config_spec_1.expect)(f.isOptional).to.be.true);
487
+ const klassType = klass.getType({ flags: 2 /* SymbolTypeFlag.typetime */ });
488
+ const klassMembers = klassType.getMemberTable().getAllSymbols(1 /* SymbolTypeFlag.runtime */);
489
+ (0, chai_config_spec_1.expect)(klassMembers.length).to.eq(1);
490
+ // eslint-disable-next-line no-bitwise
491
+ klassMembers.forEach(sym => (0, chai_config_spec_1.expect)(sym.flags & 4 /* SymbolTypeFlag.optional */).to.eq(4 /* SymbolTypeFlag.optional */));
387
492
  });
388
493
  });
389
494
  });