Fix the wireless settings button for AirPCap devices in the
[obnox/wireshark/wip.git] / gtk / Makefile.nmake
index 3a52de789de66bdf978531b79d13b59c7ec8525f..a47340254c23fe5c66e4507b371e40e94d554d6a 100644 (file)
-## Makefile for building ethereal.exe with Microsoft C and nmake
+## Makefile for building wireshark.exe with Microsoft C and nmake
 ## Use: $(MAKE) /$(MAKEFLAGS) -f makefile.nmake
 #
-# $Id: Makefile.nmake,v 1.77 2004/06/25 07:10:54 jmayer Exp $
+# $Id$
 
 include ..\config.nmake
+include ..\Makefile.nmake.inc
 
 ############### no need to modify below this line #########
 
-CFLAGS=-DHAVE_CONFIG_H /I.. /I../wiretap $(GTK_CFLAGS) \
+# We use GENERATED_CFLAGS to get around flex's non-LLP64-compliant output
+GENERATED_CFLAGS=\
+       $(STANDARD_CFLAGS) \
+       -D_NEED_VAR_IMPORT_ /Zm800 \
+       /I.. /I../wiretap $(GTK_CFLAGS) $(GNUTLS_CFLAGS) \
        /I$(PCAP_DIR)\WPCAP\LIBPCAP /I$(PCAP_DIR)\WPCAP\LIBPCAP\bpf \
        /I$(PCAP_DIR)\WPCAP\LIBPCAP\lbl \
-       /I$(PCAP_DIR)\include /I$(NET_SNMP_DIR)\include \
-       /I$(NET_SNMP_DIR)\win32 /Zm800 -D_U_="" -D_NEED_VAR_IMPORT_ $(LOCAL_CFLAGS)
+       /I$(PCAP_DIR)\include $(AIRPCAP_CFLAGS) \
+       $(PORTAUDIO_CFLAGS) \
+       $(HHC_CFLAGS)
 
-CVARSDLL=-DWIN32 -DNULL=0 -D_MT -D_DLL
+CFLAGS=$(WARNINGS_ARE_ERRORS) $(GENERATED_CFLAGS)
 
 .c.obj::
-   $(CC) $(CVARSDLL) $(CFLAGS) -Fd.\ -c $<
+       $(CC) $(CVARSDLL) $(CFLAGS) $(WSUG_CFLAGS) -Fd.\ -c $<
 
 include Makefile.common
 
 
 # if you add files here, be sure to include them also in Makefile.am EXTRA_DIST
