X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=debian%2Frules;h=3cbe40c695269789f502bd8e677e49218b68bf62;hb=4538f78a8111e8c4739776e4096e3daba44aca69;hp=995325230200b742c73ecf9e277e5dc71da1ccf6;hpb=a183e0be1314180dc618c0ec9990767f46f02014;p=pkg-collectd.git diff --git a/debian/rules b/debian/rules index 9953252..3cbe40c 100755 --- a/debian/rules +++ b/debian/rules @@ -1,7 +1,7 @@ -#!/usr/bin/make -f +#! /usr/bin/make -f # debian/rules for collectd # -# Written by Sebastian Harl . +# Written by Sebastian Harl . # Uncomment this to turn on verbose mode. #export DH_VERBOSE=1 @@ -12,13 +12,19 @@ DEB_HOST_GNU_TYPE ?= $(shell dpkg-architecture -qDEB_HOST_GNU_TYPE) DEB_BUILD_ARCH ?= $(shell dpkg-architecture -qDEB_BUILD_ARCH) DEB_BUILD_GNU_TYPE ?= $(shell dpkg-architecture -qDEB_BUILD_GNU_TYPE) -CFLAGS = -Wall -g -I$(CURDIR)/debian/include +CPPFLAGS = -I$(CURDIR)/debian/include +CFLAGS = -Wall -g # There is no way to tell lt_dlopen() to use the RTLD_GLOBAL flag which is # however required by the perl plugin (which would otherwise be unable to find # symbols defined in libperl when loading perl modules that require such # symbols). This is a workaround for this issue. -CFLAGS += -DLT_LAZY_OR_NOW='RTLD_LAZY|RTLD_GLOBAL' +CPPFLAGS += -DLT_LAZY_OR_NOW='RTLD_LAZY|RTLD_GLOBAL' + +# Upstream defaults to ${sysconfdir}/collectd.conf. Setting ${sysconfdir} to +# /etc/collectd would be wrong though. +CPPFLAGS += -UCONFIGFILE +CPPFLAGS += -DCONFIGFILE='\"/etc/collectd/collectd.conf\"' ifneq (,$(findstring noopt,$(DEB_BUILD_OPTIONS))) CFLAGS += -O0 @@ -26,6 +32,20 @@ else CFLAGS += -O2 endif +# The archdir map has been copied from openjdk-6's debian/rules. +JAVA_ARCHDIR_MAP = armel=arm hppa=parisc lpia=i386 powerpc=ppc +JAVA_ARCHDIR = $(strip $(patsubst $(DEB_BUILD_ARCH)=%, %, \ + $(filter $(DEB_BUILD_ARCH)=%, $(JAVA_ARCHDIR_MAP)))) +ifeq (,$(JAVA_ARCHDIR)) + JAVA_ARCHDIR = $(DEB_BUILD_ARCH) +endif +JAVA_HOME = /usr/lib/jvm/java-6-openjdk +JAVA_LIBDIR = $(JAVA_HOME)/jre/lib/$(JAVA_ARCHDIR)/server + +JAVAC = $(JAVA_HOME)/bin/javac +JAVA_CPPFLAGS = -I$(JAVA_HOME)/include +JAVA_LDFLAGS = -L$(JAVA_LIBDIR) -Wl,-rpath -Wl,$(JAVA_LIBDIR) + include /usr/share/dpatch/dpatch.make confflags = --host=$(DEB_HOST_GNU_TYPE) \ @@ -33,29 +53,80 @@ confflags = --host=$(DEB_HOST_GNU_TYPE) \ --mandir=\$${prefix}/share/man \ --localstatedir=/var --sysconfdir=/etc \ --with-perl-bindings="INSTALLDIRS=vendor" \ - --disable-xmms \ - --without-libstatgrab - -# libiptc is no longer available on Debian (see #472655). -confflags += --disable-iptables + --without-libstatgrab \ + --without-included-ltdl \ + --disable-static \ + --enable-all-plugins # These plugins do not provide any functionality under Linux. confflags += --disable-apple_sensors --disable-tape -# The static libraries iptc, netstat and upsclient cannot be used on -# 64bit systems (see bugs #358637 and #419684 for more details). -ifneq (,$(findstring $(DEB_BUILD_ARCH),alpha amd64 hppa ia64 ppc64)) - confflags += --disable-netlink --disable-nut +# libnetapp is required for the netapp plugin. +confflags += --disable-netapp + +# libowcapi is required for the onewire plugin. +confflags += --disable-onewire + +# libclntsh is required for the oracle plugin. +confflags += --disable-oracle + +# librouteros is required for the routeros plugin. +confflags += --disable-routeros + +# rrdclient support in librrd is required for the rrdcached plugin. +confflags += --disable-rrdcached + +# libtokyotyrant is required for the tokyotyrant plugin. +confflags += --disable-tokyotyrant + +# xmms1 is required for the xmms plugin. +confflags += --disable-xmms + +# libkstat is required for the xfs_arc plugin. +confflags += --disable-zfs-arc + +# The static library netstat cannot be linked into shared objects on some +# architectures (see bugs #358637, #419684 and #524593 for more details). +ifneq (,$(findstring $(DEB_BUILD_ARCH),alpha amd64 hppa ia64 ppc64 mips mipsel)) + confflags += --disable-netlink +endif + +# These plugins are Linux-specific. +ifneq (,$(findstring $(DEB_BUILD_ARCH),kfreebsd-i386 kfreebsd-amd64)) + confflags += \ + --disable-iptables \ + --disable-ipvs \ + --disable-netlink endif -# libvirt is only available on amd64, i386 and powerpc. -ifeq (,$(findstring $(DEB_BUILD_ARCH),amd64 i386 powerpc)) - confflags += --disable-libvirt +# Build-dependencies of these plugins are (not yet) available for kfreebsd. +ifneq (,$(findstring $(DEB_BUILD_ARCH),kfreebsd-i386 kfreebsd-amd64)) + confflags += \ + --disable-gmond \ + --disable-libvirt \ + --disable-java +endif + +# The hppa buildds currently do not keep up with Java related stuff, thus +# prevending testing transitions. +ifneq (,$(findstring $(DEB_BUILD_ARCH),hppa)) + confflags += --disable-java endif config.status: configure $(DPATCH_STAMPFN) dh_testdir - CFLAGS="$(CFLAGS)" ./configure $(confflags) + + # This is a work-around for #474087 (broken openipmi .pc files). + mkdir debian/pkgconfig + sed -re 's/^(Requires:.*) pthread(.*)$$/\1\2/' \ + /usr/lib/pkgconfig/OpenIPMIpthread.pc \ + > debian/pkgconfig/OpenIPMIpthread.pc + + PKG_CONFIG_PATH="$(CURDIR)/debian/pkgconfig:$$PKG_CONFIG_PATH" \ + ./configure $(confflags) CPPFLAGS="$(CPPFLAGS)" CFLAGS="$(CFLAGS)" \ + JAVAC="$(JAVAC)" JAVA_CPPFLAGS="$(JAVA_CPPFLAGS)" \ + JAVA_LDFLAGS="$(JAVA_LDFLAGS)" \ + || ( status=$$?; cat config.log; exit $$status ) build: build-stamp @@ -75,8 +146,11 @@ clean: unpatch [ ! -f Makefile ] || $(MAKE) distclean rm -f debian/README.Debian.plugins + rm -f src/*.1 src/*.5 + + rm -rf debian/pkgconfig - dh_clean + dh_clean debconf-updatepo install-indep: @@ -84,41 +158,27 @@ install-indep: dh_testroot dh_clean -k dh_installdirs -i - - include_dir=debian/collectd-dev/usr/include/collectd/ \ - && mkdir -p $$include_dir/liboconfig \ - && cp src/*.h $$include_dir \ - && cp src/liboconfig/oconfig.h $$include_dir/liboconfig + dh_install -i install-arch: build dh_testdir dh_testroot - dh_clean -k + dh_clean -k dh_installdirs -a - $(MAKE) install DESTDIR=$(CURDIR)/debian/collectd - - rm -rf debian/collectd/usr/include/ - rm -f debian/collectd/usr/lib/collectd/*.la + $(MAKE) install DESTDIR=$(CURDIR)/debian/tmp - rm -f debian/collectd/etc/collectd.conf - install -D -m 0644 debian/collectd.conf \ - debian/collectd/etc/collectd/collectd.conf - install -m 0644 debian/collection.conf \ - debian/collectd/etc/collectd/collection.conf - install -m 0644 debian/thresholds.conf \ - debian/collectd/etc/collectd/thresholds.conf + rm -f debian/tmp/usr/lib/collectd/*.la + rm -f debian/tmp/usr/lib/libcollectdclient.la + rm -f debian/tmp/etc/collectd.conf - mkdir -p debian/collectd/usr/lib/collectd/utils/ - for UTIL in rrd_filter.px migrate-3-4.px; do \ - cp contrib/$$UTIL debian/collectd/usr/lib/collectd/utils/; \ - done + dh_install -a --sourcedir=$(CURDIR)/debian/tmp --fail-missing perl ./debian/bin/gen_plugin_deps.pl - mkdir -p debian/collectd/usr/share/lintian/overrides/ - cp debian/collectd.overrides \ - debian/collectd/usr/share/lintian/overrides/collectd + mkdir -p debian/collectd-core/usr/share/lintian/overrides/ + cp debian/collectd-core.overrides \ + debian/collectd-core/usr/share/lintian/overrides/collectd-core binary-indep: install-indep dh_testdir @@ -127,7 +187,7 @@ binary-indep: install-indep dh_installdocs -A -i debian/README.Debian AUTHORS README TODO dh_installexamples -i contrib/examples/myplugin.c \ contrib/examples/MyPlugin.pm - dh_compress -i -Xexamples/myplugin.c -Xexamples/MyPlugin.c + dh_compress -i -Xexamples/ dh_fixperms -i dh_installdeb -i dh_gencontrol -i @@ -141,21 +201,38 @@ binary-arch: build install-arch dh_installdocs -A -a debian/README.Debian AUTHORS README TODO dh_installdocs -a debian/NEWS.Debian debian/README.Debian.plugins dh_installexamples -a contrib/collectd2html.pl contrib/collection.cgi \ + contrib/collection3/ contrib/php-collection/ \ contrib/exec-munin.conf contrib/exec-munin.px contrib/exec-smartctl \ contrib/exec-nagios.conf contrib/exec-nagios.px \ contrib/SpamAssassin/ contrib/iptables/ contrib/cussh.pl \ - contrib/snmp-data.conf contrib/add_rra.sh contrib/network-proxy.py + contrib/snmp-data.conf contrib/add_rra.sh contrib/network-proxy.py \ + contrib/collectd_network.py contrib/collectd_unixsock.py \ + contrib/snmp-probe-host.px contrib/GenericJMX.conf \ + debian/collectd.conf debian/filters.conf debian/thresholds.conf + # some upstream tarballs have been built inside a dirty working dir + ( cd debian/collectd-core/ \ + && cd usr/share/doc/collectd-core/examples/collection3/ \ + && rm -f bin/foo bin/test_config.px etc/collection4.conf \ + && rm -f lib/Collectd/Graph.pm lib/Collectd/Graph/Data.pm \ + && rm -f lib/Collectd/Graph/File.pm lib/Collectd/Graph/Filter.pm \ + && rm -f lib/Collectd/Graph/MetaData.pm ) dh_installdebconf -a - dh_installinit -a -- defaults 95 + dh_installinit -pcollectd-core --name=collectd -- defaults 95 dh_link -a dh_strip -a --dbg-package=collectd-dbg - dh_compress -a + dh_compress -a -Xexamples/ dh_fixperms -a + dh_makeshlibs -a dh_installdeb -a + dh_shlibdeps -a -Ncollectd-core -Ncollectd dpkg-shlibdeps -Tdebian/collectd.substvars \ - -dDepends debian/collectd/usr/bin/* debian/collectd/usr/sbin/* \ - debian/collectd/usr/lib/collectd/rrdtool.so \ - -dRecommends debian/collectd/usr/lib/collectd/*.so + -dDepends debian/collectd-core/usr/lib/collectd/rrdtool.so + dpkg-shlibdeps -Tdebian/collectd-core.substvars \ + -dDepends debian/collectd-core/usr/sbin/* \ + -dSuggests debian/collectd-core/usr/lib/collectd/*.so + grep shlibs:Suggests debian/collectd-core.substvars \ + | sed -e 's/shlibs:Suggests/shlibs:Recommends/' \ + >> debian/collectd.substvars dh_gencontrol -a dh_md5sums -a dh_builddeb -a