All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH 0/2] libcap-ng, swig: add packages
@ 2015-08-19  7:29 wenzong.fan
  2015-08-19  7:29 ` [PATCH 1/2] swig: add package 3.0.2 wenzong.fan
  2015-08-19  7:29 ` [PATCH 2/2] libcap-ng: add package 0.7.7 wenzong.fan
  0 siblings, 2 replies; 7+ messages in thread
From: wenzong.fan @ 2015-08-19  7:29 UTC (permalink / raw)
  To: openembedded-core

From: Wenzong Fan <wenzong.fan@windriver.com>

Add packages libcap-ng and swig.

They are from meta-oe and with adding them to oe-core, the copies from
multiple layers could be removed: meta-oe, meta-selinux ...

* The swig is depended by libcap-ng to build python bindings

* The libcap-ng library is intended to make programming with posix
  capabilities much easier than the traditional libcap library.
    
  It's not a replacement to libcap, it provides different library
  (libcap-ng.so) while packages explicitly look for libcap.so. It
  could be used by qemu, util-linux, libvirt, audit ... to work
  with posix capabilities.

The following changes since commit c348fa50186fb0796bc7b793c4b8d710419f2a0d:

  bitbake: toaster: move code from setup_lv_tests to setUp (2015-08-17 14:41:45 +0100)

are available in the git repository at:

  git://git.pokylinux.org/poky-contrib wenzong/libcap-ng
  http://git.pokylinux.org/cgit.cgi/poky-contrib/log/?h=wenzong/libcap-ng

Wenzong Fan (2):
  swig: add package 3.0.2
  libcap-ng: add package 0.7.7

 meta/recipes-devtools/swig/swig.inc                | 63 ++++++++++++++++++++
 ...lf-exe-for-swig-swiglib-on-non-Win32-plat.patch | 69 ++++++++++++++++++++++
 ...nfigure-use-pkg-config-for-pcre-detection.patch | 64 ++++++++++++++++++++
 meta/recipes-devtools/swig/swig_3.0.2.bb           |  8 +++
 .../libcap-ng/libcap-ng/python.patch               | 58 ++++++++++++++++++
 meta/recipes-support/libcap-ng/libcap-ng_0.7.7.bb  | 39 ++++++++++++
 6 files changed, 301 insertions(+)
 create mode 100644 meta/recipes-devtools/swig/swig.inc
 create mode 100644 meta/recipes-devtools/swig/swig/0001-Use-proc-self-exe-for-swig-swiglib-on-non-Win32-plat.patch
 create mode 100644 meta/recipes-devtools/swig/swig/0001-configure-use-pkg-config-for-pcre-detection.patch
 create mode 100644 meta/recipes-devtools/swig/swig_3.0.2.bb
 create mode 100644 meta/recipes-support/libcap-ng/libcap-ng/python.patch
 create mode 100644 meta/recipes-support/libcap-ng/libcap-ng_0.7.7.bb

-- 
1.9.1



^ permalink raw reply	[flat|nested] 7+ messages in thread

* [PATCH 1/2] swig: add package 3.0.2
  2015-08-19  7:29 [PATCH 0/2] libcap-ng, swig: add packages wenzong.fan
@ 2015-08-19  7:29 ` wenzong.fan
  2015-08-19 13:12   ` Martin Jansa
  2015-08-19  7:29 ` [PATCH 2/2] libcap-ng: add package 0.7.7 wenzong.fan
  1 sibling, 1 reply; 7+ messages in thread
From: wenzong.fan @ 2015-08-19  7:29 UTC (permalink / raw)
  To: openembedded-core

From: Wenzong Fan <wenzong.fan@windriver.com>

Pull package from meta-oe to oe-core:
meta-oe commit: 8b7d90d8e4c3338f94c588fc7e4a88319bd9a9e8

It's required for libcap-ng to build python bindings.

With adding it to oe-core, the copies from following layers could
be removed:

* meta-oe, meta-selinux, meta-intel-iot-middleware ...

Signed-off-by: Wenzong Fan <wenzong.fan@windriver.com>
---
 meta/recipes-devtools/swig/swig.inc                | 63 ++++++++++++++++++++
 ...lf-exe-for-swig-swiglib-on-non-Win32-plat.patch | 69 ++++++++++++++++++++++
 ...nfigure-use-pkg-config-for-pcre-detection.patch | 64 ++++++++++++++++++++
 meta/recipes-devtools/swig/swig_3.0.2.bb           |  8 +++
 4 files changed, 204 insertions(+)
 create mode 100644 meta/recipes-devtools/swig/swig.inc
 create mode 100644 meta/recipes-devtools/swig/swig/0001-Use-proc-self-exe-for-swig-swiglib-on-non-Win32-plat.patch
 create mode 100644 meta/recipes-devtools/swig/swig/0001-configure-use-pkg-config-for-pcre-detection.patch
 create mode 100644 meta/recipes-devtools/swig/swig_3.0.2.bb

diff --git a/meta/recipes-devtools/swig/swig.inc b/meta/recipes-devtools/swig/swig.inc
new file mode 100644
index 0000000..9821fa5
--- /dev/null
+++ b/meta/recipes-devtools/swig/swig.inc
@@ -0,0 +1,63 @@
+DESCRIPTION = "SWIG - Simplified Wrapper and Interface Generator"
+HOMEPAGE = "http://swig.sourceforge.net/"
+LICENSE = "BSD & GPLv3"
+LIC_FILES_CHKSUM = "file://LICENSE;md5=e7807a6282784a7dde4c846626b08fc6 \
+                    file://LICENSE-GPL;md5=d32239bcb673463ab874e80d47fae504 \
+                    file://LICENSE-UNIVERSITIES;md5=8ce9dcc8f7c994de4a408b205c72ba08"
+
+SECTION = "devel"
+
+DEPENDS = "libpcre python"
+
+SRC_URI = "${SOURCEFORGE_MIRROR}/${BPN}/${BPN}-${PV}.tar.gz"
+
+inherit autotools pythonnative
+
+EXTRA_OECONF = " \
+    --with-python=${PYTHON} \
+    --without-allegrocl \
+    --without-android \
+    --without-boost \
+    --without-chicken \
+    --without-clisp \
+    --without-csharp \
+    --without-d \
+    --without-gcj \
+    --without-go \
+    --without-guile \
+    --without-java \
+    --without-lua \
+    --without-mzscheme \
+    --without-ocaml \
+    --without-octave \
+    --without-perl5 \
+    --without-pike \
+    --without-php \
+    --without-python3 \
+    --without-r \
+    --without-ruby \
+    --without-tcl \
+"
+
+BBCLASSEXTEND = "native nativesdk"
+
+do_configure() {
+    install -m 0755 ${STAGING_DATADIR_NATIVE}/gnu-config/config.guess ${S}/Tools/config
+    install -m 0755 ${STAGING_DATADIR_NATIVE}/gnu-config/config.sub ${S}/Tools/config
+    install -m 0755 ${STAGING_DATADIR_NATIVE}/gnu-config/config.guess ${S}
+    install -m 0755 ${STAGING_DATADIR_NATIVE}/gnu-config/config.sub ${S}
+    oe_runconf
+}
+
+do_install_append_class-nativesdk() {
+    cd ${D}${bindir}
+    ln -s swig swig2.0
+}
+
+def swiglib_relpath(d):
+    swiglib = d.getVar('datadir', True) + "/" + d.getVar('BPN', True) + "/" + d.getVar('PV', True)
+    return os.path.relpath(swiglib, d.getVar('bindir', True))
+
+do_install_append_class-native() {
+    create_wrapper ${D}${bindir}/swig SWIG_LIB='`dirname $''realpath`'/${@swiglib_relpath(d)}
+}
diff --git a/meta/recipes-devtools/swig/swig/0001-Use-proc-self-exe-for-swig-swiglib-on-non-Win32-plat.patch b/meta/recipes-devtools/swig/swig/0001-Use-proc-self-exe-for-swig-swiglib-on-non-Win32-plat.patch
new file mode 100644
index 0000000..81df3e2
--- /dev/null
+++ b/meta/recipes-devtools/swig/swig/0001-Use-proc-self-exe-for-swig-swiglib-on-non-Win32-plat.patch
@@ -0,0 +1,69 @@
+From a4a0440a644c6c5e5da096efe3cf05ba309a284f Mon Sep 17 00:00:00 2001
+From: "NODA, Kai" <nodakai@gmail.com>
+Date: Sun, 22 Apr 2012 17:01:02 +0900
+Subject: [PATCH] Use /proc/self/exe for "swig -swiglib" on non-Win32
+ platforms.
+
+If it wasn't found, then fall back to a fixed string just as before.
+
+Upstream-Status: Submitted
+http://sourceforge.net/mailarchive/message.php?msg_id=29179733
+
+---
+ Source/Modules/main.cxx |   24 ++++++++++++++++++++++--
+ 1 file changed, 22 insertions(+), 2 deletions(-)
+
+diff --git a/Source/Modules/main.cxx b/Source/Modules/main.cxx
+index d2f5d3b..cbb0a12 100644
+--- a/Source/Modules/main.cxx
++++ b/Source/Modules/main.cxx
+@@ -26,6 +26,11 @@ char cvsroot_main_cxx[] = "$Id$";
+ #include "cparse.h"
+ #include <ctype.h>
+ #include <limits.h>		// for INT_MAX
++#ifndef _WIN32
++#include <cstddef>
++#include <unistd.h>		// for readlink
++#include <sys/stat.h>		// for stat
++#endif
+ 
+ // Global variables
+ 
+@@ -902,9 +907,9 @@ int SWIG_main(int argc, char *argv[], Language *l) {
+ 
+   // Check for SWIG_LIB environment variable
+   if ((c = getenv("SWIG_LIB")) == (char *) 0) {
++    char *p;
+ #if defined(_WIN32)
+     char buf[MAX_PATH];
+-    char *p;
+     if (!(GetModuleFileName(0, buf, MAX_PATH) == 0 || (p = strrchr(buf, '\\')) == 0)) {
+       *(p + 1) = '\0';
+       SwigLib = NewStringf("%sLib", buf); // Native windows installation path
+@@ -914,7 +919,22 @@ int SWIG_main(int argc, char *argv[], Language *l) {
+     if (Len(SWIG_LIB_WIN_UNIX) > 0)
+       SwigLibWinUnix = NewString(SWIG_LIB_WIN_UNIX); // Unix installation path using a drive letter (for msys/mingw)
+ #else
+-    SwigLib = NewString(SWIG_LIB);
++    char buf[PATH_MAX];
++    if (0 < ::readlink("/proc/self/exe", buf, sizeof(buf)) &&
++        (p = ::strstr(buf, "/bin/swig"))) {
++        int major, minor, patch;
++        const int ret = ::sscanf(VERSION, "%d.%d.%d", &major, &minor, &patch);
++        if (3 == ret) {
++            const ::ptrdiff_t dir_part_len = p - buf;
++            ::snprintf(p, PATH_MAX - dir_part_len, "/share/swig/%d.%d.%d", major, minor, patch);
++            struct ::stat stat_res;
++            if (0 == ::stat(buf, &stat_res) && S_ISDIR(stat_res.st_mode)) {
++                SwigLib = NewString(buf);
++            }
++        }
++    }
++    if (NULL == SwigLib)
++        SwigLib = NewString(SWIG_LIB);
+ #endif
+   } else {
+     SwigLib = NewString(c);
+-- 
+1.7.9.5
+
diff --git a/meta/recipes-devtools/swig/swig/0001-configure-use-pkg-config-for-pcre-detection.patch b/meta/recipes-devtools/swig/swig/0001-configure-use-pkg-config-for-pcre-detection.patch
new file mode 100644
index 0000000..1b1128a
--- /dev/null
+++ b/meta/recipes-devtools/swig/swig/0001-configure-use-pkg-config-for-pcre-detection.patch
@@ -0,0 +1,64 @@
+From 5c4d6d8538994d5fe9b3b46bfafaf0a605e3bda6 Mon Sep 17 00:00:00 2001
+From: Koen Kooi <koen.kooi@linaro.org>
+Date: Tue, 17 Jun 2014 08:18:17 +0200
+Subject: [PATCH] configure: use pkg-config for pcre detection
+
+Signed-off-by: Koen Kooi <koen.kooi@linaro.org>
+Upstream-Status: pending
+---
+ configure.ac | 38 +++++++-------------------------------
+ 1 file changed, 7 insertions(+), 31 deletions(-)
+
+diff --git a/configure.ac b/configure.ac
+index 0c984b7..6edcec1 100644
+--- a/configure.ac
++++ b/configure.ac
+@@ -70,38 +70,14 @@ AC_MSG_RESULT([$with_pcre])
+ 
+ dnl To make configuring easier, check for a locally built PCRE using the Tools/pcre-build.sh script
+ if test x"${with_pcre}" = xyes ; then
+-  AC_MSG_CHECKING([whether to use local PCRE])
+-  local_pcre_config=no
+-  if test -z $PCRE_CONFIG; then
+-    if test -f `pwd`/pcre/pcre-swig-install/bin/pcre-config; then
+-      PCRE_CONFIG=`pwd`/pcre/pcre-swig-install/bin/pcre-config
+-      local_pcre_config=$PCRE_CONFIG
+-    fi
+-  fi
+-  AC_MSG_RESULT([$local_pcre_config])
+-fi
+-AS_IF([test "x$with_pcre" != xno],
+-  [AX_PATH_GENERIC([pcre],
+-    [], dnl Minimal version of PCRE we need -- accept any
+-    [], dnl custom sed script for version parsing is not needed
+-    [AC_DEFINE([HAVE_PCRE], [1], [Define if you have PCRE library])
+-     LIBS="$LIBS $PCRE_LIBS"
+-     CPPFLAGS="$CPPFLAGS $PCRE_CFLAGS"
+-    ],
+-    [AC_MSG_FAILURE([
+-        Cannot find pcre-config script from PCRE (Perl Compatible Regular Expressions)
+-        library package. This dependency is needed for configure to complete,
+-        Either:
+-        - Install the PCRE developer package on your system (preferred approach).
+-        - Download the PCRE source tarball, build and install on your system
+-          as you would for any package built from source distribution.
+-        - Use the Tools/pcre-build.sh script to build PCRE just for SWIG to statically
+-          link against. Run 'Tools/pcre-build.sh --help' for instructions.
+-          (quite easy and does not require privileges to install PCRE on your system)
+-        - Use configure --without-pcre to disable regular expressions support in SWIG
+-          (not recommended).])
+-    ])
++  PKG_CHECK_MODULES([PCRE], [libpcre], [
++    AC_DEFINE([HAVE_PCRE], [1], [Define if you have PCRE library])
++    LIBS="$LIBS $PCRE_LIBS"
++    CPPFLAGS="$CPPFLAGS $PCRE_CFLAGS"
++  ], [
++    AC_MSG_WARN([$PCRE_PKG_ERRORS])
+   ])
++fi
+ 
+ 
+ dnl CCache
+-- 
+1.9.3
+
diff --git a/meta/recipes-devtools/swig/swig_3.0.2.bb b/meta/recipes-devtools/swig/swig_3.0.2.bb
new file mode 100644
index 0000000..ac41914
--- /dev/null
+++ b/meta/recipes-devtools/swig/swig_3.0.2.bb
@@ -0,0 +1,8 @@
+require ${BPN}.inc
+
+SRC_URI += "file://0001-Use-proc-self-exe-for-swig-swiglib-on-non-Win32-plat.patch \
+            file://0001-configure-use-pkg-config-for-pcre-detection.patch \
+           "
+
+SRC_URI[md5sum] = "62f9b0d010cef36a13a010dc530d0d41"
+SRC_URI[sha256sum] = "a2669657cabcedc371f63c0457407a183e0b6b2ef4e7e303c1ec9a3964cc7813"
-- 
1.9.1



^ permalink raw reply related	[flat|nested] 7+ messages in thread

* [PATCH 2/2] libcap-ng: add package 0.7.7
  2015-08-19  7:29 [PATCH 0/2] libcap-ng, swig: add packages wenzong.fan
  2015-08-19  7:29 ` [PATCH 1/2] swig: add package 3.0.2 wenzong.fan
