If we have pcap_open, call it instead of pcap_open_live, otherwise we might
[obnox/wireshark/wip.git] / Makefile.nmake
index 91d19a10b8626147397439e9e941c2f35c61e928..5de3b97d52c3583531526585c1c1bb7eface25e7 100644 (file)
@@ -8,9 +8,9 @@ include <win32.mak>
 
 ############### no need to modify below this line #########
 
-CC = cl         
+CC = cl
 LINK= link
-        
+
 LDFLAGS = /NOLOGO /INCREMENTAL:no /MACHINE:I386 $(LOCAL_LDFLAGS)
 
 CFLAGS=-WX -DHAVE_CONFIG_H $(LOCAL_CFLAGS) $(GLIB_CFLAGS) /I. /Iwiretap \
@@ -30,6 +30,7 @@ include Makefile.common
 
 wireshark_OBJECTS = $(wireshark_SOURCES:.c=.obj)
 tshark_OBJECTS = $(tshark_SOURCES:.c=.obj)
+rawshark_OBJECTS = $(rawshark_SOURCES:.c=.obj)
 dftest_OBJECTS = $(dftest_SOURCES:.c=.obj)
 dumpcap_OBJECTS = $(dumpcap_SOURCES:.c=.obj)
 randpkt_OBJECTS = $(randpkt_SOURCES:.c=.obj)
@@ -55,7 +56,7 @@ wireshark_LIBS= wiretap\wiretap-$(WTAP_VERSION).lib \
        $(ADNS_LIBS) \
        $(PCRE_LIBS) \
        $(ZLIB_LIBS) \
-       $(GNUTLS_LIBS) 
+       $(GNUTLS_LIBS)
 !ENDIF
 
 tshark_LIBS= wiretap\wiretap-$(WTAP_VERSION).lib \
@@ -75,6 +76,23 @@ tshark_LIBS= wiretap\wiretap-$(WTAP_VERSION).lib \
        $(GNUTLS_LIBS)
 !ENDIF
 
+rawshark_LIBS= wiretap\wiretap-$(WTAP_VERSION).lib \
+       wsock32.lib user32.lib \
+       $(GLIB_LIBS) \
+!IFDEF ENABLE_LIBWIRESHARK
+       epan\libwireshark.lib \
+!ELSE
+       epan\dissectors\dissectors.lib \
+       epan\wireshark.lib \
+       epan\crypt\airpdcap.lib \
+       epan\dfilter\dfilter.lib \
+       epan\ftypes\ftypes.lib \
+       $(ADNS_LIBS) \
+       $(PCRE_LIBS) \
+       $(ZLIB_LIBS) \
+       $(GNUTLS_LIBS)
+!ENDIF
+
 capinfos_LIBS= wiretap\wiretap-$(WTAP_VERSION).lib \
        wsock32.lib user32.lib shell32.lib \
        $(GLIB_LIBS)
@@ -108,23 +126,24 @@ dftest_LIBS=  wiretap\wiretap-$(WTAP_VERSION).lib \
        $(PCRE_LIBS) \
        $(ZLIB_LIBS) \
        $(SMI_LIBS) \
-       $(GNUTLS_LIBS)  
+       $(GNUTLS_LIBS)
 !ENDIF
 
 randpkt_LIBS= wiretap\wiretap-$(WTAP_VERSION).lib \
        user32.lib \
        $(GLIB_LIBS)
 
-EXECUTABLES=wireshark.exe wireshark-gtk2.exe tshark.exe \
+EXECUTABLES=wireshark.exe tshark.exe rawshark.exe \
        capinfos.exe editcap.exe mergecap.exe text2pcap.exe randpkt.exe dumpcap.exe
 
 RESOURCES=image\wireshark.res image\libwireshark.res image\tshark.res \
        image\capinfos.res image\editcap.res image\mergecap.res \
-       image\text2pcap.res image\wiretap.res image\dumpcap.res
+       image\text2pcap.res image\wiretap.res image\dumpcap.res \
+       image\rawshark.res
 
 LIBS_CHECK=_libs_check_
 
-all: $(LIBS_CHECK) config.h tools image codecs $(ZLIB_DLL) wiretap epan $(EXECUTABLES) $(RESOURCES) doc install-deps
+all: $(LIBS_CHECK) config.h tools image codecs $(ADNS_DLL) $(ZLIB_DLL) wiretap epan $(EXECUTABLES) $(RESOURCES) doc install-all
 
 packaging: all
        cd packaging
@@ -133,18 +152,6 @@ packaging: all
        cd ..
        cd ..
 
-separate_packaging: all
-       cd packaging
-       cd nsis
-!IFDEF GTK1_DIR
-       $(MAKE) /$(MAKEFLAGS) -f makefile.nmake GTK1_ONLY="USE"
-!ENDIF
-!IFDEF GTK2_DIR
-       $(MAKE) /$(MAKEFLAGS) -f makefile.nmake GTK2_ONLY="USE"
-!ENDIF
-       cd ..
-       cd ..
-
 packaging_u3: all
        cd packaging
        cd u3
@@ -164,77 +171,52 @@ packaging_papps: all
        cd ..
 
 # use (info-)zip from cygwin to pack things
-packaging_zip1: all
-!IFDEF MSVCR_DLL
-       xcopy "$(MSVCR_DLL)" $(INSTALL1_DIR)
-!ENDIF
-!IFDEF VCREDIST_EXE
-       @echo Including vcredist_x86.exe -- your recipient may need to run it!
-       xcopy "$(VCREDIST_EXE)" $(INSTALL1_DIR)
-!ENDIF
-       rm -f wireshark-gtk1.zip
-       zip -r -9 wireshark-gtk1.zip $(INSTALL1_DIR)/
-
-# use (info-)zip from cygwin to pack things
-packaging_zip2: all
+packaging_zip: all
 !IFDEF MSVCR_DLL
-       xcopy "$(MSVCR_DLL)" $(INSTALL2_DIR)
+       xcopy "$(MSVCR_DLL)" $(INSTALL_DIR)
 !ENDIF
 !IFDEF VCREDIST_EXE
        @echo Including vcredist_x86.exe -- your recipient may need to run it!
-       xcopy "$(VCREDIST_EXE)" $(INSTALL2_DIR)
+       xcopy "$(VCREDIST_EXE)" $(INSTALL_DIR)
 !ENDIF
-       rm -f wireshark-gtk2.zip
-       zip -r -9 wireshark-gtk2.zip $(INSTALL2_DIR)/
-
-packaging_zip: packaging_zip1 packaging_zip2
+       rm -f wireshark.zip
+       zip -r -9 wireshark.zip $(INSTALL_DIR)/
 
 
 $(RESOURCES): image
 
 wiretap\wiretap-$(WTAP_VERSION).lib: image $(ZLIB_DLL) wiretap
 
-!IFNDEF GTK1_DIR
-wireshark.exe  : 
-!ELSE
 wireshark.exe  : $(LIBS_CHECK) config.h svnversion.h $(wireshark_OBJECTS) getopt.obj inet_ntop.obj inet_pton.obj codecs epan gtk image\wireshark.res wiretap\wiretap-$(WTAP_VERSION).lib codecs\codecs.lib gtk\libui.lib plugins
        @echo Linking $@
        $(LINK) @<<
