mirror of
https://github.com/netwide-assembler/nasm.git
synced 2025-03-31 18:20:22 +08:00
nasm.c: Fix is_suppressed_warning()
The logic in is_suppressed_warning() was severely wrong, which would cause a lot of legitimate warnings to be suppressed while some warnings would be duplicated. Signed-off-by: H. Peter Anvin <hpa@zytor.com>
This commit is contained in:
parent
10da41e328
commit
442a05a897
13
nasm.c
13
nasm.c
@ -1915,23 +1915,20 @@ static void nasm_verror_vc(int severity, const char *fmt, va_list ap)
|
||||
*/
|
||||
static bool is_suppressed_warning(int severity)
|
||||
{
|
||||
|
||||
/* Not a warning at all */
|
||||
if ((severity & ERR_MASK) != ERR_WARNING)
|
||||
return false;
|
||||
|
||||
/* Might be a warning but suppresed explicitly */
|
||||
if (severity & ERR_WARN_MASK) {
|
||||
if (warning_on[WARN_IDX(severity)])
|
||||
return false;
|
||||
}
|
||||
|
||||
/* See if it's a pass-one only warning and we're not in pass one. */
|
||||
if (((severity & ERR_PASS1) && pass0 != 1) ||
|
||||
((severity & ERR_PASS2) && pass0 != 2))
|
||||
return true;
|
||||
|
||||
return true;
|
||||
/* Might be a warning but suppresed explicitly */
|
||||
if (severity & ERR_WARN_MASK)
|
||||
return !warning_on[WARN_IDX(severity)];
|
||||
else
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
|
Loading…
x
Reference in New Issue
Block a user