繁体   English   中英

是否有任何 function 或工具(免费)可以自动完成 any.Net 类型名称到完全合格的名称?

[英]Is there any function or tool (free) to auto complete any .Net type name to fully qualified one?

我正在将 VB.NET 与 Visual Studio 2010 一起使用。是否有任何 function 或工具可以自动将 any.Net 类型名称完成为完全合格的名称?

我的意思是一个工具/功能,它实际上将源代码从简写更改为完全限定名称,如下所示:

StringSystem.String

Process.Start到这个System.Diagnostics.Process.Start

更新:

感谢 ReSharper 的建议。 但我不准备购买它或奖励商业产品建议。 对此感到抱歉 我应该清楚地说明我的问题。 在问这个问题之前,我已经尝试过 ReSharper。

Resharper能够做到这一点。

虽然 Resharper 不是免费的,但绝对值得购买。 一旦开始使用 Resharper,没有它您将无法继续。

下面逐步显示,因为如何做到这一点并不简单:

  1. 下载并安装 Resharper。
  2. 打开 VS 和 go 到菜单Rehsarper => Options => Languages => C# => Namespace Import Select Use fully qualified names 默认情况下Insert using directives when necessary被选中。

    在此处输入图像描述

    从现在开始,每当您使用Alt+Enter解析命名空间时,Resharper 都会解析完全限定的命名空间。

  3. Go 到Rehsarper => Options => Tools => Code cleanup 点击Add按钮添加新的清理配置文件。 为新配置文件命名,例如Namespaces Reformat 选中Optimizing using directives复选框。在此处输入图像描述

  4. 右键单击项目和 select Cleanup Code... ,或使用快捷键Ctrl+E, Ctrl+C Select 之前创建的配置文件并点击Run按钮。

    在此处输入图像描述


测试

原始代码:

using System;

namespace ConsoleApplication5
{
    class Program
    {
        static void Main(string[] args)
        {
            Console.WriteLine("Test");
        }
    }
}

结果代码:

namespace ConsoleApplication5
{
    class Program
    {
        static void Main(string[] args)
        {
            System.Console.WriteLine("Test");
        }
    }
}

这是一个适用于 C# 代码的宏。

当我在 VB.Net 项目上对其进行测试时,它不适用于程序集引用中的类型。 似乎 VB.Net 的项目代码 model 不包括外部类型。

无论如何,我在这里包含代码。 也许其他人知道如何为 VB 做


首先我们需要一个找到当前上下文的 function

Private Function FindCodeElement(ByVal caretPosition As TextPoint, ByVal elems As CodeElements) As CodeElement
    If elems Is Nothing Then Return Nothing
    Return elems.Cast(Of CodeElement) _
                .Where(Function(x) x.StartPoint.LessThan(caretPosition) AndAlso _
                                   x.EndPoint.GreaterThan(caretPosition)) _
                .Select(Function(x) If(FindCodeElement(caretPosition, GetMembers(x)), x)) _
                .FirstOrDefault()
End Function

我们还需要一个基于 using/import 语句创建所有候选名称的 function

Private Sub FindAllCandidates(ByVal elem As Object, ByVal className As String)
    If TypeOf elem Is CodeFunction Then
        FindAllCandidates(CType(elem, CodeFunction).Parent, className)
    ElseIf TypeOf elem Is CodeClass Then
        mCandidates.Add(CType(elem, CodeClass).FullName & "." & className)
        FindAllCandidates(CType(elem, CodeClass).Parent, className)
    ElseIf TypeOf elem Is CodeStruct Then
        mCandidates.Add(CType(elem, CodeStruct).FullName & "." & className)
        FindAllCandidates(CType(elem, CodeStruct).Parent, className)
    ElseIf TypeOf elem Is CodeNamespace Then
        mCandidates.Add(CType(elem, CodeNamespace).FullName & "." & className)
        For Each ns As String In CType(elem, CodeNamespace).Members.OfType(Of CodeImport) _
                                                                   .Select(Function(x) x.Namespace)
            mCandidates.Add(ns & "." & className)
        Next
        FindAllCandidates(CType(elem, CodeNamespace).Parent, className)
    ElseIf TypeOf elem Is FileCodeModel Then
        For Each ns As String In CType(elem, FileCodeModel).CodeElements.OfType(Of CodeImport) _
                                                                        .Select(Function(x) x.Namespace)
            mCandidates.Add(ns & "." & className)
        Next
    End If
End Sub

然后是一个 function 循环所有可用项目以找到其中一个候选人

Private Function FindClassInCodeElements(ByVal elems As CodeElements) As CodeElement
    If elems Is Nothing Then Return Nothing
    For Each elem As CodeElement In elems
        If IsClassType(elem) Then
            If mCandidates.Contains(elem.FullName) Then Return elem
        ElseIf TypeOf elem Is CodeNamespace Then
            For Each candidate As String In mCandidates
                If candidate.StartsWith(elem.FullName) Then
                    Dim found As CodeElement = FindClassInCodeElements(GetMembers(elem))
                    If found IsNot Nothing Then Return found
                    Exit For
                End If
            Next
        End If
    Next
    Return Nothing
End Function

两个小辅助函数

Private Function IsClassType(ByVal elem As CodeElement) As Boolean
    Return TypeOf elem Is CodeClass OrElse TypeOf elem Is CodeStruct OrElse TypeOf elem Is CodeInterface
End Function

Private Function GetMembers(ByVal elem As CodeElement) As CodeElements
    If TypeOf elem Is CodeClass Then
        Return CType(elem, CodeClass).Members
    ElseIf TypeOf elem Is CodeNamespace Then
        Return CType(elem, CodeNamespace).Members
    ElseIf TypeOf elem Is CodeStruct Then
        Return CType(elem, CodeStruct).Members
    ElseIf TypeOf elem Is CodeInterface Then
        Return CType(elem, CodeInterface).Members
    End If
    Return Nothing
End Function

然后我们可以编写主要的 function,您可以根据自己的使用方式对其进行更改。

Dim mCandidates As New HashSet(Of String)

Sub ExpandFullNameOfSelection()
    Dim selection As EnvDTE.TextSelection = CType(DTE.ActiveDocument.Selection(), EnvDTE.TextSelection)
    ' Assume type is selected
    Dim className As String = selection.Text

    ' Find current context
    Dim currentFunction As CodeElement = FindCodeElement(selection.ActivePoint, DTE.ActiveDocument.ProjectItem.FileCodeModel.CodeElements)

    mCandidates.Clear()
    FindAllCandidates(currentFunction, className)

    Dim classType As CodeElement = DTE.Solution.Projects.Cast(Of Project) _
                                                        .Where(Function(x) x.CodeModel IsNot Nothing) _
                                                        .Select(Function(x) FindClassInCodeElements(x.CodeModel.CodeElements)) _
                                                        .FirstOrDefault(Function(x) x IsNot Nothing)
    If classType IsNot Nothing Then
        selection.Text = classType.FullName ' replace with full name
    End If
End Function

JetBrains 的 ReSharper 可以通过“代码清理” function以及许多其他代码更改(例如显式类型使用而不是var等)来执行此操作。

请注意,我不是附属机构,而是 R# 的忠实粉丝。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM