mirror of
https://github.com/Z3Prover/z3
synced 2025-04-23 09:05:31 +00:00
theory_str model validation for Length
This commit is contained in:
parent
cb566ad5ce
commit
3dff240bb3
2 changed files with 19 additions and 2 deletions
|
@ -26,7 +26,7 @@ Notes:
|
|||
br_status str_rewriter::mk_str_Concat(expr * arg0, expr * arg1, expr_ref & result) {
|
||||
TRACE("t_str_rw", tout << "rewrite (Concat " << mk_pp(arg0, m()) << " " << mk_pp(arg1, m()) << ")" << std::endl;);
|
||||
if(m_strutil.is_string(arg0) && m_strutil.is_string(arg1)) {
|
||||
TRACE("t_str_rw", tout << "evaluating Concat of two constant strings" << std::endl;);
|
||||
TRACE("t_str_rw", tout << "evaluating concat of two constant strings" << std::endl;);
|
||||
std::string arg0Str = m_strutil.get_string_constant_value(arg0);
|
||||
std::string arg1Str = m_strutil.get_string_constant_value(arg1);
|
||||
std::string resultStr = arg0Str + arg1Str;
|
||||
|
@ -37,6 +37,20 @@ br_status str_rewriter::mk_str_Concat(expr * arg0, expr * arg1, expr_ref & resul
|
|||
}
|
||||
}
|
||||
|
||||
br_status str_rewriter::mk_str_Length(expr * arg0, expr_ref & result) {
|
||||
TRACE("t_str_rw", tout << "rewrite (Length " << mk_pp(arg0, m()) << ")" << std::endl;);
|
||||
if (m_strutil.is_string(arg0)) {
|
||||
TRACE("t_str_rw", tout << "evaluating length of constant string" << std::endl;);
|
||||
std::string arg0Str = m_strutil.get_string_constant_value(arg0);
|
||||
rational arg0Len((unsigned)arg0Str.length());
|
||||
result = m_autil.mk_numeral(arg0Len, true);
|
||||
TRACE("t_str_rw", tout << "result is " << mk_pp(result, m()) << std::endl;);
|
||||
return BR_DONE;
|
||||
} else {
|
||||
return BR_FAILED;
|
||||
}
|
||||
}
|
||||
|
||||
br_status str_rewriter::mk_str_CharAt(expr * arg0, expr * arg1, expr_ref & result) {
|
||||
TRACE("t_str_rw", tout << "rewrite (CharAt " << mk_pp(arg0, m()) << " " << mk_pp(arg1, m()) << ")" << std::endl;);
|
||||
// if arg0 is a string constant and arg1 is an integer constant,
|
||||
|
@ -287,11 +301,13 @@ br_status str_rewriter::mk_app_core(func_decl * f, unsigned num_args, expr * con
|
|||
|
||||
TRACE("t_str_rw", tout << "rewrite app: " << f->get_name() << std::endl;);
|
||||
|
||||
// TODO more rewrites for really easy cases, e.g. (Concat "abc" "def")...
|
||||
switch(f->get_decl_kind()) {
|
||||
case OP_STRCAT:
|
||||
SASSERT(num_args == 2);
|
||||
return mk_str_Concat(args[0], args[1], result);
|
||||
case OP_STRLEN:
|
||||
SASSERT(num_args == 1);
|
||||
return mk_str_Length(args[0], result);
|
||||
case OP_STR_CHARAT:
|
||||
SASSERT(num_args == 2);
|
||||
return mk_str_CharAt(args[0], args[1], result);
|
||||
|
|
|
@ -41,6 +41,7 @@ public:
|
|||
br_status mk_eq_core(expr * lhs, expr * rhs, expr_ref & result);
|
||||
|
||||
br_status mk_str_Concat(expr * arg0, expr * arg1, expr_ref & result);
|
||||
br_status mk_str_Length(expr * arg0, expr_ref & result);
|
||||
br_status mk_str_CharAt(expr * arg0, expr * arg1, expr_ref & result);
|
||||
br_status mk_str_StartsWith(expr * haystack, expr * needle, expr_ref & result);
|
||||
br_status mk_str_EndsWith(expr * haystack, expr * needle, expr_ref & result);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue