gtk_label_set -> gtk_label_set_text
[metze/wireshark/wip.git] / config.nmake
index a0eb53336851397b256eaf8fc07a3d66ab75a320..bda2183f0f30f4f4d47ff60baec0051095071ce9 100644 (file)
@@ -1,17 +1,23 @@
 # $Id$
 
-# Some more informations about the settings in this file, can be found 
+# Some more informations about the settings in this file, can be found
 # in the file README.win32 and the Developer's Guide (available online).
 
-
+##### Target platform #####
+# Only "win32" is valid (for now).
+# This can be defined in the system environment.
+!IFNDEF PLATFORM
+PLATFORM=win32
+!ENDIF
 
 ##### Versions #####
 
 # The current Wireshark version
 # It's highly recommended to leave MAJOR/MINOR/MICRO unchanged
-VERSION_MAJOR=0
-VERSION_MINOR=99
-VERSION_MICRO=5
+VERSION_MAJOR=1
+VERSION_MINOR=1
+VERSION_MICRO=3
+VERSION_BUILD=0
 # It's recommended to change VERSION_EXTRA for your own custom builds
 # e.g. "-SVN-12345"
 VERSION_EXTRA=
@@ -25,62 +31,98 @@ WTAP_VERSION_MICRO=1
 
 ##### Directories #####
 
-# 
-# Base directory, where your libraries reside, which are needed to 
+#
+# Base directory, where your libraries reside, which are needed to
 # compile the sources. This setting is used only inside this file.
 #
-WIRESHARK_LIBS=C:\wireshark-win32-libs
+WIRESHARK_LIBS=C:\wireshark-$(PLATFORM)-libs
 
-# 
-# Base directory, where your programs reside. 
+#
+# Base directory, where your programs reside.
 # This setting is used only inside this file.
 #
-PROGRAM_FILES=C:/Program Files
+PROGRAM_FILES=$(PROGRAMFILES)
+
+#
+# Location of the "tools" directory. This affects HTML2TXT below and should
+# be overridden by makefiles in any subdirectories that use HTML2TXT.
+!IFNDEF TOOLS_DIR
+TOOLS_DIR=tools
+!ENDIF
 
+#
+# Machine type for the compiler and linker
+# TARGET_MACHINE (Used for link /MACHINE) should be one of "X86" or "X64"
+# (sorry ARM, Alpha, MIPS, and Itanium fans).
+# CPU (Used by win32.mak) should be one of "i386" or "AMD64".
+!if "$(PLATFORM)" == "win32"
+TARGET_MACHINE=X86
+CPU=i386
+!else if "$(PLATFORM)" == "win64"
+TARGET_MACHINE=X64
+CPU=AMD64
+!endif
 
 
 ##### Microsoft Visual C / Studio Variant #####
 # for the different Studios, see: http://en.wikipedia.org/wiki/Microsoft_Visual_Studio
 # only one of the following MSVC_VARIANT settings should be used
+# BTW: The "Microsoft Visual C++ Toolkit 2003" DOESN'T WORK for WS!
 
-# "Microsoft Visual Studio 6.0" - THE ONLY RECOMMENDED
+# "Microsoft Visual Studio 6.0"
 # Visual C++ 6.0, _MSC_VER 1200, msvcrt.dll (version 6)
-MSVC_VARIANT=MSVC6
+#MSVC_VARIANT=MSVC6
 
-# "Microsoft Visual Studio .NET (2002)" - NOT YET WORKING
+# "Microsoft Visual Studio .NET (2002)"
 # Visual C++ 7.0, _MSC_VER 1300, msvcr70.dll
 #MSVC_VARIANT=MSVC2002
 
-# "Microsoft Visual Studio .NET 2003" - NOT YET WORKING
+# "Microsoft .Net Framework SDK Version 1.0"
+# needs additional Platform SDK installation
+# Visual C++ 7.0, _MSC_VER 1300, msvcr70.dll
+#MSVC_VARIANT=DOTNET10
+
+# "Microsoft Visual Studio .NET 2003"
 # Visual C++ 7.1, _MSC_VER 1310, msvcr71.dll
 #MSVC_VARIANT=MSVC2003
 
-# "Microsoft Visual C++ Toolkit 2003" - NOT YET WORKING
+# "Microsoft .Net Framework SDK Version 1.1"
 # needs additional Platform SDK installation
 # Visual C++ 7.1, _MSC_VER 1310, msvcr71.dll
-#MSVC_VARIANT=VC2003TOOLKIT
+#MSVC_VARIANT=DOTNET11
+
+# "Microsoft Visual Studio 2005"
+# Visual C++ 8.0, _MSC_VER 1400, msvcr80.dll
+#MSVC_VARIANT=MSVC2005
 
-# "Microsoft .Net Framework SDK Version 1.1" - NOT YET WORKING
+# "Microsoft Visual C++ 2005 Express Edition"
 # needs additional Platform SDK installation
-# XXX - Visual C++ 7.1, _MSC_VER 1310, msvcr71.dll
-#MSVC_VARIANT=DOTNET11FRAMEWORK
+# Visual C++ 8.0, _MSC_VER 1400, msvcr80.dll
+#MSVC_VARIANT=MSVC2005EE
 
-# "Microsoft Visual Studio 2005" - EXPERIMENTAL
-# "Microsoft Visual C++ 2005 Express Edition" - EXPERIMENTAL
-# The "Express Edition" needs additional Platform SDK installation
+# "Microsoft .Net Framework 2.0 SDK"
+# needs additional Platform SDK installation
 # Visual C++ 8.0, _MSC_VER 1400, msvcr80.dll
-#MSVC_VARIANT=MSVC2005
+#MSVC_VARIANT=DOTNET20
+
+# "Microsoft Visual Studio 2008"
+# Visual C++ 9.0, _MSC_VER 1500, msvcr90.dll
+MSVC_VARIANT=MSVC2008
+
+# "Microsoft Visual C++ 2008 Express Edition"
+# Visual C++ 9.0, _MSC_VER 1500, msvcr90.dll
+#MSVC_VARIANT=MSVC2008EE
 
 #
-# Optional: Microsoft Platform SDK.
-# (Mandatory for some MSVC_VARIANTs, see above)
+# Optional: To compile some time critical code from assembler instead of C
 #
-# If you don't have the PSDK, comment this line out, so that 
-# PLATFORM_SDK_DIR isn't defined.
+# If you have the NASM compiler, set this to the NASM executable.
+# http://nasm.sourceforge.net/
 #
-# If you have installed a platform SDK, set this to the directory where it reside
-#PLATFORM_SDK_DIR=$(PROGRAM_FILES)\Microsoft Platform SDK for Windows Server 2003 R2
-
+# If you don't have NASM, comment this line out, so that NASM
+# isn't defined.
+#
+NASM=$(WIRESHARK_LIBS)\nasm-2.02\nasm.exe
 
 
 ##### Libraries #####
