recipe 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. # Build recipe for itstool.
  2. #
  3. # Copyright (c) 2019, 2021-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=itstool
  19. version=2.0.7
  20. arch=noarch
  21. release=1
  22. # Define a category for the output of the package name
  23. pkgcategory=docbook
  24. tarname=${program}-${version}.tar.bz2
  25. # Remote source(s)
  26. fetch=http://files.itstool.org/itstool/$tarname
  27. description="
  28. Convert between XML and PO using ITS.
  29. Itstool extracts messages from XML files and outputs PO template
  30. files, then merges translations from MO files to create translated
  31. XML files. It determines what to translate and how to chunk it
  32. into messages using the W3C Internationalization Tag Set (ITS).
  33. "
  34. homepage=https://itstool.org
  35. license=GPLv3+
  36. # Source documentation
  37. docs="AUTHORS COPYING* ChangeLog NEWS README"
  38. docsdir="${docdir}/${program}-${version}"
  39. build()
  40. {
  41. unpack "${tardir}/$tarname"
  42. cd "$srcdir"
  43. # Set sane permissions
  44. chmod -R u+w,go-w,a+rX-s .
  45. ./configure PYTHON="/usr/bin/python3" \
  46. $configure_args \
  47. --mandir=$mandir \
  48. --docdir=$docsdir \
  49. --build="$(gcc -dumpmachine)"
  50. make -j${jobs} V=1
  51. make -j${jobs} DESTDIR="$destdir" install
  52. # Compress and link man pages (if needed)
  53. if test -d "${destdir}/$mandir"
  54. then
  55. (
  56. cd "${destdir}/$mandir"
  57. find . -type f -exec lzip -9 {} +
  58. find . -type l | while read -r file
  59. do
  60. ln -sf "$(readlink -- "$file").lz" "${file}.lz"
  61. rm -- "$file"
  62. done
  63. )
  64. fi
  65. # Copy documentation
  66. mkdir -p "${destdir}/$docsdir"
  67. cp -p $docs "${destdir}/$docsdir"
  68. }