-               /OUT:wireshark.exe $(guiflags) $(guilibsdll) $(LDFLAGS) /LARGEADDRESSAWARE /SUBSYSTEM:windows $(wireshark_LIBS) getopt.obj inet_ntop.obj inet_pton.obj $(GTK1_LIBS) codecs\codecs.lib gtk\libui.lib $(wireshark_OBJECTS) image\wireshark.res
+               /OUT:wireshark.exe $(guiflags) $(guilibsdll) $(LDFLAGS) /LARGEADDRESSAWARE /SUBSYSTEM:windows $(wireshark_LIBS) getopt.obj inet_ntop.obj inet_pton.obj $(GTK_LIBS) codecs\codecs.lib gtk\libui.lib $(wireshark_OBJECTS) image\wireshark.res
 <<
-!IF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20" 
+!IF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20"
        mt.exe -nologo -manifest "wireshark.exe.manifest" -outputresource:wireshark.exe;1
 !ENDIF
-!ENDIF
 
-!IFNDEF GTK2_DIR
-wireshark-gtk2.exe     : 
-!ELSE
-wireshark-gtk2.exe     : $(LIBS_CHECK) config.h svnversion.h $(wireshark_OBJECTS) getopt.obj inet_ntop.obj inet_pton.obj codecs epan gtk2 image\wireshark.res wiretap\wiretap-$(WTAP_VERSION).lib codecs\codecs.lib gtk2.tmp\libui.lib plugins
+tshark.exe     : $(LIBS_CHECK) config.h svnversion.h $(tshark_OBJECTS) getopt.obj inet_ntop.obj epan image\tshark.res wiretap\wiretap-$(WTAP_VERSION).lib plugins
        @echo Linking $@
        $(LINK) @<<
-               /OUT:wireshark-gtk2.exe $(guiflags) $(guilibsdll) $(LDFLAGS) /LARGEADDRESSAWARE /SUBSYSTEM:windows $(wireshark_LIBS) getopt.obj inet_ntop.obj inet_pton.obj $(GTK2_LIBS) codecs\codecs.lib gtk2.tmp\libui.lib $(wireshark_OBJECTS) image\wireshark.res
+               /OUT:tshark.exe $(conflags) $(conlibsdll) $(LDFLAGS) /LARGEADDRESSAWARE /SUBSYSTEM:console $(tshark_LIBS) $(tshark_OBJECTS) getopt.obj inet_ntop.obj image\tshark.res
 <<
-!IF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20" 
-       mt.exe -nologo -manifest "wireshark-gtk2.exe.manifest" -outputresource:wireshark-gtk2.exe;1
-!ENDIF
+!IF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20"
+       mt.exe -nologo -manifest "tshark.exe.manifest" -outputresource:tshark.exe;1
 !ENDIF
 
-tshark.exe     : $(LIBS_CHECK) config.h svnversion.h $(tshark_OBJECTS) getopt.obj inet_ntop.obj epan image\tshark.res wiretap\wiretap-$(WTAP_VERSION).lib plugins
+rawshark.exe   : $(LIBS_CHECK) config.h svnversion.h $(rawshark_OBJECTS) getopt.obj inet_ntop.obj epan image\rawshark.res wiretap\wiretap-$(WTAP_VERSION).lib plugins
        @echo Linking $@
        $(LINK) @<<
-               /OUT:tshark.exe $(conflags) $(conlibsdll) $(LDFLAGS) /LARGEADDRESSAWARE /SUBSYSTEM:console $(tshark_LIBS) $(tshark_OBJECTS) getopt.obj inet_ntop.obj image\tshark.res
+               /OUT:rawshark.exe $(conflags) $(conlibsdll) $(LDFLAGS) /LARGEADDRESSAWARE /SUBSYSTEM:console $(rawshark_LIBS) $(rawshark_OBJECTS) getopt.obj inet_ntop.obj image\rawshark.res
 <<
-!IF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20" 
-       mt.exe -nologo -manifest "tshark.exe.manifest" -outputresource:tshark.exe;1
-!ENDIF
 
 capinfos.exe   : $(LIBS_CHECK) config.h capinfos.obj getopt.obj epan/unicode-utils.obj epan/plugins.obj epan/report_err.obj epan/privileges.obj epan/filesystem.obj wiretap\wiretap-$(WTAP_VERSION).lib image\capinfos.res
        @echo Linking $@
        $(LINK) @<<
                /OUT:capinfos.exe $(conflags) $(conlibsdll) $(LDFLAGS) /SUBSYSTEM:console capinfos.obj getopt.obj epan/unicode-utils.obj epan/plugins.obj epan/report_err.obj epan/privileges.obj epan/filesystem.obj $(capinfos_LIBS) image\capinfos.res
 <<
-!IF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20" 
+!IF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20"
        mt.exe -nologo -manifest "capinfos.exe.manifest" -outputresource:capinfos.exe;1
 !ENDIF
 
@@ -243,7 +225,7 @@ editcap.exe : $(LIBS_CHECK) config.h editcap.obj getopt.obj strptime.obj epan\cr
        $(LINK) @<<
                /OUT:editcap.exe $(conflags) $(conlibsdll) $(LDFLAGS) /SUBSYSTEM:console editcap.obj getopt.obj strptime.obj epan/unicode-utils.obj epan\crypt\crypt-md5.obj epan/plugins.obj epan/report_err.obj epan/privileges.obj epan/filesystem.obj $(editcap_LIBS) image\editcap.res
 <<
-!IF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20" 
+!IF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20"
        mt.exe -nologo -manifest "editcap.exe.manifest" -outputresource:editcap.exe;1
 !ENDIF
 
@@ -252,7 +234,7 @@ mergecap.exe        : $(LIBS_CHECK)  config.h svnversion.h mergecap.obj merge.obj getop
        $(LINK) @<<
                /OUT:mergecap.exe $(conflags) $(conlibsdll) $(LDFLAGS) /SUBSYSTEM:console mergecap.obj merge.obj getopt.obj $(mergecap_LIBS) image\mergecap.res
 <<
-!IF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20" 
+!IF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20"
        mt.exe -nologo -manifest "mergecap.exe.manifest" -outputresource:mergecap.exe;1
 !ENDIF
 
@@ -261,7 +243,7 @@ text2pcap.exe       : $(LIBS_CHECK) config.h text2pcap.obj text2pcap-scanner.obj getop
        $(LINK) @<<
                /OUT:text2pcap.exe $(conflags) $(conlibsdll) $(LDFLAGS) /SUBSYSTEM:console text2pcap.obj text2pcap-scanner.obj getopt.obj $(text2pcap_LIBS) strptime.obj image\text2pcap.res
 <<
-!IF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20" 
+!IF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20"
        mt.exe -nologo -manifest "text2pcap.exe.manifest" -outputresource:text2pcap.exe;1
 !ENDIF
 
@@ -270,7 +252,7 @@ dftest.exe  : $(dftest_OBJECTS) epan
        $(LINK) @<<
                /OUT:dftest.exe $(conflags) $(conlibsdll) $(LDFLAGS) /SUBSYSTEM:console $(dftest_LIBS) $(dftest_OBJECTS)
 <<
-!IF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20" 
+!IF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20"
        mt.exe -nologo -manifest "dftest.exe.manifest" -outputresource:dftest.exe;1
 !ENDIF
 
@@ -279,16 +261,16 @@ randpkt.exe       : $(randpkt_OBJECTS) getopt.obj
        $(LINK) @<<
                /OUT:randpkt.exe $(conflags) $(conlibsdll) $(LDFLAGS) /SUBSYSTEM:console $(randpkt_LIBS) $(randpkt_OBJECTS) getopt.obj
 <<
