Logic 未能对合金表达式进行类型检查
我是Alloy(规范语言)的初学者,需要在案例研究的基础上做一些进一步的工作,可以找到(代码在第5页)。相关代码:Logic 未能对合金表达式进行类型检查,logic,modeling,specifications,first-order-logic,alloy,Logic,Modeling,Specifications,First Order Logic,Alloy,我是Alloy(规范语言)的初学者,需要在案例研究的基础上做一些进一步的工作,可以找到(代码在第5页)。相关代码: open util/ordering[Time] as T0 pred Eavesdropping() { some pro:Process | some m:Protected_Msg | some t: (Time - T0/last) - T0/prev[T0/last] | let t' = T0/t.next | let t'' = T0/t'
open util/ordering[Time] as T0
pred Eavesdropping() {
some pro:Process | some m:Protected_Msg |
some t: (Time - T0/last) - T0/prev[T0/last] | let t' = T0/t.next |
let t'' = T0/t'.next | !HasReadAccess[pro,m] && (m->t in pro.knows)
&& (m.contents->t not in pro.knows) && (m.contents->t'' in
pro.knows) && IsUnique(m.contents) }
在更正了一些语法之后,我得到了这个错误消息:“这个表达式没有被类型检查”,它在
let t'=T0/t.next
中突出显示t'
。如何打字检查t'
?这里的错误是next是别名T0
引用的模块中的一个函数,因此let绑定的RHS上的表达式应该是t.T0/next
,而不是T0/t.next
。但实际上,无论如何,您都不需要T0
,因为Alloy可以确定引用的是哪个模块。因此,只要删除对T0
的所有引用,它就可以很好地编译
另一个注释:您可以删除所有这些连接符号,并使用隐式连接、书写
{ A B C }
这里的错误不是
A&&B&&C
,而是next是别名T0
引用的模块中的函数,因此let绑定的RHS上的表达式应该是t.T0/next
,而不是T0/t.next
。但实际上,无论如何,您都不需要T0
,因为Alloy可以确定引用的是哪个模块。因此,只要删除对T0
的所有引用,它就可以很好地编译
另一个注释:您可以删除所有这些连接符号,并使用隐式连接、书写
{ A B C }
而不是A&&B&&C