2014-11-11 20:26:26 +00:00
|
|
|
/*
|
|
|
|
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 "kernel/find_fn.h"
|
|
|
|
#include "kernel/inductive/inductive.h"
|
|
|
|
|
|
|
|
namespace lean {
|
2014-11-11 21:46:36 +00:00
|
|
|
bool has_unit_decls(environment const & env) {
|
|
|
|
auto d = env.find(name({"unit", "star"}));
|
|
|
|
if (!d)
|
|
|
|
return false;
|
|
|
|
if (length(d->get_univ_params()) != 1)
|
|
|
|
return false;
|
|
|
|
expr const & type = d->get_type();
|
|
|
|
if (!is_constant(type))
|
|
|
|
return false;
|
|
|
|
return const_name(type) == "unit";
|
|
|
|
}
|
|
|
|
|
|
|
|
bool has_eq_decls(environment const & env) {
|
|
|
|
auto d = env.find(name({"eq", "refl"}));
|
|
|
|
if (!d)
|
|
|
|
return false;
|
|
|
|
if (length(d->get_univ_params()) != 1)
|
|
|
|
return false;
|
|
|
|
expr type = d->get_type();
|
|
|
|
if (!is_pi(type) || !is_pi(binding_body(type)))
|
|
|
|
return false;
|
|
|
|
type = get_app_fn(binding_body(binding_body(type)));
|
|
|
|
if (!is_constant(type))
|
|
|
|
return false;
|
|
|
|
return const_name(type) == "eq";
|
|
|
|
}
|
|
|
|
|
|
|
|
bool has_heq_decls(environment const & env) {
|
|
|
|
auto d = env.find(name({"heq", "refl"}));
|
|
|
|
if (!d)
|
|
|
|
return false;
|
|
|
|
if (length(d->get_univ_params()) != 1)
|
|
|
|
return false;
|
|
|
|
expr type = d->get_type();
|
|
|
|
for (unsigned i = 0; i < 2; i++) {
|
|
|
|
if (!is_pi(type))
|
|
|
|
return type;
|
|
|
|
type = binding_body(type);
|
|
|
|
}
|
|
|
|
type = get_app_fn(type);
|
|
|
|
if (!is_constant(type))
|
|
|
|
return false;
|
|
|
|
return const_name(type) == "heq";
|
|
|
|
}
|
|
|
|
|
2014-11-11 20:26:26 +00:00
|
|
|
bool is_recursive_datatype(environment const & env, name const & n) {
|
|
|
|
optional<inductive::inductive_decls> decls = inductive::is_inductive_decl(env, n);
|
|
|
|
if (!decls)
|
|
|
|
return false;
|
|
|
|
for (inductive::inductive_decl const & decl : std::get<2>(*decls)) {
|
|
|
|
for (inductive::intro_rule const & intro : inductive::inductive_decl_intros(decl)) {
|
|
|
|
expr type = inductive::intro_rule_type(intro);
|
|
|
|
while (is_pi(type)) {
|
|
|
|
if (find(binding_domain(type), [&](expr const & e, unsigned) {
|
|
|
|
return is_constant(e) && const_name(e) == n; }))
|
|
|
|
return true;
|
|
|
|
type = binding_body(type);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
2014-11-11 21:24:58 +00:00
|
|
|
|
|
|
|
bool is_inductive_predicate(environment const & env, name const & n) {
|
|
|
|
if (!env.impredicative())
|
|
|
|
return false; // environment does not have Prop
|
|
|
|
if (!inductive::is_inductive_decl(env, n))
|
|
|
|
return false; // n is not inductive datatype
|
|
|
|
expr type = env.get(n).get_type();
|
|
|
|
while (is_pi(type)) {
|
|
|
|
type = binding_body(type);
|
|
|
|
}
|
|
|
|
return is_sort(type) && is_zero(sort_level(type));
|
|
|
|
}
|
2014-11-11 20:26:26 +00:00
|
|
|
}
|