-!IF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20" 
+!IF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20"
        mt.exe -nologo -manifest "randpkt.exe.manifest" -outputresource:randpkt.exe;1
 !ENDIF
 
-dumpcap.exe    : $(LIBS_CHECK) config.h svnversion.h $(dumpcap_OBJECTS) getopt.obj epan/unicode-utils.obj inet_ntop.obj mkstemp.obj wiretap\wiretap-$(WTAP_VERSION).lib image\dumpcap.res 
+dumpcap.exe    : $(LIBS_CHECK) config.h svnversion.h $(dumpcap_OBJECTS) getopt.obj epan/unicode-utils.obj inet_ntop.obj mkstemp.obj wiretap\wiretap-$(WTAP_VERSION).lib image\dumpcap.res
        @echo Linking $@
        $(LINK) @<<
-               /OUT:dumpcap.exe $(conflags) $(conlibsdll) $(LDFLAGS) /SUBSYSTEM:console $(dumpcap_LIBS) $(dumpcap_OBJECTS) getopt.obj epan/unicode-utils.obj inet_ntop.obj mkstemp.obj image\dumpcap.res
+               /OUT:dumpcap.exe $(conflags) $(conlibsdll) $(LDFLAGS) /SUBSYSTEM:console $(dumpcap_LIBS) $(dumpcap_OBJECTS) getopt.obj inet_ntop.obj mkstemp.obj image\dumpcap.res
 <<
-!IF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20" 
+!IF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20"
        mt.exe -nologo -manifest "dumpcap.exe.manifest" -outputresource:dumpcap.exe;1
 !ENDIF
 
@@ -354,14 +336,14 @@ AUTHORS-SHORT-FORMAT: AUTHORS-SHORT make-authors-format.pl
     $(PERL) perlnoutf.pl make-authors-format.pl < AUTHORS-SHORT > AUTHORS-SHORT-FORMAT
 
 #
-# Build "tshark-tap-register.c", which contains a function 
+# Build "tshark-tap-register.c", which contains a function
 # "register_all_tap_listeners()"
 # that calls the register routines for all TShark tap listeners.
 #
 # We do this by grepping through sources.
 #
-# Formatting conventions:  The name of the tap_listener_register_* 
-# routines must start in column zero, or must be preceded only by 
+# Formatting conventions:  The name of the tap_listener_register_*
+# routines must start in column zero, or must be preceded only by
 # "void " starting in column zero, and must not be inside #if.
 #
 # The first argument is the name of the file to write.
@@ -375,12 +357,9 @@ tshark-tap-register.c: $(TSHARK_TAP_SRC) make-tapreg-dotc
 text2pcap-scanner.c : text2pcap-scanner.l
        $(LEX) -otext2pcap-scanner.c text2pcap-scanner.l
 
-clean_gtk2.tmp:
-       rm -rf gtk2.tmp
-
-clean-local: clean_gtk2.tmp clean-deps
-       rm -f $(wireshark_OBJECTS) $(tshark_OBJECTS) $(dumpcap_OBJECTS) $(EXTRA_OBJECTS) \
-               $(EXECUTABLES) *.pdb *.exe.manifest \
+clean-local: clean-deps
+       rm -f $(wireshark_OBJECTS) $(tshark_OBJECTS) $(dumpcap_OBJECTS) $(rawshark_OBJECTS) \
+               $(EXTRA_OBJECTS) $(EXECUTABLES) *.pdb *.exe.manifest \
                capinfos.obj editcap.obj mergecap.obj text2pcap.obj \
                nio-ie5.obj update.obj \
                text2pcap-scanner.obj text2pcap-scanner.c rdps.obj \
@@ -423,10 +402,15 @@ clean: clean-local
 # "distclean" removes all files not part of the distribution.
 # It does not remove generated files that are part of the distribution.
 distclean-local: clean-local
+!IFDEF ADNS_DIR
+!IF "$(MSVC_VARIANT)" != "MSVC6"
+       rm -f $(ADNS_DLL) $(ADNS_LIBS)
+!ENDIF
+!ENDIF
 !IFDEF ZLIB_DIR
-       rm -f $(ZLIB_DIR)\zlib1.dll $(ZLIB_DIR)\zlib1.dll.manifest \
+       rm -f $(ZLIB_DLL) $(ZLIB_DIR)\zlib1.dll.manifest \
                $(ZLIB_DIR)\include\zlib.h $(ZLIB_DIR)\include\zconf.h \
-               $(ZLIB_DIR)\lib\zdll.lib 
+               $(ZLIB_DIR)\lib\zdll.lib
 !ENDIF
        rm -f config.h $(BUILT_SOURCES)
 
@@ -500,19 +484,53 @@ image::
        $(MAKE) /$(MAKEFLAGS) -f Makefile.nmake
        cd ..
 
+!IFDEF ADNS_DIR
+# Non-MSVC6 variants have to avoid indirectly using msvcrt.dll,
+# therefore compile the adns dll from source ADNS_DIR package.
+# To avoid path problems, copy the adns sources to a temp dir,
+# compile and copy the resulting files back to (source) ADNS_DIR
+#
+# Unfortunately:
+# - we need to "patch" adns_dll.rep and adns_dll.rc (at least for MSVC2005EE)
+# - on MSVC6 we can't easily rebuild, because iphlpapi.h is needed
+# 
+$(ADNS_DLL):
+!IF "$(MSVC_VARIANT)" == "MSVC6"
+       if not exist $(WIRESHARK_LIBS)\$(MSVC_VARIANT)\adns mkdir $(WIRESHARK_LIBS)\$(MSVC_VARIANT)\adns
+       copy $(ADNS_DIR)\adns_win32\lib\adns_dll.dll $(ADNS_DLL)
+       copy $(ADNS_DIR)\adns_win32\lib\adns_dll.lib $(ADNS_LIBS)
+!ELSE
+       xcopy $(ADNS_DIR) adns.tmp /D /I /E /Y
+       copy adns_dll.dep adns.tmp\adns_win32\adns_dll
+       copy adns_dll.rc adns.tmp\adns_win32\adns_dll
+       cd adns.tmp\adns_win32\adns_dll
+       set CFG=adns_dll - Win32 Release
+       $(MAKE) /$(MAKEFLAGS) -f adns_dll.mak LOC="-D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE"
+       cd ..\lib
+!IF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20"
+       mt.exe -nologo -manifest "adns_dll.dll.manifest" -outputresource:adns_dll.dll;2
+!ENDIF
+       if not exist $(WIRESHARK_LIBS)\$(MSVC_VARIANT)\adns mkdir $(WIRESHARK_LIBS)\$(MSVC_VARIANT)\adns
+       copy adns_dll.dll $(ADNS_DLL)
+       copy adns_dll.lib $(ADNS_LIBS)
+       cd ..\..\..
+       rm -r -f adns.tmp
+!ENDIF
+!ENDIF
+
 !IFDEF ZLIB_DIR
-# NonMSVC6 variants have to avoid indirectly using msvcrt.dll,
+# Non-MSVC6 variants have to avoid indirectly using msvcrt.dll,
 # therefore compile the zlib dll from source ZLIB_DIR package.
 # To avoid path problems, copy the zlib sources to a temp dir,
 # compile and copy the resulting files back to (source) ZLIB_DIR
 $(ZLIB_DLL):
        xcopy $(ZLIB_DIR) zlib.tmp /D /I /E /Y
        cd zlib.tmp
