commit:     94b31620a546137d41747b51d968ec617e122173
Author:     Chema Alonso <nimiux <AT> gentoo <DOT> org>
AuthorDate: Wed Dec 17 16:19:39 2014 +0000
Commit:     José María Alonso <nimiux <AT> gentoo <DOT> org>
CommitDate: Wed Dec 17 16:19:39 2014 +0000
URL:        
http://sources.gentoo.org/gitweb/?p=proj/lisp.git;a=commit;h=94b31620

dev-lisp/sbcl: bump to version 1.2.6

---
 dev-lisp/sbcl/files/bsd-sockets-test-1.2.patch     |  24 +++
 dev-lisp/sbcl/files/concurrency-test-1.2.6.patch   |  24 +++
 ...7-gentoo-fix_nopie_for_hardened_toolchain.patch |  22 +++
 dev-lisp/sbcl/metadata.xml                         |   1 +
 dev-lisp/sbcl/sbcl-1.2.6.ebuild                    | 206 +++++++++++++++++++++
 5 files changed, 277 insertions(+)

diff --git a/dev-lisp/sbcl/files/bsd-sockets-test-1.2.patch 
b/dev-lisp/sbcl/files/bsd-sockets-test-1.2.patch
new file mode 100644
index 0000000..7a7b12b
--- /dev/null
+++ b/dev-lisp/sbcl/files/bsd-sockets-test-1.2.patch
@@ -0,0 +1,24 @@
+diff -r -U1 sbcl-1.2.2.orig/contrib/sb-bsd-sockets/tests.lisp 
sbcl-1.2.2/contrib/sb-bsd-sockets/tests.lisp
+--- sbcl-1.2.2.orig/contrib/sb-bsd-sockets/tests.lisp  2014-07-28 
17:15:05.000000000 +0700
++++ sbcl-1.2.2/contrib/sb-bsd-sockets/tests.lisp       2014-08-01 
19:48:30.011931081 +0700
+@@ -31,11 +31,11 @@
+ ;;; for unknown protocols...
+-#-(and freebsd sb-thread)
+-#-(and dragonfly sb-thread)
+-(deftest get-protocol-by-name/error
+-  (handler-case (get-protocol-by-name "nonexistent-protocol")
+-    (unknown-protocol ()
+-      t)
+-    (:no-error ()
+-      nil))
+-  t)
++;#-(and freebsd sb-thread)
++;#-(and dragonfly sb-thread)
++;(deftest get-protocol-by-name/error
++;  (handler-case (get-protocol-by-name "nonexistent-protocol")
++;    (unknown-protocol ()
++;      t)
++;    (:no-error ()
++;      nil))
++;  t)
+ 

