Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
lwm1986
roslyn
提交
2f66a553
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,体验更适合开发者的 AI 搜索 >>
提交
2f66a553
编写于
1月 14, 2020
作者:
C
Cyrus Najmabadi
提交者:
Sam Harwell
1月 14, 2020
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Reorder conditions for clarity
上级
e83ff3ff
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
15 addition
and
13 deletion
+15
-13
src/Workspaces/CSharp/Portable/Extensions/ExpressionSyntaxExtensions.cs
.../CSharp/Portable/Extensions/ExpressionSyntaxExtensions.cs
+10
-8
src/Workspaces/VisualBasic/Portable/Extensions/ExpressionSyntaxExtensions.vb
...alBasic/Portable/Extensions/ExpressionSyntaxExtensions.vb
+5
-5
未找到文件。
src/Workspaces/CSharp/Portable/Extensions/ExpressionSyntaxExtensions.cs
浏览文件 @
2f66a553
...
...
@@ -805,12 +805,6 @@ private static bool CanReplace(ISymbol symbol)
if
(
memberAccess
.
Name
==
null
||
memberAccess
.
Expression
==
null
)
return
false
;
if
(
memberAccess
.
Expression
.
IsKind
(
SyntaxKind
.
ThisExpression
)
&&
!
SimplificationHelpers
.
ShouldSimplifyMemberAccessExpression
(
semanticModel
,
memberAccess
.
Name
,
optionSet
))
{
return
false
;
}
// if this node is annotated as being a SpecialType, let's use this information.
if
(
memberAccess
.
HasAnnotations
(
SpecialTypeAnnotation
.
Kind
))
{
...
...
@@ -824,6 +818,12 @@ private static bool CanReplace(ISymbol symbol)
return
true
;
}
if
(
memberAccess
.
Expression
.
IsKind
(
SyntaxKind
.
ThisExpression
)
&&
!
SimplificationHelpers
.
ShouldSimplifyMemberAccessExpression
(
semanticModel
,
memberAccess
.
Name
,
optionSet
))
{
return
false
;
}
// if this node is on the left side, we could simplify to aliases
if
(!
memberAccess
.
IsRightSideOfDot
())
{
...
...
@@ -1052,9 +1052,11 @@ private static bool PreferPredefinedTypeKeywordInDeclarations(NameSyntax name, O
private
static
bool
PreferPredefinedTypeKeywordInMemberAccess
(
ExpressionSyntax
expression
,
OptionSet
optionSet
,
SemanticModel
semanticModel
)
{
if
(!
SimplificationHelpers
.
PreferPredefinedTypeKeywordInMemberAccess
(
optionSet
,
semanticModel
.
Language
))
return
false
;
return
(
IsInMemberAccessContext
(
expression
)
||
InsideCrefReference
(
expression
))
&&
!
InsideNameOfExpression
(
expression
,
semanticModel
)
&&
SimplificationHelpers
.
PreferPredefinedTypeKeywordInMemberAccess
(
optionSet
,
semanticModel
.
Language
);
!
InsideNameOfExpression
(
expression
,
semanticModel
);
}
public
static
bool
IsInMemberAccessContext
(
this
ExpressionSyntax
expression
)
=>
...
...
src/Workspaces/VisualBasic/Portable/Extensions/ExpressionSyntaxExtensions.vb
浏览文件 @
2f66a553
...
...
@@ -969,11 +969,6 @@ Namespace Microsoft.CodeAnalysis.VisualBasic.Extensions
Return
False
End
If
If
memberAccess
.
Expression
.
IsKind
(
SyntaxKind
.
MeExpression
)
AndAlso
Not
SimplificationHelpers
.
ShouldSimplifyMemberAccessExpression
(
semanticModel
,
memberAccess
.
Name
,
optionSet
)
Then
Return
False
End
If
If
memberAccess
.
HasAnnotations
(
SpecialTypeAnnotation
.
Kind
)
Then
replacementNode
=
SyntaxFactory
.
PredefinedType
(
SyntaxFactory
.
Token
(
...
...
@@ -984,6 +979,11 @@ Namespace Microsoft.CodeAnalysis.VisualBasic.Extensions
Return
True
End
If
If
memberAccess
.
Expression
.
IsKind
(
SyntaxKind
.
MeExpression
)
AndAlso
Not
SimplificationHelpers
.
ShouldSimplifyMemberAccessExpression
(
semanticModel
,
memberAccess
.
Name
,
optionSet
)
Then
Return
False
End
If
If
Not
memberAccess
.
IsRightSideOfDot
()
Then
Dim
aliasReplacement
As
IAliasSymbol
=
Nothing
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录