recipe 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. # Build recipe for libcap-ng.
  2. #
  3. # Copyright (c) 2018-2022 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. # Exit immediately on any error
  17. set -e
  18. program=libcap-ng
  19. version=0.8.3
  20. release=1
  21. # Define a category for the output of the package name
  22. pkgcategory=libs
  23. tarname=${program}-${version}.tar.gz
  24. # Remote source(s)
  25. fetch=https://people.redhat.com/sgrubb/libcap-ng/$tarname
  26. description="
  27. An alternate POSIX capabilities library.
  28. The libcap-ng library is intended to make programming with POSIX
  29. capabilities much easier than the traditional libcap library.
  30. It includes utilities that can analyse all currently running
  31. applications and print out any capabilities and whether or not it has
  32. an open ended bounding set. An open bounding set without the securebits
  33. \"NOROOT\" flag will allow full capabilities escalation for apps
  34. retaining UID 0 simply by calling execve.
  35. "
  36. homepage=https://people.redhat.com/sgrubb/libcap-ng/
  37. license="GPLv2+, LGPLv2.1"
  38. # Source documentation
  39. docs="AUTHORS COPYING* ChangeLog NEWS README*"
  40. docsdir="${docdir}/${program}-${version}"
  41. build()
  42. {
  43. unpack "${tardir}/$tarname"
  44. cd "$srcdir"
  45. # Set sane permissions
  46. chmod -R u+w,go-w,a+rX-s .
  47. ./configure CPPFLAGS="$QICPPFLAGS" \
  48. CFLAGS="$QICFLAGS" LDFLAGS="$QILDFLAGS" \
  49. $configure_args \
  50. --libdir=/usr/lib${libSuffix} \
  51. --infodir=$infodir \
  52. --mandir=$mandir \
  53. --docdir=$docsdir \
  54. --enable-static=yes \
  55. --enable-shared=yes \
  56. --with-python=no \
  57. --with-python3 \
  58. --build="$(gcc -dumpmachine)"
  59. make -j${jobs} V=1
  60. make -j${jobs} DESTDIR="$destdir" install-strip
  61. # Compress info documents deleting index file for the package
  62. if test -d "${destdir}/$infodir"
  63. then
  64. rm -f "${destdir}/${infodir}/dir"
  65. lzip -9 "${destdir}/${infodir}"/*
  66. fi
  67. # Compress and link man pages (if needed)
  68. if test -d "${destdir}/$mandir"
  69. then
  70. (
  71. cd "${destdir}/$mandir"
  72. find . -type f -exec lzip -9 {} +
  73. find . -type l | while read -r file
  74. do
  75. ln -sf "$(readlink -- "$file").lz" "${file}.lz"
  76. rm -- "$file"
  77. done
  78. )
  79. fi
  80. # Copy documentation
  81. mkdir -p "${destdir}/$docsdir"
  82. cp -p $docs "${destdir}/$docsdir"
  83. }