Openembedded Core Discussions
 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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox