Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
lwm1986
roslyn
提交
1d867101
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,发现更多精彩内容 >>
提交
1d867101
编写于
11月 07, 2016
作者:
C
CyrusNajmabadi
提交者:
GitHub
11月 07, 2016
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #14984 from CyrusNajmabadi/outVarCrash
Fix crash in 'use out-var' Fixes #14982
上级
c1118eb1
dd2885fb
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
32 addition
and
1 deletion
+32
-1
src/EditorFeatures/CSharpTest/InlineDeclaration/CSharpInlineDeclarationTests.cs
...arpTest/InlineDeclaration/CSharpInlineDeclarationTests.cs
+25
-0
src/Features/CSharp/Portable/InlineDeclaration/CSharpInlineDeclarationCodeFixProvider.cs
...lineDeclaration/CSharpInlineDeclarationCodeFixProvider.cs
+4
-1
src/Workspaces/Core/Portable/Shared/Extensions/LocationExtensions.cs
...ces/Core/Portable/Shared/Extensions/LocationExtensions.cs
+3
-0
未找到文件。
src/EditorFeatures/CSharpTest/InlineDeclaration/CSharpInlineDeclarationTests.cs
浏览文件 @
1d867101
...
...
@@ -47,6 +47,31 @@ void M()
}"
);
}
[
Fact
,
Trait
(
Traits
.
Feature
,
Traits
.
Features
.
CodeActionsInlineDeclaration
)]
public
async
Task
InlineInNestedCall
()
{
await
TestAsync
(
@"class C
{
void M()
{
[|int|] i;
if (Foo(int.TryParse(v, out i)))
{
}
}
}"
,
@"class C
{
void M()
{
if (Foo(int.TryParse(v, out int i)))
{
}
}
}"
);
}
[
Fact
,
Trait
(
Traits
.
Feature
,
Traits
.
Features
.
CodeActionsInlineDeclaration
)]
public
async
Task
InlineVariableWithConstructor1
()
{
...
...
src/Features/CSharp/Portable/InlineDeclaration/CSharpInlineDeclarationCodeFixProvider.cs
浏览文件 @
1d867101
...
...
@@ -85,9 +85,12 @@ private Task<Document> FixAsync(Document document, Diagnostic diagnostic, Cancel
var
invocationOrCreationLocation
=
diagnostic
.
AdditionalLocations
[
2
];
var
outArgumentContainingStatementLocation
=
diagnostic
.
AdditionalLocations
[
3
];
var
root
=
declaratorLocation
.
SourceTree
.
GetRoot
(
cancellationToken
);
var
declarator
=
(
VariableDeclaratorSyntax
)
declaratorLocation
.
FindNode
(
cancellationToken
);
var
identifier
=
(
IdentifierNameSyntax
)
identifierLocation
.
FindNode
(
cancellationToken
);
var
invocationOrCreation
=
(
ExpressionSyntax
)
invocationOrCreationLocation
.
FindNode
(
cancellationToken
);
var
invocationOrCreation
=
(
ExpressionSyntax
)
invocationOrCreationLocation
.
FindNode
(
getInnermostNodeForTie
:
true
,
cancellationToken
:
cancellationToken
);
var
outArgumentContainingStatement
=
(
StatementSyntax
)
outArgumentContainingStatementLocation
.
FindNode
(
cancellationToken
);
var
declaration
=
(
VariableDeclarationSyntax
)
declarator
.
Parent
;
...
...
src/Workspaces/Core/Portable/Shared/Extensions/LocationExtensions.cs
浏览文件 @
1d867101
...
...
@@ -12,6 +12,9 @@ public static SyntaxToken FindToken(this Location location, CancellationToken ca
public
static
SyntaxNode
FindNode
(
this
Location
location
,
CancellationToken
cancellationToken
)
=>
location
.
SourceTree
.
GetRoot
(
cancellationToken
).
FindNode
(
location
.
SourceSpan
);
public
static
SyntaxNode
FindNode
(
this
Location
location
,
bool
getInnermostNodeForTie
,
CancellationToken
cancellationToken
)
=>
location
.
SourceTree
.
GetRoot
(
cancellationToken
).
FindNode
(
location
.
SourceSpan
,
getInnermostNodeForTie
:
getInnermostNodeForTie
);
public
static
bool
IsVisibleSourceLocation
(
this
Location
loc
)
{
if
(!
loc
.
IsInSource
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录