@@ -88,145 +130,119 @@ MSVC_VARIANT=MSVC6
 #
 # Mandatory: GLib settings
 #
-# Current versions of GTK+ 1.3 require GLib 2.0.  Earlier versions of
-# GTK+ 1.3 are buggy; we don't recommend using them, and we don't
-# support them.  Upgrade to at least GLib 2.0.
+# Please note: Since Wireshark release 1.0.0, we no longer support GLib1.x
 #
 GLIB_VERSION=2.0
 GLIB_DIR=$(WIRESHARK_LIBS)\glib
 
 #
-# Mandatory: GTK (& related) settings
-#
-# It's possible, to build both GTK version 1 and 2 at the same time,
-# or only one of the versions. GTK version 2 is recommended.
-# 
-# If you want building with GTK+ 1.3, set GTK1_DIR to the pathname of the 
-# "gtk+" directory; if you want building with GTK+ 2.x, set GTK2_DIR to 
-# the pathname of the directory in which the "include" and "lib" directories 
-# reside.
-#
-GTK1_DIR=$(WIRESHARK_LIBS)\gtk+
-GTK2_DIR=$(WIRESHARK_LIBS)\gtk2
-
+# Mandatory: GTK (& related libs) settings
 #
-# Mandatory for GTK >= 2: Version numbers of gtk2 and pango.
+# Please note: Since Wireshark release 1.0.0, we no longer support GTK1.x
 #
-# (MAJOR + MINOR Version number but without MICRO version number) 
-# These macros are used by the nsis installer script and by the setup target.
+# If you want building with GTK+, set GTK_DIR to the pathname of the 
+# directory in which the "include" and "lib" directories reside.
 #
-# GTK 2.6 is the mainline since Ethereal 0.10.14
-#GTK2_INST_VERSION=2.6
-#PANGO_INST_VERSION=1.8
-# Support for GTK 2.8 
-#GTK2_INST_VERSION=2.8
-#PANGO_INST_VERSION=1.14
-# Support for GTK 2.10 is currently experimental ...
-GTK2_INST_VERSION=2.10
-PANGO_INST_VERSION=1.14
+GTK_DIR=$(WIRESHARK_LIBS)\gtk2
 
 #
-# If you have GTK-Wimp, set this to the pathname of the directory in
-# which the files are stored.
+# Mandatory: Version numbers of GTK and pango.
 #
-# If you don't have GTK-Wimp, comment this line out, so that GTK-Wimp isn't
-# defined.
-#
-# Please note: GTK 2.8 (and later?) includes GTK-Wimp
-# (in this case these GTK-Wimp related settings will have no effect)
+# (MAJOR + MINOR Version number but without MICRO version number)
+# These macros are used by the nsis installer script and by the setup target.
 #
-GTK_WIMP_DIR=$(WIRESHARK_LIBS)\gtk-wimp\gtk-wimp-0.7.0-bin
+# GTK 2.12 is the mainline since Wireshark 0.99.7
+GTK_INST_VERSION=2.14
+PANGO_INST_VERSION=1.22
 
 #
 # Optional: WinPcap developer's pack to capture network traffic.
 #
-# The WinPcap developer's pack version Wireshark is build with.
+# If you have the WinPcap developer's pack (at least version 3.0),
+# set this to the directory in which the WinPcap developer's pack resides.
 #
-# If you don't have the WPdpack, comment this line out, so that 
-# WINPCAP_VERSION isn't defined.
-#
-#WINPCAP_VERSION=3.0
-WINPCAP_VERSION=3.1
-# XXX - what to set for 4.0 beta 1?
-#
-# If you have the WinPcap developer's pack, set this to the directory 
-# in which the WinPcap developer's pack resides.
-#
-# If you don't have the WPdpack, comment this line out, so that 
+# If you don't have the WPdpack, comment this line out, so that
 # PCAP_DIR isn't defined.
 #
 PCAP_DIR=$(WIRESHARK_LIBS)\WPdpack
 
 #
-# Optional: The ZLib enables unzipping of gzip compressed capture files 
+# Optional: WinPcap remote capture support and new API
+# (pcap_open(), pcap_findalldevs_ex(), etc.)
+#
+PCAP_REMOTE=1
+
+#
+# Optional: The ZLib enables unzipping of gzip compressed capture files
 # "on the fly".
 #
-# If you have Zlib, set this to directory in which the Zlib headers 
+# If you have Zlib, set this to directory in which the Zlib headers
 # and .lib file are stored.
 #
 # If you don't have Zlib, comment this line out, so that ZLIB_DIR isn't
 # defined.
 #
-# XXX - ZLIB must be recompiled on MSVC 2005 because of C runtime lib (msvcr)
-# problems, simply disable it for now on MSVC 2005 (and other none 6 versions)
-!IF "$(MSVC_VARIANT)" == "MSVC6"
-ZLIB_DIR=$(WIRESHARK_LIBS)\zlib123-dll
-!ENDIF
+ZLIB_DIR=$(WIRESHARK_LIBS)\zlib123
 
 #
-# Optional: The Net-SNMP library enables SNMP OID to name resolvings
-# for the MIBs available.
+# Optional: the ADNS library enables asynchronous (nonblocking) DNS
+# name resolvings.
 #
-# If you have Net-SNMP, set this to the pathname of the directory in
-# which the Net-SNMP headers and .lib file are stored.
+# If you have GNU ADNS, set this to the directory in which the GNU ADNS
+# .lib file is stored.
 #
-# If you don't have Net-SNMP, comment this line out, so that NET_SNMP_DIR
+# If you don't have GNU ADNS, comment this line out, so that ADNS_DIR
 # isn't defined.
 #
-NET_SNMP_DIR=$(WIRESHARK_LIBS)\net-snmp-5.4
+# If C_ARES_DIR is defined below, it will override this setting.
+#
+#ADNS_DIR=$(WIRESHARK_LIBS)\adns-1.0-win32-05ws
 
 #
-# Optional: the ADNS library enables asynchronous (nonblocking) DNS 
+# Optional: the c-ares library enables asynchronous (nonblocking) DNS
 # name resolvings.
 #
-# If you have GNU ADNS, set this to the directory in which the GNU ADNS 
-# .lib file is stored.
+# If you have c-ares, set this to the directory in which the c-ares
+# .lib file is stored. Setting this will override ADNS_DIR above. You
+# can't have both.
 #
-# If you don't have GNU ADNS, comment this line out, so that ADNS_DIR
+# If you're using Visual C++ 6.0, you'll have to use a platform SDK that
+# defines socklen_t, such as Windows Server 2003 PSDK.
+#
+# If you don't have c-ares, comment this line out, so that C_ARES_DIR
 # isn't defined.
 #
-ADNS_DIR=$(WIRESHARK_LIBS)\adns-1.0-win32-05
+C_ARES_DIR=$(WIRESHARK_LIBS)\c-ares-1.6.0ws
 
 #
-# Optional: the PCRE (Perl Compatible Regular Expressions) library 
+# Optional: the PCRE (Perl Compatible Regular Expressions) library
 # enables regular expressions for display filters.
 #
