mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-04 09:40:19 +00:00
26edfe6d18
We really always want to force-include msvc_recommended_pragmas.h to check for things at compile time so that we can avoid stuff like missing includes or attempting to return a value in a function that is supposed to have a void-return-type. The current problem is that, as indicated in the Visual Studio CI job, that we couldn't locate msvc_recommended_pragmas.h during the build if GLib is built as a subproject, and/or when msvc_recommended_pragmas.h is not in the paths indicated by %INCLUDE%, meaning that the aforementioned issues would not be caught by CI, which will then break builds on Visual Studio for people when msvc_recommended_pragmas.h is found during their builds. It would also be nice to be quiet from the warnings that we can really disregard anyways. So, add a copy of msvc_recommended_pragmas.h from GLib and update the build files to look for it in build-aux/msvc, so that it can always be used during the build, especially by the CI.
42 lines
2.2 KiB
C
42 lines
2.2 KiB
C
#ifndef _MSC_VER
|
|
#pragma error "This header is for Microsoft VC or clang-cl only."
|
|
#endif /* _MSC_VER */
|
|
|
|
/* Make MSVC more pedantic, this is a recommended pragma list
|
|
* from _Win32_Programming_ by Rector and Newcomer.
|
|
*/
|
|
#ifndef __clang__
|
|
#pragma warning(error:4002) /* too many actual parameters for macro */
|
|
#pragma warning(error:4003) /* not enough actual parameters for macro */
|
|
#pragma warning(1:4010) /* single-line comment contains line-continuation character */
|
|
#pragma warning(error:4013) /* 'function' undefined; assuming extern returning int */
|
|
#pragma warning(1:4016) /* no function return type; using int as default */
|
|
#pragma warning(error:4020) /* too many actual parameters */
|
|
#pragma warning(error:4021) /* too few actual parameters */
|
|
#pragma warning(error:4027) /* function declared without formal parameter list */
|
|
#pragma warning(error:4029) /* declared formal parameter list different from definition */
|
|
#pragma warning(error:4033) /* 'function' must return a value */
|
|
#pragma warning(error:4035) /* 'function' : no return value */
|
|
#pragma warning(error:4045) /* array bounds overflow */
|
|
#pragma warning(error:4047) /* different levels of indirection */
|
|
#pragma warning(error:4049) /* terminating line number emission */
|
|
#pragma warning(error:4053) /* An expression of type void was used as an operand */
|
|
#pragma warning(error:4071) /* no function prototype given */
|
|
#pragma warning(disable:4101) /* unreferenced local variable */
|
|
#pragma warning(error:4150)
|
|
|
|
/* G_NORETURN */
|
|
#pragma warning(error:4646) /* function declared with __declspec(noreturn) has non-void return type */
|
|
#pragma warning(error:4715) /* 'function': not all control paths return a value */
|
|
#pragma warning(error:4098) /* 'void' function returning a value */
|
|
|
|
#pragma warning(disable:4244) /* No possible loss of data warnings */
|
|
#pragma warning(disable:4305) /* No truncation from int to char warnings */
|
|
|
|
#pragma warning(error:4819) /* The file contains a character that cannot be represented in the current code page */
|
|
#endif /* __clang__ */
|
|
|
|
/* work around Microsoft's premature attempt to deprecate the C-Library */
|
|
#define _CRT_SECURE_NO_WARNINGS
|
|
#define _CRT_NONSTDC_NO_WARNINGS
|