# Makefile.am
# Automake file for Ethereal
#
-# $Id: Makefile.am,v 1.83 1999/10/14 01:28:27 guy Exp $
+# $Id: Makefile.am,v 1.156 2000/01/15 13:45:06 gram Exp $
#
# Ethereal - Network traffic analyzer
# By Gerald Combs <gerald@zing.org>
# along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
-bin_PROGRAMS = ethereal
+bin_PROGRAMS = ethereal editcap tethereal
-man_MANS = ethereal.1
+man_MANS = ethereal.1 editcap.1 tethereal.1
sysconf_DATA = manuf
# Any POSIX-compatible YACC should honor the -p flag
YFLAGS=-d -p dfilter_
-ethereal_SOURCES = \
- alignment.h \
- capture.c \
- capture.h \
- colors.c \
- colors.h \
- column.c \
- column.h \
- dfilter-int.h \
- dfilter-grammar.y \
- dfilter-scanner.l \
- dfilter.c \
- dfilter.h \
- display.c \
- display.h \
- ethertype.c \
- etypes.h \
- file.c \
- file.h \
- follow.c \
- follow.h \
- globals.h \
+DISSECTOR_SOURCES = \
packet-aarp.c \
+ packet-afs.c \
+ packet-afs.h \
packet-arp.c \
+ packet-arp.h \
packet-ascend.c\
packet-atalk.c \
+ packet-atalk.h \
packet-atm.c \
+ packet-auto_rp.c \
+ packet-bgp.c \
+ packet-bgp.h \
packet-bootp.c \
+ packet-bootparams.c \
+ packet-bootparams.h \
packet-bpdu.c \
packet-cdp.c \
packet-clip.c \
packet-ftp.c \
packet-giop.c \
packet-gre.c \
+ packet-hsrp.c \
packet-http.c \
packet-icmpv6.c\
packet-icp.c \
+ packet-icq.c \
+ packet-imap.c \
packet-ip.c \
packet-ip.h \
packet-ipp.c \
packet-ipv6.h \
packet-ipx.c \
packet-ipx.h \
+ packet-irc.c \
packet-isakmp.c\
+ packet-isis.h \
+ packet-isis.c \
+ packet-isis-clv.h \
+ packet-isis-clv.c \
+ packet-isis-hello.h \
+ packet-isis-hello.c \
+ packet-isis-lsp.h \
+ packet-isis-lsp.c \
+ packet-isis-snp.h \
+ packet-isis-snp.c \
+ packet-l2tp.c \
packet-lapb.c \
+ packet-lapd.c \
+ packet-ldap.c \
packet-llc.c \
packet-lpd.c \
+ packet-mapi.c \
+ packet-mount.c \
+ packet-mount.h \
packet-nbipx.c \
packet-nbns.c \
packet-ncp.c \
packet-ncp.h \
packet-netbios.c \
packet-netbios.h \
+ packet-nfs.c \
+ packet-nfs.h \
+ packet-nlm.c \
+ packet-nlm.h \
packet-nntp.c \
+ packet-ntp.c \
+ packet-ntp.h \
packet-null.c \
packet-osi.c \
packet-ospf.c \
packet-ospf.h \
packet-pim.c \
packet-pop.c \
+ packet-portmap.c \
+ packet-portmap.h \
packet-ppp.c \
packet-pppoe.c \
packet-pptp.c \
+ packet-q2931.c \
+ packet-q931.c \
+ packet-q931.h \
packet-radius.c\
packet-raw.c \
packet-rip.c \
packet-rip.h \
packet-ripng.c \
packet-ripng.h \
+ packet-rpc.c \
+ packet-rpc.h \
packet-rsvp.c \
packet-rsvp.h \
packet-rtsp.c \
+ packet-rx.c \
+ packet-rx.h \
+ packet-sap.c \
packet-sdp.c \
packet-smb.c \
packet-sna.c \
+ packet-sna.h \
+ packet-snmp.c \
+ packet-snmp.h \
+ packet-srvloc.c \
+ packet-sscop.c \
+ packet-stat.c \
+ packet-stat.h \
+ packet-tacacs.c \
packet-tcp.c \
packet-telnet.c\
packet-tftp.c \
+ packet-tns.c \
+ packet-tns.h \
packet-tr.c \
packet-trmac.c \
packet-udp.c \
+ packet-v120.c \
packet-vines.c \
packet-vines.h \
+ packet-vlan.c \
+ packet-vrrp.c \
+ packet-wccp.c\
+ packet-who.c\
packet-x25.c \
packet-yhoo.c \
packet-yhoo.h \
+ packet-ypbind.c \
+ packet-ypbind.h \
+ packet-ypserv.c \
+ packet-ypserv.h \
+ packet-ypxfr.c \
+ packet-ypxfr.h
+
+ETHEREAL_COMMON_SOURCES = \
+ alignment.h \
+ asn1.c \
+ asn1.h \
+ column.c \
+ column.h \
+ conversation.c \
+ conversation.h \
+ dfilter-int.h \
+ dfilter-grammar.y \
+ dfilter-scanner.l \
+ dfilter.c \
+ dfilter.h \
+ ethertype.c \
+ etypes.h \
+ follow.c \
+ follow.h \
+ inet_v6defs.h \
+ ipproto.c \
+ ipv4.c \
+ ipv4.h \
+ nlpid.h \
+ oui.h \
packet.c \
packet.h \
+ plugins.c \
+ plugins.h \
prefs.c \
prefs.h \
print.c \
proto.h \
ps.c \
ps.h \
+ register.c \
+ register.h \
resolv.c \
resolv.h \
smb.h \
- summary.c \
- summary.h \
timestamp.h \
util.c \
util.h \
xdlc.c \
xdlc.h
+ethereal_SOURCES = \
+ $(DISSECTOR_SOURCES) \
+ $(ETHEREAL_COMMON_SOURCES) \
+ capture.c \
+ capture.h \
+ colors.c \
+ colors.h \
+ file.c \
+ file.h \
+ globals.h \
+ menu.h \
+ simple_dialog.h \
+ summary.c \
+ summary.h \
+ ui_util.h
+
EXTRA_ethereal_SOURCES = \
dfilter-grammar.c \
dfilter-grammar.h \
dfilter-scanner.c \
- packet-snmp.c \
snprintf.c \
snprintf.h \
snprintf-imp.h \
strerror.h \
strncasecmp.c \
mkstemp.c \
- inet_aton.c
+ mkstemp.h \
+ inet_aton.c \
+ inet_pton.c \
+ inet_ntop.c
+
+# Optional objects that I know how to build. These will be
+# linked into the ethereal executable.
+# They will also be linked into the tethereal executable; if this
+# list ever grows to include something that can't be linked with
+# tethereal, or if tethereal needs something that ethereal doesn't,
+# we should probably split this into stuff needed both
+# by ethereal and tethereal and stuff needed only by one or the
+# other.
+ethereal_optional_objects = @SNPRINTF_O@ @STRERROR_O@ @STRNCASECMP_O@ @MKSTEMP_O@ \
+ @INET_ATON_O@ @INET_PTON_O@ @INET_NTOP_O@
+
+# Additional libs that I know how to build. These will be
+# linked into the ethereal executable.
+ethereal_additional_libs = wiretap/libwiretap.a gtk/libui.a
+
+# This is the automake dependency variable for the executable
+ethereal_DEPENDENCIES = \
+ $(ethereal_optional_objects) \
+ $(ethereal_additional_libs) \
+ plugins/gryphon/gryphon.la
+
+# This automake variable adds to the link-line for the executable.
+#
+# Note that Ethereal doesn't have to be linked with @GLIB_LIBS@, as
+# they are included in @GTK_LIBS@, and doesn't have to be linked with
+# @SOCKET_LIBS@ or @NSL_LIBS@, as those should also be included in
+# @GTK_LIBS@ (as those are also needed for X applications, and GTK+
+# applications are X applications).
+ethereal_LDADD = \
+ $(ethereal_optional_objects) \
+ $(ethereal_additional_libs) \
+ @SNMP_LIBS@ \
+ "-dlopen" self \
+ "-dlopen" plugins/gryphon/gryphon.la @PCAP_LIBS@ @GTK_LIBS@
+
+ethereal_LDFLAGS = -export-dynamic
+
+tethereal_SOURCES = \
+ $(DISSECTOR_SOURCES) \
+ $(ETHEREAL_COMMON_SOURCES) \
+ tethereal.c
+
+# Additional libs that I know how to build. These will be
+# linked into the tethereal executable.
+tethereal_additional_libs = wiretap/libwiretap.a
+
+# This is the automake dependency variable for the executable
+tethereal_DEPENDENCIES = \
+ $(ethereal_optional_objects) \
+ $(tethereal_additional_libs) \
+ plugins/gryphon/gryphon.la
+
+# This automake variable adds to the link-line for the executable
+tethereal_LDADD = wiretap/libwiretap.a \
+ $(ethereal_optional_objects) \
+ $(tethereal_additional_libs) \
+ @SNMP_LIBS@ \
+ "-dlopen" self \
+ "-dlopen" plugins/gryphon/gryphon.la @GLIB_LIBS@ -lm \
+ @PCAP_LIBS@ @SOCKET_LIBS@ @NSL_LIBS@
+
+tethereal_LDFLAGS = -export-dynamic
+
+editcap_SOURCES = editcap.c
-ethereal_DEPENDENCIES = @SNMP_O@ @SNPRINTF_O@ @STRERROR_O@ \
-@STRNCASECMP_O@ @MKSTEMP_O@ @INET_ATON_O@ wiretap/libwiretap.a gtk/libui.a
-ethereal_LDADD = @SNMP_O@ @SNPRINTF_O@ @STRERROR_O@ \
-@STRNCASECMP_O@ @MKSTEMP_O@ @INET_ATON_O@ wiretap/libwiretap.a gtk/libui.a \
-@SNMP_A@
+# This is the automake dependency variable for the executable
+editcap_DEPENDENCIES = wiretap/libwiretap.a
+
+# This automake variable adds to the link-line for the executable
+editcap_LDADD = wiretap/libwiretap.a @GLIB_LIBS@
+
+#
+# Build "register.c", which contains a function "register_all_protocols()"
+# that calls the register routines for all protocols.
+#
+# We do this by grepping through sources. If that turns out to be too slow,
+# maybe we could just require every .o file to have an register routine
+# of a given name (packet-aarp.o -> proto_register_aarp, etc.).
+#
+# Formatting conventions: The name of the proto_register_* routines must
+# start in column zero, or must be preceded only by "void " starting in
+# column zero, and must not be inside #if.
+#
+# We assume that all dissector routines are in "packet-XXX.c" files,
+# or in "packet.c".
+#
+# For some unknown reason, having a big "for" loop in the Makefile
+# to scan all the "packet-XXX.c" files doesn't work with some "make"s;
+# they seem to pass only the first few names in the list to the shell,
+# for some reason.
+#
+# Therefore, we have a script to generate the "register.c" file.
+#
+# The first argument is the directory in which the source files live.
+# All subsequent arguments are the files to scan.
+#
+register.c: packet.c $(DISSECTOR_SOURCES)
+ @echo Making register.c
+ @$(srcdir)/make-reg-dotc $(srcdir) packet.c $(DISSECTOR_SOURCES)
ps.c: print.ps rdps
./rdps $(srcdir)/print.ps ps.c
$(LINK) -o randpkt randpkt.o wiretap/libwiretap.a `glib-config --libs` -lz
DISTCLEANFILES = \
+ register.c \
rdps \
ps.c \
*~
doc/Makefile.in \
doc/Makefile.am \
doc/dfilter2pod.in \
+ doc/editcap.pod \
doc/ethereal.pod.template \
+ doc/proto_tree \
doc/randpkt.txt \
+ doc/tethereal.pod.template \
+ editcap.c \
ethereal.spec.in \
+ image/ethereal48x48-trans.png \
+ image/ethereal48x48.png \
image/icon-excl.xpm \
image/icon-ethereal.xpm \
+ INSTALL.configure \
Makefile.nmake \
+ make-reg-dotc \
manuf \
print.ps \
+ README.aix \
+ README.hpux \
README.irix \
README.linux \
README.tru64 \
+ README.vmware \
README.win32 \
randpkt.c \
- rdps.c
+ rdps.c \
+ TODO
-SUBDIRS = wiretap gtk @ethereal_SUBDIRS@
+#
+# Currently register.c can be included in the distribution because
+# we always build all protocol dissectors. We used to have to check
+# whether or not to build the snmp dissector. If we again need to
+# variably build something, making register.c non-portable, uncomment
+# the dist-hook line below.
+#
+# Oh, yuk. We don't want to include "register.c" in the distribution, as
+# its contents depend on the configuration, and therefore we want it
+# to be built when the first "make" is done; however, Automake insists
+# on putting *all* source into the distribution.
+#
+# We work around this by having a "dist-hook" rule that deletes
+# "register.c", so that "dist" won't pick it up.
+#
+#dist-hook:
+# @rm -f $(distdir)/register.c
+
+SUBDIRS = wiretap gtk plugins @ethereal_SUBDIRS@
ethereal.1: ethereal doc/ethereal.pod.template
(cd doc ; \
$(MAKE) ../ethereal.1 )
+tethereal.1: tethereal doc/tethereal.pod.template
+ (cd doc ; \
+ $(MAKE) ../tethereal.1 )
+
+editcap.1: doc/editcap.pod
+ (cd doc ; \
+ $(MAKE) ../editcap.1 )
+
dfilter-scanner.c : dfilter-scanner.l
$(LEX) -Pdfilter_ -t $(srcdir)/dfilter-scanner.l > dfilter-scanner.c
+
+libtool: $(LIBTOOL_DEPS)
+ $(SHELL) ./config.status --recheck