Makefile.am 4.87 KB
Newer Older
1
2
3
# -*- Makefile -*-

AM_CFLAGS        = ${regular_CFLAGS}
4
AM_CPPFLAGS      = ${regular_CPPFLAGS} -I${top_builddir}/include -I${top_srcdir}/include -I${top_srcdir} ${kinclude_CPPFLAGS} ${libmnl_CFLAGS} ${libnftnl_CFLAGS} ${libnetfilter_conntrack_CFLAGS}
5
AM_YFLAGS = -d
6

7
8
BUILT_SOURCES =

9
10
11
xtables_legacy_multi_SOURCES  = xtables-legacy-multi.c iptables-xml.c
xtables_legacy_multi_CFLAGS   = ${AM_CFLAGS}
xtables_legacy_multi_LDADD    = ../extensions/libext.a
12
if ENABLE_STATIC
13
xtables_legacy_multi_CFLAGS  += -DALL_INCLUSIVE
14
15
endif
if ENABLE_IPV4
16
xtables_legacy_multi_SOURCES += iptables-standalone.c iptables.c
17
18
xtables_legacy_multi_CFLAGS  += -DENABLE_IPV4
xtables_legacy_multi_LDADD   += ../libiptc/libip4tc.la ../extensions/libext4.a
19
20
endif
if ENABLE_IPV6
21
xtables_legacy_multi_SOURCES += ip6tables-standalone.c ip6tables.c
22
23
xtables_legacy_multi_CFLAGS  += -DENABLE_IPV6
xtables_legacy_multi_LDADD   += ../libiptc/libip6tc.la ../extensions/libext6.a
24
endif
25
xtables_legacy_multi_SOURCES += xshared.c iptables-restore.c iptables-save.c
26
xtables_legacy_multi_LDADD   += ../libxtables/libxtables.la -lm
27

28
# iptables using nf_tables api
29
if ENABLE_NFTABLES
30
BUILT_SOURCES += xtables-config-parser.h
31
32
33
xtables_nft_multi_SOURCES  = xtables-nft-multi.c iptables-xml.c
xtables_nft_multi_CFLAGS   = ${AM_CFLAGS}
xtables_nft_multi_LDADD    = ../extensions/libext.a ../extensions/libext_ebt.a
34
if ENABLE_STATIC
35
xtables_nft_multi_CFLAGS  += -DALL_INCLUSIVE
36
endif
37
38
39
xtables_nft_multi_CFLAGS  += -DENABLE_NFTABLES -DENABLE_IPV4 -DENABLE_IPV6
xtables_nft_multi_SOURCES += xtables-config-parser.y xtables-config-syntax.l
xtables_nft_multi_SOURCES += xtables-save.c xtables-restore.c \
40
41
				xtables-standalone.c xtables.c nft.c \
				nft-shared.c nft-ipv4.c nft-ipv6.c nft-arp.c \
42
				xtables-monitor.c \
43
				xtables-arp-standalone.c xtables-arp.c \
44
				nft-bridge.c \
45
				xtables-eb-standalone.c xtables-eb.c \
46
				xtables-eb-translate.c \
47
				xtables-translate.c
48
xtables_nft_multi_LDADD   += ${libmnl_LIBS} ${libnftnl_LIBS} ${libnetfilter_conntrack_LIBS} ../extensions/libext4.a ../extensions/libext6.a ../extensions/libext_ebt.a ../extensions/libext_arpt.a
49
# yacc and lex generate dirty code
50
51
52
xtables_nft_multi-xtables-config-parser.o xtables_nft_multi-xtables-config-syntax.o: AM_CFLAGS += -Wno-missing-prototypes -Wno-missing-declarations -Wno-implicit-function-declaration -Wno-nested-externs -Wno-undef -Wno-redundant-decls
xtables_nft_multi_SOURCES += xshared.c
xtables_nft_multi_LDADD   += ../libxtables/libxtables.la -lm
53
54
endif

55
sbin_PROGRAMS    = xtables-legacy-multi
56
if ENABLE_NFTABLES
57
sbin_PROGRAMS	+= xtables-nft-multi
58
endif
59
60
man_MANS         = iptables.8 iptables-restore.8 iptables-save.8 \
                   iptables-xml.1 ip6tables.8 ip6tables-restore.8 \
61
62
                   ip6tables-save.8 iptables-extensions.8 \
                   xtables-nft.8 xtables-translate.8 xtables-legacy.8 \
63
                   iptables-translate.8 ip6tables-translate.8 \
64
                   xtables-monitor.8
65
66
67
68
if ENABLE_NFTABLES
man_MANS	+= arptables-nft.8 arptables-nft-restore.8 arptables-nft-save.8 \
		   ebtables-nft.8
endif
69
CLEANFILES       = iptables.8 xtables-monitor.8 \
70
		   iptables-translate.8 ip6tables-translate.8 \
71
		   xtables-config-parser.c xtables-config-syntax.c
72
73
74

vx_bin_links   = iptables-xml
if ENABLE_IPV4
75
76
v4_sbin_links  = iptables-legacy iptables-legacy-restore iptables-legacy-save \
		 iptables iptables-restore iptables-save
77
78
endif
if ENABLE_IPV6
79
80
v6_sbin_links  = ip6tables-legacy ip6tables-legacy-restore ip6tables-legacy-save \
		 ip6tables ip6tables-restore ip6tables-save
81
endif
82
if ENABLE_NFTABLES
83
84
x_sbin_links  = iptables-nft iptables-nft-restore iptables-nft-save \
		ip6tables-nft ip6tables-nft-restore ip6tables-nft-save \
85
86
		iptables-translate ip6tables-translate \
		iptables-restore-translate ip6tables-restore-translate \
87
88
89
90
91
92
93
		arptables-nft arptables \
		arptables-nft-restore arptables-restore \
		arptables-nft-save arptables-save \
		ebtables-nft ebtables \
		ebtables-nft-restore ebtables-restore \
		ebtables-nft-save ebtables-save \
		xtables-monitor
94
endif
95
96
97
98
99
100

iptables-extensions.8: iptables-extensions.8.tmpl ../extensions/matches.man ../extensions/targets.man
	${AM_VERBOSE_GEN} sed \
		-e '/@MATCH@/ r ../extensions/matches.man' \
		-e '/@TARGET@/ r ../extensions/targets.man' $< >$@;

101
102
103
iptables-translate.8 ip6tables-translate.8:
	${AM_VERBOSE_GEN} echo '.so man8/xtables-translate.8' >$@

104
105
106
107
108
109
pkgconfig_DATA = xtables.pc

# Using if..fi avoids an ugly "error (ignored)" message :)
install-exec-hook:
	-if test -z "${DESTDIR}"; then /sbin/ldconfig; fi;
	${INSTALL} -dm0755 "${DESTDIR}${bindir}";
110
111
112
113
	for i in ${vx_bin_links}; do ${LN_S} -f "${sbindir}/xtables-legacy-multi" "${DESTDIR}${bindir}/$$i"; done;
	for i in ${v4_sbin_links}; do ${LN_S} -f xtables-legacy-multi "${DESTDIR}${sbindir}/$$i"; done;
	for i in ${v6_sbin_links}; do ${LN_S} -f xtables-legacy-multi "${DESTDIR}${sbindir}/$$i"; done;
	for i in ${x_sbin_links}; do ${LN_S} -f xtables-nft-multi "${DESTDIR}${sbindir}/$$i"; done;