Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
lwm1986
roslyn
提交
59e47d37
R
roslyn
项目概览
lwm1986
/
roslyn
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
roslyn
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
59e47d37
编写于
9月 25, 2017
作者:
R
Ravi Chande
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Add an option to disable name suggestions
上级
790aeaca
变更
8
隐藏空白更改
内联
并排
Showing
8 changed file
with
59 addition
and
4 deletion
+59
-4
src/EditorFeatures/CSharpTest/Completion/CompletionProviders/DeclarationNameCompletionProviderTests.cs
...letionProviders/DeclarationNameCompletionProviderTests.cs
+29
-4
src/Features/CSharp/Portable/Completion/CompletionProviders/DeclarationNameCompletionProvider.cs
.../CompletionProviders/DeclarationNameCompletionProvider.cs
+5
-0
src/Features/Core/Portable/Completion/CompletionOptions.cs
src/Features/Core/Portable/Completion/CompletionOptions.cs
+4
-0
src/VisualStudio/CSharp/Impl/CSharpVSResources.Designer.cs
src/VisualStudio/CSharp/Impl/CSharpVSResources.Designer.cs
+9
-0
src/VisualStudio/CSharp/Impl/CSharpVSResources.resx
src/VisualStudio/CSharp/Impl/CSharpVSResources.resx
+3
-0
src/VisualStudio/CSharp/Impl/Options/IntelliSenseOptionPageControl.xaml
...io/CSharp/Impl/Options/IntelliSenseOptionPageControl.xaml
+4
-0
src/VisualStudio/CSharp/Impl/Options/IntelliSenseOptionPageControl.xaml.cs
...CSharp/Impl/Options/IntelliSenseOptionPageControl.xaml.cs
+2
-0
src/VisualStudio/CSharp/Impl/Options/IntelliSenseOptionPageStrings.cs
...udio/CSharp/Impl/Options/IntelliSenseOptionPageStrings.cs
+3
-0
未找到文件。
src/EditorFeatures/CSharpTest/Completion/CompletionProviders/DeclarationNameCompletionProviderTests.cs
浏览文件 @
59e47d37
...
...
@@ -207,9 +207,9 @@ public class C
void Goo(StringBuilder $$) {}
}
"
;
await
VerifyItemExistsAsync
(
markup
,
"stringBuilder"
,
glyph
:
(
int
)
Glyph
.
Parameter
);
await
VerifyItemExistsAsync
(
markup
,
"@string"
,
glyph
:
(
int
)
Glyph
.
Parameter
);
await
VerifyItemExistsAsync
(
markup
,
"builder"
,
glyph
:
(
int
)
Glyph
.
Parameter
);
await
VerifyItemExistsAsync
(
markup
,
"stringBuilder"
,
glyph
:
(
int
)
Glyph
.
Parameter
);
await
VerifyItemExistsAsync
(
markup
,
"@string"
,
glyph
:
(
int
)
Glyph
.
Parameter
);
await
VerifyItemExistsAsync
(
markup
,
"builder"
,
glyph
:
(
int
)
Glyph
.
Parameter
);
}
[
WorkItem
(
19260
,
"https://github.com/dotnet/roslyn/issues/19260"
)]
...
...
@@ -223,7 +223,7 @@ public class C
void Goo(For $$) {}
}
"
;
await
VerifyItemExistsAsync
(
markup
,
"@for"
,
glyph
:
(
int
)
Glyph
.
Parameter
);
await
VerifyItemExistsAsync
(
markup
,
"@for"
,
glyph
:
(
int
)
Glyph
.
Parameter
);
}
[
WorkItem
(
19260
,
"https://github.com/dotnet/roslyn/issues/19260"
)]
...
...
@@ -626,5 +626,30 @@ void Do<T>(out T goo)
"
;
await
VerifyItemExistsAsync
(
markup
,
"test"
);
}
[
Fact
,
Trait
(
Traits
.
Feature
,
Traits
.
Features
.
Completion
)]
public
async
void
DisabledByOption
()
{
var
workspace
=
WorkspaceFixture
.
GetWorkspace
();
var
originalOptions
=
WorkspaceFixture
.
GetWorkspace
().
Options
;
try
{
workspace
.
Options
=
originalOptions
.
WithChangedOption
(
CompletionOptions
.
ShowNameSuggestions
,
LanguageNames
.
CSharp
,
false
);
var
markup
=
@"
class Test
{
Test $$
}
"
;
await
VerifyNoItemsExistAsync
(
markup
);
}
finally
{
workspace
.
Options
=
originalOptions
;
}
}
}
}
src/Features/CSharp/Portable/Completion/CompletionProviders/DeclarationNameCompletionProvider.cs
浏览文件 @
59e47d37
...
...
@@ -32,6 +32,11 @@ public override async Task ProvideCompletionsAsync(CompletionContext completionC
var
cancellationToken
=
completionContext
.
CancellationToken
;
var
semanticModel
=
await
document
.
GetSemanticModelForSpanAsync
(
new
Text
.
TextSpan
(
position
,
0
),
cancellationToken
).
ConfigureAwait
(
false
);
if
(!
completionContext
.
Options
.
GetOption
(
CompletionOptions
.
ShowNameSuggestions
,
LanguageNames
.
CSharp
))
{
return
;
}
var
context
=
CSharpSyntaxContext
.
CreateContext
(
document
.
Project
.
Solution
.
Workspace
,
semanticModel
,
position
,
cancellationToken
);
if
(
context
.
IsInNonUserCode
)
{
...
...
src/Features/Core/Portable/Completion/CompletionOptions.cs
浏览文件 @
59e47d37
...
...
@@ -37,6 +37,10 @@ internal static class CompletionOptions
nameof
(
CompletionOptions
),
nameof
(
BlockForCompletionItems
),
defaultValue
:
true
,
storageLocations
:
new
RoamingProfileStorageLocation
(
$"TextEditor.%LANGUAGE%.Specific.
{
BlockForCompletionItems
}
"
));
public
static
readonly
PerLanguageOption
<
bool
>
ShowNameSuggestions
=
new
PerLanguageOption
<
bool
>(
nameof
(
CompletionOptions
),
nameof
(
ShowNameSuggestions
),
defaultValue
:
true
,
storageLocations
:
new
RoamingProfileStorageLocation
(
"TextEditor.%LANGUAGE%.Specific.ShowNameSuggestions"
));
public
static
IEnumerable
<
PerLanguageOption
<
bool
>>
GetDev15CompletionOptions
()
{
yield
return
ShowCompletionItemFilters
;
...
...
src/VisualStudio/CSharp/Impl/CSharpVSResources.Designer.cs
浏览文件 @
59e47d37
...
...
@@ -1149,6 +1149,15 @@ internal class CSharpVSResources {
}
}
/// <summary>
/// Looks up a localized string similar to Show name s_uggestions.
/// </summary>
internal
static
string
Show_name_suggestions
{
get
{
return
ResourceManager
.
GetString
(
"Show_name_suggestions"
,
resourceCulture
);
}
}
/// <summary>
/// Looks up a localized string similar to Show preview for rename _tracking.
/// </summary>
...
...
src/VisualStudio/CSharp/Impl/CSharpVSResources.resx
浏览文件 @
59e47d37
...
...
@@ -528,4 +528,7 @@
<data
name=
"Separate_using_directive_groups"
xml:space=
"preserve"
>
<value>
Separate using directive groups
</value>
</data>
<data
name=
"Show_name_suggestions"
xml:space=
"preserve"
>
<value>
Show name s_uggestions
</value>
</data>
</root>
\ No newline at end of file
src/VisualStudio/CSharp/Impl/Options/IntelliSenseOptionPageControl.xaml
浏览文件 @
59e47d37
...
...
@@ -60,6 +60,10 @@
x:Name="Always_add_new_line_on_enter"
Content="{x:Static local:IntelliSenseOptionPageStrings.Option_Always_add_new_line_on_enter}"/>
</StackPanel>
<CheckBox x:Uid="Show_name_suggestions"
x:Name="Show_name_suggestions"
Content="{x:Static local:IntelliSenseOptionPageStrings.Option_Show_name_suggestions}" />
</StackPanel>
</GroupBox>
</StackPanel>
...
...
src/VisualStudio/CSharp/Impl/Options/IntelliSenseOptionPageControl.xaml.cs
浏览文件 @
59e47d37
...
...
@@ -29,6 +29,8 @@ public IntelliSenseOptionPageControl(IServiceProvider serviceProvider) : base(se
BindToOption
(
Never_add_new_line_on_enter
,
CompletionOptions
.
EnterKeyBehavior
,
EnterKeyRule
.
Never
,
LanguageNames
.
CSharp
);
BindToOption
(
Only_add_new_line_on_enter_with_whole_word
,
CompletionOptions
.
EnterKeyBehavior
,
EnterKeyRule
.
AfterFullyTypedWord
,
LanguageNames
.
CSharp
);
BindToOption
(
Always_add_new_line_on_enter
,
CompletionOptions
.
EnterKeyBehavior
,
EnterKeyRule
.
Always
,
LanguageNames
.
CSharp
);
BindToOption
(
Show_name_suggestions
,
CompletionOptions
.
ShowNameSuggestions
,
LanguageNames
.
CSharp
);
}
private
void
Show_completion_list_after_a_character_is_typed_Checked
(
object
sender
,
RoutedEventArgs
e
)
...
...
src/VisualStudio/CSharp/Impl/Options/IntelliSenseOptionPageStrings.cs
浏览文件 @
59e47d37
...
...
@@ -59,5 +59,8 @@ public static string Option_ShowSnippets
public
static
string
Option_Include_snippets_when_question_Tab_is_typed_after_an_identifier
=>
CSharpVSResources
.
Include_snippets_when_Tab_is_typed_after_an_identifier
;
public
static
string
Option_Show_name_suggestions
=>
CSharpVSResources
.
Show_name_suggestions
;
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录