-       $(MAKE) /$(MAKEFLAGS) -f win32/Makefile.msc zlib1.dll LOC="-D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE" 
+       $(MAKE) /$(MAKEFLAGS) -f win32/Makefile.msc zlib1.dll LOC="-D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE"
        if not exist $(ZLIB_DIR) mkdir $(ZLIB_DIR)
        if not exist $(ZLIB_DIR)\lib mkdir $(ZLIB_DIR)\lib
        if not exist $(ZLIB_DIR)\include mkdir $(ZLIB_DIR)\include
-!IF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20" 
+!IF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20"
        mt.exe -nologo -manifest "zlib1.dll.manifest" -outputresource:zlib1.dll;2
 !ENDIF
        copy zlib1.dll $(ZLIB_DIR)
@@ -523,6 +541,7 @@ $(ZLIB_DLL):
     rm -r -f zlib.tmp
 !ENDIF
 
+
 wiretap::
        cd wiretap
        $(MAKE) /$(MAKEFLAGS) -f Makefile.nmake
@@ -535,19 +554,7 @@ codecs::
 
 gtk:: help config.h svnversion.h AUTHORS-SHORT doxygen
        cd gtk
-       $(MAKE) /$(MAKEFLAGS) /f Makefile.nmake GTK_CFLAGS="$(GTK1_CFLAGS)" GTK_LIBS="$(GTK1_LIBS)" libui.lib
-       cd ..
-
-# copy all required files to gtk2.tmp (but only when newer than existing) and compile in that dir
-gtk2:: help config.h svnversion.h AUTHORS-SHORT
-       if not exist gtk2.tmp mkdir gtk2.tmp
-       cd gtk
-       set copycmd=/y
-       xcopy Makefile.* ..\gtk2.tmp /d
-       xcopy *.c        ..\gtk2.tmp /d
-       xcopy *.h        ..\gtk2.tmp /d
-       cd ..\gtk2.tmp
-       $(MAKE) /$(MAKEFLAGS) /f Makefile.nmake GTK_CFLAGS="$(GTK2_CFLAGS)" GTK_LIBS="$(GTK2_LIBS)" libui.lib
+       $(MAKE) /$(MAKEFLAGS) /f Makefile.nmake libui.lib
        cd ..
 
 epan:: $(RESOURCES) $(ZLIB_DLL) wiretap\wiretap-$(WTAP_VERSION).lib $(BUILT_SOURCES) doxygen
@@ -602,7 +609,6 @@ REQUIRED_TOOLS=\
        /usr/bin/find   \
        $(PERL) \
        $(PYTHON)       \
-       $(NASM) \
        sed     \
        unzip   \
        wget
@@ -616,9 +622,9 @@ verify_tools:
 WIN32_SETUP_OPT=--download
 !ENDIF
 
-# Verify that the required library 'package' (zip) files have been downloaded. 
-# (It seems reasonable to assume that if the files have been downloaded 
-#  then they have been installed). 
+# Verify that the required library 'package' (zip) files have been downloaded.
+# (It seems reasonable to assume that if the files have been downloaded
+#  then they have been installed).
 check_libs:
        $(MAKE) /$(MAKEFLAGS) -f Makefile.nmake WIN32_SETUP_OPT=--libverify process_libs
 
@@ -632,7 +638,7 @@ $(LIBS_CHECK): Makefile.nmake
        @touch --reference=Makefile.nmake $@
 
 # Download (if needed) and install all the required libraries into WIRESHARK_LIBS.
-# A clean_setup is done first to ensure that the target dirs don't 
+# A clean_setup is done first to ensure that the target dirs don't
 # contain old files remaining from a previous setup run.
 setup: verify_tools clean_setup process_libs
 
@@ -641,39 +647,32 @@ setup: verify_tools clean_setup process_libs
 # (The choice is determined by the value of the macro WIN32_SETUP_OPT).
 process_libs:
     if not exist $(WIRESHARK_LIBS) md $(WIRESHARK_LIBS)
-!IF "$(GTK2_INST_VERSION)" == "2.12"
+!IF "$(GTK_INST_VERSION)" == "2.12"
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
-               glib gtk2.12/glib-2.14.4.zip
+               glib gtk2.12/glib-2.16.3.zip
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
-               glib gtk2.12/glib-dev-2.14.4.zip
-!ELSEIF "$(GTK2_INST_VERSION)" == "2.10"
+               glib gtk2.12/glib-dev-2.16.3.zip
+!ELSEIF "$(GTK_INST_VERSION)" == "2.10"
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
                glib gtk2.10/glib-2.12.13.zip
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
                glib gtk2.10/glib-dev-2.12.13.zip
 !ELSE
-       @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
-               glib glib-2.2.3-20040116.zip
-       @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
-               glib glib-dev-2.2.3-20040116.zip
-!ENDIF
-!IFDEF GTK1_DIR
-       @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
-               gtk+ gtk+-1.3.0-20030717.zip
-       @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
-               gtk+ gtk+-dev-1.3.0-20030115.zip
+!ERROR ? Unknown or invalid GTK_INST_VERSION
 !ENDIF
+!IFDEF ICONV_DIR
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
                libiconv-1.9.1.bin.woe32 libiconv-1.9.1.bin.woe32.zip
+!ENDIF
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
-               gettext-runtime-0.17 gettext-runtime-0.17.zip
+               gettext-runtime-0.17-1 gettext-runtime-0.17-1.zip
 !IFDEF KFW_DIR
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
                kfw-2.5 kfw-2.5.zip
 !ENDIF
 !IFDEF PCAP_DIR
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
-               . WpdPack_3_1.zip
+               . WpdPack_4_0_2.zip
 !ENDIF
 !IFDEF AIRPCAP_DIR
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
@@ -685,9 +684,9 @@ process_libs:
 !ENDIF
 !IFDEF PCRE_DIR
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
-               pcre-6.4 pcre-6.4-bin.zip
+               pcre-7.0 pcre-7.0-bin.zip
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
-               pcre-6.4 pcre-6.4-lib.zip
+               pcre-7.0 pcre-7.0-lib.zip
 !ENDIF
 !IFDEF ZLIB_DIR
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
@@ -708,30 +707,30 @@ process_libs:
 !ENDIF
 !IFDEF SMI_DIR
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
-               . libsmi-0.4.5.zip
+               . libsmi-0.4.8.zip
 !ENDIF
 
-!IFDEF GTK2_DIR
-!IF "$(GTK2_INST_VERSION)" == "2.12"
+!IFDEF GTK_DIR
+!IF "$(GTK_INST_VERSION)" == "2.12"
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
-               gtk2 gtk2.12/gtk+-2.12.3.zip
+               gtk2 gtk2.12/gtk+-2.12.9.zip
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
-               gtk2 gtk2.12/gtk+-dev-2.12.3.zip
+               gtk2 gtk2.12/gtk+-dev-2.12.9.zip
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
-               gtk2 gtk2.12/cairo-1.4.10.zip
+               gtk2 gtk2.12/cairo-1.6.4-1.zip
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
-               gtk2 gtk2.12/cairo-dev-1.4.10.zip
+               gtk2 gtk2.12/cairo-dev-1.6.4-1.zip
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
-               gtk2 gtk2.12/atk-1.20.0.zip
+               gtk2 gtk2.12/atk-1.22.0.zip
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
-               gtk2 gtk2.12/atk-dev-1.20.0.zip
+               gtk2 gtk2.12/atk-dev-1.22.0.zip
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
                gtk2 gtk2.12/libpng-1.2.8-bin.zip
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
                gtk2 gtk2.12/tiff-3.8.2-1-bin.zip
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
                gtk2 gtk2.12/jpeg-6b-4-bin.zip