-# If you have the PCRE library, set this to the directory in which 
+# If you have the PCRE library, set this to the directory in which
 # the GNUWIN32 pcre-lib package is stored.
 #
 # If you don't have PCRE, comment this line out, so that PCRE_DIR
 # isn't defined.
 #
-PCRE_DIR=$(WIRESHARK_LIBS)\pcre-6.4
+PCRE_DIR=$(WIRESHARK_LIBS)\pcre-7.0
 
 #
 # Optional: the GNUTLS library enables ssl decryption.
 #
-# If you have the GNUTLS library, set this to the directory where 
+# If you have the GNUTLS library, set this to the directory where
 # the lib and include files are stored.
 #
 # If you don't have GNUTLS, comment this line out, so that GNUTLS_DIR
 # isn't defined.
 #
 # Platform SDK conflicts with openssl.h header
-!IFNDEF PLATFORM_SDK_DIR
-GNUTLS_DIR=$(WIRESHARK_LIBS)\gnutls-1.6.1-1
-!ENDIF
+#GNUTLS_DIR=$(WIRESHARK_LIBS)\gnutls-2.6.3-1
+GNUTLS_DIR=$(WIRESHARK_LIBS)\gnutls-2.6.4-1
 
 #
 # Optional: the KFW library enables kerberos/sasl/dcerpc decryption.
 #
-# If you have the kerberos for windows (mit) library, set this to the 
+# If you have the kerberos for windows (mit) library, set this to the
 # directory where the kfw package is stored.
 #
 # If you don't have KFW, comment this line out, so that KFW_DIR
@@ -237,7 +253,7 @@ KFW_DIR=$(WIRESHARK_LIBS)\kfw-2.5
 #
 # Optional: the Nettle library enables ??? decryption.
 #
-# If you have the Nettle encryption library, set this to the 
+# If you have the Nettle encryption library, set this to the
 # directory in which the nettle package is stored.
 #
 # If you don't have Nettle, comment this line out, so that NETTLE_DIR
@@ -248,39 +264,39 @@ KFW_DIR=$(WIRESHARK_LIBS)\kfw-2.5
 #
 # Optional: the LUA library enables scripting support.
 #
-# If you have the LUA library, set this to the directory in which 
+# If you have the LUA library, set this to the directory in which
 # the LUA package is stored.
 #
 # If you don't have LUA, comment this line out, so that LUA_DIR
 # isn't defined.
 #
-LUA_DIR=$(WIRESHARK_LIBS)\lua5.1
+LUA_DIR=$(WIRESHARK_LIBS)\lua5.1.4
 
 #
 # Optional: the PORTAUDIO library enables audio output for RTP streams.
 #
-# If you have the PORTAUDIO library (used for rtp_player), set this to 
+# If you have the PORTAUDIO library (used for rtp_player), set this to
 # the directory in which the PORTAUDIO library is stored.
 #
-# If you don't have PORTAUDIO, comment this line out, so that 
+# If you don't have PORTAUDIO, comment this line out, so that
 # PORTAUDIO_DIR isn't defined.
 #
 #PORTAUDIO_DIR=$(WIRESHARK_LIBS)\portaudio_v18_1
-PORTAUDIO_DIR=$(WIRESHARK_LIBS)\portaudio_v19
+PORTAUDIO_DIR=$(WIRESHARK_LIBS)\portaudio_v19_2
 
 #
 # Version number of PortAudio
-# 
+#
 #PORTAUDIO_VERSION=18
 PORTAUDIO_VERSION=19
 
 #
-# Mandatory for GTK >= 2: Iconv
-#
+# Iconv: Mandatory for Glib >= 2 and <= 2.14.4
+# [win-iconv statically linked as part of Glib >= 2.14.5]
 # Set ICONV_DIR to the directory in which the
 # ICONV include files and library resides.
 #
-ICONV_DIR=$(WIRESHARK_LIBS)\libiconv-1.9.1.bin.woe32
+##ICONV_DIR=$(WIRESHARK_LIBS)\libiconv-1.9.1.bin.woe32
 
 #
 # Mandatory for GTK >= 2: Gettext
@@ -288,22 +304,38 @@ ICONV_DIR=$(WIRESHARK_LIBS)\libiconv-1.9.1.bin.woe32
 # Set GETTEXT_DIR to the directory in which the
 # GETTEXT include files and library resides.
 #
-#GETTEXT_DIR=$(WIRESHARK_LIBS)\gettext-runtime-0.13.1
-GETTEXT_DIR=$(WIRESHARK_LIBS)\gettext-0.14.5
-
+#GETTEXT_DIR=$(WIRESHARK_LIBS)\gettext-0.14.5
+GETTEXT_DIR=$(WIRESHARK_LIBS)\gettext-runtime-0.17-1
 #
-# Optional: AirPcap developer's pack to capture wireless network traffic 
+# Optional: AirPcap developer's pack to capture wireless network traffic
 # incl. 802.11 management frames.
 #
-# If you have the AirPcap developer's pack, set this to the directory 
+# If you have the AirPcap developer's pack, set this to the directory
 # in which the AirPcap developer's pack resides.
 #
-# If you don't have the AirPcap developer's pack, comment this line out, 
+# If you don't have the AirPcap developer's pack, comment this line out,
 # so that AIRPCAP_DIR isn't defined.
 #
 AIRPCAP_DIR=$(WIRESHARK_LIBS)\AirPcap_Devpack_1_0_0_594\AirPcap_Devpack
 
+#
+# Optional: LIBSMI, System Management Interface
+#
+# Used for oid-name resolution for SNMP and other protocols
+#
+SMI_DIR=$(WIRESHARK_LIBS)\libsmi-0.4.8
 
+#
+# Optional: GeoIP, IP address database lookups
+#
+# Used to map IP addresses to MaxMind GeoIP database entries
+#
+# GeoIP requires IPv6 definitions that don't ship with Visual C++ 6.0.
+# However, the Microsoft Platform SDK for Windows Server 2003 R2 provides
+# these definitions. The SDK's SetEnv.bat script defines INETSDK.
+!IF "$(MSVC_VARIANT)" != "MSVC6" || DEFINED(INETSDK)
+GEOIP_DIR=$(WIRESHARK_LIBS)\GeoIP-1.4.5ws
+!ENDIF
 
 ##### Tools #####
 
@@ -317,7 +349,7 @@ CYGWIN_PATH=c:\cygwin\bin
 SH_PROG=bash
 
 # bash versions after 3.1.6 need the 'igncr' shell option to be able to
-#  process scripts in windows 'native format' (dos crlf format). 
+#  process scripts in windows 'native format' (dos crlf format).
 # The following !IF results in the option being used only if it is available
 #  since using it on bash version 3.1.6 (or earlier) is not required and
 #  will cause an error message.
@@ -331,19 +363,35 @@ SH=$(SH_PROG) $(SH_FLAGS)
 # command for perl (cygwin's perl package recommended)
 PERL=perl
 
