]> git.ipfire.org Git - thirdparty/krb5.git/commitdiff
Avoid side effects in assert expressions
authorTom Yu <tlyu@mit.edu>
Mon, 22 Apr 2013 23:02:56 +0000 (19:02 -0400)
committerTom Yu <tlyu@mit.edu>
Mon, 22 Apr 2013 23:58:13 +0000 (19:58 -0400)
asserts may be compiled out with -DNDEBUG, so it's wrong to use an
assert expression with an important side effect.

(We also have scores of side-effecting asserts in test programs, but
those are less important and can be dealt with separately.)

(back ported from commit 221cd4a23691601a14500bc00146c265b50bdc94)

ticket: 7614 (new)
version_fixed: 1.9.5
status: resolved

src/lib/crypto/krb/cf2.c
src/util/et/com_err.c

index ab0a134b9d7a5b8c06237ea2a0886ef4183bbac2..29e59d09ec64597fc2adfad3cbb1ecadf6d14a60 100644 (file)
@@ -112,7 +112,8 @@ krb5_c_fx_cf2_simple(krb5_context context,
         return KRB5_BAD_ENCTYPE;
     out_enctype_num = k1->enctype;
     assert(out != NULL);
-    assert((out_enctype = find_enctype(out_enctype_num)) != NULL);
+    out_enctype = find_enctype(out_enctype_num);
+    assert(out_enctype != NULL);
     if (out_enctype->prf == NULL) {
         if (context)
             krb5int_set_error(&(context->err), KRB5_CRYPTO_INTERNAL,
index aaba89744f792216b39be21dd2d37dd55f318d9c..96922ec24f49de581d86f340b2ca81f67b3196c5 100644 (file)
@@ -154,8 +154,10 @@ et_old_error_hook_func set_com_err_hook (et_old_error_hook_func new_proc)
     et_old_error_hook_func x;
 
     /* Broken initialization?  What can we do?  */
-    assert(com_err_finish_init() == 0);
-    assert(com_err_lock_hook_handle() == 0);
+    if (com_err_finish_init() != 0)
+        abort();
+    if (com_err_lock_hook_handle() != 0)
+        abort();
     x = com_err_hook;
     com_err_hook = new_proc;
     k5_mutex_unlock(&com_err_hook_lock);
@@ -167,8 +169,10 @@ et_old_error_hook_func reset_com_err_hook ()
     et_old_error_hook_func x;
 
     /* Broken initialization?  What can we do?  */
-    assert(com_err_finish_init() == 0);
-    assert(com_err_lock_hook_handle() == 0);
+    if (com_err_finish_init() != 0)
+        abort();
+    if (com_err_lock_hook_handle() != 0)
+        abort();
     x = com_err_hook;
     com_err_hook = NULL;
     k5_mutex_unlock(&com_err_hook_lock);