I used #ifdef Win32
for safe calls alike sprintf_s
but now I want to build project with MinGW and it's just wrong now. I need to use #ifdef VC++
or somehow like that. Is it possible?
See the "Microsoft-Specific Predefined Macros" table of Visual C predefined macros
You could check for _MSC_VER
.
#ifdef __clang__
/*code specific to clang compiler*/
#elif __GNUC__
/*code for GNU C compiler */
#elif _MSC_VER
/*usually has the version number in _MSC_VER*/
/*code specific to MSVC compiler*/
#elif __BORLANDC__
/*code specific to borland compilers*/
#elif __MINGW32__
/*code specific to mingw compilers*/
#endif
__GNUC__
is a language dialect, not a compiler. Most compilers (Clang and ICC included) will define __GNUC__
at least sometimes. –
Goal __GNUC__
is a language dialect, but the code you write is usually for the compiler and hopefully humans. However, if you meant that I have to improve this answer by changing /* code for GNU C compiler */
to /* code in GNU C Dialect */
then, you may submit a proposal for improvement –
Unveiling __GNUC__
would be insufficient. In that case, this question/answer would fit their situation better. –
Goal See the "Microsoft-Specific Predefined Macros" table of Visual C predefined macros
You could check for _MSC_VER
.
Preferably, you should resort to using portable symbols. I understand sometimes those symbols may not be defined, so you can see the Predef project for an extensive list of preprocessor macros regarding standards, compilers, libraries, operating systems and architectures that aren't portable.
However, the function you specifically mention in this question has been included within the C11 standard as a part of Annex K.3, the bounds-checking interfaces (library).
K.3.1.1p2 states:
The functions, macros, and types declared or defined in K.3 and its subclauses are declared and defined by their respective headers if
__STDC_WANT_LIB_EXT1__
is defined as a macro which expands to the integer constant 1 at the point in the source file where the appropriate header is first included
Thus, you should place preference upon checking __STDC_WANT_LIB_EXT1__
, and only use compiler-specific symbols when that doesn't exist.
© 2022 - 2024 — McMap. All rights reserved.
snprintf()
which is a standard function that does the same thing. – Manlovesnprintf
wasn't guaranteed to exist in C89. There's the similar_snprintf
, though IIRC that wasn't renamed tosnprintf
because that does something subtly different. – Stevens