2 # Automake file for MATE Wireshark plugin
6 # Wireshark - Network traffic analyzer
7 # By Gerald Combs <gerald@wireshark.org>
8 # Copyright 1998 Gerald Combs
10 # This program is free software; you can redistribute it and/or
11 # modify it under the terms of the GNU General Public License
12 # as published by the Free Software Foundation; either version 2
13 # of the License, or (at your option) any later version.
15 # This program is distributed in the hope that it will be useful,
16 # but WITHOUT ANY WARRANTY; without even the implied warranty of
17 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 # GNU General Public License for more details.
20 # You should have received a copy of the GNU General Public License
21 # along with this program; if not, write to the Free Software
22 # Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
25 include $(top_srcdir)/Makefile.am.inc
27 INCLUDES = -I$(top_srcdir)
29 include Makefile.common
31 plugindir = @plugindir@
33 plugin_LTLIBRARIES = mate.la
39 $(DISSECTOR_SUPPORT_SRC) \
42 mate_la_LDFLAGS = -module -avoid-version
43 mate_la_LIBADD = @PLUGIN_LIBS@
45 # Libs must be cleared, or else libtool won't create a shared module.
46 # If your module needs to be linked against any particular libraries,
51 # Build plugin.c, which contains the plugin version[] string, a
52 # function plugin_register() that calls the register routines for all
53 # protocols, and a function plugin_reg_handoff() that calls the handoff
54 # registration routines for all protocols.
56 # We do this by scanning sources. If that turns out to be too slow,
57 # maybe we could just require every .o file to have an register routine
58 # of a given name (packet-aarp.o -> proto_register_aarp, etc.).
60 # Formatting conventions: The name of the proto_register_* routines an
61 # proto_reg_handoff_* routines must start in column zero, or must be
62 # preceded only by "void " starting in column zero, and must not be
65 # DISSECTOR_SRC is assumed to have all the files that need to be scanned.
67 # For some unknown reason, having a big "for" loop in the Makefile
68 # to scan all the files doesn't work with some "make"s; they seem to
69 # pass only the first few names in the list to the shell, for some
72 # Therefore, we have a script to generate the plugin.c file.
73 # The shell script runs slowly, as multiple greps and seds are run
74 # for each input file; this is especially slow on Windows. Therefore,
75 # if Python is present (as indicated by PYTHON being defined), we run
76 # a faster Python script to do that work instead.
78 # The first argument is the directory in which the source files live.
79 # The second argument is "plugin", to indicate that we should build
80 # a plugin.c file for a plugin.
81 # All subsequent arguments are the files to scan.
83 plugin.c: $(DISSECTOR_SRC) $(top_srcdir)/tools/make-dissector-reg \
84 $(top_srcdir)/tools/make-dissector-reg.py
85 @if test -n "$(PYTHON)"; then \
86 echo Making plugin.c with python ; \
87 $(PYTHON) $(top_srcdir)/tools/make-dissector-reg.py $(srcdir) \
88 plugin $(DISSECTOR_SRC) ; \
90 echo Making plugin.c with shell script ; \
91 $(top_srcdir)/tools/make-dissector-reg $(srcdir) \
92 $(plugin_src) plugin $(DISSECTOR_SRC) ; \
96 # Currently plugin.c can be included in the distribution because
97 # we always build all protocol dissectors. We used to have to check
98 # whether or not to build the snmp dissector. If we again need to
99 # variably build something, making plugin.c non-portable, uncomment
100 # the dist-hook line below.
102 # Oh, yuk. We don't want to include "plugin.c" in the distribution, as
103 # its contents depend on the configuration, and therefore we want it
104 # to be built when the first "make" is done; however, Automake insists
105 # on putting *all* source into the distribution.
107 # We work around this by having a "dist-hook" rule that deletes
108 # "plugin.c", so that "dist" won't pick it up.
111 # @rm -f $(distdir)/plugin.c
122 MAINTAINERCLEANFILES = \
136 RUNLEX = $(top_srcdir)/tools/runlex.sh
138 mate_parser_lex.h : mate_parser.c
140 LEMON = $(top_builddir)/tools/lemon
142 mate_grammar.h : mate_grammar.c
143 mate_grammar.c : mate_grammar.lemon mate.h mate_util.h $(LEMON)/lemon$(EXEEXT)
144 $(LEMON)/lemon$(EXEEXT) t=$(srcdir)/$(LEMON)/lempar.c $(srcdir)/mate_grammar.lemon || \
145 (rm -f grammar.c grammar.h ; false)
148 $(PERL) $(top_srcdir)/tools/checkAPIs.pl -g abort -g termoutput $(DISSECTOR_SRC) $(DISSECTOR_INCLUDES)