Compare commits
No commits in common. "b2d512c3b9e98a912bdd2ad654322e4666473d5d" and "d8f5fa47f3a6f49a40b5cc96152a634a0aae696e" have entirely different histories.
b2d512c3b9
...
d8f5fa47f3
@ -1,2 +1 @@
|
||||
DIST gerbil-0.16.tar.gz 1715765 BLAKE2B 74cd501b19c8f124f9478c73080e92c2ba0bf92e8cb9faa4cba492b2def8a61633897b67def4200e53962ccf22287f58cf7fdd33604104acc80bde12dd58b07c SHA512 46782b4b71a3b437501b825f2f164e53b285d3a4cdba8f04485edaaa589d8500535c06a47a1464fc537ab7546413dde37c8d6a16a5e076a99ccf255905ed105d
|
||||
DIST gerbil-0.17.tar.gz 1792073 BLAKE2B 1c28f3e44b1618408dba83598e55d136aa800e3482322fbd8761c0c4c851b5358d0a040d88c33be896008af33f5132a32faca8ab1ef28928a9dcdb8ac96bdfbe SHA512 c23d5ead0b23991181c977b9fe5784df5ba9ee46221b44a3f3a194d7669b7fb1268b9bfa310f5cfd1c994036f2fbee2f8611c9bce556f1c235e17babc31ce43d
|
||||
|
@ -1,77 +0,0 @@
|
||||
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
|
||||
|
@ -1,129 +0,0 @@
|
||||
# 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
|
||||
}
|
114
dev-scheme/gerbil/gerbil-9999.ebuild
Normal file
114
dev-scheme/gerbil/gerbil-9999.ebuild
Normal file
@ -0,0 +1,114 @@
|
||||
# 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.
|
||||
</longdescription>
|
||||
<upstream>
|
||||
<bugs-to>https://github.com/mighty-gerbils/gerbil</bugs-to>
|
||||
<remote-id type="github">mighty-gerbils/gerbil</remote-id>
|
||||
<bugs-to>https://github.com/vyzo/gerbil</bugs-to>
|
||||
<remote-id type="github">vyzo/gerbil</remote-id>
|
||||
</upstream>
|
||||
</pkgmetadata>
|
||||
|
Loading…
Reference in New Issue
Block a user