| 1 | /* Macros for controlling diagnostic output from the compiler. | 
|---|
| 2 | Copyright (C) 2014-2020 Free Software Foundation, Inc. | 
|---|
| 3 | This file is part of the GNU C Library. | 
|---|
| 4 |  | 
|---|
| 5 | The GNU C Library is free software; you can redistribute it and/or | 
|---|
| 6 | modify it under the terms of the GNU Lesser General Public | 
|---|
| 7 | License as published by the Free Software Foundation; either | 
|---|
| 8 | version 2.1 of the License, or (at your option) any later version. | 
|---|
| 9 |  | 
|---|
| 10 | The GNU C Library 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 GNU | 
|---|
| 13 | Lesser General Public License for more details. | 
|---|
| 14 |  | 
|---|
| 15 | You should have received a copy of the GNU Lesser General Public | 
|---|
| 16 | License along with the GNU C Library; if not, see | 
|---|
| 17 | <https://www.gnu.org/licenses/>.  */ | 
|---|
| 18 |  | 
|---|
| 19 | #ifndef _LIBC_DIAG_H | 
|---|
| 20 | #define _LIBC_DIAG_H 1 | 
|---|
| 21 |  | 
|---|
| 22 | /* Ignore the value of an expression when a cast to void does not | 
|---|
| 23 | suffice (in particular, for a call to a function declared with | 
|---|
| 24 | attribute warn_unused_result).  */ | 
|---|
| 25 | #define ignore_value(x) \ | 
|---|
| 26 | ({ __typeof__ (x) __ignored_value = (x); (void) __ignored_value; }) | 
|---|
| 27 |  | 
|---|
| 28 | /* The macros to control diagnostics are structured like this, rather | 
|---|
| 29 | than a single macro that both pushes and pops diagnostic state and | 
|---|
| 30 | takes the affected code as an argument, because the GCC pragmas | 
|---|
| 31 | work by disabling the diagnostic for a range of source locations | 
|---|
| 32 | and do not work when all the pragmas and the affected code are in a | 
|---|
| 33 | single macro expansion.  */ | 
|---|
| 34 |  | 
|---|
| 35 | /* Push diagnostic state.  */ | 
|---|
| 36 | #define  _Pragma ("GCC diagnostic push") | 
|---|
| 37 |  | 
|---|
| 38 | /* Pop diagnostic state.  */ | 
|---|
| 39 | #define  _Pragma ("GCC diagnostic pop") | 
|---|
| 40 |  | 
|---|
| 41 | #define _DIAG_STR1(s) #s | 
|---|
| 42 | #define _DIAG_STR(s) _DIAG_STR1(s) | 
|---|
| 43 |  | 
|---|
| 44 | /* Ignore the diagnostic OPTION.  VERSION is the most recent GCC | 
|---|
| 45 | version for which the diagnostic has been confirmed to appear in | 
|---|
| 46 | the absence of the pragma (in the form MAJOR.MINOR for GCC 4.x, | 
|---|
| 47 | just MAJOR for GCC 5 and later).  Uses of this pragma should be | 
|---|
| 48 | reviewed when the GCC version given is no longer supported for | 
|---|
| 49 | building glibc; the version number should always be on the same | 
|---|
| 50 | source line as the macro name, so such uses can be found with grep. | 
|---|
| 51 | Uses should come with a comment giving more details of the | 
|---|
| 52 | diagnostic, and an architecture on which it is seen if possibly | 
|---|
| 53 | optimization-related and not in architecture-specific code.  This | 
|---|
| 54 | macro should only be used if the diagnostic seems hard to fix (for | 
|---|
| 55 | example, optimization-related false positives).  */ | 
|---|
| 56 | #define (version, option)     \ | 
|---|
| 57 | _Pragma (_DIAG_STR (GCC diagnostic ignored option)) | 
|---|
| 58 |  | 
|---|
| 59 | /* Similar to DIAG_IGNORE_NEEDS_COMMENT the following macro ignores the | 
|---|
| 60 | diagnostic OPTION but only if optimizations for size are enabled. | 
|---|
| 61 | This is required because different warnings may be generated for | 
|---|
| 62 | different optimization levels.  For example a key piece of code may | 
|---|
| 63 | only generate a warning when compiled at -Os, but at -O2 you could | 
|---|
| 64 | still want the warning to be enabled to catch errors.  In this case | 
|---|
| 65 | you would use DIAG_IGNORE_Os_NEEDS_COMMENT to disable the warning | 
|---|
| 66 | only for -Os.  */ | 
|---|
| 67 | #ifdef __OPTIMIZE_SIZE__ | 
|---|
| 68 | # define DIAG_IGNORE_Os_NEEDS_COMMENT(version, option) \ | 
|---|
| 69 | _Pragma (_DIAG_STR (GCC diagnostic ignored option)) | 
|---|
| 70 | #else | 
|---|
| 71 | # define (version, option) | 
|---|
| 72 | #endif | 
|---|
| 73 |  | 
|---|
| 74 | #endif /* libc-diag.h */ | 
|---|
| 75 |  | 
|---|