mirror of
				https://github.com/Z3Prover/z3
				synced 2025-10-31 11:42:28 +00:00 
			
		
		
		
	Add srem, urem, shift, ext operators to c++ api
This commit is contained in:
		
							parent
							
								
									7a317a4f07
								
							
						
					
					
						commit
						ae2821dea1
					
				
					 1 changed files with 46 additions and 1 deletions
				
			
		|  | @ -1275,6 +1275,51 @@ namespace z3 { | ||||||
|     inline expr udiv(expr const & a, int b) { return udiv(a, a.ctx().num_val(b, a.get_sort())); } |     inline expr udiv(expr const & a, int b) { return udiv(a, a.ctx().num_val(b, a.get_sort())); } | ||||||
|     inline expr udiv(int a, expr const & b) { return udiv(b.ctx().num_val(a, b.get_sort()), b); } |     inline expr udiv(int a, expr const & b) { return udiv(b.ctx().num_val(a, b.get_sort()), b); } | ||||||
| 
 | 
 | ||||||
|  | 	/**
 | ||||||
|  | 		\brief signed reminder operator for bitvectors | ||||||
|  | 	*/ | ||||||
|  | 	inline expr srem(expr const & a, expr const & b) { return to_expr(a.ctx(), Z3_mk_bvsrem(a.ctx(), a, b)); } | ||||||
|  | 	inline expr srem(expr const & a, int b) { return srem(a, a.ctx().num_val(b, a.get_sort())); } | ||||||
|  | 	inline expr srem(int a, expr const & b) { return srem(b.ctx().num_val(a, b.get_sort()), b); } | ||||||
|  | 
 | ||||||
|  | 	/**
 | ||||||
|  | 	\brief unsigned reminder operator for bitvectors | ||||||
|  | 	*/ | ||||||
|  | 	inline expr urem(expr const & a, expr const & b) { return to_expr(a.ctx(), Z3_mk_bvurem(a.ctx(), a, b)); } | ||||||
|  | 	inline expr urem(expr const & a, int b) { return urem(a, a.ctx().num_val(b, a.get_sort())); } | ||||||
|  | 	inline expr urem(int a, expr const & b) { return urem(b.ctx().num_val(a, b.get_sort()), b); } | ||||||
|  | 
 | ||||||
|  | 	/**
 | ||||||
|  | 	\brief shift left operator for bitvectors | ||||||
|  | 	*/ | ||||||
|  | 	inline expr shl(expr const & a, expr const & b) { return to_expr(a.ctx(), Z3_mk_bvshl(a.ctx(), a, b)); } | ||||||
|  | 	inline expr shl(expr const & a, int b) { return shl(a, a.ctx().num_val(b, a.get_sort())); } | ||||||
|  | 	inline expr shl(int a, expr const & b) { return shl(b.ctx().num_val(a, b.get_sort()), b); } | ||||||
|  | 
 | ||||||
|  | 	/**
 | ||||||
|  | 	\brief logic shift right operator for bitvectors | ||||||
|  | 	*/ | ||||||
|  | 	inline expr lshr(expr const & a, expr const & b) { return to_expr(a.ctx(), Z3_mk_bvlshr(a.ctx(), a, b)); } | ||||||
|  | 	inline expr lshr(expr const & a, int b) { return lshr(a, a.ctx().num_val(b, a.get_sort())); } | ||||||
|  | 	inline expr lshr(int a, expr const & b) { return lshr(b.ctx().num_val(a, b.get_sort()), b); } | ||||||
|  | 
 | ||||||
|  | 	/**
 | ||||||
|  | 	\brief arithmetic shift right operator for bitvectors | ||||||
|  | 	*/ | ||||||
|  | 	inline expr ashr(expr const & a, expr const & b) { return to_expr(a.ctx(), Z3_mk_bvashr(a.ctx(), a, b)); } | ||||||
|  | 	inline expr ashr(expr const & a, int b) { return ashr(a, a.ctx().num_val(b, a.get_sort())); } | ||||||
|  | 	inline expr ashr(int a, expr const & b) { return ashr(b.ctx().num_val(a, b.get_sort()), b); } | ||||||
|  | 
 | ||||||
|  | 	/**
 | ||||||
|  | 	\brief Extend the given bit-vector with zeros to the (unsigned) equivalent bitvector of size m+i, where m is the size of the given bit-vector. | ||||||
|  | 	*/ | ||||||
|  | 	inline expr zext(expr const & a, unsigned i) { return to_expr(a.ctx(), Z3_mk_zero_ext(a.ctx(), i, a)); } | ||||||
|  | 
 | ||||||
|  | 	/**
 | ||||||
|  | 	\brief Sign-extend of the given bit-vector to the (signed) equivalent bitvector of size m+i, where m is the size of the given bit-vector. | ||||||
|  | 	*/ | ||||||
|  | 	inline expr sext(expr const & a, unsigned i) { return to_expr(a.ctx(), Z3_mk_sign_ext(a.ctx(), i, a)); } | ||||||
|  | 
 | ||||||
|     template<typename T> class cast_ast; |     template<typename T> class cast_ast; | ||||||
| 
 | 
 | ||||||
|     template<> class cast_ast<ast> { |     template<> class cast_ast<ast> { | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue