From b4484c0740cd1d4dd1058390f1666b4325deeced Mon Sep 17 00:00:00 2001 From: Mike Frysinger Date: Mon, 2 Jan 2012 19:40:31 +0000 Subject: [PATCH] Add patch from upstream to drop libtool requirement #394717. Package-Manager: portage-2.2.0_alpha81/cvs/Linux x86_64 --- dev-libs/libp11/ChangeLog | 8 +- dev-libs/libp11/Manifest | 22 +- .../libp11/files/libp11-0.2.8-no-ltdl.patch | 196 ++++++++++++++++++ dev-libs/libp11/libp11-0.2.8-r1.ebuild | 51 +++++ 4 files changed, 271 insertions(+), 6 deletions(-) create mode 100644 dev-libs/libp11/files/libp11-0.2.8-no-ltdl.patch create mode 100644 dev-libs/libp11/libp11-0.2.8-r1.ebuild diff --git a/dev-libs/libp11/ChangeLog b/dev-libs/libp11/ChangeLog index db7a23c82ecb..ce83d3c96bd9 100644 --- a/dev-libs/libp11/ChangeLog +++ b/dev-libs/libp11/ChangeLog @@ -1,6 +1,12 @@ # ChangeLog for dev-libs/libp11 # Copyright 1999-2012 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/dev-libs/libp11/ChangeLog,v 1.59 2012/01/01 15:55:19 armin76 Exp $ +# $Header: /var/cvsroot/gentoo-x86/dev-libs/libp11/ChangeLog,v 1.60 2012/01/02 19:40:31 vapier Exp $ + +*libp11-0.2.8-r1 (02 Jan 2012) + + 02 Jan 2012; Mike Frysinger +libp11-0.2.8-r1.ebuild, + +files/libp11-0.2.8-no-ltdl.patch: + Add patch from upstream to drop libtool requirement #394717. 01 Jan 2012; Raúl Porcel libp11-0.2.8.ebuild: alpha/ia64/sparc stable wrt #393865 diff --git a/dev-libs/libp11/Manifest b/dev-libs/libp11/Manifest index c203e874cf19..4309b2dfc02e 100644 --- a/dev-libs/libp11/Manifest +++ b/dev-libs/libp11/Manifest @@ -1,16 +1,28 @@ -----BEGIN PGP SIGNED MESSAGE----- Hash: SHA1 +AUX libp11-0.2.8-no-ltdl.patch 5184 RMD160 cef14f80af372f5f0be046fcf74ac65961c26730 SHA1 04ab4a3d8af21d9e4fec3f7081fb43cb9f9cd565 SHA256 9be90655cfa80a0e3695605a7b7c05cdcc81a8c39c2d347eef6715017cc2b199 DIST libp11-0.2.7.tar.gz 376422 RMD160 f3988b4c32c7d0fe19c16ebe3aa92d7a16df46a2 SHA1 aa794f4c114eb41f03b9c844ec31fb932b1aed02 SHA256 b741e2fea57d692c070111ad843e4bd025c18c0954aaca3df3a076e5142e5f4d DIST libp11-0.2.8.tar.gz 377508 RMD160 6cda5a5b456aa46dd8f10021f606b86393a88465 SHA1 2d1f6dc4200038f55a0cb7e22858f93e484b0724 SHA256 a4121015503ade98074b5e2a2517fc8a139f8b28aed10021db2bb77283f40691 EBUILD libp11-0.2.7.ebuild 1233 RMD160 da4b731d6ee255301d42005420fbd8dc0017f40b SHA1 4b8dcb223a6793ec8f7276cb6c2bb5c5f50d102c SHA256 ed070c6ae5786e6903e24a960a4f42f7cd4271f054d1f92a34d4c6314afb02ef +EBUILD libp11-0.2.8-r1.ebuild 1298 RMD160 dac63bb2461669feb0d1369c73fcf5c3a873f426 SHA1 a0187fd985336f6f2a70f1e3fe66d58d53db1ca2 SHA256 428f16e2b038a59100c2d9e070c3f89e2ca3fdbb49694ee97f71dd82a7e11c4e EBUILD libp11-0.2.8.ebuild 1352 RMD160 ec975054fecdffc89fab69e41a892ab34023938f SHA1 c8fc571cada0c4acdb1d54e71377182e5951894a SHA256 dfefbe21a5500fe9819be6e79016e6fd0dc27badfc87bdc87f40919f3d531a6a -MISC ChangeLog 6979 RMD160 80a61152b822d56f7c7bc49c8198f4f055b04758 SHA1 b9e3554e999a917ec068c6109c1ce6edf4830d31 SHA256 2ce762e150eaceab66eabddd56628f5e6b230c739090d7503a516d42c80c3f36 +MISC ChangeLog 7186 RMD160 957a63218823bebdf8bf43117688146764d9e728 SHA1 987c23ce1d74efbd3e402bfd3458ea9b4016422c SHA256 bdbfa418086b83628ee6b05492724aeb8b825933a705e00a6ddb832a42d024f2 MISC metadata.xml 427 RMD160 cfde707fb189d9daca8046e645a69b29b7e40c45 SHA1 a65d4c9863c8b172273ceb9b244cd9dfcbc96905 SHA256 702a9485ff50ace3adf3a39c6862d82666d9d1b0aa98dc9b9cb33ca084637de7 -----BEGIN PGP SIGNATURE----- -Version: GnuPG v2.0.17 (GNU/Linux) +Version: GnuPG v2.0.18 (GNU/Linux) -iEYEARECAAYFAk8Age0ACgkQuQc30/atMkAfTACgsFLj7na8ve+Bwl2szI6mZcnv -Ds8An1U3+hhmeKdRGroMbw9thEzVyHQB -=6SAh +iQIcBAEBAgAGBQJPAgg+AAoJELEHsLL7fEFWx1UP/jDd0xz8x2PhVobg0TpgWSls +jW8JRgHcT9I9rog+x/Nq7G/jwJRYp9dKe5qM5y2fN7tKNMZK8G4rlmT5+Yql+zag +vPtb7SVS4ywU7U1zudlT1a7OEydb2XvUBJG6M9OLbmqVT72cu6qQVj/7GRFQ/k5c +7/GCjh0xddwkXfBhzuuJvOg/OZJNANgVVzAI+kqWZSBcZWwGO32XwWwqHUTfVOQP +/wXgs9Uhva0v1KnpkLM6EAW42qC7/tss6LBcGgMCLA5yeGKlrYtEebCI5Efx1Lqx +o+PmiUmr90vreH7e61fcvvOvQbquzdY8lWm/Q9sRzNGmW0iCXA+tVruoq736bbXe +9EF2bcSq3oKWpUpgwfgK6MG3XnGWiuGmxduOhmchC8124X7C+E+/sbOjfBGUe1jl +TDpjI9L/5XtObQRjcyposyn8CpNQs4I17tS5dXVFdX6ZZCn6CiZ+okydnRSuwuOW +usFBsDLINgsoQ4H52Gf4NhwidYJk+AnuVlk9JpYMgtQC3Qbbqn4Usdzenc/I7hHb +vP/I2SbesJpQ5mijozkYnhXMidI8/U3OweW4/fjG5ur8XekOFBlmYWRR8OmnoIAd +7xRbNynx6DSQvlX16Jccn5HtD8YV+penrZ4flpCfFp2Y9NdES18yIc4dUPp3cIxP +YacaCfRWAyx5LvIiupQb +=FlII -----END PGP SIGNATURE----- diff --git a/dev-libs/libp11/files/libp11-0.2.8-no-ltdl.patch b/dev-libs/libp11/files/libp11-0.2.8-no-ltdl.patch new file mode 100644 index 000000000000..f3997ba65ba1 --- /dev/null +++ b/dev-libs/libp11/files/libp11-0.2.8-no-ltdl.patch @@ -0,0 +1,196 @@ +patch from upstream + +From 1c872a3e9c4cbf3cbd485168a7e98b589bbad57a Mon Sep 17 00:00:00 2001 +From: alonbl +Date: Wed, 14 Dec 2011 10:46:45 +0000 +Subject: [PATCH] Remove ltdl usage + +Use native POSIX/Windows + + +git-svn-id: http://www.opensc-project.org/svn/libp11/trunk@202 6d86ddd8-19ff-0310-a323-aa2ba648d307 +--- + configure.ac | 23 +++++------------------ + src/Makefile.am | 4 ++-- + src/Makefile.mak | 7 ++----- + src/libpkcs11.c | 52 +++++++++++++++++++++++++++++++++++++++------------- + 4 files changed, 48 insertions(+), 38 deletions(-) + +diff --git a/configure.ac b/configure.ac +index 679b8da..9fa96bf 100644 +--- a/configure.ac ++++ b/configure.ac +@@ -180,25 +180,14 @@ if test "${svn_checkout}" = "yes"; then + fi + fi + +-AC_ARG_VAR([LTLIB_CFLAGS], [C compiler flags for libltdl]) +-AC_ARG_VAR([LTLIB_LIBS], [linker flags for libltdl]) +-if test -z "${LTLIB_LIBS}"; then ++if test "${WIN32}" != "yes"; then + AC_CHECK_LIB( +- [ltdl], +- [lt_dlopen], +- [LTLIB_LIBS="-lltdl"], +- [AC_MSG_ERROR([ltdl not found, please install libltdl and/or libtool])] ++ [dl], ++ [dlopen], ++ , ++ [AC_MSG_ERROR([libdl required])] + ) +- + fi +-saved_CFLAGS="${CFLAGS}" +-CFLAGS="${CFLAGS} ${LTLIB_CFLAGS}" +-AC_CHECK_HEADER( +- [ltdl.h], +- , +- [AC_MSG_ERROR([ltdl.h not found, please install libltdl and/or libtool])] +-) +-CFLAGS="${saved_CFLAGS}" + + PKG_CHECK_MODULES( + [OPENSSL], +@@ -273,8 +262,6 @@ Compiler flags: ${CFLAGS} + Linker flags: ${LDFLAGS} + Libraries: ${LIBS} + +-LTLIB_CFLAGS: ${LTLIB_CFLAGS} +-LTLIB_LIBS: ${LTLIB_LIBS} + OPENSSL_CFLAGS: ${OPENSSL_CFLAGS} + OPENSSL_LIBS: ${OPENSSL_LIBS} + +diff --git a/src/Makefile.am b/src/Makefile.am +index c66a8cd..0910f44 100644 +--- a/src/Makefile.am ++++ b/src/Makefile.am +@@ -16,8 +16,8 @@ libp11_la_SOURCES += versioninfo.rc + else + dist_noinst_DATA = versioninfo.rc + endif +-libp11_la_CFLAGS = $(AM_CFLAGS) $(OPENSSL_CFLAGS) $(LTLIB_CFLAGS) +-libp11_la_LIBADD = $(OPENSSL_LIBS) $(LTLIB_LIBS) ++libp11_la_CFLAGS = $(AM_CFLAGS) $(OPENSSL_CFLAGS) ++libp11_la_LIBADD = $(OPENSSL_LIBS) + libp11_la_LDFLAGS = $(AM_LDFLAGS) \ + -version-info @LIBP11_LT_CURRENT@:@LIBP11_LT_REVISION@:@LIBP11_LT_AGE@ \ + -export-symbols "$(srcdir)/libp11.exports" \ +diff --git a/src/Makefile.mak b/src/Makefile.mak +index 73b5428..fa0809c 100644 +--- a/src/Makefile.mak ++++ b/src/Makefile.mak +@@ -1,10 +1,7 @@ +-LIBLTDL_INC = # E.g. /IC:\libtool-1.5.8-lib\include +-LIBLTDL_LIB = # E.g. C:\libtool-1.5.8-lib\lib\libltdl.lib +- + OPENSSL_INC = /IC:\openssl\include + OPENSSL_LIB = C:\openssl\out32dll\libeay32.lib + +-COPTS = /Zi /MD /nologo /I..\ /I. $(OPENSSL_INC) $(LIBLTDL_INC) /D_WIN32_WINNT=0x0400 /DWIN32 /DWIN32_LEAN_AND_MEAN ++COPTS = /Zi /MD /nologo /I..\ /I. $(OPENSSL_INC) /D_WIN32_WINNT=0x0400 /DWIN32 /DWIN32_LEAN_AND_MEAN + LINKFLAGS = /DEBUG /NOLOGO /INCREMENTAL:NO /MACHINE:IX86 + + TARGET = libp11.dll +@@ -28,6 +25,6 @@ $(TARGET): $(OBJECTS) versioninfo.res + echo EXPORTS >> $*.def + type $*.exports >> $*.def + link $(LINKFLAGS) /dll /def:$*.def /implib:$*.lib /out:$(TARGET) \ +- $(OBJECTS) $(OPENSSL_LIB) $(LIBLTDL_LIB) versioninfo.res ++ $(OBJECTS) $(OPENSSL_LIB) versioninfo.res + if EXIST $*.dll.manifest mt -manifest $*.dll.manifest -outputresource:$*.dll;2 + +diff --git a/src/libpkcs11.c b/src/libpkcs11.c +index a146361..93584d9 100644 +--- a/src/libpkcs11.c ++++ b/src/libpkcs11.c +@@ -27,14 +27,18 @@ + #include + #include + #include +-#include ++#ifdef WIN32 ++#include ++#else ++#include ++#endif + #include "libp11-int.h" + + #define MAGIC 0xd00bed00 + + struct sc_pkcs11_module { + unsigned int _magic; +- lt_dlhandle handle; ++ void *handle; + }; + typedef struct sc_pkcs11_module sc_pkcs11_module_t; + +@@ -52,19 +56,40 @@ C_LoadModule(const char *mspec, CK_FUNCTION_LIST_PTR_PTR funcs) + if (mspec == NULL) + return NULL; + +- if (lt_dlinit() != 0) +- return NULL; +- + mod = (sc_pkcs11_module_t *) calloc(1, sizeof(*mod)); + mod->_magic = MAGIC; + +- mod->handle = lt_dlopen(mspec); ++#ifdef WIN32 ++ mod->handle = LoadLibraryA(mspec); ++#else ++ mod->handle = dlopen(mspec, RTLD_NOW); ++#endif ++ + if (mod->handle == NULL) + goto failed; + +- /* Get the list of function pointers */ +- c_get_function_list = (CK_RV (*)(CK_FUNCTION_LIST_PTR_PTR)) +- lt_dlsym(mod->handle, "C_GetFunctionList"); ++#ifdef WIN32 ++ c_get_function_list = (CK_C_GetFunctionList)GetProcAddress ( ++ mod->handle, ++ "C_GetFunctionList" ++ ); ++#else ++ { ++ /* ++ * Make compiler happy! ++ */ ++ void *p = dlsym( ++ mod->handle, ++ "C_GetFunctionList" ++ ); ++ memmove( ++ &c_get_function_list, ++ &p, ++ sizeof(void *) ++ ); ++ } ++#endif ++ + if (!c_get_function_list) + goto failed; + rv = c_get_function_list(funcs); +@@ -89,13 +114,14 @@ C_UnloadModule(void *module) + if (!mod || mod->_magic != MAGIC) + return CKR_ARGUMENTS_BAD; + +- if (lt_dlclose(mod->handle) < 0) +- return CKR_FUNCTION_FAILED; ++#ifdef WIN32 ++ FreeLibrary(mod->handle); ++#else ++ dlclose(mod->handle); ++#endif + + memset(mod, 0, sizeof(*mod)); + free(mod); + +- lt_dlexit(); +- + return CKR_OK; + } +-- +1.7.6.1 + diff --git a/dev-libs/libp11/libp11-0.2.8-r1.ebuild b/dev-libs/libp11/libp11-0.2.8-r1.ebuild new file mode 100644 index 000000000000..578247f18ece --- /dev/null +++ b/dev-libs/libp11/libp11-0.2.8-r1.ebuild @@ -0,0 +1,51 @@ +# Copyright 1999-2012 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/dev-libs/libp11/libp11-0.2.8-r1.ebuild,v 1.1 2012/01/02 19:40:31 vapier Exp $ + +EAPI="4" +inherit eutils autotools + +DESCRIPTION="A library implementing a layer on top of PKCS#11 API to make using PKCS#11 implementations easier." +HOMEPAGE="http://www.opensc-project.org/libp11/" + +if [[ "${PV}" = "9999" ]]; then + inherit autotools subversion + ESVN_REPO_URI="http://www.opensc-project.org/svn/${PN}/trunk" +else + SRC_URI="http://www.opensc-project.org/files/${PN}/${P}.tar.gz" +fi + +LICENSE="LGPL-2.1" +SLOT="0" +KEYWORDS="~alpha ~amd64 ~hppa ~ia64 ~ppc ~ppc64 ~sparc ~x86" +IUSE="doc" + +RDEPEND="dev-libs/openssl" +DEPEND="${RDEPEND} + dev-util/pkgconfig + doc? ( app-doc/doxygen )" + +if [[ "${PV}" = "9999" ]]; then + DEPEND="${DEPEND} + app-text/docbook-xsl-stylesheets + dev-libs/libxslt" +fi + +src_prepare() { + epatch "${FILESDIR}"/${P}-no-ltdl.patch + eautoreconf +} + +src_configure() { + econf \ + --docdir="/usr/share/doc/${PF}" \ + --htmldir="/usr/share/doc/${PF}/html" \ + --enable-shared --disable-static \ + --enable-doc \ + $(use_enable doc api-doc) +} + +src_install() { + emake install DESTDIR="${D}" || die "emake install failed" + find "${D}" -name '*.la' -delete +} -- 2.26.2