@ 2015-08-19  7:29 ` wenzong.fan
  1 sibling, 0 replies; 7+ messages in thread
From: wenzong.fan @ 2015-08-19  7:29 UTC (permalink / raw)
  To: openembedded-core

From: Wenzong Fan <wenzong.fan@windriver.com>

Pull package from meta-oe to oe-core:
meta-oe commit: bce4dba5546480c8e43c6442959ac7d0a4ef32f6

The libcap-ng library is intended to make programming with posix
capabilities much easier than the traditional libcap library.

It's not a replacement to libcap, it provides different library
(libcap-ng.so) while packages explicitly look for libcap.so. It
could be used by qemu, util-linux, libvirt, audit ...

With adding it to oe-core, the copies from following layers could
be removed:

* meta-oe, meta-selinux, meta-security-framework ...

Signed-off-by: Wenzong Fan <wenzong.fan@windriver.com>
---
 .../libcap-ng/libcap-ng/python.patch               | 58 ++++++++++++++++++++++
 meta/recipes-support/libcap-ng/libcap-ng_0.7.7.bb  | 39 +++++++++++++++
 2 files changed, 97 insertions(+)
 create mode 100644 meta/recipes-support/libcap-ng/libcap-ng/python.patch
 create mode 100644 meta/recipes-support/libcap-ng/libcap-ng_0.7.7.bb

diff --git a/meta/recipes-support/libcap-ng/libcap-ng/python.patch b/meta/recipes-support/libcap-ng/libcap-ng/python.patch
new file mode 100644
index 0000000..59591eb
--- /dev/null
+++ b/meta/recipes-support/libcap-ng/libcap-ng/python.patch
@@ -0,0 +1,58 @@
+From b01bb2694f66cd981e6d61523433dc3eb5ed32f2 Mon Sep 17 00:00:00 2001
+From: Li xin <lixin.fnst@cn.fujitsu.com>
+Date: Sat, 18 Jul 2015 23:03:30 +0900
+Subject: [PATCH] configure.ac - Avoid an incorrect check for python.
+ Makefile.am - avoid hard coded host include paths.
+
+Upstream-Status: pending
+
+Signed-off-by: Mark Hatle <mark.hatle@windriver.com>
+Signed-off-by: Li Xin <lixin.fnst@cn.fujitsu.com>
+---
+ bindings/python/Makefile.am |  3 ++-
+ configure.ac                | 15 ++-------------
+ 2 files changed, 4 insertions(+), 14 deletions(-)
+
+diff --git a/bindings/python/Makefile.am b/bindings/python/Makefile.am
+index 82b9bb8..f9fe7a8 100644
+--- a/bindings/python/Makefile.am
++++ b/bindings/python/Makefile.am
+@@ -23,7 +23,8 @@ SUBDIRS = test
+ CONFIG_CLEAN_FILES = *.loT *.rej *.orig
+ AM_CFLAGS = -fPIC -DPIC
+ PYLIBVER ?= python$(PYTHON_VERSION)
+-AM_CPPFLAGS = -I. -I$(top_builddir) -I@PYINCLUDEDIR@
++PYINC ?= /usr/include/$(PYLIBVER)
++AM_CPPFLAGS = -I. -I$(top_builddir) -I$(PYINC)
+ LIBS = $(top_builddir)/src/libcap-ng.la
+ SWIG_FLAGS = -python
+ SWIG_INCLUDES = ${AM_CPPFLAGS}
+diff --git a/configure.ac b/configure.ac
+index 1d777d5..9d90f64 100644
+--- a/configure.ac
++++ b/configure.ac
+@@ -123,19 +123,8 @@ if test x$use_python = xno ; then
+ else
+ AC_MSG_RESULT(testing)
+ AM_PATH_PYTHON
+-PYINCLUDEDIR=`python${am_cv_python_version} -c "from distutils import sysconfig; print(sysconfig.get_config_var('INCLUDEPY'))"`
+-if test -f ${PYINCLUDEDIR}/Python.h ; then
+-	python_found="yes"
+-	AC_SUBST(PYINCLUDEDIR)
+-	AC_MSG_NOTICE(Python bindings will be built)
+-else
+-	python_found="no"
+-	if test x$use_python = xyes ; then
+-		AC_MSG_ERROR([Python explicitly required and python headers found])
+-	else
+-		AC_MSG_WARN("Python headers not found - python bindings will not be made")
+-	fi
+-fi
++python_found="yes"
++AC_MSG_NOTICE(Python bindings will be built)
+ fi
+ AM_CONDITIONAL(HAVE_PYTHON, test ${python_found} = "yes")
+ 
+-- 
+1.8.4.2
+
diff --git a/meta/recipes-support/libcap-ng/libcap-ng_0.7.7.bb b/meta/recipes-support/libcap-ng/libcap-ng_0.7.7.bb
new file mode 100644
index 0000000..a31d5dc
--- /dev/null
+++ b/meta/recipes-support/libcap-ng/libcap-ng_0.7.7.bb
@@ -0,0 +1,39 @@
+SUMMARY = "An alternate posix capabilities library"
+DESCRIPTION = "The libcap-ng library is intended to make programming \
+with POSIX capabilities much easier than the traditional libcap library."
+HOMEPAGE = "http://freecode.com/projects/libcap-ng"
+SECTION = "base"
+LICENSE = "GPLv2+ & LGPLv2.1+"
+LIC_FILES_CHKSUM = "file://COPYING;md5=94d55d512a9ba36caa9b7df079bae19f \
+		    file://COPYING.LIB;md5=e3eda01d9815f8d24aae2dbd89b68b06"
+
+SRC_URI = "http://people.redhat.com/sgrubb/libcap-ng/libcap-ng-${PV}.tar.gz \
+           file://python.patch"
+
+inherit lib_package autotools pythonnative
+
+SRC_URI[md5sum] = "3d7d126b29e2869a0257c17c8b0d9b2e"
+SRC_URI[sha256sum] = "615549ce39b333f6b78baee0c0b4ef18bc726c6bf1cca123dfd89dd963f6d06b"
+
+DEPENDS += "swig-native python"
+
+EXTRA_OECONF += "--without-python3"
+
+EXTRA_OEMAKE += "PYLIBVER='python${PYTHON_BASEVERSION}' PYINC='${STAGING_INCDIR}/${PYLIBVER}'"
+
+PACKAGES += "${PN}-python"
+
+FILES_${PN}-dbg += "${libdir}/python${PYTHON_BASEVERSION}/*/.debug"
+FILES_${PN}-python = "${libdir}/python${PYTHON_BASEVERSION}"
+
+BBCLASSEXTEND = "native"
+
+do_install_append() {
+	# Moving libcap-ng to base_libdir
+	if [ ! ${D}${libdir} -ef ${D}${base_libdir} ]; then
+		mkdir -p ${D}/${base_libdir}/
+		mv -f ${D}${libdir}/libcap-ng.so.* ${D}${base_libdir}/
+		relpath=${@os.path.relpath("${base_libdir}", "${libdir}")}
+		ln -sf ${relpath}/libcap-ng.so.0.0.0 ${D}${libdir}/libcap-ng.so
+	fi
+}
-- 
1.9.1



^ permalink raw reply related	[flat|nested] 7+ messages in thread

* Re: [PATCH 1/2] swig: add package 3.0.2
  2015-08-19  7:29 ` [PATCH 1/2] swig: add package 3.0.2 wenzong.fan
