recipe 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. # Build recipe for btrfs-progs.
  2. #
  3. # Copyright (c) 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=btrfs-progs
  19. version=5.16
  20. release=1
  21. # Define a category for the output of the package name
  22. pkgcategory=tools
  23. tarname=${program}-v${version}.tar.gz
  24. # Remote source(s)
  25. fetch=https://www.kernel.org/pub/linux/kernel/people/kdave/btrfs-progs/$tarname
  26. description="
  27. Userspace utilities to manage btrfs filesystems.
  28. Btrfs is a copy on write (COW) filesystem for Linux aimed at implementing
  29. advanced features while focusing on fault tolerance, repair and easy
  30. administration.
  31. "
  32. homepage=https://www.kernel.org/pub/linux/kernel/people/kdave/btrfs-progs/
  33. license=GPLv2+
  34. # Source documentation
  35. docs="CHANGES COPYING README* VERSION"
  36. docsdir="${docdir}/${program}-${version}"
  37. # The source has a custom directory name
  38. srcdir="${tarname%.tar*}"
  39. build()
  40. {
  41. unpack "${tardir}/$tarname"
  42. cd "$srcdir"
  43. # Fix conflict with the sysinfo definition under Musl
  44. patch -Np1 -i "${worktree}/patches/btrfs-progs/sysinfo-glibc.patch"
  45. # Set sane permissions
  46. chmod -R u+w,go-w,a+rX-s .
  47. ./configure CPPFLAGS="$QICPPFLAGS" \
  48. CFLAGS="$QICFLAGS -O3" LDFLAGS="$QILDFLAGS" \
  49. $configure_args \
  50. --libdir=/usr/lib${libSuffix} \
  51. --infodir=$infodir \
  52. --mandir=$mandir \
  53. --docdir=$docsdir \
  54. --disable-backtrace \
  55. --disable-zstd \
  56. --with-convert=ext2 \
  57. --build="$(gcc -dumpmachine)"
  58. make -j${jobs} V=1
  59. make -j${jobs} DESTDIR="$destdir" install
  60. # Install Bash completion file
  61. install -p -m 644 btrfs-completion -D \
  62. "${destdir}/usr/share/bash-completion/completions/btrfs"
  63. # Compress and link man pages (if needed)
  64. if test -d "${destdir}/$mandir"
  65. then
  66. (
  67. cd "${destdir}/$mandir"
  68. find . -type f -exec lzip -9 {} +
  69. find . -type l | while read -r file
  70. do
  71. ln -sf "$(readlink -- "$file").lz" "${file}.lz"
  72. rm -- "$file"
  73. done
  74. )
  75. fi
  76. # Copy documentation
  77. mkdir -p "${destdir}/$docsdir"
  78. cp -p $docs "${destdir}/$docsdir"
  79. }