All Downloads are FREE. Search and download functionalities are using the official Maven repository.

z3-z3-4.12.6.src.util.sexpr.h Maven / Gradle / Ivy

There is a newer version: 4.13.0.1
Show newest version
/*++
Copyright (c) 2011 Microsoft Corporation

Module Name:

    sexpr.h

Abstract:

    Generic sexpr
    
Author:

    Leonardo (leonardo) 2011-07-28

Notes:

--*/
#pragma once

#include "util/rational.h"
#include "util/symbol.h"
#include "util/obj_ref.h"
#include "util/ref_vector.h"

class sexpr_manager;

class sexpr {
public:
    enum class kind_t {
        COMPOSITE, NUMERAL, BV_NUMERAL, STRING, KEYWORD, SYMBOL
    };
protected:
    kind_t   m_kind;
    unsigned m_ref_count;
    unsigned m_line;
    unsigned m_pos;
    sexpr(kind_t k, unsigned line, unsigned pos);
    void display_atom(std::ostream & out) const;
    friend class sexpr_manager;
public:
    void inc_ref() { m_ref_count++; }
    unsigned get_ref_count() const { return m_ref_count; }
    unsigned get_line() const { return m_line; }
    unsigned get_pos() const { return m_pos; }
    kind_t get_kind() const { return m_kind; }
    bool is_composite() const { return get_kind() == kind_t::COMPOSITE; }
    bool is_numeral() const { return get_kind() == kind_t::NUMERAL; }
    bool is_bv_numeral() const { return get_kind() == kind_t::BV_NUMERAL; }
    bool is_string() const { return get_kind() == kind_t::STRING; }
    bool is_keyword() const { return get_kind() == kind_t::KEYWORD; }
    bool is_symbol() const { return get_kind() == kind_t::SYMBOL; }
    rational const & get_numeral() const;
    unsigned get_bv_size() const;
    symbol get_symbol() const;
    std::string const & get_string() const;
    unsigned get_num_children() const;
    sexpr * get_child(unsigned idx) const;
    sexpr * const * get_children() const;
    void display(std::ostream & out) const;
};

class sexpr_manager {
    small_object_allocator m_allocator;
    ptr_vector      m_to_delete;
    void del(sexpr * n);
public:
    sexpr_manager();
    sexpr * mk_composite(unsigned num_children, sexpr * const * children, unsigned line = UINT_MAX, unsigned pos = UINT_MAX);
    sexpr * mk_numeral(rational const & val, unsigned line = UINT_MAX, unsigned pos = UINT_MAX);
    sexpr * mk_bv_numeral(rational const & val, unsigned bv_size, unsigned line = UINT_MAX, unsigned pos = UINT_MAX);
    sexpr * mk_string(std::string const & val, unsigned line = UINT_MAX, unsigned pos = UINT_MAX);
    sexpr * mk_string(char const * val, unsigned line = UINT_MAX, unsigned pos = UINT_MAX);
    sexpr * mk_keyword(symbol const & val, unsigned line = UINT_MAX, unsigned pos = UINT_MAX);
    sexpr * mk_symbol(symbol const & val, unsigned line = UINT_MAX, unsigned pos = UINT_MAX);
    void inc_ref(sexpr * n) { n->inc_ref(); }
    void dec_ref(sexpr * n) { SASSERT(n->m_ref_count > 0); n->m_ref_count--; if (n->m_ref_count == 0) del(n); }
};

typedef obj_ref sexpr_ref;
typedef ref_vector sexpr_ref_vector;





© 2015 - 2024 Weber Informatics LLC | Privacy Policy