recipe 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. # Build recipe for json-c.
  2. #
  3. # Copyright (c) 2022 DustDFG, <dfgdust@gmail.com>.
  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=json-c
  19. version=0.16-20220414
  20. release=1
  21. # Define a category for the output of the package name
  22. pkgcategory=libs
  23. tarname=${program}-${version}.tar.gz
  24. # Remote source(s)
  25. fetch=https://github.com/json-c/json-c/archive/refs/tags/$tarname
  26. description="
  27. The C library for parsing and manipulating strings in JSON format.
  28. JSON-C implements a reference counting object model that allows you to easily
  29. construct JSON objects in C, output them as JSON formatted strings and parse
  30. JSON formatted strings back into the C representation of JSON objects. It aims
  31. to conform to RFC 7159.
  32. "
  33. homepage=https://github.com/json-c/json-c
  34. license=MIT
  35. # Source documentation
  36. docs="COPYING README.md"
  37. docsdir="${docdir}/${program}-${version}"
  38. # The source has a custom directory name
  39. srcdir=${program}-json-c-${version}
  40. build()
  41. {
  42. unpack "${tardir}/$tarname"
  43. cd "$srcdir"
  44. # Set sane permissions
  45. chmod -R u+w,go-w,a+rX-s .
  46. rm -rf BUILD
  47. mkdir BUILD
  48. cd BUILD
  49. cmake -DCMAKE_BUILD_TYPE=Release \
  50. -DCMAKE_C_FLAGS="$QICFLAGS" \
  51. -DCMAKE_SHARED_LINKER_FLAGS="$QILDFLAGS" \
  52. -DCMAKE_STATIC_LINKER_FLAGS="$QILDFLAGS" \
  53. -DCMAKE_INSTALL_PREFIX=/usr \
  54. -DCMAKE_INSTALL_LIBDIR=lib${libSuffix} \
  55. -DCMAKE_INSTALL_MANDIR=$mandir \
  56. -DCMAKE_INSTALL_DOCDIR=$docsdir \
  57. -DBUILD_SHARED_LIBS=ON \
  58. -DBUILD_STATIC_LIBS=ON \
  59. -DBUILD_TESTING=OFF \
  60. -DENABLE_THREADING=OFF \
  61. -G Ninja ..
  62. #TODO: build docs when Dragora will have doxygen
  63. ninja -j${jobs}
  64. DESTDIR="$destdir" ninja -j${jobs} install
  65. # Compress info documents deleting index file for the package
  66. if test -d "${destdir}/$infodir"
  67. then
  68. rm -f "${destdir}/${infodir}/dir"
  69. lzip -9 "${destdir}/${infodir}"/*
  70. fi
  71. # Compress and link man pages (if needed)
  72. if test -d "${destdir}/$mandir"
  73. then
  74. (
  75. cd "${destdir}/$mandir"
  76. find . -type f -exec lzip -9 {} +
  77. find . -type l | while read -r file
  78. do
  79. ln -sf "$(readlink -- "$file").lz" "${file}.lz"
  80. rm -- "$file"
  81. done
  82. )
  83. fi
  84. cd ../
  85. # Copy documentation
  86. mkdir -p "${destdir}/$docsdir"
  87. cp -p $docs "${destdir}/$docsdir"
  88. }