Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
lwm1986
roslyn
提交
aac94f49
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,发现更多精彩内容 >>
提交
aac94f49
编写于
4月 03, 2017
作者:
S
Sam Harwell
提交者:
GitHub
4月 03, 2017
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #18399 from MaximRouiller/master
Fix "Hide base member" code fix for constants
上级
c8cb52f3
b16c100b
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
44 addition
and
26 deletion
+44
-26
src/EditorFeatures/CSharpTest/Diagnostics/HideBase/HideBaseTests.cs
...Features/CSharpTest/Diagnostics/HideBase/HideBaseTests.cs
+40
-2
src/Features/CSharp/Portable/CodeFixes/HideBase/HideBaseCodeFixProvider.AddNewKeywordAction.cs
...s/HideBase/HideBaseCodeFixProvider.AddNewKeywordAction.cs
+4
-24
未找到文件。
src/EditorFeatures/CSharpTest/Diagnostics/HideBase/HideBaseTests.cs
浏览文件 @
aac94f49
...
...
@@ -34,7 +34,7 @@ class App : Application
class App : Application
{
public
static new
App Current { get; set; }
public
new static
App Current { get; set; }
}"
);
}
...
...
@@ -64,7 +64,7 @@ public static void Method()
class App : Application
{
public
static new
void Method()
public
new static
void Method()
{
}
}"
);
...
...
@@ -93,5 +93,43 @@ class App : Application
public new int Test;
}"
);
}
[
WorkItem
(
18391
,
"https://github.com/dotnet/roslyn/issues/18391"
)]
[
Fact
,
Trait
(
Traits
.
Feature
,
Traits
.
Features
.
CodeActionsAddNew
)]
public
async
Task
TestAddNewToConstant
()
{
await
TestInRegularAndScriptAsync
(
@"class Application
{
public const int Test = 1;
}
class App : Application
{
[|public const int Test = Application.Test + 1;|]
}"
,
@"class Application
{
public const int Test = 1;
}
class App : Application
{
public new const int Test = Application.Test + 1;
}"
);
}
[
WorkItem
(
14455
,
"https://github.com/dotnet/roslyn/issues/14455"
)]
[
Fact
,
Trait
(
Traits
.
Feature
,
Traits
.
Features
.
CodeActionsAddNew
)]
public
async
Task
TestAddNewToConstantInternalFields
()
{
await
TestInRegularAndScriptAsync
(
@"class A { internal const int i = 0; }
class B : A { [|internal const int i = 1;|] }
"
,
@"class A { internal const int i = 0; }
class B : A { internal new const int i = 1; }
"
);
}
}
}
\ No newline at end of file
src/Features/CSharp/Portable/CodeFixes/HideBase/HideBaseCodeFixProvider.AddNewKeywordAction.cs
浏览文件 @
aac94f49
...
...
@@ -4,6 +4,8 @@
using
System.Threading
;
using
Microsoft.CodeAnalysis.Formatting
;
using
Microsoft.CodeAnalysis.CSharp.Syntax
;
using
Microsoft.CodeAnalysis.Editing
;
using
Microsoft.CodeAnalysis.Shared.Extensions
;
namespace
Microsoft.CodeAnalysis.CSharp.CodeFixes.HideBase
{
...
...
@@ -34,30 +36,8 @@ protected override async Task<Document> GetChangedDocumentAsync(CancellationToke
private
SyntaxNode
GetNewNode
(
Document
document
,
SyntaxNode
node
,
CancellationToken
cancellationToken
)
{
SyntaxNode
newNode
=
null
;
var
propertyStatement
=
node
as
PropertyDeclarationSyntax
;
if
(
propertyStatement
!=
null
)
{
newNode
=
propertyStatement
.
AddModifiers
(
SyntaxFactory
.
Token
(
SyntaxKind
.
NewKeyword
))
as
SyntaxNode
;
}
var
methodStatement
=
node
as
MethodDeclarationSyntax
;
if
(
methodStatement
!=
null
)
{
newNode
=
methodStatement
.
AddModifiers
(
SyntaxFactory
.
Token
(
SyntaxKind
.
NewKeyword
));
}
var
fieldDeclaration
=
node
as
FieldDeclarationSyntax
;
if
(
fieldDeclaration
!=
null
)
{
newNode
=
fieldDeclaration
.
AddModifiers
(
SyntaxFactory
.
Token
(
SyntaxKind
.
NewKeyword
));
}
//Make sure we preserve any trivia from the original node
newNode
=
newNode
.
WithTriviaFrom
(
node
);
return
newNode
.
WithAdditionalAnnotations
(
Formatter
.
Annotation
);
var
generator
=
SyntaxGenerator
.
GetGenerator
(
_document
);
return
generator
.
WithModifiers
(
node
,
generator
.
GetModifiers
(
node
).
WithIsNew
(
true
));
}
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录