recipe 2.4 KB

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