feat(library/unifier): add 'quick' failure
Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
parent
dd96bb151b
commit
c9cfb844f1
3 changed files with 44 additions and 7 deletions
|
@ -1165,13 +1165,18 @@ unifier_plugin get_noop_unifier_plugin() {
|
||||||
}
|
}
|
||||||
|
|
||||||
lazy_list<substitution> unify(std::shared_ptr<unifier_fn> u) {
|
lazy_list<substitution> unify(std::shared_ptr<unifier_fn> u) {
|
||||||
return mk_lazy_list<substitution>([=]() {
|
if (u->in_conflict()) {
|
||||||
auto s = u->next();
|
u->failure(); // make sure exception is thrown if u->m_use_exception is true
|
||||||
if (s)
|
return lazy_list<substitution>();
|
||||||
return some(mk_pair(*s, unify(u)));
|
} else {
|
||||||
else
|
return mk_lazy_list<substitution>([=]() {
|
||||||
return lazy_list<substitution>::maybe_pair();
|
auto s = u->next();
|
||||||
});
|
if (s)
|
||||||
|
return some(mk_pair(*s, unify(u)));
|
||||||
|
else
|
||||||
|
return lazy_list<substitution>::maybe_pair();
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
lazy_list<substitution> unify(environment const & env, unsigned num_cs, constraint const * cs, name_generator const & ngen,
|
lazy_list<substitution> unify(environment const & env, unsigned num_cs, constraint const * cs, name_generator const & ngen,
|
||||||
|
|
|
@ -7,3 +7,6 @@ add_test(deep_copy ${CMAKE_CURRENT_BINARY_DIR}/deep_copy)
|
||||||
add_executable(occurs occurs.cpp)
|
add_executable(occurs occurs.cpp)
|
||||||
target_link_libraries(occurs ${EXTRA_LIBS})
|
target_link_libraries(occurs ${EXTRA_LIBS})
|
||||||
add_test(occurs ${CMAKE_CURRENT_BINARY_DIR}/occurs)
|
add_test(occurs ${CMAKE_CURRENT_BINARY_DIR}/occurs)
|
||||||
|
add_executable(unifier unifier.cpp)
|
||||||
|
target_link_libraries(unifier ${EXTRA_LIBS})
|
||||||
|
add_test(unifier ${CMAKE_CURRENT_BINARY_DIR}/unifier)
|
||||||
|
|
29
src/tests/library/unifier.cpp
Normal file
29
src/tests/library/unifier.cpp
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
/*
|
||||||
|
Copyright (c) 2014 Microsoft Corporation. All rights reserved.
|
||||||
|
Released under Apache 2.0 license as described in the file LICENSE.
|
||||||
|
|
||||||
|
Author: Leonardo de Moura
|
||||||
|
*/
|
||||||
|
#include "util/test.h"
|
||||||
|
#include "library/unifier.h"
|
||||||
|
using namespace lean;
|
||||||
|
|
||||||
|
static void tst1() {
|
||||||
|
environment env;
|
||||||
|
name_generator ngen("foo");
|
||||||
|
expr A = Local("A", Type);
|
||||||
|
expr f = Local("f", A >> (A >> A));
|
||||||
|
expr a = Local("a", A);
|
||||||
|
expr b = Local("b", A);
|
||||||
|
expr m = mk_metavar("m", A);
|
||||||
|
expr t1 = f(m, m);
|
||||||
|
expr t2 = f(a, b);
|
||||||
|
auto r = unify(env, t1, t2, ngen);
|
||||||
|
lean_assert(r.is_nil());
|
||||||
|
}
|
||||||
|
|
||||||
|
int main() {
|
||||||
|
save_stack_info();
|
||||||
|
tst1();
|
||||||
|
return has_violations() ? 1 : 0;
|
||||||
|
}
|
Loading…
Reference in a new issue