recipe 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. # Build recipe for parted.
  2. #
  3. # Copyright (c) 2022 Matias Fonzo, <selk@dragora>.
  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=parted
  19. version=3.5
  20. release=1
  21. # Define a category for the output of the package name
  22. pkgcategory=tools
  23. tarname=${program}-${version}.tar.xz
  24. # Remote source(s)
  25. fetch=https://ftp.gnu.org/gnu/parted/$tarname
  26. description="
  27. GNU Parted manipulates partition tables.
  28. This is useful for creating space for new operating systems,
  29. reorganizing disk usage, copying data on hard disks and disk
  30. imaging. The package contains a library, libparted, as well
  31. as a command-line frontend, parted, which can also be used
  32. in scripts.
  33. "
  34. homepage=https://www.gnu.org/software/parted/
  35. license=GPLv3+
  36. # Source documentation
  37. docs="AUTHORS BUGS COPYING ChangeLog NEWS README THANKS TODO doc/API doc/FAT"
  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 CPPFLAGS="$QICPPFLAGS" \
  46. CFLAGS="$QICFLAGS" LDFLAGS="$QILDFLAGS" \
  47. $configure_args \
  48. --libdir=/usr/lib${libSuffix} \
  49. --infodir=$infodir \
  50. --mandir=$mandir \
  51. --docdir=$docsdir \
  52. --enable-static=no \
  53. --enable-shared=yes \
  54. --enable-device-mapper \
  55. --enable-part-static \
  56. --enable-pc98=no \
  57. --enable-Werror=no \
  58. --build="$(gcc -dumpmachine)"
  59. make -j${jobs} V=1
  60. make -j${jobs} DESTDIR="$destdir" install
  61. # Compress info documents deleting index file for the package
  62. if test -d "${destdir}/$infodir"
  63. then
  64. rm -f "${destdir}/${infodir}/dir"
  65. lzip -9 "${destdir}/${infodir}"/*
  66. fi
  67. # Compress and link man pages (if needed)
  68. if test -d "${destdir}/$mandir"
  69. then
  70. (
  71. cd "${destdir}/$mandir"
  72. find . -type f -exec lzip -9 {} +
  73. find . -type l | while read -r file
  74. do
  75. ln -sf "$(readlink -- "$file").lz" "${file}.lz"
  76. rm -- "$file"
  77. done
  78. )
  79. fi
  80. # Copy documentation
  81. mkdir -p "${destdir}/$docsdir"
  82. cp -p $docs "${destdir}/$docsdir"
  83. }