Z3
Loading...
Searching...
No Matches
context Class Reference

A Context manages all other Z3 objects, global configuration options, etc. More...

#include <z3++.h>

Public Member Functions

 context ()
 context (config &c)
 ~context ()
 operator Z3_context () const
Z3_error_code check_error () const
 Auxiliary method used to check for API usage errors.
void check_parser_error () const
void set_enable_exceptions (bool f)
 The C++ API uses by defaults exceptions on errors. For applications that don't work well with exceptions (there should be only few) you have the ability to turn off exceptions. The tradeoffs are that applications have to be very careful about using check_error() after calls that may result in an erroneous state.
bool enable_exceptions () const
void set (char const *param, char const *value)
 Update global parameter param with string value.
void set (char const *param, bool value)
 Update global parameter param with Boolean value.
void set (char const *param, int value)
 Update global parameter param with Integer value.
void interrupt ()
 Interrupt the current procedure being executed by any object managed by this context. This is a soft interruption: there is no guarantee the object will actually stop.
symbol str_symbol (char const *s)
 Create a Z3 symbol based on the given string.
symbol int_symbol (int n)
 Create a Z3 symbol based on the given integer.
sort bool_sort ()
 Return the Boolean sort.
sort int_sort ()
 Return the integer sort.
sort real_sort ()
 Return the Real sort.
sort bv_sort (unsigned sz)
 Return the Bit-vector sort of size sz. That is, the sort for bit-vectors of size sz.
sort char_sort ()
 Return the sort for Unicode characters.
sort string_sort ()
 Return the sort for Unicode strings.
sort seq_sort (sort &s)
 Return a sequence sort over base sort s.
sort re_sort (sort &seq_sort)
 Return a regular expression sort over sequences seq_sort.
sort array_sort (sort d, sort r)
 Return an array sort for arrays from d to r.
sort array_sort (sort_vector const &d, sort r)
sort fpa_sort (unsigned ebits, unsigned sbits)
 Return a floating point sort. ebits is a number of exponent bits, sbits is a number of significand bits,.
template<size_t precision>
sort fpa_sort ()
 Return a FloatingPoint sort with given precision bitwidth (16, 32, 64 or 128).
sort fpa_rounding_mode_sort ()
 Return a RoundingMode sort.
void set_rounding_mode (rounding_mode rm)
 Sets RoundingMode of FloatingPoints.
sort enumeration_sort (char const *name, unsigned n, char const *const *enum_names, func_decl_vector &cs, func_decl_vector &ts)
 Return an enumeration sort: enum_names[0], ..., enum_names[n-1]. cs and ts are output parameters. The method stores in cs the constants corresponding to the enumerated elements, and in ts the predicates for testing if terms of the enumeration sort correspond to an enumeration.
func_decl tuple_sort (char const *name, unsigned n, char const *const *names, sort const *sorts, func_decl_vector &projs)
 Return a tuple constructor. name is the name of the returned constructor, n are the number of arguments, names and sorts are their projected sorts. projs is an output parameter. It contains the set of projection functions.
sort datatype (symbol const &name, constructors const &cs)
 Create a recursive datatype over a single sort. name is the name of the recursive datatype n - the number of constructors of the datatype cs - the n constructors used to define the datatype.
sort datatype (symbol const &name, sort_vector const &params, constructors const &cs)
 Create a parametric recursive datatype. name is the name of the recursive datatype params - the sort parameters of the datatype cs - the n constructors used to define the datatype References to the datatype and mutually recursive datatypes can be created using datatype_sort.
sort_vector datatypes (unsigned n, symbol const *names, constructor_list *const *cons)
 Create a set of mutually recursive datatypes. n - number of recursive datatypes names - array of names of length n cons - array of constructor lists of length n.
sort datatype_sort (symbol const &name)
 a reference to a recursively defined datatype. Expect that it gets defined as a datatype.
sort datatype_sort (symbol const &name, sort_vector const &params)
 a reference to a recursively defined parametric datatype. Expect that it gets defined as a datatype.
sort uninterpreted_sort (char const *name)
 create an uninterpreted sort with the name given by the string or symbol.
sort uninterpreted_sort (symbol const &name)
func_decl function (symbol const &name, unsigned arity, sort const *domain, sort const &range)
func_decl function (char const *name, unsigned arity, sort const *domain, sort const &range)
func_decl function (symbol const &name, sort_vector const &domain, sort const &range)
func_decl function (char const *name, sort_vector const &domain, sort const &range)
func_decl function (char const *name, sort const &domain, sort const &range)
func_decl function (char const *name, sort const &d1, sort const &d2, sort const &range)
func_decl function (char const *name, sort const &d1, sort const &d2, sort const &d3, sort const &range)
func_decl function (char const *name, sort const &d1, sort const &d2, sort const &d3, sort const &d4, sort const &range)
func_decl function (char const *name, sort const &d1, sort const &d2, sort const &d3, sort const &d4, sort const &d5, sort const &range)
func_decl recfun (symbol const &name, unsigned arity, sort const *domain, sort const &range)
func_decl recfun (symbol const &name, const sort_vector &domain, sort const &range)
func_decl recfun (char const *name, sort_vector const &domain, sort const &range)
func_decl recfun (char const *name, unsigned arity, sort const *domain, sort const &range)
func_decl recfun (char const *name, sort const &domain, sort const &range)
func_decl recfun (char const *name, sort const &d1, sort const &d2, sort const &range)
void recdef (func_decl decl, expr_vector const &args, expr const &body)
 add function definition body to declaration decl. decl needs to be declared using context::recfun.
func_decl user_propagate_function (symbol const &name, sort_vector const &domain, sort const &range)
expr constant (symbol const &name, sort const &s)
 create an uninterpreted constant.
expr constant (char const *name, sort const &s)
expr bool_const (char const *name)
 create uninterpreted constants of a given sort.
expr int_const (char const *name)
expr real_const (char const *name)
expr string_const (char const *name)
expr bv_const (char const *name, unsigned sz)
expr fpa_const (char const *name, unsigned ebits, unsigned sbits)
template<size_t precision>
expr fpa_const (char const *name)
expr variable (unsigned index, sort const &s)
 create a de-Bruijn variable.
expr fpa_rounding_mode ()
expr bool_val (bool b)
expr int_val (int n)
expr int_val (unsigned n)
expr int_val (int64_t n)
expr int_val (uint64_t n)
expr int_val (char const *n)
expr real_val (int n)
expr real_val (unsigned n)
expr real_val (int64_t n)
expr real_val (uint64_t n)
expr real_val (int64_t n, int64_t d)
expr real_val (char const *n)
expr bv_val (int n, unsigned sz)
expr bv_val (unsigned n, unsigned sz)
expr bv_val (int64_t n, unsigned sz)
expr bv_val (uint64_t n, unsigned sz)
expr bv_val (char const *n, unsigned sz)
expr bv_val (unsigned n, bool const *bits)
expr fpa_val (double n)
expr fpa_val (float n)
expr fpa_nan (sort const &s)
expr fpa_inf (sort const &s, bool sgn)
expr string_val (char const *s)
expr string_val (char const *s, unsigned n)
expr string_val (std::string const &s)
expr string_val (std::u32string const &s)
expr num_val (int n, sort const &s)
expr_vector parse_string (char const *s)
 parsing
