fix(library/unifier): set conflict if type mismatch during metavariable assignment
Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
parent
5b6589709c
commit
18a883ab1b
1 changed files with 5 additions and 1 deletions
|
@ -457,8 +457,12 @@ struct unifier_fn {
|
||||||
m_subst = m_subst.assign(m, v, j);
|
m_subst = m_subst.assign(m, v, j);
|
||||||
expr m_type = mlocal_type(m);
|
expr m_type = mlocal_type(m);
|
||||||
expr v_type = m_tc.infer(v);
|
expr v_type = m_tc.infer(v);
|
||||||
if (in_conflict() || !m_tc.is_def_eq(m_type, v_type, j))
|
if (in_conflict())
|
||||||
return false;
|
return false;
|
||||||
|
if (!m_tc.is_def_eq(m_type, v_type, j)) {
|
||||||
|
set_conflict(j);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
auto it = m_mvar_occs.find(mlocal_name(m));
|
auto it = m_mvar_occs.find(mlocal_name(m));
|
||||||
if (it) {
|
if (it) {
|
||||||
cnstr_idx_set s = *it;
|
cnstr_idx_set s = *it;
|
||||||
|
|
Loading…
Reference in a new issue