我认为 Coq ideslave(也称为 Coq XML 协议)的“添加”调用一次需要一段代码,由句点 ( .
) 分隔。在大多数情况下,我仍然相信这是真的。例如,
Inductive or (A B:Prop) : Prop :=
| or_introl : A -> A \/ B
| or_intror : B -> A \/ B
where "A \/ B" := (or A B) : type_scope.
尽管这个代码块有几行,它应该由一个“添加”调用输入,因为只有最后一行有一个句点。
+
但是,当存在项目符号( 、-
、*
、{
和}
)时,情况并非如此。例如,
- intros [H _]; exact H.
应该由两个“添加”调用输入,-
在intros [H _]; exact H.
另一种情况下,
{ destruct Hl; [ right | destruct Fl | ]; assumption. }
应分三部分输入,{
、destruct Hl; [ right | destruct Fl | ]; assumption.
和}
。我在 CoqIDE 中观察到了这些行为,我认为它在内部使用了 Coq ideslave。
我的第一个问题:这些是将 .v 文件划分为块以使用“添加”调用的完整规则吗?如果不是,完整的规则是什么?
第二个问题:如果我只使用“partitioned-by-period”规则,假设我尝试{ destruct Hl; [ right | destruct Fl | ]; assumption. }
作为一个“Add”调用而不是三个调用,XML 不会立即引发错误。但是,经过几个证明步骤后,它可能会引发一个This proof is focused, but cannot be unfocused this way
从未出现在 Coq IDE 中的错误 ( ),我无法通过以下方式撤消该错误
<call val="Edit_at">
<state_id val="..."/>
</call>
如果我尝试撤消错误,Coq XML 会给出相同的错误消息。这个错误是否与将子弹作为一个块喂食有关?如果是,为什么 Coq XML 不会在我提供该块时抱怨这个?
另一个问题:我想在不久的将来尝试 SerAPI。SerAPI 是否共享相同的提供代码块的规则?
非常感谢您的帮助!