1 /* Run-time assert-like macros.
2 
3    Copyright (C) 2014-2020 Free Software Foundation, Inc.
4 
5    This program is free software: you can redistribute it and/or modify
6    it under the terms of the GNU General Public License as published by
7    the Free Software Foundation; either version 3 of the License, or
8    (at your option) any later version.
9 
10    This program is distributed in the hope that it will be useful,
11    but WITHOUT ANY WARRANTY; without even the implied warranty of
12    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13    GNU General Public License for more details.
14 
15    You should have received a copy of the GNU General Public License
16    along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
17 
18 /* Written by Paul Eggert.  */
19 
20 #ifndef _GL_ASSURE_H
21 #define _GL_ASSURE_H
22 
23 #include <assert.h>
24 #include "verify.h"
25 
26 /* Evaluate an assertion E that is guaranteed to be true.
27    If NDEBUG is not defined, abort the program if E is false.
28    If NDEBUG is defined, the compiler can assume E and behavior is
29    undefined if E is false, fails to evaluate, or has side effects.
30 
31    Unlike standard 'assert', this macro evaluates E even when NDEBUG
32    is defined, so as to catch typos, avoid some GCC warnings, and
33    improve performance when E is simple enough.
34 
35    Also see the documentation for 'assume' in verify.h.  */
36 
37 #ifdef NDEBUG
38 # define affirm(E) assume (E)
39 #else
40 # define affirm(E) assert (E)
41 #endif
42 
43 /* Check E's value at runtime, and report an error and abort if not.
44    However, do nothing if NDEBUG is defined.
45 
46    Unlike standard 'assert', this macro compiles E even when NDEBUG
47    is defined, so as to catch typos and avoid some GCC warnings.
48    Unlike 'affirm', it is OK for E to use hard-to-optimize features,
49    since E is not executed if NDEBUG is defined.  */
50 
51 #ifdef NDEBUG
52 # define assure(E) ((void) (0 && (E)))
53 #else
54 # define assure(E) assert (E)
55 #endif
56 
57 #endif
58