forked from MidnightCommander/mc
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Ticket #3617: (mc_open): handle varargs mode_t promotion issue.
On systems where 'mode_t' is smaller than 'int', doing 'va_arg (ap, mode_t)' is wrong because of C's "default argument promotions". GCC 4 creates crashing code in this case. The "va_arg" page of Gnulib's manual describes the problem and a simple solution: https://www.gnu.org/software/gnulib/manual/html_node/va_005farg.html However, since that solution reportedly (see thread at next link) still causes GCC to print warnings (for no good reason; perhaps this was fixed in newer GCCs), we pick a solution that defines a PROMOTED_MODE_T at the configuration stage: https://lists.gnu.org/archive/html/bug-gnulib/2009-05/msg00231.html (We take our 'mode_t.m4' from the most recent Gnulib source.) (If any of the URLs above no longer works, simply search the web for the mentioned words.)
- Loading branch information
Showing
4 changed files
with
32 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
# mode_t.m4 serial 2 | ||
dnl Copyright (C) 2009-2016 Free Software Foundation, Inc. | ||
dnl This file is free software; the Free Software Foundation | ||
dnl gives unlimited permission to copy and/or distribute it, | ||
dnl with or without modifications, as long as this notice is preserved. | ||
|
||
# For using mode_t, it's sufficient to use AC_TYPE_MODE_T and | ||
# include <sys/types.h>. | ||
|
||
# Define PROMOTED_MODE_T to the type that is the result of "default argument | ||
# promotion" (ISO C 6.5.2.2.(6)) of the type mode_t. | ||
AC_DEFUN([gl_PROMOTED_TYPE_MODE_T], | ||
[ | ||
AC_REQUIRE([AC_TYPE_MODE_T]) | ||
AC_CACHE_CHECK([for promoted mode_t type], [gl_cv_promoted_mode_t], [ | ||
dnl Assume mode_t promotes to 'int' if and only if it is smaller than 'int', | ||
dnl and to itself otherwise. This assumption is not guaranteed by the ISO C | ||
dnl standard, but we don't know of any real-world counterexamples. | ||
AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include <sys/types.h>]], | ||
[[typedef int array[2 * (sizeof (mode_t) < sizeof (int)) - 1];]])], | ||
[gl_cv_promoted_mode_t='int'], | ||
[gl_cv_promoted_mode_t='mode_t']) | ||
]) | ||
AC_DEFINE_UNQUOTED([PROMOTED_MODE_T], [$gl_cv_promoted_mode_t], | ||
[Define to the type that is the result of default argument promotions of type mode_t.]) | ||
]) |