brighterscript 1.0.0-alpha.5 → 1.0.0-alpha.51
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/README.md +79 -138
- package/bsconfig.schema.json +196 -5
- 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 +45 -0
- package/dist/AstValidationSegmenter.js +322 -0
- package/dist/AstValidationSegmenter.js.map +1 -0
- package/dist/BsConfig.d.ts +161 -43
- package/dist/BusyStatusTracker.d.ts +61 -0
- package/dist/BusyStatusTracker.js +148 -0
- package/dist/BusyStatusTracker.js.map +1 -0
- package/dist/Cache.d.ts +3 -8
- package/dist/Cache.js +9 -14
- 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 +29 -4
- package/dist/CodeActionUtil.js +22 -5
- package/dist/CodeActionUtil.js.map +1 -1
- package/dist/CommentFlagProcessor.d.ts +20 -15
- package/dist/CommentFlagProcessor.js +143 -58
- package/dist/CommentFlagProcessor.js.map +1 -1
- package/dist/CrossScopeValidator.d.ts +68 -0
- package/dist/CrossScopeValidator.js +650 -0
- package/dist/CrossScopeValidator.js.map +1 -0
- 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 +21 -5
- package/dist/DiagnosticCollection.js +77 -24
- package/dist/DiagnosticCollection.js.map +1 -1
- package/dist/DiagnosticFilterer.d.ts +27 -6
- package/dist/DiagnosticFilterer.js +273 -60
- package/dist/DiagnosticFilterer.js.map +1 -1
- package/dist/DiagnosticManager.d.ts +83 -0
- package/dist/DiagnosticManager.js +422 -0
- package/dist/DiagnosticManager.js.map +1 -0
- package/dist/DiagnosticMessages.d.ts +602 -196
- package/dist/DiagnosticMessages.js +926 -342
- package/dist/DiagnosticMessages.js.map +1 -1
- package/dist/DiagnosticSeverityAdjuster.d.ts +7 -0
- package/dist/DiagnosticSeverityAdjuster.js +45 -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 +136 -104
- package/dist/LanguageServer.js +577 -741
- package/dist/LanguageServer.js.map +1 -1
- package/dist/Logger.d.ts +17 -13
- package/dist/Logger.js +64 -34
- package/dist/Logger.js.map +1 -1
- package/dist/PluginInterface.d.ts +32 -10
- package/dist/PluginInterface.js +117 -7
- package/dist/PluginInterface.js.map +1 -1
- package/dist/Program.d.ts +302 -98
- package/dist/Program.js +1613 -726
- package/dist/Program.js.map +1 -1
- package/dist/ProgramBuilder.d.ts +39 -22
- package/dist/ProgramBuilder.js +245 -179
- package/dist/ProgramBuilder.js.map +1 -1
- package/dist/Scope.d.ts +227 -106
- package/dist/Scope.js +609 -557
- package/dist/Scope.js.map +1 -1
- package/dist/ScopeNamespaceLookup.d.ts +73 -0
- package/dist/ScopeNamespaceLookup.js +242 -0
- package/dist/ScopeNamespaceLookup.js.map +1 -0
- package/dist/SemanticTokenUtils.js +5 -1
- package/dist/SemanticTokenUtils.js.map +1 -1
- 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 +145 -26
- package/dist/SymbolTable.js +575 -64
- package/dist/SymbolTable.js.map +1 -1
- package/dist/SymbolTypeFlag.d.ts +9 -0
- package/dist/SymbolTypeFlag.js +14 -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 +34 -90
- package/dist/XmlScope.js.map +1 -1
- package/dist/astUtils/CachedLookups.d.ts +50 -0
- package/dist/astUtils/CachedLookups.js +337 -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/creators.d.ts +54 -19
- package/dist/astUtils/creators.js +242 -42
- package/dist/astUtils/creators.js.map +1 -1
- package/dist/astUtils/reflection.d.ts +199 -85
- package/dist/astUtils/reflection.js +518 -145
- package/dist/astUtils/reflection.js.map +1 -1
- package/dist/astUtils/stackedVisitor.js.map +1 -1
- package/dist/astUtils/visitors.d.ts +117 -53
- package/dist/astUtils/visitors.js +95 -15
- package/dist/astUtils/visitors.js.map +1 -1
- package/dist/astUtils/xml.d.ts +9 -8
- package/dist/astUtils/xml.js +12 -7
- package/dist/astUtils/xml.js.map +1 -1
- package/dist/bscPlugin/BscPlugin.d.ts +26 -4
- package/dist/bscPlugin/BscPlugin.js +96 -4
- package/dist/bscPlugin/BscPlugin.js.map +1 -1
- package/dist/bscPlugin/CallExpressionInfo.d.ts +36 -0
- package/dist/bscPlugin/CallExpressionInfo.js +142 -0
- package/dist/bscPlugin/CallExpressionInfo.js.map +1 -0
- package/dist/bscPlugin/FileWriter.d.ts +19 -0
- package/dist/bscPlugin/FileWriter.js +79 -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 +109 -7
- package/dist/bscPlugin/codeActions/CodeActionsProcessor.js +676 -26
- package/dist/bscPlugin/codeActions/CodeActionsProcessor.js.map +1 -1
- package/dist/bscPlugin/codeActions/FixAllCodeActionsProcessor.d.ts +17 -0
- package/dist/bscPlugin/codeActions/FixAllCodeActionsProcessor.js +66 -0
- package/dist/bscPlugin/codeActions/FixAllCodeActionsProcessor.js.map +1 -0
- package/dist/bscPlugin/codeActions/codeActionHelpers.d.ts +18 -0
- package/dist/bscPlugin/codeActions/codeActionHelpers.js +31 -0
- package/dist/bscPlugin/codeActions/codeActionHelpers.js.map +1 -0
- package/dist/bscPlugin/completions/CompletionsProcessor.d.ts +65 -0
- package/dist/bscPlugin/completions/CompletionsProcessor.js +633 -0
- package/dist/bscPlugin/completions/CompletionsProcessor.js.map +1 -0
- package/dist/bscPlugin/definition/DefinitionProvider.d.ts +13 -0
- package/dist/bscPlugin/definition/DefinitionProvider.js +220 -0
- package/dist/bscPlugin/definition/DefinitionProvider.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 +238 -0
- package/dist/bscPlugin/hover/HoverProcessor.js.map +1 -0
- package/dist/bscPlugin/references/ReferencesProvider.d.ts +12 -0
- package/dist/bscPlugin/references/ReferencesProvider.js +57 -0
- package/dist/bscPlugin/references/ReferencesProvider.js.map +1 -0
- package/dist/bscPlugin/selectionRanges/SelectionRangesProcessor.d.ts +7 -0
- package/dist/bscPlugin/selectionRanges/SelectionRangesProcessor.js +77 -0
- package/dist/bscPlugin/selectionRanges/SelectionRangesProcessor.js.map +1 -0
- package/dist/bscPlugin/semanticTokens/BrsFileSemanticTokensProcessor.d.ts +14 -0
- package/dist/bscPlugin/semanticTokens/BrsFileSemanticTokensProcessor.js +164 -0
- package/dist/bscPlugin/semanticTokens/BrsFileSemanticTokensProcessor.js.map +1 -0
- package/dist/bscPlugin/serialize/BslibManager.d.ts +12 -0
- package/dist/bscPlugin/serialize/BslibManager.js +46 -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 +80 -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/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/symbolUtils.d.ts +5 -0
- package/dist/bscPlugin/symbols/symbolUtils.js +141 -0
- package/dist/bscPlugin/symbols/symbolUtils.js.map +1 -0
- package/dist/bscPlugin/transpile/BrsFileTranspileProcessor.d.ts +34 -0
- package/dist/bscPlugin/transpile/BrsFileTranspileProcessor.js +504 -0
- package/dist/bscPlugin/transpile/BrsFileTranspileProcessor.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/BrsFileAfterValidator.d.ts +7 -0
- package/dist/bscPlugin/validation/BrsFileAfterValidator.js +18 -0
- package/dist/bscPlugin/validation/BrsFileAfterValidator.js.map +1 -0
- package/dist/bscPlugin/validation/BrsFileValidator.d.ts +51 -0
- package/dist/bscPlugin/validation/BrsFileValidator.js +714 -0
- package/dist/bscPlugin/validation/BrsFileValidator.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 +158 -0
- package/dist/bscPlugin/validation/ScopeValidator.js +1481 -0
- package/dist/bscPlugin/validation/ScopeValidator.js.map +1 -0
- package/dist/bscPlugin/validation/XmlFileValidator.d.ts +8 -0
- package/dist/bscPlugin/validation/XmlFileValidator.js +50 -0
- package/dist/bscPlugin/validation/XmlFileValidator.js.map +1 -0
- package/dist/cli.js +140 -28
- package/dist/cli.js.map +1 -1
- package/dist/common/Sequencer.d.ts +53 -0
- package/dist/common/Sequencer.js +233 -0
- package/dist/common/Sequencer.js.map +1 -0
- package/dist/deferred.d.ts +5 -3
- package/dist/deferred.js +10 -0
- package/dist/deferred.js.map +1 -1
- package/dist/diagnosticUtils.d.ts +61 -4
- package/dist/diagnosticUtils.js +285 -25
- package/dist/diagnosticUtils.js.map +1 -1
- package/dist/examples/plugins/removePrint.d.ts +2 -2
- 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.d.ts +161 -87
- package/dist/files/BrsFile.js +919 -936
- package/dist/files/BrsFile.js.map +1 -1
- package/dist/files/BscFile.d.ts +102 -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 +21 -0
- package/dist/files/LazyFileData.js +54 -0
- package/dist/files/LazyFileData.js.map +1 -0
- package/dist/files/XmlFile.d.ts +80 -41
- package/dist/files/XmlFile.js +162 -137
- package/dist/files/XmlFile.js.map +1 -1
- package/dist/globalCallables.d.ts +3 -1
- package/dist/globalCallables.js +424 -184
- package/dist/globalCallables.js.map +1 -1
- package/dist/index.d.ts +32 -4
- package/dist/index.js +54 -7
- package/dist/index.js.map +1 -1
- package/dist/interfaces.d.ts +987 -125
- package/dist/interfaces.js +21 -0
- package/dist/interfaces.js.map +1 -1
- package/dist/lexer/Lexer.d.ts +51 -12
- package/dist/lexer/Lexer.js +214 -65
- package/dist/lexer/Lexer.js.map +1 -1
- package/dist/lexer/Token.d.ts +27 -11
- package/dist/lexer/Token.js +10 -2
- package/dist/lexer/Token.js.map +1 -1
- package/dist/lexer/TokenKind.d.ts +48 -2
- package/dist/lexer/TokenKind.js +167 -10
- package/dist/lexer/TokenKind.js.map +1 -1
- package/dist/logging.d.ts +14 -0
- package/dist/logging.js +29 -0
- package/dist/logging.js.map +1 -0
- package/dist/lsp/ActionQueue.d.ts +35 -0
- package/dist/lsp/ActionQueue.js +115 -0
- package/dist/lsp/ActionQueue.js.map +1 -0
- package/dist/lsp/DocumentManager.d.ts +63 -0
- package/dist/lsp/DocumentManager.js +122 -0
- package/dist/lsp/DocumentManager.js.map +1 -0
- package/dist/lsp/LspProject.d.ts +287 -0
- package/dist/lsp/LspProject.js +3 -0
- package/dist/lsp/LspProject.js.map +1 -0
- package/dist/lsp/PathFilterer.d.ts +75 -0
- package/dist/lsp/PathFilterer.js +196 -0
- package/dist/lsp/PathFilterer.js.map +1 -0
- package/dist/lsp/Project.d.ts +200 -0
- package/dist/lsp/Project.js +562 -0
- package/dist/lsp/Project.js.map +1 -0
- package/dist/lsp/ProjectManager.d.ts +288 -0
- package/dist/lsp/ProjectManager.js +967 -0
- package/dist/lsp/ProjectManager.js.map +1 -0
- package/dist/lsp/ReaderWriterManager.d.ts +21 -0
- package/dist/lsp/ReaderWriterManager.js +60 -0
- package/dist/lsp/ReaderWriterManager.js.map +1 -0
- package/dist/lsp/worker/MessageHandler.d.ts +99 -0
- package/dist/lsp/worker/MessageHandler.js +138 -0
- package/dist/lsp/worker/MessageHandler.js.map +1 -0
- package/dist/lsp/worker/WorkerPool.d.ts +38 -0
- package/dist/lsp/worker/WorkerPool.js +78 -0
- package/dist/lsp/worker/WorkerPool.js.map +1 -0
- package/dist/lsp/worker/WorkerThreadProject.d.ts +168 -0
- package/dist/lsp/worker/WorkerThreadProject.js +205 -0
- package/dist/lsp/worker/WorkerThreadProject.js.map +1 -0
- package/dist/lsp/worker/WorkerThreadProjectRunner.d.ts +15 -0
- package/dist/lsp/worker/WorkerThreadProjectRunner.js +58 -0
- package/dist/lsp/worker/WorkerThreadProjectRunner.js.map +1 -0
- package/dist/lsp/worker/run.js +14 -0
- package/dist/lsp/worker/run.js.map +1 -0
- package/dist/parser/AstNode.d.ts +205 -0
- package/dist/parser/AstNode.js +305 -0
- package/dist/parser/AstNode.js.map +1 -0
- package/dist/parser/BrightScriptDocParser.d.ts +56 -0
- package/dist/parser/BrightScriptDocParser.js +294 -0
- package/dist/parser/BrightScriptDocParser.js.map +1 -0
- package/dist/parser/BrsTranspileState.d.ts +22 -3
- package/dist/parser/BrsTranspileState.js +19 -0
- package/dist/parser/BrsTranspileState.js.map +1 -1
- package/dist/parser/Expression.d.ts +601 -220
- package/dist/parser/Expression.js +1516 -502
- package/dist/parser/Expression.js.map +1 -1
- package/dist/parser/Parser.d.ts +137 -121
- package/dist/parser/Parser.js +1808 -982
- package/dist/parser/Parser.js.map +1 -1
- package/dist/parser/SGParser.d.ts +30 -13
- package/dist/parser/SGParser.js +94 -56
- package/dist/parser/SGParser.js.map +1 -1
- package/dist/parser/SGTypes.d.ts +134 -46
- package/dist/parser/SGTypes.js +206 -115
- package/dist/parser/SGTypes.js.map +1 -1
- package/dist/parser/Statement.d.ts +854 -267
- package/dist/parser/Statement.js +2416 -621
- package/dist/parser/Statement.js.map +1 -1
- package/dist/parser/TranspileState.d.ts +30 -14
- package/dist/parser/TranspileState.js +124 -27
- package/dist/parser/TranspileState.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/roku-types/data.json +20554 -0
- package/dist/roku-types/index.d.ts +5726 -0
- package/dist/roku-types/index.js +11 -0
- package/dist/roku-types/index.js.map +1 -0
- package/dist/types/ArrayType.d.ts +12 -5
- package/dist/types/ArrayType.js +95 -25
- package/dist/types/ArrayType.js.map +1 -1
- package/dist/types/AssociativeArrayType.d.ts +15 -0
- package/dist/types/AssociativeArrayType.js +64 -0
- package/dist/types/AssociativeArrayType.js.map +1 -0
- package/dist/types/BaseFunctionType.d.ts +10 -0
- package/dist/types/BaseFunctionType.js +26 -0
- package/dist/types/BaseFunctionType.js.map +1 -0
- package/dist/types/BooleanType.d.ts +9 -5
- package/dist/types/BooleanType.js +19 -8
- package/dist/types/BooleanType.js.map +1 -1
- package/dist/types/BscType.d.ts +41 -3
- package/dist/types/BscType.js +152 -0
- package/dist/types/BscType.js.map +1 -1
- package/dist/types/BscTypeKind.d.ts +28 -0
- package/dist/types/BscTypeKind.js +33 -0
- package/dist/types/BscTypeKind.js.map +1 -0
- package/dist/types/BuiltInInterfaceAdder.d.ts +28 -0
- package/dist/types/BuiltInInterfaceAdder.js +212 -0
- package/dist/types/BuiltInInterfaceAdder.js.map +1 -0
- package/dist/types/CallFuncableType.d.ts +24 -0
- package/dist/types/CallFuncableType.js +91 -0
- package/dist/types/CallFuncableType.js.map +1 -0
- package/dist/types/ClassType.d.ts +17 -0
- package/dist/types/ClassType.js +63 -0
- package/dist/types/ClassType.js.map +1 -0
- package/dist/types/ComponentType.d.ts +22 -0
- package/dist/types/ComponentType.js +110 -0
- package/dist/types/ComponentType.js.map +1 -0
- package/dist/types/DoubleType.d.ts +10 -5
- package/dist/types/DoubleType.js +21 -17
- package/dist/types/DoubleType.js.map +1 -1
- package/dist/types/DynamicType.d.ts +13 -5
- package/dist/types/DynamicType.js +26 -5
- package/dist/types/DynamicType.js.map +1 -1
- package/dist/types/EnumType.d.ts +42 -0
- package/dist/types/EnumType.js +101 -0
- package/dist/types/EnumType.js.map +1 -0
- package/dist/types/FloatType.d.ts +10 -5
- package/dist/types/FloatType.js +21 -17
- package/dist/types/FloatType.js.map +1 -1
- package/dist/types/FunctionType.d.ts +8 -22
- package/dist/types/FunctionType.js +25 -63
- package/dist/types/FunctionType.js.map +1 -1
- package/dist/types/InheritableType.d.ts +29 -0
- package/dist/types/InheritableType.js +173 -0
- package/dist/types/InheritableType.js.map +1 -0
- package/dist/types/InlineInterfaceType.d.ts +5 -0
- package/dist/types/InlineInterfaceType.js +17 -0
- package/dist/types/InlineInterfaceType.js.map +1 -0
- package/dist/types/IntegerType.d.ts +10 -5
- package/dist/types/IntegerType.js +21 -17
- package/dist/types/IntegerType.js.map +1 -1
- package/dist/types/InterfaceType.d.ts +14 -6
- package/dist/types/InterfaceType.js +30 -15
- package/dist/types/InterfaceType.js.map +1 -1
- package/dist/types/IntersectionType.d.ts +29 -0
- package/dist/types/IntersectionType.js +256 -0
- package/dist/types/IntersectionType.js.map +1 -0
- package/dist/types/InvalidType.d.ts +10 -5
- package/dist/types/InvalidType.js +21 -9
- package/dist/types/InvalidType.js.map +1 -1
- package/dist/types/LongIntegerType.d.ts +10 -5
- package/dist/types/LongIntegerType.js +21 -17
- package/dist/types/LongIntegerType.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 +12 -5
- package/dist/types/ObjectType.js +25 -8
- package/dist/types/ObjectType.js.map +1 -1
- package/dist/types/ReferenceType.d.ts +123 -0
- package/dist/types/ReferenceType.js +726 -0
- package/dist/types/ReferenceType.js.map +1 -0
- package/dist/types/StringType.d.ts +12 -5
- package/dist/types/StringType.js +23 -8
- package/dist/types/StringType.js.map +1 -1
- package/dist/types/TypeStatementType.d.ts +19 -0
- package/dist/types/TypeStatementType.js +56 -0
- package/dist/types/TypeStatementType.js.map +1 -0
- package/dist/types/TypedFunctionType.d.ts +34 -0
- package/dist/types/TypedFunctionType.js +157 -0
- package/dist/types/TypedFunctionType.js.map +1 -0
- package/dist/types/UninitializedType.d.ts +11 -6
- package/dist/types/UninitializedType.js +20 -11
- package/dist/types/UninitializedType.js.map +1 -1
- package/dist/types/UnionType.d.ts +27 -0
- package/dist/types/UnionType.js +196 -0
- package/dist/types/UnionType.js.map +1 -0
- package/dist/types/VoidType.d.ts +11 -5
- package/dist/types/VoidType.js +22 -8
- package/dist/types/VoidType.js.map +1 -1
- package/dist/types/helpers.d.ts +51 -0
- package/dist/types/helpers.js +329 -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/types/roFunctionType.d.ts +11 -0
- package/dist/types/roFunctionType.js +37 -0
- package/dist/types/roFunctionType.js.map +1 -0
- package/dist/util.d.ts +325 -185
- package/dist/util.js +2135 -568
- package/dist/util.js.map +1 -1
- package/dist/validators/ClassValidator.d.ts +9 -15
- package/dist/validators/ClassValidator.js +93 -138
- package/dist/validators/ClassValidator.js.map +1 -1
- package/package.json +183 -138
- package/CHANGELOG.md +0 -1188
- package/dist/astUtils/creators.spec.js +0 -21
- package/dist/astUtils/creators.spec.js.map +0 -1
- 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/astUtils/reflection.spec.d.ts +0 -1
- package/dist/astUtils/reflection.spec.js +0 -292
- package/dist/astUtils/reflection.spec.js.map +0 -1
- package/dist/astUtils/stackedVisitor.spec.d.ts +0 -1
- package/dist/astUtils/stackedVisitor.spec.js +0 -79
- package/dist/astUtils/stackedVisitor.spec.js.map +0 -1
- package/dist/astUtils/visitors.spec.d.ts +0 -1
- package/dist/astUtils/visitors.spec.js +0 -854
- package/dist/astUtils/visitors.spec.js.map +0 -1
- package/dist/bscPlugin/codeActions/CodeActionsProcessor.spec.d.ts +0 -1
- package/dist/bscPlugin/codeActions/CodeActionsProcessor.spec.js +0 -194
- package/dist/bscPlugin/codeActions/CodeActionsProcessor.spec.js.map +0 -1
- package/dist/bscPlugin/semanticTokens/SemanticTokensProcessor.d.ts +0 -7
- package/dist/bscPlugin/semanticTokens/SemanticTokensProcessor.js +0 -63
- package/dist/bscPlugin/semanticTokens/SemanticTokensProcessor.js.map +0 -1
- package/dist/bscPlugin/semanticTokens/SemanticTokensProcessor.spec.d.ts +0 -1
- package/dist/bscPlugin/semanticTokens/SemanticTokensProcessor.spec.js +0 -45
- package/dist/bscPlugin/semanticTokens/SemanticTokensProcessor.spec.js.map +0 -1
- package/dist/files/BrsFile.Class.spec.d.ts +0 -1
- package/dist/files/BrsFile.Class.spec.js +0 -1081
- package/dist/files/BrsFile.Class.spec.js.map +0 -1
- package/dist/files/BrsFile.spec.d.ts +0 -1
- package/dist/files/BrsFile.spec.js +0 -2524
- package/dist/files/BrsFile.spec.js.map +0 -1
- package/dist/files/XmlFile.spec.d.ts +0 -1
- package/dist/files/XmlFile.spec.js +0 -1065
- package/dist/files/XmlFile.spec.js.map +0 -1
- package/dist/files/tests/imports.spec.d.ts +0 -1
- package/dist/files/tests/imports.spec.js +0 -241
- package/dist/files/tests/imports.spec.js.map +0 -1
- package/dist/lexer/Character.spec.d.ts +0 -1
- package/dist/lexer/Character.spec.js +0 -27
- package/dist/lexer/Character.spec.js.map +0 -1
- package/dist/lexer/Lexer.spec.d.ts +0 -1
- package/dist/lexer/Lexer.spec.js +0 -1101
- package/dist/lexer/Lexer.spec.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/Parser.Class.spec.d.ts +0 -1
- package/dist/parser/Parser.Class.spec.js +0 -390
- package/dist/parser/Parser.Class.spec.js.map +0 -1
- package/dist/parser/Parser.spec.d.ts +0 -4
- package/dist/parser/Parser.spec.js +0 -1216
- package/dist/parser/Parser.spec.js.map +0 -1
- package/dist/parser/SGParser.spec.d.ts +0 -1
- package/dist/parser/SGParser.spec.js +0 -145
- package/dist/parser/SGParser.spec.js.map +0 -1
- package/dist/parser/SGTypes.spec.d.ts +0 -1
- package/dist/parser/SGTypes.spec.js +0 -351
- package/dist/parser/SGTypes.spec.js.map +0 -1
- package/dist/parser/Statement.spec.d.ts +0 -1
- package/dist/parser/Statement.spec.js +0 -94
- package/dist/parser/Statement.spec.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/parser/tests/Parser.spec.d.ts +0 -18
- package/dist/parser/tests/Parser.spec.js +0 -35
- package/dist/parser/tests/Parser.spec.js.map +0 -1
- package/dist/parser/tests/controlFlow/For.spec.d.ts +0 -1
- package/dist/parser/tests/controlFlow/For.spec.js +0 -161
- package/dist/parser/tests/controlFlow/For.spec.js.map +0 -1
- package/dist/parser/tests/controlFlow/ForEach.spec.d.ts +0 -1
- package/dist/parser/tests/controlFlow/ForEach.spec.js +0 -106
- package/dist/parser/tests/controlFlow/ForEach.spec.js.map +0 -1
- package/dist/parser/tests/controlFlow/If.spec.d.ts +0 -1
- package/dist/parser/tests/controlFlow/If.spec.js +0 -551
- package/dist/parser/tests/controlFlow/If.spec.js.map +0 -1
- package/dist/parser/tests/controlFlow/While.spec.d.ts +0 -1
- package/dist/parser/tests/controlFlow/While.spec.js +0 -107
- package/dist/parser/tests/controlFlow/While.spec.js.map +0 -1
- package/dist/parser/tests/expression/Additive.spec.d.ts +0 -1
- package/dist/parser/tests/expression/Additive.spec.js +0 -99
- package/dist/parser/tests/expression/Additive.spec.js.map +0 -1
- package/dist/parser/tests/expression/ArrayLiterals.spec.d.ts +0 -1
- package/dist/parser/tests/expression/ArrayLiterals.spec.js +0 -254
- package/dist/parser/tests/expression/ArrayLiterals.spec.js.map +0 -1
- package/dist/parser/tests/expression/AssociativeArrayLiterals.spec.d.ts +0 -1
- package/dist/parser/tests/expression/AssociativeArrayLiterals.spec.js +0 -266
- package/dist/parser/tests/expression/AssociativeArrayLiterals.spec.js.map +0 -1
- package/dist/parser/tests/expression/Boolean.spec.d.ts +0 -1
- package/dist/parser/tests/expression/Boolean.spec.js +0 -83
- package/dist/parser/tests/expression/Boolean.spec.js.map +0 -1
- package/dist/parser/tests/expression/Call.spec.d.ts +0 -1
- package/dist/parser/tests/expression/Call.spec.js +0 -134
- package/dist/parser/tests/expression/Call.spec.js.map +0 -1
- package/dist/parser/tests/expression/Exponential.spec.d.ts +0 -1
- package/dist/parser/tests/expression/Exponential.spec.js +0 -37
- package/dist/parser/tests/expression/Exponential.spec.js.map +0 -1
- package/dist/parser/tests/expression/Function.spec.d.ts +0 -1
- package/dist/parser/tests/expression/Function.spec.js +0 -403
- package/dist/parser/tests/expression/Function.spec.js.map +0 -1
- package/dist/parser/tests/expression/Indexing.spec.d.ts +0 -1
- package/dist/parser/tests/expression/Indexing.spec.js +0 -219
- package/dist/parser/tests/expression/Indexing.spec.js.map +0 -1
- package/dist/parser/tests/expression/Multiplicative.spec.d.ts +0 -1
- package/dist/parser/tests/expression/Multiplicative.spec.js +0 -67
- package/dist/parser/tests/expression/Multiplicative.spec.js.map +0 -1
- package/dist/parser/tests/expression/NullCoalescenceExpression.spec.d.ts +0 -1
- package/dist/parser/tests/expression/NullCoalescenceExpression.spec.js +0 -201
- package/dist/parser/tests/expression/NullCoalescenceExpression.spec.js.map +0 -1
- package/dist/parser/tests/expression/PrefixUnary.spec.d.ts +0 -1
- package/dist/parser/tests/expression/PrefixUnary.spec.js +0 -105
- package/dist/parser/tests/expression/PrefixUnary.spec.js.map +0 -1
- package/dist/parser/tests/expression/Primary.spec.d.ts +0 -1
- package/dist/parser/tests/expression/Primary.spec.js +0 -149
- package/dist/parser/tests/expression/Primary.spec.js.map +0 -1
- package/dist/parser/tests/expression/Relational.spec.d.ts +0 -1
- package/dist/parser/tests/expression/Relational.spec.js +0 -83
- package/dist/parser/tests/expression/Relational.spec.js.map +0 -1
- package/dist/parser/tests/expression/SourceLiteralExpression.spec.d.ts +0 -1
- package/dist/parser/tests/expression/SourceLiteralExpression.spec.js +0 -201
- package/dist/parser/tests/expression/SourceLiteralExpression.spec.js.map +0 -1
- package/dist/parser/tests/expression/TemplateStringExpression.spec.d.ts +0 -1
- package/dist/parser/tests/expression/TemplateStringExpression.spec.js +0 -202
- package/dist/parser/tests/expression/TemplateStringExpression.spec.js.map +0 -1
- package/dist/parser/tests/expression/TernaryExpression.spec.d.ts +0 -1
- package/dist/parser/tests/expression/TernaryExpression.spec.js +0 -323
- package/dist/parser/tests/expression/TernaryExpression.spec.js.map +0 -1
- package/dist/parser/tests/statement/AssignmentOperators.spec.d.ts +0 -1
- package/dist/parser/tests/statement/AssignmentOperators.spec.js +0 -79
- package/dist/parser/tests/statement/AssignmentOperators.spec.js.map +0 -1
- package/dist/parser/tests/statement/Declaration.spec.d.ts +0 -1
- package/dist/parser/tests/statement/Declaration.spec.js +0 -108
- package/dist/parser/tests/statement/Declaration.spec.js.map +0 -1
- package/dist/parser/tests/statement/Dim.spec.d.ts +0 -1
- package/dist/parser/tests/statement/Dim.spec.js +0 -73
- package/dist/parser/tests/statement/Dim.spec.js.map +0 -1
- package/dist/parser/tests/statement/Function.spec.d.ts +0 -1
- package/dist/parser/tests/statement/Function.spec.js +0 -332
- package/dist/parser/tests/statement/Function.spec.js.map +0 -1
- package/dist/parser/tests/statement/Goto.spec.d.ts +0 -1
- package/dist/parser/tests/statement/Goto.spec.js +0 -50
- package/dist/parser/tests/statement/Goto.spec.js.map +0 -1
- package/dist/parser/tests/statement/Increment.spec.d.ts +0 -1
- package/dist/parser/tests/statement/Increment.spec.js +0 -117
- package/dist/parser/tests/statement/Increment.spec.js.map +0 -1
- package/dist/parser/tests/statement/LibraryStatement.spec.d.ts +0 -1
- package/dist/parser/tests/statement/LibraryStatement.spec.js +0 -74
- package/dist/parser/tests/statement/LibraryStatement.spec.js.map +0 -1
- package/dist/parser/tests/statement/Misc.spec.d.ts +0 -1
- package/dist/parser/tests/statement/Misc.spec.js +0 -333
- package/dist/parser/tests/statement/Misc.spec.js.map +0 -1
- package/dist/parser/tests/statement/PrintStatement.spec.d.ts +0 -1
- package/dist/parser/tests/statement/PrintStatement.spec.js +0 -181
- package/dist/parser/tests/statement/PrintStatement.spec.js.map +0 -1
- package/dist/parser/tests/statement/ReturnStatement.spec.d.ts +0 -1
- package/dist/parser/tests/statement/ReturnStatement.spec.js +0 -94
- package/dist/parser/tests/statement/ReturnStatement.spec.js.map +0 -1
- package/dist/parser/tests/statement/Set.spec.d.ts +0 -1
- package/dist/parser/tests/statement/Set.spec.js +0 -218
- package/dist/parser/tests/statement/Set.spec.js.map +0 -1
- package/dist/parser/tests/statement/Stop.spec.d.ts +0 -1
- package/dist/parser/tests/statement/Stop.spec.js +0 -37
- package/dist/parser/tests/statement/Stop.spec.js.map +0 -1
- package/dist/parser/tests/statement/Throw.spec.d.ts +0 -1
- package/dist/parser/tests/statement/Throw.spec.js +0 -35
- package/dist/parser/tests/statement/Throw.spec.js.map +0 -1
- package/dist/parser/tests/statement/TryCatch.spec.d.ts +0 -1
- package/dist/parser/tests/statement/TryCatch.spec.js +0 -140
- package/dist/parser/tests/statement/TryCatch.spec.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/Manifest.spec.d.ts +0 -0
- package/dist/preprocessor/Manifest.spec.js +0 -105
- package/dist/preprocessor/Manifest.spec.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.d.ts +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.d.ts +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/ArrayType.spec.d.ts +0 -1
- package/dist/types/ArrayType.spec.js +0 -30
- package/dist/types/ArrayType.spec.js.map +0 -1
- package/dist/types/BooleanType.spec.d.ts +0 -1
- package/dist/types/BooleanType.spec.js +0 -12
- package/dist/types/BooleanType.spec.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/DoubleType.spec.d.ts +0 -1
- package/dist/types/DoubleType.spec.js +0 -12
- package/dist/types/DoubleType.spec.js.map +0 -1
- package/dist/types/DynamicType.spec.d.ts +0 -1
- package/dist/types/DynamicType.spec.js +0 -12
- package/dist/types/DynamicType.spec.js.map +0 -1
- package/dist/types/FloatType.spec.d.ts +0 -1
- package/dist/types/FloatType.spec.js +0 -12
- package/dist/types/FloatType.spec.js.map +0 -1
- package/dist/types/FunctionType.spec.d.ts +0 -1
- package/dist/types/FunctionType.spec.js +0 -29
- package/dist/types/FunctionType.spec.js.map +0 -1
- package/dist/types/IntegerType.spec.d.ts +0 -1
- package/dist/types/IntegerType.spec.js +0 -12
- package/dist/types/IntegerType.spec.js.map +0 -1
- package/dist/types/InvalidType.spec.d.ts +0 -1
- package/dist/types/InvalidType.spec.js +0 -12
- package/dist/types/InvalidType.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/types/LongIntegerType.spec.d.ts +0 -1
- package/dist/types/LongIntegerType.spec.js +0 -12
- package/dist/types/LongIntegerType.spec.js.map +0 -1
- package/dist/types/ObjectType.spec.d.ts +0 -1
- package/dist/types/ObjectType.spec.js +0 -12
- package/dist/types/ObjectType.spec.js.map +0 -1
- package/dist/types/StringType.spec.d.ts +0 -1
- package/dist/types/StringType.spec.js +0 -12
- package/dist/types/StringType.spec.js.map +0 -1
- package/dist/types/VoidType.spec.d.ts +0 -1
- package/dist/types/VoidType.spec.js +0 -12
- package/dist/types/VoidType.spec.js.map +0 -1
- /package/dist/{astUtils/creators.spec.d.ts → lsp/worker/run.d.ts} +0 -0
|
@@ -0,0 +1,633 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.NativeTypeCompletions = exports.KeywordCompletions = exports.CompletionsProcessor = void 0;
|
|
4
|
+
const reflection_1 = require("../../astUtils/reflection");
|
|
5
|
+
const TokenKind_1 = require("../../lexer/TokenKind");
|
|
6
|
+
const util_1 = require("../../util");
|
|
7
|
+
const Parser_1 = require("../../parser/Parser");
|
|
8
|
+
const vscode_languageserver_1 = require("vscode-languageserver");
|
|
9
|
+
const BooleanType_1 = require("../../types/BooleanType");
|
|
10
|
+
const InvalidType_1 = require("../../types/InvalidType");
|
|
11
|
+
const creators_1 = require("../../astUtils/creators");
|
|
12
|
+
const Logger_1 = require("../../Logger");
|
|
13
|
+
const SCOPES_FOR_COMPLETION = 3;
|
|
14
|
+
class CompletionsProcessor {
|
|
15
|
+
constructor(event) {
|
|
16
|
+
this.event = event;
|
|
17
|
+
}
|
|
18
|
+
process() {
|
|
19
|
+
let file = this.event.file;
|
|
20
|
+
this.event.program.logger.time(Logger_1.LogLevel.log, ['Processing completions'], () => {
|
|
21
|
+
// Find the scopes for this file - Only process the first few scopes
|
|
22
|
+
const scopesToProcess = this.getScopesForCompletion();
|
|
23
|
+
//get the completions from all scopes for this file
|
|
24
|
+
let completionResults = [];
|
|
25
|
+
let globalResults = [];
|
|
26
|
+
if ((0, reflection_1.isXmlFile)(file)) {
|
|
27
|
+
completionResults = this.getXmlFileCompletions(this.event.position, file);
|
|
28
|
+
}
|
|
29
|
+
else if ((0, reflection_1.isBrsFile)(file)) {
|
|
30
|
+
//handle script import completions
|
|
31
|
+
let scriptImport = util_1.util.getScriptImportAtPosition(file.ownScriptImports, this.event.position);
|
|
32
|
+
if (scriptImport) {
|
|
33
|
+
this.event.completions.push(...this.getScriptImportCompletions(file.program, file.pkgPath, scriptImport));
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
const results = this.getBrsFileCompletions(this.event.position, file, scopesToProcess);
|
|
37
|
+
completionResults = results.scoped;
|
|
38
|
+
globalResults = results.global;
|
|
39
|
+
}
|
|
40
|
+
//push any global results to the completions array
|
|
41
|
+
this.event.completions.push(...globalResults);
|
|
42
|
+
//only keep completions common to every scope for this file (the global results are not considered in this filter and will always be included)
|
|
43
|
+
let allCompletions = completionResults.flat();
|
|
44
|
+
let keyCounts = new Map();
|
|
45
|
+
for (let completion of allCompletions) {
|
|
46
|
+
let key = `${completion.label}-${completion.kind}`;
|
|
47
|
+
keyCounts.set(key, keyCounts.has(key) ? keyCounts.get(key) + 1 : 1);
|
|
48
|
+
if (keyCounts.get(key) === scopesToProcess.length) {
|
|
49
|
+
this.event.completions.push(completion);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
getScopesForCompletion() {
|
|
55
|
+
var _a;
|
|
56
|
+
//the scopes for this file
|
|
57
|
+
let scopesForFile = (_a = this.event.scopes) !== null && _a !== void 0 ? _a : [];
|
|
58
|
+
// //if there are no scopes, include the global scope so we at least get the built-in functions
|
|
59
|
+
// if (this.event.program) {
|
|
60
|
+
// scopesForFile = scopesForFile.length > 0 ? scopesForFile : [];
|
|
61
|
+
// }
|
|
62
|
+
// Only process the first few scopes. This might result in missing completions,
|
|
63
|
+
// but it's better than wasting TONS of cycles building essentially the same completions over and over
|
|
64
|
+
const scopesToProcess = scopesForFile.slice(0, SCOPES_FOR_COMPLETION);
|
|
65
|
+
// always include the source scope if applicable to this file
|
|
66
|
+
let sourceScope = scopesForFile.find(x => x.name === 'source');
|
|
67
|
+
if (sourceScope && !scopesToProcess.includes(sourceScope)) {
|
|
68
|
+
//replace the first scope with the source scope so we process a consistent number of scopes if possible
|
|
69
|
+
scopesToProcess[0] = sourceScope;
|
|
70
|
+
}
|
|
71
|
+
return scopesToProcess;
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* Get all available completions for the specified position
|
|
75
|
+
* @param position the position to get completions
|
|
76
|
+
*/
|
|
77
|
+
getXmlFileCompletions(position, file) {
|
|
78
|
+
let scriptImport = util_1.util.getScriptImportAtPosition(file.scriptTagImports, position);
|
|
79
|
+
if (scriptImport) {
|
|
80
|
+
return this.getScriptImportCompletions(file.program, file.pkgPath, scriptImport);
|
|
81
|
+
}
|
|
82
|
+
else {
|
|
83
|
+
return [];
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* Get a list of all script imports, relative to the specified pkgPath
|
|
88
|
+
* @param program - reference to the program
|
|
89
|
+
* @param sourcePkgPath - the pkgPath of the source that wants to resolve script imports
|
|
90
|
+
* @param scriptImport - example script import
|
|
91
|
+
*/
|
|
92
|
+
getScriptImportCompletions(program, sourcePkgPath, scriptImport) {
|
|
93
|
+
let lowerSourcePkgPath = sourcePkgPath.toLowerCase();
|
|
94
|
+
let result = [];
|
|
95
|
+
/**
|
|
96
|
+
* hashtable to prevent duplicate results
|
|
97
|
+
*/
|
|
98
|
+
let resultPkgPaths = {};
|
|
99
|
+
//restrict to only .brs files
|
|
100
|
+
for (let key in program.files) {
|
|
101
|
+
let file = program.files[key];
|
|
102
|
+
const ext = util_1.util.getExtension(file.srcPath);
|
|
103
|
+
if (
|
|
104
|
+
//is a BrightScript or BrighterScript file
|
|
105
|
+
(ext === '.bs' || ext === '.brs') &&
|
|
106
|
+
//this file is not the current file
|
|
107
|
+
lowerSourcePkgPath !== file.pkgPath.toLowerCase()) {
|
|
108
|
+
//add the relative path
|
|
109
|
+
let relativePath = util_1.util.getRelativePath(sourcePkgPath, file.destPath).replace(/\\/g, '/');
|
|
110
|
+
let pkgPathStandardized = file.pkgPath.replace(/\\/g, '/');
|
|
111
|
+
let filePkgPath = `pkg:/${pkgPathStandardized}`;
|
|
112
|
+
let importPkgPath = util_1.util.getImportPackagePath(file.srcPath, filePkgPath);
|
|
113
|
+
let lowerFilePkgPath = filePkgPath.toLowerCase();
|
|
114
|
+
if (!resultPkgPaths[lowerFilePkgPath]) {
|
|
115
|
+
resultPkgPaths[lowerFilePkgPath] = true;
|
|
116
|
+
result.push({
|
|
117
|
+
label: relativePath,
|
|
118
|
+
detail: file.srcPath,
|
|
119
|
+
kind: vscode_languageserver_1.CompletionItemKind.File,
|
|
120
|
+
textEdit: {
|
|
121
|
+
newText: relativePath,
|
|
122
|
+
range: scriptImport.filePathRange
|
|
123
|
+
}
|
|
124
|
+
});
|
|
125
|
+
//add the absolute path
|
|
126
|
+
result.push({
|
|
127
|
+
label: importPkgPath,
|
|
128
|
+
detail: file.srcPath,
|
|
129
|
+
kind: vscode_languageserver_1.CompletionItemKind.File,
|
|
130
|
+
textEdit: {
|
|
131
|
+
newText: importPkgPath,
|
|
132
|
+
range: scriptImport.filePathRange
|
|
133
|
+
}
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
return result;
|
|
139
|
+
}
|
|
140
|
+
/**
|
|
141
|
+
* Get completions available at the given cursor. This aggregates all values from this file and the current scope.
|
|
142
|
+
*/
|
|
143
|
+
getBrsFileCompletions(position, file, scopesToProcess) {
|
|
144
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
|
|
145
|
+
let result = [];
|
|
146
|
+
const currentTokenByFilePosition = file.getTokenAt(position);
|
|
147
|
+
const currentToken = currentTokenByFilePosition !== null && currentTokenByFilePosition !== void 0 ? currentTokenByFilePosition : file.getTokenAt((_b = (_a = file.getClosestExpression(position)) === null || _a === void 0 ? void 0 : _a.location) === null || _b === void 0 ? void 0 : _b.range.start);
|
|
148
|
+
const emptyResult = { global: [], scoped: [] };
|
|
149
|
+
if (!currentToken) {
|
|
150
|
+
return emptyResult;
|
|
151
|
+
}
|
|
152
|
+
const tokenKind = currentToken === null || currentToken === void 0 ? void 0 : currentToken.kind;
|
|
153
|
+
//if cursor is after a comment, disable completions
|
|
154
|
+
if (this.isPositionInComment(file, position)) {
|
|
155
|
+
return emptyResult;
|
|
156
|
+
}
|
|
157
|
+
let expression;
|
|
158
|
+
let shouldLookForMembers = false;
|
|
159
|
+
let shouldLookForCallFuncMembers = false;
|
|
160
|
+
let symbolTableLookupFlag = 1 /* SymbolTypeFlag.runtime */;
|
|
161
|
+
let beforeDotToken;
|
|
162
|
+
if (file.tokenFollows(currentToken, TokenKind_1.TokenKind.Goto)) {
|
|
163
|
+
let functionScope = file.getFunctionScopeAtPosition(position);
|
|
164
|
+
return { global: [], scoped: this.getLabelCompletion(functionScope) };
|
|
165
|
+
}
|
|
166
|
+
if (this.isTokenAdjacentTo(file, currentToken, TokenKind_1.TokenKind.Dot)) {
|
|
167
|
+
const dotToken = this.getAdjacentToken(file, currentToken, TokenKind_1.TokenKind.Dot);
|
|
168
|
+
beforeDotToken = file.getTokenBefore(dotToken);
|
|
169
|
+
expression = file.getClosestExpression((_c = beforeDotToken === null || beforeDotToken === void 0 ? void 0 : beforeDotToken.location) === null || _c === void 0 ? void 0 : _c.range.end);
|
|
170
|
+
shouldLookForMembers = true;
|
|
171
|
+
}
|
|
172
|
+
else if (this.isTokenAdjacentTo(file, currentToken, TokenKind_1.TokenKind.Callfunc)) {
|
|
173
|
+
const dotToken = this.getAdjacentToken(file, currentToken, TokenKind_1.TokenKind.Callfunc);
|
|
174
|
+
beforeDotToken = file.getTokenBefore(dotToken);
|
|
175
|
+
expression = file.getClosestExpression((_d = beforeDotToken === null || beforeDotToken === void 0 ? void 0 : beforeDotToken.location) === null || _d === void 0 ? void 0 : _d.range.end);
|
|
176
|
+
shouldLookForCallFuncMembers = true;
|
|
177
|
+
}
|
|
178
|
+
else if (this.isTokenAdjacentTo(file, currentToken, TokenKind_1.TokenKind.As)) {
|
|
179
|
+
if (file.parseMode === Parser_1.ParseMode.BrightScript) {
|
|
180
|
+
return { global: exports.NativeTypeCompletions, scoped: [] };
|
|
181
|
+
}
|
|
182
|
+
expression = file.getClosestExpression(this.event.position);
|
|
183
|
+
symbolTableLookupFlag = 2 /* SymbolTypeFlag.typetime */;
|
|
184
|
+
}
|
|
185
|
+
else if (this.isTokenAdjacentTo(file, currentToken, TokenKind_1.TokenKind.Equal)) {
|
|
186
|
+
expression = file.getClosestExpression(this.event.position);
|
|
187
|
+
if (expression === null || expression === void 0 ? void 0 : expression.findAncestor(reflection_1.isAliasStatement)) {
|
|
188
|
+
// allow runtime and typetime lookups in alias statements
|
|
189
|
+
// eslint-disable-next-line no-bitwise
|
|
190
|
+
symbolTableLookupFlag = 1 /* SymbolTypeFlag.runtime */ | 2 /* SymbolTypeFlag.typetime */;
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
else {
|
|
194
|
+
expression = file.getClosestExpression(this.event.position);
|
|
195
|
+
}
|
|
196
|
+
if ((0, reflection_1.isFunctionExpression)(expression)) {
|
|
197
|
+
// if completion is the last character of the function, use the completions of the body of the function
|
|
198
|
+
expression = expression.body;
|
|
199
|
+
}
|
|
200
|
+
if (!expression) {
|
|
201
|
+
return emptyResult;
|
|
202
|
+
}
|
|
203
|
+
const tokenBefore = file.getTokenBefore(file.getClosestToken((_f = (_e = expression.location) === null || _e === void 0 ? void 0 : _e.range) === null || _f === void 0 ? void 0 : _f.start));
|
|
204
|
+
// helper to check get correct symbol tables for look ups
|
|
205
|
+
function getSymbolTableForLookups() {
|
|
206
|
+
if (shouldLookForMembers) {
|
|
207
|
+
let type = expression.getType({ flags: 1 /* SymbolTypeFlag.runtime */ });
|
|
208
|
+
if ((0, reflection_1.isEnumType)(type) && !(0, reflection_1.isEnumType)(expression.getType({ flags: 2 /* SymbolTypeFlag.typetime */ }))) {
|
|
209
|
+
// enum members are registered in the symbol table as enum type
|
|
210
|
+
// an enum type should ONLY use the enum type's members when called directly
|
|
211
|
+
// since this is not a typetime enum, the actual type is actually an enum member!
|
|
212
|
+
type = type.defaultMemberType;
|
|
213
|
+
}
|
|
214
|
+
// Make sure built in interfaces are added.
|
|
215
|
+
if (type.isResolvable()) {
|
|
216
|
+
type.addBuiltInInterfaces();
|
|
217
|
+
}
|
|
218
|
+
return type === null || type === void 0 ? void 0 : type.getMemberTable();
|
|
219
|
+
}
|
|
220
|
+
else if (shouldLookForCallFuncMembers) {
|
|
221
|
+
let type = expression.getType({ flags: 1 /* SymbolTypeFlag.runtime */ });
|
|
222
|
+
if ((0, reflection_1.isComponentType)(type)) {
|
|
223
|
+
// it's a component and you're doing a callFunc - only let it do functions from that table
|
|
224
|
+
return type.getCallFuncTable();
|
|
225
|
+
}
|
|
226
|
+
// this is not a component type - there should be no callfunc members
|
|
227
|
+
return undefined;
|
|
228
|
+
}
|
|
229
|
+
const symbolTableToUse = expression.getSymbolTable();
|
|
230
|
+
return symbolTableToUse;
|
|
231
|
+
}
|
|
232
|
+
const areMembers = (shouldLookForMembers || shouldLookForCallFuncMembers);
|
|
233
|
+
const notMembers = !areMembers;
|
|
234
|
+
const isAfterNew = (tokenBefore === null || tokenBefore === void 0 ? void 0 : tokenBefore.kind) === TokenKind_1.TokenKind.New;
|
|
235
|
+
const shouldLookInNamespace = notMembers && expression.findAncestor(reflection_1.isNamespaceStatement);
|
|
236
|
+
const containingClassStmt = expression.findAncestor(reflection_1.isClassStatement);
|
|
237
|
+
const containingNamespace = expression.findAncestor(reflection_1.isNamespaceStatement);
|
|
238
|
+
const containingNamespaceName = containingNamespace === null || containingNamespace === void 0 ? void 0 : containingNamespace.getName(Parser_1.ParseMode.BrighterScript);
|
|
239
|
+
const containingFunctionExpression = expression.findAncestor(reflection_1.isFunctionExpression);
|
|
240
|
+
const tokenIsLiteralString = (tokenKind === TokenKind_1.TokenKind.StringLiteral || tokenKind === TokenKind_1.TokenKind.TemplateStringQuasi);
|
|
241
|
+
const globalCompletions = [];
|
|
242
|
+
if (!tokenIsLiteralString && notMembers && !isAfterNew && ((_g = this.event.program) === null || _g === void 0 ? void 0 : _g.globalScope)) {
|
|
243
|
+
let globalSymbols = (_h = this.event.program.globalScope.symbolTable.getAllSymbols(symbolTableLookupFlag)) !== null && _h !== void 0 ? _h : [];
|
|
244
|
+
if (symbolTableLookupFlag === 1 /* SymbolTypeFlag.runtime */) {
|
|
245
|
+
globalSymbols.push(...this.getGlobalValues());
|
|
246
|
+
}
|
|
247
|
+
globalCompletions.push(...this.getSymbolsCompletion(globalSymbols));
|
|
248
|
+
}
|
|
249
|
+
for (const scope of scopesToProcess) {
|
|
250
|
+
if (tokenKind === TokenKind_1.TokenKind.StringLiteral || tokenKind === TokenKind_1.TokenKind.TemplateStringQuasi) {
|
|
251
|
+
result.push(...this.getStringLiteralCompletions(scope, currentToken));
|
|
252
|
+
continue;
|
|
253
|
+
}
|
|
254
|
+
scope.linkSymbolTable();
|
|
255
|
+
const symbolTable = getSymbolTableForLookups();
|
|
256
|
+
let currentSymbols = [];
|
|
257
|
+
if (areMembers) {
|
|
258
|
+
currentSymbols = (_j = symbolTable === null || symbolTable === void 0 ? void 0 : symbolTable.getAllSymbols(symbolTableLookupFlag)) !== null && _j !== void 0 ? _j : [];
|
|
259
|
+
const tokenType = expression.getType({ flags: 1 /* SymbolTypeFlag.runtime */ });
|
|
260
|
+
if ((0, reflection_1.isClassType)(tokenType)) {
|
|
261
|
+
currentSymbols = currentSymbols.filter((symbol) => {
|
|
262
|
+
if (symbol.name === 'new') {
|
|
263
|
+
// don't return the constructor as a property
|
|
264
|
+
return false;
|
|
265
|
+
}
|
|
266
|
+
return this.isMemberAccessible(scope, symbol, containingClassStmt, containingNamespaceName);
|
|
267
|
+
});
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
else {
|
|
271
|
+
currentSymbols = (_k = symbolTable === null || symbolTable === void 0 ? void 0 : symbolTable.getOwnSymbols(symbolTableLookupFlag)) !== null && _k !== void 0 ? _k : [];
|
|
272
|
+
if (containingFunctionExpression) {
|
|
273
|
+
if (symbolTable !== containingFunctionExpression.body.symbolTable) {
|
|
274
|
+
// this is a pocket table - get all symbols defined in full function
|
|
275
|
+
currentSymbols.push(...containingFunctionExpression.body.getSymbolTable().getOwnSymbols(symbolTableLookupFlag));
|
|
276
|
+
}
|
|
277
|
+
currentSymbols.push(...containingFunctionExpression.getSymbolTable().getOwnSymbols(symbolTableLookupFlag));
|
|
278
|
+
}
|
|
279
|
+
if (shouldLookInNamespace) {
|
|
280
|
+
const nsNameParts = shouldLookInNamespace.getNameParts();
|
|
281
|
+
let nameSpaceTypeSofar;
|
|
282
|
+
let nsNameLookupTable = scope.symbolTable;
|
|
283
|
+
for (const namePart of nsNameParts) {
|
|
284
|
+
nameSpaceTypeSofar = nsNameLookupTable === null || nsNameLookupTable === void 0 ? void 0 : nsNameLookupTable.getSymbolType(namePart.text, { flags: symbolTableLookupFlag });
|
|
285
|
+
if ((0, reflection_1.isNamespaceType)(nameSpaceTypeSofar)) {
|
|
286
|
+
nsNameLookupTable = nameSpaceTypeSofar.getMemberTable();
|
|
287
|
+
}
|
|
288
|
+
else {
|
|
289
|
+
break;
|
|
290
|
+
}
|
|
291
|
+
}
|
|
292
|
+
if ((0, reflection_1.isNamespaceType)(nameSpaceTypeSofar)) {
|
|
293
|
+
currentSymbols.push(...nameSpaceTypeSofar.getMemberTable().getAllSymbols(symbolTableLookupFlag));
|
|
294
|
+
}
|
|
295
|
+
}
|
|
296
|
+
currentSymbols.push(...this.getScopeSymbolCompletions(file, scope, symbolTableLookupFlag));
|
|
297
|
+
}
|
|
298
|
+
let ignoreAllPropertyNames = false;
|
|
299
|
+
if (isAfterNew) {
|
|
300
|
+
//we are after a new keyword; so we can only be namespaces that have a class or classes at this point
|
|
301
|
+
currentSymbols = currentSymbols.filter(symbol => (0, reflection_1.isClassType)(symbol.type) || this.isNamespaceTypeWithMemberType(symbol.type, reflection_1.isClassType));
|
|
302
|
+
ignoreAllPropertyNames = true;
|
|
303
|
+
}
|
|
304
|
+
result.push(...this.getSymbolsCompletion(currentSymbols, areMembers));
|
|
305
|
+
if (shouldLookForMembers && currentSymbols.length === 0 && !ignoreAllPropertyNames) {
|
|
306
|
+
// could not find members of actual known types.. just try everything
|
|
307
|
+
result.push(...this.getPropertyNameCompletions(scope), ...this.getAllClassMemberCompletions(scope).values());
|
|
308
|
+
}
|
|
309
|
+
else if (shouldLookForCallFuncMembers && currentSymbols.length === 0) {
|
|
310
|
+
// could not find members of actual known types.. just try everything
|
|
311
|
+
result.push(...this.getCallFuncNameCompletions(scope));
|
|
312
|
+
}
|
|
313
|
+
scope.unlinkSymbolTable();
|
|
314
|
+
}
|
|
315
|
+
return { global: globalCompletions, scoped: result };
|
|
316
|
+
}
|
|
317
|
+
getScopeSymbolCompletions(file, scope, symbolTableLookupFlag) {
|
|
318
|
+
// get all scope available symbols
|
|
319
|
+
const scopeSymbols = file.parseMode === Parser_1.ParseMode.BrighterScript
|
|
320
|
+
? [...scope.symbolTable.getOwnSymbols(symbolTableLookupFlag), ...scope.allNamespaceTypeTable.getOwnSymbols(symbolTableLookupFlag)]
|
|
321
|
+
: scope.symbolTable.getOwnSymbols(symbolTableLookupFlag);
|
|
322
|
+
const fileSymbols = file.ast.getSymbolTable().getOwnSymbols(symbolTableLookupFlag);
|
|
323
|
+
scopeSymbols.push(...fileSymbols);
|
|
324
|
+
const scopeAvailableSymbols = scopeSymbols.filter(sym => {
|
|
325
|
+
if (file.parseMode === Parser_1.ParseMode.BrighterScript) {
|
|
326
|
+
// eslint-disable-next-line no-bitwise
|
|
327
|
+
if (sym.flags & 32 /* SymbolTypeFlag.postTranspile */) {
|
|
328
|
+
// underscored symbols should not be available in Brighterscript files
|
|
329
|
+
return false;
|
|
330
|
+
}
|
|
331
|
+
}
|
|
332
|
+
else if (file.parseMode === Parser_1.ParseMode.BrightScript) {
|
|
333
|
+
if ((0, reflection_1.isNamespaceType)(sym.type)) {
|
|
334
|
+
return false;
|
|
335
|
+
}
|
|
336
|
+
}
|
|
337
|
+
return true;
|
|
338
|
+
});
|
|
339
|
+
return scopeAvailableSymbols;
|
|
340
|
+
}
|
|
341
|
+
getSymbolsCompletion(symbols, areMembers = false) {
|
|
342
|
+
return symbols.map(symbol => {
|
|
343
|
+
var _a, _b, _c;
|
|
344
|
+
// if this is low priority, sort it at the end of the list
|
|
345
|
+
const sortText = ((_a = symbol.data) === null || _a === void 0 ? void 0 : _a.completionPriority) ? 'z'.repeat((_b = symbol.data) === null || _b === void 0 ? void 0 : _b.completionPriority) + symbol.name : undefined;
|
|
346
|
+
return {
|
|
347
|
+
label: symbol.name,
|
|
348
|
+
kind: this.getCompletionKindFromSymbol(symbol, areMembers),
|
|
349
|
+
detail: (_c = symbol === null || symbol === void 0 ? void 0 : symbol.type) === null || _c === void 0 ? void 0 : _c.toString(),
|
|
350
|
+
documentation: this.getDocumentation(symbol),
|
|
351
|
+
sortText: sortText
|
|
352
|
+
};
|
|
353
|
+
});
|
|
354
|
+
}
|
|
355
|
+
getDocumentation(symbol) {
|
|
356
|
+
var _a, _b, _c;
|
|
357
|
+
if ((_a = symbol.data) === null || _a === void 0 ? void 0 : _a.description) {
|
|
358
|
+
return (_b = symbol.data) === null || _b === void 0 ? void 0 : _b.description;
|
|
359
|
+
}
|
|
360
|
+
return util_1.util.getNodeDocumentation((_c = symbol.data) === null || _c === void 0 ? void 0 : _c.definingNode);
|
|
361
|
+
}
|
|
362
|
+
getCompletionKindFromSymbol(symbol, areMembers = false) {
|
|
363
|
+
var _a;
|
|
364
|
+
let type = symbol === null || symbol === void 0 ? void 0 : symbol.type;
|
|
365
|
+
if ((0, reflection_1.isTypeStatementType)(type)) {
|
|
366
|
+
type = type.wrappedType;
|
|
367
|
+
}
|
|
368
|
+
const extraData = symbol === null || symbol === void 0 ? void 0 : symbol.data;
|
|
369
|
+
let definingNode = extraData === null || extraData === void 0 ? void 0 : extraData.definingNode;
|
|
370
|
+
let isAlias = extraData === null || extraData === void 0 ? void 0 : extraData.isAlias;
|
|
371
|
+
let isInstance = extraData === null || extraData === void 0 ? void 0 : extraData.isInstance;
|
|
372
|
+
if ((0, reflection_1.isAliasStatement)(extraData === null || extraData === void 0 ? void 0 : extraData.definingNode)) {
|
|
373
|
+
isAlias = true;
|
|
374
|
+
const aliasExtraData = {};
|
|
375
|
+
type = extraData.definingNode.value.getType({ flags: symbol.flags, data: aliasExtraData });
|
|
376
|
+
definingNode = aliasExtraData === null || aliasExtraData === void 0 ? void 0 : aliasExtraData.definingNode;
|
|
377
|
+
}
|
|
378
|
+
if ((0, reflection_1.isConstStatement)(definingNode)) {
|
|
379
|
+
return vscode_languageserver_1.CompletionItemKind.Constant;
|
|
380
|
+
}
|
|
381
|
+
else if ((0, reflection_1.isClassType)(type) && !isInstance) {
|
|
382
|
+
return vscode_languageserver_1.CompletionItemKind.Class;
|
|
383
|
+
}
|
|
384
|
+
else if ((0, reflection_1.isCallableType)(type)) {
|
|
385
|
+
const finalTypeNameLower = type === null || type === void 0 ? void 0 : type.toString().split('.').pop().toLowerCase();
|
|
386
|
+
const symbolNameLower = symbol === null || symbol === void 0 ? void 0 : symbol.name.toLowerCase();
|
|
387
|
+
let nameMatchesType = symbolNameLower === finalTypeNameLower;
|
|
388
|
+
if ((0, reflection_1.isTypedFunctionType)(type) && !nameMatchesType) {
|
|
389
|
+
if (symbolNameLower === ((_a = type.name) === null || _a === void 0 ? void 0 : _a.replace(/\./gi, '_').toLowerCase())) {
|
|
390
|
+
nameMatchesType = true;
|
|
391
|
+
}
|
|
392
|
+
}
|
|
393
|
+
if (nameMatchesType || isAlias) {
|
|
394
|
+
return areMembers ? vscode_languageserver_1.CompletionItemKind.Method : vscode_languageserver_1.CompletionItemKind.Function;
|
|
395
|
+
}
|
|
396
|
+
}
|
|
397
|
+
else if ((0, reflection_1.isInterfaceType)(type) && !isInstance) {
|
|
398
|
+
return vscode_languageserver_1.CompletionItemKind.Interface;
|
|
399
|
+
}
|
|
400
|
+
else if ((0, reflection_1.isEnumType)(type) && !isInstance) {
|
|
401
|
+
return vscode_languageserver_1.CompletionItemKind.Enum;
|
|
402
|
+
}
|
|
403
|
+
else if ((0, reflection_1.isEnumMemberType)(type)) {
|
|
404
|
+
return vscode_languageserver_1.CompletionItemKind.EnumMember;
|
|
405
|
+
}
|
|
406
|
+
else if ((0, reflection_1.isNamespaceType)(type)) {
|
|
407
|
+
return vscode_languageserver_1.CompletionItemKind.Module;
|
|
408
|
+
}
|
|
409
|
+
else if ((0, reflection_1.isComponentType)(type) && (!isInstance)) {
|
|
410
|
+
return vscode_languageserver_1.CompletionItemKind.Interface;
|
|
411
|
+
}
|
|
412
|
+
if (areMembers) {
|
|
413
|
+
return vscode_languageserver_1.CompletionItemKind.Field;
|
|
414
|
+
}
|
|
415
|
+
const lowerSymbolName = symbol.name.toLowerCase();
|
|
416
|
+
if (lowerSymbolName === 'true' ||
|
|
417
|
+
lowerSymbolName === 'false' ||
|
|
418
|
+
lowerSymbolName === 'invalid') {
|
|
419
|
+
return vscode_languageserver_1.CompletionItemKind.Value;
|
|
420
|
+
}
|
|
421
|
+
const tokenIdentifier = util_1.util.tokenToBscType((0, creators_1.createIdentifier)(symbol.name));
|
|
422
|
+
if ((0, reflection_1.isNativeType)(tokenIdentifier)) {
|
|
423
|
+
return vscode_languageserver_1.CompletionItemKind.Keyword;
|
|
424
|
+
}
|
|
425
|
+
return vscode_languageserver_1.CompletionItemKind.Variable;
|
|
426
|
+
}
|
|
427
|
+
isNamespaceTypeWithMemberType(nsType, predicate) {
|
|
428
|
+
if (!(0, reflection_1.isNamespaceType)(nsType)) {
|
|
429
|
+
return false;
|
|
430
|
+
}
|
|
431
|
+
const members = nsType.memberTable.getAllSymbols(1 /* SymbolTypeFlag.runtime */);
|
|
432
|
+
for (const member of members) {
|
|
433
|
+
if (predicate(member.type)) {
|
|
434
|
+
return true;
|
|
435
|
+
}
|
|
436
|
+
else if ((0, reflection_1.isNamespaceType)(member.type)) {
|
|
437
|
+
if (this.isNamespaceTypeWithMemberType(member.type, predicate)) {
|
|
438
|
+
return true;
|
|
439
|
+
}
|
|
440
|
+
}
|
|
441
|
+
}
|
|
442
|
+
return false;
|
|
443
|
+
}
|
|
444
|
+
isMemberAccessible(scope, member, containingClassStmt, containingNamespaceName) {
|
|
445
|
+
var _a, _b;
|
|
446
|
+
// eslint-disable-next-line no-bitwise
|
|
447
|
+
const isPrivate = member.flags & 8 /* SymbolTypeFlag.private */;
|
|
448
|
+
// eslint-disable-next-line no-bitwise
|
|
449
|
+
const isProtected = member.flags & 16 /* SymbolTypeFlag.protected */;
|
|
450
|
+
if (!containingClassStmt || !(isPrivate || isProtected)) {
|
|
451
|
+
// not in a class - no private or protected members allowed
|
|
452
|
+
return !(isPrivate || isProtected);
|
|
453
|
+
}
|
|
454
|
+
const containingClassName = containingClassStmt.getName(Parser_1.ParseMode.BrighterScript);
|
|
455
|
+
const classStmtThatDefinedMember = (_b = (_a = member.data) === null || _a === void 0 ? void 0 : _a.definingNode) === null || _b === void 0 ? void 0 : _b.findAncestor(reflection_1.isClassStatement);
|
|
456
|
+
if (isPrivate) {
|
|
457
|
+
return containingClassStmt === classStmtThatDefinedMember;
|
|
458
|
+
}
|
|
459
|
+
else if (isProtected) {
|
|
460
|
+
const ancestorClasses = scope.getClassHierarchy(containingClassName, containingNamespaceName).map(link => link.item);
|
|
461
|
+
return ancestorClasses.includes(classStmtThatDefinedMember);
|
|
462
|
+
}
|
|
463
|
+
return true;
|
|
464
|
+
}
|
|
465
|
+
getLabelCompletion(functionScope) {
|
|
466
|
+
return functionScope.labelStatements.map(label => ({
|
|
467
|
+
label: label.name,
|
|
468
|
+
kind: vscode_languageserver_1.CompletionItemKind.Reference
|
|
469
|
+
}));
|
|
470
|
+
}
|
|
471
|
+
createCompletionFromFunctionStatement(statement, completionKind = vscode_languageserver_1.CompletionItemKind.Function) {
|
|
472
|
+
const funcType = statement.getType({ flags: 1 /* SymbolTypeFlag.runtime */ });
|
|
473
|
+
return {
|
|
474
|
+
label: statement.getName(Parser_1.ParseMode.BrighterScript),
|
|
475
|
+
kind: completionKind,
|
|
476
|
+
detail: funcType.toString(),
|
|
477
|
+
documentation: util_1.util.getNodeDocumentation(statement)
|
|
478
|
+
};
|
|
479
|
+
}
|
|
480
|
+
getStringLiteralCompletions(scope, currentToken) {
|
|
481
|
+
var _a, _b, _c, _d;
|
|
482
|
+
const match = /^("?)(pkg|libpkg):/.exec(currentToken.text);
|
|
483
|
+
let result = [];
|
|
484
|
+
if (match) {
|
|
485
|
+
// Get file path locations
|
|
486
|
+
const [, openingQuote, fileProtocol] = match;
|
|
487
|
+
//include every absolute file path from this scope
|
|
488
|
+
for (const file of scope.getAllFiles()) {
|
|
489
|
+
const pkgPath = `${fileProtocol}:/${file.pkgPath.replace(/\\/g, '/')}`;
|
|
490
|
+
result.push({
|
|
491
|
+
label: pkgPath,
|
|
492
|
+
textEdit: vscode_languageserver_1.TextEdit.replace(util_1.util.createRange((_a = currentToken.location) === null || _a === void 0 ? void 0 : _a.range.start.line,
|
|
493
|
+
//+1 to step past the opening quote
|
|
494
|
+
((_b = currentToken.location) === null || _b === void 0 ? void 0 : _b.range.start.character) + (openingQuote ? 1 : 0), (_c = currentToken.location) === null || _c === void 0 ? void 0 : _c.range.end.line,
|
|
495
|
+
//-1 to exclude the closing quotemark (or the end character if there is no closing quotemark)
|
|
496
|
+
((_d = currentToken.location) === null || _d === void 0 ? void 0 : _d.range.end.character) + (currentToken.text.endsWith('"') ? -1 : 0)), pkgPath),
|
|
497
|
+
kind: vscode_languageserver_1.CompletionItemKind.File
|
|
498
|
+
});
|
|
499
|
+
}
|
|
500
|
+
return result;
|
|
501
|
+
}
|
|
502
|
+
else {
|
|
503
|
+
//do nothing. we don't want to show completions inside of strings...
|
|
504
|
+
return [];
|
|
505
|
+
}
|
|
506
|
+
}
|
|
507
|
+
/**
|
|
508
|
+
* Scan all files for property names, and return them as completions
|
|
509
|
+
*/
|
|
510
|
+
getPropertyNameCompletions(scope) {
|
|
511
|
+
let results = [];
|
|
512
|
+
scope.enumerateBrsFiles((file) => {
|
|
513
|
+
results.push(...file.propertyNameCompletions);
|
|
514
|
+
});
|
|
515
|
+
return results;
|
|
516
|
+
}
|
|
517
|
+
getAllClassMemberCompletions(scope) {
|
|
518
|
+
let results = new Map();
|
|
519
|
+
let filesSearched = new Set();
|
|
520
|
+
for (const file of scope.getAllFiles()) {
|
|
521
|
+
if ((0, reflection_1.isBrsFile)(file) && !filesSearched.has(file)) {
|
|
522
|
+
// eslint-disable-next-line @typescript-eslint/dot-notation
|
|
523
|
+
for (let cs of file['_cachedLookups'].classStatements) {
|
|
524
|
+
for (let s of [...cs.methods, ...cs.fields]) {
|
|
525
|
+
if (!results.has(s.tokens.name.text) && s.tokens.name.text.toLowerCase() !== 'new') {
|
|
526
|
+
results.set(s.tokens.name.text, {
|
|
527
|
+
label: s.tokens.name.text,
|
|
528
|
+
kind: (0, reflection_1.isMethodStatement)(s) ? vscode_languageserver_1.CompletionItemKind.Method : vscode_languageserver_1.CompletionItemKind.Field
|
|
529
|
+
});
|
|
530
|
+
}
|
|
531
|
+
}
|
|
532
|
+
}
|
|
533
|
+
}
|
|
534
|
+
filesSearched.add(file);
|
|
535
|
+
}
|
|
536
|
+
return results;
|
|
537
|
+
}
|
|
538
|
+
/**
|
|
539
|
+
* Scan all xmlScopes for call funcs
|
|
540
|
+
*/
|
|
541
|
+
getCallFuncNameCompletions(scope) {
|
|
542
|
+
let completionsArray = [];
|
|
543
|
+
let completetionsLabels = [];
|
|
544
|
+
const xmlScopes = this.event.program.getScopes().filter((s) => (0, reflection_1.isXmlScope)(s));
|
|
545
|
+
// is next to a @. callfunc invocation - must be an component interface method.
|
|
546
|
+
for (const scope of xmlScopes) {
|
|
547
|
+
let fileLinks = this.event.program.getStatementsForXmlFile(scope);
|
|
548
|
+
for (let fileLink of fileLinks) {
|
|
549
|
+
let pushItem = this.createCompletionFromFunctionStatement(fileLink.item, vscode_languageserver_1.CompletionItemKind.Method);
|
|
550
|
+
if (!completetionsLabels.includes(pushItem.label)) {
|
|
551
|
+
completetionsLabels.push(pushItem.label);
|
|
552
|
+
completionsArray.push(pushItem);
|
|
553
|
+
}
|
|
554
|
+
}
|
|
555
|
+
}
|
|
556
|
+
//no other result is possible in this case
|
|
557
|
+
return completionsArray;
|
|
558
|
+
}
|
|
559
|
+
getGlobalValues() {
|
|
560
|
+
return [
|
|
561
|
+
{
|
|
562
|
+
name: 'true',
|
|
563
|
+
type: BooleanType_1.BooleanType.instance,
|
|
564
|
+
flags: 1 /* SymbolTypeFlag.runtime */,
|
|
565
|
+
data: {}
|
|
566
|
+
},
|
|
567
|
+
{
|
|
568
|
+
name: 'false',
|
|
569
|
+
type: BooleanType_1.BooleanType.instance,
|
|
570
|
+
flags: 1 /* SymbolTypeFlag.runtime */,
|
|
571
|
+
data: {}
|
|
572
|
+
},
|
|
573
|
+
{
|
|
574
|
+
name: 'invalid',
|
|
575
|
+
type: InvalidType_1.InvalidType.instance,
|
|
576
|
+
flags: 1 /* SymbolTypeFlag.runtime */,
|
|
577
|
+
data: {}
|
|
578
|
+
}
|
|
579
|
+
];
|
|
580
|
+
}
|
|
581
|
+
isPositionInComment(file, position) {
|
|
582
|
+
var _a, _b;
|
|
583
|
+
const currentToken = file.getCurrentOrNextTokenAt(position);
|
|
584
|
+
const tokenKind = currentToken === null || currentToken === void 0 ? void 0 : currentToken.kind;
|
|
585
|
+
if (!currentToken) {
|
|
586
|
+
return true;
|
|
587
|
+
}
|
|
588
|
+
if (tokenKind === TokenKind_1.TokenKind.Comment) {
|
|
589
|
+
return true;
|
|
590
|
+
}
|
|
591
|
+
const nextNonComment = file.getNextTokenByPredicate(currentToken, (t) => !TokenKind_1.AllowedTriviaTokens.includes(t.kind), 1);
|
|
592
|
+
const firstComment = (_a = nextNonComment === null || nextNonComment === void 0 ? void 0 : nextNonComment.leadingTrivia) === null || _a === void 0 ? void 0 : _a.find(t => t.kind === TokenKind_1.TokenKind.Comment);
|
|
593
|
+
if (firstComment && util_1.util.comparePosition(position, (_b = firstComment === null || firstComment === void 0 ? void 0 : firstComment.location) === null || _b === void 0 ? void 0 : _b.range.start) >= 0) {
|
|
594
|
+
return true;
|
|
595
|
+
}
|
|
596
|
+
return false;
|
|
597
|
+
}
|
|
598
|
+
isTokenAdjacentTo(file, currentToken, targetKind) {
|
|
599
|
+
var _a;
|
|
600
|
+
return ((_a = file.getPreviousToken(currentToken)) === null || _a === void 0 ? void 0 : _a.kind) === targetKind || file.isTokenNextToTokenKind(currentToken, targetKind);
|
|
601
|
+
}
|
|
602
|
+
getAdjacentToken(file, currentToken, targetKind) {
|
|
603
|
+
return currentToken.kind === targetKind ? currentToken : file.getTokenBefore(currentToken, targetKind);
|
|
604
|
+
}
|
|
605
|
+
}
|
|
606
|
+
exports.CompletionsProcessor = CompletionsProcessor;
|
|
607
|
+
/**
|
|
608
|
+
* List of completions for all valid keywords/reserved words.
|
|
609
|
+
* Build this list once because it won't change for the lifetime of this process
|
|
610
|
+
*/
|
|
611
|
+
exports.KeywordCompletions = Object.keys(TokenKind_1.Keywords)
|
|
612
|
+
//remove any keywords with whitespace
|
|
613
|
+
.filter(x => !x.includes(' '))
|
|
614
|
+
//create completions
|
|
615
|
+
.map(x => {
|
|
616
|
+
return {
|
|
617
|
+
label: x,
|
|
618
|
+
kind: vscode_languageserver_1.CompletionItemKind.Keyword
|
|
619
|
+
};
|
|
620
|
+
});
|
|
621
|
+
/**
|
|
622
|
+
* List of completions for all valid intrinsic types.
|
|
623
|
+
* Build this list once because it won't change for the lifetime of this process
|
|
624
|
+
*/
|
|
625
|
+
exports.NativeTypeCompletions = TokenKind_1.DeclarableTypes
|
|
626
|
+
//create completions
|
|
627
|
+
.map(x => {
|
|
628
|
+
return {
|
|
629
|
+
label: x.toLowerCase(),
|
|
630
|
+
kind: vscode_languageserver_1.CompletionItemKind.Keyword
|
|
631
|
+
};
|
|
632
|
+
});
|
|
633
|
+
//# sourceMappingURL=CompletionsProcessor.js.map
|