Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
dotNET Platform
fsharp
提交
9da2b33b
F
fsharp
项目概览
dotNET Platform
/
fsharp
12 个月 前同步成功
通知
0
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
F
fsharp
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
未验证
提交
9da2b33b
编写于
10月 18, 2018
作者:
D
dotnet-automerge-bot
提交者:
GitHub
10月 18, 2018
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #5792 from Microsoft/merges/master-to-dev16.0
Merge master to dev16.0
上级
e767f86e
11055119
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
28 addition
and
12 deletion
+28
-12
src/fsharp/SignatureConformance.fs
src/fsharp/SignatureConformance.fs
+28
-12
未找到文件。
src/fsharp/SignatureConformance.fs
浏览文件 @
9da2b33b
...
...
@@ -177,46 +177,62 @@ type Checker(g, amap, denv, remapInfo: SignatureRepackageInfo, checkingSig) =
|>
ListSet
.
setify
(
typeEquiv
g
)
|>
List
.
filter
(
isInterfaceTy
g
)
let
aintfs
=
flatten
aintfs
let
aintfsUser
=
flatten
aintfsUser
let
fintfs
=
flatten
fintfs
let
unimpl
=
ListSet
.
subtract
(
fun
fity
aity
->
typeAEquiv
g
aenv
aity
fity
)
fintfs
aintfs
(
unimpl
|>
List
.
forall
(
fun
ity
->
errorR
(
Error
(
FSComp
.
SR
.
DefinitionsInSigAndImplNotCompatibleMissingInterface
(
implTycon
.
TypeOrMeasureKind
.
ToString
()
,
implTycon
.
DisplayName
,
NicePrint
.
minimalStringOfType
denv
ity
),
m
));
false
))
&&
(
unimpl
|>
List
.
forall
(
fun
ity
->
let
errorMessage
=
FSComp
.
SR
.
DefinitionsInSigAndImplNotCompatibleMissingInterface
(
implTycon
.
TypeOrMeasureKind
.
ToString
()
,
implTycon
.
DisplayName
,
NicePrint
.
minimalStringOfType
denv
ity
)
errorR
(
Error
(
errorMessage
,
m
));
false
))
&&
let
aintfsUser
=
flatten
aintfsUser
let
hidden
=
ListSet
.
subtract
(
typeAEquiv
g
aenv
)
aintfsUser
fintfs
let
warningOrError
=
if
implTycon
.
IsFSharpInterfaceTycon
then
error
else
warning
hidden
|>
List
.
iter
(
fun
ity
->
warningOrError
(
InterfaceNotRevealed
(
denv
,
ity
,
implTycon
.
Range
)))
let
continueChecks
,
warningOrError
=
if
implTycon
.
IsFSharpInterfaceTycon
then
false
,
errorR
else
true
,
warning
(
hidden
|>
List
.
forall
(
fun
ity
->
warningOrError
(
InterfaceNotRevealed
(
denv
,
ity
,
implTycon
.
Range
));
continueChecks
))
&&
let
aNull
=
IsUnionTypeWithNullAsTrueValue
g
implTycon
let
fNull
=
IsUnionTypeWithNullAsTrueValue
g
sigTycon
if
aNull
&&
not
fNull
then
errorR
(
Error
(
FSComp
.
SR
.
DefinitionsInSigAndImplNotCompatibleImplementationSaysNull
(
implTycon
.
TypeOrMeasureKind
.
ToString
()
,
implTycon
.
DisplayName
),
m
))
errorR
(
Error
(
FSComp
.
SR
.
DefinitionsInSigAndImplNotCompatibleImplementationSaysNull
(
implTycon
.
TypeOrMeasureKind
.
ToString
()
,
implTycon
.
DisplayName
),
m
))
false
elif
fNull
&&
not
aNull
then
errorR
(
Error
(
FSComp
.
SR
.
DefinitionsInSigAndImplNotCompatibleSignatureSaysNull
(
implTycon
.
TypeOrMeasureKind
.
ToString
()
,
implTycon
.
DisplayName
),
m
))
errorR
(
Error
(
FSComp
.
SR
.
DefinitionsInSigAndImplNotCompatibleSignatureSaysNull
(
implTycon
.
TypeOrMeasureKind
.
ToString
()
,
implTycon
.
DisplayName
),
m
))
false
else
let
aNull2
=
TypeNullIsExtraValue
g
m
(
generalizedTyconRef
(
mkLocalTyconRef
implTycon
))
let
fNull2
=
TypeNullIsExtraValue
g
m
(
generalizedTyconRef
(
mkLocalTyconRef
implTycon
))
if
aNull2
&&
not
fNull2
then
errorR
(
Error
(
FSComp
.
SR
.
DefinitionsInSigAndImplNotCompatibleImplementationSaysNull2
(
implTycon
.
TypeOrMeasureKind
.
ToString
()
,
implTycon
.
DisplayName
),
m
))
false
elif
fNull2
&&
not
aNull2
then
errorR
(
Error
(
FSComp
.
SR
.
DefinitionsInSigAndImplNotCompatibleSignatureSaysNull2
(
implTycon
.
TypeOrMeasureKind
.
ToString
()
,
implTycon
.
DisplayName
),
m
))
false
else
let
aSealed
=
isSealedTy
g
(
generalizedTyconRef
(
mkLocalTyconRef
implTycon
))
let
fSealed
=
isSealedTy
g
(
generalizedTyconRef
(
mkLocalTyconRef
sigTycon
))
if
aSealed
&&
not
fSealed
then
if
aSealed
&&
not
fSealed
then
errorR
(
Error
(
FSComp
.
SR
.
DefinitionsInSigAndImplNotCompatibleImplementationSealed
(
implTycon
.
TypeOrMeasureKind
.
ToString
()
,
implTycon
.
DisplayName
),
m
))
if
not
aSealed
&&
fSealed
then
false
elif
not
aSealed
&&
fSealed
then
errorR
(
Error
(
FSComp
.
SR
.
DefinitionsInSigAndImplNotCompatibleImplementationIsNotSealed
(
implTycon
.
TypeOrMeasureKind
.
ToString
()
,
implTycon
.
DisplayName
),
m
))
false
else
let
aPartial
=
isAbstractTycon
implTycon
let
fPartial
=
isAbstractTycon
sigTycon
if
aPartial
&&
not
fPartial
then
errorR
(
Error
(
FSComp
.
SR
.
DefinitionsInSigAndImplNotCompatibleImplementationIsAbstract
(
implTycon
.
TypeOrMeasureKind
.
ToString
()
,
implTycon
.
DisplayName
),
m
))
if
not
aPartial
&&
fPartial
then
false
el
if
not
aPartial
&&
fPartial
then
errorR
(
Error
(
FSComp
.
SR
.
DefinitionsInSigAndImplNotCompatibleSignatureIsAbstract
(
implTycon
.
TypeOrMeasureKind
.
ToString
()
,
implTycon
.
DisplayName
),
m
))
if
not
(
typeAEquiv
g
aenv
(
superOfTycon
g
implTycon
)
(
superOfTycon
g
sigTycon
))
then
false
el
if
not
(
typeAEquiv
g
aenv
(
superOfTycon
g
implTycon
)
(
superOfTycon
g
sigTycon
))
then
errorR
(
Error
(
FSComp
.
SR
.
DefinitionsInSigAndImplNotCompatibleTypesHaveDifferentBaseTypes
(
implTycon
.
TypeOrMeasureKind
.
ToString
()
,
implTycon
.
DisplayName
),
m
))
false
else
checkTypars
m
aenv
implTypars
sigTypars
&&
checkTypeRepr
m
aenv
implTycon
sigTycon
.
TypeReprInfo
&&
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录