-# command for pod2man and pod2html 
+# command for pod2man and pod2html
 # (part of the perl package, usually leave these unchanged)
 POD2MAN=$(SH) pod2man
 POD2HTML=$(SH) pod2html
 
-# command for native windows python (recommended)
-PYTHON="C:/python24/python.exe"
-# add native python to the path (not needed if cygwin's python is used)
-PATH=c:\python24;$(PATH)
+# Command for native Windows Python (recommended)
+# V2.4 to V2.6 should work
+
+# If you want to specify your Python settings, uncomment the lines below.
+#PYTHON="C:\Python26\python.exe"
+#PATH=c:\Python26;$(PATH)
 
-# command for python (cygwin's python package, not recommended)
+# Command for Cygwin's Python (not recommended)
 #PYTHON=env python
 
+# Otherwise, find Python automatically.
+!IF !DEFINED(PYTHON)
+!IF EXIST(c:\Python26\python.exe)
+PYTHON="C:\Python26\python.exe"
+PATH=c:\Python26;$(PATH)
+!ELSE IF EXIST(c:\Python25\python.exe)
+PYTHON="C:\Python25\python.exe"
+PATH=c:\Python25;$(PATH)
+!ELSE IF EXIST(c:\Python24\python.exe)
+PYTHON="C:\Python24\python.exe"
+PATH=c:\Python24;$(PATH)
+!ENDIF
+!ENDIF
+
 # command for lex/flexx (cygwin's flex recommended)
 LEX=flex
 
@@ -361,11 +409,11 @@ YACC=bison
 MAKENSIS="$(PROGRAM_FILES)\nsis\makensis.exe"
 
 #
-# Optional: To build the developers documentation with doxygen and dot.
-# Currently experimental only.
+# Optional: To build the developers API documentation with doxygen and dot.
+# Currently experimental, outdated and incomplete.
 #
 # You will have to download and install:
-# Doxygen from: www.doxygen.org
+# Doxygen from: http://www.doxygen.org
 # Graphviz from: http://www.research.att.com/sw/tools/graphviz/
 #
 # If you have doxygen, set this to the doxygen executable.
@@ -376,33 +424,68 @@ MAKENSIS="$(PROGRAM_FILES)\nsis\makensis.exe"
 #DOXYGEN="$(PROGRAM_FILES)/doxygen/bin/doxygen.exe"
 
 #
-# Optional: To build compressed html help format .chm and use it as online help format.
-# You will have to download and install the html help compiler from:
+# Recommended: Use the compressed html help format .chm as the Wireshark integrated help.
+#
+# The required htmlhelp.h and htmlhelp.lib should be included in MSVC_VARIANT > MSVC6.
+#
+# For MSVC_VARIANT == MSVC6 you will have to download and install the html help workshop from:
 #
 # http://msdn.microsoft.com/library/default.asp?url=/library/en-us/htmlhelp/html
-# /hwMicrosoftHTMLHelpDownloads.asp 
+# /hwMicrosoftHTMLHelpDownloads.asp
 #
 # Then point HHC_DIR to the html help dir (where hhc.exe resides).
 #
 # If you don't want the online help (or don't have the tools),
 # comment this line out, so that HHC_DIR isn't defined.
 #
-#HHC_DIR="$(PROGRAM_FILES)/HTML Help Workshop/"
+HHC_DIR=$(PROGRAM_FILES)/HTML Help Workshop
 
+#
+# Optional: To reduce the size of dlls and exes, which is especially useful for USB device distributions (U3, PortableApps)
+#
+# If you have the UPX package, set this to the upx.exe executable.
+#
+# UPX can be downloaded from:
+#   http://upx.sourceforge.net/
+#
+# If you don't have UPX, or don't want to pack exes and dlls,
+# comment this line out, so that UPX isn't defined.
+#
 
+UPX=$(WIRESHARK_LIBS)\upx301w\upx.exe
 
 ##### Flags, PATHs and Miscellaneous #####
 
+# "convert" the MSVC variant into the required MSC compiler version
+!IF "$(MSVC_VARIANT)" == "MSVC6"
+MSC_VER_REQUIRED=1200
+!ELSEIF "$(MSVC_VARIANT)" == "MSVC2002" || "$(MSVC_VARIANT)" == "DOTNET10"
+MSC_VER_REQUIRED=1300
+!ELSEIF "$(MSVC_VARIANT)" == "MSVC2003" || "$(MSVC_VARIANT)" == "DOTNET11"
+MSC_VER_REQUIRED=1310
+!ELSEIF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20"
+MSC_VER_REQUIRED=1400
+!ELSEIF "$(MSVC_VARIANT)" == "MSVC2008" ||  "$(MSVC_VARIANT)" == "MSVC2008EE"
+MSC_VER_REQUIRED=1500
+!ELSE
+!ERROR MSVC_VARIANT unknown
+!ENDIF
+
 # Compiler flags:
 # /W3  warning level 3 (0 less - 4 most, 1 default)
 # /Zi  create .pdb file for debugging
-# /D_CRT_SECURE_NO_DEPRECATE don't warn for "insecure" calls, see MSDN "Security Enhancements in the CRT"
-# /D_CRT_NONSTDC_NO_DEPRECATE don't warn for "Deprecated CRT Functions" as MSDN calls this
-#
-!IF "$(MSVC_VARIANT)" == "MSVC6"
-LOCAL_CFLAGS=/Zi /W3
-!ELSEIF "$(MSVC_VARIANT)" == "MSVC2005"
-LOCAL_CFLAGS=/Zi /W3 /D_CRT_SECURE_NO_DEPRECATE /D_CRT_NONSTDC_NO_DEPRECATE
+# /MD  use "Multithreading Debug" libraries
+# /D_CRT_SECURE_NO_DEPRECATE        Don't warn for "insecure" calls, see MSDN "Security Enhancements in the CRT"
+# /D_CRT_NONSTDC_NO_DEPRECATE       Don't warn for "Deprecated CRT Functions" as MSDN calls this
+# /D_BIND_TO_CURRENT_CRT_VERSION=1  Make sure our CRT and manifest versions match (http://msdn.microsoft.com/en-us/library/cc664727.aspx)
+# /DWIN32_LEAN_AND_MEAN             Don't include unnecessary Windows include files (see windows.h)
+# /MP [<number of processes>]       [MSVC2008]: Compiles multiple source files by using multiple processes 
+#                                               Add if desired for compile speedup on machines with 2 or more "effective processors"
+#
+!IF "$(MSVC_VARIANT)" == "MSVC6" || "$(MSVC_VARIANT)" == "MSVC2002" || "$(MSVC_VARIANT)" == "DOTNET10" || "$(MSVC_VARIANT)" == "MSVC2003" || "$(MSVC_VARIANT)" == "DOTNET11"
+LOCAL_CFLAGS=/Zi /W3 /MD /DWIN32_LEAN_AND_MEAN /DMSC_VER_REQUIRED=$(MSC_VER_REQUIRED)
+!ELSEIF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20" || "$(MSVC_VARIANT)" == "MSVC2008" || "$(MSVC_VARIANT)" == "MSVC2008EE"
+LOCAL_CFLAGS=/Zi /W3 /MD /D_CRT_SECURE_NO_DEPRECATE /D_CRT_NONSTDC_NO_DEPRECATE /DWIN32_LEAN_AND_MEAN /DMSC_VER_REQUIRED=$(MSC_VER_REQUIRED) /D_BIND_TO_CURRENT_CRT_VERSION=1
 !ELSE
 !ERROR MSVC_VARIANT unknown
 !ENDIF
