]> granicus.if.org Git - p11-kit/commitdiff
Don't use _GNU_SOURCE and fix strerror_r usage
authorStef Walter <stef@thewalter.net>
Tue, 23 Jul 2013 21:02:52 +0000 (23:02 +0200)
committerStef Walter <stef@thewalter.net>
Tue, 23 Jul 2013 21:06:30 +0000 (23:06 +0200)
glibc declares strerror_r completely different if in POSIX or GNU
mode. Nastiness. Stop using _GNU_SOURCE all together.

common/compat.h
common/message.c
common/test.c
common/tests/Makefile.am
common/tests/test-message.c [new file with mode: 0644]
configure.ac
trust/token.c

index 5b76d0069f4efded1f859daa349775545f7ef079..b593cf607ce3b3aad9e4dc6e0259091b0fd2c870 100644 (file)
 
 #include <sys/types.h>
 
+#ifdef _GNU_SOURCE
+#error Make the crap stop. _GNU_SOURCE is completely unportable and breaks all sorts of behavior
+#endif
+
 #if !defined(__cplusplus) && (__GNUC__ > 2)
 #define GNUC_PRINTF(x, y) __attribute__((__format__(__printf__, x, y)))
 #else
@@ -266,7 +270,7 @@ char *     strconcat        (const char *first,
 
 #endif /* HAVE_STRCONCAT */
 
-#ifndef HAVE_ASPRINTF
+#if defined HAVE_DECL_ASPRINTF && !HAVE_DECL_ASPRINTF
 
 int        asprintf         (char **strp,
                              const char *fmt,
@@ -274,14 +278,14 @@ int        asprintf         (char **strp,
 
 #endif /* HAVE_ASPRINTF */
 
-#ifndef HAVE_VASPRINTF
+#if defined HAVE_DECL_VASPRINTF && !HAVE_DECL_VASPRINTF
 #include <stdarg.h>
 
 int        vasprintf        (char **strp,
                              const char *fmt,
                              va_list ap);
 
-#endif /* HAVE_VASPRINTF */
+#endif /* HAVE_DECL_VASPRINTF */
 
 #ifndef HAVE_GMTIME_R
 #include <time.h>
index e68dfac561c8d2ca0b9991e90f3d426150fd15f1..35f2764487a9311ad247b12f5eed3a50a1c7f225 100644 (file)
 
 #include "config.h"
 
+/*
+ * Oh god. glibc is nasty. Changes behavior and definitions of POSIX
+ * functions to completely different signatures depending on defines
+ */
+#define _POSIX_C_SOURCE 200112L
+
 #include "compat.h"
 #define P11_DEBUG_FLAG P11_DEBUG_LIB
 #include "debug.h"
index af0ea96f2b7749713d54a40f5a7dfceaaa9cc546..daee663f655cc6f85c377db4c9af70cfb7b9e839 100644 (file)
@@ -36,6 +36,7 @@
 
 #define P11_TEST_SOURCE 1
 
+#include "compat.h"
 #include "test.h"
 #include "debug.h"
 #include "path.h"
index af4dc15afc604366373d7e262d4d09fde9f12566..432ca95985e64adfb47c660b68b28cc48d75d419 100644 (file)
@@ -26,6 +26,7 @@ CHECK_PROGS = \
        test-url \
        test-path \
        test-lexer \
+       test-message \
        $(NULL)
 
 noinst_PROGRAMS = \
diff --git a/common/tests/test-message.c b/common/tests/test-message.c
new file mode 100644 (file)
index 0000000..63ecf31
--- /dev/null
@@ -0,0 +1,65 @@
+/*
+ * Copyright (c) 2013 Red Hat Inc.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ *
+ *     * Redistributions of source code must retain the above
+ *       copyright notice, this list of conditions and the
+ *       following disclaimer.
+ *     * Redistributions in binary form must reproduce the
+ *       above copyright notice, this list of conditions and
+ *       the following disclaimer in the documentation and/or
+ *       other materials provided with the distribution.
+ *     * The names of contributors to this software may not be
+ *       used to endorse or promote products derived from this
+ *       software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
+ * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
+ * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
+ * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
+ * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
+ * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
+ * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
+ * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
+ * DAMAGE.
+ *
+ * Author: Stef Walter <stefw@redhat.com>
+ */
+
+#include "config.h"
+#include "test.h"
+
+#include "message.h"
+
+#include <errno.h>
+#include <stdlib.h>
+
+static void
+test_with_err (void)
+{
+       const char *last;
+       char *expected;
+
+       errno = E2BIG;
+       p11_message_err (ENOENT, "Details: %s", "value");
+       last = p11_message_last ();
+
+       if (asprintf (&expected, "Details: value: %s", strerror (ENOENT)) < 0)
+               assert_not_reached ();
+       assert_str_eq (expected, last);
+       free (expected);
+}
+
+int
+main (int argc,
+      char *argv[])
+{
+       p11_test (test_with_err, "/message/with-err");
+       return p11_test_run (argc, argv);
+}
index 0587f6a5b6d1fd248aa7d26ac1ca90d5f1405d6e..ecf9ee90b1418a48bd30b640b60c500248c8ae24 100644 (file)
@@ -6,8 +6,6 @@ AC_INIT([p11-kit],
        [p11-kit],
        [http://p11-glue.freedesktop.org/p11-kit.html])
 
-AC_USE_SYSTEM_EXTENSIONS
-
 # ------------------------------------------------------------------------------
 # p11-kit libtool versioning
 # CURRENT : REVISION : AGE
@@ -85,6 +83,8 @@ if test "$os_unix" = "yes"; then
        AC_CHECK_FUNCS([asprintf vasprintf vsnprintf])
        AC_CHECK_FUNCS([timegm])
 
+       AC_CHECK_DECLS([asprintf, vasprintf], [], [], [[#include <stdio.h>]])
+
        # Required functions
        AC_CHECK_FUNCS([gmtime_r],
                [AC_DEFINE([HAVE_GMTIME_R], 1, [Whether gmtime_r() is available])],
index 1336443e891733ddf4e7c22a4c99eedbea9ccdda..4e7c63167255d32b1aaaefa298a1c9e0117b03c9 100644 (file)
@@ -226,7 +226,7 @@ loader_load_if_file (p11_token *token,
 
        if (stat (path, &sb) < 0) {
                if (errno != ENOENT)
-                       p11_message_err (errno, "couldn't stat path: %s", path);
+                       p11_message_err (errno, "couldn't stat path: %d: %s", errno, path);
 
        } else if (!S_ISDIR (sb.st_mode)) {
                return loader_load_file (token, path, &sb);