expr_vector parse_file (char const *file)
expr_vector parse_string (char const *s, sort_vector const &sorts, func_decl_vector const &decls)
expr_vector parse_file (char const *s, sort_vector const &sorts, func_decl_vector const &decls)
template<>
sort fpa_sort ()
template<>
sort fpa_sort ()
template<>
sort fpa_sort ()
template<>
sort fpa_sort ()

Friends

class user_propagator_base

Detailed Description

A Context manages all other Z3 objects, global configuration options, etc.

Definition at line 160 of file z3++.h.

Constructor & Destructor Documentation

◆ context() [1/2]

context ( )
inline

Definition at line 184 of file z3++.h.

184{ config c; init(c); }

◆ context() [2/2]

context ( config & c)
inline

Definition at line 185 of file z3++.h.

185{ init(c); }

◆ ~context()

~context ( )
inline

Definition at line 186 of file z3++.h.

186{ if (m_ctx) Z3_del_context(m_ctx); }
void Z3_API Z3_del_context(Z3_context c)
Delete the given logical context.

Member Function Documentation

◆ array_sort() [1/2]

sort array_sort ( sort d,
sort r )
inline

Return an array sort for arrays from d to r.

Example: Given a context c, c.array_sort(c.int_sort(), c.bool_sort()) is an array sort from integer to Boolean.

Definition at line 3530 of file z3++.h.

3530{ Z3_sort s = Z3_mk_array_sort(m_ctx, d, r); check_error(); return sort(*this, s); }
Z3_sort Z3_API Z3_mk_array_sort(Z3_context c, Z3_sort domain, Z3_sort range)
Create an array type.

◆ array_sort() [2/2]

sort array_sort ( sort_vector const & d,
sort r )
inline

Definition at line 3531 of file z3++.h.

3531 {
3532 array<Z3_sort> dom(d);
3533 Z3_sort s = Z3_mk_array_sort_n(m_ctx, dom.size(), dom.ptr(), r); check_error(); return sort(*this, s);
3534 }
Z3_sort Z3_API Z3_mk_array_sort_n(Z3_context c, unsigned n, Z3_sort const *domain, Z3_sort range)
Create an array type with N arguments.

◆ bool_const()

expr bool_const ( char const * name)
inline

create uninterpreted constants of a given sort.

Definition at line 3810 of file z3++.h.

3810{ return constant(name, bool_sort()); }

◆ bool_sort()

sort bool_sort ( )
inline

Return the Boolean sort.

Definition at line 3506 of file z3++.h.

3506{ Z3_sort s = Z3_mk_bool_sort(m_ctx); check_error(); return sort(*this, s); }
Z3_sort Z3_API Z3_mk_bool_sort(Z3_context c)
Create the Boolean type.

Referenced by bool_const().

◆ bool_val()

expr bool_val ( bool b)
inline

Definition at line 3833 of file z3++.h.

3833{ return b ? expr(*this, Z3_mk_true(m_ctx)) : expr(*this, Z3_mk_false(m_ctx)); }
Z3_ast Z3_API Z3_mk_true(Z3_context c)
Create an AST node representing true.
Z3_ast Z3_API Z3_mk_false(Z3_context c)
Create an AST node representing false.

Referenced by goal::as_expr(), user_propagator_base::conflict(), user_propagator_base::conflict(), expr::implies, expr::implies, expr::operator&&, expr::operator&&, expr::operator||, expr::operator||, and solver::to_smt2().

◆ bv_const()

expr bv_const ( char const * name,
unsigned sz )
inline

Definition at line 3814 of file z3++.h.

3814{ return constant(name, bv_sort(sz)); }

◆ bv_sort()

sort bv_sort ( unsigned sz)
inline

Return the Bit-vector sort of size sz. That is, the sort for bit-vectors of size sz.

Definition at line 3509 of file z3++.h.

3509{ Z3_sort s = Z3_mk_bv_sort(m_ctx, sz); check_error(); return sort(*this, s); }
Z3_sort Z3_API Z3_mk_bv_sort(Z3_context c, unsigned sz)
Create a bit-vector type of the given size.

Referenced by bv_const(), bv_val(), bv_val(), bv_val(), bv_val(), and bv_val().

◆ bv_val() [1/6]

expr bv_val ( char const * n,
unsigned sz )
inline

Definition at line 3852 of file z3++.h.

3852{ sort s = bv_sort(sz); Z3_ast r = Z3_mk_numeral(m_ctx, n, s); check_error(); return expr(*this, r); }
Z3_ast Z3_API Z3_mk_numeral(Z3_context c, Z3_string numeral, Z3_sort ty)
Create a numeral of a given sort.

◆ bv_val() [2/6]

expr bv_val ( int n,
unsigned sz )
inline

Definition at line 3848 of file z3++.h.

3848{ sort s = bv_sort(sz); Z3_ast r = Z3_mk_int(m_ctx, n, s); check_error(); return expr(*this, r); }
Z3_ast Z3_API Z3_mk_int(Z3_context c, int v, Z3_sort ty)
Create a numeral of an int, bit-vector, or finite-domain sort.

◆ bv_val() [3/6]

expr bv_val ( int64_t n,
unsigned sz )
inline

Definition at line 3850 of file z3++.h.

3850{ sort s = bv_sort(sz); Z3_ast r = Z3_mk_int64(m_ctx, n, s); check_error(); return expr(*this, r); }
Z3_ast Z3_API Z3_mk_int64(Z3_context c, int64_t v, Z3_sort ty)
Create a numeral of a int, bit-vector, or finite-domain sort.

◆ bv_val() [4/6]

expr bv_val ( uint64_t n,
unsigned sz )
inline

Definition at line 3851 of file z3++.h.

3851{ sort s = bv_sort(sz); Z3_ast r = Z3_mk_unsigned_int64(m_ctx, n, s); check_error(); return expr(*this, r); }
Z3_ast Z3_API Z3_mk_unsigned_int64(Z3_context c, uint64_t v, Z3_sort ty)
Create a numeral of a int, bit-vector, or finite-domain sort.

◆ bv_val() [5/6]

expr bv_val ( unsigned n,
bool const * bits )
inline

Definition at line 3853 of file z3++.h.

3853 {
3854 array<bool> _bits(n);
3855 for (unsigned i = 0; i < n; ++i) _bits[i] = bits[i] ? 1 : 0;
3856 Z3_ast r = Z3_mk_bv_numeral(m_ctx, n, _bits.ptr()); check_error(); return expr(*this, r);
3857 }
Z3_ast Z3_API Z3_mk_bv_numeral(Z3_context c, unsigned sz, bool const *bits)
create a bit-vector numeral from a vector of Booleans.

