recipe 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. # Build recipe for libpipeline.
  2. #
  3. # Copyright (c) 2016-2018 Matias Fonzo, <selk@dragora.org>.
  4. #
  5. # Licensed under the Apache License, Version 2.0 (the "License");
  6. # you may not use this file except in compliance with the License.
  7. # You may obtain a copy of the License at
  8. #
  9. # http://www.apache.org/licenses/LICENSE-2.0
  10. #
  11. # Unless required by applicable law or agreed to in writing, software
  12. # distributed under the License is distributed on an "AS IS" BASIS,
  13. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14. # See the License for the specific language governing permissions and
  15. # limitations under the License.
  16. program=libpipeline
  17. version=1.5.0
  18. release=1
  19. # Set 'outdir' for a nice and well-organized output directory
  20. outdir="${outdir}/${arch}/libs"
  21. tarname=${program}-${version}.tar.gz
  22. # Remote source(s)
  23. fetch=http://download.savannah.gnu.org/releases/libpipeline/$tarname
  24. description="
  25. Pipeline manipulation library.
  26. Libpipeline is a C library for setting up and running pipelines of
  27. processes, without needing to involve shell command-line parsing
  28. which is often error-prone and insecure.
  29. "
  30. homepage=http://libpipeline.nongnu.org
  31. license=GPLv3+
  32. # Source documentation
  33. docs="COPYING ChangeLog NEWS README TODO"
  34. docsdir="${docdir}/${program}-${version}"
  35. build()
  36. {
  37. set -e
  38. unpack "${tardir}/$tarname"
  39. cd "$srcdir"
  40. # Set sane permissions
  41. chmod -R u+w,go-w,a+rX-s .
  42. ./configure CFLAGS="$QICFLAGS" LDFLAGS="$QILDFLAGS" \
  43. $configure_args \
  44. --libdir=/usr/lib${libSuffix} \
  45. --infodir=$infodir \
  46. --mandir=$mandir \
  47. --disable-shared \
  48. --enable-static \
  49. --build="$(cc -dumpmachine)"
  50. make -j${jobs} V=1
  51. make -j${jobs} check
  52. make -j${jobs} DESTDIR="$destdir" install
  53. # Compress info documents deleting index file for the package
  54. if test -d "${destdir}/$infodir"
  55. then
  56. rm -f "${destdir}/${infodir}/dir"
  57. lzip -9 "${destdir}/${infodir}"/*
  58. fi
  59. # Compress and link man pages (if needed)
  60. if test -d "${destdir}/$mandir"
  61. then
  62. (
  63. cd "${destdir}/$mandir"
  64. find . -type f -exec lzip -9 '{}' +
  65. find . -type l | while read -r file
  66. do
  67. ln -sf "$(readlink -- "$file").lz" "${file}.lz"
  68. rm -- "$file"
  69. done
  70. )
  71. fi
  72. # Copy documentation
  73. mkdir -p "${destdir}${docsdir}"
  74. cp -p $docs "${destdir}${docsdir}"
  75. }