recipe 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. # Build recipe for gexiv2.
  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=gexiv2
  19. version=0.14.0
  20. release=1
  21. # Define a category for the output of the package name
  22. pkgcategory=x-libs
  23. tarname=${program}-${version}.tar.xz
  24. # Remote source(s)
  25. fetch="https://download.gnome.org/sources/gexiv2/${version%.*}/$tarname"
  26. description="
  27. A GObject-based Exiv2 wrapper.
  28. Gexiv2 is a GObject wrapper around the Exiv2 photo metadata library.
  29. It allows for GNOME applications to easily inspect and update EXIF,
  30. IPTC, and XMP metadata in photo and video files of various formats.
  31. "
  32. homepage=https://wiki.gnome.org/Projects/gexiv2
  33. license=GPLv2+
  34. # Source documentation
  35. docs="AUTHORS COPYING NEWS README THANKS"
  36. docsdir="${docdir}/${program}-${version}"
  37. build()
  38. {
  39. unpack "${tardir}/$tarname"
  40. cd "$srcdir"
  41. # Set sane permissions
  42. chmod -R u+w,go-w,a+rX-s .
  43. rm -rf BUILD
  44. mkdir BUILD
  45. cd BUILD
  46. CPPFLAGS="$QICPPFLAGS" \
  47. CFLAGS="$QICFLAGS" \
  48. CXXFLAGS="$QICXXFLAGS" \
  49. LDFLAGS="$QILDFLAGS" \
  50. meson setup $configure_args \
  51. --libdir /usr/lib${libSuffix} \
  52. --buildtype=release \
  53. --strip \
  54. ..
  55. ninja -j${jobs}
  56. DESTDIR="$destdir" ninja -j${jobs} install
  57. # Switch back to the main source directory
  58. cd ..
  59. # Compress and link man pages (if needed)
  60. if test -d "${destdir}/$mandir"
  61. then
  62. (
  63. cd "${destdir}/$mandir"
  64. find . -type f -exec lzip -9 {} +
  65. find . -type l | while read -r file
  66. do
  67. ln -sf "$(readlink -- "$file").lz" "${file}.lz"
  68. rm -- "$file"
  69. done
  70. )
  71. fi
  72. # Copy documentation
  73. mkdir -p "${destdir}/$docsdir"
  74. cp -p $docs "${destdir}/$docsdir"
  75. }