-ETHEREAL_WIN32_GTK_SRC = \
-       $(ETHEREAL_GTK_SRC) \
-       print_mswin.c
+WIRESHARK_GTK_SRC = \
+       $(WIRESHARK_GTK_SRC) \
+       $(GENERATED_C_FILES) \
+       capture_if_details_dlg_win32.c \
+       gtkvumeter.c
+
+PORT_AUDIO_SRC = \
+!IFDEF PORTAUDIO_DIR
+!IF "$(PORTAUDIO_VERSION)" == "18"
+       pa_lib.c \
+!ELSE
+       pa_allocation.c \
+       pa_converters.c \
+       pa_cpuload.c \
+       pa_dither.c \
+       pa_front.c \
+       pa_process.c \
+       pa_skeleton.c \
+       pa_stream.c \
+       pa_trace.c \
+       pa_win_util.c \
+       pa_win_hostapis.c \
+       pa_x86_plain_converters.c \
+       pa_win_waveformat.c \
+!ENDIF
+       pa_win_wmme.c
+!ENDIF
+
+WIRESHARK_TAP_OBJECTS = $(WIRESHARK_TAP_SRC:.c=.obj)
+
+
+WIRESHARK_GTK_OBJECTS = \
+       $(WIRESHARK_GTK_SRC:.c=.obj) \
+       $(DIRTY_GENERATED_C_FILES:.c=.obj) \
+       $(PORT_AUDIO_SRC:.c=.obj)
+
+libui.lib      : ..\config.h $(WIRESHARK_GTK_OBJECTS) $(WIRESHARK_TAP_OBJECTS)
+       link /lib /out:libui.lib $(WIRESHARK_GTK_OBJECTS) $(WIRESHARK_TAP_OBJECTS) winmm.lib
+
+# 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
+wireshark-tap-register.c: $(WIRESHARK_TAP_SRC) ../tools/make-tap-reg.py
+       @echo Making wireshark-tap-register.c (using python)
+       @$(PYTHON) "../tools/make-tap-reg.py" . taps $(WIRESHARK_TAP_SRC)
+!ELSE
+wireshark-tap-register.c: $(WIRESHARK_TAP_SRC) ../tools/make-tapreg-dotc Makefile.common
+       @echo Making wireshark-tap-register.c
+       @$(SH) ../tools/make-tapreg-dotc wireshark-tap-register.c . $(WIRESHARK_TAP_SRC)
+!ENDIF
+
+RUNLEX=..\tools\runlex.sh
+
+text_import_scanner.h: text_import_scanner.c
+text_import_scanner_lex.h: text_import_scanner.c
+text_import_scanner.obj : text_import_scanner.c
+       $(CC) $(CVARSDLL) $(GENERATED_CFLAGS) $(WSUG_CFLAGS) -Fd.\ -c $?
+
+!IF "$(PORTAUDIO_VERSION)" == "18"
+pa_lib.obj: $(PORTAUDIO_DIR)\pa_common\pa_lib.c
+       $(CC) -c $(LOCAL_CFLAGS) $?
 
+pa_win_wmme.obj: $(PORTAUDIO_DIR)\pa_win_wmme\pa_win_wmme.c
+       $(CC) -c $(LOCAL_CFLAGS) $(PORTAUDIO_CFLAGS) $?
+!ELSE
+pa_front.obj: $(PORTAUDIO_DIR)\src\common\pa_front.c
+       $(CC) -c $(LOCAL_CFLAGS) $(PORTAUDIO_CFLAGS) $?
 
-ETHEREAL_TAP_OBJECTS = $(ETHEREAL_TAP_SRC:.c=.obj)
+pa_allocation.obj: $(PORTAUDIO_DIR)\src\common\pa_allocation.c
+       $(CC) -c $(LOCAL_CFLAGS) $(PORTAUDIO_CFLAGS) $?
 
+pa_converters.obj: $(PORTAUDIO_DIR)\src\common\pa_converters.c
+       $(CC) -c $(LOCAL_CFLAGS) $(PORTAUDIO_CFLAGS) $?
 
-ETHEREAL_WIN32_GTK_OBJECTS = $(ETHEREAL_WIN32_GTK_SRC:.c=.obj)
-       
+pa_cpuload.obj: $(PORTAUDIO_DIR)\src\common\pa_cpuload.c
+       $(CC) -c $(LOCAL_CFLAGS) $(PORTAUDIO_CFLAGS) $?
 
-libui.lib      : ..\config.h $(ETHEREAL_WIN32_GTK_OBJECTS) $(ETHEREAL_TAP_OBJECTS)
-       lib /out:libui.lib $(ETHEREAL_WIN32_GTK_OBJECTS) $(ETHEREAL_TAP_OBJECTS)
+pa_dither.obj: $(PORTAUDIO_DIR)\src\common\pa_dither.c
+       $(CC) -c $(LOCAL_CFLAGS) $(PORTAUDIO_CFLAGS) $?
 
-ethereal-tap-register.c: $(ETHEREAL_TAP_SRC) ../make-tapreg-dotc Makefile.common
-       @echo Making ethereal-tap-register.c
-       @$(SH) ../make-tapreg-dotc ethereal-tap-register.c . $(ETHEREAL_TAP_SRC)
+pa_process.obj: $(PORTAUDIO_DIR)\src\common\pa_process.c
+       $(CC) -c $(LOCAL_CFLAGS) $(PORTAUDIO_CFLAGS) $?
 
