wireshark/plugins/mate/Makefile.nmake

167 lines
5.2 KiB
Makefile
Raw Normal View History

# Makefile.nmake
# nmake file for mate plugin
#
# $Id$
#
include ..\..\config.nmake
include ..\..\Makefile.nmake.inc
include moduleinfo.nmake
include Makefile.common
LEMON=..\..\tools\lemon
# We use GENERATED_CFLAGS to get around flex's non-LLP64-compliant output
GENERATED_CFLAGS=\
$(STANDARD_CFLAGS) \
/I../.. $(GLIB_CFLAGS) /I$(LEMON) \
/I$(PCAP_DIR)\include
CFLAGS=$(WARNINGS_ARE_ERRORS) $(GENERATED_CFLAGS)
.c.obj::
$(CC) $(CFLAGS) -Fd.\ -c $<
LDFLAGS = $(PLUGIN_LDFLAGS)
!IFDEF ENABLE_LIBWIRESHARK
LINK_PLUGIN_WITH=..\..\epan\libwireshark.lib ..\..\wsutil\libwsutil.lib
CFLAGS=/D_NEED_VAR_IMPORT_ $(CFLAGS)
DISSECTOR_OBJECTS = \
$(DISSECTOR_C_FILES:.c=.obj) \
$(DISSECTOR_CPP_FILES:.cpp=.obj)
NODIST_DISSECTOR_OBJECTS = \
$(NODIST_DISSECTOR_C_FILES:.c=.obj) \
$(NODIST_DISSECTOR_CPP_FILES:.cpp=.obj)
SUPPORT_OBJECTS = \
$(SUPPORT_C_FILES:.c=.obj) \
$(SUPPORT_CPP_FILES:.cpp=.obj)
NODIST_SUPPORT_OBJECTS = \
$(NODIST_SUPPORT_C_FILES:.c=.obj) \
$(NODIST_SUPPORT_CPP_FILES:.cpp=.obj)
OBJECTS = \
$(DISSECTOR_OBJECTS) \
$(NODIST_DISSECTOR_OBJECTS) \
$(SUPPORT_OBJECTS) \
$(NODIST_SUPPORT_OBJECTS) \
plugin.obj
RESOURCE=$(PLUGIN_NAME).res
all: $(PLUGIN_NAME).dll
$(PLUGIN_NAME).rc : moduleinfo.nmake
sed -e s/@PLUGIN_NAME@/$(PLUGIN_NAME)/ \
-e s/@RC_MODULE_VERSION@/$(RC_MODULE_VERSION)/ \
-e s/@RC_VERSION@/$(RC_VERSION)/ \
-e s/@MODULE_VERSION@/$(MODULE_VERSION)/ \
-e s/@PACKAGE@/$(PACKAGE)/ \
-e s/@VERSION@/$(VERSION)/ \
-e s/@MSVC_VARIANT@/$(MSVC_VARIANT)/ \
< plugin.rc.in > $@
$(PLUGIN_NAME).dll $(PLUGIN_NAME).exp $(PLUGIN_NAME).lib : $(OBJECTS) $(LINK_PLUGIN_WITH) $(RESOURCE)
link -dll /out:$(PLUGIN_NAME).dll $(LDFLAGS) $(OBJECTS) $(LINK_PLUGIN_WITH) \
$(GLIB_LIBS) $(RESOURCE)
#
# Build plugin.c, which contains the plugin version[] string, a
# function plugin_register() that calls the register routines for all
# protocols, and a function plugin_reg_handoff() that calls the handoff
# registration routines for all protocols.
#
# We do this by scanning 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 an
# proto_reg_handoff_* routines must start in column zero, or must be
# preceded only by "void " starting in column zero, and must not be
# inside #if.
#
# DISSECTOR_SRC_FILES and NODIST_DISSECTOR_SRC_FILES are assumed to have
# all the files that need to be scanned.
#
# For some unknown reason, having a big "for" loop in the Makefile
# to scan all the 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 plugin.c file.
# The shell script runs slowly, as multiple greps and seds are run
# for each input file; this is especially slow on Windows. Therefore,
# if Python is present (as indicated by PYTHON being defined), we run
# a faster Python script to do that work instead.
#
# The first argument is the directory in which the source files live.
# The second argument is "plugin", to indicate that we should build
# a plugin.c file for a plugin.
# All subsequent arguments are the files to scan.
#
!IFDEF PYTHON
plugin.c: $(DISSECTOR_SRC_FILES) moduleinfo.h Makefile.common ../../tools/make-dissector-reg.py
@echo Making plugin.c (using python)
@$(PYTHON) "../../tools/make-dissector-reg.py" . plugin $(DISSECTOR_SRC_FILES) $(NODIST_DISSECTOR_SRC_FILES)
!ELSE
plugin.c: $(DISSECTOR_SRC_FILES) moduleinfo.h Makefile.common ../../tools/make-dissector-reg
@echo Making plugin.c (using sh)
@$(SH) ../../tools/make-dissector-reg . plugin $(DISSECTOR_SRC_FILES) $(NODIST_DISSECTOR_SRC_FILES)
!ENDIF
!ENDIF
clean:
rm -f $(OBJECTS) $(RESOURCE) plugin.c *.pdb *.sbr \
$(PLUGIN_NAME).dll $(PLUGIN_NAME).dll.manifest $(PLUGIN_NAME).lib \
$(PLUGIN_NAME).exp $(PLUGIN_NAME).rc
# We remove the generated files with "distclean" because files generated
# by Flex need different #includes for UN*X and Windows (UN*X versions of
# Flex make it include <unistd.h>, but that's a UN*X-only header), so if
# you're going to build from source, you need to re-generate the files
# from the distribution that were generated by Flex.
#
# This might not be necessary for files generated by other tools not
# distributed with Wireshark, but we handle them the same for now.
#
distclean: clean
rm -f $(GENERATED_SRC_FILES) \
$(GENERATED_HEADER_FILES) \
$(NODIST_GENERATED_SRC_FILES) \
$(NODIST_GENERATED_HEADER_FILES) \
mate_grammar.out
maintainer-clean: distclean
RUNLEX = ..\..\tools\runlex.sh
#
# In order to generate mate_parser_lex.h, we need to run Flex on
# mate_parser.l; that's done by generating mate_parser.c.
#
mate_parser_lex.h : mate_parser.c
mate_parser.obj : mate_grammar.h
mate_parser.obj : mate_parser.c
$(CC) $(GENERATED_CFLAGS) -Fd.\ -c mate_parser.c
mate_grammar.h : mate_grammar.c
mate_grammar.c : mate_grammar.lemon $(LEMON)\lemon.exe
$(LEMON)\lemon.exe t=$(LEMON)\lempar.c mate_grammar.lemon
$(LEMON)\lemon.exe:
cd ../../tools
$(MAKE) /$(MAKEFLAGS) -f makefile.nmake lemon
cd ../plugins/mate
checkapi:
$(PERL) ../../tools/checkAPIs.pl -g abort -g termoutput -build \
$(SRC_FILES) $(NODIST_SRC_FILES) $(HEADER_FILES)