◆ bv_val() [6/6]

expr bv_val ( unsigned n,
unsigned sz )
inline

Definition at line 3849 of file z3++.h.

3849{ sort s = bv_sort(sz); Z3_ast r = Z3_mk_unsigned_int(m_ctx, n, s); check_error(); return expr(*this, r); }
Z3_ast Z3_API Z3_mk_unsigned_int(Z3_context c, unsigned v, Z3_sort ty)
Create a numeral of a int, bit-vector, or finite-domain sort.

◆ char_sort()

sort char_sort ( )
inline

Return the sort for Unicode characters.

Definition at line 3511 of file z3++.h.

3511{ Z3_sort s = Z3_mk_char_sort(m_ctx); check_error(); return sort(*this, s); }
Z3_sort Z3_API Z3_mk_char_sort(Z3_context c)
Create a sort for unicode characters.

◆ check_error()

Z3_error_code check_error ( ) const
inline

Auxiliary method used to check for API usage errors.

Definition at line 192 of file z3++.h.

192 {
194 if (e != Z3_OK && enable_exceptions())
195 Z3_THROW(exception(Z3_get_error_msg(m_ctx, e)));
196 return e;
197 }
Z3_string Z3_API Z3_get_error_msg(Z3_context c, Z3_error_code err)
Return a string describing the given error code.
Z3_error_code
Z3 error codes (See Z3_get_error_code).
Definition z3_api.h:1349
Z3_error_code Z3_API Z3_get_error_code(Z3_context c)
Return the error code for the last API call.
@ Z3_OK
Definition z3_api.h:1350
#define Z3_THROW(x)
Definition z3++.h:103

Referenced by array_sort(), array_sort(), expr::bit2bool(), bool_sort(), bv_sort(), bv_val(), bv_val(), bv_val(), bv_val(), bv_val(), bv_val(), char_sort(), check_parser_error(), expr::concat, constant(), datatype(), datatype(), datatype_sort(), datatype_sort(), enumeration_sort(), expr::extract(), z3::foldl(), z3::foldli(), fpa_inf(), fpa_nan(), fpa_rounding_mode_sort(), fpa_sort(), fpa_val(), fpa_val(), function(), function(), function(), function(), function(), function(), function(), int_sort(), int_symbol(), int_val(), int_val(), int_val(), int_val(), int_val(), z3::map(), z3::mapi(), num_val(), func_decl::operator()(), func_decl::operator()(), func_decl::operator()(), func_decl::operator()(), func_decl::operator()(), func_decl::operator()(), func_decl::operator()(), func_decl::operator()(), func_decl::operator()(), parse_file(), parse_file(), parse_string(), parse_string(), z3::re_diff(), z3::re_intersect(), re_sort(), real_sort(), real_val(), real_val(), real_val(), real_val(), real_val(), real_val(), recfun(), recfun(), expr::repeat(), expr::rotate_left(), expr::rotate_right(), seq_sort(), str_symbol(), string_sort(), string_val(), string_val(), string_val(), string_val(), z3::to_expr(), z3::to_func_decl(), z3::to_sort(), tuple_sort(), user_propagate_function(), and variable().

◆ check_parser_error()

void check_parser_error ( ) const
inline

Definition at line 199 of file z3++.h.

199 {
200 check_error();
201 }

Referenced by solver::from_file(), and solver::from_string().

◆ constant() [1/2]

expr constant ( char const * name,
sort const & s )
inline

Definition at line 3804 of file z3++.h.

3804{ return constant(str_symbol(name), s); }

◆ constant() [2/2]

expr constant ( symbol const & name,
sort const & s )
inline

create an uninterpreted constant.

Definition at line 3799 of file z3++.h.

3799 {
3800 Z3_ast r = Z3_mk_const(m_ctx, name, s);
3801 check_error();
3802 return expr(*this, r);
3803 }
Z3_ast Z3_API Z3_mk_const(Z3_context c, Z3_symbol s, Z3_sort ty)
Declare and create a constant.

Referenced by bool_const(), bv_const(), constant(), fpa_const(), fpa_const(), int_const(), real_const(), and string_const().

◆ datatype() [1/2]

sort datatype ( symbol const & name,
constructors const & cs )
inline

Create a recursive datatype over a single sort. name is the name of the recursive datatype n - the number of constructors of the datatype cs - the n constructors used to define the datatype.

References to the datatype can be created using datatype_sort.

Definition at line 3620 of file z3++.h.

3620 {
3621 array<Z3_constructor> _cs(cs.size());
3622 for (unsigned i = 0; i < cs.size(); ++i) _cs[i] = cs[i];
3623 Z3_sort s = Z3_mk_datatype(*this, name, cs.size(), _cs.ptr());
3624 check_error();
3625 return sort(*this, s);
3626 }
Z3_sort Z3_API Z3_mk_datatype(Z3_context c, Z3_symbol name, unsigned num_constructors, Z3_constructor constructors[])
Create datatype, such as lists, trees, records, enumerations or unions of records....

◆ datatype() [2/2]

sort datatype ( symbol const & name,
sort_vector const & params,
constructors const & cs )
inline

Create a parametric recursive datatype. name is the name of the recursive datatype params - the sort parameters of the datatype cs - the n constructors used to define the datatype References to the datatype and mutually recursive datatypes can be created using datatype_sort.

Definition at line 3628 of file z3++.h.

3628 {
3629 array<Z3_sort> _params(params);
3630 array<Z3_constructor> _cs(cs.size());
3631 for (unsigned i = 0; i < cs.size(); ++i)
3632 _cs[i] = cs[i];
3633 Z3_sort s = Z3_mk_polymorphic_datatype(*this, name, _params.size(), _params.ptr(), cs.size(), _cs.ptr());
3634 check_error();
3635 return sort(*this, s);
3636 }
Z3_sort Z3_API Z3_mk_polymorphic_datatype(Z3_context c, Z3_symbol name, unsigned num_parameters, Z3_sort parameters[], unsigned num_constructors, Z3_constructor constructors[])
Create a parametric datatype with explicit type parameters.

◆ datatype_sort() [1/2]

sort datatype_sort ( symbol const & name)
inline

a reference to a recursively defined datatype. Expect that it gets defined as a datatype.

Definition at line 3654 of file z3++.h.

3654 {
3655 Z3_sort s = Z3_mk_datatype_sort(*this, name, 0, nullptr);
3656 check_error();
3657 return sort(*this, s);
3658 }
Z3_sort Z3_API Z3_mk_datatype_sort(Z3_context c, Z3_symbol name, unsigned num_params, Z3_sort const params[])
create a forward reference to a recursive datatype being declared. The forward reference can be used ...

◆ datatype_sort() [2/2]

sort datatype_sort ( symbol const & name,
sort_vector const & params )
inline

a reference to a recursively defined parametric datatype. Expect that it gets defined as a datatype.

Parameters
namename of the datatype
paramssort parameters

Definition at line 3660 of file z3++.h.

