33 if(
const auto i = numeric_cast<unsigned long>(
simplify_expr(expr, ns)))
42 DEPRECATED(
SINCE(2017, 10, 5,
"use add_axioms_for_string_of_int instead"))
47 PRECONDITION(f.arguments().size() == 3 || f.arguments().size() == 4);
49 array_pool.
find(f.arguments()[1], f.arguments()[0]);
50 if(f.arguments().size() == 4)
51 return add_axioms_for_string_of_int_with_radix(
52 res, f.arguments()[2], f.arguments()[3], 0);
54 return add_axioms_for_string_of_int(res, f.arguments()[2], 0);
63 DEPRECATED(
SINCE(2017, 10, 5,
"Java specific, should be implemented in Java"))
80 std::string str_true =
"true";
82 eq,
equal_to(array_pool.get_or_create_length(res), str_true.length()));
85 for(std::size_t i = 0; i < str_true.length(); i++)
92 std::string str_false =
"false";
95 equal_to(array_pool.get_or_create_length(res), str_false.length()));
98 for(std::size_t i = 0; i < str_false.length(); i++)
116 std::pair<exprt, string_constraintst>
119 const exprt &input_int,
124 res, input_int, radix, max_size);
136 std::pair<exprt, string_constraintst>
139 const exprt &input_int,
143 PRECONDITION(max_size < std::numeric_limits<size_t>::max());
150 CHECK_RETURN((radix_ul >= 2 && radix_ul <= 36) || radix_ul == 0);
155 CHECK_RETURN(max_size < std::numeric_limits<size_t>::max());
161 const bool strict_formatting =
true;
164 res, radix_as_char, radix_ul, max_size, strict_formatting);
173 result2.existential.push_back(
conjunction(std::move(result1)));
198 DEPRECATED(
SINCE(2017, 10, 5,
"use add_axioms_for_string_of_int_with_radix"))
204 const typet &type = i.type();
221 for(
size_t size = 1; size <= max_size; size++)
227 for(
size_t j = 0; j < size; j++)
243 equal_to(array_pool.get_or_create_length(res), size);
258 std::pair<exprt, string_constraintst>
281 const exprt &radix_as_char,
282 const unsigned long radix_ul,
283 const std::size_t max_size,
284 const bool strict_formatting)
286 std::vector<exprt> conjuncts;
290 const exprt &chr = str[0];
293 const exprt starts_with_digit =
299 conjuncts.push_back(non_empty);
301 if(strict_formatting)
304 const or_exprt correct_first(starts_with_minus, starts_with_digit);
305 conjuncts.push_back(correct_first);
311 starts_with_minus, starts_with_digit, starts_with_plus);
312 conjuncts.push_back(correct_first);
317 or_exprt(starts_with_minus, starts_with_plus),
320 conjuncts.push_back(contains_digit);
329 for(std::size_t index = 1; index < max_size; ++index)
337 str[index], strict_formatting, radix_as_char, radix_ul));
338 conjuncts.push_back(character_at_index_is_digit);
341 if(strict_formatting)
350 conjuncts.push_back(no_leading_zero);
355 conjuncts.push_back(no_leading_zero_after_minus);
374 const exprt &input_int,
376 const bool strict_formatting,
378 const std::size_t max_string_length,
380 const unsigned long radix_ul)
389 str[0],
char_type, type, strict_formatting, radix_ul);
398 for(
size_t size = 2; size <= max_string_length; size++)
418 str[size - 1],
char_type, type, strict_formatting, radix_ul));
425 if(size - 1 >= max_string_length - 2 || radix_ul == 0)
434 if(no_overflow.has_value())
450 and_exprt(string_length_equals_size, starts_with_minus),
460 const typet &target_int_type)
473 PRECONDITION((radix_ul >= 2 && radix_ul <= 36) || radix_ul == 0);
475 const std::size_t max_string_length =
478 return {str, radix, radix_ul, max_string_length};
488 std::pair<exprt, string_constraintst>
494 called_function == ID_cprover_string_is_valid_int_func ||
495 called_function == ID_cprover_string_is_valid_long_func);
497 called_function == ID_cprover_string_is_valid_int_func ? 32 : 64)};
503 const bool strict_formatting =
false;
511 args.max_string_length,
524 std::pair<exprt, string_constraintst>
533 const bool strict_formatting =
false;
540 args.max_string_length,
544 return {input_int, std::move(constraints2)};
557 const bool strict_formatting,
558 const exprt &radix_as_char,
559 const unsigned long radix_ul)
561 PRECONDITION((radix_ul >= 2 && radix_ul <= 36) || radix_ul == 0);
565 const and_exprt is_digit_when_radix_le_10(
569 if(radix_ul <= 10 && radix_ul != 0)
571 return is_digit_when_radix_le_10;
579 const minus_exprt radix_minus_ten(radix_as_char, ten_char_type);
588 chr, ID_lt,
plus_exprt(a_char, radix_minus_ten))));
590 if(!strict_formatting)
596 chr, ID_lt,
plus_exprt(A_char, radix_minus_ten))));
603 is_digit_when_radix_le_10,
604 is_digit_when_radix_gt_10);
608 return std::move(is_digit_when_radix_gt_10);
627 const bool strict_formatting,
628 const unsigned long radix_ul)
635 chr, ID_ge, zero_char);
637 if(radix_ul <= 10 && radix_ul != 0)
642 upper_case_lower_case_or_digit,
655 if(strict_formatting)
664 upper_case_lower_case_or_digit,
679 upper_case_or_lower_case,
682 upper_case_lower_case_or_digit,
704 double radix =
static_cast<double>(radix_ul);
705 bool signed_type = type.
id() == ID_signedbv;
724 double max = signed_type
725 ? floor(
static_cast<double>(n_bits - 1) / log2(radix)) + 2.0
726 : ceil(
static_cast<double>(n_bits) / log2(radix));
727 return static_cast<size_t>(max);