cprover
boolbv_union.cpp
Go to the documentation of this file.
1 /*******************************************************************\
2 
3 Module:
4 
5 Author: Daniel Kroening, kroening@kroening.com
6 
7 \*******************************************************************/
8 
9 #include "boolbv.h"
10 
12 {
13  std::size_t width=boolbv_width(expr.type());
14 
15  if(width==0)
16  return conversion_failed(expr);
17 
18  const bvt &op_bv=convert_bv(expr.op());
19 
20  INVARIANT(
21  op_bv.size() <= width,
22  "operand bitvector width shall not be larger than the width indicated by "
23  "the union type");
24 
25  bvt bv;
26  bv.resize(width);
27 
28  endianness_mapt map_u = endianness_map(expr.type());
29  endianness_mapt map_op = endianness_map(expr.op().type());
30 
31  for(std::size_t i = 0; i < op_bv.size(); i++)
32  bv[map_u.map_bit(i)] = op_bv[map_op.map_bit(i)];
33 
34  // pad with nondets
35  for(std::size_t i = op_bv.size(); i < bv.size(); i++)
36  bv[map_u.map_bit(i)] = prop.new_variable();
37 
38  return bv;
39 }
bvt
std::vector< literalt > bvt
Definition: literal.h:201
union_exprt
Union constructor from single element.
Definition: std_expr.h:1516
propt::new_variable
virtual literalt new_variable()=0
boolbvt::convert_union
virtual bvt convert_union(const union_exprt &expr)
Definition: boolbv_union.cpp:11
exprt::type
typet & type()
Return the type of the expression.
Definition: expr.h:82
boolbvt::conversion_failed
void conversion_failed(const exprt &expr, bvt &bv)
Definition: boolbv.h:126
boolbvt::boolbv_width
virtual std::size_t boolbv_width(const typet &type) const
Definition: boolbv.h:96
endianness_mapt::map_bit
size_t map_bit(size_t bit) const
Definition: endianness_map.h:47
unary_exprt::op
const exprt & op() const
Definition: std_expr.h:293
boolbvt::convert_bv
virtual const bvt & convert_bv(const exprt &expr, const optionalt< std::size_t > expected_width=nullopt)
Convert expression to vector of literalts, using an internal cache to speed up conversion if availabl...
Definition: boolbv.cpp:47
endianness_mapt
Maps a big-endian offset to a little-endian offset.
Definition: endianness_map.h:31
boolbv.h
boolbvt::endianness_map
virtual endianness_mapt endianness_map(const typet &type, bool little_endian) const
Definition: boolbv.h:102
INVARIANT
#define INVARIANT(CONDITION, REASON)
This macro uses the wrapper function 'invariant_violated_string'.
Definition: invariant.h:424
prop_conv_solvert::prop
propt & prop
Definition: prop_conv_solver.h:128