3660 {
3661 array<Z3_sort> _params(params);
3662 Z3_sort s = Z3_mk_datatype_sort(*this, name, _params.size(), _params.ptr());
3663 check_error();
3664 return sort(*this, s);
3665 }

◆ datatypes()

sort_vector datatypes ( unsigned n,
symbol const * names,
constructor_list *const * cons )
inline

Create a set of mutually recursive datatypes. n - number of recursive datatypes names - array of names of length n cons - array of constructor lists of length n.

Definition at line 3638 of file z3++.h.

3640 {
3641 sort_vector result(*this);
3642 array<Z3_symbol> _names(n);
3643 array<Z3_sort> _sorts(n);
3644 array<Z3_constructor_list> _cons(n);
3645 for (unsigned i = 0; i < n; ++i)
3646 _names[i] = names[i], _cons[i] = *cons[i];
3647 Z3_mk_datatypes(*this, n, _names.ptr(), _sorts.ptr(), _cons.ptr());
3648 for (unsigned i = 0; i < n; ++i)
3649 result.push_back(sort(*this, _sorts[i]));
3650 return result;
3651 }
void Z3_API Z3_mk_datatypes(Z3_context c, unsigned num_sorts, Z3_symbol const sort_names[], Z3_sort sorts[], Z3_constructor_list constructor_lists[])
Create mutually recursive datatypes.
ast_vector_tpl< sort > sort_vector
Definition z3++.h:77

◆ enable_exceptions()

bool enable_exceptions ( ) const
inline

Definition at line 212 of file z3++.h.

212{ return m_enable_exceptions; }

Referenced by check_error().

◆ enumeration_sort()

sort enumeration_sort ( char const * name,
unsigned n,
char const *const * enum_names,
func_decl_vector & cs,
func_decl_vector & ts )
inline

Return an enumeration sort: enum_names[0], ..., enum_names[n-1]. cs and ts are output parameters. The method stores in cs the constants corresponding to the enumerated elements, and in ts the predicates for testing if terms of the enumeration sort correspond to an enumeration.

Definition at line 3535 of file z3++.h.

3535 {
3536 array<Z3_symbol> _enum_names(n);
3537 for (unsigned i = 0; i < n; i++) { _enum_names[i] = Z3_mk_string_symbol(*this, enum_names[i]); }
3538 array<Z3_func_decl> _cs(n);
3539 array<Z3_func_decl> _ts(n);
3540 Z3_symbol _name = Z3_mk_string_symbol(*this, name);
3541 sort s = to_sort(*this, Z3_mk_enumeration_sort(*this, _name, n, _enum_names.ptr(), _cs.ptr(), _ts.ptr()));
3542 check_error();
3543 for (unsigned i = 0; i < n; i++) { cs.push_back(func_decl(*this, _cs[i])); ts.push_back(func_decl(*this, _ts[i])); }
3544 return s;
3545 }
Z3_sort Z3_API Z3_mk_enumeration_sort(Z3_context c, Z3_symbol name, unsigned n, Z3_symbol const enum_names[], Z3_func_decl enum_consts[], Z3_func_decl enum_testers[])
Create a enumeration sort.
Z3_symbol Z3_API Z3_mk_string_symbol(Z3_context c, Z3_string s)
Create a Z3 symbol using a C string.
sort to_sort(context &c, Z3_sort s)
Definition z3++.h:2133

◆ fpa_const() [1/2]

template<size_t precision>
expr fpa_const ( char const * name)
inline

Definition at line 3818 of file z3++.h.

3818{ return constant(name, fpa_sort<precision>()); }

◆ fpa_const() [2/2]

expr fpa_const ( char const * name,
unsigned ebits,
unsigned sbits )
inline

Definition at line 3815 of file z3++.h.

3815{ return constant(name, fpa_sort(ebits, sbits)); }

◆ fpa_inf()

expr fpa_inf ( sort const & s,
bool sgn )
inline

Definition at line 3862 of file z3++.h.

3862{ Z3_ast r = Z3_mk_fpa_inf(m_ctx, s, sgn); check_error(); return expr(*this, r); }
Z3_ast Z3_API Z3_mk_fpa_inf(Z3_context c, Z3_sort s, bool negative)
Create a floating-point infinity of sort s.

◆ fpa_nan()

expr fpa_nan ( sort const & s)
inline

Definition at line 3861 of file z3++.h.

3861{ Z3_ast r = Z3_mk_fpa_nan(m_ctx, s); check_error(); return expr(*this, r); }
Z3_ast Z3_API Z3_mk_fpa_nan(Z3_context c, Z3_sort s)
Create a floating-point NaN of sort s.

◆ fpa_rounding_mode()

expr fpa_rounding_mode ( )
inline

Definition at line 3822 of file z3++.h.

3822 {
3823 switch (m_rounding_mode) {
3824 case RNA: return expr(*this, Z3_mk_fpa_rna(m_ctx));
3825 case RNE: return expr(*this, Z3_mk_fpa_rne(m_ctx));
3826 case RTP: return expr(*this, Z3_mk_fpa_rtp(m_ctx));
3827 case RTN: return expr(*this, Z3_mk_fpa_rtn(m_ctx));
3828 case RTZ: return expr(*this, Z3_mk_fpa_rtz(m_ctx));
3829 default: return expr(*this);
3830 }
3831 }
Z3_ast Z3_API Z3_mk_fpa_rna(Z3_context c)
Create a numeral of RoundingMode sort which represents the NearestTiesToAway rounding mode.
Z3_ast Z3_API Z3_mk_fpa_rtn(Z3_context c)
Create a numeral of RoundingMode sort which represents the TowardNegative rounding mode.
Z3_ast Z3_API Z3_mk_fpa_rtp(Z3_context c)
Create a numeral of RoundingMode sort which represents the TowardPositive rounding mode.
Z3_ast Z3_API Z3_mk_fpa_rtz(Z3_context c)
Create a numeral of RoundingMode sort which represents the TowardZero rounding mode.
Z3_ast Z3_API Z3_mk_fpa_rne(Z3_context c)
Create a numeral of RoundingMode sort which represents the NearestTiesToEven rounding mode.
@ RNE
Definition z3++.h:141
@ RNA
Definition z3++.h:140
@ RTZ
Definition z3++.h:144
@ RTN
Definition z3++.h:143
@ RTP
Definition z3++.h:142

Referenced by expr::fpa_to_fpa, expr::fpa_to_sbv, expr::fpa_to_ubv, expr::operator*, expr::operator+, expr::operator-, expr::operator/, expr::round_fpa_to_closest_integer, expr::sbv_to_fpa, and expr::ubv_to_fpa.

◆ fpa_rounding_mode_sort()

sort fpa_rounding_mode_sort ( )
inline

Return a RoundingMode sort.

Definition at line 3528 of file z3++.h.

3528{ Z3_sort r = Z3_mk_fpa_rounding_mode_sort(m_ctx); check_error(); return sort(*this, r); }
Z3_sort Z3_API Z3_mk_fpa_rounding_mode_sort(Z3_context c)
Create the RoundingMode sort.

◆ fpa_sort() [1/6]

template<>
sort fpa_sort ( )
inline

Definition at line 3526 of file z3++.h.

3526{ return fpa_sort(15, 113); }

Referenced by fpa_sort().

◆ fpa_sort() [2/6]

template<>
sort fpa_sort ( )
inline

Definition at line 3523 of file z3++.h.

3523{ return fpa_sort(11, 53); }

Referenced by fpa_sort().

◆ fpa_sort() [3/6]

template<>
sort fpa_sort ( )
inline

Definition at line 3520 of file z3++.h.

3520{ return fpa_sort(8, 24); }

Referenced by fpa_sort().

◆ fpa_sort() [4/6]

template<>
sort fpa_sort ( )
inline

Definition at line 3517 of file z3++.h.

3517{ return fpa_sort(5, 11); }

Referenced by fpa_sort().

◆ fpa_sort() [5/6]

template<size_t precision>
sort fpa_sort ( )

Return a FloatingPoint sort with given precision bitwidth (16, 32, 64 or 128).

Referenced by fpa_const(), fpa_val(), and fpa_val().

◆ fpa_sort() [6/6]

sort fpa_sort ( unsigned ebits,
unsigned sbits )
inline

Return a floating point sort. ebits is a number of exponent bits, sbits is a number of significand bits,.

Precondition
where ebits must be larger than 1 and sbits must be larger than 2.

Definition at line 3514 of file z3++.h.

3514{ Z3_sort s = Z3_mk_fpa_sort(m_ctx, ebits, sbits); check_error(); return sort(*this, s); }
Z3_sort Z3_API Z3_mk_fpa_sort(Z3_context c, unsigned ebits, unsigned sbits)
Create a FloatingPoint sort.

Referenced by fpa_const().

◆ fpa_val() [1/2]

expr fpa_val ( double n)
inline

Definition at line 3859 of file z3++.h.

3859{ sort s = fpa_sort<64>(); Z3_ast r = Z3_mk_fpa_numeral_double(m_ctx, n, s); check_error(); return expr(*this, r); }
Z3_ast Z3_API Z3_mk_fpa_numeral_double(Z3_context c, double v, Z3_sort ty)
Create a numeral of FloatingPoint sort from a double.

Referenced by z3::operator!=(), z3::operator!=(), z3::operator==(), and z3::operator==().

◆ fpa_val() [2/2]

expr fpa_val ( float n)
inline

Definition at line 3860 of file z3++.h.

3860{ sort s = fpa_sort<32>(); Z3_ast r = Z3_mk_fpa_numeral_float(m_ctx, n, s); check_error(); return expr(*this, r); }
Z3_ast Z3_API Z3_mk_fpa_numeral_float(Z3_context c, float v, Z3_sort ty)
Create an expression of FloatingPoint sort from three bit-vector expressions.

◆ function() [1/9]

func_decl function ( char const * name,
sort const & d1,
sort const & d2,
sort const & d3,
sort const & d4,
sort const & d5,
sort const & range )
inline

Definition at line 3739 of file z3++.h.

3739 {
3740 check_context(d1, range); check_context(d2, range); check_context(d3, range); check_context(d4, range); check_context(d5, range);
3741 Z3_sort args[5] = { d1, d2, d3, d4, d5 };
3742 Z3_func_decl f = Z3_mk_func_decl(m_ctx, str_symbol(name), 5, args, range);
3743 check_error();
3744 return func_decl(*this, f);
3745 }
Z3_func_decl Z3_API Z3_mk_func_decl(Z3_context c, Z3_symbol s, unsigned domain_size, Z3_sort const domain[], Z3_sort range)
Declare a constant or function.
void check_context(object const &a, object const &b)
Definition z3++.h:495

◆ function() [2/9]

func_decl function ( char const * name,
sort const & d1,
sort const & d2,
sort const & d3,
sort const & d4,
sort const & range )
inline

Definition at line 3731 of file z3++.h.

3731 {
3732 check_context(d1, range); check_context(d2, range); check_context(d3, range); check_context(d4, range);
3733 Z3_sort args[4] = { d1, d2, d3, d4 };
3734 Z3_func_decl f = Z3_mk_func_decl(m_ctx, str_symbol(name), 4, args, range);
3735 check_error();
3736 return func_decl(*this, f);
3737 }

◆ function() [3/9]

func_decl function ( char const * name,
sort const & d1,
sort const & d2,
sort const & d3,
sort const & range )
inline

Definition at line 3723 of file z3++.h.

3723 {
3724 check_context(d1, range); check_context(d2, range); check_context(d3, range);
3725 Z3_sort args[3] = { d1, d2, d3 };
3726 Z3_func_decl f = Z3_mk_func_decl(m_ctx, str_symbol(name), 3, args, range);
3727 check_error();
3728 return func_decl(*this, f);
3729 }

◆ function() [4/9]

func_decl function ( char const * name,
sort const & d1,
sort const & d2,
sort const & range )
inline

Definition at line 3715 of file z3++.h.

3715 {
3716 check_context(d1, range); check_context(d2, range);
3717 Z3_sort args[2] = { d1, d2 };
3718 Z3_func_decl f = Z3_mk_func_decl(m_ctx, str_symbol(name), 2, args, range);
3719 check_error();
3720 return func_decl(*this, f);
3721 }

◆ function() [5/9]

func_decl function ( char const * name,
sort const & domain,
sort const & range )
inline

Definition at line 3707 of file z3++.h.

3707 {
3708 check_context(domain, range);
3709 Z3_sort args[1] = { domain };
3710 Z3_func_decl f = Z3_mk_func_decl(m_ctx, str_symbol(name), 1, args, range);
3711 check_error();
3712 return func_decl(*this, f);
3713 }

◆ function() [6/9]

func_decl function ( char const * name,
sort_vector const & domain,
sort const & range )
inline

Definition at line 3702 of file z3++.h.

3702 {
3703 return function(range.ctx().str_symbol(name), domain, range);
3704 }
symbol str_symbol(char const *s)
Create a Z3 symbol based on the given string.
Definition z3++.h:3503
context & ctx() const
Definition z3++.h:491
func_decl function(symbol const &name, unsigned arity, sort const *domain, sort const &range)
Definition z3++.h:3955
expr range(expr const &lo, expr const &hi)
Definition z3++.h:4178

◆ function() [7/9]

func_decl function ( char const * name,
unsigned arity,
sort const * domain,
sort const & range )
inline

Definition at line 3687 of file z3++.h.

3687 {
3688 return function(range.ctx().str_symbol(name), arity, domain, range);
3689 }

◆ function() [8/9]

func_decl function ( symbol const & name,
sort_vector const & domain,
sort const & range )
inline

Definition at line 3691 of file z3++.h.

3691 {
3692 array<Z3_sort> args(domain.size());
3693 for (unsigned i = 0; i < domain.size(); i++) {
3694 check_context(domain[i], range);
3695 args[i] = domain[i];
3696 }
3697 Z3_func_decl f = Z3_mk_func_decl(m_ctx, name, domain.size(), args.ptr(), range);
3698 check_error();
3699 return func_decl(*this, f);
3700 }