-!ELSEIF "$(GTK2_INST_VERSION)" == "2.10"
+!ELSEIF "$(GTK_INST_VERSION)" == "2.10"
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
                gtk2 gtk2.10/gtk+-2.10.14.zip
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
@@ -747,30 +746,20 @@ process_libs:
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
                gtk2 gtk2.10/libpng-1.2.8-bin.zip
 !ELSE
-       @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
-               gtk2 gtk2/gtk+-2.2.4-20040124.zip
-       @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
-               gtk2 gtk2/gtk+-dev-2.2.4-20040124.zip
-       @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
-               gtk2 gtk2/atk-1.4.0.zip
-       @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
-               gtk2 gtk2/atk-dev-1.4.0.zip
+!ERROR ? Unknown or invalid GTK_INST_VERSION
 !ENDIF
-!IF "$(PANGO_INST_VERSION)" == "1.18"
+!IF "$(PANGO_INST_VERSION)" == "1.20"
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
-               gtk2 gtk2.12/pango-1.18.3.zip
+               gtk2 gtk2.12/pango-1.20.2.zip
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
-               gtk2 gtk2.12/pango-dev-1.18.3.zip
+               gtk2 gtk2.12/pango-dev-1.20.2.zip
 !ELSEIF "$(PANGO_INST_VERSION)" == "1.16"
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
                gtk2 gtk2.10/pango-1.16.4.zip
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
                gtk2 gtk2.10/pango-dev-1.16.4.zip
 !ELSE
-       @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
-               gtk2 gtk2/pango-1.2.5-20040124.zip
-       @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
-               gtk2 gtk2/pango-dev-1.2.5-20040124.zip
+!ERROR ? Unknown or invalid PANGO_INST_VERSION
 !ENDIF
 !ENDIF
 !IFDEF GTK_WIMP_DIR
@@ -779,22 +768,28 @@ process_libs:
 !ENDIF
 !IFDEF HHC_DIR
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
-               user-guide user-guide-23522.zip
+               user-guide user-guide-24665.zip
 !ENDIF
 !IFDEF UPX
        @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
                . upx301w.zip
+!ENDIF
+!IFDEF NASM
+       @$(SH) tools\win32-setup.sh "$(WIN32_SETUP_OPT)" "$(WIRESHARK_LIBS)" \
+               . nasm-2.02-win32.zip
 !ENDIF
        @echo.
        @echo Wireshark is ready to build.
 
-# Cleanup files installed by the setup target. It will not remove the 
+# Cleanup files installed by the setup target. It will not remove the
 # downloaded zip files.
-# WHEN UPDATING LIBRARY VERSIONS, KEEP ALSO ONE FORMER VERSION SO 
-# UPDATING REMOVES THE FORMER USER DIRS 
+# WHEN UPDATING LIBRARY VERSIONS, KEEP ALSO ONE FORMER VERSION SO
+# UPDATING REMOVES THE FORMER USER DIRS
 clean_setup:
     rm -r -f $(WIRESHARK_LIBS)/adns-1.0-win32-05
     rm -r -f $(WIRESHARK_LIBS)/gettext-0.14.5
+    rm -r -f $(WIRESHARK_LIBS)/gettext-runtime-0.17
+    rm -r -f $(WIRESHARK_LIBS)/gettext-runtime-0.17-1
     rm -r -f $(WIRESHARK_LIBS)/glib
     rm -r -f $(WIRESHARK_LIBS)/gnutls-1.6.1-1
     rm -r -f $(WIRESHARK_LIBS)/gtk2
@@ -804,7 +799,11 @@ clean_setup:
     rm -r -f $(WIRESHARK_LIBS)/libiconv-1.9.1.bin.woe32
     rm -r -f $(WIRESHARK_LIBS)/lua5.1
     rm -r -f $(WIRESHARK_LIBS)/libsmi-0.4.5
+    rm -r -f $(WIRESHARK_LIBS)/libsmi-0.4.8
+    rm -r -f $(WIRESHARK_LIBS)/nasm-2.00
+    rm -r -f $(WIRESHARK_LIBS)/nasm-2.02
     rm -r -f $(WIRESHARK_LIBS)/pcre-6.4
+    rm -r -f $(WIRESHARK_LIBS)/pcre-7.0
     rm -r -f $(WIRESHARK_LIBS)/portaudio_v18_1
     rm -r -f $(WIRESHARK_LIBS)/portaudio_v19
     rm -r -f $(WIRESHARK_LIBS)/user-guide
@@ -819,48 +818,21 @@ clean_setup:
 ################################################################################
 
 
-# generate and install Wireshark GTK1 in INSTALL1_DIR
-debug-gtk1: wireshark.exe install-files1
-
-# generate and install Wireshark GTK2 in INSTALL2_DIR
-debug-gtk2: wireshark-gtk2.exe install-files2
-
-# generate and install Wireshark GTK2 in INSTALL2_DIR
-debug-tshark: tshark.exe
-       set copycmd=/y
-       set INSTALL_DIR=$(INSTALL2_DIR)
-       $(MAKE) /$(MAKEFLAGS) -f Makefile.nmake install-common-files
+# prepare debugging of Wireshark in INSTALL_DIR
+debug-wireshark: wireshark.exe install-generated-files
 
-# generate and install Wireshark GTK2 in INSTALL2_DIR
-debug-dumpcap: dumpcap.exe
+# prepare debugging of tshark in INSTALL_DIR
+debug-tshark: tshark.exe install-generated-files
 
+# prepare debugging of rawshark in INSTALL_DIR
+debug-rawshark: rawshark.exe install-generated-files
 
-# "install-deps" will copy all files needed to run Wwireshark/Tshark
-# to the INSTALL1_DIR/INSTALL2_DIR, so you can run/debug Wireshark/Tshark from there.
+# prepare debugging of dumpcap in INSTALL_DIR
+debug-dumpcap: dumpcap.exe install-generated-files
 
-install-deps: install-deps1 install-deps2 install-files1 install-files2
 
-# install Wireshark GTK1 and other generated files
-install-files1:
-!IFDEF GTK1_DIR
-       set copycmd=/y
-       set INSTALL_DIR=$(INSTALL1_DIR)
-       $(MAKE) /$(MAKEFLAGS) -f Makefile.nmake install-common-files
-       xcopy wireshark.exe $(INSTALL1_DIR) /d
-       if exist wireshark.pdb xcopy wireshark.pdb $(INSTALL1_DIR) /d
-!ENDIF
-
-# install Wireshark GTK2 and other generated files
-install-files2:
-!IFDEF GTK2_DIR
-       set INSTALL_DIR=$(INSTALL2_DIR)
-       $(MAKE) /$(MAKEFLAGS) -f Makefile.nmake install-common-files
-       copy wireshark-gtk2.exe $(INSTALL2_DIR)\wireshark.exe
-       if exist wireshark-gtk2.pdb copy wireshark-gtk2.pdb $(INSTALL2_DIR)\wireshark.pdb
-       if exist ".\docbook\user-guide.chm" xcopy ".\docbook\user-guide.chm" $(INSTALL2_DIR) /d
-!ENDIF
-
-install-common-files:
+# install generated files (exe, "our" libs, ...)
+install-generated-files:
        set copycmd=/y
 !IF "$(MSVC_VARIANT)" == "MSVC2008EE"
        xcopy "$(MSVCR_DLL)" $(INSTALL_DIR)
