105 lines
3.5 KiB
Makefile
105 lines
3.5 KiB
Makefile
# Makefile.am
|
|
OCT_INC = $(OCT_PATH)/software/include
|
|
|
|
INCLUDES = -I$(top_srcdir) -I$(includedir) -I$(OCT_INC) -I$(OCT_INC)/octvc1 -I$(OCT_INC)/vocallo -I$(OCT_INC)/octpkt
|
|
|
|
include Makefile.common
|
|
|
|
AM_CFLAGS=-DTGT_VERSION=$(TGT_VERSION) -DMODULE_VERSION=$(MODULE_VERSION)
|
|
|
|
plugindir = @plugindir@
|
|
|
|
plugin_LTLIBRARIES = octvc1_ws.la
|
|
octvc1_ws_la_SOURCES = \
|
|
source/plugin.c \
|
|
source/octvc1_msg_ctrl.c \
|
|
source/octvc1_plugin.c \
|
|
source/octvc1_msg_event.c \
|
|
source/ws_util.c \
|
|
include/plugin_info.h \
|
|
$(DISSECTOR_SRC) \
|
|
$(DISSECTOR_INCLUDES)
|
|
|
|
octvc1_ws_la_LDFLAGS = -module -avoid-version
|
|
octvc1_ws_la_LIBADD = @PLUGIN_LIBS@
|
|
|
|
# Libs must be cleared, or else libtool won't create a shared module.
|
|
# If your module needs to be linked against any particular libraries,
|
|
# add them here.
|
|
LIBS =
|
|
|
|
#
|
|
# 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 is 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.
|
|
#
|
|
plugin.c: $(DISSECTOR_SRC) $(top_srcdir)/tools/make-dissector-reg \
|
|
$(top_srcdir)/tools/make-dissector-reg.py
|
|
@if test -n "$(PYTHON)"; then \
|
|
echo Making plugin.c with python ; \
|
|
$(PYTHON) $(top_srcdir)/tools/make-dissector-reg.py $(srcdir) \
|
|
plugin $(DISSECTOR_SRC) ; \
|
|
else \
|
|
echo Making plugin.c with shell script ; \
|
|
$(top_srcdir)/tools/make-dissector-reg $(srcdir) \
|
|
$(plugin_src) plugin $(DISSECTOR_SRC) ; \
|
|
fi
|
|
|
|
#
|
|
# Currently plugin.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 plugin.c non-portable, uncomment
|
|
# the dist-hook line below.
|
|
#
|
|
# Oh, yuk. We don't want to include "plugin.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
|
|
# "plugin.c", so that "dist" won't pick it up.
|
|
#
|
|
#dist-hook:
|
|
# @rm -f $(distdir)/plugin.c
|
|
|
|
CLEANFILES = \
|
|
octvc1_ws \
|
|
*~
|
|
|
|
MAINTAINERCLEANFILES = \
|
|
Makefile.in \
|
|
plugin.c
|
|
|
|
EXTRA_DIST = \
|
|
Makefile.common \
|
|
Makefile.nmake
|