|
' Licensed to the .NET Foundation under one or more agreements.
' The .NET Foundation licenses this file to you under the MIT license.
' See the LICENSE file in the project root for more information.
Imports System.Composition
Imports System.Threading
Imports Microsoft.CodeAnalysis
Imports Microsoft.CodeAnalysis.BraceCompletion
Imports Microsoft.CodeAnalysis.Host.Mef
Imports Microsoft.CodeAnalysis.Text
Imports Microsoft.CodeAnalysis.VisualBasic
Imports Microsoft.CodeAnalysis.VisualBasic.Syntax
Namespace Microsoft.CodeAnalysis.VisualBasic.BraceCompletion
<ExportBraceCompletionService(LanguageNames.VisualBasic), [Shared]>
Friend NotInheritable Class BracketBraceCompletionService
Inherits AbstractVisualBasicBraceCompletionService
<ImportingConstructor>
<Obsolete(MefConstruction.ImportingConstructorMessage, True)>
Public Sub New()
MyBase.New()
End Sub
Protected Overrides ReadOnly Property OpeningBrace As Char = Bracket.OpenCharacter
Protected Overrides ReadOnly Property ClosingBrace As Char = Bracket.CloseCharacter
Public Overrides Function AllowOverType(context As BraceCompletionContext, cancellationToken As CancellationToken) As Boolean
Return AllowOverTypeInUserCodeWithValidClosingToken(context, cancellationToken)
End Function
Protected Overrides Function IsValidOpeningBraceToken(token As SyntaxToken) As Boolean
Return token.IsKind(SyntaxKind.OpenBraceToken)
End Function
Protected Overrides Function IsValidClosingBraceToken(token As SyntaxToken) As Boolean
' Identifiers in VB can be bracketed, e.g. Dim [Dim]. The closing brace token in this case is an identifier token.
Return token.IsKind(SyntaxKind.CloseBraceToken, SyntaxKind.IdentifierToken)
End Function
Protected Overrides Function IsValidOpenBraceTokenAtPosition(text As SourceText, token As SyntaxToken, position As Integer) As Boolean
If position = token.SpanStart AndAlso
token.Kind = SyntaxKind.BadToken AndAlso
token.ToString() = Bracket.OpenCharacter Then
Return Not IsBracketInCData(token)
End If
If position < token.SpanStart Then
Return False
End If
For Each trivia In token.TrailingTrivia
Dim span = trivia.Span
If span.End < position Then
Return False
ElseIf Not span.IntersectsWith(position) OrElse
Not trivia.HasStructure Then
Continue For
End If
If TypeOf trivia.GetStructure() Is SkippedTokensTriviaSyntax Then
Return True
End If
Next
Return False
End Function
Private Shared Function IsBracketInCData(token As SyntaxToken) As Boolean
Dim skippedToken = TryCast(token.Parent, SkippedTokensTriviaSyntax)
If skippedToken Is Nothing Then
Return False
End If
Return skippedToken.ParentTrivia.Token.Kind = SyntaxKind.GreaterThanToken
End Function
End Class
End Namespace
|