recipe 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. # Build recipe for gzip.
  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=gzip
  17. version=1.9
  18. release=1
  19. # Set 'outdir' for a nice and well-organized output directory
  20. outdir="${outdir}/${arch}/compressors"
  21. tarname=${program}-${version}.tar.gz
  22. # Remote source(s)
  23. fetch=ftp://ftp.gnu.org/gnu/gzip/$tarname
  24. description="
  25. Compression utility.
  26. Gzip (GNU zip) is a compression utility designed to be a replacement
  27. for 'compress'. Its main advantages over 'compress' are much better
  28. compression and freedom from patented algorithms. It has been adopted
  29. by the GNU project and is now relatively popular on the Internet.
  30. This package has been built to be used with the zutils package.
  31. "
  32. homepage=http://www.gnu.org/software/gzip
  33. license=GPLv3+
  34. # Source documentation
  35. docs="AUTHORS COPYING ChangeLog NEWS README* THANKS TODO"
  36. docsdir="${docdir}/${program}-${version}"
  37. build()
  38. {
  39. set -e
  40. unpack "${tardir}/$tarname"
  41. cd "$srcdir"
  42. # Set sane permissions
  43. chmod -R u+w,go-w,a+rX-s .
  44. ./configure CC="gcc -no-pie -fno-PIE" \
  45. CFLAGS="$QICFLAGS" LDFLAGS="$QILDFLAGS -static" \
  46. $configure_args \
  47. --libdir=/usr/lib${libSuffix} \
  48. --infodir=$infodir \
  49. --mandir=$mandir \
  50. --program-transform-name='s/^z/gz/' \
  51. --build="$(cc -dumpmachine)"
  52. make -j${jobs} V=1
  53. make -j${jobs} DESTDIR="$destdir" install
  54. # No, no hard links for the package size
  55. ( cd "${destdir}/usr/bin" && ln -sf gunzip uncompress )
  56. (
  57. cd "${destdir}/${mandir}/man1" || exit 1
  58. ln -sf gzip.1 gunzip.1
  59. ln -sf gzip.1 gzcat.1
  60. ln -sf gzdiff.1 gzcmp.1
  61. )
  62. # Compress info documents deleting index file for the package
  63. if test -d "${destdir}/$infodir"
  64. then
  65. rm -f "${destdir}/${infodir}/dir"
  66. lzip -9 "${destdir}/${infodir}"/*
  67. fi
  68. # Compress and link man pages (if needed)
  69. if test -d "${destdir}/$mandir"
  70. then
  71. (
  72. cd "${destdir}/$mandir"
  73. find . -type f -exec lzip -9 '{}' +
  74. find . -type l | while read -r file
  75. do
  76. ln -sf "$(readlink -- "$file").lz" "${file}.lz"
  77. rm -- "$file"
  78. done
  79. )
  80. fi
  81. # Copy documentation
  82. mkdir -p "${destdir}${docsdir}"
  83. cp -p $docs "${destdir}${docsdir}"
  84. }