Skip to content

Commit 8d81a2d

Browse files
authored
Note that Z3_get_numeral_small is essentially redundant (#7599)
* Check that Z3_get_numeral_small is given non-null out params Analogous to other Z3_get_numeral_* functions with out params. * Note that Z3_get_numeral_small is essentially redundant The error behavior of Z3_get_numeral_small does not follow the pattern of the other functions. The functions that have out params and return a bool indicating success (such as Z3_get_numeral_rational_int64) return false rather than signaling an error when given an unsupported expression argument (such as a rounding mode value). The functions that do not have out params signal an error in such cases. Z3_get_numeral_small is the odd one out in that it signals errors and returns a status bool. This error handling is the only difference between Z3_get_numeral_small and Z3_get_numeral_rational_int64, so this patch adds a comment to the documentation.
1 parent 63ad283 commit 8d81a2d

File tree

2 files changed

+6
-0
lines changed

2 files changed

+6
-0
lines changed

src/api/api_numeral.cpp

+4
Original file line numberDiff line numberDiff line change
@@ -318,6 +318,10 @@ extern "C" {
318318
LOG_Z3_get_numeral_small(c, a, num, den);
319319
RESET_ERROR_CODE();
320320
CHECK_IS_EXPR(a, false);
321+
if (!num || !den) {
322+
SET_ERROR_CODE(Z3_INVALID_ARG, nullptr);
323+
return false;
324+
}
321325
rational r;
322326
bool ok = Z3_get_numeral_rational(c, a, r);
323327
if (ok) {

src/api/z3_api.h

+2
Original file line numberDiff line numberDiff line change
@@ -5109,6 +5109,8 @@ extern "C" {
51095109
51105110
Return \c true if the numeral value fits in 64 bit numerals, \c false otherwise.
51115111
5112+
Equivalent to \c Z3_get_numeral_rational_int64 except that for unsupported expression arguments \c Z3_get_numeral_small signals an error while \c Z3_get_numeral_rational_int64 returns \c false.
5113+
51125114
\pre Z3_get_ast_kind(a) == Z3_NUMERAL_AST
51135115
51145116
def_API('Z3_get_numeral_small', BOOL, (_in(CONTEXT), _in(AST), _out(INT64), _out(INT64)))

0 commit comments

Comments
 (0)