recipe 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. # Build recipe for libuv.
  2. #
  3. # Copyright (c) 2018 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. program=libuv
  17. version=v1.24.1
  18. release=1
  19. # Set 'outdir' for a nice and well-organized output directory
  20. outdir="${outdir}/${arch}/libs"
  21. pkgversion="${version#v*}"
  22. tarname=${program}-${version}.tar.gz
  23. # Remote source(s)
  24. fetch=http://dist.libuv.org/dist/${version}/$tarname
  25. homepage=http://www.libuv.org
  26. license=MIT
  27. description="
  28. An asynchronous I/O library.
  29. libuv is a multi-platform support library with a focus on asynchronous
  30. I/O. See $homepage for more information.
  31. "
  32. # Source documentation
  33. docs="AUTHORS CONTRIBUTING.md LICENSE* MAINTAINERS.md README.md"
  34. docsdir="${docdir}/${program}-${pkgversion}"
  35. build()
  36. {
  37. set -e
  38. unpack "${tardir}/$tarname"
  39. cd "$srcdir"
  40. # Set sane permissions
  41. chmod -R u+w,go-w,a+rX-s .
  42. sh ./autogen.sh
  43. ./configure CFLAGS="$QICFLAGS" LDFLAGS="$QILDFLAGS" \
  44. $configure_args \
  45. --libdir=/usr/lib${libSuffix} \
  46. --mandir=$mandir \
  47. --docdir=$docsdir \
  48. --enable-static=no \
  49. --enable-shared=yes \
  50. --build="$(cc -dumpmachine)"
  51. make -j${jobs} V=1
  52. #make -C docs man; # It needs "sphinx"
  53. make -j${jobs} DESTDIR="$destdir" install-strip
  54. # Compress and link man pages (if needed)
  55. if test -d "${destdir}/$mandir"
  56. then
  57. (
  58. cd "${destdir}/$mandir"
  59. find . -type f -exec lzip -9 '{}' +
  60. find . -type l | while read -r file
  61. do
  62. ln -sf "$(readlink -- "$file").lz" "${file}.lz"
  63. rm -- "$file"
  64. done
  65. )
  66. fi
  67. # Copy documentation
  68. mkdir -p "${destdir}${docsdir}"
  69. cp -p $docs "${destdir}${docsdir}"
  70. }