brighterscript 1.0.0-alpha.3 → 1.0.0-alpha.30
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.
- package/CHANGELOG.md +1230 -285
- package/README.md +61 -131
- package/bsconfig.schema.json +68 -2
- package/dist/ActionPipeline.d.ts +10 -0
- package/dist/ActionPipeline.js +40 -0
- package/dist/ActionPipeline.js.map +1 -0
- package/dist/AstValidationSegmenter.d.ts +35 -0
- package/dist/AstValidationSegmenter.js +209 -0
- package/dist/AstValidationSegmenter.js.map +1 -0
- package/dist/BsConfig.d.ts +51 -6
- package/dist/BusyStatusTracker.d.ts +31 -0
- package/dist/BusyStatusTracker.js +83 -0
- package/dist/BusyStatusTracker.js.map +1 -0
- package/dist/Cache.d.ts +5 -6
- package/dist/Cache.js +12 -11
- package/dist/Cache.js.map +1 -1
- package/dist/CacheVerifier.d.ts +7 -0
- package/dist/CacheVerifier.js +20 -0
- package/dist/CacheVerifier.js.map +1 -0
- package/dist/CodeActionUtil.d.ts +11 -2
- package/dist/CodeActionUtil.js +17 -3
- package/dist/CodeActionUtil.js.map +1 -1
- package/dist/CommentFlagProcessor.d.ts +7 -6
- package/dist/CommentFlagProcessor.js +10 -7
- package/dist/CommentFlagProcessor.js.map +1 -1
- package/dist/DependencyGraph.d.ts +8 -3
- package/dist/DependencyGraph.js +49 -16
- package/dist/DependencyGraph.js.map +1 -1
- package/dist/DiagnosticCollection.d.ts +5 -3
- package/dist/DiagnosticCollection.js +18 -16
- package/dist/DiagnosticCollection.js.map +1 -1
- package/dist/DiagnosticFilterer.d.ts +8 -4
- package/dist/DiagnosticFilterer.js +77 -44
- package/dist/DiagnosticFilterer.js.map +1 -1
- package/dist/DiagnosticManager.d.ts +55 -0
- package/dist/DiagnosticManager.js +214 -0
- package/dist/DiagnosticManager.js.map +1 -0
- package/dist/DiagnosticMessages.d.ts +184 -17
- package/dist/DiagnosticMessages.js +242 -24
- package/dist/DiagnosticMessages.js.map +1 -1
- package/dist/DiagnosticSeverityAdjuster.d.ts +7 -0
- package/dist/DiagnosticSeverityAdjuster.js +41 -0
- package/dist/DiagnosticSeverityAdjuster.js.map +1 -0
- package/dist/FunctionScope.d.ts +28 -0
- package/dist/FunctionScope.js +52 -0
- package/dist/FunctionScope.js.map +1 -0
- package/dist/KeyedThrottler.d.ts +3 -3
- package/dist/KeyedThrottler.js +3 -3
- package/dist/KeyedThrottler.js.map +1 -1
- package/dist/LanguageServer.d.ts +72 -47
- package/dist/LanguageServer.js +544 -312
- package/dist/LanguageServer.js.map +1 -1
- package/dist/Logger.d.ts +9 -10
- package/dist/Logger.js +36 -30
- package/dist/Logger.js.map +1 -1
- package/dist/PluginInterface.d.ts +29 -7
- package/dist/PluginInterface.js +90 -7
- package/dist/PluginInterface.js.map +1 -1
- package/dist/Program.d.ts +204 -99
- package/dist/Program.js +1060 -699
- package/dist/Program.js.map +1 -1
- package/dist/ProgramBuilder.d.ts +29 -18
- package/dist/ProgramBuilder.js +170 -132
- package/dist/ProgramBuilder.js.map +1 -1
- package/dist/Scope.d.ts +144 -109
- package/dist/Scope.js +538 -551
- package/dist/Scope.js.map +1 -1
- package/dist/SemanticTokenUtils.d.ts +14 -0
- package/dist/SemanticTokenUtils.js +81 -0
- package/dist/SemanticTokenUtils.js.map +1 -0
- package/dist/Stopwatch.d.ts +4 -0
- package/dist/Stopwatch.js +8 -1
- package/dist/Stopwatch.js.map +1 -1
- package/dist/SymbolTable.d.ts +91 -24
- package/dist/SymbolTable.js +286 -63
- package/dist/SymbolTable.js.map +1 -1
- package/dist/SymbolTypeFlag.d.ts +8 -0
- package/dist/SymbolTypeFlag.js +13 -0
- package/dist/SymbolTypeFlag.js.map +1 -0
- package/dist/Throttler.d.ts +12 -0
- package/dist/Throttler.js +39 -0
- package/dist/Throttler.js.map +1 -1
- package/dist/Watcher.d.ts +0 -3
- package/dist/Watcher.js +0 -3
- package/dist/Watcher.js.map +1 -1
- package/dist/XmlScope.d.ts +5 -15
- package/dist/XmlScope.js +35 -87
- package/dist/XmlScope.js.map +1 -1
- package/dist/astUtils/CachedLookups.d.ts +49 -0
- package/dist/astUtils/CachedLookups.js +324 -0
- package/dist/astUtils/CachedLookups.js.map +1 -0
- package/dist/astUtils/Editor.d.ts +69 -0
- package/dist/astUtils/Editor.js +245 -0
- package/dist/astUtils/Editor.js.map +1 -0
- package/dist/astUtils/Editor.spec.js +258 -0
- package/dist/astUtils/Editor.spec.js.map +1 -0
- package/dist/astUtils/creators.d.ts +33 -10
- package/dist/astUtils/creators.js +224 -30
- package/dist/astUtils/creators.js.map +1 -1
- package/dist/astUtils/creators.spec.js +5 -5
- package/dist/astUtils/creators.spec.js.map +1 -1
- package/dist/astUtils/reflection.d.ts +145 -82
- package/dist/astUtils/reflection.js +304 -132
- package/dist/astUtils/reflection.js.map +1 -1
- package/dist/astUtils/reflection.spec.js +267 -162
- package/dist/astUtils/reflection.spec.js.map +1 -1
- package/dist/astUtils/stackedVisitor.js.map +1 -1
- package/dist/astUtils/stackedVisitor.spec.js +14 -14
- package/dist/astUtils/stackedVisitor.spec.js.map +1 -1
- package/dist/astUtils/visitors.d.ts +114 -53
- package/dist/astUtils/visitors.js +70 -13
- package/dist/astUtils/visitors.js.map +1 -1
- package/dist/astUtils/visitors.spec.js +465 -51
- package/dist/astUtils/visitors.spec.js.map +1 -1
- package/dist/astUtils/xml.d.ts +9 -8
- package/dist/astUtils/xml.js +10 -5
- package/dist/astUtils/xml.js.map +1 -1
- package/dist/bscPlugin/BscPlugin.d.ts +22 -1
- package/dist/bscPlugin/BscPlugin.js +88 -0
- package/dist/bscPlugin/BscPlugin.js.map +1 -1
- package/dist/bscPlugin/CallExpressionInfo.d.ts +36 -0
- package/dist/bscPlugin/CallExpressionInfo.js +131 -0
- package/dist/bscPlugin/CallExpressionInfo.js.map +1 -0
- package/dist/bscPlugin/FileWriter.d.ts +6 -0
- package/dist/bscPlugin/FileWriter.js +24 -0
- package/dist/bscPlugin/FileWriter.js.map +1 -0
- package/dist/bscPlugin/SignatureHelpUtil.d.ts +10 -0
- package/dist/bscPlugin/SignatureHelpUtil.js +137 -0
- package/dist/bscPlugin/SignatureHelpUtil.js.map +1 -0
- package/dist/bscPlugin/codeActions/CodeActionsProcessor.d.ts +1 -1
- package/dist/bscPlugin/codeActions/CodeActionsProcessor.js +26 -17
- package/dist/bscPlugin/codeActions/CodeActionsProcessor.js.map +1 -1
- package/dist/bscPlugin/codeActions/CodeActionsProcessor.spec.js +94 -20
- package/dist/bscPlugin/codeActions/CodeActionsProcessor.spec.js.map +1 -1
- package/dist/bscPlugin/completions/CompletionsProcessor.d.ts +60 -0
- package/dist/bscPlugin/completions/CompletionsProcessor.js +601 -0
- package/dist/bscPlugin/completions/CompletionsProcessor.js.map +1 -0
- package/dist/bscPlugin/completions/CompletionsProcessor.spec.js +2139 -0
- package/dist/bscPlugin/completions/CompletionsProcessor.spec.js.map +1 -0
- package/dist/bscPlugin/definition/DefinitionProvider.d.ts +13 -0
- package/dist/bscPlugin/definition/DefinitionProvider.js +210 -0
- package/dist/bscPlugin/definition/DefinitionProvider.js.map +1 -0
- package/dist/bscPlugin/definition/DefinitionProvider.spec.js +88 -0
- package/dist/bscPlugin/definition/DefinitionProvider.spec.js.map +1 -0
- package/dist/bscPlugin/fileProviders/FileProvider.d.ts +9 -0
- package/dist/bscPlugin/fileProviders/FileProvider.js +51 -0
- package/dist/bscPlugin/fileProviders/FileProvider.js.map +1 -0
- package/dist/bscPlugin/hover/HoverProcessor.d.ts +18 -0
- package/dist/bscPlugin/hover/HoverProcessor.js +218 -0
- package/dist/bscPlugin/hover/HoverProcessor.js.map +1 -0
- package/dist/bscPlugin/hover/HoverProcessor.spec.d.ts +1 -0
- package/dist/bscPlugin/hover/HoverProcessor.spec.js +737 -0
- package/dist/bscPlugin/hover/HoverProcessor.spec.js.map +1 -0
- package/dist/bscPlugin/references/ReferencesProvider.d.ts +12 -0
- package/dist/bscPlugin/references/ReferencesProvider.js +56 -0
- package/dist/bscPlugin/references/ReferencesProvider.js.map +1 -0
- package/dist/bscPlugin/references/ReferencesProvider.spec.d.ts +1 -0
- package/dist/bscPlugin/references/ReferencesProvider.spec.js +51 -0
- package/dist/bscPlugin/references/ReferencesProvider.spec.js.map +1 -0
- package/dist/bscPlugin/semanticTokens/BrsFileSemanticTokensProcessor.d.ts +14 -0
- package/dist/bscPlugin/semanticTokens/BrsFileSemanticTokensProcessor.js +138 -0
- package/dist/bscPlugin/semanticTokens/BrsFileSemanticTokensProcessor.js.map +1 -0
- package/dist/bscPlugin/semanticTokens/BrsFileSemanticTokensProcessor.spec.d.ts +1 -0
- package/dist/bscPlugin/semanticTokens/BrsFileSemanticTokensProcessor.spec.js +491 -0
- package/dist/bscPlugin/semanticTokens/BrsFileSemanticTokensProcessor.spec.js.map +1 -0
- package/dist/bscPlugin/serialize/BslibInjector.spec.d.ts +1 -0
- package/dist/bscPlugin/serialize/BslibInjector.spec.js +19 -0
- package/dist/bscPlugin/serialize/BslibInjector.spec.js.map +1 -0
- package/dist/bscPlugin/serialize/BslibManager.d.ts +9 -0
- package/dist/bscPlugin/serialize/BslibManager.js +40 -0
- package/dist/bscPlugin/serialize/BslibManager.js.map +1 -0
- package/dist/bscPlugin/serialize/FileSerializer.d.ts +9 -0
- package/dist/bscPlugin/serialize/FileSerializer.js +72 -0
- package/dist/bscPlugin/serialize/FileSerializer.js.map +1 -0
- package/dist/bscPlugin/symbols/DocumentSymbolProcessor.d.ts +7 -0
- package/dist/bscPlugin/symbols/DocumentSymbolProcessor.js +22 -0
- package/dist/bscPlugin/symbols/DocumentSymbolProcessor.js.map +1 -0
- package/dist/bscPlugin/symbols/DocumentSymbolProcessor.spec.d.ts +1 -0
- package/dist/bscPlugin/symbols/DocumentSymbolProcessor.spec.js +291 -0
- package/dist/bscPlugin/symbols/DocumentSymbolProcessor.spec.js.map +1 -0
- package/dist/bscPlugin/symbols/WorkspaceSymbolProcessor.d.ts +7 -0
- package/dist/bscPlugin/symbols/WorkspaceSymbolProcessor.js +26 -0
- package/dist/bscPlugin/symbols/WorkspaceSymbolProcessor.js.map +1 -0
- package/dist/bscPlugin/symbols/WorkspaceSymbolProcessor.spec.d.ts +1 -0
- package/dist/bscPlugin/symbols/WorkspaceSymbolProcessor.spec.js +245 -0
- package/dist/bscPlugin/symbols/WorkspaceSymbolProcessor.spec.js.map +1 -0
- package/dist/bscPlugin/symbols/symbolUtils.d.ts +5 -0
- package/dist/bscPlugin/symbols/symbolUtils.js +140 -0
- package/dist/bscPlugin/symbols/symbolUtils.js.map +1 -0
- package/dist/bscPlugin/transpile/BrsFileTranspileProcessor.d.ts +21 -0
- package/dist/bscPlugin/transpile/BrsFileTranspileProcessor.js +202 -0
- package/dist/bscPlugin/transpile/BrsFileTranspileProcessor.js.map +1 -0
- package/dist/bscPlugin/transpile/BrsFileTranspileProcessor.spec.d.ts +1 -0
- package/dist/bscPlugin/transpile/BrsFileTranspileProcessor.spec.js +41 -0
- package/dist/bscPlugin/transpile/BrsFileTranspileProcessor.spec.js.map +1 -0
- package/dist/bscPlugin/transpile/XmlFilePreTranspileProcessor.d.ts +12 -0
- package/dist/bscPlugin/transpile/XmlFilePreTranspileProcessor.js +99 -0
- package/dist/bscPlugin/transpile/XmlFilePreTranspileProcessor.js.map +1 -0
- package/dist/bscPlugin/validation/BrsFileAfterValidatior.d.ts +7 -0
- package/dist/bscPlugin/validation/BrsFileAfterValidatior.js +18 -0
- package/dist/bscPlugin/validation/BrsFileAfterValidatior.js.map +1 -0
- package/dist/bscPlugin/validation/BrsFileValidator.d.ts +34 -0
- package/dist/bscPlugin/validation/BrsFileValidator.js +462 -0
- package/dist/bscPlugin/validation/BrsFileValidator.js.map +1 -0
- package/dist/bscPlugin/validation/BrsFileValidator.spec.d.ts +1 -0
- package/dist/bscPlugin/validation/BrsFileValidator.spec.js +758 -0
- package/dist/bscPlugin/validation/BrsFileValidator.spec.js.map +1 -0
- package/dist/bscPlugin/validation/ProgramValidator.d.ts +11 -0
- package/dist/bscPlugin/validation/ProgramValidator.js +33 -0
- package/dist/bscPlugin/validation/ProgramValidator.js.map +1 -0
- package/dist/bscPlugin/validation/ScopeValidator.d.ts +131 -0
- package/dist/bscPlugin/validation/ScopeValidator.js +1097 -0
- package/dist/bscPlugin/validation/ScopeValidator.js.map +1 -0
- package/dist/bscPlugin/validation/ScopeValidator.spec.d.ts +1 -0
- package/dist/bscPlugin/validation/ScopeValidator.spec.js +2796 -0
- package/dist/bscPlugin/validation/ScopeValidator.spec.js.map +1 -0
- package/dist/bscPlugin/validation/XmlFileValidator.d.ts +8 -0
- package/dist/bscPlugin/validation/XmlFileValidator.js +44 -0
- package/dist/bscPlugin/validation/XmlFileValidator.js.map +1 -0
- package/dist/cli.js +117 -11
- package/dist/cli.js.map +1 -1
- package/dist/deferred.d.ts +3 -3
- package/dist/deferred.js.map +1 -1
- package/dist/diagnosticUtils.d.ts +10 -3
- package/dist/diagnosticUtils.js +58 -21
- package/dist/diagnosticUtils.js.map +1 -1
- package/dist/examples/plugins/removePrint.js +8 -12
- package/dist/examples/plugins/removePrint.js.map +1 -1
- package/dist/files/AssetFile.d.ts +24 -0
- package/dist/files/AssetFile.js +25 -0
- package/dist/files/AssetFile.js.map +1 -0
- package/dist/files/BrsFile.Class.spec.js +858 -153
- package/dist/files/BrsFile.Class.spec.js.map +1 -1
- package/dist/files/BrsFile.d.ts +144 -82
- package/dist/files/BrsFile.js +847 -911
- package/dist/files/BrsFile.js.map +1 -1
- package/dist/files/BrsFile.spec.js +2928 -834
- package/dist/files/BrsFile.spec.js.map +1 -1
- package/dist/files/BscFile.d.ts +101 -0
- package/dist/files/BscFile.js +15 -0
- package/dist/files/BscFile.js.map +1 -0
- package/dist/files/Factory.d.ts +25 -0
- package/dist/files/Factory.js +22 -0
- package/dist/files/Factory.js.map +1 -0
- package/dist/files/LazyFileData.d.ts +20 -0
- package/dist/files/LazyFileData.js +54 -0
- package/dist/files/LazyFileData.js.map +1 -0
- package/dist/files/LazyFileData.spec.d.ts +1 -0
- package/dist/files/LazyFileData.spec.js +27 -0
- package/dist/files/LazyFileData.spec.js.map +1 -0
- package/dist/files/XmlFile.d.ts +73 -41
- package/dist/files/XmlFile.js +126 -138
- package/dist/files/XmlFile.js.map +1 -1
- package/dist/files/XmlFile.spec.js +450 -318
- package/dist/files/XmlFile.spec.js.map +1 -1
- package/dist/files/tests/imports.spec.js +62 -52
- package/dist/files/tests/imports.spec.js.map +1 -1
- package/dist/files/tests/optionalChaning.spec.d.ts +1 -0
- package/dist/files/tests/optionalChaning.spec.js +152 -0
- package/dist/files/tests/optionalChaning.spec.js.map +1 -0
- package/dist/globalCallables.d.ts +3 -1
- package/dist/globalCallables.js +416 -162
- package/dist/globalCallables.js.map +1 -1
- package/dist/index.d.ts +25 -3
- package/dist/index.js +42 -5
- package/dist/index.js.map +1 -1
- package/dist/interfaces.d.ts +722 -119
- package/dist/interfaces.js +31 -0
- package/dist/interfaces.js.map +1 -1
- package/dist/lexer/Character.spec.js +5 -5
- package/dist/lexer/Character.spec.js.map +1 -1
- package/dist/lexer/Lexer.d.ts +40 -9
- package/dist/lexer/Lexer.js +191 -49
- package/dist/lexer/Lexer.js.map +1 -1
- package/dist/lexer/Lexer.spec.js +775 -563
- package/dist/lexer/Lexer.spec.js.map +1 -1
- package/dist/lexer/Token.d.ts +11 -3
- package/dist/lexer/Token.js +10 -2
- package/dist/lexer/Token.js.map +1 -1
- package/dist/lexer/TokenKind.d.ts +27 -1
- package/dist/lexer/TokenKind.js +112 -5
- package/dist/lexer/TokenKind.js.map +1 -1
- package/dist/logging.d.ts +9 -0
- package/dist/logging.js +16 -0
- package/dist/logging.js.map +1 -0
- package/dist/parser/AstNode.d.ts +180 -0
- package/dist/parser/AstNode.js +245 -0
- package/dist/parser/AstNode.js.map +1 -0
- package/dist/parser/AstNode.spec.d.ts +1 -0
- package/dist/parser/AstNode.spec.js +165 -0
- package/dist/parser/AstNode.spec.js.map +1 -0
- package/dist/parser/BrsTranspileState.d.ts +12 -2
- package/dist/parser/BrsTranspileState.js +6 -0
- package/dist/parser/BrsTranspileState.js.map +1 -1
- package/dist/parser/Expression.d.ts +454 -210
- package/dist/parser/Expression.js +953 -498
- package/dist/parser/Expression.js.map +1 -1
- package/dist/parser/Parser.Class.spec.js +200 -95
- package/dist/parser/Parser.Class.spec.js.map +1 -1
- package/dist/parser/Parser.d.ts +105 -120
- package/dist/parser/Parser.js +1406 -912
- package/dist/parser/Parser.js.map +1 -1
- package/dist/parser/Parser.spec.d.ts +3 -1
- package/dist/parser/Parser.spec.js +1383 -456
- package/dist/parser/Parser.spec.js.map +1 -1
- package/dist/parser/SGParser.d.ts +44 -6
- package/dist/parser/SGParser.js +212 -185
- package/dist/parser/SGParser.js.map +1 -1
- package/dist/parser/SGParser.spec.js +30 -28
- package/dist/parser/SGParser.spec.js.map +1 -1
- package/dist/parser/SGTypes.d.ts +293 -50
- package/dist/parser/SGTypes.js +540 -187
- package/dist/parser/SGTypes.js.map +1 -1
- package/dist/parser/Statement.d.ts +734 -244
- package/dist/parser/Statement.js +1758 -611
- package/dist/parser/Statement.js.map +1 -1
- package/dist/parser/Statement.spec.js +45 -34
- package/dist/parser/Statement.spec.js.map +1 -1
- package/dist/parser/TranspileState.d.ts +17 -8
- package/dist/parser/TranspileState.js +73 -11
- package/dist/parser/TranspileState.js.map +1 -1
- package/dist/parser/tests/Parser.spec.d.ts +10 -9
- package/dist/parser/tests/Parser.spec.js +18 -14
- package/dist/parser/tests/Parser.spec.js.map +1 -1
- package/dist/parser/tests/controlFlow/For.spec.js +79 -69
- package/dist/parser/tests/controlFlow/For.spec.js.map +1 -1
- package/dist/parser/tests/controlFlow/ForEach.spec.js +53 -47
- package/dist/parser/tests/controlFlow/ForEach.spec.js.map +1 -1
- package/dist/parser/tests/controlFlow/If.spec.js +217 -196
- package/dist/parser/tests/controlFlow/If.spec.js.map +1 -1
- package/dist/parser/tests/controlFlow/While.spec.js +48 -42
- package/dist/parser/tests/controlFlow/While.spec.js.map +1 -1
- package/dist/parser/tests/expression/Additive.spec.js +31 -31
- package/dist/parser/tests/expression/Additive.spec.js.map +1 -1
- package/dist/parser/tests/expression/ArrayLiterals.spec.js +157 -120
- package/dist/parser/tests/expression/ArrayLiterals.spec.js.map +1 -1
- package/dist/parser/tests/expression/AssociativeArrayLiterals.spec.js +202 -139
- package/dist/parser/tests/expression/AssociativeArrayLiterals.spec.js.map +1 -1
- package/dist/parser/tests/expression/Boolean.spec.js +25 -25
- package/dist/parser/tests/expression/Boolean.spec.js.map +1 -1
- package/dist/parser/tests/expression/Call.spec.js +150 -41
- package/dist/parser/tests/expression/Call.spec.js.map +1 -1
- package/dist/parser/tests/expression/Exponential.spec.js +18 -18
- package/dist/parser/tests/expression/Exponential.spec.js.map +1 -1
- package/dist/parser/tests/expression/Function.spec.js +257 -257
- package/dist/parser/tests/expression/Function.spec.js.map +1 -1
- package/dist/parser/tests/expression/Indexing.spec.js +160 -90
- package/dist/parser/tests/expression/Indexing.spec.js.map +1 -1
- package/dist/parser/tests/expression/Multiplicative.spec.js +38 -38
- package/dist/parser/tests/expression/Multiplicative.spec.js.map +1 -1
- package/dist/parser/tests/expression/NullCoalescenceExpression.spec.js +196 -98
- package/dist/parser/tests/expression/NullCoalescenceExpression.spec.js.map +1 -1
- package/dist/parser/tests/expression/PrefixUnary.spec.js +42 -42
- package/dist/parser/tests/expression/PrefixUnary.spec.js.map +1 -1
- package/dist/parser/tests/expression/Primary.spec.js +42 -42
- package/dist/parser/tests/expression/Primary.spec.js.map +1 -1
- package/dist/parser/tests/expression/RegexLiteralExpression.spec.d.ts +1 -0
- package/dist/parser/tests/expression/RegexLiteralExpression.spec.js +171 -0
- package/dist/parser/tests/expression/RegexLiteralExpression.spec.js.map +1 -0
- package/dist/parser/tests/expression/Relational.spec.js +44 -44
- package/dist/parser/tests/expression/Relational.spec.js.map +1 -1
- package/dist/parser/tests/expression/SourceLiteralExpression.spec.js +31 -31
- package/dist/parser/tests/expression/SourceLiteralExpression.spec.js.map +1 -1
- package/dist/parser/tests/expression/TemplateStringExpression.spec.js +230 -90
- package/dist/parser/tests/expression/TemplateStringExpression.spec.js.map +1 -1
- package/dist/parser/tests/expression/TernaryExpression.spec.js +377 -148
- package/dist/parser/tests/expression/TernaryExpression.spec.js.map +1 -1
- package/dist/parser/tests/expression/TypeExpression.spec.d.ts +1 -0
- package/dist/parser/tests/expression/TypeExpression.spec.js +126 -0
- package/dist/parser/tests/expression/TypeExpression.spec.js.map +1 -0
- package/dist/parser/tests/expression/UnaryExpression.spec.d.ts +1 -0
- package/dist/parser/tests/expression/UnaryExpression.spec.js +52 -0
- package/dist/parser/tests/expression/UnaryExpression.spec.js.map +1 -0
- package/dist/parser/tests/statement/AssignmentOperators.spec.js +37 -37
- package/dist/parser/tests/statement/AssignmentOperators.spec.js.map +1 -1
- package/dist/parser/tests/statement/ConstStatement.spec.d.ts +1 -0
- package/dist/parser/tests/statement/ConstStatement.spec.js +262 -0
- package/dist/parser/tests/statement/ConstStatement.spec.js.map +1 -0
- package/dist/parser/tests/statement/Continue.spec.d.ts +1 -0
- package/dist/parser/tests/statement/Continue.spec.js +119 -0
- package/dist/parser/tests/statement/Continue.spec.js.map +1 -0
- package/dist/parser/tests/statement/Declaration.spec.js +45 -45
- package/dist/parser/tests/statement/Declaration.spec.js.map +1 -1
- package/dist/parser/tests/statement/Dim.spec.js +22 -22
- package/dist/parser/tests/statement/Dim.spec.js.map +1 -1
- package/dist/parser/tests/statement/Enum.spec.d.ts +1 -0
- package/dist/parser/tests/statement/Enum.spec.js +684 -0
- package/dist/parser/tests/statement/Enum.spec.js.map +1 -0
- package/dist/parser/tests/statement/For.spec.d.ts +1 -0
- package/dist/parser/tests/statement/For.spec.js +45 -0
- package/dist/parser/tests/statement/For.spec.js.map +1 -0
- package/dist/parser/tests/statement/ForEach.spec.d.ts +1 -0
- package/dist/parser/tests/statement/ForEach.spec.js +36 -0
- package/dist/parser/tests/statement/ForEach.spec.js.map +1 -0
- package/dist/parser/tests/statement/Function.spec.js +208 -198
- package/dist/parser/tests/statement/Function.spec.js.map +1 -1
- package/dist/parser/tests/statement/Goto.spec.js +16 -15
- package/dist/parser/tests/statement/Goto.spec.js.map +1 -1
- package/dist/parser/tests/statement/Increment.spec.js +51 -51
- package/dist/parser/tests/statement/Increment.spec.js.map +1 -1
- package/dist/parser/tests/statement/InterfaceStatement.spec.d.ts +1 -0
- package/dist/parser/tests/statement/InterfaceStatement.spec.js +109 -0
- package/dist/parser/tests/statement/InterfaceStatement.spec.js.map +1 -0
- package/dist/parser/tests/statement/LibraryStatement.spec.js +18 -18
- package/dist/parser/tests/statement/LibraryStatement.spec.js.map +1 -1
- package/dist/parser/tests/statement/Misc.spec.js +123 -163
- package/dist/parser/tests/statement/Misc.spec.js.map +1 -1
- package/dist/parser/tests/statement/PrintStatement.spec.js +125 -108
- package/dist/parser/tests/statement/PrintStatement.spec.js.map +1 -1
- package/dist/parser/tests/statement/ReturnStatement.spec.js +51 -49
- package/dist/parser/tests/statement/ReturnStatement.spec.js.map +1 -1
- package/dist/parser/tests/statement/Set.spec.js +110 -97
- package/dist/parser/tests/statement/Set.spec.js.map +1 -1
- package/dist/parser/tests/statement/Stop.spec.js +13 -12
- package/dist/parser/tests/statement/Stop.spec.js.map +1 -1
- package/dist/parser/tests/statement/Throw.spec.js +6 -6
- package/dist/parser/tests/statement/Throw.spec.js.map +1 -1
- package/dist/parser/tests/statement/TryCatch.spec.js +26 -15
- package/dist/parser/tests/statement/TryCatch.spec.js.map +1 -1
- package/dist/preprocessor/Manifest.d.ts +6 -6
- package/dist/preprocessor/Manifest.js +17 -38
- package/dist/preprocessor/Manifest.js.map +1 -1
- package/dist/preprocessor/Manifest.spec.d.ts +1 -0
- package/dist/preprocessor/Manifest.spec.js +78 -103
- package/dist/preprocessor/Manifest.spec.js.map +1 -1
- package/dist/roku-types/data.json +19351 -0
- package/dist/roku-types/index.d.ts +5483 -0
- package/dist/roku-types/index.js +11 -0
- package/dist/roku-types/index.js.map +1 -0
- package/dist/types/ArrayType.d.ts +9 -5
- package/dist/types/ArrayType.js +68 -24
- package/dist/types/ArrayType.js.map +1 -1
- package/dist/types/ArrayType.spec.js +39 -11
- package/dist/types/ArrayType.spec.js.map +1 -1
- package/dist/types/AssociativeArrayType.d.ts +14 -0
- package/dist/types/AssociativeArrayType.js +60 -0
- package/dist/types/AssociativeArrayType.js.map +1 -0
- package/dist/types/BaseFunctionType.d.ts +9 -0
- package/dist/types/BaseFunctionType.js +25 -0
- package/dist/types/BaseFunctionType.js.map +1 -0
- package/dist/types/BooleanType.d.ts +10 -5
- package/dist/types/BooleanType.js +21 -9
- package/dist/types/BooleanType.js.map +1 -1
- package/dist/types/BooleanType.spec.js +10 -4
- package/dist/types/BooleanType.spec.js.map +1 -1
- package/dist/types/BscType.d.ts +29 -3
- package/dist/types/BscType.js +121 -0
- package/dist/types/BscType.js.map +1 -1
- package/dist/types/BscTypeKind.d.ts +25 -0
- package/dist/types/BscTypeKind.js +30 -0
- package/dist/types/BscTypeKind.js.map +1 -0
- package/dist/types/BuiltInInterfaceAdder.d.ts +23 -0
- package/dist/types/BuiltInInterfaceAdder.js +174 -0
- package/dist/types/BuiltInInterfaceAdder.js.map +1 -0
- package/dist/types/BuiltInInterfaceAdder.spec.d.ts +1 -0
- package/dist/types/BuiltInInterfaceAdder.spec.js +115 -0
- package/dist/types/BuiltInInterfaceAdder.spec.js.map +1 -0
- package/dist/types/ClassType.d.ts +17 -0
- package/dist/types/ClassType.js +58 -0
- package/dist/types/ClassType.js.map +1 -0
- package/dist/types/ClassType.spec.d.ts +1 -0
- package/dist/types/ClassType.spec.js +76 -0
- package/dist/types/ClassType.spec.js.map +1 -0
- package/dist/types/ComponentType.d.ts +27 -0
- package/dist/types/ComponentType.js +83 -0
- package/dist/types/ComponentType.js.map +1 -0
- package/dist/types/DoubleType.d.ts +10 -5
- package/dist/types/DoubleType.js +25 -18
- package/dist/types/DoubleType.js.map +1 -1
- package/dist/types/DoubleType.spec.js +12 -4
- package/dist/types/DoubleType.spec.js.map +1 -1
- package/dist/types/DynamicType.d.ts +12 -5
- package/dist/types/DynamicType.js +22 -6
- package/dist/types/DynamicType.js.map +1 -1
- package/dist/types/DynamicType.spec.js +16 -5
- package/dist/types/DynamicType.spec.js.map +1 -1
- package/dist/types/EnumType.d.ts +40 -0
- package/dist/types/EnumType.js +80 -0
- package/dist/types/EnumType.js.map +1 -0
- package/dist/types/EnumType.spec.d.ts +1 -0
- package/dist/types/EnumType.spec.js +33 -0
- package/dist/types/EnumType.spec.js.map +1 -0
- package/dist/types/FloatType.d.ts +10 -5
- package/dist/types/FloatType.js +25 -18
- package/dist/types/FloatType.js.map +1 -1
- package/dist/types/FloatType.spec.js +4 -4
- package/dist/types/FloatType.spec.js.map +1 -1
- package/dist/types/FunctionType.d.ts +10 -22
- package/dist/types/FunctionType.js +26 -63
- package/dist/types/FunctionType.js.map +1 -1
- package/dist/types/InheritableType.d.ts +28 -0
- package/dist/types/InheritableType.js +157 -0
- package/dist/types/InheritableType.js.map +1 -0
- package/dist/types/IntegerType.d.ts +10 -5
- package/dist/types/IntegerType.js +25 -18
- package/dist/types/IntegerType.js.map +1 -1
- package/dist/types/IntegerType.spec.js +8 -4
- package/dist/types/IntegerType.spec.js.map +1 -1
- package/dist/types/InterfaceType.d.ts +14 -6
- package/dist/types/InterfaceType.js +26 -15
- package/dist/types/InterfaceType.js.map +1 -1
- package/dist/types/InterfaceType.spec.d.ts +1 -0
- package/dist/types/InterfaceType.spec.js +227 -0
- package/dist/types/InterfaceType.spec.js.map +1 -0
- package/dist/types/InvalidType.d.ts +9 -5
- package/dist/types/InvalidType.js +20 -9
- package/dist/types/InvalidType.js.map +1 -1
- package/dist/types/InvalidType.spec.js +8 -4
- package/dist/types/InvalidType.spec.js.map +1 -1
- package/dist/types/LongIntegerType.d.ts +10 -5
- package/dist/types/LongIntegerType.js +25 -18
- package/dist/types/LongIntegerType.js.map +1 -1
- package/dist/types/LongIntegerType.spec.js +10 -4
- package/dist/types/LongIntegerType.spec.js.map +1 -1
- package/dist/types/NamespaceType.d.ts +12 -0
- package/dist/types/NamespaceType.js +28 -0
- package/dist/types/NamespaceType.js.map +1 -0
- package/dist/types/ObjectType.d.ts +10 -5
- package/dist/types/ObjectType.js +23 -9
- package/dist/types/ObjectType.js.map +1 -1
- package/dist/types/ObjectType.spec.js +3 -3
- package/dist/types/ObjectType.spec.js.map +1 -1
- package/dist/types/ReferenceType.d.ts +71 -0
- package/dist/types/ReferenceType.js +467 -0
- package/dist/types/ReferenceType.js.map +1 -0
- package/dist/types/ReferenceType.spec.d.ts +1 -0
- package/dist/types/ReferenceType.spec.js +151 -0
- package/dist/types/ReferenceType.spec.js.map +1 -0
- package/dist/types/StringType.d.ts +13 -5
- package/dist/types/StringType.js +25 -9
- package/dist/types/StringType.js.map +1 -1
- package/dist/types/StringType.spec.js +3 -3
- package/dist/types/StringType.spec.js.map +1 -1
- package/dist/types/TypedFunctionType.d.ts +33 -0
- package/dist/types/TypedFunctionType.js +106 -0
- package/dist/types/TypedFunctionType.js.map +1 -0
- package/dist/types/TypedFunctionType.spec.d.ts +1 -0
- package/dist/types/TypedFunctionType.spec.js +122 -0
- package/dist/types/TypedFunctionType.spec.js.map +1 -0
- package/dist/types/UninitializedType.d.ts +8 -6
- package/dist/types/UninitializedType.js +15 -9
- package/dist/types/UninitializedType.js.map +1 -1
- package/dist/types/UnionType.d.ts +20 -0
- package/dist/types/UnionType.js +127 -0
- package/dist/types/UnionType.js.map +1 -0
- package/dist/types/UnionType.spec.d.ts +1 -0
- package/dist/types/UnionType.spec.js +129 -0
- package/dist/types/UnionType.spec.js.map +1 -0
- package/dist/types/VoidType.d.ts +10 -5
- package/dist/types/VoidType.js +20 -9
- package/dist/types/VoidType.js.map +1 -1
- package/dist/types/VoidType.spec.js +3 -3
- package/dist/types/VoidType.spec.js.map +1 -1
- package/dist/types/helper.spec.d.ts +1 -0
- package/dist/types/helper.spec.js +144 -0
- package/dist/types/helper.spec.js.map +1 -0
- package/dist/types/helpers.d.ts +24 -0
- package/dist/types/helpers.js +178 -0
- package/dist/types/helpers.js.map +1 -0
- package/dist/types/index.d.ts +22 -0
- package/dist/types/index.js +39 -0
- package/dist/types/index.js.map +1 -0
- package/dist/util.d.ts +216 -106
- package/dist/util.js +1289 -319
- package/dist/util.js.map +1 -1
- package/dist/validators/ClassValidator.d.ts +9 -15
- package/dist/validators/ClassValidator.js +81 -134
- package/dist/validators/ClassValidator.js.map +1 -1
- package/package.json +169 -138
- package/dist/astUtils/index.d.ts +0 -7
- package/dist/astUtils/index.js +0 -26
- package/dist/astUtils/index.js.map +0 -1
- package/dist/lexer/index.d.ts +0 -3
- package/dist/lexer/index.js +0 -17
- package/dist/lexer/index.js.map +0 -1
- package/dist/parser/index.d.ts +0 -3
- package/dist/parser/index.js +0 -16
- package/dist/parser/index.js.map +0 -1
- package/dist/preprocessor/Chunk.d.ts +0 -82
- package/dist/preprocessor/Chunk.js +0 -77
- package/dist/preprocessor/Chunk.js.map +0 -1
- package/dist/preprocessor/Preprocessor.d.ts +0 -60
- package/dist/preprocessor/Preprocessor.js +0 -156
- package/dist/preprocessor/Preprocessor.js.map +0 -1
- package/dist/preprocessor/Preprocessor.spec.js +0 -152
- package/dist/preprocessor/Preprocessor.spec.js.map +0 -1
- package/dist/preprocessor/PreprocessorParser.d.ts +0 -61
- package/dist/preprocessor/PreprocessorParser.js +0 -194
- package/dist/preprocessor/PreprocessorParser.js.map +0 -1
- package/dist/preprocessor/PreprocessorParser.spec.js +0 -116
- package/dist/preprocessor/PreprocessorParser.spec.js.map +0 -1
- package/dist/preprocessor/index.d.ts +0 -3
- package/dist/preprocessor/index.js +0 -16
- package/dist/preprocessor/index.js.map +0 -1
- package/dist/types/CustomType.d.ts +0 -10
- package/dist/types/CustomType.js +0 -35
- package/dist/types/CustomType.js.map +0 -1
- package/dist/types/FunctionType.spec.js +0 -29
- package/dist/types/FunctionType.spec.js.map +0 -1
- package/dist/types/LazyType.d.ts +0 -15
- package/dist/types/LazyType.js +0 -32
- package/dist/types/LazyType.js.map +0 -1
- /package/dist/{preprocessor/Preprocessor.spec.d.ts → astUtils/Editor.spec.d.ts} +0 -0
- /package/dist/{preprocessor/PreprocessorParser.spec.d.ts → bscPlugin/completions/CompletionsProcessor.spec.d.ts} +0 -0
- /package/dist/{types/FunctionType.spec.d.ts → bscPlugin/definition/DefinitionProvider.spec.d.ts} +0 -0
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SignatureHelpUtil = void 0;
|
|
4
|
+
const vscode_languageserver_protocol_1 = require("vscode-languageserver-protocol");
|
|
5
|
+
const reflection_1 = require("../astUtils/reflection");
|
|
6
|
+
const TokenKind_1 = require("../lexer/TokenKind");
|
|
7
|
+
const Parser_1 = require("../parser/Parser");
|
|
8
|
+
const CallExpressionInfo_1 = require("./CallExpressionInfo");
|
|
9
|
+
const util_1 = require("../util");
|
|
10
|
+
class SignatureHelpUtil {
|
|
11
|
+
getSignatureHelpItems(callExpressionInfo) {
|
|
12
|
+
let signatureHelpItems = [];
|
|
13
|
+
let file = callExpressionInfo.file;
|
|
14
|
+
let dotPart = callExpressionInfo.dotPart;
|
|
15
|
+
let name = callExpressionInfo.name;
|
|
16
|
+
let results = new Map();
|
|
17
|
+
switch (callExpressionInfo.type) {
|
|
18
|
+
case CallExpressionInfo_1.CallExpressionType.namespaceCall:
|
|
19
|
+
signatureHelpItems = file.program.getStatementsByName(name, file, dotPart).map((fileLink) => this.getSignatureHelpForStatement(fileLink, dotPart));
|
|
20
|
+
break;
|
|
21
|
+
case CallExpressionInfo_1.CallExpressionType.myClassCall:
|
|
22
|
+
let statement = file.getClassMethod(callExpressionInfo.myClass, name, true);
|
|
23
|
+
if (statement) {
|
|
24
|
+
signatureHelpItems = [this.getSignatureHelpForStatement({ item: statement, file: file })];
|
|
25
|
+
}
|
|
26
|
+
break;
|
|
27
|
+
case CallExpressionInfo_1.CallExpressionType.otherClassCall:
|
|
28
|
+
signatureHelpItems = file.program.getStatementsByName(name, file).filter((fileLink) => (0, reflection_1.isClassStatement)(fileLink.item.parent)).map((fileLink) => this.getSignatureHelpForStatement(fileLink));
|
|
29
|
+
break;
|
|
30
|
+
case CallExpressionInfo_1.CallExpressionType.callFunc:
|
|
31
|
+
// must be from some call func interface method
|
|
32
|
+
signatureHelpItems = [];
|
|
33
|
+
for (const scope of file.program.getScopes().filter((s) => (0, reflection_1.isXmlScope)(s))) {
|
|
34
|
+
signatureHelpItems.push(...file.program.getStatementsForXmlFile(scope, name).map((fileLink) => this.getSignatureHelpForStatement(fileLink)));
|
|
35
|
+
}
|
|
36
|
+
break;
|
|
37
|
+
case CallExpressionInfo_1.CallExpressionType.call:
|
|
38
|
+
signatureHelpItems = file.program.getStatementsByName(name, file).map((fileLink) => this.getSignatureHelpForStatement(fileLink));
|
|
39
|
+
break;
|
|
40
|
+
case CallExpressionInfo_1.CallExpressionType.constructorCall:
|
|
41
|
+
let classItem = file.getClassFileLink(dotPart ? `${dotPart}.${name}` : name);
|
|
42
|
+
let constructorSignatureHelp = this.getClassSignatureHelp(classItem);
|
|
43
|
+
if (constructorSignatureHelp) {
|
|
44
|
+
signatureHelpItems.push(constructorSignatureHelp);
|
|
45
|
+
}
|
|
46
|
+
break;
|
|
47
|
+
default:
|
|
48
|
+
}
|
|
49
|
+
for (let sigHelp of signatureHelpItems) {
|
|
50
|
+
if (!results.has[sigHelp.key]) {
|
|
51
|
+
sigHelp.index = callExpressionInfo.parameterIndex;
|
|
52
|
+
results.set(sigHelp.key, sigHelp);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
return [...results.values()];
|
|
56
|
+
}
|
|
57
|
+
getSignatureHelpForStatement(fileLink, namespaceName) {
|
|
58
|
+
var _a;
|
|
59
|
+
let statement = fileLink.item;
|
|
60
|
+
let file = fileLink.file;
|
|
61
|
+
if (!(0, reflection_1.isFunctionStatement)(statement) && !(0, reflection_1.isMethodStatement)(statement)) {
|
|
62
|
+
return undefined;
|
|
63
|
+
}
|
|
64
|
+
const func = statement.func;
|
|
65
|
+
const funcStartPosition = func.range.start;
|
|
66
|
+
// Get function comments in reverse order
|
|
67
|
+
const trivia = func.getLeadingTrivia().reverse();
|
|
68
|
+
let functionComments = [];
|
|
69
|
+
for (const currentToken of trivia) {
|
|
70
|
+
if (!currentToken) {
|
|
71
|
+
break;
|
|
72
|
+
}
|
|
73
|
+
if (currentToken.range.start.line + 1 < funcStartPosition.line) {
|
|
74
|
+
if (functionComments.length === 0) {
|
|
75
|
+
break;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
const kind = currentToken.kind;
|
|
79
|
+
if (kind === TokenKind_1.TokenKind.Comment) {
|
|
80
|
+
// Strip off common leading characters to make it easier to read
|
|
81
|
+
const commentText = currentToken.text.replace(/^[' *\/]+/, '');
|
|
82
|
+
functionComments.unshift(commentText);
|
|
83
|
+
}
|
|
84
|
+
else if (kind === TokenKind_1.TokenKind.Newline) {
|
|
85
|
+
if (functionComments.length === 0) {
|
|
86
|
+
continue;
|
|
87
|
+
}
|
|
88
|
+
// if we already had a new line as the last token then exit out
|
|
89
|
+
if (functionComments[0] === currentToken.text) {
|
|
90
|
+
break;
|
|
91
|
+
}
|
|
92
|
+
functionComments.unshift(currentToken.text);
|
|
93
|
+
}
|
|
94
|
+
else if (kind === TokenKind_1.TokenKind.Whitespace) {
|
|
95
|
+
}
|
|
96
|
+
else {
|
|
97
|
+
break;
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
const documentation = functionComments.join('').trim();
|
|
101
|
+
const lines = util_1.util.splitIntoLines(file.fileContents);
|
|
102
|
+
let key = statement.tokens.name.text + documentation;
|
|
103
|
+
const params = [];
|
|
104
|
+
for (const param of func.parameters) {
|
|
105
|
+
params.push(vscode_languageserver_protocol_1.ParameterInformation.create(param.tokens.name.text));
|
|
106
|
+
key += param.tokens.name.text;
|
|
107
|
+
}
|
|
108
|
+
let label = util_1.util.getTextForRange(lines, util_1.util.createRangeFromPositions((_a = func.tokens.functionType) === null || _a === void 0 ? void 0 : _a.range.start, func.body.range.start)).trim();
|
|
109
|
+
if (namespaceName) {
|
|
110
|
+
label = label.replace(/^(sub | function )/gim, `$1${namespaceName}.`);
|
|
111
|
+
}
|
|
112
|
+
const signature = vscode_languageserver_protocol_1.SignatureInformation.create(label, documentation, ...params);
|
|
113
|
+
const index = 1;
|
|
114
|
+
return { key: key, signature: signature, index: index };
|
|
115
|
+
}
|
|
116
|
+
getClassSignatureHelp(fileLink) {
|
|
117
|
+
let file = fileLink.file;
|
|
118
|
+
let classStatement = fileLink.item;
|
|
119
|
+
const classConstructor = file.getClassMethod(classStatement, 'new');
|
|
120
|
+
let sigHelp = classConstructor ? this.getSignatureHelpForStatement({ item: classConstructor, file: file }) : undefined;
|
|
121
|
+
let className = classStatement.getName(Parser_1.ParseMode.BrighterScript);
|
|
122
|
+
if (sigHelp) {
|
|
123
|
+
sigHelp.key = className;
|
|
124
|
+
sigHelp.signature.label = sigHelp.signature.label.replace(/(function|sub) new/, sigHelp.key);
|
|
125
|
+
}
|
|
126
|
+
else {
|
|
127
|
+
sigHelp = {
|
|
128
|
+
key: className,
|
|
129
|
+
signature: vscode_languageserver_protocol_1.SignatureInformation.create(`${className}()`, ''),
|
|
130
|
+
index: 0
|
|
131
|
+
};
|
|
132
|
+
}
|
|
133
|
+
return sigHelp;
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
exports.SignatureHelpUtil = SignatureHelpUtil;
|
|
137
|
+
//# sourceMappingURL=SignatureHelpUtil.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SignatureHelpUtil.js","sourceRoot":"","sources":["../../src/bscPlugin/SignatureHelpUtil.ts"],"names":[],"mappings":"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"}
|
|
@@ -8,7 +8,7 @@ export declare class CodeActionsProcessor {
|
|
|
8
8
|
* Generic import suggestion function. Shouldn't be called directly from the main loop, but instead called by more specific diagnostic handlers
|
|
9
9
|
*/
|
|
10
10
|
private suggestImports;
|
|
11
|
-
private
|
|
11
|
+
private suggestCannotFindName;
|
|
12
12
|
private suggestClassImports;
|
|
13
13
|
private addMissingExtends;
|
|
14
14
|
}
|
|
@@ -4,8 +4,9 @@ exports.CodeActionsProcessor = void 0;
|
|
|
4
4
|
const vscode_languageserver_1 = require("vscode-languageserver");
|
|
5
5
|
const CodeActionUtil_1 = require("../../CodeActionUtil");
|
|
6
6
|
const DiagnosticMessages_1 = require("../../DiagnosticMessages");
|
|
7
|
-
const
|
|
7
|
+
const Parser_1 = require("../../parser/Parser");
|
|
8
8
|
const util_1 = require("../../util");
|
|
9
|
+
const reflection_1 = require("../../astUtils/reflection");
|
|
9
10
|
class CodeActionsProcessor {
|
|
10
11
|
constructor(event) {
|
|
11
12
|
this.event = event;
|
|
@@ -13,8 +14,8 @@ class CodeActionsProcessor {
|
|
|
13
14
|
}
|
|
14
15
|
process() {
|
|
15
16
|
for (const diagnostic of this.event.diagnostics) {
|
|
16
|
-
if (diagnostic.code === DiagnosticMessages_1.DiagnosticCodeMap.
|
|
17
|
-
this.
|
|
17
|
+
if (diagnostic.code === DiagnosticMessages_1.DiagnosticCodeMap.cannotFindName || diagnostic.code === DiagnosticMessages_1.DiagnosticCodeMap.cannotFindFunction) {
|
|
18
|
+
this.suggestCannotFindName(diagnostic);
|
|
18
19
|
}
|
|
19
20
|
else if (diagnostic.code === DiagnosticMessages_1.DiagnosticCodeMap.classCouldNotBeFound) {
|
|
20
21
|
this.suggestClassImports(diagnostic);
|
|
@@ -28,19 +29,21 @@ class CodeActionsProcessor {
|
|
|
28
29
|
* Generic import suggestion function. Shouldn't be called directly from the main loop, but instead called by more specific diagnostic handlers
|
|
29
30
|
*/
|
|
30
31
|
suggestImports(diagnostic, key, files) {
|
|
31
|
-
var _a, _b, _c;
|
|
32
|
+
var _a, _b, _c, _d;
|
|
32
33
|
//skip if we already have this suggestion
|
|
33
|
-
if (this.suggestedImports.has(key)) {
|
|
34
|
+
if (this.suggestedImports.has(key) || !(0, reflection_1.isBrsFile)(this.event.file)) {
|
|
34
35
|
return;
|
|
35
36
|
}
|
|
36
37
|
this.suggestedImports.add(key);
|
|
37
|
-
|
|
38
|
+
// eslint-disable-next-line @typescript-eslint/dot-notation
|
|
39
|
+
const importStatements = this.event.file['_cachedLookups'].importStatements;
|
|
38
40
|
//find the position of the first import statement, or the top of the file if there is none
|
|
39
|
-
const insertPosition = (_c = (_b = (_a = importStatements[importStatements.length - 1]) === null || _a === void 0 ? void 0 : _a.
|
|
41
|
+
const insertPosition = (_d = (_c = (_b = (_a = importStatements[importStatements.length - 1]) === null || _a === void 0 ? void 0 : _a.tokens.import) === null || _b === void 0 ? void 0 : _b.range) === null || _c === void 0 ? void 0 : _c.start) !== null && _d !== void 0 ? _d : util_1.util.createPosition(0, 0);
|
|
40
42
|
//find all files that reference this function
|
|
41
43
|
for (const file of files) {
|
|
44
|
+
const destPath = util_1.util.sanitizePkgPath(file.destPath);
|
|
42
45
|
this.event.codeActions.push(CodeActionUtil_1.codeActionUtil.createCodeAction({
|
|
43
|
-
title: `import "${
|
|
46
|
+
title: `import "${destPath}"`,
|
|
44
47
|
diagnostics: [diagnostic],
|
|
45
48
|
isPreferred: false,
|
|
46
49
|
kind: vscode_languageserver_1.CodeActionKind.QuickFix,
|
|
@@ -48,33 +51,39 @@ class CodeActionsProcessor {
|
|
|
48
51
|
type: 'insert',
|
|
49
52
|
filePath: this.event.file.srcPath,
|
|
50
53
|
position: insertPosition,
|
|
51
|
-
newText: `import "${
|
|
54
|
+
newText: `import "${destPath}"\n`
|
|
52
55
|
}]
|
|
53
56
|
}));
|
|
54
57
|
}
|
|
55
58
|
}
|
|
56
|
-
|
|
59
|
+
suggestCannotFindName(diagnostic) {
|
|
60
|
+
var _a;
|
|
57
61
|
//skip if not a BrighterScript file
|
|
58
|
-
if (diagnostic.file.parseMode !==
|
|
62
|
+
if (diagnostic.file.parseMode !== Parser_1.ParseMode.BrighterScript) {
|
|
59
63
|
return;
|
|
60
64
|
}
|
|
61
|
-
const
|
|
62
|
-
this.suggestImports(diagnostic,
|
|
65
|
+
const lowerName = ((_a = diagnostic.data.fullName) !== null && _a !== void 0 ? _a : diagnostic.data.name).toLowerCase();
|
|
66
|
+
this.suggestImports(diagnostic, lowerName, [
|
|
67
|
+
...this.event.program.findFilesForFunction(lowerName),
|
|
68
|
+
...this.event.program.findFilesForClass(lowerName),
|
|
69
|
+
...this.event.program.findFilesForNamespace(lowerName),
|
|
70
|
+
...this.event.program.findFilesForEnum(lowerName)
|
|
71
|
+
]);
|
|
63
72
|
}
|
|
64
73
|
suggestClassImports(diagnostic) {
|
|
65
74
|
//skip if not a BrighterScript file
|
|
66
|
-
if (diagnostic.file.parseMode !==
|
|
75
|
+
if (diagnostic.file.parseMode !== Parser_1.ParseMode.BrighterScript) {
|
|
67
76
|
return;
|
|
68
77
|
}
|
|
69
78
|
const lowerClassName = diagnostic.data.className.toLowerCase();
|
|
70
|
-
this.suggestImports(diagnostic, lowerClassName, this.event.
|
|
79
|
+
this.suggestImports(diagnostic, lowerClassName, this.event.program.findFilesForClass(lowerClassName));
|
|
71
80
|
}
|
|
72
81
|
addMissingExtends(diagnostic) {
|
|
73
82
|
var _a;
|
|
74
83
|
const srcPath = this.event.file.srcPath;
|
|
75
|
-
const {
|
|
84
|
+
const { componentElement } = this.event.file.parser.ast;
|
|
76
85
|
//inject new attribute after the final attribute, or after the `<component` if there are no attributes
|
|
77
|
-
const pos = ((_a =
|
|
86
|
+
const pos = ((_a = componentElement.attributes[componentElement.attributes.length - 1]) !== null && _a !== void 0 ? _a : componentElement.tokens.startTagName).range.end;
|
|
78
87
|
this.event.codeActions.push(CodeActionUtil_1.codeActionUtil.createCodeAction({
|
|
79
88
|
title: `Extend "Group"`,
|
|
80
89
|
diagnostics: [diagnostic],
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CodeActionsProcessor.js","sourceRoot":"","sources":["../../../src/bscPlugin/codeActions/CodeActionsProcessor.ts"],"names":[],"mappings":";;;AACA,iEAAuD;AACvD,yDAAsD;AAEtD,iEAA6D;
|
|
1
|
+
{"version":3,"file":"CodeActionsProcessor.js","sourceRoot":"","sources":["../../../src/bscPlugin/codeActions/CodeActionsProcessor.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,30 +1,38 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const
|
|
3
|
+
const chai_config_spec_1 = require("../../chai-config.spec");
|
|
4
4
|
const vscode_uri_1 = require("vscode-uri");
|
|
5
5
|
const Program_1 = require("../../Program");
|
|
6
6
|
const testHelpers_spec_1 = require("../../testHelpers.spec");
|
|
7
7
|
const util_1 = require("../../util");
|
|
8
|
-
const
|
|
8
|
+
const testHelpers_spec_2 = require("../../testHelpers.spec");
|
|
9
9
|
describe('CodeActionsProcessor', () => {
|
|
10
10
|
let program;
|
|
11
11
|
beforeEach(() => {
|
|
12
12
|
program = new Program_1.Program({
|
|
13
|
-
rootDir: rootDir
|
|
13
|
+
rootDir: testHelpers_spec_2.rootDir,
|
|
14
|
+
autoImportComponentScript: true
|
|
14
15
|
});
|
|
15
16
|
});
|
|
16
17
|
afterEach(() => {
|
|
17
18
|
program.dispose();
|
|
18
19
|
});
|
|
20
|
+
/**
|
|
21
|
+
* Helper function for testing code actions
|
|
22
|
+
*/
|
|
23
|
+
function testGetCodeActions(file, range, expected) {
|
|
24
|
+
program.validate();
|
|
25
|
+
(0, chai_config_spec_1.expect)(program.getCodeActions(typeof file === 'string' ? file : file.srcPath, range).map(x => x.title).sort()).to.eql(expected);
|
|
26
|
+
}
|
|
19
27
|
describe('getCodeActions', () => {
|
|
20
28
|
it('suggests `extends=Group`', () => {
|
|
21
|
-
const file = program.setFile('components/comp1.xml', testHelpers_spec_1.trim `
|
|
29
|
+
const file = program.setFile('components/comp1.xml', (0, testHelpers_spec_1.trim) `
|
|
22
30
|
<?xml version="1.0" encoding="utf-8" ?>
|
|
23
31
|
<component name="comp1">
|
|
24
32
|
</component>
|
|
25
33
|
`);
|
|
26
34
|
program.validate();
|
|
27
|
-
testHelpers_spec_1.expectCodeActions(() => {
|
|
35
|
+
(0, testHelpers_spec_1.expectCodeActions)(() => {
|
|
28
36
|
program.getCodeActions(file.srcPath,
|
|
29
37
|
//<comp|onent name="comp1">
|
|
30
38
|
util_1.util.createRange(1, 5, 1, 5));
|
|
@@ -33,7 +41,7 @@ describe('CodeActionsProcessor', () => {
|
|
|
33
41
|
isPreferred: true,
|
|
34
42
|
kind: 'quickfix',
|
|
35
43
|
changes: [{
|
|
36
|
-
filePath: util_1.standardizePath `${rootDir}/components/comp1.xml`,
|
|
44
|
+
filePath: (0, util_1.standardizePath) `${testHelpers_spec_2.rootDir}/components/comp1.xml`,
|
|
37
45
|
newText: ' extends="Group"',
|
|
38
46
|
type: 'insert',
|
|
39
47
|
//<component name="comp1"|>
|
|
@@ -43,7 +51,7 @@ describe('CodeActionsProcessor', () => {
|
|
|
43
51
|
title: `Extend "Task"`,
|
|
44
52
|
kind: 'quickfix',
|
|
45
53
|
changes: [{
|
|
46
|
-
filePath: util_1.standardizePath `${rootDir}/components/comp1.xml`,
|
|
54
|
+
filePath: (0, util_1.standardizePath) `${testHelpers_spec_2.rootDir}/components/comp1.xml`,
|
|
47
55
|
newText: ' extends="Task"',
|
|
48
56
|
type: 'insert',
|
|
49
57
|
//<component name="comp1"|>
|
|
@@ -53,7 +61,7 @@ describe('CodeActionsProcessor', () => {
|
|
|
53
61
|
title: `Extend "ContentNode"`,
|
|
54
62
|
kind: 'quickfix',
|
|
55
63
|
changes: [{
|
|
56
|
-
filePath: util_1.standardizePath `${rootDir}/components/comp1.xml`,
|
|
64
|
+
filePath: (0, util_1.standardizePath) `${testHelpers_spec_2.rootDir}/components/comp1.xml`,
|
|
57
65
|
newText: ' extends="ContentNode"',
|
|
58
66
|
type: 'insert',
|
|
59
67
|
//<component name="comp1"|>
|
|
@@ -62,7 +70,7 @@ describe('CodeActionsProcessor', () => {
|
|
|
62
70
|
}]);
|
|
63
71
|
});
|
|
64
72
|
it('adds attribute at end of component with multiple attributes`', () => {
|
|
65
|
-
const file = program.setFile('components/comp1.xml', testHelpers_spec_1.trim `
|
|
73
|
+
const file = program.setFile('components/comp1.xml', (0, testHelpers_spec_1.trim) `
|
|
66
74
|
<?xml version="1.0" encoding="utf-8" ?>
|
|
67
75
|
<component name="comp1" attr2="attr3" attr3="attr3">
|
|
68
76
|
</component>
|
|
@@ -71,7 +79,7 @@ describe('CodeActionsProcessor', () => {
|
|
|
71
79
|
const codeActions = program.getCodeActions(file.srcPath,
|
|
72
80
|
//<comp|onent name="comp1">
|
|
73
81
|
util_1.util.createRange(1, 5, 1, 5));
|
|
74
|
-
|
|
82
|
+
(0, chai_config_spec_1.expect)(codeActions[0].edit.changes[vscode_uri_1.URI.file((0, util_1.standardizePath) `${testHelpers_spec_2.rootDir}/components/comp1.xml`).toString()][0].range).to.eql(util_1.util.createRange(1, 51, 1, 51));
|
|
75
83
|
});
|
|
76
84
|
it('does not produce duplicate code actions for bs imports', () => {
|
|
77
85
|
//define the function in two files
|
|
@@ -90,13 +98,13 @@ describe('CodeActionsProcessor', () => {
|
|
|
90
98
|
end sub
|
|
91
99
|
`);
|
|
92
100
|
//import the file in two scopes
|
|
93
|
-
program.setFile('components/comp1.xml', testHelpers_spec_1.trim `
|
|
101
|
+
program.setFile('components/comp1.xml', (0, testHelpers_spec_1.trim) `
|
|
94
102
|
<?xml version="1.0" encoding="utf-8" ?>
|
|
95
103
|
<component name="ChildScene">
|
|
96
104
|
<script uri="ComponentCommon.bs" />
|
|
97
105
|
</component>
|
|
98
106
|
`);
|
|
99
|
-
program.setFile('components/comp2.xml', testHelpers_spec_1.trim `
|
|
107
|
+
program.setFile('components/comp2.xml', (0, testHelpers_spec_1.trim) `
|
|
100
108
|
<?xml version="1.0" encoding="utf-8" ?>
|
|
101
109
|
<component name="ChildScene">
|
|
102
110
|
<script uri="ComponentCommon.bs" />
|
|
@@ -107,14 +115,14 @@ describe('CodeActionsProcessor', () => {
|
|
|
107
115
|
const codeActions = program.getCodeActions(componentCommonFile.srcPath,
|
|
108
116
|
// doSome|thing()
|
|
109
117
|
util_1.util.createRange(2, 22, 2, 22));
|
|
110
|
-
|
|
118
|
+
(0, chai_config_spec_1.expect)(codeActions.map(x => x.title).sort()).to.eql([
|
|
111
119
|
`import "pkg:/components/lib1.brs"`,
|
|
112
120
|
`import "pkg:/components/lib2.brs"`
|
|
113
121
|
]);
|
|
114
122
|
});
|
|
115
123
|
it('does not suggest imports for brs files', () => {
|
|
116
124
|
//import the file in two scopes
|
|
117
|
-
program.setFile('components/comp1.xml', testHelpers_spec_1.trim `
|
|
125
|
+
program.setFile('components/comp1.xml', (0, testHelpers_spec_1.trim) `
|
|
118
126
|
<?xml version="1.0" encoding="utf-8" ?>
|
|
119
127
|
<component name="ChildScene">
|
|
120
128
|
<script uri="comp1.brs" />
|
|
@@ -136,11 +144,11 @@ describe('CodeActionsProcessor', () => {
|
|
|
136
144
|
const codeActions = program.getCodeActions(file.srcPath,
|
|
137
145
|
// DoSometh|ing()
|
|
138
146
|
util_1.util.createRange(2, 28, 2, 28));
|
|
139
|
-
|
|
147
|
+
(0, chai_config_spec_1.expect)(codeActions).to.be.empty;
|
|
140
148
|
});
|
|
141
149
|
it('suggests class imports', () => {
|
|
142
150
|
//import the file in two scopes
|
|
143
|
-
program.setFile('components/comp1.xml', testHelpers_spec_1.trim `
|
|
151
|
+
program.setFile('components/comp1.xml', (0, testHelpers_spec_1.trim) `
|
|
144
152
|
<?xml version="1.0" encoding="utf-8" ?>
|
|
145
153
|
<component name="ChildScene">
|
|
146
154
|
<script uri="comp1.bs" />
|
|
@@ -156,7 +164,7 @@ describe('CodeActionsProcessor', () => {
|
|
|
156
164
|
end class
|
|
157
165
|
`);
|
|
158
166
|
program.validate();
|
|
159
|
-
|
|
167
|
+
(0, chai_config_spec_1.expect)(program.getCodeActions(file.srcPath,
|
|
160
168
|
// new Per|son()
|
|
161
169
|
util_1.util.createRange(2, 34, 2, 34)).map(x => x.title).sort()).to.eql([
|
|
162
170
|
`import "pkg:/source/Person.bs"`
|
|
@@ -164,9 +172,9 @@ describe('CodeActionsProcessor', () => {
|
|
|
164
172
|
});
|
|
165
173
|
it('suggests class imports', () => {
|
|
166
174
|
//import the file in two scopes
|
|
167
|
-
program.setFile('components/comp1.xml', testHelpers_spec_1.trim `
|
|
175
|
+
program.setFile('components/comp1.xml', (0, testHelpers_spec_1.trim) `
|
|
168
176
|
<?xml version="1.0" encoding="utf-8" ?>
|
|
169
|
-
<component name="ChildScene">
|
|
177
|
+
<component name="ChildScene" extends="Group">
|
|
170
178
|
<script uri="comp1.bs" />
|
|
171
179
|
</component>
|
|
172
180
|
`);
|
|
@@ -183,12 +191,78 @@ describe('CodeActionsProcessor', () => {
|
|
|
183
191
|
end namespace
|
|
184
192
|
`);
|
|
185
193
|
program.validate();
|
|
186
|
-
|
|
194
|
+
(0, chai_config_spec_1.expect)(program.getCodeActions(file.srcPath,
|
|
187
195
|
// new Anim|als.Cat()
|
|
188
196
|
util_1.util.createRange(2, 36, 2, 36)).map(x => x.title).sort()).to.eql([
|
|
189
197
|
`import "pkg:/source/Animals.bs"`
|
|
190
198
|
]);
|
|
191
199
|
});
|
|
200
|
+
it('suggests all files for a root namespace name', () => {
|
|
201
|
+
program.setFile('source/first.bs', `
|
|
202
|
+
namespace alpha
|
|
203
|
+
function firstAction()
|
|
204
|
+
end function
|
|
205
|
+
end namespace
|
|
206
|
+
`);
|
|
207
|
+
program.setFile('source/second.bs', `
|
|
208
|
+
namespace alpha.beta
|
|
209
|
+
function secondAction()
|
|
210
|
+
end function
|
|
211
|
+
end namespace
|
|
212
|
+
`);
|
|
213
|
+
program.setFile('components/MainScene.xml', (0, testHelpers_spec_1.trim) `<component name="MainScene" extends="Scene"></component>`);
|
|
214
|
+
const file = program.setFile('components/MainScene.bs', `
|
|
215
|
+
sub init()
|
|
216
|
+
print alpha.secondAction()
|
|
217
|
+
end sub
|
|
218
|
+
`);
|
|
219
|
+
// print al|pha.secondAction()
|
|
220
|
+
testGetCodeActions(file, util_1.util.createRange(2, 28, 2, 28), [
|
|
221
|
+
`import "pkg:/source/first.bs"`,
|
|
222
|
+
`import "pkg:/source/second.bs"`
|
|
223
|
+
]);
|
|
224
|
+
});
|
|
225
|
+
it('suggests files for second part of missing namespace', () => {
|
|
226
|
+
program.setFile('source/first.bs', `
|
|
227
|
+
namespace alpha
|
|
228
|
+
function firstAction()
|
|
229
|
+
end function
|
|
230
|
+
end namespace
|
|
231
|
+
`);
|
|
232
|
+
program.setFile('source/second.bs', `
|
|
233
|
+
namespace alpha.beta
|
|
234
|
+
function secondAction()
|
|
235
|
+
end function
|
|
236
|
+
end namespace
|
|
237
|
+
`);
|
|
238
|
+
program.setFile('components/MainScene.xml', (0, testHelpers_spec_1.trim) `<component name="MainScene" extends="Scene"></component>`);
|
|
239
|
+
const file = program.setFile('components/MainScene.bs', `
|
|
240
|
+
import "pkg:/source/first.bs"
|
|
241
|
+
sub init()
|
|
242
|
+
print alpha.beta.secondAction()
|
|
243
|
+
end sub
|
|
244
|
+
`);
|
|
245
|
+
// print alpha.be|ta.secondAction()
|
|
246
|
+
testGetCodeActions(file, util_1.util.createRange(3, 34, 3, 34), [`import "pkg:/source/second.bs"`]);
|
|
247
|
+
});
|
|
248
|
+
});
|
|
249
|
+
it('suggests imports at very start and very end of diagnostic', () => {
|
|
250
|
+
program.setFile('source/first.bs', `
|
|
251
|
+
namespace alpha
|
|
252
|
+
function firstAction()
|
|
253
|
+
end function
|
|
254
|
+
end namespace
|
|
255
|
+
`);
|
|
256
|
+
program.setFile('components/MainScene.xml', (0, testHelpers_spec_1.trim) `<component name="MainScene" extends="Scene"></component>`);
|
|
257
|
+
const file = program.setFile('components/MainScene.bs', `
|
|
258
|
+
sub init()
|
|
259
|
+
print alpha.firstAction()
|
|
260
|
+
end sub
|
|
261
|
+
`);
|
|
262
|
+
// print |alpha.firstAction()
|
|
263
|
+
testGetCodeActions(file, util_1.util.createRange(2, 22, 2, 22), [`import "pkg:/source/first.bs"`]);
|
|
264
|
+
// print alpha|.firstAction()
|
|
265
|
+
testGetCodeActions(file, util_1.util.createRange(2, 27, 2, 27), [`import "pkg:/source/first.bs"`]);
|
|
192
266
|
});
|
|
193
267
|
});
|
|
194
268
|
//# sourceMappingURL=CodeActionsProcessor.spec.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CodeActionsProcessor.spec.js","sourceRoot":"","sources":["../../../src/bscPlugin/codeActions/CodeActionsProcessor.spec.ts"],"names":[],"mappings":";;AAAA
|
|
1
|
+
{"version":3,"file":"CodeActionsProcessor.spec.js","sourceRoot":"","sources":["../../../src/bscPlugin/codeActions/CodeActionsProcessor.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import type { FileReference, ProvideCompletionsEvent } from '../../interfaces';
|
|
2
|
+
import type { Scope } from '../../Scope';
|
|
3
|
+
import type { CompletionItem, Position } from 'vscode-languageserver';
|
|
4
|
+
import type { XmlFile } from '../../files/XmlFile';
|
|
5
|
+
import type { Program } from '../../Program';
|
|
6
|
+
import type { BrsFile } from '../../files/BrsFile';
|
|
7
|
+
import type { FunctionStatement } from '../../parser/Statement';
|
|
8
|
+
export declare class CompletionsProcessor {
|
|
9
|
+
private event;
|
|
10
|
+
constructor(event: ProvideCompletionsEvent);
|
|
11
|
+
process(): void;
|
|
12
|
+
/**
|
|
13
|
+
* Get all available completions for the specified position
|
|
14
|
+
* @param position the position to get completions
|
|
15
|
+
*/
|
|
16
|
+
getXmlFileCompletions(position: Position, file: XmlFile): CompletionItem[];
|
|
17
|
+
/**
|
|
18
|
+
* Get a list of all script imports, relative to the specified pkgPath
|
|
19
|
+
* @param program - reference to the program
|
|
20
|
+
* @param sourcePkgPath - the pkgPath of the source that wants to resolve script imports
|
|
21
|
+
* @param scriptImport - example script import
|
|
22
|
+
*/
|
|
23
|
+
getScriptImportCompletions(program: Program, sourcePkgPath: string, scriptImport: FileReference): CompletionItem[];
|
|
24
|
+
/**
|
|
25
|
+
* Get completions available at the given cursor. This aggregates all values from this file and the current scope.
|
|
26
|
+
*/
|
|
27
|
+
getBrsFileCompletions(position: Position, file: BrsFile): CompletionItem[];
|
|
28
|
+
private getScopeSymbolCompletions;
|
|
29
|
+
private getSymbolsCompletion;
|
|
30
|
+
private getDocumentation;
|
|
31
|
+
private getCompletionKindFromSymbol;
|
|
32
|
+
private isNamespaceTypeWithMemberType;
|
|
33
|
+
private isMemberAccessible;
|
|
34
|
+
private getLabelCompletion;
|
|
35
|
+
createCompletionFromFunctionStatement(statement: FunctionStatement): CompletionItem;
|
|
36
|
+
private getStringLiteralCompletions;
|
|
37
|
+
/**
|
|
38
|
+
* Scan all files for property names, and return them as completions
|
|
39
|
+
*/
|
|
40
|
+
getPropertyNameCompletions(scope: Scope): CompletionItem[];
|
|
41
|
+
getAllClassMemberCompletions(scope: Scope): Map<string, CompletionItem>;
|
|
42
|
+
/**
|
|
43
|
+
* Scan all xmlScopes for call funcs
|
|
44
|
+
*/
|
|
45
|
+
getCallFuncNameCompletions(scope: Scope): CompletionItem[];
|
|
46
|
+
private getGlobalValues;
|
|
47
|
+
private isPostionInComment;
|
|
48
|
+
private isTokenAdjacentTo;
|
|
49
|
+
private getAdjacentToken;
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* List of completions for all valid keywords/reserved words.
|
|
53
|
+
* Build this list once because it won't change for the lifetime of this process
|
|
54
|
+
*/
|
|
55
|
+
export declare const KeywordCompletions: CompletionItem[];
|
|
56
|
+
/**
|
|
57
|
+
* List of completions for all valid intrinsic types.
|
|
58
|
+
* Build this list once because it won't change for the lifetime of this process
|
|
59
|
+
*/
|
|
60
|
+
export declare const NativeTypeCompletions: CompletionItem[];
|