@@ -870,21 +842,27 @@ install-common-files:
        xcopy epan\libwireshark.dll $(INSTALL_DIR) /d
 !ENDIF
        xcopy ".\wiretap\wiretap-$(WTAP_VERSION).dll" $(INSTALL_DIR) /d
-       if exist ".\wiretap\wiretap-$(WTAP_VERSION).pdb" xcopy ".\wiretap\wiretap-$(WTAP_VERSION).pdb" $(INSTALL_DIR) /d        
+       if exist ".\wiretap\wiretap-$(WTAP_VERSION).pdb" xcopy ".\wiretap\wiretap-$(WTAP_VERSION).pdb" $(INSTALL_DIR) /d
        xcopy ".\epan\libwireshark.dll" $(INSTALL_DIR) /d
-       if exist ".\epan\libwireshark.pdb" xcopy ".\epan\libwireshark.pdb" $(INSTALL_DIR) /d    
+       if exist ".\epan\libwireshark.pdb" xcopy ".\epan\libwireshark.pdb" $(INSTALL_DIR) /d
+       if exist wireshark.exe copy wireshark.exe $(INSTALL_DIR)\wireshark.exe
+       if exist wireshark.pdb copy wireshark.pdb $(INSTALL_DIR)\wireshark.pdb
+       if exist ".\docbook\user-guide.chm" xcopy ".\docbook\user-guide.chm" $(INSTALL_DIR) /d
        if exist tshark.exe xcopy tshark.exe $(INSTALL_DIR) /d
-       if exist tshark.pdb xcopy tshark.pdb $(INSTALL_DIR) /d  
+       if exist tshark.pdb xcopy tshark.pdb $(INSTALL_DIR) /d
+       if exist rawshark.exe xcopy rawshark.exe $(INSTALL_DIR) /d
+       if exist rawshark.exe.manifest xcopy rawshark.exe.manifest $(INSTALL_DIR) /d
+       if exist rawshark.pdb xcopy rawshark.pdb $(INSTALL_DIR) /d
        if exist dumpcap.exe xcopy dumpcap.exe $(INSTALL_DIR) /d
-       if exist dumpcap.pdb xcopy dumpcap.pdb $(INSTALL_DIR) /d        
+       if exist dumpcap.pdb xcopy dumpcap.pdb $(INSTALL_DIR) /d
        if exist mergecap.exe xcopy mergecap.exe $(INSTALL_DIR) /d
-       if exist mergecap.pdb xcopy mergecap.pdb $(INSTALL_DIR) /d      
+       if exist mergecap.pdb xcopy mergecap.pdb $(INSTALL_DIR) /d
        if exist text2pcap.exe xcopy text2pcap.exe $(INSTALL_DIR) /d
-       if exist text2pcap.pdb xcopy text2pcap.pdb $(INSTALL_DIR) /d    
+       if exist text2pcap.pdb xcopy text2pcap.pdb $(INSTALL_DIR) /d
        if exist capinfos.exe xcopy capinfos.exe $(INSTALL_DIR) /d
-       if exist capinfos.pdb xcopy capinfos.pdb $(INSTALL_DIR) /d      
+       if exist capinfos.pdb xcopy capinfos.pdb $(INSTALL_DIR) /d
        if exist editcap.exe xcopy editcap.exe $(INSTALL_DIR) /d
-       if exist editcap.pdb xcopy editcap.pdb $(INSTALL_DIR) /d        
+       if exist editcap.pdb xcopy editcap.pdb $(INSTALL_DIR) /d
        xcopy ".\AUTHORS-SHORT" $(INSTALL_DIR) /d
        xcopy ".\manuf" $(INSTALL_DIR) /d
        xcopy ".\services" $(INSTALL_DIR) /d
@@ -903,9 +881,6 @@ install-common-files:
        xcopy ".\epan\wslua\console.lua" $(INSTALL_DIR) /d
 !ENDIF
        xcopy doc\*.html $(INSTALL_DIR) /d
-!IFDEF ETHEREAL_EUG_DIR
-       xcopy $(ETHEREAL_EUG_DIR) $(INSTALL_DIR) /d
-!ENDIF
        if not exist $(INSTALL_DIR)\help mkdir $(INSTALL_DIR)\help
        xcopy ".\help\*.*" $(INSTALL_DIR)\help /d
        if not exist $(INSTALL_DIR)\dtds mkdir $(INSTALL_DIR)\dtds
@@ -929,11 +904,13 @@ install-common-files:
        xcopy ".\plugins\ciscosm\ciscosm.dll" $(INSTALL_DIR)\plugins\$(VERSION) /d
        xcopy ".\plugins\docsis\docsis.dll" $(INSTALL_DIR)\plugins\$(VERSION) /d
        xcopy ".\plugins\enttec\enttec.dll" $(INSTALL_DIR)\plugins\$(VERSION) /d
+       xcopy ".\plugins\ethercat\ethercat.dll" $(INSTALL_DIR)\plugins\$(VERSION) /d
        xcopy ".\plugins\giop\coseventcomm.dll" $(INSTALL_DIR)\plugins\$(VERSION) /d
        xcopy ".\plugins\giop\cosnaming.dll" $(INSTALL_DIR)\plugins\$(VERSION) /d
        xcopy ".\plugins\giop\parlay.dll" $(INSTALL_DIR)\plugins\$(VERSION) /d
        xcopy ".\plugins\giop\tango.dll" $(INSTALL_DIR)\plugins\$(VERSION) /d
        xcopy ".\plugins\gryphon\gryphon.dll" $(INSTALL_DIR)\plugins\$(VERSION) /d
+       xcopy ".\plugins\infiniband\infiniband.dll" $(INSTALL_DIR)\plugins\$(VERSION) /d
        xcopy ".\plugins\irda\irda.dll" $(INSTALL_DIR)\plugins\$(VERSION) /d
        xcopy ".\plugins\lwres\lwres.dll" $(INSTALL_DIR)\plugins\$(VERSION) /d
        xcopy ".\plugins\m2m\m2m.dll" $(INSTALL_DIR)\plugins\$(VERSION) /d
@@ -946,6 +923,7 @@ install-common-files:
        xcopy ".\plugins\rtnet\rtnet.dll" $(INSTALL_DIR)\plugins\$(VERSION) /d
        xcopy ".\plugins\rudp\rudp.dll" $(INSTALL_DIR)\plugins\$(VERSION) /d
        xcopy ".\plugins\sbus\sbus.dll" $(INSTALL_DIR)\plugins\$(VERSION) /d
+       xcopy ".\plugins\sercosiii\sercosiii.dll" $(INSTALL_DIR)\plugins\$(VERSION) /d
        xcopy ".\plugins\stats_tree\stats_tree.dll" $(INSTALL_DIR)\plugins\$(VERSION) /d
        xcopy ".\plugins\unistim\unistim.dll" $(INSTALL_DIR)\plugins\$(VERSION) /d
        xcopy ".\plugins\v5ua\v5ua.dll" $(INSTALL_DIR)\plugins\$(VERSION) /d
@@ -953,88 +931,68 @@ install-common-files:
        xcopy ".\plugins\wimaxasncp\wimaxasncp.dll" $(INSTALL_DIR)\plugins\$(VERSION) /d
        if exist custom-install.bat custom-install $(INSTALL_DIR) $(VERSION)
 