@@ -412,27 +495,10 @@ LOCAL_CFLAGS=/Zi /W3 /D_CRT_SECURE_NO_DEPRECATE /D_CRT_NONSTDC_NO_DEPRECATE
 # /PROFILE generate map file(s) for profiling
 # /DEFAULTLIB:xxx use xxx as the standard C library
 # /NODEFAULTLIB:xxx don't use xxx as the standard C library
-# 
-!IF "$(MSVC_VARIANT)" == "MSVC6"
-LOCAL_LDFLAGS=/DEBUG 
-!ELSEIF "$(MSVC_VARIANT)" == "MSVC2005"
-#LOCAL_LDFLAGS=/DEBUG /DEFAULTLIB:msvcrt /NODEFAULTLIB:libc /NODEFAULTLIB:libcmt
-LOCAL_LDFLAGS=/DEBUG /DEFAULTLIB:msvcrt /NODEFAULTLIB:libc /NODEFAULTLIB:libcmt
-!ELSE
-!ERROR MSVC_VARIANT unknown
-!ENDIF
-
-WS_PLUGIN_LDFLAGS=/DEBUG /NOLOGO /INCREMENTAL:no /MACHINE:I386 
-
-
-# 
-# Optional: Use the User's Guide as the online help system
-# (currently experimental).
 #
-# If you don't have the User's Guide, comment this line out, so that 
-# ENABLE_WSUG isn't defined.
-#
-#ENABLE_WSUG=USE
+LOCAL_LDFLAGS=/DEBUG /MACHINE:$(TARGET_MACHINE)
+
+PLUGIN_LDFLAGS = /NOLOGO /INCREMENTAL:no $(LOCAL_LDFLAGS)
 
 #
 # According to http://bugs.wireshark.org/bugzilla/show_bug.cgi?id=403
@@ -449,12 +515,99 @@ COPYCMD=/y
 ENABLE_LIBWIRESHARK=USE
 
 #
-# install (debug) directory for Wireshark GTK1 version (relative to your source dir)
-INSTALL1_DIR=wireshark-gtk1
+# install (debug) directory for Wireshark (relative to your source dir)
+INSTALL_DIR=wireshark-gtk2
+
+
+
+##### C-Runtime Redistributable #####
+#
+# The C-Runtime since Version 7 must be shipped together with
+# the program installer, to avoid missing msvcr*.dll files on
+# the target machine.
+#
+# The location of these files differ on the various compiler
+# packages, the following will use the default paths depending
+# on the package version.
+#
+!IF "$(MSVC_VARIANT)" == "MSVC6"
+# msvcrt.dll will already be available on target machines - nothing additional to install
+
+!ELSEIF "$(MSVC_VARIANT)" == "MSVC2002"
+# you probably need to tweak this directory if you don't use the professional edition!
+MSVCR_DLL=$(PROGRAM_FILES)\Microsoft Visual Studio .NET\Visual Studio .NET Professional - English\msvcr70.dll
+
+!ELSEIF "$(MSVC_VARIANT)" == "DOTNET10"
+# no redistributable available for this package!
+
+!ELSEIF "$(MSVC_VARIANT)" == "MSVC2003"
+# you probably need to tweak this directory if you don't use the professional edition!
+MSVCR_DLL=$(PROGRAM_FILES)\Microsoft Visual Studio .NET 2003\Visual Studio .NET Professional 2003 - English\msvcr71.dll
+
+!ELSEIF "$(MSVC_VARIANT)" == "DOTNET11"
+# no redistributable available for this package!
+
+!ELSEIF "$(MSVC_VARIANT)" == "MSVC2005"
+MSVCR_DLL=$(PROGRAM_FILES)\Microsoft Visual Studio 8\VC\redist\x86\Microsoft.VC80.CRT\*.*
+
+!ELSEIF "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20" || "$(MSVC_VARIANT)" == "MSVC2008EE"
+# you need to download the redistributable package vcredist_x86.exe from Microsoft first,
+# and copy it to the lib folder!!!
+VCREDIST_EXE=$(WIRESHARK_LIBS)\vcredist_x86.exe
+
+!ELSEIF "$(MSVC_VARIANT)" == "MSVC2008"
+MSVCR_DLL=$(PROGRAM_FILES)\Microsoft Visual Studio 9.0\VC\redist\x86\Microsoft.VC90.CRT\*.*
+
+!ELSE
+!ERROR MSVC_VARIANT unknown
+!ENDIF
+
+
+
+##### Advanced: Docbook/XML documentation generation #####
+# If you want to generate the Docbook/XML based docs (User's and Developer's
+# Guide, ...), you'll need some additional tools / libraries compared to the
+# rest of the build process.
+#
+# FOR DETAILED INSTRUCTIONS TO GENERATE THE DOCS, SEE: docbook\readme.txt.
+#
+# If you don't call the Makefile.nmake in the docbook dir to generate the
+# docs, the following settings in this section will have no effect.
+
+# formatting objects processor executable
+# Comment this out if you don't have fop installed or you don't want the docs
+# in PDF format.
+!IFNDEF FOP
+FOP=fop-0.20.5\fop.bat
+!ENDIF
+
+# Additional options to fop.
+FOP_OPTS=-Xmx256m
 
+# html help compiler
+# Comment this out if you don't have hhc.exe or you don't want the docs in
+# .chm format.
 #
-# install (debug) directory for Wireshark GTK2 version (relative to your source dir)
-INSTALL2_DIR=wireshark-gtk2
+# Beware: hhc.exe is NOT part of the MSVC packages in HHC_DIR mentioned above,
+# so you'll need to install the HTML Help Workshop for this.
+HHC_EXE="$(HHC_DIR)\hhc.exe"
+
+# html to text converter for text version of release notes, e.g. elinks.
+# This could also be "lynx", or "true" if neither elinks nor lynx is installed
+# (cygwin: lynx works, elinks not available, links and true doesn't produce output)
+#HTML2TXT=elinks -dump -dump-width 72
+#HTML2TXT=links -dump -width 72
+#HTML2TXT=lynx -dump -width=72 -nolist -stdin
+
+!IFNDEF HTML2TXT
+HTML2TXT=$(PYTHON) $(TOOLS_DIR)\html2text.py --width=72 --no-links
+!ENDIF
+
+# the XSL processor (part of cygwin's libxslt package)
+XSLTPROC="xsltproc"
+
+# the XML validator (part of cygwin's libxml2 package)
+XMLLINT="xmllint"
 
 
 
