Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
lwm1986
roslyn
提交
d6d41000
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,发现更多精彩内容 >>
提交
d6d41000
编写于
6月 20, 2019
作者:
S
Sam Harwell
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Only use IFeatureServiceFactory for controlling async completion
Closes #33807
上级
bb39bc82
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
20 addition
and
54 deletion
+20
-54
src/EditorFeatures/Core/Implementation/IntelliSense/Completion/AsyncCompletionService.cs
...ntation/IntelliSense/Completion/AsyncCompletionService.cs
+2
-39
src/EditorFeatures/TestUtilities2/Intellisense/EmptyFeatureController.vb
...res/TestUtilities2/Intellisense/EmptyFeatureController.vb
+14
-0
src/EditorFeatures/TestUtilities2/Intellisense/LegacyTestState.vb
...orFeatures/TestUtilities2/Intellisense/LegacyTestState.vb
+4
-0
src/VisualStudio/IntegrationTest/TestUtilities/VisualStudioInstanceFactory.cs
...egrationTest/TestUtilities/VisualStudioInstanceFactory.cs
+0
-14
src/Workspaces/Core/Portable/Experiments/IExperimentationService.cs
...aces/Core/Portable/Experiments/IExperimentationService.cs
+0
-1
未找到文件。
src/EditorFeatures/Core/Implementation/IntelliSense/Completion/AsyncCompletionService.cs
浏览文件 @
d6d41000
...
...
@@ -35,13 +35,6 @@ internal class AsyncCompletionService : ForegroundThreadAffinitizedObject, IAsyn
private
readonly
IEnumerable
<
Lazy
<
IBraceCompletionSessionProvider
,
BraceCompletionMetadata
>>
_autoBraceCompletionChars
;
private
readonly
Dictionary
<
IContentType
,
ImmutableHashSet
<
char
>>
_autoBraceCompletionCharSet
;
/// <summary>
/// The new completion API is not checked by default - null
/// false - disabled
/// true - enabled
/// </summary>
private
bool
?
_newCompletionAPIEnabled
=
null
;
[
ImportingConstructor
]
[
Obsolete
(
MefConstruction
.
ImportingConstructorMessage
,
error
:
true
)]
public
AsyncCompletionService
(
...
...
@@ -95,40 +88,10 @@ public bool TryGetController(ITextView textView, ITextBuffer subjectBuffer, out
private
bool
UseLegacyCompletion
(
IFeatureServiceFactory
featureServiceFactory
,
ITextView
textView
,
ITextBuffer
subjectBuffer
)
{
if
(!
_newCompletionAPIEnabled
.
HasValue
)
{
int
userSetting
=
0
;
const
string
useAsyncCompletionOptionName
=
"UseAsyncCompletion"
;
if
(
textView
.
Options
.
GlobalOptions
.
IsOptionDefined
(
useAsyncCompletionOptionName
,
localScopeOnly
:
false
))
{
userSetting
=
textView
.
Options
.
GlobalOptions
.
GetOptionValue
<
int
>(
useAsyncCompletionOptionName
);
}
// The meaning of the UseAsyncCompletion option definition's values:
// -1 - user disabled async completion
// 0 - no changes from the user; check the experimentation service for whether to use async completion
// 1 - user enabled async completion
if
(
userSetting
==
1
)
{
_newCompletionAPIEnabled
=
true
;
}
else
if
(
userSetting
==
-
1
)
{
_newCompletionAPIEnabled
=
false
;
}
else
{
if
(
Workspace
.
TryGetWorkspace
(
subjectBuffer
.
AsTextContainer
(),
out
var
workspace
))
{
var
experimentationService
=
workspace
.
Services
.
GetService
<
IExperimentationService
>();
_newCompletionAPIEnabled
=
experimentationService
.
IsExperimentEnabled
(
WellKnownExperimentNames
.
CompletionAPI
)
&&
featureServiceFactory
.
GlobalFeatureService
.
IsEnabled
(
PredefinedEditorFeatureNames
.
AsyncCompletion
);
}
}
}
var
newCompletionEnabled
=
featureServiceFactory
.
GetOrCreate
(
textView
).
IsEnabled
(
PredefinedEditorFeatureNames
.
AsyncCompletion
);
// Check whether the feature flag (async completion API) is set or this feature is off.
if
(
_newCompletionAPIEnabled
==
true
||
!
subjectBuffer
.
GetFeatureOnOffOption
(
InternalFeatureOnOffOptions
.
CompletionSet
))
if
(
newCompletionEnabled
||
!
subjectBuffer
.
GetFeatureOnOffOption
(
InternalFeatureOnOffOptions
.
CompletionSet
))
{
return
false
;
}
...
...
src/EditorFeatures/TestUtilities2/Intellisense/EmptyFeatureController.vb
0 → 100644
浏览文件 @
d6d41000
' Copyright (c) Microsoft. All Rights Reserved. Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information.
Imports
Microsoft.VisualStudio.Utilities
Namespace
Microsoft.CodeAnalysis.Editor.UnitTests.IntelliSense
Friend
NotInheritable
Class
EmptyFeatureController
Implements
IFeatureController
Friend
Shared
ReadOnly
Instance
As
EmptyFeatureController
=
New
EmptyFeatureController
()
Private
Sub
New
()
End
Sub
End
Class
End
Namespace
src/EditorFeatures/TestUtilities2/Intellisense/LegacyTestState.vb
浏览文件 @
d6d41000
...
...
@@ -6,6 +6,7 @@ Imports Microsoft.CodeAnalysis.Completion
Imports
Microsoft.CodeAnalysis.Editor.CommandHandlers
Imports
Microsoft.VisualStudio.Text.Editor
Imports
Microsoft.VisualStudio.Text.Editor.Commanding.Commands
Imports
Microsoft.VisualStudio.Utilities
Imports
Roslyn.Utilities
Imports
VSCommanding
=
Microsoft
.
VisualStudio
.
Commanding
...
...
@@ -32,6 +33,9 @@ Namespace Microsoft.CodeAnalysis.Editor.UnitTests.IntelliSense
MyBase
.
New
(
workspaceElement
,
extraCompletionProviders
,
excludedTypes
,
extraExportedTypes
,
includeFormatCommandHandler
,
workspaceKind
)
Me
.
CompletionCommandHandler
=
GetExportedValue
(
Of
CompletionCommandHandler
)()
Dim
featureServiceFactory
=
GetExportedValue
(
Of
IFeatureServiceFactory
)()
featureServiceFactory
.
GlobalFeatureService
.
Disable
(
PredefinedEditorFeatureNames
.
AsyncCompletion
,
EmptyFeatureController
.
Instance
)
End
Sub
#Region "Editor Related Operations"
...
...
src/VisualStudio/IntegrationTest/TestUtilities/VisualStudioInstanceFactory.cs
浏览文件 @
d6d41000
...
...
@@ -11,7 +11,6 @@
using
System.Threading.Tasks
;
using
EnvDTE
;
using
Microsoft.VisualStudio.Setup.Configuration
;
using
Microsoft.Win32
;
using
RunTests
;
using
Process
=
System
.
Diagnostics
.
Process
;
...
...
@@ -328,19 +327,6 @@ private static Process StartNewVisualStudioProcess(string installationPath, int
// Disable background download UI to avoid toasts
Process
.
Start
(
vsRegEditExeFile
,
$"set \"
{
installationPath
}
\"
{
Settings
.
Default
.
VsRootSuffix
}
HKCU \"FeatureFlags\\Setup\\BackgroundDownload\" Value dword 0"
).
WaitForExit
();
// Remove legacy settings for controlling async completion to ensure they do not interfere
//
// 1. UseAsyncCompletion option
// 2. completionapi A/B experiment
Process
.
Start
(
vsRegEditExeFile
,
$"remove \"
{
installationPath
}
\"
{
Settings
.
Default
.
VsRootSuffix
}
HKCU \"ApplicationPrivateSettings\\WindowManagement\\Options\" UseAsyncCompletion"
).
WaitForExit
();
var
disabledFlights
=
Registry
.
GetValue
(
@"HKEY_CURRENT_USER\Software\Microsoft\VisualStudio\ABExp\LocalTest"
,
"DisabledFlights"
,
Array
.
Empty
<
string
>())
as
string
[]
??
Array
.
Empty
<
string
>();
if
(
disabledFlights
.
Any
())
{
disabledFlights
=
disabledFlights
.
Where
(
flight
=>
!
string
.
Equals
(
flight
,
"completionapi"
,
StringComparison
.
OrdinalIgnoreCase
)).
ToArray
();
Registry
.
SetValue
(
@"HKEY_CURRENT_USER\Software\Microsoft\VisualStudio\ABExp\LocalTest"
,
"DisabledFlights"
,
disabledFlights
,
RegistryValueKind
.
MultiString
);
}
// Disable text editor error reporting because it pops up a dialog. We want to either fail fast in our
// custom handler or fail silently and continue testing.
Process
.
Start
(
vsRegEditExeFile
,
$"set \"
{
installationPath
}
\"
{
Settings
.
Default
.
VsRootSuffix
}
HKCU \"Text Editor\" \"Report Exceptions\" dword 0"
).
WaitForExit
();
...
...
src/Workspaces/Core/Portable/Experiments/IExperimentationService.cs
浏览文件 @
d6d41000
...
...
@@ -27,7 +27,6 @@ public DefaultExperimentationService()
internal
static
class
WellKnownExperimentNames
{
public
const
string
RoslynOOP64bit
=
nameof
(
RoslynOOP64bit
);
public
const
string
CompletionAPI
=
nameof
(
CompletionAPI
);
public
const
string
PartialLoadMode
=
"Roslyn.PartialLoadMode"
;
public
const
string
TypeImportCompletion
=
"Roslyn.TypeImportCompletion"
;
public
const
string
TargetTypedCompletionFilter
=
"Roslyn.TargetTypedCompletionFilter"
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录