diff options
author | rtk0c <[email protected]> | 2022-04-06 20:52:51 -0700 |
---|---|---|
committer | rtk0c <[email protected]> | 2022-04-06 20:52:51 -0700 |
commit | f163e8f37123e651ea80b690793845b31ddb8639 (patch) | |
tree | e2c9f14d600f073533c9d01cfb90c4d60938127c /source/Macros.hpp | |
parent | 11edae3fbf770695d1b263712ca4f3a40bdd70e3 (diff) |
Changeset: 2 Work on moving infrastruture to this project
Diffstat (limited to 'source/Macros.hpp')
-rw-r--r-- | source/Macros.hpp | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/source/Macros.hpp b/source/Macros.hpp new file mode 100644 index 0000000..71a438a --- /dev/null +++ b/source/Macros.hpp @@ -0,0 +1,29 @@ +#pragma once + +#define STRINGIFY_IMPL(text) #text +#define STRINGIFY(text) STRINGIFY_IMPL(text) + +#define CONCAT_IMPL(a, b) a##b +#define CONCAT(a, b) CONCAT_IMPL(a, b) +#define CONCAT_3(a, b, c) CONCAT(a, CONCAT(b, c)) +#define CONCAT_4(a, b, c, d) CONCAT(CONCAT(a, b), CONCAT(c, d)) + +#define UNIQUE_NAME(prefix) CONCAT(prefix, __COUNTER__) +#define UNIQUE_NAME_LINE(prefix) CONCAT(prefix, __LINE__) +#define DISCARD UNIQUE_NAME(_discard) + +#define UNUSED(x) (void)x; + +#if defined(_MSC_VER) +# define UNREACHABLE __assume(0) +#elif defined(__GNUC__) || defined(__clang__) +# define UNREACHABLE __builtin_unreachable() +#else +# define UNREACHABLE +#endif + +#if defined(DOCTEST_CONFIG_DISABLE) +# define TESTED_MEMEBERS_VISBILITY private +#else +# define TESTED_MEMEBERS_VISBILITY public +#endif |