Skip to content

Commit f6e617d

Browse files
committed
byte_extract lowering: lower newly introduced byte_extract expressions
byte_extract lowering must not return any further byte_extract expressions.
1 parent a8c5ee0 commit f6e617d

File tree

2 files changed

+3
-4
lines changed

2 files changed

+3
-4
lines changed

src/solvers/lowering/byte_operators.cpp

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -289,7 +289,7 @@ exprt lower_byte_extract(const byte_extract_exprt &src, const namespacet &ns)
289289
tmp.type()=comp.type();
290290
tmp.offset()=new_offset;
291291

292-
s.add_to_operands(std::move(tmp));
292+
s.add_to_operands(lower_byte_extract(tmp, ns));
293293
}
294294

295295
if(!failed)

unit/solvers/lowering/byte_operators.cpp

Lines changed: 2 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -154,9 +154,8 @@ SCENARIO("byte_extract_lowering", "[core][solvers][lowering][byte_extract]")
154154
const exprt lower_be = lower_byte_extract(be, ns);
155155
const exprt lower_be_s = simplify_expr(lower_be, ns);
156156

157-
// TODO: does not currently hold
158-
// REQUIRE(!has_subexpr(lower_be, ID_byte_extract_little_endian));
159-
// REQUIRE(!has_subexpr(lower_be, ID_byte_extract_big_endian));
157+
REQUIRE(!has_subexpr(lower_be, ID_byte_extract_little_endian));
158+
REQUIRE(!has_subexpr(lower_be, ID_byte_extract_big_endian));
160159
REQUIRE(lower_be.type() == be.type());
161160
// TODO: does not currently hold
162161
// REQUIRE(lower_be == r);

0 commit comments

Comments
 (0)