@@ -470,25 +623,20 @@ INSTALL2_DIR=wireshark-gtk2
 #
 ##############################################################################
 
-!IFDEF ENABLE_LIBWIRESHARK
-# Uncomment next line to link plugins with the import library of libwireshark.dll 
-LINK_PLUGINS_WITH_LIBWIRESHARK=USE
-!ENDIF
-
 #
-# The RC_VERSION should be comma-separated, not dot-separated, 
+# The RC_VERSION should be comma-separated, not dot-separated,
 # as per Graham Bloice's message in
 #
 #      http://www.ethereal.com/lists/ethereal-dev/200303/msg00283.html
 #
-# "The RC_VERSION variable in config.nmake should be comma separated. 
+# "The RC_VERSION variable in config.nmake should be comma separated.
 # This allows the resources to be built correctly and the version
 # number to be correctly displayed in the explorer properties dialog
 # for the executables, and XP's tooltip, rather than 0.0.0.0."
 #
 
 VERSION=$(VERSION_MAJOR).$(VERSION_MINOR).$(VERSION_MICRO)$(VERSION_EXTRA)
-RC_VERSION=$(VERSION_MAJOR),$(VERSION_MINOR),$(VERSION_MICRO)
+RC_VERSION=$(VERSION_MAJOR),$(VERSION_MINOR),$(VERSION_MICRO),$(VERSION_BUILD)
 
 WTAP_VERSION=$(WTAP_VERSION_MAJOR).$(WTAP_VERSION_MINOR).$(WTAP_VERSION_MICRO)
 RC_WTAP_VERSION=$(WTAP_VERSION_MAJOR),$(WTAP_VERSION_MINOR),$(WTAP_VERSION_MICRO)
@@ -502,69 +650,56 @@ GLIB_LIBS=$(GLIB_DIR)\lib\glib-$(GLIB_VERSION).lib \
        $(GLIB_DIR)\lib\gmodule-$(GLIB_VERSION).lib \
        $(GLIB_DIR)\lib\gobject-$(GLIB_VERSION).lib
 
-# GTK+ 1.3
-GTK1_CFLAGS=$(GLIB_CFLAGS) /I$(GTK1_DIR)\include /I$(GTK1_DIR)\include\gdk \
-       /I$(GTK1_DIR)\lib\gtk+\include
-GTK1_LIBS=$(GTK1_DIR)\lib\gtk.lib \
-       $(GTK1_DIR)\lib\gdk.lib \
-       $(GLIB_LIBS)
-
-# GTK+ 2.x
-GTK2_CFLAGS=$(GLIB_CFLAGS) /I$(GTK2_DIR)\include\gtk-2.0 \
-       /I$(GTK2_DIR)\lib\gtk-2.0\include \
-       /I$(GTK2_DIR)\include\atk-1.0 \
-       /I$(GTK2_DIR)\include\cairo \
-       /I$(GTK2_DIR)\include\pango-1.0
-GTK2_LIBS=$(GTK2_DIR)\lib\gtk-win32-2.0.lib \
-       $(GTK2_DIR)\lib\gdk-win32-2.0.lib \
-       $(GTK2_DIR)\lib\gdk_pixbuf-2.0.lib \
-       $(GTK2_DIR)\lib\pango-1.0.lib \
+# GTK+
+GTK_CFLAGS=$(GLIB_CFLAGS) /I$(GTK_DIR)\include\gtk-2.0 \
+       /I$(GTK_DIR)\lib\gtk-2.0\include \
+       /I$(GTK_DIR)\include\atk-1.0 \
+       /I$(GTK_DIR)\include\cairo \
+       /I$(GTK_DIR)\include\pango-1.0
+GTK_LIBS=$(GTK_DIR)\lib\gtk-win32-2.0.lib \
+       $(GTK_DIR)\lib\gdk-win32-2.0.lib \
+       $(GTK_DIR)\lib\gdk_pixbuf-2.0.lib \
+       $(GTK_DIR)\lib\pango-1.0.lib \
        $(GLIB_LIBS)
 
-!IF "$(GTK2_INST_VERSION)" == "2.10"
-GTK2_LIB_DIR=2.10.0
+!IF "$(GTK_INST_VERSION)" == "2.14"
+GTK_LIB_DIR=2.10.0
 NEED_LIBPNG_DLL=USE
+NEED_LIBJPEG_DLL=USE
+NEED_LIBTIFF_DLL=USE
 NEED_CAIRO_DLL=USE
-GTK_WIMP_DIR=DUMMY_TO_USE_WIMP
-GTK_WIMP_DLLSRC_DIR=$(GTK2_DIR)\lib\gtk-2.0\2.10.0\engines
+GTK_WIMP_DLLSRC_DIR=$(GTK_DIR)\lib\gtk-2.0\2.10.0\engines
 GTK_WIMP_DLLDST_DIR=lib\gtk-2.0\2.10.0\engines
-GTK_WIMP_RCSRC_DIR=$(GTK2_DIR)\share\themes\MS-Windows\gtk-2.0
+GTK_WIMP_RCSRC_DIR=$(GTK_DIR)\share\themes\MS-Windows\gtk-2.0
 GTK_WIMP_RCDST_DIR=etc\gtk-2.0
-!ELSEIF "$(GTK2_INST_VERSION)" == "2.8"
-# the lib dir of GTK2.6 didn't changed since 2.4.0
-GTK2_LIB_DIR=2.4.0
+!ELSEIF "$(GTK_INST_VERSION)" == "2.12"
+GTK_LIB_DIR=2.10.0
 NEED_LIBPNG_DLL=USE
+NEED_LIBJPEG_DLL=USE
+NEED_LIBTIFF_DLL=USE
 NEED_CAIRO_DLL=USE
-GTK_WIMP_DIR=DUMMY_TO_USE_WIMP
-GTK_WIMP_DLLSRC_DIR=$(GTK2_DIR)\lib\gtk-2.0\2.4.0\engines
-GTK_WIMP_DLLDST_DIR=lib\gtk-2.0\2.4.0\engines
-GTK_WIMP_RCSRC_DIR=$(GTK2_DIR)\share\themes\MS-Windows\gtk-2.0
+GTK_WIMP_DLLSRC_DIR=$(GTK_DIR)\lib\gtk-2.0\2.10.0\engines
+GTK_WIMP_DLLDST_DIR=lib\gtk-2.0\2.10.0\engines
+GTK_WIMP_RCSRC_DIR=$(GTK_DIR)\share\themes\MS-Windows\gtk-2.0
 GTK_WIMP_RCDST_DIR=etc\gtk-2.0
