feat(library/unifier): add 'quick' failure

Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
Leonardo de Moura 2014-07-03 11:28:21 -07:00
parent dd96bb151b
commit c9cfb844f1
3 changed files with 44 additions and 7 deletions

View file

@ -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,

View file

@ -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)

View 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;
}