2015-11-12 00:11:51 +00:00
|
|
|
/*
|
|
|
|
Copyright (c) 2015 Microsoft Corporation. All rights reserved.
|
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
|
|
|
|
Author: Leonardo de Moura
|
|
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include "kernel/expr.h"
|
|
|
|
#include "library/type_context.h"
|
2015-11-18 23:41:44 +00:00
|
|
|
#include "library/io_state_stream.h"
|
2015-11-12 00:11:51 +00:00
|
|
|
|
|
|
|
namespace lean {
|
|
|
|
namespace blast {
|
|
|
|
|
|
|
|
/** \brief Generalized expressions. It is a mechanism for representing
|
|
|
|
regular expression and universe polymorphic lemmas.
|
|
|
|
|
|
|
|
A universe polymorphic lemma can be converted into a regular expression
|
|
|
|
by instantiating it with fresh universe meta-variables.
|
|
|
|
|
|
|
|
We use the abstraction to provide a uniform API to some of the actions
|
|
|
|
available in blast. */
|
|
|
|
struct gexpr {
|
|
|
|
bool m_univ_poly;
|
|
|
|
expr m_expr;
|
|
|
|
public:
|
|
|
|
gexpr(name const & n):m_univ_poly(true), m_expr(mk_constant(n)) {}
|
|
|
|
gexpr(expr const & e):m_univ_poly(false), m_expr(e) {}
|
2015-11-18 23:41:44 +00:00
|
|
|
gexpr(environment const & env, name const & n):
|
|
|
|
m_univ_poly(env.get(n).get_univ_params()), m_expr(mk_constant(n)) {}
|
2015-11-12 00:11:51 +00:00
|
|
|
|
|
|
|
bool is_universe_polymorphic() const {
|
|
|
|
return m_univ_poly;
|
|
|
|
}
|
|
|
|
|
|
|
|
/** \brief Convert generalized expression into a regular expression.
|
|
|
|
If it is universe polymorphic, we accomplish that by creating
|
|
|
|
meta-variables using \c ctx. */
|
|
|
|
expr to_expr(type_context & ctx) const;
|
|
|
|
|
|
|
|
/** \brief Similar to previous method, but uses \c mk_fresh_uref to
|
|
|
|
create fresh universe meta-variables */
|
|
|
|
expr to_expr() const;
|
2015-11-18 23:41:44 +00:00
|
|
|
|
|
|
|
friend bool operator==(gexpr const & ge1, gexpr const & ge2);
|
|
|
|
friend std::ostream const & operator<<(std::ostream const & out, gexpr const & ge);
|
2015-11-12 00:11:51 +00:00
|
|
|
};
|
2015-11-18 23:41:44 +00:00
|
|
|
|
|
|
|
bool operator==(gexpr const & ge1, gexpr const & ge2);
|
|
|
|
inline bool operator!=(gexpr const & ge1, gexpr const & ge2) { return !operator==(ge1, ge2); }
|
|
|
|
std::ostream & operator<<(std::ostream & out, gexpr const & ge);
|
|
|
|
|
2015-11-12 00:11:51 +00:00
|
|
|
}}
|