I tried googling it but all results were about C 's throw std::exception().
I was reading through libraries (was curious how stuff like printf, malloc and FILE were implemented) and came across the definition for the malloc function:
extern void *malloc (size_t __size) __THROW __attribute_malloc__
__attribute_alloc_size__ ((1)) __wur;
When using the IDE (Visual Studio Code) to trace back to definitions for each thing, __THROW led to this:
# if !defined __cplusplus && __GNUC_PREREQ (3, 3)
// stuff that doesn't happen
# else
# if defined __cplusplus && __GNUC_PREREQ (2,8)
# define __THROW throw ()
# define __THROWNL throw ()
# define __NTH(fct) __LEAF_ATTR fct throw ()
# define __NTHNL(fct) fct throw ()
// continuation to the if-else macro
This confused me, as, as far as i know, c doesn't have exceptions and instead uses int error codes. Even more, why are there parentheses as in a function call?
What does it mean and what does it do in the presented case?
CodePudding user response:
There is no throw keyword in C. That's a C thing.
As to why you find it in your code, the clue is right here in the preprocessor macros:
# if !defined __cplusplus && __GNUC_PREREQ (3, 3)
// stuff that doesn't happen
# else
# if defined __cplusplus && __GNUC_PREREQ (2,8)
# define __THROW throw ()
# define __THROWNL throw ()
# define __NTH(fct) __LEAF_ATTR fct throw ()
# define __NTHNL(fct) fct throw ()
// continuation to the if-else macro
This code is written so it will compile with either a C or C compiler. The C bit that references throw and other C isms will only be compiled if a C compiler is used, as such a compiler will define the __cplusplus macro.
When you compile it with a C compiler, only the bit marked // stuff that doesn't happen will be used, not the else block.
CodePudding user response:
There is no throw keyword in C. In C, the source text throw is an ordinary identifier.
The macro __THROW you show is replaced by nothing (an empty sequence of preprocessor tokens) when compiling in C, because the compilers the code you show is targeted for define __cplusplus only when compiling as C , not when compiling as C. So, in C, !defined __cplusplus_ is true, and the // stuff that doesn't happen happens. You do not show that code, but it likely contains #define __THROW or equivalent, defining __THROW to be replaced by the empty sequence.
If you see other statements being used, where __THROW is defined to be replaced by throw (), then you are compiling in C mode, not C.
CodePudding user response:
The C 2017 standard doesn't define a throw keyword. The header file may be used by both C and C compilers and as @Barmar noted it doesn't apply to C (in C , btw, throw() specifier means that the function doesn't throw exceptions).
