fix(library/elaborator): missing condition
The elaborator was failing in the following higher-order constraint ctx |- (?M a) = (?M b) This constraint has solution, but the missing condition was making the elaborator to reduce this problem to ctx |- a = b That does not have a solution. Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
parent
f67b5c4d00
commit
f177c8d1ec
1 changed files with 1 additions and 1 deletions
|
@ -1354,7 +1354,7 @@ class elaborator::imp {
|
||||||
if (process_assigned_metavar(c, a, true) || process_assigned_metavar(c, b, false))
|
if (process_assigned_metavar(c, a, true) || process_assigned_metavar(c, b, false))
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
if (m_assume_injectivity && is_app(a) && is_app(b) && num_args(a) == num_args(b) && arg(a, 0) == arg(b, 0)) {
|
if (m_assume_injectivity && is_app(a) && is_app(b) && num_args(a) == num_args(b) && arg(a, 0) == arg(b, 0) && !is_metavar(arg(a, 0))) {
|
||||||
// If m_assume_injectivity is true, we apply the following rule
|
// If m_assume_injectivity is true, we apply the following rule
|
||||||
// ctx |- (f a1 a2) == (f b1 b2)
|
// ctx |- (f a1 a2) == (f b1 b2)
|
||||||
// ===>
|
// ===>
|
||||||
|
|
Loading…
Reference in a new issue