diff --git a/dev-lisp/sbcl/files/concurrency-test-1.2.6.patch 
b/dev-lisp/sbcl/files/concurrency-test-1.2.6.patch
new file mode 100644
index 0000000..b85fc16
--- /dev/null
+++ b/dev-lisp/sbcl/files/concurrency-test-1.2.6.patch
@@ -0,0 +1,24 @@
+diff -Nuar a/contrib/sb-concurrency/tests/test-frlock.lisp 
b/contrib/sb-concurrency/tests/test-frlock.lisp
+--- a/contrib/sb-concurrency/tests/test-frlock.lisp    2014-11-29 
19:56:58.000000000 +0100
++++ b/contrib/sb-concurrency/tests/test-frlock.lisp    2014-12-16 
23:52:18.569947139 +0100
+@@ -22,9 +22,9 @@
+   #+openbsd 0.01
+   #-openbsd 0.0001)
+ 
+-(defun test-frlocks (&key (reader-count 100) (read-count 1000000)
++(defun test-frlocks (&key (reader-count 50) (read-count 500000)
+                           (outer-read-pause 0) (inner-read-pause 0)
+-                          (writer-count 10) (write-count (/ 1 
*minimum-sleep*))
++                          (writer-count 10) (write-count 5000)
+                           (outer-write-pause *minimum-sleep*) 
(inner-write-pause 0))
+     (let ((rw (make-frlock))
+           (a 0)
+@@ -87,7 +87,7 @@
+ #+sb-thread
+ (deftest* (frlock.1 :fails-on :win32)
+     (handler-case
+-        (sb-ext:with-timeout 60 (test-frlocks))
++        (sb-ext:with-timeout 240 (test-frlocks))
+       (sb-ext:timeout (c)
+         (error "~A" c)))
+   nil

diff --git 
a/dev-lisp/sbcl/files/sbcl-1.1.17-gentoo-fix_nopie_for_hardened_toolchain.patch 
b/dev-lisp/sbcl/files/sbcl-1.1.17-gentoo-fix_nopie_for_hardened_toolchain.patch
new file mode 100644
index 0000000..bf03ada
--- /dev/null
+++ 
b/dev-lisp/sbcl/files/sbcl-1.1.17-gentoo-fix_nopie_for_hardened_toolchain.patch
@@ -0,0 +1,22 @@
+--- sbcl-1.1.17-orig/src/runtime/Config.x86-linux      2014-03-31 
03:14:22.000000000 +1100
++++ sbcl-1.1.17/src/runtime/Config.x86-linux   2014-04-28 15:34:59.822482441 
+1000
+@@ -27,7 +27,7 @@
+ # (You *are* encouraged to design and implement a coherent stable
+ # interface, though.:-| As far as I (WHN 2002-05-19) know, no one is
+ # working on one and it would be a nice thing to have.)
+-LINKFLAGS += -Wl,--export-dynamic -m32
++LINKFLAGS += -Wl,--export-dynamic -m32 -nopie
+ OS_LIBS = -ldl
+ 
+ ifdef LISP_FEATURE_LARGEFILE
+--- sbcl-1.1.17-orig/src/runtime/Config.x86-64-linux   2014-03-31 
03:14:22.000000000 +1100
++++ sbcl-1.1.17/src/runtime/Config.x86-64-linux        2014-04-28 
15:35:22.364623003 +1000
+@@ -27,7 +27,7 @@
+ # (You *are* encouraged to design and implement a coherent stable
+ # interface, though.:-| As far as I (WHN 2002-05-19) know, no one is
+ # working on one and it would be a nice thing to have.)
+-LINKFLAGS += -Wl,--export-dynamic
++LINKFLAGS += -Wl,--export-dynamic -nopie
+ OS_LIBS = -ldl
+ 
+ ifdef LISP_FEATURE_LARGEFILE

diff --git a/dev-lisp/sbcl/metadata.xml b/dev-lisp/sbcl/metadata.xml
index 1fe9d18..d2fa3df 100644
--- a/dev-lisp/sbcl/metadata.xml
+++ b/dev-lisp/sbcl/metadata.xml
@@ -22,5 +22,6 @@ SBCL 0.8.17 and later support Unicode.
 <use>
 <flag name='cobalt'>mips only: use mipsel binary instead of mips big endian
 binary to bootstrap</flag>
+<flag name='pax_kernel'>Enable if the user plans to run the package under a 
pax enabled hardened kernel</flag>
 </use>
 </pkgmetadata>

diff --git a/dev-lisp/sbcl/sbcl-1.2.6.ebuild b/dev-lisp/sbcl/sbcl-1.2.6.ebuild
new file mode 100644
index 0000000..6210100
--- /dev/null
+++ b/dev-lisp/sbcl/sbcl-1.2.6.ebuild
@@ -0,0 +1,206 @@
+# Copyright 1999-2014 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: $
+
+EAPI=5
+inherit multilib eutils flag-o-matic pax-utils
+
+#same order as http://www.sbcl.org/platform-table.html
+BV_X86=1.0.58
+BV_AMD64=1.2.6
+BV_PPC=1.0.28
+BV_SPARC=1.0.28
+BV_ALPHA=1.0.28
+
+DESCRIPTION="Steel Bank Common Lisp (SBCL) is an implementation of ANSI Common 
Lisp"
+HOMEPAGE="http://sbcl.sourceforge.net/";
+SRC_URI="mirror://sourceforge/sbcl/${P}-source.tar.bz2
+       x86? ( 
mirror://sourceforge/sbcl/${PN}-${BV_X86}-x86-linux-binary.tar.bz2 )
+       amd64? ( 
mirror://sourceforge/sbcl/${PN}-${BV_AMD64}-x86-64-linux-binary.tar.bz2 )
+       ppc? ( 
mirror://sourceforge/sbcl/${PN}-${BV_PPC}-powerpc-linux-binary.tar.bz2 )
+       sparc? ( 
mirror://sourceforge/sbcl/${PN}-${BV_SPARC}-sparc-linux-binary.tar.bz2 )
+       alpha? ( 
mirror://sourceforge/sbcl/${PN}-${BV_ALPHA}-alpha-linux-binary.tar.bz2 )"
+
+LICENSE="MIT"
+SLOT="0/${PV}"
+KEYWORDS="~amd64 ~ppc ~sparc ~x86"
+IUSE="debug doc source +threads +unicode pax_kernel zlib"
+
+CDEPEND=">=dev-lisp/asdf-3.1:="
+DEPEND="${CDEPEND}
+               doc? ( sys-apps/texinfo >=media-gfx/graphviz-2.26.0 )
+               pax_kernel? ( sys-apps/paxctl sys-apps/elfix )"
+RDEPEND="${CDEPEND}
+                elibc_glibc? ( >=sys-libs/glibc-2.6 )"
+
+# Disable warnings about executable stacks, as this won't be fixed soon by 
upstream
+QA_EXECSTACK="usr/bin/sbcl"
+
+CONFIG="${S}/customize-target-features.lisp"
+ENVD="${T}/50sbcl"
+
+# Prevent ASDF from using the system libraries
+CL_SOURCE_REGISTRY="(:source-registry :ignore-inherited-configuration)"
+ASDF_OUTPUT_TRANSLATIONS="(:output-translations 
:ignore-inherited-configuration)"
+
+usep() {
+       use ${1} && echo "true" || echo "false"
+}
+
+sbcl_feature() {
+       echo "$( [[ ${1} == "true" ]] && echo "(enable ${2})" || echo "(disable 
${2})")" >> "${CONFIG}"
+}
+
+sbcl_apply_features() {
+       sed 's/^X//' > "${CONFIG}" <<-'EOF'
+       (lambda (list)
+       X  (flet ((enable  (x) (pushnew x list))
+       X         (disable (x) (setf list (remove x list))))
+       EOF
+       if use x86 || use amd64; then
+               sbcl_feature "$(usep threads)" ":sb-thread"
+       fi
+       sbcl_feature "true" ":sb-ldb"
+       sbcl_feature "false" ":sb-test"
+       sbcl_feature "$(usep unicode)" ":sb-unicode"
+       sbcl_feature "$(usep zlib)" ":sb-core-compression"
+       sbcl_feature "$(usep debug)" ":sb-xref-for-internals"
+       sed 's/^X//' >> "${CONFIG}" <<-'EOF'
+       X    )
+       X  list)
+       EOF
+       cat "${CONFIG}"
+}
+
+src_unpack() {
+       unpack ${A}
+       mv sbcl-*-linux sbcl-binary || die
+       cd "${S}"
+}
+
+src_prepare() {
+       epatch "${FILESDIR}"/gentoo-fix_install_man.patch
+       # bug #468482
+       epatch "${FILESDIR}/concurrency-test-${PV}.patch"
+       # bug #486552
+       epatch "${FILESDIR}"/bsd-sockets-test-1.2.patch
+
+       # To make the hardened compiler NOT compile with -fPIE -pie
+       if gcc-specs-pie ; then
+               einfo "Disabling PIE..."
+               epatch 
"${FILESDIR}"/${PN}-1.1.17-gentoo-fix_nopie_for_hardened_toolchain.patch
+       fi
+
+       cp /usr/share/common-lisp/source/asdf/build/asdf.lisp contrib/asdf/ || 
die
+
+       use source && sed 's%"$(BUILD_ROOT)%$(MODULE).lisp "$(BUILD_ROOT)%' -i 
contrib/vanilla-module.mk
+
+       # Some shells(such as dash) don't have "time" as builtin
+       # and we don't want to DEPEND on sys-process/time
+       sed "s,^time ,," -i make.sh || die
+       sed "s,/lib,/$(get_libdir),g" -i install.sh || die
+       # #define SBCL_HOME ...
+       sed "s,/usr/local/lib,/usr/$(get_libdir),g" -i src/runtime/runtime.c || 
die
+
+       find . -type f -name .cvsignore -delete
+}
+
+src_configure() {
+       # customizing SBCL version as per
+       # 
http://sbcl.cvs.sourceforge.net/sbcl/sbcl/doc/PACKAGING-SBCL.txt?view=markup
+       echo -e ";;; Auto-generated by Gentoo\n\"gentoo-${PR}\"" > 
branch-version.lisp-expr
+
+       # applying customizations
+       sbcl_apply_features
+}
+
+src_compile() {
+       local bindir="${WORKDIR}"/sbcl-binary
+
+       strip-unsupported-flags ; filter-flags -fomit-frame-pointer
+
+       if host-is-pax ; then
+               # To disable PaX on hardened systems
+               pax-mark -mr "${bindir}"/src/runtime/sbcl
+
+               # Hack to disable PaX on second GENESIS stage
+               sed -i -e '/^[ \t]*echo \/\/doing warm init - compilation 
phase$/a\    paxmark.sh -mr \.\/src\/runtime\/sbcl' \
+                       "${S}"/make-target-2.sh || die "Cannot disable PaX on 
second GENESIS runtime"
+       fi
+
+       # clear the environment to get rid of non-ASCII strings, see bug 174702
+       # set HOME for paludis
+       env - HOME="${T}" \
+               CC="$(tc-getCC)" AS="$(tc-getAS)" LD="$(tc-getLD)" \
+               CPPFLAGS="${CPPFLAGS}" CFLAGS="${CFLAGS}" ASFLAGS="${ASFLAGS}" 
LDFLAGS="${LDFLAGS}" \
+               GNUMAKE=make ./make.sh \
+               "sh ${bindir}/run-sbcl.sh --no-sysinit --no-userinit 
--disable-debugger" \
+               || die "make failed"
+
+       # need to set HOME because libpango(used by graphviz) complains about it
+       if use doc; then
+               env - HOME="${T}" \
+                       CL_SOURCE_REGISTRY="(:source-registry 
:ignore-inherited-configuration)" \
+                       ASDF_OUTPUT_TRANSLATIONS="(:output-translations 
:ignore-inherited-configuration)" \
+                       make -C doc/manual info html || die "Cannot build 
manual"
+               env - HOME="${T}" \
+                       CL_SOURCE_REGISTRY="(:source-registry 
:ignore-inherited-configuration)" \
+                       ASDF_OUTPUT_TRANSLATIONS="(:output-translations 
:ignore-inherited-configuration)" \
+                       make -C doc/internals info html || die "Cannot build 
internal docs"
+       fi
+}
+
+src_test() {
+       ewarn "Unfortunately, it is known that some tests fail eg."
+       ewarn "run-program.impure.lisp. This is an issue of the upstream's"
+       ewarn "development and not of Gentoo's side. Please, before filing"
+       ewarn "any bug(s) search for older submissions. Thank you."
+       time ( cd tests && sh run-tests.sh )
+}
+
+src_install() {
+       # install system-wide initfile
+       dodir /etc/
+       sed 's/^X//' > "${D}"/etc/sbclrc <<-EOF
+       ;;; The following is required if you want source location functions to
+       ;;; work in SLIME, for example.
+       X
+       (setf (logical-pathname-translations "SYS")
+       X      '(("SYS:SRC;**;*.*.*" #p"/usr/$(get_libdir)/sbcl/src/**/*.*")
+       X        ("SYS:CONTRIB;**;*.*.*" #p"/usr/$(get_libdir)/sbcl/**/*.*")))
+       X
+       ;;; Setup ASDF2
+       (load "/etc/common-lisp/gentoo-init.lisp")
+       EOF
+
+       # Install documentation
+       unset SBCL_HOME
+       INSTALL_ROOT="${D}/usr" LIB_DIR="/usr/$(get_libdir)" 
DOC_DIR="${D}/usr/share/doc/${PF}" \
+               sh install.sh || die "install.sh failed"
+
+       # rm empty directories lest paludis complain about this
+       find "${D}" -empty -type d -exec rmdir -v {} +
+
+       if use doc; then
+               dohtml -r doc/manual/
+               doinfo doc/manual/*.info*
+               dohtml -r doc/internals/sbcl-internals
+               doinfo doc/internals/sbcl-internals.info
+               docinto internals-notes && dodoc doc/internals-notes/*
+       else
+               rm -Rv "${D}/usr/share/doc/${PF}" || die
+       fi
+
+       dodoc BUGS CREDITS INSTALL NEWS OPTIMIZATIONS PRINCIPLES README TLA TODO
+
+       # install the SBCL source
+       if use source; then
+               ./clean.sh
+               cp -av src "${D}/usr/$(get_libdir)/sbcl/" || die
+       fi
+
+       # necessary for running newly-saved images
+       echo "SBCL_HOME=/usr/$(get_libdir)/${PN}" > "${ENVD}"
+       echo "SBCL_SOURCE_ROOT=/usr/$(get_libdir)/${PN}/src" >> "${ENVD}"
+       doenvd "${ENVD}"
+}

Reply via email to