recipe 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. # Build recipe for libuv.
  2. #
  3. # Copyright (c) 2018-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=libuv
  19. version=v1.44.1
  20. pkgversion="${version#v*}"
  21. release=1
  22. # Define a category for the output of the package name
  23. pkgcategory=libs
  24. tarname=${program}-${version}.tar.gz
  25. # Remote source(s)
  26. fetch=https://dist.libuv.org/dist/${version}/$tarname
  27. homepage=https://www.libuv.org
  28. license=MIT
  29. description="
  30. An asynchronous I/O library.
  31. libuv is a multi-platform support library with a focus on asynchronous
  32. I/O. See $homepage for more information.
  33. "
  34. # Source documentation
  35. docs="AUTHORS CONTRIBUTING.md LICENSE* MAINTAINERS.md README.md"
  36. docsdir="${docdir}/${program}-${pkgversion}"
  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. sh ./autogen.sh
  44. ./configure \
  45. CPPFLAGS="$QICPPFLAGS" CFLAGS="$QICFLAGS" LDFLAGS="$QILDFLAGS" \
  46. $configure_args \
  47. --libdir=/usr/lib${libSuffix} \
  48. --mandir=$mandir \
  49. --docdir=$docsdir \
  50. --enable-static=no \
  51. --enable-shared=yes \
  52. --build="$(gcc -dumpmachine)"
  53. make -j${jobs} V=1
  54. #make -C docs man; # It needs "Sphinx"
  55. make -j${jobs} DESTDIR="$destdir" install-strip
  56. # Compress and link man pages (if needed)
  57. if test -d "${destdir}/$mandir"
  58. then
  59. (
  60. cd "${destdir}/$mandir"
  61. find . -type f -exec lzip -9 {} +
  62. find . -type l | while read -r file
  63. do
  64. ln -sf "$(readlink -- "$file").lz" "${file}.lz"
  65. rm -- "$file"
  66. done
  67. )
  68. fi
  69. # Copy documentation
  70. mkdir -p "${destdir}/$docsdir"
  71. cp -p $docs "${destdir}/$docsdir"
  72. }