2014-07-09 08:12:36 +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
|
|
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <utility>
|
|
|
|
#include <limits>
|
2014-08-19 23:28:58 +00:00
|
|
|
#include "util/pair.h"
|
2014-07-09 08:12:36 +00:00
|
|
|
#include "util/name_map.h"
|
|
|
|
#include "util/name_set.h"
|
|
|
|
#include "util/sexpr/options.h"
|
|
|
|
#include "util/sexpr/format.h"
|
|
|
|
#include "kernel/environment.h"
|
|
|
|
#include "kernel/type_checker.h"
|
2014-10-19 15:40:56 +00:00
|
|
|
#include "frontends/lean/token_table.h"
|
2014-07-09 08:12:36 +00:00
|
|
|
|
|
|
|
namespace lean {
|
2014-10-19 15:40:56 +00:00
|
|
|
class notation_entry;
|
|
|
|
|
2014-07-09 08:12:36 +00:00
|
|
|
class pretty_fn {
|
|
|
|
public:
|
2014-11-07 15:51:40 +00:00
|
|
|
static unsigned max_bp() { return get_max_prec(); }
|
|
|
|
static unsigned inf_bp() { return std::numeric_limits<unsigned>::max(); }
|
2014-10-19 15:40:56 +00:00
|
|
|
class result {
|
|
|
|
unsigned m_lbp;
|
|
|
|
unsigned m_rbp;
|
|
|
|
format m_fmt;
|
|
|
|
public:
|
|
|
|
result():m_lbp(max_bp()), m_rbp(max_bp()) {}
|
2014-11-07 15:51:40 +00:00
|
|
|
result(format const & fmt):m_lbp(inf_bp()), m_rbp(inf_bp()), m_fmt(fmt) {}
|
2014-10-19 15:40:56 +00:00
|
|
|
result(unsigned rbp, format const & fmt):m_lbp(max_bp()), m_rbp(rbp), m_fmt(fmt) {}
|
|
|
|
result(unsigned lbp, unsigned rbp, format const & fmt):m_lbp(lbp), m_rbp(rbp), m_fmt(fmt) {}
|
|
|
|
unsigned lbp() const { return m_lbp; }
|
|
|
|
unsigned rbp() const { return m_rbp; }
|
|
|
|
format const & fmt() const { return m_fmt; }
|
|
|
|
};
|
2014-07-09 08:12:36 +00:00
|
|
|
private:
|
2014-10-19 15:40:56 +00:00
|
|
|
environment m_env;
|
|
|
|
type_checker m_tc;
|
|
|
|
token_table const & m_token_table;
|
|
|
|
unsigned m_num_steps;
|
|
|
|
unsigned m_depth;
|
|
|
|
name m_meta_prefix;
|
|
|
|
unsigned m_next_meta_idx;
|
|
|
|
name_map<name> m_purify_meta_table;
|
2014-10-30 19:45:41 +00:00
|
|
|
name_set m_purify_used_metas;
|
2014-10-19 15:40:56 +00:00
|
|
|
name_map<name> m_purify_local_table;
|
|
|
|
name_set m_purify_used_locals;
|
2014-07-09 08:12:36 +00:00
|
|
|
// cached configuration
|
2014-10-19 15:40:56 +00:00
|
|
|
options m_options;
|
|
|
|
unsigned m_indent;
|
|
|
|
unsigned m_max_depth;
|
|
|
|
unsigned m_max_steps;
|
|
|
|
bool m_implict; //!< if true show implicit arguments
|
|
|
|
bool m_unicode; //!< if true use unicode chars
|
|
|
|
bool m_coercion; //!< if true show coercions
|
2014-12-01 23:10:53 +00:00
|
|
|
bool m_num_nat_coe; //!< truen when !m_coercion && env has coercion from num -> nat
|
2014-10-19 15:40:56 +00:00
|
|
|
bool m_notation;
|
|
|
|
bool m_universes;
|
|
|
|
bool m_full_names;
|
|
|
|
bool m_private_names;
|
|
|
|
bool m_metavar_args;
|
2014-11-09 19:04:22 +00:00
|
|
|
bool m_purify_metavars;
|
2014-11-28 22:49:00 +00:00
|
|
|
bool m_purify_locals;
|
2014-10-19 15:40:56 +00:00
|
|
|
bool m_beta;
|
2014-12-12 01:28:58 +00:00
|
|
|
bool m_numerals;
|
2015-02-11 02:27:02 +00:00
|
|
|
bool m_abbreviations;
|
2015-03-13 19:42:57 +00:00
|
|
|
bool m_hide_full_terms;
|
2015-03-25 23:45:58 +00:00
|
|
|
bool m_extra_spaces;
|
2015-05-19 16:57:13 +00:00
|
|
|
bool m_preterm;
|
2014-07-09 08:12:36 +00:00
|
|
|
|
|
|
|
name mk_metavar_name(name const & m);
|
2014-07-10 13:13:51 +00:00
|
|
|
name mk_local_name(name const & n, name const & suggested);
|
2014-07-09 08:12:36 +00:00
|
|
|
level purify(level const & l);
|
|
|
|
expr purify(expr const & e);
|
|
|
|
bool is_implicit(expr const & f);
|
|
|
|
bool is_prop(expr const & e);
|
2014-09-03 00:09:57 +00:00
|
|
|
bool has_implicit_args(expr const & f);
|
2014-10-01 18:24:45 +00:00
|
|
|
optional<name> is_aliased(name const & n) const;
|
2015-02-11 03:06:09 +00:00
|
|
|
optional<name> is_abbreviated(expr const & e) const;
|
2014-07-09 08:12:36 +00:00
|
|
|
|
|
|
|
format pp_binder_block(buffer<name> const & names, expr const & type, binder_info const & bi);
|
|
|
|
format pp_binders(buffer<expr> const & locals);
|
|
|
|
format pp_level(level const & l);
|
|
|
|
|
2014-10-19 15:40:56 +00:00
|
|
|
bool match(level const & p, level const & l);
|
|
|
|
bool match(expr const & p, expr const & e, buffer<optional<expr>> & args);
|
|
|
|
result pp_notation_child(expr const & e, unsigned lbp, unsigned rbp);
|
|
|
|
optional<result> pp_notation(notation_entry const & entry, buffer<optional<expr>> & args);
|
|
|
|
optional<result> pp_notation(expr const & e);
|
|
|
|
|
2015-05-29 21:07:38 +00:00
|
|
|
result add_paren_if_needed(result const & r, unsigned bp);
|
|
|
|
|
|
|
|
result pp_overriden_local_ref(expr const & e);
|
|
|
|
bool ignore_local_ref(expr const & e);
|
2015-04-22 19:44:08 +00:00
|
|
|
optional<result> pp_local_ref(expr const & e);
|
|
|
|
|
2015-03-13 19:42:57 +00:00
|
|
|
result pp_coercion_fn(expr const & e, unsigned sz, bool ignore_hide = false);
|
|
|
|
result pp_coercion(expr const & e, unsigned bp, bool ignore_hide = false);
|
|
|
|
result pp_child_core(expr const & e, unsigned bp, bool ignore_hide = false);
|
|
|
|
result pp_child(expr const & e, unsigned bp, bool ignore_hide = false);
|
2014-07-09 08:12:36 +00:00
|
|
|
result pp_var(expr const & e);
|
|
|
|
result pp_sort(expr const & e);
|
2015-05-29 21:07:38 +00:00
|
|
|
result pp_const(expr const & e, optional<unsigned> const & num_ref_univs = optional<unsigned>());
|
2014-07-09 08:12:36 +00:00
|
|
|
result pp_meta(expr const & e);
|
|
|
|
result pp_local(expr const & e);
|
|
|
|
result pp_app(expr const & e);
|
|
|
|
result pp_lambda(expr const & e);
|
|
|
|
result pp_pi(expr const & e);
|
2014-07-27 04:35:26 +00:00
|
|
|
result pp_have(expr const & e);
|
2014-07-27 04:56:35 +00:00
|
|
|
result pp_show(expr const & e);
|
2014-07-09 08:12:36 +00:00
|
|
|
result pp_macro(expr const & e);
|
2014-07-29 21:26:27 +00:00
|
|
|
result pp_explicit(expr const & e);
|
2014-08-29 01:20:58 +00:00
|
|
|
result pp_let(expr e);
|
2014-08-14 16:11:34 +00:00
|
|
|
result pp_num(mpz const & n);
|
2015-02-11 03:06:09 +00:00
|
|
|
// If fn is true, then \c e is of the form (f a), and the abbreviation is \c f.
|
2015-03-17 00:10:30 +00:00
|
|
|
result pp_abbreviation(expr const & e, name const & abbrev, bool fn, unsigned bp = 0, bool ignore_hide = false);
|
2014-07-27 16:41:25 +00:00
|
|
|
void set_options_core(options const & o);
|
2014-07-09 08:12:36 +00:00
|
|
|
|
|
|
|
public:
|
|
|
|
pretty_fn(environment const & env, options const & o);
|
2015-03-13 19:42:57 +00:00
|
|
|
result pp(expr const & e, bool ignore_hide = false);
|
2014-07-27 16:41:25 +00:00
|
|
|
void set_options(options const & o);
|
|
|
|
options const & get_options() const { return m_options; }
|
2014-07-09 08:12:36 +00:00
|
|
|
format operator()(expr const & e);
|
|
|
|
};
|
|
|
|
|
2014-07-10 17:32:00 +00:00
|
|
|
formatter_factory mk_pretty_formatter_factory();
|
2014-09-23 17:00:36 +00:00
|
|
|
void initialize_pp();
|
|
|
|
void finalize_pp();
|
2014-07-09 08:12:36 +00:00
|
|
|
}
|