Compare commits
3 Commits
d8f5fa47f3
...
b2d512c3b9
Author | SHA1 | Date | |
---|---|---|---|
|
b2d512c3b9 | ||
|
f32ecdbc27 | ||
|
20b108ce2f |
@ -1 +1,2 @@
|
|||||||
DIST gerbil-0.16.tar.gz 1715765 BLAKE2B 74cd501b19c8f124f9478c73080e92c2ba0bf92e8cb9faa4cba492b2def8a61633897b67def4200e53962ccf22287f58cf7fdd33604104acc80bde12dd58b07c SHA512 46782b4b71a3b437501b825f2f164e53b285d3a4cdba8f04485edaaa589d8500535c06a47a1464fc537ab7546413dde37c8d6a16a5e076a99ccf255905ed105d
|
DIST gerbil-0.16.tar.gz 1715765 BLAKE2B 74cd501b19c8f124f9478c73080e92c2ba0bf92e8cb9faa4cba492b2def8a61633897b67def4200e53962ccf22287f58cf7fdd33604104acc80bde12dd58b07c SHA512 46782b4b71a3b437501b825f2f164e53b285d3a4cdba8f04485edaaa589d8500535c06a47a1464fc537ab7546413dde37c8d6a16a5e076a99ccf255905ed105d
|
||||||
|
DIST gerbil-0.17.tar.gz 1792073 BLAKE2B 1c28f3e44b1618408dba83598e55d136aa800e3482322fbd8761c0c4c851b5358d0a040d88c33be896008af33f5132a32faca8ab1ef28928a9dcdb8ac96bdfbe SHA512 c23d5ead0b23991181c977b9fe5784df5ba9ee46221b44a3f3a194d7669b7fb1268b9bfa310f5cfd1c994036f2fbee2f8611c9bce556f1c235e17babc31ce43d
|
||||||
|
@ -0,0 +1,77 @@
|
|||||||
|
From 7bb1c82c8cad8818f8805f28e7ff5b39d82c1ab0 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Alfred Wingate <parona@protonmail.com>
|
||||||
|
Date: Thu, 26 Oct 2023 16:15:45 +0300
|
||||||
|
Subject: [PATCH] Add support for destdir
|
||||||
|
|
||||||
|
Signed-off-by: Alfred Wingate <parona@protonmail.com>
|
||||||
|
--- a/Makefile.in
|
||||||
|
+++ b/Makefile.in
|
||||||
|
@@ -83,9 +83,9 @@ tags:
|
||||||
|
cd src && LDFLAGS="$(LIBS)" ./build.sh tags
|
||||||
|
|
||||||
|
install:
|
||||||
|
- mkdir -p ${gerbil_bin} ${gerbil_share} ${gerbil_bin_linkdir} ${gerbil_share_linkdir}
|
||||||
|
- cd src && ./install
|
||||||
|
- cp -a --link --remove-destination ${gerbil_bin}/* ${gerbil_bin_linkdir} || \
|
||||||
|
- cp -a ${gerbil_bin}/* ${gerbil_bin_linkdir}
|
||||||
|
- cp -a --link --remove-destination ${gerbil_share}/* ${gerbil_share_linkdir} || \
|
||||||
|
- cp -a ${gerbil_share}/* ${gerbil_share_linkdir}
|
||||||
|
+ mkdir -p $(DESTDIR)${gerbil_bin} $(DESTDIR)${gerbil_share} $(DESTDIR)${gerbil_bin_linkdir} $(DESTDIR)${gerbil_share_linkdir}
|
||||||
|
+ cd src && ./install $(DESTDIR)
|
||||||
|
+ cp -a --link --remove-destination $(DESTDIR)${gerbil_bin}/* $(DESTDIR)${gerbil_bin_linkdir} || \
|
||||||
|
+ cp -a $(DESTDIR)${gerbil_bin}/* $(DESTDIR)${gerbil_bin_linkdir}
|
||||||
|
+ cp -a --link --remove-destination $(DESTDIR)${gerbil_share}/* $(DESTDIR)${gerbil_share_linkdir} || \
|
||||||
|
+ cp -a $(DESTDIR)${gerbil_share}/* $(DESTDIR)${gerbil_share_linkdir}
|
||||||
|
--- a/src/install
|
||||||
|
+++ b/src/install
|
||||||
|
@@ -2,6 +2,7 @@
|
||||||
|
;; -*- Scheme -*-
|
||||||
|
|
||||||
|
(define default-gerbil-home #f)
|
||||||
|
+(define destdir #f)
|
||||||
|
|
||||||
|
(define (die . message-bits)
|
||||||
|
(parameterize ((current-output-port (current-error-port)))
|
||||||
|
@@ -28,7 +29,7 @@
|
||||||
|
(copy-file from to))))
|
||||||
|
|
||||||
|
(define (patch-gxc-shebang)
|
||||||
|
- (let* ((filename (string-append default-gerbil-home "/bin/gxc"))
|
||||||
|
+ (let* ((filename (string-append destdir default-gerbil-home "/bin/gxc"))
|
||||||
|
(new-content (with-input-from-file filename
|
||||||
|
(lambda ()
|
||||||
|
(with-output-to-string
|
||||||
|
@@ -40,17 +41,19 @@
|
||||||
|
(lambda ()
|
||||||
|
(display new-content)))))
|
||||||
|
|
||||||
|
-(define (main)
|
||||||
|
+(define (main . args)
|
||||||
|
+ (if args
|
||||||
|
+ (set! destdir (car args)))
|
||||||
|
(if (not default-gerbil-home)
|
||||||
|
(die "This gerbil build was not configured with a prefix, so there's nothing to do."))
|
||||||
|
- (create-directory-if-necessary default-gerbil-home)
|
||||||
|
- (install "../bin" (string-append default-gerbil-home "/bin"))
|
||||||
|
- (install "../lib" (string-append default-gerbil-home "/lib"))
|
||||||
|
- (create-directory-if-necessary (string-append default-gerbil-home "/share"))
|
||||||
|
- (create-directory-if-necessary (string-append default-gerbil-home "/share/emacs"))
|
||||||
|
- (create-directory-if-necessary (string-append default-gerbil-home "/share/emacs/site-lisp"))
|
||||||
|
- (create-directory-if-necessary (string-append default-gerbil-home "/share/emacs/site-lisp/gerbil"))
|
||||||
|
- (install "../etc/gerbil-mode.el" (string-append default-gerbil-home "/share/emacs/site-lisp/gerbil/gerbil-mode.el"))
|
||||||
|
- (create-directory-if-necessary (string-append default-gerbil-home "/share/gerbil"))
|
||||||
|
- (install "TAGS" (string-append default-gerbil-home "/share/gerbil/TAGS"))
|
||||||
|
+ (create-directory-if-necessary (string-append destdir default-gerbil-home))
|
||||||
|
+ (install "../bin" (string-append destdir default-gerbil-home "/bin"))
|
||||||
|
+ (install "../lib" (string-append destdir default-gerbil-home "/lib"))
|
||||||
|
+ (create-directory-if-necessary (string-append destdir default-gerbil-home "/share"))
|
||||||
|
+ (create-directory-if-necessary (string-append destdir default-gerbil-home "/share/emacs"))
|
||||||
|
+ (create-directory-if-necessary (string-append destdir default-gerbil-home "/share/emacs/site-lisp"))
|
||||||
|
+ (create-directory-if-necessary (string-append destdir default-gerbil-home "/share/emacs/site-lisp/gerbil"))
|
||||||
|
+ (install "../etc/gerbil-mode.el" (string-append destdir default-gerbil-home "/share/emacs/site-lisp/gerbil/gerbil-mode.el"))
|
||||||
|
+ (create-directory-if-necessary (string-append destdir default-gerbil-home "/share/gerbil"))
|
||||||
|
+ (install "TAGS" (string-append destdir default-gerbil-home "/share/gerbil/TAGS"))
|
||||||
|
(patch-gxc-shebang))
|
||||||
|
--
|
||||||
|
2.42.0
|
||||||
|
|
129
dev-scheme/gerbil/gerbil-0.17.ebuild
Normal file
129
dev-scheme/gerbil/gerbil-0.17.ebuild
Normal file
@ -0,0 +1,129 @@
|
|||||||
|
# Copyright 1999-2023 Gentoo Authors
|
||||||
|
# Distributed under the terms of the GNU General Public License v2
|
||||||
|
|
||||||
|
EAPI=8
|
||||||
|
|
||||||
|
inherit autotools elisp-common toolchain-funcs
|
||||||
|
|
||||||
|
DESCRIPTION="Dialect of Scheme designed for Systems Programming"
|
||||||
|
HOMEPAGE="https://cons.io/ https://github.com/vyzo/gerbil"
|
||||||
|
|
||||||
|
if [[ "${PV}" == *9999* ]]; then
|
||||||
|
inherit git-r3
|
||||||
|
EGIT_REPO_URI="https://github.com/mighty-gerbils/gerbil"
|
||||||
|
else
|
||||||
|
SRC_URI="https://github.com/mighty-gerbils/gerbil/archive/refs/tags/v${PV}.tar.gz -> ${P}.tar.gz"
|
||||||
|
KEYWORDS="~amd64"
|
||||||
|
fi
|
||||||
|
|
||||||
|
LICENSE="Apache-2.0 LGPL-2.1"
|
||||||
|
SLOT="0"
|
||||||
|
IUSE="emacs leveldb lmdb mysql +sqlite +xml yaml +zlib"
|
||||||
|
|
||||||
|
# no tests
|
||||||
|
RESTRICT="test"
|
||||||
|
|
||||||
|
SUPPORTED_GAMBIT="
|
||||||
|
|| (
|
||||||
|
~dev-scheme/gambit-4.9.5
|
||||||
|
~dev-scheme/gambit-4.9.4
|
||||||
|
)
|
||||||
|
"
|
||||||
|
|
||||||
|
RDEPEND="
|
||||||
|
${SUPPORTED_GAMBIT}
|
||||||
|
emacs? ( >=app-editors/emacs-23.1:* )
|
||||||
|
leveldb? ( dev-libs/leveldb:= )
|
||||||
|
lmdb? ( dev-db/lmdb:= )
|
||||||
|
mysql? ( dev-db/mysql-connector-c:= )
|
||||||
|
sqlite? ( dev-db/sqlite:3 )
|
||||||
|
xml? ( dev-libs/libxml2 )
|
||||||
|
yaml? ( dev-libs/libyaml )
|
||||||
|
zlib? ( sys-libs/zlib )
|
||||||
|
dev-libs/openssl:=
|
||||||
|
"
|
||||||
|
DEPEND="${RDEPEND}"
|
||||||
|
BDEPEND="${SUPPORTED_GAMBIT}"
|
||||||
|
|
||||||
|
SITEFILE="70${PN}-gentoo.el"
|
||||||
|
|
||||||
|
DESTDIR="${EPREFIX}/opt/gerbil"
|
||||||
|
|
||||||
|
PATCHES=(
|
||||||
|
"${FILESDIR}/gebril-0.17-add-support-for-destdir.patch"
|
||||||
|
)
|
||||||
|
|
||||||
|
src_prepare() {
|
||||||
|
# NIH mix of autotools and scheme doesn't install well with autotools switches
|
||||||
|
#export GERBIL_HOME="${EPREFIX}/usr/share/${PN}"
|
||||||
|
unset GEBRIL_HOME
|
||||||
|
unset GERBIL_PATH
|
||||||
|
|
||||||
|
# Verbose build process
|
||||||
|
export GAMBCOMP_VERBOSE="yes"
|
||||||
|
|
||||||
|
eapply_user
|
||||||
|
|
||||||
|
eapply ${PATCHES[@]}
|
||||||
|
|
||||||
|
# Really
|
||||||
|
sed -i -e "s/v0.16/v${PV}/" -e "s/v0_16/v${PV/./_}/" configure.ac || die
|
||||||
|
|
||||||
|
eautoconf
|
||||||
|
|
||||||
|
sed -i "s|gcc|$(tc-getCC)|g" src/build.sh || die "Failed to fix CC setting"
|
||||||
|
sed -i "s|-O2|${CFLAGS}|g" src/build.sh || die "Failed to fix CFLAGS setting"
|
||||||
|
|
||||||
|
sed -i 's|local target_lib_gerbil="${GERBIL_BASE}/lib/gerbil"|local target_lib_gerbil="${GERBIL_BASE}"|' \
|
||||||
|
src/build.sh || die
|
||||||
|
}
|
||||||
|
|
||||||
|
src_configure() {
|
||||||
|
|
||||||
|
local myconf=(
|
||||||
|
$(use_enable leveldb)
|
||||||
|
$(use_enable lmdb)
|
||||||
|
$(use_enable mysql)
|
||||||
|
$(use_enable sqlite)
|
||||||
|
$(use_enable xml libxml)
|
||||||
|
$(use_enable yaml libyaml)
|
||||||
|
$(use_enable zlib)
|
||||||
|
)
|
||||||
|
|
||||||
|
econf ${myconf[@]}
|
||||||
|
}
|
||||||
|
|
||||||
|
src_compile() {
|
||||||
|
ewarn "Build is extremely slow and IS NOT PARALLEL ~20min"
|
||||||
|
default
|
||||||
|
}
|
||||||
|
|
||||||
|
src_install() {
|
||||||
|
emake DESTDIR="${D}" install
|
||||||
|
|
||||||
|
# Move them to better positions. Quite ugly...
|
||||||
|
mkdir -p "${D}${DESTDIR}" || die
|
||||||
|
mv -T "${D}/usr/lib/gerbil/" "${D}${DESTDIR}" || die
|
||||||
|
rm -rf "${D}${DESTDIR}/share" || die
|
||||||
|
sed -i -e "s|/usr/lib/gerbil/|${DESTDIR}|" "${D}${DESTDIR}"/bin/gxc || die
|
||||||
|
|
||||||
|
# Remove so that they can be installed with the eclass.
|
||||||
|
if use emacs; then
|
||||||
|
elisp-compile "${D}/usr/share/emacs/site-lisp/gerbil"/*.el ||
|
||||||
|
die "Failed to compile elisp files"
|
||||||
|
elisp-site-file-install "${FILESDIR}/${SITEFILE}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Without this the programs compiled with gxc will break!
|
||||||
|
newenvd - 99gerbil <<- EOF
|
||||||
|
GERBIL_HOME="${DESTDIR}"
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
|
pkg_postinst() {
|
||||||
|
use emacs && elisp-site-regen
|
||||||
|
}
|
||||||
|
|
||||||
|
pkg_postrm() {
|
||||||
|
use emacs && elisp-site-regen
|
||||||
|
}
|
@ -1,114 +0,0 @@
|
|||||||
# Copyright 1999-2021 Gentoo Authors
|
|
||||||
# Distributed under the terms of the GNU General Public License v2
|
|
||||||
|
|
||||||
EAPI=8
|
|
||||||
|
|
||||||
inherit elisp-common toolchain-funcs wrapper
|
|
||||||
|
|
||||||
DESCRIPTION="Dialect of Scheme designed for Systems Programming"
|
|
||||||
HOMEPAGE="https://cons.io/ https://github.com/vyzo/gerbil"
|
|
||||||
|
|
||||||
if [[ "${PV}" == *9999* ]]; then
|
|
||||||
inherit git-r3
|
|
||||||
EGIT_REPO_URI="https://github.com/vyzo/${PN}.git"
|
|
||||||
else
|
|
||||||
SRC_URI="https://github.com/vyzo/${PN}/archive/v${PV}.tar.gz -> ${P}.tar.gz"
|
|
||||||
KEYWORDS="~amd64"
|
|
||||||
fi
|
|
||||||
S="${S}/src"
|
|
||||||
|
|
||||||
LICENSE="Apache-2.0 LGPL-2.1"
|
|
||||||
SLOT="0"
|
|
||||||
IUSE="emacs leveldb lmdb mysql +sqlite +xml yaml +zlib"
|
|
||||||
|
|
||||||
BDEPEND="dev-scheme/gambit"
|
|
||||||
RDEPEND="
|
|
||||||
dev-scheme/gambit
|
|
||||||
emacs? ( >=app-editors/emacs-23.1:* )
|
|
||||||
leveldb? ( dev-libs/leveldb )
|
|
||||||
lmdb? ( dev-db/lmdb )
|
|
||||||
mysql? ( dev-db/mariadb:* )
|
|
||||||
sqlite? ( dev-db/sqlite )
|
|
||||||
xml? ( dev-libs/libxml2 )
|
|
||||||
yaml? ( dev-libs/libyaml )
|
|
||||||
zlib? ( sys-libs/zlib )
|
|
||||||
"
|
|
||||||
DEPEND="${RDEPEND}"
|
|
||||||
|
|
||||||
SITEFILE="70${PN}-gentoo.el"
|
|
||||||
|
|
||||||
src_prepare() {
|
|
||||||
# Just to be safe, because './configure --help' says:
|
|
||||||
# "Set default GERBIL_HOME (environment variable still overrides)"
|
|
||||||
unset GERBIL_HOME
|
|
||||||
unset GERBIL_PATH
|
|
||||||
|
|
||||||
# Verbose build process
|
|
||||||
export GAMBCOMP_VERBOSE="yes"
|
|
||||||
|
|
||||||
default
|
|
||||||
|
|
||||||
sed -i "s|gcc|$(tc-getCC)|g" ./build.sh || die "Failed to fix CC setting"
|
|
||||||
sed -i "s|-O2|${CFLAGS}|g" ./build.sh || die "Failed to fix CFLAGS setting"
|
|
||||||
}
|
|
||||||
|
|
||||||
src_configure() {
|
|
||||||
local myconf=(
|
|
||||||
$(use_enable leveldb)
|
|
||||||
$(use_enable lmdb)
|
|
||||||
$(use_enable mysql)
|
|
||||||
$(use_enable xml libxml)
|
|
||||||
$(use_enable yaml libyaml)
|
|
||||||
$(usex sqlite '' '--disable-sqlite')
|
|
||||||
$(usex zlib '' '--disable-zlib')
|
|
||||||
--prefix="${D}/usr/share/${PN}"
|
|
||||||
)
|
|
||||||
# This is not a standard 'configure' script!
|
|
||||||
gsi ./configure ${myconf[@]} ||
|
|
||||||
die "Failed to configure using the 'configure' script"
|
|
||||||
}
|
|
||||||
|
|
||||||
src_compile() {
|
|
||||||
# The 'build.sh' script uses environment variables that are exported
|
|
||||||
# by portage, ie.: CFLAGS, LDFLAGS, ...
|
|
||||||
sh ./build.sh ||
|
|
||||||
die "Failed to compile using the 'build.sh' script"
|
|
||||||
}
|
|
||||||
|
|
||||||
src_install() {
|
|
||||||
mkdir -p "${D}"/usr/share/${PN} ||
|
|
||||||
die "Failed to make ${D}/usr/share/${PN} directory"
|
|
||||||
gsi ./install || die "Failed to install using the 'install' script"
|
|
||||||
|
|
||||||
sed -i "s|${D}|${EPREFIX}|g" "${D}"/usr/share/${PN}/bin/gxc ||
|
|
||||||
die "Failed to fix the 'gxc' executable script"
|
|
||||||
|
|
||||||
mv "${D}"/usr/share/${PN}/share/emacs "${D}"/usr/share/emacs || die
|
|
||||||
mv "${D}"/usr/share/${PN}/share/${PN}/TAGS "${D}"/usr/share/${PN}/TAGS || die
|
|
||||||
|
|
||||||
# Compile the 'gerbil-mode.el'
|
|
||||||
if use emacs; then
|
|
||||||
elisp-compile "${D}/usr/share/emacs/site-lisp/gerbil"/*.el ||
|
|
||||||
die "Failed to compile elisp files"
|
|
||||||
elisp-site-file-install "${FILESDIR}/${SITEFILE}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Create wrappers for gerbil executables in GERBIL_HOME (/usr/share/gerbil)
|
|
||||||
pushd "${D}"/usr/share/${PN}/bin >/dev/null || die
|
|
||||||
local gx_bin
|
|
||||||
for gx_bin in *; do
|
|
||||||
make_wrapper "${gx_bin}" "${EPREFIX}/usr/share/${PN}/bin/${gx_bin}"
|
|
||||||
done
|
|
||||||
popd >/dev/null || die
|
|
||||||
|
|
||||||
# Without this the programs compiled with gxc will break!
|
|
||||||
doenvd "${FILESDIR}/99${PN}"
|
|
||||||
}
|
|
||||||
|
|
||||||
pkg_postinst() {
|
|
||||||
use emacs && elisp-site-regen
|
|
||||||
}
|
|
||||||
|
|
||||||
pkg_postrm() {
|
|
||||||
use emacs && elisp-site-regen
|
|
||||||
}
|
|
@ -26,7 +26,7 @@
|
|||||||
and compiled macros.
|
and compiled macros.
|
||||||
</longdescription>
|
</longdescription>
|
||||||
<upstream>
|
<upstream>
|
||||||
<bugs-to>https://github.com/vyzo/gerbil</bugs-to>
|
<bugs-to>https://github.com/mighty-gerbils/gerbil</bugs-to>
|
||||||
<remote-id type="github">vyzo/gerbil</remote-id>
|
<remote-id type="github">mighty-gerbils/gerbil</remote-id>
|
||||||
</upstream>
|
</upstream>
|
||||||
</pkgmetadata>
|
</pkgmetadata>
|
||||||
|
Loading…
Reference in New Issue
Block a user