recipe 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. # Build recipe for qpdf.
  2. #
  3. # Copyright (c) 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=qpdf
  19. version=11.2.0
  20. release=1
  21. # Define a category for the output of the package name
  22. pkgcategory=printing
  23. tarname=${program}-${version}.tar.gz
  24. # Remote source(s)
  25. fetch=https://github.com/qpdf/qpdf/releases/download/v${version}/$tarname
  26. description="
  27. Command-line programs and PDF transformation library.
  28. The qpdf package contains command-line programs and a library that does
  29. structural, content-preserving transformations on PDF files.
  30. "
  31. homepage=https://qpdf.sourceforge.io
  32. license="Artistic License v2.0 | Apache License v2.0"
  33. # Source documentation
  34. docs="Artistic-* ChangeLog* LICENSE.txt NOTICE.md README* TODO"
  35. docsdir="${docdir}/${program}-${version}"
  36. build()
  37. {
  38. unpack "${tardir}/$tarname"
  39. cd "$srcdir"
  40. # Set sane permissions
  41. chmod -R u+w,go-w,a+rX-s .
  42. rm -rf BUILD
  43. mkdir BUILD
  44. cd BUILD
  45. cmake -DCMAKE_BUILD_TYPE=Release \
  46. -DCMAKE_C_FLAGS="$QICFLAGS" \
  47. -DCMAKE_CXX_FLAGS="$QICXXFLAGS" \
  48. -DCMAKE_EXE_LINKER_FLAGS="$QILDFLAGS" \
  49. -DCMAKE_SHARED_LINKER_FLAGS="$QILDFLAGS" \
  50. -DCMAKE_STATIC_LINKER_FLAGS="$QILDFLAGS" \
  51. -DCMAKE_INSTALL_PREFIX=/usr \
  52. -DCMAKE_INSTALL_LIBDIR=lib${libSuffix} \
  53. -DCMAKE_INSTALL_MANDIR=$mandir \
  54. -DCMAKE_INSTALL_DOCDIR=$docsdir \
  55. -DBUILD_STATIC_LIBS=OFF \
  56. -DUSE_IMPLICIT_CRYPTO=0 \
  57. -DREQUIRE_CRYPTO_GNUTLS=1 \
  58. -G Ninja ..
  59. ninja -j${jobs}
  60. DESTDIR="$destdir" ninja -j${jobs} install
  61. # Switch back to the main source directory
  62. cd ..
  63. # Install available Shell completions
  64. install -p -m 644 completions/bash/qpdf -D \
  65. "${destdir}/usr/share/bash-completion/completions/qpdf"
  66. install -p -m 644 completions/zsh/_qpdf -D \
  67. "${destdir}/usr/share/zsh/site-functions/_qpdf"
  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. # Remove junk from the documentation
  85. rm -f "${destdir}/${docsdir}/README-windows.md"
  86. }