recipe 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. # Build recipe for liblouis.
  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=liblouis
  19. version=3.24.0
  20. release=1
  21. # Define a category for the output of the package name
  22. pkgcategory=braille
  23. tarname=${program}-${version}.tar.gz
  24. # Remote source(s)
  25. fetch=https://github.com/liblouis/liblouis/releases/download/v${version}/$tarname
  26. description="
  27. A Braille translator and back-translator.
  28. The liblouis package suite provides an open-source braille translator,
  29. back-translator and formatter for a large number of languages and
  30. braille codes. It is a set of libraries designed for use in any of a
  31. number of applications, both free and commercial.
  32. It is written in C so that it does not require a runtime environment
  33. and hence can be used in applications written in high-level languages
  34. such as Java and Python.
  35. "
  36. homepage=http://liblouis.org
  37. license="GPLv3+, LGPLv2.1"
  38. # Source documentation
  39. docs="AUTHORS COPYING* ChangeLog HACKING NEWS README doc/liblouis.html doc/liblouis.txt"
  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-shared=yes \
  55. --enable-static=no \
  56. --enable-ucs4 \
  57. --without-yaml \
  58. --build="$(gcc -dumpmachine)"
  59. make -j${jobs} V=1
  60. make -j${jobs} DESTDIR="$destdir" install
  61. # Install Python bindings
  62. (
  63. cd python
  64. python3 setup.py build
  65. python3 setup.py install --prefix=/usr --root="$destdir" --optimize=1
  66. )
  67. # Compress info documents deleting index file for the package
  68. if test -d "${destdir}/$infodir"
  69. then
  70. rm -f "${destdir}/${infodir}/dir"
  71. lzip -9 "${destdir}/${infodir}"/*
  72. fi
  73. # Compress and link man pages (if needed)
  74. if test -d "${destdir}/$mandir"
  75. then
  76. (
  77. cd "${destdir}/$mandir"
  78. find . -type f -exec lzip -9 {} +
  79. find . -type l | while read -r file
  80. do
  81. ln -sf "$(readlink -- "$file").lz" "${file}.lz"
  82. rm -- "$file"
  83. done
  84. )
  85. fi
  86. # Copy documentation
  87. mkdir -p "${destdir}/$docsdir"
  88. cp -p $docs "${destdir}/$docsdir"
  89. }