recipe 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. # Build recipe for zstd.
  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=zstd
  19. version=1.5.2
  20. release=1
  21. # Define a category for the output of the package name
  22. pkgcategory=compressors
  23. tarname=${program}-${version}.tar.gz
  24. # Remote source(s)
  25. fetch=https://github.com/facebook/zstd/releases/download/${version}/$tarname
  26. description="
  27. Zstandard is a fast compression algorithm.
  28. Zstandard, or zstd as short version, is a fast lossless compression algorithm,
  29. targeting real-time compression scenarios at zlib-level and better compression
  30. ratios. It is backed by a very fast entropy stage, provided by Huff0 and FSE
  31. library.
  32. "
  33. homepage=https://facebook.github.io/zstd/
  34. license="GPLv2+ | BSD-3 clause"
  35. # Source documentation
  36. docs="CHANGELOG CODE_OF_CONDUCT.md CONTRIBUTING.md COPYING LICENSE README.md TESTING.md"
  37. docsdir="${docdir}/${program}-${version}"
  38. build()
  39. {
  40. unpack "${tardir}/$tarname"
  41. cd "$srcdir"
  42. # Set sane permissions
  43. chmod -R u+w,go-w,a+rX-s .
  44. rm -rf BUILD
  45. mkdir BUILD
  46. cd BUILD
  47. cmake -DCMAKE_BUILD_TYPE=Release \
  48. -DCMAKE_C_FLAGS="$QICFLAGS" \
  49. -DCMAKE_CXX_FLAGS="$QICXXFLAGS" \
  50. -DCMAKE_EXE_LINKER_FLAGS="$QILDFLAGS" \
  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_INFODIR=$infodir \
  56. -DCMAKE_INSTALL_MANDIR=$mandir \
  57. -DCMAKE_INSTALL_DOCDIR=$docsdir \
  58. -DZSTD_BUILD_CONTRIB=OFF \
  59. -DZSTD_BUILD_PROGRAMS=ON \
  60. -DZSTD_BUILD_SHARED=ON \
  61. -DZSTD_BUILD_STATIC=ON \
  62. -DZSTD_BUILD_TESTS=OFF \
  63. -DZSTD_LEGACY_SUPPORT=ON \
  64. -DZSTD_MULTITHREAD_SUPPORT=ON \
  65. -DZSTD_PROGRAMS_LINK_SHARED=ON \
  66. -DZSTD_LZ4_SUPPORT=OFF \
  67. -DZSTD_LZMA_SUPPORT=OFF \
  68. -DZSTD_ZLIB_SUPPORT=OFF \
  69. -G Ninja ../build/cmake
  70. ninja -j${jobs}
  71. DESTDIR="$destdir" ninja -j${jobs} install
  72. # Compress info documents deleting index file for the package
  73. if test -d "${destdir}/$infodir"
  74. then
  75. rm -f "${destdir}/${infodir}/dir"
  76. lzip -9 "${destdir}/${infodir}"/*
  77. fi
  78. # Compress and link man pages (if needed)
  79. if test -d "${destdir}/$mandir"
  80. then
  81. (
  82. cd "${destdir}/$mandir"
  83. find . -type f -exec lzip -9 {} +
  84. find . -type l | while read -r file
  85. do
  86. ln -sf "$(readlink -- "$file").lz" "${file}.lz"
  87. rm -- "$file"
  88. done
  89. )
  90. fi
  91. cd ../
  92. # Copy documentation
  93. mkdir -p "${destdir}/$docsdir"
  94. cp -p $docs "${destdir}/$docsdir"
  95. }