-!ELSEIF "$(GTK2_INST_VERSION)" == "2.6"
-GTK2_LIB_DIR=2.4.0
-GTK_WIMP_DLLSRC_DIR=$(GTK_WIMP_DIR)
-GTK_WIMP_DLLDST_DIR=lib\gtk-2.0\2.4.0\engines
-GTK_WIMP_RCSRC_DIR=$(GTK_WIMP_DIR)\Theme\gtk-2.0
-GTK_WIMP_RCDST_DIR=share\themes\Default\gtk-2.0
-GTK_THEME_DIR=$(GTK_WIMP_DIR)\Theme\gtk-2.0
+!ELSE
+!ERROR ? Unknown or invalid GTK_INST_VERSION
 !ENDIF
 
-# the lib dir of PANGO changed in 1.12
-!IF "$(PANGO_INST_VERSION)" == "1.14"
+!IF "$(PANGO_INST_VERSION)" == "1.22"
 PANGO_LIB_DIR=1.5.0
-!ELSEIF "$(PANGO_INST_VERSION)" == "1.10"
-PANGO_LIB_DIR=1.4.0
-!ELSEIF "$(PANGO_INST_VERSION)" == "1.8"
-PANGO_LIB_DIR=1.4.0
-!ELSEIF "$(PANGO_INST_VERSION)" == "1.4"
-PANGO_LIB_DIR=1.4.0
-!ELSEIF "$(PANGO_INST_VERSION)" == "1.2"
-PANGO_LIB_DIR=1.2.0
+!ELSEIF "$(PANGO_INST_VERSION)" == "1.18"
+PANGO_LIB_DIR=1.5.0
+!ELSEIF "$(PANGO_INST_VERSION)" == "1.16"
+PANGO_LIB_DIR=1.5.0
+!ELSE
+!ERROR ? Unknown or invalid PANGO_INST_VERSION
 !ENDIF
 
 !IFDEF AIRPCAP_DIR
 AIRPCAP_CONFIG=^#define HAVE_AIRPCAP 1
 AIRPDCAP_CONFIG=^#define HAVE_AIRPDCAP 1
+#AIRPCAP_CFLAGS=/I$(AIRPCAP_DIR)\include
 !ELSE
 AIRPCAP_CONFIG=
 AIRPDCAP_CONFIG=
@@ -573,67 +708,79 @@ AIRPDCAP_CONFIG=
 !IFDEF PCAP_DIR
 # Nmake uses carets to escape special characters
 WINPCAP_CONFIG=^#define HAVE_LIBPCAP 1
-!IF "$(WINPCAP_VERSION)" == "3.0" || "$(WINPCAP_VERSION)" == "3.1"
 PCAP_FINDALLDEVS_CONFIG=^#define HAVE_PCAP_FINDALLDEVS 1
 PCAP_DATALINK_NAME_TO_VAL_CONFIG=^#define HAVE_PCAP_DATALINK_NAME_TO_VAL 1
 PCAP_DATALINK_VAL_TO_NAME_CONFIG=^#define HAVE_PCAP_DATALINK_VAL_TO_NAME 1
 # PCAP_BREAKLOOP won't have any benefit on Win32, but breaks compatibility with 3.0
-#!IF "$(WINPCAP_VERSION)" == "3.1"
-#PCAP_BREAKLOOP_CONFIG=^#define HAVE_PCAP_BREAKLOOP 1
-#!ELSE
 PCAP_BREAKLOOP_CONFIG=
-#!ENDIF
 WPCAP_CONSTIFIED_CONFIG=^#define WPCAP_CONSTIFIED 1
 !ELSE
+# no WpdPack installed
+WINPCAP_CONFIG=
 PCAP_FINDALLDEVS_CONFIG=
 PCAP_DATALINK_NAME_TO_VAL_CONFIG=
 PCAP_DATALINK_VAL_TO_NAME_CONFIG=
 PCAP_BREAKLOOP_CONFIG=
 WPCAP_CONSTIFIED=
 !ENDIF
+
+PCAP_LIST_DATALINKS_CONFIG=^#define HAVE_PCAP_LIST_DATALINKS 1
+PCAP_SET_DATALINK_CONFIG=^#define HAVE_PCAP_SET_DATALINK 1
+
+!IF DEFINED(PCAP_DIR) && DEFINED(PCAP_REMOTE)
+PCAP_HAVE_REMOTE_CONFIG=^#define HAVE_REMOTE 1
+PCAP_REMOTE_CONFIG=^#define HAVE_PCAP_REMOTE 1
+PCAP_OPEN_CONFIG=^#define HAVE_PCAP_OPEN 1
+PCAP_FINDALLDEVS_EX_CONFIG=^#define HAVE_PCAP_FINDALLDEVS_EX 1
+PCAP_CREATESRCSTR_CONFIG=^#define HAVE_PCAP_CREATESRCSTR 1
+PCAP_SETSAMPLING_CONFIG=^#define HAVE_PCAP_SETSAMPLING 1
 !ELSE
-WINPCAP_CONFIG=
-PCAP_FINDALLDEVS_CONFIG=
-PCAP_DATALINK_NAME_TO_VAL_CONFIG=
-PCAP_DATALINK_VAL_TO_NAME_CONFIG=
-PCAP_BREAKLOOP_CONFIG=
-WPCAP_CONSTIFIED=
+PCAP_HAVE_REMOTE_CONFIG=
+PCAP_REMOTE_CONFIG=
+PCAP_OPEN_CONFIG=
+PCAP_FINDALLDEVS_EX_CONFIG=
+PCAP_CREATESRCSTR_CONFIG=
+PCAP_SETSAMPLING_CONFIG=
 !ENDIF
 
 !IFDEF ZLIB_DIR
 ZLIB_PATH=$(ZLIB_DIR)
 ZLIB_CFLAGS=/I$(ZLIB_DIR)\include
 ZLIB_LIBS=$(ZLIB_DIR)\lib\zdll.lib
+ZLIB_DLL=$(ZLIB_DIR)\zlib1.dll
 # Nmake uses carets to escape special characters
 ZLIB_CONFIG=^#define HAVE_LIBZ 1
 !else
 ZLIB_CFLAGS=
 ZLIB_LIBS=
+ZLIB_DLL=
 ZLIB_CONFIG=
 !ENDIF
 
-!IFDEF NET_SNMP_DIR
-NET_SNMP_CFLAGS=/I$(NET_SNMP_DIR)\include /I$(NET_SNMP_DIR)\win32
-NET_SNMP_LIBS=$(NET_SNMP_DIR)\win32\lib\release\netsnmp.lib
+!IFDEF C_ARES_DIR
+!UNDEF ADNS_DIR
+C_ARES_CFLAGS=/I$(C_ARES_DIR)
+C_ARES_LIBS=$(C_ARES_DIR)\cares.lib
+C_ARES_DLL=$(C_ARES_DIR)\cares.dll
 # Nmake uses carets to escape special characters
-NET_SNMP_CONFIG=^#define HAVE_NET_SNMP 1
+C_ARES_CONFIG=^#define HAVE_C_ARES 1
 !else
