Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
lwm1986
roslyn
提交
9cbb7342
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,发现更多精彩内容 >>
未验证
提交
9cbb7342
编写于
10月 23, 2019
作者:
I
Ivan Basov
提交者:
GitHub
10月 23, 2019
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Ignore await in completion when triggers completion between two dots (#39302)
上级
f64581a7
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
89 addition
and
1 deletion
+89
-1
src/EditorFeatures/CSharpTest/Completion/CompletionProviders/SymbolCompletionProviderTests.cs
...tion/CompletionProviders/SymbolCompletionProviderTests.cs
+83
-0
src/Workspaces/CSharp/Portable/Recommendations/CSharpRecommendationServiceRunner.cs
...able/Recommendations/CSharpRecommendationServiceRunner.cs
+6
-1
未找到文件。
src/EditorFeatures/CSharpTest/Completion/CompletionProviders/SymbolCompletionProviderTests.cs
浏览文件 @
9cbb7342
...
...
@@ -7178,6 +7178,89 @@ async Task<int> goo()
await
VerifyItemWithMscorlib45Async
(
markup
,
"goo"
,
description
,
"C#"
);
}
[
Fact
,
Trait
(
Traits
.
Feature
,
Traits
.
Features
.
Completion
)]
public
async
Task
AwaitableDotsLikeRangeExpression
()
{
var
markup
=
@"
using System.IO;
using System.Threading.Tasks;
namespace N
{
class C
{
async Task M()
{
var request = new Request();
var m = await request.$$.ReadAsStreamAsync();
}
}
class Request
{
public Task<Stream> ReadAsStreamAsync() => null;
}
}"
;
await
VerifyItemExistsAsync
(
markup
,
"ReadAsStreamAsync"
);
}
[
Fact
,
Trait
(
Traits
.
Feature
,
Traits
.
Features
.
Completion
)]
public
async
Task
AwaitableDotsLikeRangeExpressionWithParentheses
()
{
var
markup
=
@"
using System.IO;
using System.Threading.Tasks;
namespace N
{
class C
{
async Task M()
{
var request = new Request();
var m = (await request).$$.ReadAsStreamAsync();
}
}
class Request
{
public Task<Stream> ReadAsStreamAsync() => null;
}
}"
;
// Nothing should be found: no awaiter for request.
await
VerifyItemIsAbsentAsync
(
markup
,
"Result"
);
await
VerifyItemIsAbsentAsync
(
markup
,
"ReadAsStreamAsync"
);
}
[
Fact
,
Trait
(
Traits
.
Feature
,
Traits
.
Features
.
Completion
)]
public
async
Task
AwaitableDotsLikeRangeExpressionWithTaskAndParentheses
()
{
var
markup
=
@"
using System.IO;
using System.Threading.Tasks;
namespace N
{
class C
{
async Task M()
{
var request = new Task<Request>();
var m = (await request).$$.ReadAsStreamAsync();
}
}
class Request
{
public Task<Stream> ReadAsStreamAsync() => null;
}
}"
;
await
VerifyItemIsAbsentAsync
(
markup
,
"Result"
);
await
VerifyItemExistsAsync
(
markup
,
"ReadAsStreamAsync"
);
}
[
Fact
,
Trait
(
Traits
.
Feature
,
Traits
.
Features
.
Completion
)]
public
async
Task
ObsoleteItem
()
{
...
...
src/Workspaces/CSharp/Portable/Recommendations/CSharpRecommendationServiceRunner.cs
浏览文件 @
9cbb7342
...
...
@@ -323,7 +323,12 @@ private ImmutableArray<ISymbol> GetSymbolsOffOfName(NameSyntax name)
private
ImmutableArray
<
ISymbol
>
GetSymbolsOffOfExpression
(
ExpressionSyntax
originalExpression
)
{
var
expression
=
originalExpression
.
WalkDownParentheses
();
// In case of 'await x$$', we want to move to 'x' to get it's members.
// To run GetSymbolInfo, we also need to get rid of parenthesis.
var
expression
=
originalExpression
is
AwaitExpressionSyntax
awaitExpression
?
awaitExpression
.
Expression
.
WalkDownParentheses
()
:
originalExpression
.
WalkDownParentheses
();
var
leftHandBinding
=
_context
.
SemanticModel
.
GetSymbolInfo
(
expression
,
_cancellationToken
);
var
container
=
_context
.
SemanticModel
.
GetTypeInfo
(
expression
,
_cancellationToken
).
Type
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录