mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2024-11-21 23:20:20 +00:00
AK: Ignore -Wshadow in TRY() and MUST()
This makes the warning in CLion disappear when nesting them.
This commit is contained in:
parent
d2e143eec7
commit
5103e08b77
Notes:
sideshowbarker
2024-07-17 03:42:31 +09:00
Author: https://github.com/linusg Commit: https://github.com/SerenityOS/serenity/commit/5103e08b77 Pull-request: https://github.com/SerenityOS/serenity/pull/16338 Reviewed-by: https://github.com/awesomekling ✅
1 changed files with 17 additions and 11 deletions
28
AK/Try.h
28
AK/Try.h
|
@ -6,6 +6,8 @@
|
|||
|
||||
#pragma once
|
||||
|
||||
#include <AK/Diagnostics.h>
|
||||
|
||||
// NOTE: This macro works with any result type that has the expected APIs.
|
||||
// It's designed with AK::Result and AK::Error in mind.
|
||||
//
|
||||
|
@ -14,17 +16,21 @@
|
|||
// by at least clang and gcc.
|
||||
// [1] https://gcc.gnu.org/onlinedocs/gcc/Statement-Exprs.html
|
||||
|
||||
#define TRY(expression) \
|
||||
({ \
|
||||
auto _temporary_result = (expression); \
|
||||
if (_temporary_result.is_error()) [[unlikely]] \
|
||||
return _temporary_result.release_error(); \
|
||||
_temporary_result.release_value(); \
|
||||
#define TRY(expression) \
|
||||
({ \
|
||||
/* Ignore -Wshadow to allow nesting the macro. */ \
|
||||
AK_IGNORE_DIAGNOSTIC("-Wshadow", \
|
||||
auto _temporary_result = (expression)); \
|
||||
if (_temporary_result.is_error()) [[unlikely]] \
|
||||
return _temporary_result.release_error(); \
|
||||
_temporary_result.release_value(); \
|
||||
})
|
||||
|
||||
#define MUST(expression) \
|
||||
({ \
|
||||
auto _temporary_result = (expression); \
|
||||
VERIFY(!_temporary_result.is_error()); \
|
||||
_temporary_result.release_value(); \
|
||||
#define MUST(expression) \
|
||||
({ \
|
||||
/* Ignore -Wshadow to allow nesting the macro. */ \
|
||||
AK_IGNORE_DIAGNOSTIC("-Wshadow", \
|
||||
auto _temporary_result = (expression)); \
|
||||
VERIFY(!_temporary_result.is_error()); \
|
||||
_temporary_result.release_value(); \
|
||||
})
|
||||
|
|
Loading…
Reference in a new issue