z3-z3-4.13.0.src.ast.decl_collector.h Maven / Gradle / Ivy
The newest version!
/*++
Copyright (c) 2011 Microsoft Corporation
Module Name:
decl_collector.h
Abstract:
Collect uninterpreted func_delcs and sorts.
This class was originally in ast_smt_pp.h
Author:
Leonardo (leonardo) 2011-10-04
Revision History:
--*/
#pragma once
#include "util/top_sort.h"
#include "util/lim_vector.h"
#include "ast/ast.h"
#include "ast/datatype_decl_plugin.h"
#include "ast/array_decl_plugin.h"
class decl_collector {
ast_manager & m;
lim_svector m_sorts;
lim_svector m_decls;
lim_svector m_rec_decls;
ast_mark m_visited;
ast_ref_vector m_trail;
unsigned_vector m_trail_lim;
family_id m_basic_fid;
family_id m_dt_fid;
datatype_util m_dt_util;
array_util m_ar_util;
family_id m_rec_fid;
ptr_vector m_todo;
void visit_sort(sort* n);
bool is_bool(sort* s);
typedef obj_hashtable sort_set;
sort_set* collect_deps(sort* s);
void collect_deps(top_sort& st);
void collect_deps(sort* s, sort_set& set);
public:
decl_collector(ast_manager & m);
bool should_declare(func_decl* f) const;
void reset() { m_sorts.reset(); m_decls.reset(); m_visited.reset(); m_trail.reset(); }
void visit_func(func_decl* n);
void visit(ast * n);
void visit(unsigned n, expr* const* es);
void visit(expr_ref_vector const& es);
void push();
void pop(unsigned n);
void order_deps(unsigned n);
unsigned get_num_sorts() const { return m_sorts.size(); }
unsigned get_num_decls() const { return m_decls.size(); }
lim_svector const& get_sorts() const { return m_sorts; }
lim_svector const& get_func_decls() const { return m_decls; }
lim_svector const& get_rec_decls() const { return m_rec_decls; }
};