3
0
Fork 0
mirror of https://github.com/Z3Prover/z3 synced 2025-04-15 05:18:44 +00:00

have solver pretty print declarations, include also datatype declarations

Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com>
This commit is contained in:
Nikolaj Bjorner 2015-08-07 08:48:24 +02:00
parent a3c43c34fb
commit 7f517c625f
4 changed files with 78 additions and 44 deletions

71
src/ast/ast_pp_util.cpp Normal file
View file

@ -0,0 +1,71 @@
/*++
Copyright (c) 2015 Microsoft Corporation
Module Name:
ast_pp_util.cpp
Abstract:
<abstract>
Author:
Nikolaj Bjorner (nbjorner) 2015-8-6.
Revision History:
--*/
#include "ast_pp_util.h"
void ast_pp_util::collect(expr* e) {
coll.visit(e);
}
void ast_pp_util::collect(unsigned n, expr* const* es) {
for (unsigned i = 0; i < n; ++i) {
coll.visit(es[i]);
}
}
void ast_pp_util::collect(expr_ref_vector const& es) {
collect(es.size(), es.c_ptr());
}
void ast_pp_util::display_decls(std::ostream& out) {
smt2_pp_environment_dbg env(m);
ast_smt_pp pp(m);
unsigned n = coll.get_num_sorts();
for (unsigned i = 0; i < n; ++i) {
pp.display_ast_smt2(out, coll.get_sorts()[i], 0, 0, 0);
}
n = coll.get_num_decls();
for (unsigned i = 0; i < n; ++i) {
ast_smt2_pp(out, coll.get_func_decls()[i], env);
out << "\n";
}
}
void ast_pp_util::display_asserts(std::ostream& out, expr_ref_vector const& fmls, bool neat) {
func_decl_ref asrt(m);
expr_ref e(m);
sort* b = m.mk_bool_sort();
asrt = m.mk_func_decl(symbol("assert"), 1, &b, b);
if (neat) {
smt2_pp_environment_dbg env(m);
for (unsigned i = 0; i < fmls.size(); ++i) {
e = m.mk_app(asrt, fmls[i]);
ast_smt2_pp(out, e, env);
out << "\n";
}
}
else {
ast_smt_pp ll_smt2_pp(m);
for (unsigned i = 0; i < fmls.size(); ++i) {
e = m.mk_app(asrt, fmls[i]);
ll_smt2_pp.display_expr_smt2(out, e);
out << "\n";
}
}
}

View file

@ -31,51 +31,15 @@ class ast_pp_util {
ast_pp_util(ast_manager& m): m(m), coll(m, false) {}
void collect(expr* e) {
coll.visit(e);
}
void collect(expr* e);
void collect(unsigned n, expr* const* es) {
for (unsigned i = 0; i < n; ++i) {
coll.visit(es[i]);
}
}
void collect(unsigned n, expr* const* es);
void collect(expr_ref_vector const& es) {
collect(es.size(), es.c_ptr());
}
void collect(expr_ref_vector const& es);
void display_decls(std::ostream& out) {
smt2_pp_environment_dbg env(m);
unsigned n = coll.get_num_sorts();
for (unsigned i = 0; i < n; ++i) {
ast_smt2_pp(out, coll.get_sorts()[i], env);
}
n = coll.get_num_decls();
for (unsigned i = 0; i < n; ++i) {
ast_smt2_pp(out, coll.get_func_decls()[i], env);
out << "\n";
}
}
void display_decls(std::ostream& out);
void display_asserts(std::ostream& out, expr_ref_vector const& fmls, bool neat = true) {
if (neat) {
smt2_pp_environment_dbg env(m);
for (unsigned i = 0; i < fmls.size(); ++i) {
out << "(assert ";
ast_smt2_pp(out, fmls[i], env);
out << ")\n";
}
}
else {
ast_smt_pp ll_smt2_pp(m);
for (unsigned i = 0; i < fmls.size(); ++i) {
out << "(assert ";
ll_smt2_pp.display_expr_smt2(out, fmls[i]);
out << ")\n";
}
}
}
void display_asserts(std::ostream& out, expr_ref_vector const& fmls, bool neat = true);
};
#endif /* AST_PP_UTIL_H_ */

View file

@ -913,9 +913,9 @@ public:
m_out << "(";
}
m_out << m_renaming.get_symbol(f->get_name());
// if (accs.size() > 0) {
if (!accs.empty() || !m_is_smt2) {
m_out << " ";
// }
}
for (unsigned j = 0; j < accs.size(); ++j) {
func_decl* a = accs[j];
m_out << "(" << m_renaming.get_symbol(a->get_name()) << " ";

View file

@ -21,7 +21,6 @@ Notes:
--*/
#include"solver_na2as.h"
#include"tactic.h"
#include"ast_smt2_pp.h"
#include"ast_pp_util.h"
/**