123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132 |
- # Build recipe for clisp.
- #
- # Copyright (c) 2017 MMPG, <mmpg@vp.pl>.
- # Copyright (c) 2017, 2019-2022 Matias Fonzo, <selk@dragora.org>.
- #
- # Licensed under the Apache License, Version 2.0 (the "License");
- # you may not use this file except in compliance with the License.
- # You may obtain a copy of the License at
- #
- # http://www.apache.org/licenses/LICENSE-2.0
- #
- # Unless required by applicable law or agreed to in writing, software
- # distributed under the License is distributed on an "AS IS" BASIS,
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- # See the License for the specific language governing permissions and
- # limitations under the License.
- # Exit immediately on any error
- set -e
- program=clisp
- version=20221228_957c79a25; # From https://gitlab.com/gnu-clisp/clisp
- release=1
- # Define a category for the output of the package name
- pkgcategory=devel
- tarname=${program}-${version}.tar.lz
- # Remote source(s)
- fetch="
- https://dragora.mirror.garr.it/current/sources/$tarname
- rsync://rsync.dragora.org/current/sources/$tarname
- "
- description="
- An ANSI Common Lisp Implementation.
- In computing, CLISP is an implementation of the programming language
- Common Lisp originally developed by Bruno Haible and Michael Stoll for
- the Atari ST.
- LISP includes an interpreter, a bytecode compiler, debugger, socket
- interface, high-level foreign language interface, strong
- internationalization support, and two object systems:
- Common Lisp Object System (CLOS) and metaobject protocol (MOP).
- It is written in C and Common Lisp. It is now part of the GNU Project
- and is free software, available under the terms of the GNU General
- Public License (GPL).
- "
- hompage=https://clisp.org
- license=GPLv2+
- # Source documentation
- docs="ANNOUNCE COPYRIGHT GNU-GPL HACKING SUMMARY"
- docsdir="${docdir}/${program}-${version}"
- # Limit parallel jobs of this build, otherwise ends in error
- jobs=1
- build()
- {
- unpack "${tardir}/$tarname"
-
- cd "$srcdir"
- # Set sane permissions
- chmod -R u+w,go-w,a+rX-s .
- # Build in a separate directory
- rm -rf BUILD
- mkdir BUILD
- cd BUILD
- # Bogus files in order to continue with the build
- touch clisp.pdf clisp-link.pdf
- ../configure CPPFLAGS="$QICPPFLAGS" CFLAGS="$QICFLAGS" \
- LDFLAGS="$QILDFLAGS" \
- FORCE_UNSAFE_CONFIGURE=1 \
- --srcdir=../ \
- --prefix=/usr \
- --libdir=/usr/lib${libSuffix} \
- --infodir=$infodir \
- --mandir=$mandir \
- --docdir=$docsdir \
- --disable-rpath \
- --with-dynamic-ffi \
- --with-module=berkeley-db \
- --with-module=gdbm \
- --with-module=pcre \
- --with-module=zlib \
- --disable-mmap \
- --build="$(gcc -dumpmachine)"
- make -j${jobs} V=1 mandir=$mandir infodir=$infodir all
- make -j${jobs} mandir=$mandir infodir=$infodir DESTDIR="$destdir" install
- # Remove previous bogus files from the documentation
- rm -f "${destdir}/$docsdir"/*.pdf
- cd ..
- # Compress info documents deleting index file for the package
- if test -d "${destdir}/$infodir"
- then
- rm -f "${destdir}/${infodir}/dir"
- lzip -9 "${destdir}/${infodir}"/*
- fi
- # Compress and link man pages (if needed)
- if test -d "${destdir}/$mandir"
- then
- (
- cd "${destdir}/$mandir"
- find . -type f -exec lzip -9 {} +
- find . -type l | while read -r file
- do
- ln -sf "$(readlink -- "$file").lz" "${file}.lz"
- rm -- "$file"
- done
- )
- fi
- # Copy documentation
- mkdir -p "${destdir}/$docsdir"
- cp -p $docs "${destdir}/$docsdir"
- }
|