@ 2015-08-19 13:12   ` Martin Jansa
  2015-08-20  1:31     ` wenzong fan
  0 siblings, 1 reply; 7+ messages in thread
From: Martin Jansa @ 2015-08-19 13:12 UTC (permalink / raw)
  To: wenzong.fan; +Cc: openembedded-core

[-- Attachment #1: Type: text/plain, Size: 10687 bytes --]

On Wed, Aug 19, 2015 at 03:29:28AM -0400, wenzong.fan@windriver.com wrote:
> From: Wenzong Fan <wenzong.fan@windriver.com>
> 
> Pull package from meta-oe to oe-core:
> meta-oe commit: 8b7d90d8e4c3338f94c588fc7e4a88319bd9a9e8

There is patch for meta-oe to upgrade it to 3.0.6 (which isn't
compatible with some recipes, but fixes for that were sent as well
already).

> It's required for libcap-ng to build python bindings.
> 
> With adding it to oe-core, the copies from following layers could
> be removed:
> 
> * meta-oe, meta-selinux, meta-intel-iot-middleware ...
> 
> Signed-off-by: Wenzong Fan <wenzong.fan@windriver.com>
> ---
>  meta/recipes-devtools/swig/swig.inc                | 63 ++++++++++++++++++++
>  ...lf-exe-for-swig-swiglib-on-non-Win32-plat.patch | 69 ++++++++++++++++++++++
>  ...nfigure-use-pkg-config-for-pcre-detection.patch | 64 ++++++++++++++++++++
>  meta/recipes-devtools/swig/swig_3.0.2.bb           |  8 +++
>  4 files changed, 204 insertions(+)
>  create mode 100644 meta/recipes-devtools/swig/swig.inc
>  create mode 100644 meta/recipes-devtools/swig/swig/0001-Use-proc-self-exe-for-swig-swiglib-on-non-Win32-plat.patch
>  create mode 100644 meta/recipes-devtools/swig/swig/0001-configure-use-pkg-config-for-pcre-detection.patch
>  create mode 100644 meta/recipes-devtools/swig/swig_3.0.2.bb
> 
> diff --git a/meta/recipes-devtools/swig/swig.inc b/meta/recipes-devtools/swig/swig.inc
> new file mode 100644
> index 0000000..9821fa5
> --- /dev/null
> +++ b/meta/recipes-devtools/swig/swig.inc
> @@ -0,0 +1,63 @@
> +DESCRIPTION = "SWIG - Simplified Wrapper and Interface Generator"
> +HOMEPAGE = "http://swig.sourceforge.net/"
> +LICENSE = "BSD & GPLv3"
> +LIC_FILES_CHKSUM = "file://LICENSE;md5=e7807a6282784a7dde4c846626b08fc6 \
> +                    file://LICENSE-GPL;md5=d32239bcb673463ab874e80d47fae504 \
> +                    file://LICENSE-UNIVERSITIES;md5=8ce9dcc8f7c994de4a408b205c72ba08"
> +
> +SECTION = "devel"
> +
> +DEPENDS = "libpcre python"
> +
> +SRC_URI = "${SOURCEFORGE_MIRROR}/${BPN}/${BPN}-${PV}.tar.gz"
> +
> +inherit autotools pythonnative
> +
> +EXTRA_OECONF = " \
> +    --with-python=${PYTHON} \
> +    --without-allegrocl \
> +    --without-android \
> +    --without-boost \
> +    --without-chicken \
> +    --without-clisp \
> +    --without-csharp \
> +    --without-d \
> +    --without-gcj \
> +    --without-go \
> +    --without-guile \
> +    --without-java \
> +    --without-lua \
> +    --without-mzscheme \
> +    --without-ocaml \
> +    --without-octave \
> +    --without-perl5 \
> +    --without-pike \
> +    --without-php \
> +    --without-python3 \
> +    --without-r \
> +    --without-ruby \
> +    --without-tcl \
> +"
> +
> +BBCLASSEXTEND = "native nativesdk"
> +
> +do_configure() {
> +    install -m 0755 ${STAGING_DATADIR_NATIVE}/gnu-config/config.guess ${S}/Tools/config
> +    install -m 0755 ${STAGING_DATADIR_NATIVE}/gnu-config/config.sub ${S}/Tools/config
> +    install -m 0755 ${STAGING_DATADIR_NATIVE}/gnu-config/config.guess ${S}
> +    install -m 0755 ${STAGING_DATADIR_NATIVE}/gnu-config/config.sub ${S}
> +    oe_runconf
> +}
> +
> +do_install_append_class-nativesdk() {
> +    cd ${D}${bindir}
> +    ln -s swig swig2.0
> +}
> +
> +def swiglib_relpath(d):
> +    swiglib = d.getVar('datadir', True) + "/" + d.getVar('BPN', True) + "/" + d.getVar('PV', True)
> +    return os.path.relpath(swiglib, d.getVar('bindir', True))
> +
> +do_install_append_class-native() {
> +    create_wrapper ${D}${bindir}/swig SWIG_LIB='`dirname $''realpath`'/${@swiglib_relpath(d)}
> +}
> diff --git a/meta/recipes-devtools/swig/swig/0001-Use-proc-self-exe-for-swig-swiglib-on-non-Win32-plat.patch b/meta/recipes-devtools/swig/swig/0001-Use-proc-self-exe-for-swig-swiglib-on-non-Win32-plat.patch
> new file mode 100644
> index 0000000..81df3e2
> --- /dev/null
> +++ b/meta/recipes-devtools/swig/swig/0001-Use-proc-self-exe-for-swig-swiglib-on-non-Win32-plat.patch
> @@ -0,0 +1,69 @@
> +From a4a0440a644c6c5e5da096efe3cf05ba309a284f Mon Sep 17 00:00:00 2001
> +From: "NODA, Kai" <nodakai@gmail.com>
> +Date: Sun, 22 Apr 2012 17:01:02 +0900
> +Subject: [PATCH] Use /proc/self/exe for "swig -swiglib" on non-Win32
> + platforms.
> +
> +If it wasn't found, then fall back to a fixed string just as before.
> +
> +Upstream-Status: Submitted
> +http://sourceforge.net/mailarchive/message.php?msg_id=29179733
> +
> +---
> + Source/Modules/main.cxx |   24 ++++++++++++++++++++++--
> + 1 file changed, 22 insertions(+), 2 deletions(-)
> +
> +diff --git a/Source/Modules/main.cxx b/Source/Modules/main.cxx
> +index d2f5d3b..cbb0a12 100644
> +--- a/Source/Modules/main.cxx
> ++++ b/Source/Modules/main.cxx
> +@@ -26,6 +26,11 @@ char cvsroot_main_cxx[] = "$Id$";
> + #include "cparse.h"
> + #include <ctype.h>
> + #include <limits.h>		// for INT_MAX
> ++#ifndef _WIN32
> ++#include <cstddef>
> ++#include <unistd.h>		// for readlink
> ++#include <sys/stat.h>		// for stat
> ++#endif
> + 
> + // Global variables
> + 
> +@@ -902,9 +907,9 @@ int SWIG_main(int argc, char *argv[], Language *l) {
> + 
> +   // Check for SWIG_LIB environment variable
> +   if ((c = getenv("SWIG_LIB")) == (char *) 0) {
> ++    char *p;
> + #if defined(_WIN32)
> +     char buf[MAX_PATH];
> +-    char *p;
> +     if (!(GetModuleFileName(0, buf, MAX_PATH) == 0 || (p = strrchr(buf, '\\')) == 0)) {
> +       *(p + 1) = '\0';
> +       SwigLib = NewStringf("%sLib", buf); // Native windows installation path
> +@@ -914,7 +919,22 @@ int SWIG_main(int argc, char *argv[], Language *l) {
> +     if (Len(SWIG_LIB_WIN_UNIX) > 0)
> +       SwigLibWinUnix = NewString(SWIG_LIB_WIN_UNIX); // Unix installation path using a drive letter (for msys/mingw)
> + #else
> +-    SwigLib = NewString(SWIG_LIB);
> ++    char buf[PATH_MAX];
> ++    if (0 < ::readlink("/proc/self/exe", buf, sizeof(buf)) &&
> ++        (p = ::strstr(buf, "/bin/swig"))) {
> ++        int major, minor, patch;
> ++        const int ret = ::sscanf(VERSION, "%d.%d.%d", &major, &minor, &patch);
> ++        if (3 == ret) {
> ++            const ::ptrdiff_t dir_part_len = p - buf;
> ++            ::snprintf(p, PATH_MAX - dir_part_len, "/share/swig/%d.%d.%d", major, minor, patch);
> ++            struct ::stat stat_res;
> ++            if (0 == ::stat(buf, &stat_res) && S_ISDIR(stat_res.st_mode)) {
> ++                SwigLib = NewString(buf);
> ++            }
> ++        }
> ++    }
> ++    if (NULL == SwigLib)
> ++        SwigLib = NewString(SWIG_LIB);
> + #endif
> +   } else {
> +     SwigLib = NewString(c);
> +-- 
> +1.7.9.5
> +
> diff --git a/meta/recipes-devtools/swig/swig/0001-configure-use-pkg-config-for-pcre-detection.patch b/meta/recipes-devtools/swig/swig/0001-configure-use-pkg-config-for-pcre-detection.patch
> new file mode 100644
> index 0000000..1b1128a
> --- /dev/null
> +++ b/meta/recipes-devtools/swig/swig/0001-configure-use-pkg-config-for-pcre-detection.patch
> @@ -0,0 +1,64 @@
> +From 5c4d6d8538994d5fe9b3b46bfafaf0a605e3bda6 Mon Sep 17 00:00:00 2001
> +From: Koen Kooi <koen.kooi@linaro.org>
> +Date: Tue, 17 Jun 2014 08:18:17 +0200
> +Subject: [PATCH] configure: use pkg-config for pcre detection
> +
> +Signed-off-by: Koen Kooi <koen.kooi@linaro.org>
> +Upstream-Status: pending
> +---
> + configure.ac | 38 +++++++-------------------------------
> + 1 file changed, 7 insertions(+), 31 deletions(-)
> +
> +diff --git a/configure.ac b/configure.ac
> +index 0c984b7..6edcec1 100644
> +--- a/configure.ac
> ++++ b/configure.ac
> +@@ -70,38 +70,14 @@ AC_MSG_RESULT([$with_pcre])
> + 
> + dnl To make configuring easier, check for a locally built PCRE using the Tools/pcre-build.sh script
> + if test x"${with_pcre}" = xyes ; then
> +-  AC_MSG_CHECKING([whether to use local PCRE])
> +-  local_pcre_config=no
> +-  if test -z $PCRE_CONFIG; then
> +-    if test -f `pwd`/pcre/pcre-swig-install/bin/pcre-config; then
> +-      PCRE_CONFIG=`pwd`/pcre/pcre-swig-install/bin/pcre-config
> +-      local_pcre_config=$PCRE_CONFIG
> +-    fi
> +-  fi
> +-  AC_MSG_RESULT([$local_pcre_config])
> +-fi
> +-AS_IF([test "x$with_pcre" != xno],
> +-  [AX_PATH_GENERIC([pcre],
> +-    [], dnl Minimal version of PCRE we need -- accept any
> +-    [], dnl custom sed script for version parsing is not needed
> +-    [AC_DEFINE([HAVE_PCRE], [1], [Define if you have PCRE library])
> +-     LIBS="$LIBS $PCRE_LIBS"
> +-     CPPFLAGS="$CPPFLAGS $PCRE_CFLAGS"
> +-    ],
> +-    [AC_MSG_FAILURE([
> +-        Cannot find pcre-config script from PCRE (Perl Compatible Regular Expressions)
> +-        library package. This dependency is needed for configure to complete,
> +-        Either:
> +-        - Install the PCRE developer package on your system (preferred approach).
> +-        - Download the PCRE source tarball, build and install on your system
> +-          as you would for any package built from source distribution.
> +-        - Use the Tools/pcre-build.sh script to build PCRE just for SWIG to statically
> +-          link against. Run 'Tools/pcre-build.sh --help' for instructions.
> +-          (quite easy and does not require privileges to install PCRE on your system)
> +-        - Use configure --without-pcre to disable regular expressions support in SWIG
> +-          (not recommended).])
> +-    ])
> ++  PKG_CHECK_MODULES([PCRE], [libpcre], [
> ++    AC_DEFINE([HAVE_PCRE], [1], [Define if you have PCRE library])
> ++    LIBS="$LIBS $PCRE_LIBS"
> ++    CPPFLAGS="$CPPFLAGS $PCRE_CFLAGS"
> ++  ], [
> ++    AC_MSG_WARN([$PCRE_PKG_ERRORS])
> +   ])
> ++fi
> + 
> + 
> + dnl CCache
> +-- 
> +1.9.3
> +
> diff --git a/meta/recipes-devtools/swig/swig_3.0.2.bb b/meta/recipes-devtools/swig/swig_3.0.2.bb
> new file mode 100644
> index 0000000..ac41914
> --- /dev/null
> +++ b/meta/recipes-devtools/swig/swig_3.0.2.bb
> @@ -0,0 +1,8 @@
> +require ${BPN}.inc
> +
> +SRC_URI += "file://0001-Use-proc-self-exe-for-swig-swiglib-on-non-Win32-plat.patch \
> +            file://0001-configure-use-pkg-config-for-pcre-detection.patch \
> +           "
> +
> +SRC_URI[md5sum] = "62f9b0d010cef36a13a010dc530d0d41"
> +SRC_URI[sha256sum] = "a2669657cabcedc371f63c0457407a183e0b6b2ef4e7e303c1ec9a3964cc7813"
> -- 
> 1.9.1
> 
> -- 
> _______________________________________________
> Openembedded-core mailing list
> Openembedded-core@lists.openembedded.org
> http://lists.openembedded.org/mailman/listinfo/openembedded-core

-- 
Martin 'JaMa' Jansa     jabber: Martin.Jansa@gmail.com

[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 188 bytes --]

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [PATCH 1/2] swig: add package 3.0.2
  2015-08-19 13:12   ` Martin Jansa
@ 2015-08-20  1:31     ` wenzong fan
  2015-08-20 12:16       ` Martin Jansa
  0 siblings, 1 reply; 7+ messages in thread
From: wenzong fan @ 2015-08-20  1:31 UTC (permalink / raw)
  To: Martin Jansa; +Cc: openembedded-core

On 08/19/2015 09:12 PM, Martin Jansa wrote:
> On Wed, Aug 19, 2015 at 03:29:28AM -0400, wenzong.fan@windriver.com wrote:
>> From: Wenzong Fan <wenzong.fan@windriver.com>
>>
>> Pull package from meta-oe to oe-core:
>> meta-oe commit: 8b7d90d8e4c3338f94c588fc7e4a88319bd9a9e8
>
> There is patch for meta-oe to upgrade it to 3.0.6 (which isn't
> compatible with some recipes, but fixes for that were sent as well
> already).

Hi Martin,

Do you mean the fix for python-m2crypto?
----------------------------------------
commit 74de7be5a464e184fed64661e2a45f2f6fac58a5
Author: Li xin <lixin.fnst@cn.fujitsu.com>
Date:   Thu Jul 30 18:31:25 2015 +0800

     python-m2crypto: Error fix for swig >= 3.0.5

     After swig upgrade to 3.0.6, build the recipes which
     depends on python-m2crypto will occur errors like this:
     "SALT_LEN = m2.PKCS5_SALT_LEN
     AttributeError: 'module' object has no attribute 'PKCS5_SALT_LEN'"

     Reference
 
https://github.com/martinpaljak/M2Crypto/issues/60#issuecomment-75735489

     Signed-off-by: Li Xin <lixin.fnst@cn.fujitsu.com>
     Signed-off-by: Martin Jansa <Martin.Jansa@gmail.com>
-----------------------------------------

If the fixes are not applied to swig directly, I think this patch is OK. 
I'll consider to remove swig from meta-oe next step ...

Thanks
Wenzong

>
>> It's required for libcap-ng to build python bindings.
>>
>> With adding it to oe-core, the copies from following layers could
>> be removed:
>>
>> * meta-oe, meta-selinux, meta-intel-iot-middleware ...
>>
>> Signed-off-by: Wenzong Fan <wenzong.fan@windriver.com>
>> ---
>>   meta/recipes-devtools/swig/swig.inc                | 63 ++++++++++++++++++++
>>   ...lf-exe-for-swig-swiglib-on-non-Win32-plat.patch | 69 ++++++++++++++++++++++
>>   ...nfigure-use-pkg-config-for-pcre-detection.patch | 64 ++++++++++++++++++++
>>   meta/recipes-devtools/swig/swig_3.0.2.bb           |  8 +++
>>   4 files changed, 204 insertions(+)
>>   create mode 100644 meta/recipes-devtools/swig/swig.inc
>>   create mode 100644 meta/recipes-devtools/swig/swig/0001-Use-proc-self-exe-for-swig-swiglib-on-non-Win32-plat.patch
>>   create mode 100644 meta/recipes-devtools/swig/swig/0001-configure-use-pkg-config-for-pcre-detection.patch
>>   create mode 100644 meta/recipes-devtools/swig/swig_3.0.2.bb
>>
>> diff --git a/meta/recipes-devtools/swig/swig.inc b/meta/recipes-devtools/swig/swig.inc
>> new file mode 100644
>> index 0000000..9821fa5
>> --- /dev/null
>> +++ b/meta/recipes-devtools/swig/swig.inc
>> @@ -0,0 +1,63 @@
>> +DESCRIPTION = "SWIG - Simplified Wrapper and Interface Generator"
>> +HOMEPAGE = "http://swig.sourceforge.net/"
>> +LICENSE = "BSD & GPLv3"
>> +LIC_FILES_CHKSUM = "file://LICENSE;md5=e7807a6282784a7dde4c846626b08fc6 \
>> +                    file://LICENSE-GPL;md5=d32239bcb673463ab874e80d47fae504 \
>> +                    file://LICENSE-UNIVERSITIES;md5=8ce9dcc8f7c994de4a408b205c72ba08"
>> +
>> +SECTION = "devel"
>> +
>> +DEPENDS = "libpcre python"
>> +
>> +SRC_URI = "${SOURCEFORGE_MIRROR}/${BPN}/${BPN}-${PV}.tar.gz"
>> +
>> +inherit autotools pythonnative
>> +
>> +EXTRA_OECONF = " \
>> +    --with-python=${PYTHON} \
>> +    --without-allegrocl \
>> +    --without-android \
>> +    --without-boost \
>> +    --without-chicken \
>> +    --without-clisp \
>> +    --without-csharp \
>> +    --without-d \
>> +    --without-gcj \
>> +    --without-go \
>> +    --without-guile \
>> +    --without-java \
>> +    --without-lua \
>> +    --without-mzscheme \
>> +    --without-ocaml \
>> +    --without-octave \
>> +    --without-perl5 \
>> +    --without-pike \
>> +    --without-php \
>> +    --without-python3 \
>> +    --without-r \
>> +    --without-ruby \
>> +    --without-tcl \
>> +"
>> +
>> +BBCLASSEXTEND = "native nativesdk"
>> +
>> +do_configure() {
>> +    install -m 0755 ${STAGING_DATADIR_NATIVE}/gnu-config/config.guess ${S}/Tools/config
>> +    install -m 0755 ${STAGING_DATADIR_NATIVE}/gnu-config/config.sub ${S}/Tools/config
>> +    install -m 0755 ${STAGING_DATADIR_NATIVE}/gnu-config/config.guess ${S}
>> +    install -m 0755 ${STAGING_DATADIR_NATIVE}/gnu-config/config.sub ${S}
>> +    oe_runconf
>> +}
>> +
>> +do_install_append_class-nativesdk() {
>> +    cd ${D}${bindir}
>> +    ln -s swig swig2.0
>> +}
>> +
>> +def swiglib_relpath(d):
>> +    swiglib = d.getVar('datadir', True) + "/" + d.getVar('BPN', True) + "/" + d.getVar('PV', True)
>> +    return os.path.relpath(swiglib, d.getVar('bindir', True))
>> +
>> +do_install_append_class-native() {
>> +    create_wrapper ${D}${bindir}/swig SWIG_LIB='`dirname $''realpath`'/${@swiglib_relpath(d)}
>> +}
>> diff --git a/meta/recipes-devtools/swig/swig/0001-Use-proc-self-exe-for-swig-swiglib-on-non-Win32-plat.patch b/meta/recipes-devtools/swig/swig/0001-Use-proc-self-exe-for-swig-swiglib-on-non-Win32-plat.patch
>> new file mode 100644
>> index 0000000..81df3e2
>> --- /dev/null
>> +++ b/meta/recipes-devtools/swig/swig/0001-Use-proc-self-exe-for-swig-swiglib-on-non-Win32-plat.patch
>> @@ -0,0 +1,69 @@
>> +From a4a0440a644c6c5e5da096efe3cf05ba309a284f Mon Sep 17 00:00:00 2001
>> +From: "NODA, Kai" <nodakai@gmail.com>
>> +Date: Sun, 22 Apr 2012 17:01:02 +0900
>> +Subject: [PATCH] Use /proc/self/exe for "swig -swiglib" on non-Win32
>> + platforms.
>> +
>> +If it wasn't found, then fall back to a fixed string just as before.
>> +
>> +Upstream-Status: Submitted
>> +http://sourceforge.net/mailarchive/message.php?msg_id=29179733
>> +
>> +---
>> + Source/Modules/main.cxx |   24 ++++++++++++++++++++++--
>> + 1 file changed, 22 insertions(+), 2 deletions(-)
>> +
>> +diff --git a/Source/Modules/main.cxx b/Source/Modules/main.cxx
>> +index d2f5d3b..cbb0a12 100644
>> +--- a/Source/Modules/main.cxx
>> ++++ b/Source/Modules/main.cxx
>> +@@ -26,6 +26,11 @@ char cvsroot_main_cxx[] = "$Id$";
>> + #include "cparse.h"
>> + #include <ctype.h>
>> + #include <limits.h>		// for INT_MAX
>> ++#ifndef _WIN32
>> ++#include <cstddef>
>> ++#include <unistd.h>		// for readlink
>> ++#include <sys/stat.h>		// for stat
>> ++#endif
>> +
>> + // Global variables
>> +
>> +@@ -902,9 +907,9 @@ int SWIG_main(int argc, char *argv[], Language *l) {
>> +
>> +   // Check for SWIG_LIB environment variable
>> +   if ((c = getenv("SWIG_LIB")) == (char *) 0) {
>> ++    char *p;
>> + #if defined(_WIN32)
>> +     char buf[MAX_PATH];
>> +-    char *p;
>> +     if (!(GetModuleFileName(0, buf, MAX_PATH) == 0 || (p = strrchr(buf, '\\')) == 0)) {
>> +       *(p + 1) = '\0';
>> +       SwigLib = NewStringf("%sLib", buf); // Native windows installation path
>> +@@ -914,7 +919,22 @@ int SWIG_main(int argc, char *argv[], Language *l) {
>> +     if (Len(SWIG_LIB_WIN_UNIX) > 0)
>> +       SwigLibWinUnix = NewString(SWIG_LIB_WIN_UNIX); // Unix installation path using a drive letter (for msys/mingw)
>> + #else
>> +-    SwigLib = NewString(SWIG_LIB);
>> ++    char buf[PATH_MAX];
>> ++    if (0 < ::readlink("/proc/self/exe", buf, sizeof(buf)) &&
>> ++        (p = ::strstr(buf, "/bin/swig"))) {
>> ++        int major, minor, patch;
>> ++        const int ret = ::sscanf(VERSION, "%d.%d.%d", &major, &minor, &patch);
>> ++        if (3 == ret) {
>> ++            const ::ptrdiff_t dir_part_len = p - buf;
>> ++            ::snprintf(p, PATH_MAX - dir_part_len, "/share/swig/%d.%d.%d", major, minor, patch);
>> ++            struct ::stat stat_res;
>> ++            if (0 == ::stat(buf, &stat_res) && S_ISDIR(stat_res.st_mode)) {
>> ++                SwigLib = NewString(buf);
>> ++            }
>> ++        }
>> ++    }
>> ++    if (NULL == SwigLib)
>> ++        SwigLib = NewString(SWIG_LIB);
>> + #endif
>> +   } else {
>> +     SwigLib = NewString(c);
>> +--
>> +1.7.9.5
>> +
>> diff --git a/meta/recipes-devtools/swig/swig/0001-configure-use-pkg-config-for-pcre-detection.patch b/meta/recipes-devtools/swig/swig/0001-configure-use-pkg-config-for-pcre-detection.patch
>> new file mode 100644
>> index 0000000..1b1128a
>> --- /dev/null
>> +++ b/meta/recipes-devtools/swig/swig/0001-configure-use-pkg-config-for-pcre-detection.patch
>> @@ -0,0 +1,64 @@
>> +From 5c4d6d8538994d5fe9b3b46bfafaf0a605e3bda6 Mon Sep 17 00:00:00 2001
>> +From: Koen Kooi <koen.kooi@linaro.org>
>> +Date: Tue, 17 Jun 2014 08:18:17 +0200
>> +Subject: [PATCH] configure: use pkg-config for pcre detection
>> +
>> +Signed-off-by: Koen Kooi <koen.kooi@linaro.org>
>> +Upstream-Status: pending
>> +---
>> + configure.ac | 38 +++++++-------------------------------
>> + 1 file changed, 7 insertions(+), 31 deletions(-)
>> +
>> +diff --git a/configure.ac b/configure.ac
>> +index 0c984b7..6edcec1 100644
>> +--- a/configure.ac
>> ++++ b/configure.ac
>> +@@ -70,38 +70,14 @@ AC_MSG_RESULT([$with_pcre])
>> +
>> + dnl To make configuring easier, check for a locally built PCRE using the Tools/pcre-build.sh script
>> + if test x"${with_pcre}" = xyes ; then
>> +-  AC_MSG_CHECKING([whether to use local PCRE])
>> +-  local_pcre_config=no
>> +-  if test -z $PCRE_CONFIG; then
>> +-    if test -f `pwd`/pcre/pcre-swig-install/bin/pcre-config; then
>> +-      PCRE_CONFIG=`pwd`/pcre/pcre-swig-install/bin/pcre-config
>> +-      local_pcre_config=$PCRE_CONFIG
>> +-    fi
>> +-  fi
>> +-  AC_MSG_RESULT([$local_pcre_config])
>> +-fi
>> +-AS_IF([test "x$with_pcre" != xno],
>> +-  [AX_PATH_GENERIC([pcre],
>> +-    [], dnl Minimal version of PCRE we need -- accept any
>> +-    [], dnl custom sed script for version parsing is not needed
>> +-    [AC_DEFINE([HAVE_PCRE], [1], [Define if you have PCRE library])
>> +-     LIBS="$LIBS $PCRE_LIBS"
>> +-     CPPFLAGS="$CPPFLAGS $PCRE_CFLAGS"
>> +-    ],
>> +-    [AC_MSG_FAILURE([
>> +-        Cannot find pcre-config script from PCRE (Perl Compatible Regular Expressions)
>> +-        library package. This dependency is needed for configure to complete,
>> +-        Either:
>> +-        - Install the PCRE developer package on your system (preferred approach).
>> +-        - Download the PCRE source tarball, build and install on your system
>> +-          as you would for any package built from source distribution.
>> +-        - Use the Tools/pcre-build.sh script to build PCRE just for SWIG to statically
>> +-          link against. Run 'Tools/pcre-build.sh --help' for instructions.
>> +-          (quite easy and does not require privileges to install PCRE on your system)
>> +-        - Use configure --without-pcre to disable regular expressions support in SWIG
>> +-          (not recommended).])
>> +-    ])
>> ++  PKG_CHECK_MODULES([PCRE], [libpcre], [
>> ++    AC_DEFINE([HAVE_PCRE], [1], [Define if you have PCRE library])
>> ++    LIBS="$LIBS $PCRE_LIBS"
>> ++    CPPFLAGS="$CPPFLAGS $PCRE_CFLAGS"
>> ++  ], [
>> ++    AC_MSG_WARN([$PCRE_PKG_ERRORS])
>> +   ])
>> ++fi
>> +
>> +
>> + dnl CCache
>> +--
>> +1.9.3
>> +
>> diff --git a/meta/recipes-devtools/swig/swig_3.0.2.bb b/meta/recipes-devtools/swig/swig_3.0.2.bb
>> new file mode 100644
>> index 0000000..ac41914
>> --- /dev/null
>> +++ b/meta/recipes-devtools/swig/swig_3.0.2.bb
>> @@ -0,0 +1,8 @@
>> +require ${BPN}.inc
>> +
>> +SRC_URI += "file://0001-Use-proc-self-exe-for-swig-swiglib-on-non-Win32-plat.patch \
>> +            file://0001-configure-use-pkg-config-for-pcre-detection.patch \
>> +           "
>> +
>> +SRC_URI[md5sum] = "62f9b0d010cef36a13a010dc530d0d41"
>> +SRC_URI[sha256sum] = "a2669657cabcedc371f63c0457407a183e0b6b2ef4e7e303c1ec9a3964cc7813"
>> --
>> 1.9.1
>>
>> --
>> _______________________________________________
>> Openembedded-core mailing list
>> Openembedded-core@lists.openembedded.org
>> http://lists.openembedded.org/mailman/listinfo/openembedded-core
>


^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [PATCH 1/2] swig: add package 3.0.2
  2015-08-20  1:31     ` wenzong fan
@ 2015-08-20 12:16       ` Martin Jansa
  2015-08-21  2:13         ` wenzong fan
  0 siblings, 1 reply; 7+ messages in thread
From: Martin Jansa @ 2015-08-20 12:16 UTC (permalink / raw)
  To: wenzong fan; +Cc: openembedded-core

[-- Attachment #1: Type: text/plain, Size: 13058 bytes --]

On Thu, Aug 20, 2015 at 09:31:11AM +0800, wenzong fan wrote:
> On 08/19/2015 09:12 PM, Martin Jansa wrote:
> > On Wed, Aug 19, 2015 at 03:29:28AM -0400, wenzong.fan@windriver.com wrote:
> >> From: Wenzong Fan <wenzong.fan@windriver.com>
> >>
> >> Pull package from meta-oe to oe-core:
> >> meta-oe commit: 8b7d90d8e4c3338f94c588fc7e4a88319bd9a9e8
> >
> > There is patch for meta-oe to upgrade it to 3.0.6 (which isn't
> > compatible with some recipes, but fixes for that were sent as well
> > already).
> 
> Hi Martin,
> 
> Do you mean the fix for python-m2crypto?
> ----------------------------------------
> commit 74de7be5a464e184fed64661e2a45f2f6fac58a5
> Author: Li xin <lixin.fnst@cn.fujitsu.com>
> Date:   Thu Jul 30 18:31:25 2015 +0800
> 
>      python-m2crypto: Error fix for swig >= 3.0.5
> 
>      After swig upgrade to 3.0.6, build the recipes which
>      depends on python-m2crypto will occur errors like this:
>      "SALT_LEN = m2.PKCS5_SALT_LEN
>      AttributeError: 'module' object has no attribute 'PKCS5_SALT_LEN'"
> 
>      Reference
>  
> https://github.com/martinpaljak/M2Crypto/issues/60#issuecomment-75735489
> 
>      Signed-off-by: Li Xin <lixin.fnst@cn.fujitsu.com>
>      Signed-off-by: Martin Jansa <Martin.Jansa@gmail.com>
> -----------------------------------------
> 
> If the fixes are not applied to swig directly, I think this patch is OK. 
> I'll consider to remove swig from meta-oe next step ...

Yes and this swig upgrade:

commit 9cc54e10efa5ca70d9980f833a8e5a310e5ad21d
Author: Li xin <lixin.fnst@cn.fujitsu.com>
Date:   Thu Jul 23 18:03:31 2015 +0800

    swig: upgrade 3.0.2 -> 3.0.6

    Signed-off-by: Li Xin <lixin.fnst@cn.fujitsu.com>
    Signed-off-by: Martin Jansa <Martin.Jansa@gmail.com>

both changes are now in meta-oe, so if you add swig-3.0.2 instead of
3.0.5 to oe-core then you will need to upgrade it first before removing
it from meta-oe.

> Thanks
> Wenzong
> 
> >
> >> It's required for libcap-ng to build python bindings.
> >>
> >> With adding it to oe-core, the copies from following layers could
> >> be removed:
> >>
> >> * meta-oe, meta-selinux, meta-intel-iot-middleware ...
> >>
> >> Signed-off-by: Wenzong Fan <wenzong.fan@windriver.com>
> >> ---
> >>   meta/recipes-devtools/swig/swig.inc                | 63 ++++++++++++++++++++
> >>   ...lf-exe-for-swig-swiglib-on-non-Win32-plat.patch | 69 ++++++++++++++++++++++
> >>   ...nfigure-use-pkg-config-for-pcre-detection.patch | 64 ++++++++++++++++++++
> >>   meta/recipes-devtools/swig/swig_3.0.2.bb           |  8 +++
> >>   4 files changed, 204 insertions(+)
> >>   create mode 100644 meta/recipes-devtools/swig/swig.inc
> >>   create mode 100644 meta/recipes-devtools/swig/swig/0001-Use-proc-self-exe-for-swig-swiglib-on-non-Win32-plat.patch
> >>   create mode 100644 meta/recipes-devtools/swig/swig/0001-configure-use-pkg-config-for-pcre-detection.patch
> >>   create mode 100644 meta/recipes-devtools/swig/swig_3.0.2.bb
> >>
> >> diff --git a/meta/recipes-devtools/swig/swig.inc b/meta/recipes-devtools/swig/swig.inc
> >> new file mode 100644
> >> index 0000000..9821fa5
> >> --- /dev/null
> >> +++ b/meta/recipes-devtools/swig/swig.inc
> >> @@ -0,0 +1,63 @@
> >> +DESCRIPTION = "SWIG - Simplified Wrapper and Interface Generator"
> >> +HOMEPAGE = "http://swig.sourceforge.net/"
> >> +LICENSE = "BSD & GPLv3"
> >> +LIC_FILES_CHKSUM = "file://LICENSE;md5=e7807a6282784a7dde4c846626b08fc6 \
> >> +                    file://LICENSE-GPL;md5=d32239bcb673463ab874e80d47fae504 \
> >> +                    file://LICENSE-UNIVERSITIES;md5=8ce9dcc8f7c994de4a408b205c72ba08"
> >> +
> >> +SECTION = "devel"
> >> +
> >> +DEPENDS = "libpcre python"
> >> +
> >> +SRC_URI = "${SOURCEFORGE_MIRROR}/${BPN}/${BPN}-${PV}.tar.gz"
> >> +
> >> +inherit autotools pythonnative
> >> +
> >> +EXTRA_OECONF = " \
> >> +    --with-python=${PYTHON} \
> >> +    --without-allegrocl \
> >> +    --without-android \
> >> +    --without-boost \
> >> +    --without-chicken \
> >> +    --without-clisp \
> >> +    --without-csharp \
> >> +    --without-d \
> >> +    --without-gcj \
> >> +    --without-go \
> >> +    --without-guile \
> >> +    --without-java \
> >> +    --without-lua \
> >> +    --without-mzscheme \
> >> +    --without-ocaml \
> >> +    --without-octave \
> >> +    --without-perl5 \
> >> +    --without-pike \
> >> +    --without-php \
> >> +    --without-python3 \
> >> +    --without-r \
> >> +    --without-ruby \
> >> +    --without-tcl \
> >> +"
> >> +
> >> +BBCLASSEXTEND = "native nativesdk"
> >> +
> >> +do_configure() {
> >> +    install -m 0755 ${STAGING_DATADIR_NATIVE}/gnu-config/config.guess ${S}/Tools/config
> >> +    install -m 0755 ${STAGING_DATADIR_NATIVE}/gnu-config/config.sub ${S}/Tools/config
> >> +    install -m 0755 ${STAGING_DATADIR_NATIVE}/gnu-config/config.guess ${S}
> >> +    install -m 0755 ${STAGING_DATADIR_NATIVE}/gnu-config/config.sub ${S}
> >> +    oe_runconf
> >> +}
> >> +
> >> +do_install_append_class-nativesdk() {
> >> +    cd ${D}${bindir}
> >> +    ln -s swig swig2.0
> >> +}
> >> +
> >> +def swiglib_relpath(d):
> >> +    swiglib = d.getVar('datadir', True) + "/" + d.getVar('BPN', True) + "/" + d.getVar('PV', True)
> >> +    return os.path.relpath(swiglib, d.getVar('bindir', True))
> >> +
> >> +do_install_append_class-native() {
> >> +    create_wrapper ${D}${bindir}/swig SWIG_LIB='`dirname $''realpath`'/${@swiglib_relpath(d)}
> >> +}
> >> diff --git a/meta/recipes-devtools/swig/swig/0001-Use-proc-self-exe-for-swig-swiglib-on-non-Win32-plat.patch b/meta/recipes-devtools/swig/swig/0001-Use-proc-self-exe-for-swig-swiglib-on-non-Win32-plat.patch
> >> new file mode 100644
> >> index 0000000..81df3e2
> >> --- /dev/null
> >> +++ b/meta/recipes-devtools/swig/swig/0001-Use-proc-self-exe-for-swig-swiglib-on-non-Win32-plat.patch
> >> @@ -0,0 +1,69 @@
> >> +From a4a0440a644c6c5e5da096efe3cf05ba309a284f Mon Sep 17 00:00:00 2001
> >> +From: "NODA, Kai" <nodakai@gmail.com>
> >> +Date: Sun, 22 Apr 2012 17:01:02 +0900
> >> +Subject: [PATCH] Use /proc/self/exe for "swig -swiglib" on non-Win32
> >> + platforms.
> >> +
> >> +If it wasn't found, then fall back to a fixed string just as before.
> >> +
> >> +Upstream-Status: Submitted
> >> +http://sourceforge.net/mailarchive/message.php?msg_id=29179733
> >> +
> >> +---
> >> + Source/Modules/main.cxx |   24 ++++++++++++++++++++++--
> >> + 1 file changed, 22 insertions(+), 2 deletions(-)
> >> +
> >> +diff --git a/Source/Modules/main.cxx b/Source/Modules/main.cxx
> >> +index d2f5d3b..cbb0a12 100644
> >> +--- a/Source/Modules/main.cxx
> >> ++++ b/Source/Modules/main.cxx
> >> +@@ -26,6 +26,11 @@ char cvsroot_main_cxx[] = "$Id$";
> >> + #include "cparse.h"
> >> + #include <ctype.h>
> >> + #include <limits.h>		// for INT_MAX
> >> ++#ifndef _WIN32
> >> ++#include <cstddef>
> >> ++#include <unistd.h>		// for readlink
> >> ++#include <sys/stat.h>		// for stat
> >> ++#endif
> >> +
> >> + // Global variables
> >> +
> >> +@@ -902,9 +907,9 @@ int SWIG_main(int argc, char *argv[], Language *l) {
> >> +
> >> +   // Check for SWIG_LIB environment variable
> >> +   if ((c = getenv("SWIG_LIB")) == (char *) 0) {
> >> ++    char *p;
> >> + #if defined(_WIN32)
> >> +     char buf[MAX_PATH];
> >> +-    char *p;
> >> +     if (!(GetModuleFileName(0, buf, MAX_PATH) == 0 || (p = strrchr(buf, '\\')) == 0)) {
> >> +       *(p + 1) = '\0';
> >> +       SwigLib = NewStringf("%sLib", buf); // Native windows installation path
> >> +@@ -914,7 +919,22 @@ int SWIG_main(int argc, char *argv[], Language *l) {
> >> +     if (Len(SWIG_LIB_WIN_UNIX) > 0)
> >> +       SwigLibWinUnix = NewString(SWIG_LIB_WIN_UNIX); // Unix installation path using a drive letter (for msys/mingw)
> >> + #else
> >> +-    SwigLib = NewString(SWIG_LIB);
> >> ++    char buf[PATH_MAX];
> >> ++    if (0 < ::readlink("/proc/self/exe", buf, sizeof(buf)) &&
> >> ++        (p = ::strstr(buf, "/bin/swig"))) {
> >> ++        int major, minor, patch;
> >> ++        const int ret = ::sscanf(VERSION, "%d.%d.%d", &major, &minor, &patch);
> >> ++        if (3 == ret) {
> >> ++            const ::ptrdiff_t dir_part_len = p - buf;
> >> ++            ::snprintf(p, PATH_MAX - dir_part_len, "/share/swig/%d.%d.%d", major, minor, patch);
> >> ++            struct ::stat stat_res;
> >> ++            if (0 == ::stat(buf, &stat_res) && S_ISDIR(stat_res.st_mode)) {
> >> ++                SwigLib = NewString(buf);
> >> ++            }
> >> ++        }
> >> ++    }
> >> ++    if (NULL == SwigLib)
> >> ++        SwigLib = NewString(SWIG_LIB);
> >> + #endif
> >> +   } else {
> >> +     SwigLib = NewString(c);
> >> +--
> >> +1.7.9.5
> >> +
> >> diff --git a/meta/recipes-devtools/swig/swig/0001-configure-use-pkg-config-for-pcre-detection.patch b/meta/recipes-devtools/swig/swig/0001-configure-use-pkg-config-for-pcre-detection.patch
> >> new file mode 100644
> >> index 0000000..1b1128a
> >> --- /dev/null
> >> +++ b/meta/recipes-devtools/swig/swig/0001-configure-use-pkg-config-for-pcre-detection.patch
> >> @@ -0,0 +1,64 @@
> >> +From 5c4d6d8538994d5fe9b3b46bfafaf0a605e3bda6 Mon Sep 17 00:00:00 2001
> >> +From: Koen Kooi <koen.kooi@linaro.org>
> >> +Date: Tue, 17 Jun 2014 08:18:17 +0200
> >> +Subject: [PATCH] configure: use pkg-config for pcre detection
> >> +
> >> +Signed-off-by: Koen Kooi <koen.kooi@linaro.org>
> >> +Upstream-Status: pending
> >> +---
> >> + configure.ac | 38 +++++++-------------------------------
> >> + 1 file changed, 7 insertions(+), 31 deletions(-)
> >> +
> >> +diff --git a/configure.ac b/configure.ac
> >> +index 0c984b7..6edcec1 100644
> >> +--- a/configure.ac
> >> ++++ b/configure.ac
> >> +@@ -70,38 +70,14 @@ AC_MSG_RESULT([$with_pcre])
> >> +
> >> + dnl To make configuring easier, check for a locally built PCRE using the Tools/pcre-build.sh script
> >> + if test x"${with_pcre}" = xyes ; then
> >> +-  AC_MSG_CHECKING([whether to use local PCRE])
> >> +-  local_pcre_config=no
> >> +-  if test -z $PCRE_CONFIG; then
> >> +-    if test -f `pwd`/pcre/pcre-swig-install/bin/pcre-config; then
> >> +-      PCRE_CONFIG=`pwd`/pcre/pcre-swig-install/bin/pcre-config
> >> +-      local_pcre_config=$PCRE_CONFIG
> >> +-    fi
> >> +-  fi
> >> +-  AC_MSG_RESULT([$local_pcre_config])
> >> +-fi
> >> +-AS_IF([test "x$with_pcre" != xno],
> >> +-  [AX_PATH_GENERIC([pcre],
> >> +-    [], dnl Minimal version of PCRE we need -- accept any
> >> +-    [], dnl custom sed script for version parsing is not needed
> >> +-    [AC_DEFINE([HAVE_PCRE], [1], [Define if you have PCRE library])
> >> +-     LIBS="$LIBS $PCRE_LIBS"
> >> +-     CPPFLAGS="$CPPFLAGS $PCRE_CFLAGS"
> >> +-    ],
> >> +-    [AC_MSG_FAILURE([
> >> +-        Cannot find pcre-config script from PCRE (Perl Compatible Regular Expressions)
> >> +-        library package. This dependency is needed for configure to complete,
> >> +-        Either:
> >> +-        - Install the PCRE developer package on your system (preferred approach).
> >> +-        - Download the PCRE source tarball, build and install on your system
> >> +-          as you would for any package built from source distribution.
> >> +-        - Use the Tools/pcre-build.sh script to build PCRE just for SWIG to statically
> >> +-          link against. Run 'Tools/pcre-build.sh --help' for instructions.
> >> +-          (quite easy and does not require privileges to install PCRE on your system)
> >> +-        - Use configure --without-pcre to disable regular expressions support in SWIG
> >> +-          (not recommended).])
> >> +-    ])
> >> ++  PKG_CHECK_MODULES([PCRE], [libpcre], [
> >> ++    AC_DEFINE([HAVE_PCRE], [1], [Define if you have PCRE library])
> >> ++    LIBS="$LIBS $PCRE_LIBS"
> >> ++    CPPFLAGS="$CPPFLAGS $PCRE_CFLAGS"
> >> ++  ], [
> >> ++    AC_MSG_WARN([$PCRE_PKG_ERRORS])
> >> +   ])
> >> ++fi
> >> +
> >> +
> >> + dnl CCache
> >> +--
> >> +1.9.3
> >> +
> >> diff --git a/meta/recipes-devtools/swig/swig_3.0.2.bb b/meta/recipes-devtools/swig/swig_3.0.2.bb
> >> new file mode 100644
> >> index 0000000..ac41914
> >> --- /dev/null
> >> +++ b/meta/recipes-devtools/swig/swig_3.0.2.bb
> >> @@ -0,0 +1,8 @@
> >> +require ${BPN}.inc
> >> +
> >> +SRC_URI += "file://0001-Use-proc-self-exe-for-swig-swiglib-on-non-Win32-plat.patch \
> >> +            file://0001-configure-use-pkg-config-for-pcre-detection.patch \
> >> +           "
> >> +
> >> +SRC_URI[md5sum] = "62f9b0d010cef36a13a010dc530d0d41"
> >> +SRC_URI[sha256sum] = "a2669657cabcedc371f63c0457407a183e0b6b2ef4e7e303c1ec9a3964cc7813"
> >> --
> >> 1.9.1
> >>
> >> --
> >> _______________________________________________
> >> Openembedded-core mailing list
> >> Openembedded-core@lists.openembedded.org
> >> http://lists.openembedded.org/mailman/listinfo/openembedded-core
> >

-- 
Martin 'JaMa' Jansa     jabber: Martin.Jansa@gmail.com

[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 188 bytes --]

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [PATCH 1/2] swig: add package 3.0.2
  2015-08-20 12:16       ` Martin Jansa
@ 2015-08-21  2:13         ` wenzong fan
  0 siblings, 0 replies; 7+ messages in thread
From: wenzong fan @ 2015-08-21  2:13 UTC (permalink / raw)
  To: Martin Jansa; +Cc: openembedded-core

On 08/20/2015 08:16 PM, Martin Jansa wrote:
> On Thu, Aug 20, 2015 at 09:31:11AM +0800, wenzong fan wrote:
>> On 08/19/2015 09:12 PM, Martin Jansa wrote:
>>> On Wed, Aug 19, 2015 at 03:29:28AM -0400, wenzong.fan@windriver.com wrote:
>>>> From: Wenzong Fan <wenzong.fan@windriver.com>
>>>>
>>>> Pull package from meta-oe to oe-core:
>>>> meta-oe commit: 8b7d90d8e4c3338f94c588fc7e4a88319bd9a9e8
>>>
>>> There is patch for meta-oe to upgrade it to 3.0.6 (which isn't
>>> compatible with some recipes, but fixes for that were sent as well
>>> already).
>>
>> Hi Martin,
>>
>> Do you mean the fix for python-m2crypto?
>> ----------------------------------------
>> commit 74de7be5a464e184fed64661e2a45f2f6fac58a5
>> Author: Li xin <lixin.fnst@cn.fujitsu.com>
>> Date:   Thu Jul 30 18:31:25 2015 +0800
>>
>>       python-m2crypto: Error fix for swig >= 3.0.5
>>
>>       After swig upgrade to 3.0.6, build the recipes which
>>       depends on python-m2crypto will occur errors like this:
>>       "SALT_LEN = m2.PKCS5_SALT_LEN
>>       AttributeError: 'module' object has no attribute 'PKCS5_SALT_LEN'"
>>
>>       Reference
>>
>> https://github.com/martinpaljak/M2Crypto/issues/60#issuecomment-75735489
>>
>>       Signed-off-by: Li Xin <lixin.fnst@cn.fujitsu.com>
>>       Signed-off-by: Martin Jansa <Martin.Jansa@gmail.com>
>> -----------------------------------------
>>
>> If the fixes are not applied to swig directly, I think this patch is OK.
>> I'll consider to remove swig from meta-oe next step ...
>
> Yes and this swig upgrade:
>
> commit 9cc54e10efa5ca70d9980f833a8e5a310e5ad21d
> Author: Li xin <lixin.fnst@cn.fujitsu.com>
> Date:   Thu Jul 23 18:03:31 2015 +0800
>
>      swig: upgrade 3.0.2 -> 3.0.6
>
>      Signed-off-by: Li Xin <lixin.fnst@cn.fujitsu.com>
>      Signed-off-by: Martin Jansa <Martin.Jansa@gmail.com>
>
> both changes are now in meta-oe, so if you add swig-3.0.2 instead of
> 3.0.5 to oe-core then you will need to upgrade it first before removing
> it from meta-oe.

Ah, yes. I'll update my patch and pick the 3.0.6 to oe-core.

Thanks
Wenzong

>
>> Thanks
>> Wenzong
>>
>>>
>>>> It's required for libcap-ng to build python bindings.
>>>>
>>>> With adding it to oe-core, the copies from following layers could
>>>> be removed:
>>>>
>>>> * meta-oe, meta-selinux, meta-intel-iot-middleware ...
>>>>
>>>> Signed-off-by: Wenzong Fan <wenzong.fan@windriver.com>
>>>> ---
>>>>    meta/recipes-devtools/swig/swig.inc                | 63 ++++++++++++++++++++
>>>>    ...lf-exe-for-swig-swiglib-on-non-Win32-plat.patch | 69 ++++++++++++++++++++++
>>>>    ...nfigure-use-pkg-config-for-pcre-detection.patch | 64 ++++++++++++++++++++
>>>>    meta/recipes-devtools/swig/swig_3.0.2.bb           |  8 +++
>>>>    4 files changed, 204 insertions(+)
>>>>    create mode 100644 meta/recipes-devtools/swig/swig.inc
>>>>    create mode 100644 meta/recipes-devtools/swig/swig/0001-Use-proc-self-exe-for-swig-swiglib-on-non-Win32-plat.patch
>>>>    create mode 100644 meta/recipes-devtools/swig/swig/0001-configure-use-pkg-config-for-pcre-detection.patch
>>>>    create mode 100644 meta/recipes-devtools/swig/swig_3.0.2.bb
>>>>
>>>> diff --git a/meta/recipes-devtools/swig/swig.inc b/meta/recipes-devtools/swig/swig.inc
>>>> new file mode 100644
>>>> index 0000000..9821fa5
>>>> --- /dev/null
>>>> +++ b/meta/recipes-devtools/swig/swig.inc
>>>> @@ -0,0 +1,63 @@
>>>> +DESCRIPTION = "SWIG - Simplified Wrapper and Interface Generator"
>>>> +HOMEPAGE = "http://swig.sourceforge.net/"
>>>> +LICENSE = "BSD & GPLv3"
>>>> +LIC_FILES_CHKSUM = "file://LICENSE;md5=e7807a6282784a7dde4c846626b08fc6 \
>>>> +                    file://LICENSE-GPL;md5=d32239bcb673463ab874e80d47fae504 \
>>>> +                    file://LICENSE-UNIVERSITIES;md5=8ce9dcc8f7c994de4a408b205c72ba08"
>>>> +
>>>> +SECTION = "devel"
>>>> +
>>>> +DEPENDS = "libpcre python"
>>>> +
>>>> +SRC_URI = "${SOURCEFORGE_MIRROR}/${BPN}/${BPN}-${PV}.tar.gz"
>>>> +
>>>> +inherit autotools pythonnative
>>>> +
>>>> +EXTRA_OECONF = " \
>>>> +    --with-python=${PYTHON} \
>>>> +    --without-allegrocl \
>>>> +    --without-android \
>>>> +    --without-boost \
>>>> +    --without-chicken \
>>>> +    --without-clisp \
>>>> +    --without-csharp \
>>>> +    --without-d \
>>>> +    --without-gcj \
>>>> +    --without-go \
>>>> +    --without-guile \
>>>> +    --without-java \
>>>> +    --without-lua \
>>>> +    --without-mzscheme \
>>>> +    --without-ocaml \
>>>> +    --without-octave \
>>>> +    --without-perl5 \
>>>> +    --without-pike \
>>>> +    --without-php \
>>>> +    --without-python3 \
>>>> +    --without-r \
>>>> +    --without-ruby \
>>>> +    --without-tcl \
>>>> +"
>>>> +
>>>> +BBCLASSEXTEND = "native nativesdk"
>>>> +
>>>> +do_configure() {
>>>> +    install -m 0755 ${STAGING_DATADIR_NATIVE}/gnu-config/config.guess ${S}/Tools/config
>>>> +    install -m 0755 ${STAGING_DATADIR_NATIVE}/gnu-config/config.sub ${S}/Tools/config
>>>> +    install -m 0755 ${STAGING_DATADIR_NATIVE}/gnu-config/config.guess ${S}
>>>> +    install -m 0755 ${STAGING_DATADIR_NATIVE}/gnu-config/config.sub ${S}
>>>> +    oe_runconf
>>>> +}
>>>> +
>>>> +do_install_append_class-nativesdk() {
>>>> +    cd ${D}${bindir}
>>>> +    ln -s swig swig2.0
>>>> +}
>>>> +
>>>> +def swiglib_relpath(d):
>>>> +    swiglib = d.getVar('datadir', True) + "/" + d.getVar('BPN', True) + "/" + d.getVar('PV', True)
>>>> +    return os.path.relpath(swiglib, d.getVar('bindir', True))
>>>> +
>>>> +do_install_append_class-native() {
>>>> +    create_wrapper ${D}${bindir}/swig SWIG_LIB='`dirname $''realpath`'/${@swiglib_relpath(d)}
>>>> +}
>>>> diff --git a/meta/recipes-devtools/swig/swig/0001-Use-proc-self-exe-for-swig-swiglib-on-non-Win32-plat.patch b/meta/recipes-devtools/swig/swig/0001-Use-proc-self-exe-for-swig-swiglib-on-non-Win32-plat.patch
>>>> new file mode 100644
>>>> index 0000000..81df3e2
>>>> --- /dev/null
>>>> +++ b/meta/recipes-devtools/swig/swig/0001-Use-proc-self-exe-for-swig-swiglib-on-non-Win32-plat.patch
>>>> @@ -0,0 +1,69 @@
>>>> +From a4a0440a644c6c5e5da096efe3cf05ba309a284f Mon Sep 17 00:00:00 2001
>>>> +From: "NODA, Kai" <nodakai@gmail.com>
>>>> +Date: Sun, 22 Apr 2012 17:01:02 +0900
>>>> +Subject: [PATCH] Use /proc/self/exe for "swig -swiglib" on non-Win32
>>>> + platforms.
>>>> +
>>>> +If it wasn't found, then fall back to a fixed string just as before.
>>>> +
>>>> +Upstream-Status: Submitted
>>>> +http://sourceforge.net/mailarchive/message.php?msg_id=29179733
>>>> +
>>>> +---
>>>> + Source/Modules/main.cxx |   24 ++++++++++++++++++++++--
>>>> + 1 file changed, 22 insertions(+), 2 deletions(-)
>>>> +
>>>> +diff --git a/Source/Modules/main.cxx b/Source/Modules/main.cxx
>>>> +index d2f5d3b..cbb0a12 100644
>>>> +--- a/Source/Modules/main.cxx
>>>> ++++ b/Source/Modules/main.cxx
>>>> +@@ -26,6 +26,11 @@ char cvsroot_main_cxx[] = "$Id$";
>>>> + #include "cparse.h"
>>>> + #include <ctype.h>
>>>> + #include <limits.h>		// for INT_MAX
>>>> ++#ifndef _WIN32
>>>> ++#include <cstddef>
>>>> ++#include <unistd.h>		// for readlink
>>>> ++#include <sys/stat.h>		// for stat
>>>> ++#endif
>>>> +
>>>> + // Global variables
>>>> +
>>>> +@@ -902,9 +907,9 @@ int SWIG_main(int argc, char *argv[], Language *l) {
>>>> +
>>>> +   // Check for SWIG_LIB environment variable
>>>> +   if ((c = getenv("SWIG_LIB")) == (char *) 0) {
>>>> ++    char *p;
>>>> + #if defined(_WIN32)
>>>> +     char buf[MAX_PATH];
>>>> +-    char *p;
>>>> +     if (!(GetModuleFileName(0, buf, MAX_PATH) == 0 || (p = strrchr(buf, '\\')) == 0)) {
>>>> +       *(p + 1) = '\0';
>>>> +       SwigLib = NewStringf("%sLib", buf); // Native windows installation path
>>>> +@@ -914,7 +919,22 @@ int SWIG_main(int argc, char *argv[], Language *l) {
>>>> +     if (Len(SWIG_LIB_WIN_UNIX) > 0)
>>>> +       SwigLibWinUnix = NewString(SWIG_LIB_WIN_UNIX); // Unix installation path using a drive letter (for msys/mingw)
>>>> + #else
>>>> +-    SwigLib = NewString(SWIG_LIB);
>>>> ++    char buf[PATH_MAX];
>>>> ++    if (0 < ::readlink("/proc/self/exe", buf, sizeof(buf)) &&
>>>> ++        (p = ::strstr(buf, "/bin/swig"))) {
>>>> ++        int major, minor, patch;
>>>> ++        const int ret = ::sscanf(VERSION, "%d.%d.%d", &major, &minor, &patch);
>>>> ++        if (3 == ret) {
>>>> ++            const ::ptrdiff_t dir_part_len = p - buf;
>>>> ++            ::snprintf(p, PATH_MAX - dir_part_len, "/share/swig/%d.%d.%d", major, minor, patch);
>>>> ++            struct ::stat stat_res;
>>>> ++            if (0 == ::stat(buf, &stat_res) && S_ISDIR(stat_res.st_mode)) {
>>>> ++                SwigLib = NewString(buf);
>>>> ++            }
>>>> ++        }
>>>> ++    }
>>>> ++    if (NULL == SwigLib)
>>>> ++        SwigLib = NewString(SWIG_LIB);
>>>> + #endif
>>>> +   } else {
>>>> +     SwigLib = NewString(c);
>>>> +--
>>>> +1.7.9.5
>>>> +
>>>> diff --git a/meta/recipes-devtools/swig/swig/0001-configure-use-pkg-config-for-pcre-detection.patch b/meta/recipes-devtools/swig/swig/0001-configure-use-pkg-config-for-pcre-detection.patch
>>>> new file mode 100644
>>>> index 0000000..1b1128a
>>>> --- /dev/null
>>>> +++ b/meta/recipes-devtools/swig/swig/0001-configure-use-pkg-config-for-pcre-detection.patch
>>>> @@ -0,0 +1,64 @@
>>>> +From 5c4d6d8538994d5fe9b3b46bfafaf0a605e3bda6 Mon Sep 17 00:00:00 2001
>>>> +From: Koen Kooi <koen.kooi@linaro.org>
>>>> +Date: Tue, 17 Jun 2014 08:18:17 +0200
>>>> +Subject: [PATCH] configure: use pkg-config for pcre detection
>>>> +
>>>> +Signed-off-by: Koen Kooi <koen.kooi@linaro.org>
>>>> +Upstream-Status: pending
>>>> +---
>>>> + configure.ac | 38 +++++++-------------------------------
>>>> + 1 file changed, 7 insertions(+), 31 deletions(-)
>>>> +
>>>> +diff --git a/configure.ac b/configure.ac
>>>> +index 0c984b7..6edcec1 100644
>>>> +--- a/configure.ac
>>>> ++++ b/configure.ac
>>>> +@@ -70,38 +70,14 @@ AC_MSG_RESULT([$with_pcre])
>>>> +
>>>> + dnl To make configuring easier, check for a locally built PCRE using the Tools/pcre-build.sh script
>>>> + if test x"${with_pcre}" = xyes ; then
>>>> +-  AC_MSG_CHECKING([whether to use local PCRE])
>>>> +-  local_pcre_config=no
>>>> +-  if test -z $PCRE_CONFIG; then
>>>> +-    if test -f `pwd`/pcre/pcre-swig-install/bin/pcre-config; then
>>>> +-      PCRE_CONFIG=`pwd`/pcre/pcre-swig-install/bin/pcre-config
>>>> +-      local_pcre_config=$PCRE_CONFIG
>>>> +-    fi
>>>> +-  fi
>>>> +-  AC_MSG_RESULT([$local_pcre_config])
>>>> +-fi
>>>> +-AS_IF([test "x$with_pcre" != xno],
>>>> +-  [AX_PATH_GENERIC([pcre],
>>>> +-    [], dnl Minimal version of PCRE we need -- accept any
>>>> +-    [], dnl custom sed script for version parsing is not needed
>>>> +-    [AC_DEFINE([HAVE_PCRE], [1], [Define if you have PCRE library])
>>>> +-     LIBS="$LIBS $PCRE_LIBS"
>>>> +-     CPPFLAGS="$CPPFLAGS $PCRE_CFLAGS"
>>>> +-    ],
>>>> +-    [AC_MSG_FAILURE([
>>>> +-        Cannot find pcre-config script from PCRE (Perl Compatible Regular Expressions)
>>>> +-        library package. This dependency is needed for configure to complete,
>>>> +-        Either:
>>>> +-        - Install the PCRE developer package on your system (preferred approach).
>>>> +-        - Download the PCRE source tarball, build and install on your system
>>>> +-          as you would for any package built from source distribution.
>>>> +-        - Use the Tools/pcre-build.sh script to build PCRE just for SWIG to statically
>>>> +-          link against. Run 'Tools/pcre-build.sh --help' for instructions.
>>>> +-          (quite easy and does not require privileges to install PCRE on your system)
>>>> +-        - Use configure --without-pcre to disable regular expressions support in SWIG
>>>> +-          (not recommended).])
>>>> +-    ])
>>>> ++  PKG_CHECK_MODULES([PCRE], [libpcre], [
>>>> ++    AC_DEFINE([HAVE_PCRE], [1], [Define if you have PCRE library])
>>>> ++    LIBS="$LIBS $PCRE_LIBS"
>>>> ++    CPPFLAGS="$CPPFLAGS $PCRE_CFLAGS"
>>>> ++  ], [
>>>> ++    AC_MSG_WARN([$PCRE_PKG_ERRORS])
>>>> +   ])
>>>> ++fi
>>>> +
>>>> +
>>>> + dnl CCache
>>>> +--
>>>> +1.9.3
>>>> +
>>>> diff --git a/meta/recipes-devtools/swig/swig_3.0.2.bb b/meta/recipes-devtools/swig/swig_3.0.2.bb
>>>> new file mode 100644
>>>> index 0000000..ac41914
>>>> --- /dev/null
>>>> +++ b/meta/recipes-devtools/swig/swig_3.0.2.bb
>>>> @@ -0,0 +1,8 @@
>>>> +require ${BPN}.inc
>>>> +
>>>> +SRC_URI += "file://0001-Use-proc-self-exe-for-swig-swiglib-on-non-Win32-plat.patch \
>>>> +            file://0001-configure-use-pkg-config-for-pcre-detection.patch \
>>>> +           "
>>>> +
>>>> +SRC_URI[md5sum] = "62f9b0d010cef36a13a010dc530d0d41"
>>>> +SRC_URI[sha256sum] = "a2669657cabcedc371f63c0457407a183e0b6b2ef4e7e303c1ec9a3964cc7813"
>>>> --
>>>> 1.9.1
>>>>
>>>> --
>>>> _______________________________________________
>>>> Openembedded-core mailing list
>>>> Openembedded-core@lists.openembedded.org
>>>> http://lists.openembedded.org/mailman/listinfo/openembedded-core
>>>
>


^ permalink raw reply	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2015-08-21  2:13 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2015-08-19  7:29 [PATCH 0/2] libcap-ng, swig: add packages wenzong.fan
2015-08-19  7:29 ` [PATCH 1/2] swig: add package 3.0.2 wenzong.fan
2015-08-19 13:12   ` Martin Jansa
2015-08-20  1:31     ` wenzong fan
2015-08-20 12:16       ` Martin Jansa
2015-08-21  2:13         ` wenzong fan
2015-08-19  7:29 ` [PATCH 2/2] libcap-ng: add package 0.7.7 wenzong.fan

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.