Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
lwm1986
roslyn
提交
42852730
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,发现更多精彩内容 >>
未验证
提交
42852730
编写于
6月 27, 2019
作者:
J
Joey Robichaud
提交者:
GitHub
6月 27, 2019
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #36818 from mavasani/UnusedParameterFixes
Fix couple of false positives in unused parameter analyzer
上级
8b5117b4
85ef7a87
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
53 addition
and
0 deletion
+53
-0
src/EditorFeatures/CSharpTest/RemoveUnusedParametersAndValues/RemoveUnusedParametersTests.cs
...eUnusedParametersAndValues/RemoveUnusedParametersTests.cs
+13
-0
src/EditorFeatures/VisualBasicTest/RemoveUnusedParametersAndValues/RemoveUnusedParametersTests.vb
...eUnusedParametersAndValues/RemoveUnusedParametersTests.vb
+16
-0
src/Features/Core/Portable/RemoveUnusedParametersAndValues/AbstractRemoveUnusedParametersAndValuesDiagnosticAnalyzer.SymbolStartAnalyzer.cs
...ametersAndValuesDiagnosticAnalyzer.SymbolStartAnalyzer.cs
+24
-0
未找到文件。
src/EditorFeatures/CSharpTest/RemoveUnusedParametersAndValues/RemoveUnusedParametersTests.cs
浏览文件 @
42852730
...
...
@@ -1305,5 +1305,18 @@ public C(Task<IFoo> [|foo|])
public void Dispose() => foo.Result.Fooed -= fooed;
}"
,
options
);
}
[
WorkItem
(
36817
,
"https://github.com/dotnet/roslyn/issues/36817"
)]
[
Fact
,
Trait
(
Traits
.
Feature
,
Traits
.
Features
.
CodeActionsRemoveUnusedParameters
)]
public
async
Task
ParameterWithoutName_NoDiagnostic
()
{
await
TestDiagnosticMissingAsync
(
@"public class C
{
public void M[|(int )|]
{
}
}"
);
}
}
}
src/EditorFeatures/VisualBasicTest/RemoveUnusedParametersAndValues/RemoveUnusedParametersTests.vb
浏览文件 @
42852730
...
...
@@ -95,6 +95,22 @@ End Class")
$
"Class C
[|Sub M(_0 As Integer, _1 As Char, _3 As C)|]
End Sub
End Class"
)
End
Function
<
WorkItem
(
36816
,
"https://github.com/dotnet/roslyn/issues/36816"
)
>
<
Fact
,
Trait
(
Traits
.
Feature
,
Traits
.
Features
.
CodeActionsRemoveUnusedParameters
)
>
Public
Async
Function
PartialMethodParameter_NoDiagnostic
()
As
Task
Await
TestDiagnosticMissingAsync
(
$
"Class C
[|Partial Private Sub M(str As String)|]
End Sub
End Class
Partial Class C
Private Sub M(str As String)
Dim x = str.ToString()
End Sub
End Class"
)
End
Function
End
Class
...
...
src/Features/Core/Portable/RemoveUnusedParametersAndValues/AbstractRemoveUnusedParametersAndValuesDiagnosticAnalyzer.SymbolStartAnalyzer.cs
浏览文件 @
42852730
...
...
@@ -57,6 +57,12 @@ private sealed partial class SymbolStartAnalyzer
var
deserializationConstructorCheck
=
new
DeserializationConstructorCheck
(
context
.
Compilation
);
context
.
RegisterSymbolStartAction
(
symbolStartContext
=>
{
if
(
HasSyntaxErrors
((
INamedTypeSymbol
)
symbolStartContext
.
Symbol
,
symbolStartContext
.
CancellationToken
))
{
// Bail out on syntax errors.
return
;
}
// Create a new SymbolStartAnalyzer instance for every named type symbol
// to ensure there is no shared state (such as identified unused parameters within the type),
// as that would lead to duplicate diagnostics being reported from symbol end action callbacks
...
...
@@ -64,6 +70,23 @@ private sealed partial class SymbolStartAnalyzer
var
symbolAnalyzer
=
new
SymbolStartAnalyzer
(
analyzer
,
eventsArgType
,
attributeSetForMethodsToIgnore
,
deserializationConstructorCheck
);
symbolAnalyzer
.
OnSymbolStart
(
symbolStartContext
);
},
SymbolKind
.
NamedType
);
return
;
// Local functions
static
bool
HasSyntaxErrors
(
INamedTypeSymbol
namedTypeSymbol
,
CancellationToken
cancellationToken
)
{
foreach
(
var
syntaxRef
in
namedTypeSymbol
.
DeclaringSyntaxReferences
)
{
var
syntax
=
syntaxRef
.
GetSyntax
(
cancellationToken
);
if
(
syntax
.
GetDiagnostics
().
Any
(
d
=>
d
.
Severity
==
DiagnosticSeverity
.
Error
))
{
return
true
;
}
}
return
false
;
}
}
private
void
OnSymbolStart
(
SymbolStartAnalysisContext
context
)
...
...
@@ -190,6 +213,7 @@ private bool IsUnusedParameterCandidate(IParameterSymbol parameter)
method
.
IsAbstract
||
method
.
IsVirtual
||
method
.
IsOverride
||
method
.
PartialImplementationPart
!=
null
||
!
method
.
ExplicitOrImplicitInterfaceImplementations
().
IsEmpty
||
method
.
IsAccessor
()
||
method
.
IsAnonymousFunction
()
||
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录