+pa_skeleton.obj: $(PORTAUDIO_DIR)\src\common\pa_skeleton.c
+       $(CC) -c $(LOCAL_CFLAGS) $(PORTAUDIO_CFLAGS) $?
+
+pa_stream.obj: $(PORTAUDIO_DIR)\src\common\pa_stream.c
+       $(CC) -c $(LOCAL_CFLAGS) $(PORTAUDIO_CFLAGS) $?
+
+pa_trace.obj: $(PORTAUDIO_DIR)\src\common\pa_trace.c
+       $(CC) -c $(LOCAL_CFLAGS) $(PORTAUDIO_CFLAGS) $?
+
+pa_win_wmme.obj: $(PORTAUDIO_DIR)\src\hostapi\wmme\pa_win_wmme.c
+       $(CC) -c $(LOCAL_CFLAGS) $(PORTAUDIO_CFLAGS) $?
+
+pa_win_util.obj: $(PORTAUDIO_DIR)\src\os\win\pa_win_util.c
+       $(CC) -c $(LOCAL_CFLAGS) $(PORTAUDIO_CFLAGS) $?
+
+pa_win_hostapis.obj: $(PORTAUDIO_DIR)\src\os\win\pa_win_hostapis.c
+       $(CC) -c $(LOCAL_CFLAGS) $(PORTAUDIO_CFLAGS) $?
+
+pa_x86_plain_converters.obj: $(PORTAUDIO_DIR)\src\os\win\pa_x86_plain_converters.c
+       $(CC) -c $(LOCAL_CFLAGS) $(PORTAUDIO_CFLAGS) $?
+
+pa_win_waveformat.obj: $(PORTAUDIO_DIR)\src\os\win\pa_win_waveformat.c
+       $(CC) -c $(LOCAL_CFLAGS) $(PORTAUDIO_CFLAGS) $?
+
+!ENDIF
 
 clean:
-       rm -f $(ETHEREAL_WIN32_GTK_OBJECTS) $(ETHEREAL_TAP_OBJECTS) libui.lib $(PDB_FILE) doxygen.cfg
+       rm -f $(WIRESHARK_GTK_OBJECTS) $(WIRESHARK_TAP_OBJECTS) libui.lib *.pdb doxygen.cfg html/*.* wireshark-tap-register-cache.pkl
+       if exist html rmdir html
 
 distclean: clean
-       rm -f ethereal-tap-register.c
+
+maintainer-clean: distclean
+       rm -f $(GENERATED_FILES)
 
 # convert doxygen.cfg.in to doxygen.cfg with stamped version info
 doxygen.cfg: ..\config.nmake doxygen.cfg.in
@@ -59,7 +166,7 @@ doxygen-run:
        $(DOXYGEN) doxygen.cfg
 !ENDIF
 
-# MS html help conpiler hhc returns 1 on success, but as nmake expects 0 it would stop here.
+# MS html help compiler hhc returns 1 on success, but as nmake expects 0 it would stop here.
 # the prepended -1 will raise the accepted error levels of nmake, so it will continue
 doxygen.chm:
 !IFDEF HHC
@@ -68,3 +175,14 @@ doxygen.chm:
 
 doxygen: doxygen.cfg doxygen-run doxygen.chm
 
+checkapi: checkapi-base checkapi-todo
+
+checkapi-base:
+       $(PERL) ../tools/checkAPIs.pl -g deprecated-gtk \
+       $(WIRESHARK_GTK_SRC) \
+       $(WIRESHARK_TAP_SRC)
+
+checkapi-todo:
+       $(PERL) ../tools/checkAPIs.pl -M -g deprecated-gtk-todo \
+       $(WIRESHARK_GTK_SRC) \
+       $(WIRESHARK_TAP_SRC)