Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
lwm1986
roslyn
提交
bff51642
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,发现更多精彩内容 >>
未验证
提交
bff51642
编写于
2月 14, 2020
作者:
A
AlekseyTs
提交者:
GitHub
2月 14, 2020
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Allow structures to implement nested interfaces as we do for classes. (#41711)
Fixes #41501.
上级
0898a78e
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
36 addition
and
4 deletion
+36
-4
src/Compilers/CSharp/Portable/Symbols/Source/SourceNamedTypeSymbol_Bases.cs
...rp/Portable/Symbols/Source/SourceNamedTypeSymbol_Bases.cs
+4
-4
src/Compilers/CSharp/Test/Symbol/Symbols/TypeTests.cs
src/Compilers/CSharp/Test/Symbol/Symbols/TypeTests.cs
+32
-0
未找到文件。
src/Compilers/CSharp/Portable/Symbols/Source/SourceNamedTypeSymbol_Bases.cs
浏览文件 @
bff51642
...
@@ -571,12 +571,12 @@ private ImmutableArray<NamedTypeSymbol> MakeAcyclicInterfaces(ConsList<TypeSymbo
...
@@ -571,12 +571,12 @@ private ImmutableArray<NamedTypeSymbol> MakeAcyclicInterfaces(ConsList<TypeSymbo
}
}
var
declaredInterfaces
=
GetDeclaredInterfaces
(
basesBeingResolved
:
basesBeingResolved
);
var
declaredInterfaces
=
GetDeclaredInterfaces
(
basesBeingResolved
:
basesBeingResolved
);
bool
is
Class
=
(
typeKind
==
TypeKind
.
Class
);
bool
is
Interface
=
(
typeKind
==
TypeKind
.
Interface
);
ArrayBuilder
<
NamedTypeSymbol
>
result
=
is
Class
?
null
:
ArrayBuilder
<
NamedTypeSymbol
>.
GetInstance
()
;
ArrayBuilder
<
NamedTypeSymbol
>
result
=
is
Interface
?
ArrayBuilder
<
NamedTypeSymbol
>.
GetInstance
()
:
null
;
foreach
(
var
t
in
declaredInterfaces
)
foreach
(
var
t
in
declaredInterfaces
)
{
{
if
(
!
isClass
)
if
(
isInterface
)
{
{
if
(
BaseTypeAnalysis
.
TypeDependsOn
(
depends
:
t
,
on
:
this
))
if
(
BaseTypeAnalysis
.
TypeDependsOn
(
depends
:
t
,
on
:
this
))
{
{
...
@@ -611,7 +611,7 @@ private ImmutableArray<NamedTypeSymbol> MakeAcyclicInterfaces(ConsList<TypeSymbo
...
@@ -611,7 +611,7 @@ private ImmutableArray<NamedTypeSymbol> MakeAcyclicInterfaces(ConsList<TypeSymbo
}
}
}
}
return
is
Class
?
declaredInterfaces
:
result
.
ToImmutableAndFree
()
;
return
is
Interface
?
result
.
ToImmutableAndFree
()
:
declaredInterfaces
;
}
}
private
NamedTypeSymbol
MakeAcyclicBaseType
(
DiagnosticBag
diagnostics
)
private
NamedTypeSymbol
MakeAcyclicBaseType
(
DiagnosticBag
diagnostics
)
...
...
src/Compilers/CSharp/Test/Symbol/Symbols/TypeTests.cs
浏览文件 @
bff51642
...
@@ -2292,5 +2292,37 @@ public interface I1
...
@@ -2292,5 +2292,37 @@ public interface I1
Assert
.
True
(
i1
.
IsExplicitDefinitionOfNoPiaLocalType
);
Assert
.
True
(
i1
.
IsExplicitDefinitionOfNoPiaLocalType
);
}
}
[
Fact
]
[
WorkItem
(
41501
,
"https://github.com/dotnet/roslyn/issues/41501"
)]
public
void
ImplementNestedInterface_01
()
{
var
text
=
@"
public struct TestStruct : TestStruct.IInnerInterface
{
public interface IInnerInterface
{
}
}
"
;
var
compilation
=
CreateCompilation
(
text
);
compilation
.
VerifyDiagnostics
();
}
[
Fact
]
[
WorkItem
(
41501
,
"https://github.com/dotnet/roslyn/issues/41501"
)]
public
void
ImplementNestedInterface_02
()
{
var
text
=
@"
public class TestClass : TestClass.IInnerInterface
{
public interface IInnerInterface
{
}
}
"
;
var
compilation
=
CreateCompilation
(
text
);
compilation
.
VerifyDiagnostics
();
}
}
}
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录