Rename "save_LIBS" to "ethereal_save_LIBS", to reduce the risk of a name
[obnox/wireshark/wip.git] / Makefile.am
index f6b707424a5071953498d2491155db001b77db82..9974fe725cc3f393b0cd938f789fcff7a2835fec 100644 (file)
@@ -1,7 +1,7 @@
 # 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  \
@@ -70,9 +58,12 @@ ethereal_SOURCES = \
        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   \
@@ -81,51 +72,131 @@ ethereal_SOURCES = \
        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        \
@@ -134,22 +205,37 @@ ethereal_SOURCES = \
        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  \
@@ -157,13 +243,110 @@ EXTRA_ethereal_SOURCES = \
        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
@@ -178,6 +361,7 @@ randpkt: randpkt.o wiretap/libwiretap.a
        $(LINK) -o randpkt randpkt.o wiretap/libwiretap.a `glib-config --libs` -lz
 
 DISTCLEANFILES =       \
+       register.c      \
        rdps            \
        ps.c            \
        *~
@@ -187,26 +371,67 @@ EXTRA_DIST = \
        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