-NET_SNMP_CFLAGS=
-NET_SNMP_LIBS=
-NET_SNMP_CONFIG=
-!ENDIF
-
+C_ARES_CFLAGS=
+C_ARES_LIBS=
+C_ARES_CONFIG=
 !IFDEF ADNS_DIR
 ADNS_PATH=$(ADNS_DIR)\adns_win32\lib
 ADNS_CFLAGS=/I$(ADNS_DIR)\src /I$(ADNS_DIR)\adns_win32
-ADNS_LIBS=$(ADNS_DIR)\adns_win32\lib\adns_dll.lib
+ADNS_LIBS=$(WIRESHARK_LIBS)\$(MSVC_VARIANT)\adns\adns_dll.lib
+ADNS_DLL=$(WIRESHARK_LIBS)\$(MSVC_VARIANT)\adns\adns_dll.dll
 # Nmake uses carets to escape special characters
 ADNS_CONFIG=^#define HAVE_GNU_ADNS 1
 !else
 ADNS_CFLAGS=
 ADNS_LIBS=
 ADNS_CONFIG=
-!ENDIF
+!ENDIF # ADNS
+!ENDIF # C_ARES
 
 !IFDEF KFW_DIR
 KFW_PATH=$(KFW_DIR)\bin
@@ -672,12 +819,13 @@ NETTLE_CONFIG=
 
 !IFDEF GNUTLS_DIR
 GNUTLS_PATH=$(GNUTLS_DIR)
-GNUTLS_CFLAGS=/I$(GNUTLS_DIR)\include
+# /DNOCRYPT avoids inclusion of Wincrypt.h, avoiding a X509_NAME define clash
+GNUTLS_CFLAGS=/I$(GNUTLS_DIR)\include /DNOCRYPT /DIMPORT_LIGNUTLSDLL
 GNUTLS_LIBS=\
        $(GNUTLS_DIR)\bin\libtasn1-3.lib        \
        $(GNUTLS_DIR)\bin\libgpg-error-0.lib    \
        $(GNUTLS_DIR)\bin\libgcrypt-11.lib      \
-       $(GNUTLS_DIR)\bin\libgnutls-13.lib
+       $(GNUTLS_DIR)\bin\libgnutls-26.lib
 # Nmake uses carets to escape special characters
 GNUTLS_CONFIG=^#define HAVE_LIBGNUTLS 1
 LIBGCRYPT_CONFIG=^#define HAVE_LIBGCRYPT 1
@@ -690,7 +838,7 @@ LIBGCRYPT_CONFIG=
 
 !IFDEF LUA_DIR
 LUA_CFLAGS=/I$(LUA_DIR)\include
-LUA_LIBS=$(LUA_DIR)\lib\dll\lua5.1.lib
+LUA_LIBS=$(LUA_DIR)\lua5.1.lib
 # Nmake uses carets to escape special characters
 LUA_CONFIG=^#define HAVE_LUA 1
 LUA_VERSION=^#define HAVE_LUA_5_1 1
@@ -708,33 +856,64 @@ PORTAUDIO_CONFIG=^#define HAVE_LIBPORTAUDIO 1
 PORTAUDIO_CFLAGS=/I$(PORTAUDIO_DIR)\pa_common
 PORTAUDIO_API_CONFIG=^#define PORTAUDIO_API_1 1
 !ELSE
-PORTAUDIO_CFLAGS=/I$(PORTAUDIO_DIR)\include /I$(PORTAUDIO_DIR)\src\common
+PORTAUDIO_CFLAGS=/I$(PORTAUDIO_DIR)\include /I$(PORTAUDIO_DIR)\src\common /I$(PORTAUDIO_DIR)\src\os\win /DPA_NO_DS /DPA_NO_ASIO
 !ENDIF
-
-!else
+!ELSE
 PORTAUDIO_CFLAGS=
 PORTAUDIO_CONFIG=
 !ENDIF
 
 !IFDEF HHC_DIR
-HHC_CFLAGS=/I$(HHC_DIR)\include -DHHC_DIR
-HHC_LIBS=$(HHC_DIR)\lib\htmlhelp.lib
+!IF "$(MSVC_VARIANT)" == "MSVC6"
+HHC_CFLAGS=/I"$(HHC_DIR)\include" -DHHC_DIR
+HHC_LIBS="$(HHC_DIR)\lib\htmlhelp.lib"
+!ELSE
+HHC_CFLAGS=-DHHC_DIR
+HHC_LIBS=htmlhelp.lib
+!ENDIF
 !ELSE
 HHC_CFLAGS=
 HHC_LIBS=
 !ENDIF
 
+!IFDEF SMI_DIR
+SMI_CONFIG=^#define HAVE_LIBSMI 1
+SMI_CFLAGS=/I$(SMI_DIR)\include
+SMI_LIBS=$(SMI_DIR)\lib\smi.lib
+!ELSE
+SMI_LIBS=
+SMI_CFLAGS=
+SMI_CONFIG=
+!ENDIF
+
+!IFDEF GEOIP_DIR
+GEOIP_CONFIG=^#define HAVE_GEOIP 1
+GEOIP_CFLAGS=/I$(GEOIP_DIR)\libGeoIP
+GEOIP_LIBS=$(GEOIP_DIR)\libGeoIP\GeoIP.lib
+!ELSE
+GeoIP_LIBS=
+GeoIP_CFLAGS=
+GeoIP_CONFIG=
+!ENDIF
+
 !IFDEF ENABLE_LIBWIRESHARK
 LIBWIRESHARK_CONFIG=^#define HAVE_LIBWIRESHARKDLL 1
+# Link plugins with the import library of libwireshark.dll
+LINK_PLUGINS_WITH_LIBWIRESHARK=USE
 !ELSE
 LIBWIRESHARK_CONFIG=
 !ENDIF
 
-!IFDEF ENABLE_WSUG
-WSUG_CFLAGS=-DENABLE_WSUG
+# Construct the path
+!IFDEF ICONV_DIR
+PATH=$(PATH);$(CYGWIN_PATH);$(GLIB_DIR)\bin;$(GETTEXT_DIR)\bin;$(ICONV_DIR)\bin;$(ZLIB_PATH);$(ADNS_PATH)
 !ELSE
-WSUG_CFLAGS=
+PATH=$(PATH);$(CYGWIN_PATH);$(GLIB_DIR)\bin;$(GETTEXT_DIR)\bin;$(ZLIB_PATH);$(ADNS_PATH)
 !ENDIF
 
-# Construct the path
-PATH=$(PATH);$(CYGWIN_PATH);$(GLIB_DIR)\bin;$(GETTEXT_DIR)\bin;$(ICONV_DIR)\bin;$(ZLIB_PATH);$(ADNS_PATH)
+# We can't use a lot of IPv6 code with plain Visual C++ 6.0
+!IF "$(MSVC_VARIANT)" == "MSVC6" && !DEFINED(MSSDK)
+INET6_CONFIG=
+!ELSE
+INET6_CONFIG=^#define INET6 1
+!ENDIF