Update plugin to the current plugin design.
[obnox/wireshark/wip.git] / plugins / mate / Makefile.am
1 # Makefile.am
2 # Automake file for MATE Wireshark plugin
3 #
4 # $Id$
5 #
6 # Wireshark - Network traffic analyzer
7 # By Gerald Combs <gerald@wireshark.org>
8 # Copyright 1998 Gerald Combs
9
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.
14
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.
19
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.
23 #
24
25 INCLUDES = -I$(top_srcdir)
26
27 include Makefile.common
28
29 plugindir = @plugindir@
30
31 plugin_LTLIBRARIES = mate.la
32
33 mate_la_SOURCES = \
34         plugin.c        \
35         moduleinfo.h    \
36         $(DISSECTOR_SRC)        \
37         $(DISSECTOR_SUPPORT_SRC)        \
38         $(DISSECTOR_INCLUDES)
39
40 #       mate.h          \
41 #       mate_grammar.c  \
42 #       mate_grammar.h  \
43 #       mate_parser.c   \
44 #       mate_runtime.c  \
45 #       mate_setup.c    \
46 #       mate_util.c     \
47 #       mate_util.h     \
48 #       moduleinfo.h    \
49 #       packet-mate.c
50
51 mate_la_LDFLAGS = -module -avoid-version
52 mate_la_LIBADD = @PLUGIN_LIBS@
53
54 # Libs must be cleared, or else libtool won't create a shared module.
55 # If your module needs to be linked against any particular libraries,
56 # add them here.
57 LIBS =
58
59 #
60 # Build plugin.c, which contains the plugin version[] string, a
61 # function plugin_register() that calls the register routines for all
62 # protocols, and a function plugin_reg_handoff() that calls the handoff
63 # registration routines for all protocols.
64 #
65 # We do this by scanning sources.  If that turns out to be too slow,
66 # maybe we could just require every .o file to have an register routine
67 # of a given name (packet-aarp.o -> proto_register_aarp, etc.).
68 #
69 # Formatting conventions:  The name of the proto_register_* routines an
70 # proto_reg_handoff_* routines must start in column zero, or must be
71 # preceded only by "void " starting in column zero, and must not be
72 # inside #if.
73 #
74 # DISSECTOR_SRC is assumed to have all the files that need to be scanned.
75 #
76 # For some unknown reason, having a big "for" loop in the Makefile
77 # to scan all the files doesn't work with some "make"s; they seem to
78 # pass only the first few names in the list to the shell, for some
79 # reason.
80 #
81 # Therefore, we have a script to generate the plugin.c file.
82 # The shell script runs slowly, as multiple greps and seds are run
83 # for each input file; this is especially slow on Windows.  Therefore,
84 # if Python is present (as indicated by PYTHON being defined), we run
85 # a faster Python script to do that work instead.
86 #
87 # The first argument is the directory in which the source files live.
88 # The second argument is "plugin", to indicate that we should build
89 # a plugin.c file for a plugin.
90 # All subsequent arguments are the files to scan.
91 #
92 plugin.c: $(DISSECTOR_SRC) $(top_srcdir)/tools/make-dissector-reg \
93     $(top_srcdir)/tools/make-dissector-reg.py
94         @if test -n $(PYTHON); then \
95                 echo Making plugin.c with python ; \
96                 $(PYTHON) $(top_srcdir)/tools/make-dissector-reg.py $(srcdir) \
97                     plugin $(DISSECTOR_SRC) ; \
98         else \
99                 echo Making plugin.c with shell script ; \
100                 $(top_srcdir)/tools/make-dissector-reg $(srcdir) \
101                     $(plugin_src) plugin $(DISSECTOR_SRC) ; \
102         fi
103
104 #
105 # Currently plugin.c can be included in the distribution because
106 # we always build all protocol dissectors. We used to have to check
107 # whether or not to build the snmp dissector. If we again need to
108 # variably build something, making plugin.c non-portable, uncomment
109 # the dist-hook line below.
110 #
111 # Oh, yuk.  We don't want to include "plugin.c" in the distribution, as
112 # its contents depend on the configuration, and therefore we want it
113 # to be built when the first "make" is done; however, Automake insists
114 # on putting *all* source into the distribution.
115 #
116 # We work around this by having a "dist-hook" rule that deletes
117 # "plugin.c", so that "dist" won't pick it up.
118 #
119 #dist-hook:
120 #       @rm -f $(distdir)/plugin.c
121
122 CLEANFILES = \
123         mate \
124         *~
125
126 DISTCLEANFILES = \
127         mate_grammar.out        \
128         mate_grammar.c          \
129         mate_grammar.h
130
131 MAINTAINERCLEANFILES = \
132         Makefile.in             \
133         mate_grammar.c          \
134         mate_grammar.h          \
135         mate_grammar.out        \
136         mate_parser.c           \
137         plugin.c
138
139 EXTRA_DIST = \
140         mate_grammar.lemon      \
141         mate_parser.l   \
142         Makefile.nmake  \
143         Makefile.common \
144         plugin.rc.in
145
146 mate_parser.c : mate_parser.l
147         $(LEX) -Pdf_ -omate_parser.c $(srcdir)/mate_parser.l
148
149 LEMON = ../../tools/lemon
150
151 mate_grammar.h : mate_grammar.c
152 mate_grammar.c : mate_grammar.lemon mate.h mate_util.h $(LEMON)/lemon$(EXEEXT)
153         $(LEMON)/lemon$(EXEEXT) t=$(srcdir)/$(LEMON)/lempar.c $(srcdir)/mate_grammar.lemon || \
154                 (rm -f grammar.c grammar.h ; false)
155