-install-deps1: install-common-deps1
-!IFDEF GTK1_DIR
-       set copycmd=/y
-       xcopy $(GTK1_DIR)\lib\libgtk-0.dll $(INSTALL1_DIR) /d
-       xcopy $(GTK1_DIR)\lib\libgdk-0.dll $(INSTALL1_DIR) /d
-!ENDIF
-
-install-deps2: install-common-deps2
-!IFDEF GTK2_DIR
+# "install-all" will copy all files needed to run Wireshark/Tshark
+# to the INSTALL_DIR, so you can run/debug Wireshark/Tshark from there.
+install-all: install-generated-files
        set copycmd=/y
-       xcopy $(GTK2_DIR)\bin\libgdk-win32-2.0-0.dll $(INSTALL2_DIR) /d
-       xcopy $(GTK2_DIR)\bin\libgdk_pixbuf-2.0-0.dll $(INSTALL2_DIR) /d
-       xcopy $(GTK2_DIR)\bin\libgtk-win32-2.0-0.dll $(INSTALL2_DIR) /d
-       xcopy $(GTK2_DIR)\bin\libatk-1.0-0.dll $(INSTALL2_DIR) /d
-       xcopy $(GTK2_DIR)\bin\libpango-1.0-0.dll $(INSTALL2_DIR) /d
-       xcopy $(GTK2_DIR)\bin\libpangowin32-1.0-0.dll $(INSTALL2_DIR) /d
-       if not exist $(INSTALL2_DIR)\etc mkdir $(INSTALL2_DIR)\etc
-       if not exist $(INSTALL2_DIR)\etc\gtk-2.0 mkdir $(INSTALL2_DIR)\etc\gtk-2.0
-       if not exist $(INSTALL2_DIR)\etc\pango mkdir $(INSTALL2_DIR)\etc\pango
-       if not exist $(INSTALL2_DIR)\lib mkdir $(INSTALL2_DIR)\lib
-       if not exist $(INSTALL2_DIR)\lib\gtk-2.0 mkdir $(INSTALL2_DIR)\lib\gtk-2.0
-       if not exist $(INSTALL2_DIR)\lib\gtk-2.0\$(GTK2_LIB_DIR) mkdir $(INSTALL2_DIR)\lib\gtk-2.0\$(GTK2_LIB_DIR)
-       if not exist $(INSTALL2_DIR)\lib\gtk-2.0\$(GTK2_LIB_DIR)\loaders mkdir $(INSTALL2_DIR)\lib\gtk-2.0\$(GTK2_LIB_DIR)\loaders
-       if not exist $(INSTALL2_DIR)\lib\gtk-2.0\$(GTK2_LIB_DIR)\immodules mkdir $(INSTALL2_DIR)\lib\gtk-2.0\$(GTK2_LIB_DIR)\immodules
-       if not exist $(INSTALL2_DIR)\lib\gtk-2.0\$(GTK2_LIB_DIR)\immodules mkdir $(INSTALL2_DIR)\lib\gtk-2.0\$(GTK2_LIB_DIR)\engines
-#      if not exist $(INSTALL2_DIR)\lib\pango mkdir $(INSTALL2_DIR)\lib\pango
-#      if not exist $(INSTALL2_DIR)\lib\pango\$(PANGO_LIB_DIR) mkdir $(INSTALL2_DIR)\lib\pango\$(PANGO_LIB_DIR)
-#      if not exist $(INSTALL2_DIR)\lib\pango\$(PANGO_LIB_DIR)\modules mkdir $(INSTALL2_DIR)\lib\pango\$(PANGO_LIB_DIR)\modules
-       xcopy $(GTK2_DIR)\etc\gtk-2.0\*.* $(INSTALL2_DIR)\etc\gtk-2.0 /d
-       xcopy $(GTK2_DIR)\etc\pango\pango.* $(INSTALL2_DIR)\etc\pango /d
-#      xcopy $(GTK2_DIR)\lib\gtk-2.0\$(GTK2_LIB_DIR)\loaders\libpixbufloader-*.dll $(INSTALL2_DIR)\lib\gtk-2.0\$(GTK2_LIB_DIR)\loaders /d
-       xcopy $(GTK2_DIR)\lib\gtk-2.0\$(GTK2_LIB_DIR)\immodules\im-*.dll $(INSTALL2_DIR)\lib\gtk-2.0\$(GTK2_LIB_DIR)\immodules /d
-#      xcopy $(GTK2_DIR)\lib\pango\$(PANGO_LIB_DIR)\modules\pango-*.dll $(INSTALL2_DIR)\lib\pango\$(PANGO_LIB_DIR)\modules /d
+       if not exist $(INSTALL_DIR) mkdir $(INSTALL_DIR)
+       xcopy $(GTK_DIR)\bin\libgdk-win32-2.0-0.dll $(INSTALL_DIR) /d
+       xcopy $(GTK_DIR)\bin\libgdk_pixbuf-2.0-0.dll $(INSTALL_DIR) /d
+       xcopy $(GTK_DIR)\bin\libgtk-win32-2.0-0.dll $(INSTALL_DIR) /d
+       xcopy $(GTK_DIR)\bin\libatk-1.0-0.dll $(INSTALL_DIR) /d
+       xcopy $(GTK_DIR)\bin\libpango-1.0-0.dll $(INSTALL_DIR) /d
+       xcopy $(GTK_DIR)\bin\libpangowin32-1.0-0.dll $(INSTALL_DIR) /d
+       if not exist $(INSTALL_DIR)\etc mkdir $(INSTALL_DIR)\etc
+       if not exist $(INSTALL_DIR)\etc\gtk-2.0 mkdir $(INSTALL_DIR)\etc\gtk-2.0
+       if not exist $(INSTALL_DIR)\etc\pango mkdir $(INSTALL_DIR)\etc\pango
+       if not exist $(INSTALL_DIR)\lib mkdir $(INSTALL_DIR)\lib
+       if not exist $(INSTALL_DIR)\lib\gtk-2.0 mkdir $(INSTALL_DIR)\lib\gtk-2.0
+       if not exist $(INSTALL_DIR)\lib\gtk-2.0\$(GTK_LIB_DIR) mkdir $(INSTALL_DIR)\lib\gtk-2.0\$(GTK_LIB_DIR)
+       if not exist $(INSTALL_DIR)\lib\gtk-2.0\$(GTK_LIB_DIR)\loaders mkdir $(INSTALL_DIR)\lib\gtk-2.0\$(GTK_LIB_DIR)\loaders
+       if not exist $(INSTALL_DIR)\lib\gtk-2.0\$(GTK_LIB_DIR)\immodules mkdir $(INSTALL_DIR)\lib\gtk-2.0\$(GTK_LIB_DIR)\immodules
+       if not exist $(INSTALL_DIR)\lib\gtk-2.0\$(GTK_LIB_DIR)\immodules mkdir $(INSTALL_DIR)\lib\gtk-2.0\$(GTK_LIB_DIR)\engines
+#      if not exist $(INSTALL_DIR)\lib\pango mkdir $(INSTALL_DIR)\lib\pango
+#      if not exist $(INSTALL_DIR)\lib\pango\$(PANGO_LIB_DIR) mkdir $(INSTALL_DIR)\lib\pango\$(PANGO_LIB_DIR)
+#      if not exist $(INSTALL_DIR)\lib\pango\$(PANGO_LIB_DIR)\modules mkdir $(INSTALL_DIR)\lib\pango\$(PANGO_LIB_DIR)\modules
+       xcopy $(GTK_DIR)\etc\gtk-2.0\*.* $(INSTALL_DIR)\etc\gtk-2.0 /d
+       xcopy $(GTK_DIR)\etc\pango\pango.* $(INSTALL_DIR)\etc\pango /d
+       xcopy $(GTK_DIR)\lib\gtk-2.0\$(GTK_LIB_DIR)\loaders\libpixbufloader-*.dll $(INSTALL_DIR)\lib\gtk-2.0\$(GTK_LIB_DIR)\loaders /d
+       xcopy $(GTK_DIR)\lib\gtk-2.0\$(GTK_LIB_DIR)\immodules\im-*.dll $(INSTALL_DIR)\lib\gtk-2.0\$(GTK_LIB_DIR)\immodules /d
+#      xcopy $(GTK_DIR)\lib\pango\$(PANGO_LIB_DIR)\modules\pango-*.dll $(INSTALL_DIR)\lib\pango\$(PANGO_LIB_DIR)\modules /d
 !IFDEF NEED_LIBPNG_DLL
