recipe 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. # Build recipe for Pango.
  2. #
  3. # Copyright (C) 2018, MMPG <mmpg@vp.pl>
  4. # Copyright (C) 2018-2019 Matias Fonzo, <selk@dragora.org>.
  5. #
  6. # Licensed under the Apache License, Version 2.0 (the "License");
  7. # you may not use this file except in compliance with the License.
  8. # You may obtain a copy of the License at
  9. #
  10. # http://www.apache.org/licenses/LICENSE-2.0
  11. #
  12. # Unless required by applicable law or agreed to in writing, software
  13. # distributed under the License is distributed on an "AS IS" BASIS,
  14. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  15. # See the License for the specific language governing permissions and
  16. # limitations under the License.
  17. program=pango
  18. version=1.44.6
  19. release=1
  20. # Set 'outdir' for a nice and well-organized output directory
  21. outdir="${outdir}/${arch}/x-libs"
  22. tarname=${program}-${version}.tar.xz
  23. # Remote source(s)
  24. fetch="http://ftp.gnome.org/pub/gnome/sources/pango/${version%.*}/$tarname"
  25. description="
  26. A library for layout and rendering of text.
  27. Pango can be used anywhere that text layout is needed; however, most of
  28. the work on Pango was done using the GTK+ widget toolkit as a test
  29. platform. Pango forms the core of text and font handling for GTK+-2.
  30. "
  31. homepage=http://www.pango.org/Introduction/
  32. license=LGPLv2+
  33. # Copy documentation
  34. docs="CODING_STYLE.md COPYING NEWS README.md THANKS"
  35. docsdir="${docdir}/${program}-${version}"
  36. build()
  37. {
  38. set -e
  39. unpack "${tardir}/$tarname"
  40. cd "$srcdir"
  41. # Set sane permissions
  42. chmod -R u+w,go-w,a+rX-s .
  43. mkdir -p build
  44. cd build
  45. CFLAGS="$QICFLAGS" CXXFLAGS="$QICXXFLAGS" LDFLAGS="$QILDFLAGS" \
  46. meson setup $configure_args \
  47. --libdir /usr/lib${libSuffix} \
  48. --mandir $mandir \
  49. --buildtype=release \
  50. --strip \
  51. ..
  52. ninja
  53. DESTDIR="$destdir" ninja install
  54. cd ..
  55. # Copy documentation
  56. mkdir -p "${destdir}${docsdir}"
  57. cp -p $docs "${destdir}${docsdir}"
  58. # Compress and link man pages (if needed)
  59. if test -d "${destdir}/$mandir"
  60. then
  61. (
  62. cd "${destdir}/$mandir"
  63. find . -type f -exec lzip -9 '{}' +
  64. find . -type l | while read -r file
  65. do
  66. ln -sf "$(readlink -- "$file").lz" "${file}.lz"
  67. rm -- "$file"
  68. done
  69. )
  70. fi
  71. }