◆ function() [9/9]

func_decl function ( symbol const & name,
unsigned arity,
sort const * domain,
sort const & range )
inline

Definition at line 3676 of file z3++.h.

3676 {
3677 array<Z3_sort> args(arity);
3678 for (unsigned i = 0; i < arity; i++) {
3679 check_context(domain[i], range);
3680 args[i] = domain[i];
3681 }
3682 Z3_func_decl f = Z3_mk_func_decl(m_ctx, name, arity, args.ptr(), range);
3683 check_error();
3684 return func_decl(*this, f);
3685 }

Referenced by function(), and function().

◆ int_const()

expr int_const ( char const * name)
inline

Definition at line 3811 of file z3++.h.

3811{ return constant(name, int_sort()); }

◆ int_sort()

sort int_sort ( )
inline

Return the integer sort.

Definition at line 3507 of file z3++.h.

3507{ Z3_sort s = Z3_mk_int_sort(m_ctx); check_error(); return sort(*this, s); }
Z3_sort Z3_API Z3_mk_int_sort(Z3_context c)
Create the integer type.

Referenced by int_const(), int_val(), int_val(), int_val(), int_val(), and int_val().

◆ int_symbol()

symbol int_symbol ( int n)
inline

Create a Z3 symbol based on the given integer.

Definition at line 3504 of file z3++.h.

3504{ Z3_symbol r = Z3_mk_int_symbol(m_ctx, n); check_error(); return symbol(*this, r); }
Z3_symbol Z3_API Z3_mk_int_symbol(Z3_context c, int i)
Create a Z3 symbol using an integer.

◆ int_val() [1/5]

expr int_val ( char const * n)
inline

Definition at line 3839 of file z3++.h.

3839{ Z3_ast r = Z3_mk_numeral(m_ctx, n, int_sort()); check_error(); return expr(*this, r); }

◆ int_val() [2/5]

expr int_val ( int n)
inline

Definition at line 3835 of file z3++.h.

3835{ Z3_ast r = Z3_mk_int(m_ctx, n, int_sort()); check_error(); return expr(*this, r); }

Referenced by expr::abs.

◆ int_val() [3/5]

expr int_val ( int64_t n)
inline

Definition at line 3837 of file z3++.h.

3837{ Z3_ast r = Z3_mk_int64(m_ctx, n, int_sort()); check_error(); return expr(*this, r); }

◆ int_val() [4/5]

expr int_val ( uint64_t n)
inline

Definition at line 3838 of file z3++.h.

3838{ Z3_ast r = Z3_mk_unsigned_int64(m_ctx, n, int_sort()); check_error(); return expr(*this, r); }

◆ int_val() [5/5]

expr int_val ( unsigned n)
inline

Definition at line 3836 of file z3++.h.

3836{ Z3_ast r = Z3_mk_unsigned_int(m_ctx, n, int_sort()); check_error(); return expr(*this, r); }

◆ interrupt()

void interrupt ( )
inline

Interrupt the current procedure being executed by any object managed by this context. This is a soft interruption: there is no guarantee the object will actually stop.

Definition at line 234 of file z3++.h.

234{ Z3_interrupt(m_ctx); }
void Z3_API Z3_interrupt(Z3_context c)
Interrupt the execution of a Z3 procedure. This procedure can be used to interrupt: solvers,...

◆ num_val()

◆ operator Z3_context()

operator Z3_context ( ) const
inline

Definition at line 187 of file z3++.h.

187{ return m_ctx; }

◆ parse_file() [1/2]

expr_vector parse_file ( char const * file)
inline

Definition at line 4195 of file z3++.h.

4195 {
4196 Z3_ast_vector r = Z3_parse_smtlib2_file(*this, s, 0, 0, 0, 0, 0, 0);
4197 check_error();
4198 return expr_vector(*this, r);
4199 }
Z3_ast_vector Z3_API Z3_parse_smtlib2_file(Z3_context c, Z3_string file_name, unsigned num_sorts, Z3_symbol const sort_names[], Z3_sort const sorts[], unsigned num_decls, Z3_symbol const decl_names[], Z3_func_decl const decls[])
Similar to Z3_parse_smtlib2_string, but reads the benchmark from a file.
ast_vector_tpl< expr > expr_vector
Definition z3++.h:76

◆ parse_file() [2/2]

expr_vector parse_file ( char const * s,
sort_vector const & sorts,
func_decl_vector const & decls )
inline

Definition at line 4218 of file z3++.h.

4218 {
4219 array<Z3_symbol> sort_names(sorts.size());
4220 array<Z3_symbol> decl_names(decls.size());
4221 array<Z3_sort> sorts1(sorts);
4222 array<Z3_func_decl> decls1(decls);
4223 for (unsigned i = 0; i < sorts.size(); ++i) {
4224 sort_names[i] = sorts[i].name();
4225 }
4226 for (unsigned i = 0; i < decls.size(); ++i) {
4227 decl_names[i] = decls[i].name();
4228 }
4229 Z3_ast_vector r = Z3_parse_smtlib2_file(*this, s, sorts.size(), sort_names.ptr(), sorts1.ptr(), decls.size(), decl_names.ptr(), decls1.ptr());
4230 check_error();
4231 return expr_vector(*this, r);
4232 }

◆ parse_string() [1/2]

expr_vector parse_string ( char const * s)
inline

parsing

Definition at line 4189 of file z3++.h.

4189 {
4190 Z3_ast_vector r = Z3_parse_smtlib2_string(*this, s, 0, 0, 0, 0, 0, 0);
4191 check_error();
4192 return expr_vector(*this, r);
4193
4194 }
Z3_ast_vector Z3_API Z3_parse_smtlib2_string(Z3_context c, Z3_string str, unsigned num_sorts, Z3_symbol const sort_names[], Z3_sort const sorts[], unsigned num_decls, Z3_symbol const decl_names[], Z3_func_decl const decls[])
Parse the given string using the SMT-LIB2 parser.

◆ parse_string() [2/2]

expr_vector parse_string ( char const * s,
sort_vector const & sorts,
func_decl_vector const & decls )
inline

Definition at line 4201 of file z3++.h.

4201 {
4202 array<Z3_symbol> sort_names(sorts.size());
4203 array<Z3_symbol> decl_names(decls.size());
4204 array<Z3_sort> sorts1(sorts);
4205 array<Z3_func_decl> decls1(decls);
4206 for (unsigned i = 0; i < sorts.size(); ++i) {
4207 sort_names[i] = sorts[i].name();
4208 }
4209 for (unsigned i = 0; i < decls.size(); ++i) {
4210 decl_names[i] = decls[i].name();
4211 }
4212
4213 Z3_ast_vector r = Z3_parse_smtlib2_string(*this, s, sorts.size(), sort_names.ptr(), sorts1.ptr(), decls.size(), decl_names.ptr(), decls1.ptr());
4214 check_error();
4215 return expr_vector(*this, r);
4216 }

