recipe 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. # Build recipe for libmnl.
  2. #
  3. # Copyright (c) 2017 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=libmnl
  17. version=1.0.4
  18. release=1
  19. # Set 'outdir' for a nice and well-organized output directory
  20. outdir="${outdir}/${arch}/networking"
  21. tarname=${program}-${version}.tar.bz2
  22. # Remote source(s)
  23. fetch=http://www.netfilter.org/projects/libmnl/files/$tarname
  24. description="
  25. libmnl is a minimalistic library oriented to Netlink developers.
  26. There are a lot of common tasks in parsing, validating, constructing
  27. of both the Netlink header and TLVs that are repetitive and easy to
  28. get wrong. This library aims to provide simple helpers that allows
  29. you to re-use code and to avoid re-inventing the wheel.
  30. "
  31. homepage=http://www.netfilter.org/projects/libmnl
  32. license=LGPLv2.1
  33. # Source documentation
  34. docs="COPYING README"
  35. docsdir="${docdir}/${program}-${version}"
  36. build()
  37. {
  38. set -e
  39. unpack "${tardir}/$tarname"
  40. cd "$srcdir"
  41. # Set sane permissions
  42. chmod -R u+w,go-w,a+rX-s .
  43. ./configure CFLAGS="$QICFLAGS" LDFLAGS="$QILDFLAGS" \
  44. $configure_args \
  45. --libdir=/usr/lib${libSuffix} \
  46. --infodir=$infodir \
  47. --mandir=$mandir \
  48. --enable-shared \
  49. --enable-static \
  50. --build="$(cc -dumpmachine)"
  51. make -j${jobs} V=1
  52. make -j${jobs} DESTDIR="$destdir" install
  53. # Compress info documents deleting index file for the package
  54. if test -d "${destdir}/$infodir"
  55. then
  56. rm -f "${destdir}/${infodir}/dir"
  57. lzip -9 "${destdir}/${infodir}"/*
  58. fi
  59. # Compress and link man pages (if needed)
  60. if test -d "${destdir}/$mandir"
  61. then
  62. (
  63. cd "${destdir}/$mandir"
  64. find . -type f -exec lzip -9 '{}' +
  65. find . -type l | while read -r file
  66. do
  67. ln -sf "$(readlink -- "$file").lz" "${file}.lz"
  68. rm -- "$file"
  69. done
  70. )
  71. fi
  72. # Copy documentation
  73. mkdir -p "${destdir}${docsdir}"
  74. for file in $docs
  75. do
  76. cp -p $file "${destdir}${docsdir}"
  77. done
  78. }