-       xcopy $(GTK2_DIR)\bin\libpng13.dll $(INSTALL2_DIR) /d
+       xcopy $(GTK_DIR)\bin\libpng13.dll $(INSTALL_DIR) /d
 !ENDIF
 !IFDEF NEED_LIBTIFF_DLL
-       xcopy $(GTK2_DIR)\bin\libtiff3.dll $(INSTALL2_DIR) /d
+       xcopy $(GTK_DIR)\bin\libtiff3.dll $(INSTALL_DIR) /d
 !ENDIF
 !IFDEF NEED_LIBJPEG_DLL
-       xcopy $(GTK2_DIR)\bin\jpeg62.dll $(INSTALL2_DIR) /d
+       xcopy $(GTK_DIR)\bin\jpeg62.dll $(INSTALL_DIR) /d
 !ENDIF
 !IFDEF NEED_CAIRO_DLL
-       xcopy $(GTK2_DIR)\bin\libcairo-2.dll $(INSTALL2_DIR)  /d
-       xcopy $(GTK2_DIR)\bin\libpangocairo-1.0-0.dll $(INSTALL2_DIR) /d
+       xcopy $(GTK_DIR)\bin\libcairo-2.dll $(INSTALL_DIR)  /d
+       xcopy $(GTK_DIR)\bin\libpangocairo-1.0-0.dll $(INSTALL_DIR) /d
 !ENDIF
 !IFDEF GTK_WIMP_DIR
-       if not exist $(INSTALL2_DIR)\$(GTK_WIMP_DLLDST_DIR) mkdir $(INSTALL2_DIR)\$(GTK_WIMP_DLLDST_DIR)
-       xcopy "$(GTK_WIMP_DLLSRC_DIR)\libwimp.dll" $(INSTALL2_DIR)\$(GTK_WIMP_DLLDST_DIR) /d
-       if not exist $(INSTALL2_DIR)\$(GTK_WIMP_RCDST_DIR) mkdir $(INSTALL2_DIR)\$(GTK_WIMP_RCDST_DIR)
-       xcopy "$(GTK_WIMP_RCSRC_DIR)\gtkrc" $(INSTALL2_DIR)\$(GTK_WIMP_RCDST_DIR) /d
-!ENDIF
-!ENDIF
-
-install-common-deps1:
-!IFDEF GTK1_DIR
-       set INSTALL_DIR=$(INSTALL1_DIR)
-       $(MAKE) /$(MAKEFLAGS) -f Makefile.nmake install-common-deps
-!ENDIF
-
-install-common-deps2:
-!IFDEF GTK2_DIR
-       set INSTALL_DIR=$(INSTALL2_DIR)
-       $(MAKE) /$(MAKEFLAGS) -f Makefile.nmake install-common-deps
+       if not exist $(INSTALL_DIR)\$(GTK_WIMP_DLLDST_DIR) mkdir $(INSTALL_DIR)\$(GTK_WIMP_DLLDST_DIR)
+       xcopy "$(GTK_WIMP_DLLSRC_DIR)\libwimp.dll" $(INSTALL_DIR)\$(GTK_WIMP_DLLDST_DIR) /d
+       if not exist $(INSTALL_DIR)\$(GTK_WIMP_RCDST_DIR) mkdir $(INSTALL_DIR)\$(GTK_WIMP_RCDST_DIR)
+       xcopy "$(GTK_WIMP_RCSRC_DIR)\gtkrc" $(INSTALL_DIR)\$(GTK_WIMP_RCDST_DIR) /d
 !ENDIF
-
-install-common-deps:
-       set copycmd=/y
-       if not exist $(INSTALL_DIR) mkdir $(INSTALL_DIR)
        xcopy $(GLIB_DIR)\bin\libglib-2.0-0.dll $(INSTALL_DIR) /d
-       xcopy $(GLIB_DIR)\bin\libgmodule-2.0-0.dll $(INSTALL_DIR) /d
        xcopy $(GLIB_DIR)\bin\libgobject-2.0-0.dll $(INSTALL_DIR) /d
+       xcopy $(GLIB_DIR)\bin\libgmodule-2.0-0.dll $(INSTALL_DIR) /d
+!IFDEF ICONV_DIR
        xcopy $(ICONV_DIR)\bin\iconv.dll $(INSTALL_DIR) /d
+!ENDIF
        xcopy $(GETTEXT_DIR)\bin\intl.dll $(INSTALL_DIR) /d
 !IFDEF ZLIB_DIR
-       xcopy $(ZLIB_DIR)\zlib1.dll $(INSTALL_DIR) /d
+       xcopy $(ZLIB_DLL) $(INSTALL_DIR) /d
 !ENDIF
 !IFDEF ADNS_DIR
-       xcopy $(ADNS_DIR)\adns_win32\LIB\adns_dll.dll $(INSTALL_DIR) /d
+       xcopy $(ADNS_DLL) $(INSTALL_DIR) /d
 !ENDIF
 !IFDEF PCRE_DIR
-       xcopy $(PCRE_DIR)\bin\pcre.dll $(INSTALL_DIR) /d
+       xcopy $(PCRE_DIR)\bin\pcre3.dll $(INSTALL_DIR) /d
        xcopy $(PCRE_DIR)\man\cat3\pcrepattern.3.txt $(INSTALL_DIR) /d
 !ENDIF
 !IFDEF KFW_DIR
@@ -1059,19 +1017,14 @@ install-common-deps:
        xcopy "$(SMI_DIR)\mibs\*" $(INSTALL_DIR)\snmp\mibs /d
 !ENDIF
 
-clean-deps1:
-       rm -rf $(INSTALL1_DIR)
+clean-deps:
+       rm -rf $(INSTALL_DIR)
        cd plugins
        $(MAKE) /$(MAKEFLAGS) -f Makefile.nmake clean-deps
        cd ..
 
-clean-deps2:
-       rm -rf $(INSTALL2_DIR)
-       cd plugins
-       $(MAKE) /$(MAKEFLAGS) -f Makefile.nmake clean-deps
-       cd ..
-
-clean-deps: clean-deps1 clean-deps2
-
-
-
+checkapi:
+       $(PERL) tools/checkAPIs.pl *.c
+#      $(wireshark_SOURCES) \
+#      $(TSHARK_TAP_SRC)
+# EXTRA_wireshark_SOURCES
\ No newline at end of file