◆ re_sort()

sort re_sort ( sort & seq_sort)
inline

Return a regular expression sort over sequences seq_sort.

Definition at line 3513 of file z3++.h.

3513{ Z3_sort r = Z3_mk_re_sort(m_ctx, s); check_error(); return sort(*this, r); }
Z3_sort Z3_API Z3_mk_re_sort(Z3_context c, Z3_sort seq)
Create a regular expression sort out of a sequence sort.

◆ real_const()

expr real_const ( char const * name)
inline

Definition at line 3812 of file z3++.h.

3812{ return constant(name, real_sort()); }

◆ real_sort()

sort real_sort ( )
inline

Return the Real sort.

Definition at line 3508 of file z3++.h.

3508{ Z3_sort s = Z3_mk_real_sort(m_ctx); check_error(); return sort(*this, s); }
Z3_sort Z3_API Z3_mk_real_sort(Z3_context c)
Create the real type.

Referenced by real_const(), real_val(), real_val(), real_val(), real_val(), and real_val().

◆ real_val() [1/6]

expr real_val ( char const * n)
inline

Definition at line 3846 of file z3++.h.

3846{ Z3_ast r = Z3_mk_numeral(m_ctx, n, real_sort()); check_error(); return expr(*this, r); }

◆ real_val() [2/6]

expr real_val ( int n)
inline

Definition at line 3842 of file z3++.h.

3842{ Z3_ast r = Z3_mk_int(m_ctx, n, real_sort()); check_error(); return expr(*this, r); }

Referenced by expr::abs.

◆ real_val() [3/6]

expr real_val ( int64_t n)
inline

Definition at line 3844 of file z3++.h.

3844{ Z3_ast r = Z3_mk_int64(m_ctx, n, real_sort()); check_error(); return expr(*this, r); }

◆ real_val() [4/6]

expr real_val ( int64_t n,
int64_t d )
inline

Definition at line 3841 of file z3++.h.

3841{ Z3_ast r = Z3_mk_real_int64(m_ctx, n, d); check_error(); return expr(*this, r); }
Z3_ast Z3_API Z3_mk_real_int64(Z3_context c, int64_t num, int64_t den)
Create a real from a fraction of int64.

◆ real_val() [5/6]

expr real_val ( uint64_t n)
inline

Definition at line 3845 of file z3++.h.

3845{ Z3_ast r = Z3_mk_unsigned_int64(m_ctx, n, real_sort()); check_error(); return expr(*this, r); }

◆ real_val() [6/6]

expr real_val ( unsigned n)
inline

Definition at line 3843 of file z3++.h.

3843{ Z3_ast r = Z3_mk_unsigned_int(m_ctx, n, real_sort()); check_error(); return expr(*this, r); }

◆ recdef()

void recdef ( func_decl decl,
expr_vector const & args,
expr const & body )
inline

add function definition body to declaration decl. decl needs to be declared using context::recfun.

Parameters
decl
args
body

Definition at line 3785 of file z3++.h.

3785 {
3786 check_context(f, args); check_context(f, body);
3787 array<Z3_ast> vars(args);
3788 Z3_add_rec_def(f.ctx(), f, vars.size(), vars.ptr(), body);
3789 }
void Z3_API Z3_add_rec_def(Z3_context c, Z3_func_decl f, unsigned n, Z3_ast args[], Z3_ast body)
Define the body of a recursive function.

◆ recfun() [1/6]

func_decl recfun ( char const * name,
sort const & d1,
sort const & d2,
sort const & range )
inline

Definition at line 3780 of file z3++.h.

3780 {
3781 sort dom[2] = { d1, d2 };
3782 return recfun(str_symbol(name), 2, dom, range);
3783 }
func_decl recfun(symbol const &name, unsigned arity, sort const *domain, sort const &range)
Definition z3++.h:3983

◆ recfun() [2/6]

func_decl recfun ( char const * name,
sort const & domain,
sort const & range )
inline

Definition at line 3776 of file z3++.h.

3776 {
3777 return recfun(str_symbol(name), 1, &d1, range);
3778 }

◆ recfun() [3/6]

func_decl recfun ( char const * name,
sort_vector const & domain,
sort const & range )
inline

Definition at line 3767 of file z3++.h.

3767 {
3768 return recfun(str_symbol(name), domain, range);
3769
3770 }

◆ recfun() [4/6]

func_decl recfun ( char const * name,
unsigned arity,
sort const * domain,
sort const & range )
inline

Definition at line 3772 of file z3++.h.

3772 {
3773 return recfun(str_symbol(name), arity, domain, range);
3774 }

◆ recfun() [5/6]

func_decl recfun ( symbol const & name,
const sort_vector & domain,
sort const & range )
inline

Definition at line 3759 of file z3++.h.

3759 {
3760 check_context(domain, range);
3761 array<Z3_sort> domain1(domain);
3762 Z3_func_decl f = Z3_mk_rec_func_decl(m_ctx, name, domain1.size(), domain1.ptr(), range);
3763 check_error();
3764 return func_decl(*this, f);
3765 }
Z3_func_decl Z3_API Z3_mk_rec_func_decl(Z3_context c, Z3_symbol s, unsigned domain_size, Z3_sort const domain[], Z3_sort range)
Declare a recursive function.

◆ recfun() [6/6]

func_decl recfun ( symbol const & name,
unsigned arity,
sort const * domain,
sort const & range )
inline

Definition at line 3747 of file z3++.h.

3747 {
3748 array<Z3_sort> args(arity);
3749 for (unsigned i = 0; i < arity; i++) {
3750 check_context(domain[i], range);
3751 args[i] = domain[i];
3752 }
3753 Z3_func_decl f = Z3_mk_rec_func_decl(m_ctx, name, arity, args.ptr(), range);
3754 check_error();
3755 return func_decl(*this, f);
3756
3757 }

Referenced by recfun(), recfun(), recfun(), and recfun().

◆ seq_sort()

sort seq_sort ( sort & s)
inline

Return a sequence sort over base sort s.

Definition at line 3512 of file z3++.h.

3512{ Z3_sort r = Z3_mk_seq_sort(m_ctx, s); check_error(); return sort(*this, r); }
Z3_sort Z3_API Z3_mk_seq_sort(Z3_context c, Z3_sort s)
Create a sequence sort out of the sort for the elements.

◆ set() [1/3]

void set ( char const * param,
bool value )
inline

Update global parameter param with Boolean value.

Definition at line 221 of file z3++.h.

221{ Z3_update_param_value(m_ctx, param, value ? "true" : "false"); }
void Z3_API Z3_update_param_value(Z3_context c, Z3_string param_id, Z3_string param_value)
Set a value of a context parameter.

◆ set() [2/3]

void set ( char const * param,
char const * value )
inline

Update global parameter param with string value.

Definition at line 217 of file z3++.h.

217{ Z3_update_param_value(m_ctx, param, value); }

