Compare commits
No commits in common. "5d79b7aec1c025e05c90d039749e015b05f65ae7" and "ea591b015e21af5b792e683574bc0dce650d0e08" have entirely different histories.
5d79b7aec1
...
ea591b015e
@ -1,4 +1,4 @@
|
||||
DIST racket-7.8-src-builtpkgs.tgz 148635095 BLAKE2B ad944f6c269746dbe1301f029824949a1de6a81f908da75f1803eedf1c0b2aeb2bca9a263ea3d328081dddd69339089b7287f289036fadf05aea2a74b561da5b SHA512 8d0442aa73511a9d29827d0bb2481f6eef2d9ec3f3f68a7fdf1f88adc07891f623d7db388d494c26e884fe3bfcc5463444ea5bb4cc54e54989a73802ac216dca
|
||||
DIST racket-8.0-src-builtpkgs.tgz 153847792 BLAKE2B dba1b39e770954e5971689f6d2b413f1aadc6176822e4400b40b41ebf7eab00cc34b5e5158f38d1a1d8caa98fa260ef10864794dc0d4768e2ea5b2ad869d0102 SHA512 df3e14ccdba00eb4de113693a6eee22e640958b074f3ad4946e5900333fbf558c4c2653f65a89f638f6ef173d32c9f97b19349360a9d4afca82365aceb43c911
|
||||
DIST racket-8.1-src-builtpkgs.tgz 154340467 BLAKE2B 1a12ca71a3af0c506238e2abad44596c54b5102fbe81d99c713356dc52abcdba8f0a0cf969702cff1f7738a0383d55894a546f682f3d854b504ceab34cef600e SHA512 afc8c737087a98172dbf699d24cee73966da699aebbdefb8b7785a6521dc4de61b8d7f2ed3a3f1d2be7a1dfe6675db7a33d39492da9dfe0aad8d9074cd03cf9f
|
||||
DIST racket-minimal-7.8-src-builtpkgs.tgz 21202793 BLAKE2B e3ae69b31d4a5984e51a0da158e9cf09be6670e5a63dd38aa124175000b4b4a133b9d2f592d7fc2816f8d1d79ff1bc6e7a73f9f7c8ee7af3d5c6f94844022eaa SHA512 da4eabaa3e76fa56b611b4159628744ad427f406af8c6a3db27ca0fd33953a033c6f40eb497bf375bb2551eb11ccd29d413ba413baab2e10a4801485fa17d826
|
||||
DIST racket-minimal-8.0-src-builtpkgs.tgz 24065953 BLAKE2B 2af056758660d30f7d232dabe03d544e5e77478df71389df883b8af956fe224332048eac3a351fdb905051e3ef99b08bd0e0f1704e04919a4a2e68f8005922b8 SHA512 1e43b390f6a4c1405df0872c71c27638ec35a8cdd8508390db13bd59a43f5a4728f0660fe1afb5785f625d31fd25cdc1a6ecb9972daf99bcb538f7204956dabc
|
||||
DIST racket-minimal-8.1-src-builtpkgs.tgz 24172851 BLAKE2B ab3e898e257d610874b31ac5ea3034b5c213f1d181f105c206c45129c35efb53250986163ea8c2399c02084d0d7ec55d0c79c8c8499578067f1bbef4c02568c5 SHA512 eb786882383c33fc77a697a66b06d797b0dbb2de8435daa41db4211cfa893dbbc213910ada4ea087f848dae1abb4d5ff9df162af5cf8eae689f1ef69b410d6c5
|
||||
|
@ -26,6 +26,9 @@
|
||||
<flag name="futures">
|
||||
Enable racket/future library for fine-grained hardware parallelism
|
||||
</flag>
|
||||
<flag name="graphics">
|
||||
Enable support for graphics
|
||||
</flag>
|
||||
<flag name="places">
|
||||
Enable racket/place library for share-nothing parallelism and message-passing communication. Compared to futures, places are heavyweight, but they have a simpler performance model.
|
||||
</flag>
|
||||
|
@ -3,7 +3,7 @@
|
||||
|
||||
EAPI=7
|
||||
|
||||
inherit desktop pax-utils xdg-utils
|
||||
inherit desktop pax-utils xdg
|
||||
|
||||
DESCRIPTION="General purpose, multi-paradigm Lisp-Scheme programming language"
|
||||
HOMEPAGE="https://racket-lang.org/"
|
||||
@ -12,62 +12,66 @@ SRC_URI="
|
||||
!minimal? ( https://download.racket-lang.org/installers/${PV}/${P}-src-builtpkgs.tgz )
|
||||
"
|
||||
|
||||
# See https://blog.racket-lang.org/2019/11/completing-racket-s-relicensing-effort.html
|
||||
LICENSE="
|
||||
|| ( MIT Apache-2.0 )
|
||||
chez? ( Apache-2.0 )
|
||||
!chez? ( LGPL-3 )
|
||||
"
|
||||
RESTRICT="mirror"
|
||||
LICENSE="GPL-3+ LGPL-3"
|
||||
SLOT="0"
|
||||
KEYWORDS="~amd64"
|
||||
IUSE="X +chez +doc +futures +jit minimal +places +readline +threads"
|
||||
REQUIRED_USE="futures? ( jit )"
|
||||
|
||||
DEPEND="
|
||||
IUSE="
|
||||
+doc
|
||||
+futures
|
||||
+graphics
|
||||
+jit
|
||||
+places
|
||||
+readline
|
||||
+threads
|
||||
X
|
||||
minimal
|
||||
"
|
||||
REQUIRED_USE="
|
||||
futures? ( jit )
|
||||
X? ( graphics )
|
||||
"
|
||||
|
||||
RDEPEND="
|
||||
!dev-tex/slatex
|
||||
dev-db/sqlite:3
|
||||
dev-libs/libffi
|
||||
X? (
|
||||
dev-util/desktop-file-utils
|
||||
media-libs/libpng:0
|
||||
virtual/jpeg:0
|
||||
x11-libs/cairo[X]
|
||||
x11-libs/gtk+:3[X]
|
||||
x11-libs/pango[X]
|
||||
x11-misc/shared-mime-info
|
||||
graphics? (
|
||||
media-libs/libpng:0
|
||||
virtual/jpeg:0
|
||||
x11-libs/cairo[X?]
|
||||
x11-libs/pango[X?]
|
||||
)
|
||||
readline? ( dev-libs/libedit )
|
||||
readline? (
|
||||
dev-libs/libedit
|
||||
)
|
||||
X? ( x11-libs/gtk+:3[X] )
|
||||
"
|
||||
DEPEND="
|
||||
${RDEPEND}
|
||||
"
|
||||
RDEPEND="${DEPEND}"
|
||||
|
||||
S="${WORKDIR}/${P}/src"
|
||||
|
||||
# BC library is being stripped unconditionally
|
||||
QA_PRESTRIPPED="/usr/lib64/libracket3m-8.0.so"
|
||||
|
||||
src_prepare() {
|
||||
unset PLTUSERHOME
|
||||
xdg_environment_reset
|
||||
|
||||
default
|
||||
|
||||
rm -r ./bc/foreign/libffi || die "failed to remove bundled libffi"
|
||||
rm -r foreign/libffi || die 'failed to remove bundled libffi'
|
||||
}
|
||||
|
||||
src_configure() {
|
||||
# According to vapier, we should use the bundled libtool
|
||||
# such that we don't preclude cross-compile.
|
||||
# Thus don't use --enable-lt=/usr/bin/libtool
|
||||
# --enable-bc builds Racket w/o chez backend
|
||||
# such that we don't preclude cross-compile. Thus don't use
|
||||
# --enable-lt=/usr/bin/libtool
|
||||
local myconf=(
|
||||
--docdir="${EPREFIX}"/usr/share/doc/${PF}
|
||||
--enable-shared
|
||||
--enable-float
|
||||
--enable-libffi
|
||||
--enable-foreign
|
||||
--disable-libs
|
||||
--disable-strip
|
||||
--docdir="${EPREFIX}/usr/share/doc/${PF}"
|
||||
--enable-float
|
||||
--enable-foreign
|
||||
--enable-libffi
|
||||
--enable-shared
|
||||
$(usex chez "--enable-cs --enable-csonly" "--enable-bc --enable-bconly")
|
||||
$(use_enable X gracket)
|
||||
$(use_enable doc docs)
|
||||
$(use_enable jit)
|
||||
@ -79,23 +83,22 @@ src_configure() {
|
||||
}
|
||||
|
||||
src_compile() {
|
||||
if use jit && ! use chez; then
|
||||
if use jit
|
||||
then
|
||||
# When the JIT is enabled, a few binaries need to be pax-marked
|
||||
# on hardened systems (bug 613634). The trick is to pax-mark
|
||||
# them before they're used later in the build system. The
|
||||
# following order for racketcgc and racket3m was determined by
|
||||
# digging through the Makefile in src/racket to find out which
|
||||
# targets would build those binaries but not use them.
|
||||
pushd ./bc || die
|
||||
pushd racket
|
||||
emake cgc-core
|
||||
pax-mark m .libs/racketcgc
|
||||
|
||||
pushd ./gc2 || die
|
||||
pushd gc2
|
||||
emake all
|
||||
popd || die
|
||||
|
||||
popd
|
||||
pax-mark m .libs/racket3m
|
||||
popd || die
|
||||
popd
|
||||
fi
|
||||
|
||||
default
|
||||
@ -104,44 +107,44 @@ src_compile() {
|
||||
src_install() {
|
||||
default
|
||||
|
||||
if use jit; then
|
||||
if use jit
|
||||
then
|
||||
# The final binaries need to be pax-marked, too, if you want to
|
||||
# actually use them. The src_compile marking get lost somewhere
|
||||
# in the install process.
|
||||
local f
|
||||
for f in mred mzscheme racket; do
|
||||
for f in mred mzscheme racket
|
||||
do
|
||||
pax-mark m "${D}/usr/bin/${f}"
|
||||
done
|
||||
|
||||
pax-mark m "${D}/usr/$(get_libdir)/racket/starter"
|
||||
use X && pax-mark m "${D}/usr/$(get_libdir)/racket/gracket"
|
||||
fi
|
||||
|
||||
# raco needs decompressed files for packages doc installation bug 662424
|
||||
if use doc; then
|
||||
docompress -x "/usr/share/doc/${PF}"
|
||||
if use doc
|
||||
then
|
||||
docompress -x /usr/share/doc/${PF}
|
||||
fi
|
||||
|
||||
find "${ED}" \( -name "*.a" -o -name "*.la" \) -delete || die
|
||||
|
||||
# Create missing desktop files
|
||||
if use X; then
|
||||
newicon "${D}/usr/share/racket/drracket-exe-icon.png" "racket.png"
|
||||
make_desktop_entry "gracket" "GRacket" "racket" "Development;Education;"
|
||||
make_desktop_entry "plt-games" "PLT Games" "racket" "Education;Game;"
|
||||
if use X
|
||||
then
|
||||
make_desktop_entry "gracket" "GRacket" \
|
||||
"/usr/share/racket/drracket-exe-icon.png" \
|
||||
"Development;Education;"
|
||||
make_desktop_entry "plt-games" "PLT Games" \
|
||||
"/usr/share/racket/drracket-exe-icon.png" \
|
||||
"Education;Game;"
|
||||
fi
|
||||
}
|
||||
|
||||
pkg_postinst() {
|
||||
if use X; then
|
||||
xdg_desktop_database_update
|
||||
xdg_icon_cache_update
|
||||
fi
|
||||
use X && xdg_pkg_postinst
|
||||
}
|
||||
|
||||
pkg_postrm() {
|
||||
if use X; then
|
||||
xdg_desktop_database_update
|
||||
xdg_icon_cache_update
|
||||
fi
|
||||
use X && xdg_pkg_postrm
|
||||
}
|
Loading…
Reference in New Issue
Block a user