]> granicus.if.org Git - p11-kit/commitdiff
common: Factor out common initializer code into a header
authorDaiki Ueno <dueno@redhat.com>
Mon, 27 Aug 2018 10:57:51 +0000 (12:57 +0200)
committerDaiki Ueno <ueno@gnu.org>
Tue, 28 Aug 2018 12:44:56 +0000 (14:44 +0200)
common/Makefile.am
common/init.h [new file with mode: 0644]
p11-kit/client-init.c
p11-kit/proxy-init.c

index d67028a811ab3ffcf294e034ef1a8e34ce60853d..410d70418c9ac52829496d955b62ffec299322d6 100644 (file)
@@ -30,6 +30,7 @@ libp11_common_la_SOURCES = \
        common/pkcs11.h common/pkcs11x.h common/pkcs11i.h \
        common/runtime.c common/runtime.h \
        common/url.c common/url.h \
+       common/init.h \
        $(NULL)
 
 libp11_library_la_SOURCES = \
diff --git a/common/init.h b/common/init.h
new file mode 100644 (file)
index 0000000..c36b125
--- /dev/null
@@ -0,0 +1,94 @@
+/*
+ * Copyright (c) 2011 Collabora Ltd
+ * Copyright (c) 2012 Stef Walter
+ *
+ * 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.
+ *
+ *
+ * CONTRIBUTORS
+ *  Stef Walter <stef@thewalter.net>
+ */
+
+#include "library.h"
+
+#ifdef OS_UNIX
+
+void INIT (void);
+
+void FINI (void);
+
+#ifdef __GNUC__
+__attribute__((constructor))
+#endif
+void
+INIT (void)
+{
+       p11_library_init ();
+}
+
+#ifdef __GNUC__
+__attribute__((destructor))
+#endif
+void
+FINI (void)
+{
+       CLEANUP;
+       p11_library_uninit ();
+}
+
+#endif /* OS_UNIX */
+
+#ifdef OS_WIN32
+
+BOOL WINAPI DllMain (HINSTANCE, DWORD, LPVOID);
+
+BOOL WINAPI
+DllMain (HINSTANCE instance,
+         DWORD reason,
+         LPVOID reserved)
+{
+       switch (reason) {
+       case DLL_PROCESS_ATTACH:
+               p11_library_init ();
+               break;
+       case DLL_THREAD_DETACH:
+               p11_library_thread_cleanup ();
+               break;
+       case DLL_PROCESS_DETACH:
+               CLEANUP;
+               p11_library_uninit ();
+               break;
+       default:
+               break;
+       }
+
+       return TRUE;
+}
+
+#endif /* OS_WIN32 */
index 74e8905f0c7ae05fd65bf35036dc63db867aa4a2..04d323bfe45208df563d8ff70365fac05b1d6cc2 100644 (file)
@@ -38,7 +38,6 @@
 #include "config.h"
 
 #include "client.h"
-#include "library.h"
 #include "pkcs11.h"
 
 /* p11_proxy_module_check() is defined as a weak symbol in modules.c */
@@ -52,58 +51,7 @@ p11_proxy_module_check (CK_FUNCTION_LIST_PTR module)
 }
 #endif
 
-#ifdef OS_UNIX
-
-void _p11_kit_init (void);
-
-void _p11_kit_fini (void);
-
-#ifdef __GNUC__
-__attribute__((constructor))
-#endif
-void
-_p11_kit_init (void)
-{
-       p11_library_init ();
-}
-
-#ifdef __GNUC__
-__attribute__((destructor))
-#endif
-void
-_p11_kit_fini (void)
-{
-       p11_client_module_cleanup ();
-       p11_library_uninit ();
-}
-
-#endif /* OS_UNIX */
-
-#ifdef OS_WIN32
-
-BOOL WINAPI DllMain (HINSTANCE, DWORD, LPVOID);
-
-BOOL WINAPI
-DllMain (HINSTANCE instance,
-         DWORD reason,
-         LPVOID reserved)
-{
-       switch (reason) {
-       case DLL_PROCESS_ATTACH:
-               p11_library_init ();
-               break;
-       case DLL_THREAD_DETACH:
-               p11_library_thread_cleanup ();
-               break;
-       case DLL_PROCESS_DETACH:
-               p11_client_module_cleanup ();
-               p11_library_uninit ();
-               break;
-       default:
-               break;
-       }
-
-       return TRUE;
-}
-
-#endif /* OS_WIN32 */
+#define INIT _p11_kit_init
+#define FINI _p11_kit_fini
+#define CLEANUP p11_client_module_cleanup ()
+#include "init.h"
index 118478f5c14d5285fe25dad4446a8d54803b3b19..b0b9550e0273bb4bed758b06d1d08ef90c1af6c5 100644 (file)
 #include "p11-kit.h"
 #include "proxy.h"
 
-#ifdef OS_UNIX
-
-void _p11_kit_init (void);
-
-void _p11_kit_fini (void);
-
-#ifdef __GNUC__
-__attribute__((constructor))
-#endif
-void
-_p11_kit_init (void)
-{
-       p11_library_init ();
-}
-
-#ifdef __GNUC__
-__attribute__((destructor))
-#endif
-void
-_p11_kit_fini (void)
-{
-       p11_proxy_module_cleanup ();
-       p11_library_uninit ();
-}
-
-#endif /* OS_UNIX */
-
-#ifdef OS_WIN32
-
-BOOL WINAPI DllMain (HINSTANCE, DWORD, LPVOID);
-
-BOOL WINAPI
-DllMain (HINSTANCE instance,
-         DWORD reason,
-         LPVOID reserved)
-{
-       switch (reason) {
-       case DLL_PROCESS_ATTACH:
-               p11_library_init ();
-               break;
-       case DLL_THREAD_DETACH:
-               p11_library_thread_cleanup ();
-               break;
-       case DLL_PROCESS_DETACH:
-               p11_proxy_module_cleanup ();
-               p11_library_uninit ();
-               break;
-       default:
-               break;
-       }
-
-       return TRUE;
-}
-
-#endif /* OS_WIN32 */
+#define INIT _p11_kit_init
+#define FINI _p11_kit_fini
+#define CLEANUP p11_proxy_module_cleanup ()
+#include "init.h"