◆ set() [3/3]

void set ( char const * param,
int value )
inline

Update global parameter param with Integer value.

Definition at line 225 of file z3++.h.

225 {
226 auto str = std::to_string(value);
227 Z3_update_param_value(m_ctx, param, str.c_str());
228 }

◆ set_enable_exceptions()

void set_enable_exceptions ( bool f)
inline

The C++ API uses by defaults exceptions on errors. For applications that don't work well with exceptions (there should be only few) you have the ability to turn off exceptions. The tradeoffs are that applications have to be very careful about using check_error() after calls that may result in an erroneous state.

Definition at line 210 of file z3++.h.

210{ m_enable_exceptions = f; }

◆ set_rounding_mode()

void set_rounding_mode ( rounding_mode rm)
inline

Sets RoundingMode of FloatingPoints.

Definition at line 3820 of file z3++.h.

3820{ m_rounding_mode = rm; }

◆ str_symbol()

symbol str_symbol ( char const * s)
inline

Create a Z3 symbol based on the given string.

Definition at line 3503 of file z3++.h.

3503{ Z3_symbol r = Z3_mk_string_symbol(m_ctx, s); check_error(); return symbol(*this, r); }

Referenced by constant(), function(), function(), function(), function(), function(), recfun(), recfun(), recfun(), recfun(), and solver::solver().

◆ string_const()

expr string_const ( char const * name)
inline

Definition at line 3813 of file z3++.h.

3813{ return constant(name, string_sort()); }

◆ string_sort()

sort string_sort ( )
inline

Return the sort for Unicode strings.

Definition at line 3510 of file z3++.h.

3510{ Z3_sort s = Z3_mk_string_sort(m_ctx); check_error(); return sort(*this, s); }
Z3_sort Z3_API Z3_mk_string_sort(Z3_context c)
Create a sort for unicode strings.

Referenced by string_const().

◆ string_val() [1/4]

expr string_val ( char const * s)
inline

Definition at line 3865 of file z3++.h.

3865{ Z3_ast r = Z3_mk_string(m_ctx, s); check_error(); return expr(*this, r); }
Z3_ast Z3_API Z3_mk_string(Z3_context c, Z3_string s)
Create a string constant out of the string that is passed in The string may contain escape encoding f...

◆ string_val() [2/4]

expr string_val ( char const * s,
unsigned n )
inline

Definition at line 3864 of file z3++.h.

3864{ Z3_ast r = Z3_mk_lstring(m_ctx, n, s); check_error(); return expr(*this, r); }
Z3_ast Z3_API Z3_mk_lstring(Z3_context c, unsigned len, Z3_string s)
Create a string constant out of the string that is passed in It takes the length of the string as wel...

◆ string_val() [3/4]

expr string_val ( std::string const & s)
inline

Definition at line 3866 of file z3++.h.

3866{ Z3_ast r = Z3_mk_string(m_ctx, s.c_str()); check_error(); return expr(*this, r); }

◆ string_val() [4/4]

expr string_val ( std::u32string const & s)
inline

Definition at line 3867 of file z3++.h.

3867{ Z3_ast r = Z3_mk_u32string(m_ctx, (unsigned)s.size(), (unsigned const*)s.c_str()); check_error(); return expr(*this, r); }
Z3_ast Z3_API Z3_mk_u32string(Z3_context c, unsigned len, unsigned const chars[])
Create a string constant out of the string that is passed in It takes the length of the string as wel...

◆ tuple_sort()

func_decl tuple_sort ( char const * name,
unsigned n,
char const *const * names,
sort const * sorts,
func_decl_vector & projs )
inline

Return a tuple constructor. name is the name of the returned constructor, n are the number of arguments, names and sorts are their projected sorts. projs is an output parameter. It contains the set of projection functions.

Definition at line 3546 of file z3++.h.

3546 {
3547 array<Z3_symbol> _names(n);
3548 array<Z3_sort> _sorts(n);
3549 for (unsigned i = 0; i < n; i++) { _names[i] = Z3_mk_string_symbol(*this, names[i]); _sorts[i] = sorts[i]; }
3550 array<Z3_func_decl> _projs(n);
3551 Z3_symbol _name = Z3_mk_string_symbol(*this, name);
3552 Z3_func_decl tuple;
3553 sort _ignore_s = to_sort(*this, Z3_mk_tuple_sort(*this, _name, n, _names.ptr(), _sorts.ptr(), &tuple, _projs.ptr()));
3554 check_error();
3555 for (unsigned i = 0; i < n; i++) { projs.push_back(func_decl(*this, _projs[i])); }
3556 return func_decl(*this, tuple);
3557 }
Z3_sort Z3_API Z3_mk_tuple_sort(Z3_context c, Z3_symbol mk_tuple_name, unsigned num_fields, Z3_symbol const field_names[], Z3_sort const field_sorts[], Z3_func_decl *mk_tuple_decl, Z3_func_decl proj_decl[])
Create a tuple type.

◆ uninterpreted_sort() [1/2]

sort uninterpreted_sort ( char const * name)
inline

create an uninterpreted sort with the name given by the string or symbol.

Definition at line 3668 of file z3++.h.

3668 {
3669 Z3_symbol _name = Z3_mk_string_symbol(*this, name);
3670 return to_sort(*this, Z3_mk_uninterpreted_sort(*this, _name));
3671 }
Z3_sort Z3_API Z3_mk_uninterpreted_sort(Z3_context c, Z3_symbol s)
Create a free (uninterpreted) type using the given name (symbol).

◆ uninterpreted_sort() [2/2]

sort uninterpreted_sort ( symbol const & name)
inline

Definition at line 3672 of file z3++.h.

3672 {
3673 return to_sort(*this, Z3_mk_uninterpreted_sort(*this, name));
3674 }

◆ user_propagate_function()

func_decl user_propagate_function ( symbol const & name,
sort_vector const & domain,
sort const & range )
inline

Definition at line 3791 of file z3++.h.

3791 {
3792 check_context(domain, range);
3793 array<Z3_sort> domain1(domain);
3794 Z3_func_decl f = Z3_solver_propagate_declare(range.ctx(), name, domain1.size(), domain1.ptr(), range);
3795 check_error();
3796 return func_decl(*this, f);
3797 }
Z3_func_decl Z3_API Z3_solver_propagate_declare(Z3_context c, Z3_symbol name, unsigned n, Z3_sort *domain, Z3_sort range)

◆ variable()

expr variable ( unsigned index,
sort const & s )
inline

create a de-Bruijn variable.

Definition at line 3805 of file z3++.h.

3805 {
3806 Z3_ast r = Z3_mk_bound(m_ctx, idx, s);
3807 check_error();
3808 return expr(*this, r);
3809 }
Z3_ast Z3_API Z3_mk_bound(Z3_context c, unsigned index, Z3_sort ty)
Create a variable.

◆ user_propagator_base

friend class user_propagator_base
friend

Definition at line 162 of file z3++.h.

Referenced by user_propagator_base.