Message ID | 109060ccb8665c73aa0c4f73e3cbbddcd135bde4.1742107322.git.gitgitgadget@gmail.com (mailing list archive) |
---|---|
State | Superseded |
Headers | show |
Series | Add a static analysis job to prevent assertions with side effects | expand |
"Elijah Newren via GitGitGadget" <gitgitgadget@gmail.com> writes: > From: Elijah Newren <newren@gmail.com> > > Create a BUG_IF_NOT() macro which is similar to assert(), but will not be > compiled out when NDEBUG is defined, and is thus safe to use even if its > argument has side-effects. If this is meant to be "similar to" assert, let's not call it BUG_IF_NOT(). The point of BUG() is that the developer can mark the problem with something more than just a conditional, and it feels funny to call a facility that lacks that central feature with a name with BUG in it. ASSERT(), safer_assert(), safe_assert(), sane_assert()? The last one is in line with safe_istest() that is used on sane_ctype[] and sane_qsort(), with the intention to allow developers to write right code more easily than using the plain vanilla C. Thanks.
On Mon, Mar 17, 2025 at 03:33:50PM -0700, Junio C Hamano wrote: > "Elijah Newren via GitGitGadget" <gitgitgadget@gmail.com> writes: > > > From: Elijah Newren <newren@gmail.com> > > > > Create a BUG_IF_NOT() macro which is similar to assert(), but will not be > > compiled out when NDEBUG is defined, and is thus safe to use even if its > > argument has side-effects. > > If this is meant to be "similar to" assert, let's not call it > BUG_IF_NOT(). The point of BUG() is that the developer can mark the > problem with something more than just a conditional, and it feels > funny to call a facility that lacks that central feature with a name > with BUG in it. > > ASSERT(), safer_assert(), safe_assert(), sane_assert()? > > The last one is in line with safe_istest() that is used on > sane_ctype[] and sane_qsort(), with the intention to allow > developers to write right code more easily than using the plain > vanilla C. For my $.02, I prefer ASSERT() to the other options. It's clear, but indicates that it's a macro and thus not the same as assert(3). But I don't have a strong opinion here. Thanks, Taylor
diff --git a/git-compat-util.h b/git-compat-util.h index e123288e8f1..c3415ad7e0a 100644 --- a/git-compat-util.h +++ b/git-compat-util.h @@ -1460,6 +1460,7 @@ extern int bug_called_must_BUG; __attribute__((format (printf, 3, 4))) NORETURN void BUG_fl(const char *file, int line, const char *fmt, ...); #define BUG(...) BUG_fl(__FILE__, __LINE__, __VA_ARGS__) +#define BUG_IF_NOT(a) if (!(a)) BUG("Assertion `" #a "' failed.") __attribute__((format (printf, 3, 4))) void bug_fl(const char *file, int line, const char *fmt, ...); #define bug(...) bug_fl(__FILE__, __LINE__, __VA_ARGS__)