3 # Some more information about the settings in this file can be found in
4 # the file README.windows and the Developer's Guide (available online).
6 ##### Program name #####
7 # Changing the name is experimental and may break the installer/unistaller and possibly other stuff.
8 # Application data will still be under the same dir as Wireshark so perference files profiles etc
9 # will be shared with a "normal" Wireshark installation.
10 # Note that suport libararies needs to be in PROGRAM_NAME-libs...
13 PROGRAM_NAME=Wireshark
16 ##### Target platform #####
17 # Only "win32" and "win64" are valid (for now).
18 # This can be defined in the system environment.
19 !IFNDEF WIRESHARK_TARGET_PLATFORM
20 WIRESHARK_TARGET_PLATFORM=win32
25 # The SVN revision of our build. Updated by make-version.pl
28 # The current Wireshark version. Recommended: Leave unchanged.
29 # Updated by make-version.pl
33 VERSION_BUILD=$(SVN_REVISION)
35 # Local build information. Recommended: Unique string for your
36 # environment, e.g. "-JackStackBarbecue". Updated by make-version.pl
40 # The version of the wiretap library. Recommended: Leave unchanged.
41 WTAP_VERSION_MAJOR=$(VERSION_MAJOR)
42 WTAP_VERSION_MINOR=$(VERSION_MINOR)
45 ##### Directories #####
48 # Base directory, where your libraries reside, which are needed to
49 # compile the sources. This setting is used only inside this file.
50 # This can be defined in the system environment.
52 !IFNDEF WIRESHARK_LIB_DIR
53 WIRESHARK_LIB_DIR=C:\$(PROGRAM_NAME)-$(WIRESHARK_TARGET_PLATFORM)-libs
57 # Base directory, where your programs reside.
58 # This setting is used only inside this file.
60 PROGRAM_FILES=$(PROGRAMFILES)
63 # Location of the "tools" directory. This affects HTML2TXT below and should
64 # be overridden by makefiles in any subdirectories that use HTML2TXT.
70 # Machine type for the compiler and linker
71 # TARGET_MACHINE (Used for link /MACHINE) should be one of "X86" or "X64"
72 # (sorry ARM, Alpha, MIPS, and Itanium fans).
73 # CPU (Used by win32.mak) should be one of "i386" or "AMD64".
74 # PROCESSOR_ARCHITECTURE (Used for redistributable packages and
75 # manifests) should be one of "x86" or "amd64".
76 !if "$(WIRESHARK_TARGET_PLATFORM)" == "win32"
79 PROCESSOR_ARCHITECTURE=x86
80 !else if "$(WIRESHARK_TARGET_PLATFORM)" == "win64"
83 PROCESSOR_ARCHITECTURE=amd64
85 !error Your mysterious moon-man architecture "$(WIRESHARK_TARGET_PLATFORM)" frightens and confuses us.
89 ##### Microsoft Visual C / Studio Variant #####
90 # For the different Studios, see: http://en.wikipedia.org/wiki/Microsoft_Visual_Studio
91 # Only one of the following MSVC_VARIANT settings should be used
93 # "Microsoft Visual Studio 2005"
94 # Visual C++ 8.0, _MSC_VER 1400, msvcr80.dll
95 #MSVC_VARIANT=MSVC2005
97 # "Microsoft Visual C++ 2005 Express Edition"
98 # needs additional Platform SDK installation
99 # Visual C++ 8.0, _MSC_VER 1400, msvcr80.dll
100 #MSVC_VARIANT=MSVC2005EE
102 # "Microsoft .Net Framework 2.0 SDK"
103 # needs additional Platform SDK installation
104 # Visual C++ 8.0, _MSC_VER 1400, msvcr80.dll
105 #MSVC_VARIANT=DOTNET20
107 # "Microsoft Visual Studio 2008"
108 # Visual C++ 9.0, _MSC_VER 1500, msvcr90.dll
109 #MSVC_VARIANT=MSVC2008
111 # "Microsoft Visual C++ 2008 Express Edition"
112 # Visual C++ 9.0, _MSC_VER 1500, msvcr90.dll
113 #MSVC_VARIANT=MSVC2008EE
115 # "Microsoft Visual Studio 2010"
116 # Visual C++ 10.0, _MSC_VER 1600, msvcr100.dll
117 #MSVC_VARIANT=MSVC2010
119 # "Microsoft Visual C++ 2010 Express Edition"
120 # Visual C++ 10.0, _MSC_VER 1600, msvcr100.dll
121 #MSVC_VARIANT=MSVC2010EE
123 # "Microsoft Visual C++ 2012 Express Edition"
124 # Visual C++ 11.0, _MSC_VER 1700, msvcr110.dll
126 ## 1. Sep 20,2012: *Beta*: Build with VC11 (2012) succeeds; Seems OK: Minimally tested;
127 ## win32.mak is apparently not part of the MS 2012EE install;
128 ## To build Windows Wireshark, win32.mak must be obtained*
129 ## and copied to a dir specified in the Windows Environment
130 ## variable 'include' (or to a dir added to the list in 'include').
131 ## *One possibility: download the Windows 7 Platform SDK and copy
132 ## win32.mak from ...\Microsoft SDKs\Windows\v7.[something]\include
133 ## See: http://ask.wireshark.org/questions/14343/setting-development-project-under-visual-studio-2012
134 ## 2. Dec 28,2012: "VS2012 Update 1" is required to use VS 2012 to build an .exe which
135 ## will run on Windows XP (as well as on later versions of Windows).
136 ## ToDo: It appears that some special setup is required to to do this.
137 ## https://blogs.msdn.com/b/vcblog/archive/2012/10/08/10357555.aspx
138 ## 3. Feb 07,2013: [WMeier] I've noted no problems to date with Wireshark built with VS2012
139 ## based upon a fair amount of use while doing Wireshark testing and debugging.
141 #MSVC_VARIANT=MSVC2012EE
143 # "Microsoft Visual Studio 2012"
144 # Visual C++ 11.0, _MSC_VER 1700, msvcr110.dll
145 #MSVC_VARIANT=MSVC2012
147 # The default if we haven't set a system environment variable or
148 # uncommented an entry above. We default to the version recommended
149 # in the Developer's Guide, namely MSVC++ 2010 Express Edition.
151 MSVC_VARIANT=MSVC2010EE
155 # Optional: To compile some time critical code from assembler instead of C
157 # If you have the NASM compiler, set this to the NASM executable.
158 # http://nasm.sourceforge.net/
160 # If you don't have NASM, comment this line out, so that NASM
163 NASM=$(WIRESHARK_LIB_DIR)\nasm-2.09.08\nasm.exe
166 # Optional: the Python library enables scripting support.
168 # If you don't have the Python library, comment this line out, so that
169 # PYTHON_EMBED isn't defined.
171 # NOTE: The Python library must have been compiled with the same
172 # compiler (MSVC_VARIANT) as Wireshark. Known python.org Python
175 # Python version CRT (32-bit) CRT (64-bit)
182 # If you versions of Python and Visual C++ use different CRTs
185 # XXX The DLL path in epan/wspython/wspy_libws.py likely needs to
186 # be fixed before this is enabled by default.
190 # Optional: the Python interpreter is used as part of the buildsystem
192 # This will override the automatic detection below.
194 #PYTHON_DIR=C:\Python$(PYTHON_VER)
197 # If you don't have the native Python package installed, you can use
198 # the Cygwin version (not recommended)
202 # Santity check: native vs Cygwin Python options
203 !IF DEFINED(PYTHON) && DEFINED(PYTHON_DIR)
204 !ERROR PYTHON and PYTHON_DIR cannot be specified at the same time
207 # Find native Python automatically if PYTHON(_DIR) wasn't defined
208 !IF !DEFINED(PYTHON) && !DEFINED(PYTHON_DIR)
209 !IF EXIST(c:\Python27\python.exe)
211 !ELSE IF EXIST(c:\Python26\python.exe)
213 !ELSE IF EXIST(c:\Python25\python.exe)
215 !ELSE IF EXIST(c:\Python24\python.exe)
219 !IF DEFINED(PYTHON_VER)
220 PYTHON_DIR=C:\Python$(PYTHON_VER)
224 !IF DEFINED(PYTHON_DIR)
225 PYTHON="$(PYTHON_DIR)\python.exe"
226 PATH=$(PYTHON_DIR);$(PATH)
229 #### Save files as pcap-ng by default. Comment out to use pcap instead. ####
230 PCAP_NG_DEFAULT=^#define PCAP_NG_DEFAULT 1
232 ##### To Use packet editor uncomment this line ####
233 ### Warning Experimental - work in progress
234 #WANT_PACKET_EDITOR=^#define WANT_PACKET_EDITOR 1
236 !if "$(WIRESHARK_TARGET_PLATFORM)" == "win32"
237 ##### Win32 Libraries #####
239 # Mandatory: GLib settings
241 # Please note: Since Wireshark release 1.0.0, we no longer support GLib1.x
246 # Mandatory: GLib, GTK & related library settings
248 # Please note: Since Wireshark release 1.0.0, we no longer support GTK1.x
250 # If you want building with GTK+, set GTK_DIR to the pathname of the
251 # directory in which the "include" and "lib" directories reside.
253 # Set the name to gtk2 if you want to use gtk2
255 GTK_DIR=$(WIRESHARK_LIB_DIR)\$(GTK_NAME)
258 # These macros are used by the nsis installer script and by the install target.
259 #EXPAT_DLL=libexpat-1.dll
261 FONTCONFIG_DLL=libfontconfig-1.dll
262 FREETYPE_DLL=libfreetype-6.dll
263 INTL_DLL=libintl-8.dll
264 JASPER_DLL=libjasper-1.dll
265 JPEG_DLL=libjpeg-8.dll
266 LZMA_DLL=liblzma-5.dll
267 PIXMAN_DLL=libpixman-1-0.dll
268 PNG_DLL=libpng15-15.dll
269 TIFF_DLL=libtiff-5.dll
270 XML_DLL=libxml2-2.dll
272 # This macro is used by the setup target.
273 !IF "$(GTK_NAME)" == "gtk2"
274 GDK_DLL=libgdk-win32-2.0-0.dll
275 GTK_DLL=libgtk-win32-2.0-0.dll
280 GDK_DLL=libgdk-3-0.dll
281 GTK_DLL=libgtk-3-0.dll
287 # Mandatory: Version numbers of GTK and pango.
289 # (MAJOR + MINOR Version number but without MICRO version number)
290 # These macros are used by the nsis installer script and by the setup target.
292 !IF "$(GTK_NAME)" == "gtk2"
293 GTK_INST_VERSION=2.24
299 # Optional: WinPcap developer's pack to capture network traffic.
301 # If you have the WinPcap developer's pack (at least version 3.0),
302 # set this to the directory in which the WinPcap developer's pack resides.
304 # If you don't have the WPdpack, comment this line out, so that
305 # PCAP_DIR isn't defined.
307 PCAP_DIR=$(WIRESHARK_LIB_DIR)\WPdpack
308 # This macro is used by the nsis installer script, by the u3/portable apps and by the setup target.
313 # Optional: WinPcap remote capture support and new API
314 # (pcap_open(), pcap_findalldevs_ex(), etc.)
319 # Optional: The ZLib enables unzipping of gzip compressed capture files
322 # If you have Zlib, set this to directory in which the Zlib headers
323 # and .lib file are stored.
325 # If you don't have Zlib, comment this line out, so that ZLIB_DIR isn't
327 # EXperimental only use zlib 1.2.5 on win32 for now
328 ZLIB_DIR=$(WIRESHARK_LIB_DIR)\zlib125
331 # Optional: the ADNS library enables asynchronous (nonblocking) DNS
334 # If you have GNU ADNS, set this to the directory in which the GNU ADNS
335 # .lib file is stored.
337 # If you don't have GNU ADNS, comment this line out, so that ADNS_DIR
340 # If C_ARES_DIR is defined below, it will override this setting.
342 #ADNS_DIR=$(WIRESHARK_LIB_DIR)\adns-1.0-win32-05ws
345 # Optional: the c-ares library enables asynchronous (nonblocking) DNS
348 # If you have c-ares, set this to the directory in which the c-ares
349 # .lib file is stored. Setting this will override ADNS_DIR above. You
352 # If you're using Visual C++ 6.0, you'll have to use a platform SDK that
353 # defines socklen_t, such as Windows Server 2003 PSDK.
355 # If you don't have c-ares, comment this line out, so that C_ARES_DIR
361 # Optional: the GnuTLS library enables ssl decryption.
363 # If you have the GnuTLS library, set this to the package version.
365 # If you don't have GnuTLS, comment this line out, so that GNUTLS_PKG
368 # Platform SDK conflicts with openssl.h header
369 GNUTLS_PKG=2.12.18-1.2
372 # Optional: the KFW library enables kerberos/sasl/dcerpc decryption.
374 # If you have the kerberos for windows (mit) library, set this to the
375 # directory where the kfw package is stored.
377 # If you don't have KFW, comment this line out, so that KFW_DIR
380 KFW_DIR=$(WIRESHARK_LIB_DIR)\kfw-3-2-2-i386-ws-vc6
383 # Optional: the Nettle library enables ??? decryption.
385 # If you have the Nettle encryption library, set this to the
386 # directory in which the nettle package is stored.
388 # If you don't have Nettle, comment this line out, so that NETTLE_DIR
391 # NETTLE_DIR=$(WIRESHARK_LIB_DIR)\nettle-1.10
394 # Optional: the LUA library enables scripting support.
396 # If you have the LUA library, set this to the directory in which
397 # the LUA package is stored.
399 # If you don't have LUA, comment this line out, so that LUA_DIR
402 LUA_DIST=5_1_4_Win32_dll6
403 LUA_DIR=$(WIRESHARK_LIB_DIR)\lua5.1.4
406 # Optional: the PORTAUDIO library enables audio output for RTP streams.
408 # If you have the PORTAUDIO library (used for rtp_player), set this to
409 # the directory in which the PORTAUDIO library is stored.
411 # If you don't have PORTAUDIO, comment this line out, so that
412 # PORTAUDIO_DIR isn't defined.
414 #PORTAUDIO_DIR=$(WIRESHARK_LIB_DIR)\portaudio_v18_1
415 PORTAUDIO_DIR=$(WIRESHARK_LIB_DIR)\portaudio_v19_2
418 # Version number of PortAudio
420 #PORTAUDIO_VERSION=18
424 # Optional: AirPcap developer's pack to capture wireless network traffic
425 # incl. 802.11 management frames.
427 # If you have the AirPcap developer's pack, set this to the directory
428 # in which the AirPcap developer's pack resides.
430 # If you don't have the AirPcap developer's pack, comment this line out,
431 # so that AIRPCAP_DIR isn't defined.
433 AIRPCAP_DIR=$(WIRESHARK_LIB_DIR)\AirPcap_Devpack_4_1_0_1622\AirPcap_Devpack
436 # Optional: LIBSMI, System Management Interface
438 # Used for oid-name resolution for SNMP and other protocols
443 # Optional: GeoIP, IP address database lookups
445 # Used to map IP addresses to MaxMind GeoIP database entries
450 # Optional: WinSparkle, software updates
452 # Used for automatic software updates
454 WINSPARKLE_PKG=0.3-44-g2c8d9d3-win32ws
457 ##### Win64 Libraries #####
459 # Mandatory: GLib settings
461 # Please note: Since Wireshark release 1.0.0, we no longer support GLib1.x
466 # Mandatory: GLib, GTK & related library settings
468 # Please note: Since Wireshark release 1.0.0, we no longer support GTK1.x
470 # If you want building with GTK+, set GTK_DIR to the pathname of the
471 # directory in which the "include" and "lib" directories reside.
474 # Set the name to gtk3 if you want to use gtk3 - (experimental ?)
476 GTK_DIR=$(WIRESHARK_LIB_DIR)\$(GTK_NAME)
478 # These macros are used by the nsis installer script and by the install target.
479 #EXPAT_DLL=libexpat-1.dll
481 FONTCONFIG_DLL=libfontconfig-1.dll
482 FREETYPE_DLL=libfreetype-6.dll
483 INTL_DLL=libintl-8.dll
484 JASPER_DLL=libjasper-1.dll
485 JPEG_DLL=libjpeg-8.dll
486 LZMA_DLL=liblzma-5.dll
487 PIXMAN_DLL=libpixman-1-0.dll
488 PNG_DLL=libpng15-15.dll
489 TIFF_DLL=libtiff-5.dll
490 XML_DLL=libxml2-2.dll
492 # These macros are used by the setup target.
493 !IF "$(GTK_NAME)" == "gtk2"
494 GDK_DLL=libgdk-win32-2.0-0.dll
495 GTK_DLL=libgtk-win32-2.0-0.dll
500 GDK_DLL=libgdk-3-0.dll
501 GTK_DLL=libgtk-3-0.dll
507 # Mandatory: Version numbers of GTK and pango.
509 # (MAJOR + MINOR Version number but without MICRO version number)
510 # These macros are used by the nsis installer script and by the setup target.
512 !IF "$(GTK_NAME)" == "gtk2"
513 #GTK_INST_VERSION=2.16
514 GTK_INST_VERSION=2.24
520 # Optional: WinPcap developer's pack to capture network traffic.
522 # If you have the WinPcap developer's pack (at least version 3.0),
523 # set this to the directory in which the WinPcap developer's pack resides.
525 # If you don't have the WPdpack, comment this line out, so that
526 # PCAP_DIR isn't defined.
528 PCAP_DIR=$(WIRESHARK_LIB_DIR)\WPdpack
529 # This macro is used by the nsis installer script, by the u3/portable apps and by the setup target.
534 # Optional: WinPcap remote capture support and new API
535 # (pcap_open(), pcap_findalldevs_ex(), etc.)
540 # Optional: The ZLib enables unzipping of gzip compressed capture files
543 # If you have Zlib, set this to directory in which the Zlib headers
544 # and .lib file are stored.
546 # If you don't have Zlib, comment this line out, so that ZLIB_DIR isn't
549 ZLIB_DIR=$(WIRESHARK_LIB_DIR)\zlib125
552 # Optional: the ADNS library enables asynchronous (nonblocking) DNS
555 # If you have GNU ADNS, set this to the directory in which the GNU ADNS
556 # .lib file is stored.
558 # If you don't have GNU ADNS, comment this line out, so that ADNS_DIR
561 # If C_ARES_DIR is defined below, it will override this setting.
563 #ADNS_DIR=$(WIRESHARK_LIB_DIR)\adns-1.0-win32-05ws
566 # Optional: the c-ares library enables asynchronous (nonblocking) DNS
569 # If you have c-ares, set this to the directory in which the c-ares
570 # .lib file is stored. Setting this will override ADNS_DIR above. You
573 # If you're using Visual C++ 6.0, you'll have to use a platform SDK that
574 # defines socklen_t, such as Windows Server 2003 PSDK.
576 # If you don't have c-ares, comment this line out, so that C_ARES_DIR
582 # Optional: the GnuTLS library enables ssl decryption.
584 # If you have the GnuTLS library, set this to the package version.
586 # If you don't have GnuTLS, comment this line out, so that GNUTLS_PKG
589 # Platform SDK conflicts with openssl.h header
590 GNUTLS_PKG=2.12.18-1.2-1
593 # Optional: the KFW library enables kerberos/sasl/dcerpc decryption.
595 # If you have the kerberos for windows (mit) library, set this to the
596 # directory where the kfw package is stored.
598 # If you don't have KFW, comment this line out, so that KFW_DIR
601 #KFW_DIR=$(WIRESHARK_LIB_DIR)\kfw-3.2.2-ws1
604 # Optional: the Nettle library enables ??? decryption.
606 # If you have the Nettle encryption library, set this to the
607 # directory in which the nettle package is stored.
609 # If you don't have Nettle, comment this line out, so that NETTLE_DIR
612 # NETTLE_DIR=$(WIRESHARK_LIB_DIR)\nettle-1.10
615 # Optional: the LUA library enables scripting support.
617 # If you have the LUA library, set this to the directory in which
618 # the LUA package is stored.
620 # If you don't have LUA, comment this line out, so that LUA_DIR
623 LUA_DIST=-5.1.4_Win64_dll10
624 LUA_DIR=$(WIRESHARK_LIB_DIR)\lua5.1.4
627 # Optional: the PORTAUDIO library enables audio output for RTP streams.
629 # If you have the PORTAUDIO library (used for rtp_player), set this to
630 # the directory in which the PORTAUDIO library is stored.
632 # If you don't have PORTAUDIO, comment this line out, so that
633 # PORTAUDIO_DIR isn't defined.
635 #PORTAUDIO_DIR=$(WIRESHARK_LIB_DIR)\portaudio_v18_1
636 PORTAUDIO_DIR=$(WIRESHARK_LIB_DIR)\portaudio_v19_2
639 # Version number of PortAudio
641 #PORTAUDIO_VERSION=18
645 # Optional: AirPcap developer's pack to capture wireless network traffic
646 # incl. 802.11 management frames.
648 # If you have the AirPcap developer's pack, set this to the directory
649 # in which the AirPcap developer's pack resides.
651 # If you don't have the AirPcap developer's pack, comment this line out,
652 # so that AIRPCAP_DIR isn't defined.
654 AIRPCAP_DIR=$(WIRESHARK_LIB_DIR)\AirPcap_Devpack_4_1_0_1622\AirPcap_Devpack
657 # Optional: LIBSMI, System Management Interface
659 # Used for oid-name resolution for SNMP and other protocols
664 # Optional: GeoIP, IP address database lookups
666 # Used to map IP addresses to MaxMind GeoIP database entries
671 # Optional: WinSparkle, software updates
673 # Used for automatic software updates
675 WINSPARKLE_PKG=0.3-44-g2c8d9d3-win64ws
678 ##### win32 / win64 #####
680 !IF "$(GTK_NAME)" == "gtk2"
681 GTK_ETC_DIR=etc\gtk-2.0
682 GTK_ENGINES_DIR=lib\gtk-2.0\$(GTK_LIB_DIR)\engines
683 GTK_MODULES_DIR=lib\gtk-2.0\modules
684 GTK_THEMES_DIR=share\themes\MS-Windows\gtk-2.0
686 GTK_ETC_DIR=etc\gtk-3.0
687 GTK_SCHEMAS_DIR=\share\glib-2.0\schemas
693 # Set the following mandatory commands to find the tools.
694 # The easiest way is to use the corresponding packages from cygwin.
696 # Set up the path to the cygwin binaries
697 CYGWIN_PATH=c:\cygwin\bin
699 # command for a shell (cygwin's bash package recommended)
702 # bash versions after 3.1.6 need the 'igncr' shell option to be able to
703 # process scripts in windows 'native format' (dos crlf format).
704 # The following !IF results in the option being used only if it is available
705 # since using it on bash version 3.1.6 (or earlier) is not required and
706 # will cause an error message.
707 !if "$(SH_PROG)"=="bash" && [$(CYGWIN_PATH)\bash -c "set -o igncr" 2>nul: ] == 0
711 SH=$(SH_PROG) $(SH_FLAGS)
714 # command for perl (cygwin's perl package recommended)
717 # command for pod2man and pod2html
718 # (part of the perl package, usually leave these unchanged)
719 POD2MAN=$(SH) pod2man
720 POD2HTML=$(SH) pod2html
722 # command for lex/flexx (cygwin's flex recommended)
725 # command for yacc/bison (cygwin's bison recommended)
728 # Commands to convert UNIX line endings to DOS/Windows
730 TEXTIFY=$(SH) $(TOOLS_DIR)/textify.sh
733 # Optional: To build the NSIS installer.
735 # If you have the NSIS package, set this to the NSIS executable.
737 # If you don't have NSIS, comment this line out, so that MAKENSIS
740 MAKENSIS="$(PROGRAM_FILES)\NSIS\makensis.exe"
743 # Optional: To build the NSIS PortableApps installer.
745 # If you have the NSIS Unicode package, set this to the NSIS Unicode executable.
747 # If you don't have NSIS Unicode, comment this line out, so that
748 # MAKENSIS_UNICODE isn't defined.
750 MAKENSIS_UNICODE="$(PROGRAM_FILES)\NSIS\Unicode\makensis.exe"
753 # Optional: To build the developers API documentation with doxygen and dot.
754 # Currently experimental, outdated and incomplete.
756 # You will have to download and install:
757 # Doxygen from: http://www.doxygen.org
758 # Graphviz from: http://www.research.att.com/sw/tools/graphviz/
760 # If you have doxygen, set this to the doxygen executable.
762 # If you don't want the developers documentation (or don't have the tools),
763 # comment this line out, so that DOXYGEN isn't defined.
765 #DOXYGEN="$(PROGRAM_FILES)/doxygen/bin/doxygen.exe"
768 # Recommended: Use the compressed html help format .chm as the Wireshark integrated help.
770 # The required htmlhelp.h and htmlhelp.lib should be included in versions of MSVC supported by Wireshark
772 # If you don't want the online help (or don't have the tools),
773 # comment this line out, so that HHC_DIR isn't defined.
775 HHC_DIR=$(PROGRAM_FILES)\HTML Help Workshop
778 # Optional: To reduce the size of dlls and exes, which is especially useful for USB device distributions (U3, PortableApps)
780 # If you have the UPX package, set this to the upx.exe executable.
782 # UPX can be downloaded from:
783 # http://upx.sourceforge.net/
785 # If you don't have UPX, or don't want to pack exes and dlls,
786 # comment this line out, so that UPX isn't defined.
789 UPX=$(WIRESHARK_LIB_DIR)\upx303w\upx.exe
791 ##### Flags, PATHs and Miscellaneous #####
793 # Santity check: Python embedding requires a valid PYTHON_DIR
794 !IF DEFINED(PYTHON_EMBED) && !DEFINED(PYTHON_DIR)
795 !ERROR PYTHON_EMBED requires that PYTHON_DIR is defined
798 # "convert" the MSVC variant into the required MSC compiler version
799 !IF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20"
800 MSC_VER_REQUIRED=1400
801 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2008" || "$(MSVC_VARIANT)" == "MSVC2008EE"
802 MSC_VER_REQUIRED=1500
803 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2010" || "$(MSVC_VARIANT)" == "MSVC2010EE"
804 MSC_VER_REQUIRED=1600
805 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2012" || "$(MSVC_VARIANT)" == "MSVC2012EE"
806 MSC_VER_REQUIRED=1700
808 !ERROR MSVC_VARIANT unknown
811 ## Manifest processing is not needed for VC10 (Visual Studio 2010 C)
812 ## See: http://msdn.microsoft.com/en-us/library/dd293574.aspx
813 !IF ($(MSC_VER_REQUIRED) >= 1400) && ($(MSC_VER_REQUIRED) < 1600)
814 MANIFEST_INFO_REQUIRED=1
817 ## VS2012 (VC11): configure subsystem version
818 ## See: https://blogs.msdn.com/b/vcblog/archive/2012/10/08/10357555.aspx
819 ## (APPVER used in win32.mak to set subsystem version)
820 !IF ($(MSC_VER_REQUIRED) == 1700)
821 !if "$(WIRESHARK_TARGET_PLATFORM)" == "win32"
829 # /W3 Warning level 3 (0 less - 4 most, 1 default).
830 # /Zi Create .pdb file for debugging.
831 # /FR Create .sbr file with complete symbolic information.
832 # add to standard CFLAGS if you want to build the .sbr files
833 # for Wireshark compiles.
834 # Warning: using /FR for Wireshark requires ~1Gig of additional disk space
835 # XXX: provides less functionality for VC8, ... than for previous compilers ?
836 # XXX: .bsc files not usable (not supported ?) with VC10 (Visual Studio 2010) ?
837 # /MD Use "multithread- and DLL-specific version" of run-time libraries.
838 # msvc documentation states that /MD causes _MT and _DLL to be defined
839 # See: http://msdn.microsoft.com/en-us/library/2kzt1wy3%28v=VS.90%29.aspx
840 # /D_CRT_SECURE_NO_DEPRECATE Don't warn for "insecure" calls;
841 # see MSDN "Security Enhancements in the CRT".
842 # /D_CRT_NONSTDC_NO_DEPRECATE Don't warn for "Deprecated CRT Functions" as MSDN calls this.
843 # /D_BIND_TO_CURRENT_CRT_VERSION=1 Make sure our CRT and manifest versions match.
844 # (http://msdn.microsoft.com/en-us/library/cc664727.aspx)
845 # /DWIN32_LEAN_AND_MEAN Don't include unnecessary Windows include files (see windows.h).
846 # /MANIFEST:no Don't create a SxS manifest. Makes sure our plugins don't load
847 # a second copy of the CRT.
848 # -DPSAPI_VERSION=1 Programs that must run on earlier versions of Windows as well as Windows 7 and later
849 # versions should always call this function as GetProcessMemoryInfo. To ensure correct resolution of symbols,
850 # add Psapi.lib to the TARGETLIBS macro and compile the program with -DPSAPI_VERSION=1.
851 # To use run-time dynamic linking, load Psapi.dll.
852 # http://msdn.microsoft.com/en-us/library/windows/desktop/ms683219(v=vs.85).aspx
854 ##Note: LOCAL_CFLAGS are flags used for *all* compilations
855 ## STANDARD_CFLAGS (see below) are flags used just for *Wireshark* compilations
856 !IF "$(MSVC_VARIANT)" == "MSVC2005" || \
857 "$(MSVC_VARIANT)" == "MSVC2005EE" || \
858 "$(MSVC_VARIANT)" == "DOTNET20" || \
859 "$(MSVC_VARIANT)" == "MSVC2008" || \
860 "$(MSVC_VARIANT)" == "MSVC2008EE" || \
861 "$(MSVC_VARIANT)" == "MSVC2010" || \
862 "$(MSVC_VARIANT)" == "MSVC2010EE" || \
863 "$(MSVC_VARIANT)" == "MSVC2012" || \
864 "$(MSVC_VARIANT)" == "MSVC2012EE"
865 LOCAL_CFLAGS=/Zi /W3 /MD /DWIN32_LEAN_AND_MEAN /DMSC_VER_REQUIRED=$(MSC_VER_REQUIRED) \
866 /D_CRT_SECURE_NO_DEPRECATE /D_CRT_NONSTDC_NO_DEPRECATE -DPSAPI_VERSION=1
868 !IF "$(WIRESHARK_TARGET_PLATFORM)" != "win64"
869 LOCAL_CFLAGS=$(LOCAL_CFLAGS) /D_BIND_TO_CURRENT_CRT_VERSION=1
872 # Additional compiler warnings to be treated as "Level 3"
873 # when compiling Wireshark sources. (Selected from "level 4" warnings).
874 ## 4295: array is too small to include a terminating null character
875 WARNINGS_CFLAGS=/w34295
878 !ERROR MSVC_VARIANT unknown
881 # http://msdn.microsoft.com/en-us/library/bb385193.aspx
882 # /MP Compiles multiple source files by using multiple processes
883 # /MP[processMax] If you omit the processMax argument, the compiler retrieves the number of effective processors
884 # on your computer from the operating system, and creates a process for each processor.
886 # The following compiler options and language features that are incompatible with the /MP option:
888 # * #import preprocessor directive
894 !IF "$(MSVC_VARIANT)" == "MSVC2008" || \
895 "$(MSVC_VARIANT)" == "MSVC2008EE" || \
896 "$(MSVC_VARIANT)" == "MSVC2010" || \
897 "$(MSVC_VARIANT)" == "MSVC2010EE" || \
898 "$(MSVC_VARIANT)" == "MSVC2012" || \
899 "$(MSVC_VARIANT)" == "MSVC2012EE"
900 LOCAL_CFLAGS= $(LOCAL_CFLAGS) /MP
903 # Optional: Static analysis. Only supported in the full-frontal MSVC editions.
904 # http://msdn.microsoft.com/en-us/library/ms182025.aspx
906 !IFDEF ENABLE_CODE_ANALYSIS
907 LOCAL_CFLAGS= $(LOCAL_CFLAGS) /analyze:WX-
910 #STANDARD_CFLAGS are flags used for *Wireshark* compiles (not stuff like lemon, etc)
911 STANDARD_CFLAGS=/DPCAP_VERSION=$(PCAP_VERSION) $(LOCAL_CFLAGS) $(WARNINGS_CFLAGS)
913 # Optional: Define WIRESHARK_GENERATE_BSC_FILE to generate .sbr files for input to bscmake
914 !IFDEF WIRESHARK_GENERATE_BSC_FILE
915 STANDARD_CFLAGS= $(STANDARD_CFLAGS) /FR
918 #Comment out the following if warnings are not to be treated as errors
919 WARNINGS_ARE_ERRORS=-WX
922 # /DEBUG generate debug info
923 # /PROFILE generate map file(s) for profiling
924 # /DEFAULTLIB:xxx use xxx as the standard C library
925 # /NODEFAULTLIB:xxx don't use xxx as the standard C library
927 LOCAL_LDFLAGS=/DEBUG /MACHINE:$(TARGET_MACHINE)
929 !IFDEF MANIFEST_INFO_REQUIRED
930 DLL_LDFLAGS = /MANIFEST:no
933 # Enable Safe Exception Handler.
934 # http://msdn.microsoft.com/en-us/magazine/cc337897.aspx
935 !IF $(MSC_VER_REQUIRED) >= 1300
936 LOCAL_CFLAGS= $(LOCAL_CFLAGS) /GS
937 !IF "$(WIRESHARK_TARGET_PLATFORM)" != "win64"
938 LOCAL_LDFLAGS= $(LOCAL_LDFLAGS) /SafeSEH
942 # Enable ASLR. Requires VS2008 or later.
943 # http://blogs.msdn.com/b/vcblog/archive/2009/05/21/dynamicbase-and-nxcompat.aspx
944 # DEP (/NXCompat) is handled in init_process_policies() via SetProcessDEPPolicy.
946 # ASLR http://msdn.microsoft.com/en-us/library/bb384887.aspx
947 !IF $(MSC_VER_REQUIRED) >= 1500
948 LOCAL_LDFLAGS= $(LOCAL_LDFLAGS) /DYNAMICBASE /FIXED:no
951 PLUGIN_LDFLAGS = /NOLOGO /INCREMENTAL:no $(LOCAL_LDFLAGS) $(DLL_LDFLAGS)
954 # According to http://bugs.wireshark.org/bugzilla/show_bug.cgi?id=403
955 # XCOPY under Windows NT doesn't support the "/Y" flag. This works
957 # XXX - This apparently doesn't work for some versions of nmake:
958 # http://support.microsoft.com/default.aspx?scid=kb;en-us;86814
959 # It looks like we'll have to call "set copycmd=/y" before we run xcopy.
963 # If you don't want to build libwireshark.dll, you should comment out the
964 # following line. (Note: for plugin support this option must stay activated)
965 ENABLE_LIBWIRESHARK=USE
968 # install (debug) directory for Wireshark (relative to your source dir)
969 INSTALL_DIR=wireshark-gtk2
973 ##### C-Runtime Redistributable #####
975 # The C-Runtime since Version 7 must be shipped together with
976 # the program installer, to avoid missing msvcr*.dll files on
977 # the target machine.
979 # The location of these files differ on the various compiler
980 # packages, the following will use the default paths depending
981 # on the package version.
984 # You can either place the redistributable in its own platform-
985 # and compiler-specific directory or in the top-level library
987 # Microsoft maintains a list of the latest redistributables in
988 # KB 20197667: http://support.microsoft.com/kb/2019667
989 !IF EXIST("$(WIRESHARK_LIB_DIR)\vcredist_$(MSVC_VARIANT)")
990 VCREDIST_DIR=$(WIRESHARK_LIB_DIR)\vcredist_$(MSVC_VARIANT)
992 VCREDIST_DIR=$(WIRESHARK_LIB_DIR)
995 !IF "$(WIRESHARK_TARGET_PLATFORM)" == "win64"
997 # For 64-bit platforms, we don't create portable packages and therefore
998 # don't have to worry that "Using the Visual C++ Redistributable
999 # Package" requires that an installer be run to install that package,
1000 # so we use that method to make the C runtime available.
1002 VCREDIST_EXE=$(VCREDIST_DIR)\vcredist_$(TARGET_MACHINE).exe
1004 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2005"
1006 # For MSVC 2005 non-Express Edition, we "Install a particular Visual C++
1007 # assembly as a private assembly for the application", by copying
1008 # the contents of the Microsoft.VC80.CRT folder to the target directory.
1009 # This is done to reduce the size of the installer; it also makes
1010 # a portable version work, as the C runtime doesn't have to be
1011 # installed on the target machine.
1013 MSVCR_DLL=$(PROGRAM_FILES)\Microsoft Visual Studio 8\VC\redist\$(PROCESSOR_ARCHITECTURE)\Microsoft.VC80.CRT\*.*
1015 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20" || "$(MSVC_VARIANT)" == "MSVC2008EE"
1017 # For MSVC 2005 Express Edition, for the .NET Framework 2.0 SDK, and
1018 # for MSVC 2008 Express Edition, we "Use the Visual C++ Redistributable
1019 # Package", because they don't provide the Microsoft.VC80.CRT folder.
1021 # They also don't provide the redistributable package, so you need to
1022 # download the appropriate version of the redistributable package,
1023 # vcredist_x86.exe, vcredist_x64.exe, or vcredist_ia64.exe, from
1024 # Microsoft first, and copy it to the lib folder!!!
1026 VCREDIST_EXE=$(VCREDIST_DIR)\vcredist_$(TARGET_MACHINE).exe
1028 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2008"
1030 # For MSVC 2008 non-Express Edition, we "Install a particular Visual C++
1031 # assembly as a private assembly for the application", by copying
1032 # the contents of the Microsoft.VC90.CRT folder to the target directory.
1033 # This is done to reduce the size of the installer; it also makes
1034 # a portable version work, as the C runtime doesn't have to be
1035 # installed on the target machine.
1037 MSVCR_DLL=$(PROGRAM_FILES)\Microsoft Visual Studio 9.0\VC\redist\$(PROCESSOR_ARCHITECTURE)\Microsoft.VC90.CRT\*.*
1039 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2010EE"
1041 # For MSVC 2010 Express Edition, we "Use the Visual C++ Redistributable
1042 # Package", because it doesn't provide the Microsoft.VC80.CRT folder.
1044 # It also doesn't provide the redistributable package, so you need to
1045 # download the appropriate version of the redistributable package,
1046 # vcredist_x86.exe or vcredist_x64.exe, from Microsoft first, and copy
1047 # it to the lib folder!!!
1048 VCREDIST_EXE=$(VCREDIST_DIR)\vcredist_$(TARGET_MACHINE).exe
1049 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2010"
1051 # For MSVC 2010 non-Express Edition, we "Install a particular Visual C++
1052 # assembly as a private assembly for the application", by copying
1053 # the contents of the Microsoft.VC100.CRT folder to the target directory.
1054 # This is done to reduce the size of the installer; it also makes
1055 # a portable version work, as the C runtime doesn't have to be
1056 # installed on the target machine.
1058 # Note: for what it's worth, Microsoft recommends "Using the Visual C++
1059 # Redistributable Package", rather than "Installing a particular Visual
1060 # C++ assembly as a private assembly for the application", starting
1061 # with Visual Studio 2010.
1063 MSVCR_DLL=$(PROGRAM_FILES)\Microsoft Visual Studio 10.0\VC\redist\$(TARGET_MACHINE)\Microsoft.VC100.CRT\*.*
1064 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2012"
1066 # For MSVC 2012 non-Express Edition, we "Install a particular Visual C++
1067 # assembly as a private assembly for the application", by copying
1068 # the contents of the Microsoft.VC110.CRT folder to the target directory.
1069 # This is done to reduce the size of the installer; it also makes
1070 # a portable version work, as the C runtime doesn't have to be
1071 # installed on the target machine.
1073 # Note: for what it's worth, Microsoft recommends "Using the Visual C++
1074 # Redistributable Package", rather than "Installing a particular Visual
1075 # C++ assembly as a private assembly for the application", starting
1076 # with Visual Studio 2010.
1078 MSVCR_DLL=$(PROGRAM_FILES)\Microsoft Visual Studio 11.0\VC\redist\$(TARGET_MACHINE)\Microsoft.VC110.CRT\*.*
1081 !ERROR MSVC_VARIANT unknown
1084 # This is still optional yet we define it above for all users.
1085 # So, don't check if it exists...
1086 #!IF DEFINED(VCREDIST_EXE) && ! EXIST("$(VCREDIST_EXE)")
1087 #!ERROR Can't find $(VCREDIST_EXE). Have you downloaded it from Microsoft? \
1088 #See the developer's guide section "C-Runtime "Redistributable" files" for details how to get it
1091 ##### Advanced: Docbook/XML documentation generation #####
1092 # If you want to generate the Docbook/XML based docs (User's and Developer's
1093 # Guide, ...), you'll need some additional tools / libraries compared to the
1094 # rest of the build process.
1096 # FOR DETAILED INSTRUCTIONS TO GENERATE THE DOCS, SEE: docbook\README.txt.
1098 # If you don't call the Makefile.nmake in the docbook dir to generate the
1099 # docs, the following settings in this section will have no effect.
1101 # formatting objects processor executable
1102 # Comment this out if you don't have fop installed or you don't want the docs
1105 # You may want to install the FOP hyphenation patterns from
1106 # http://offo.sourceforge.net/hyphenation/
1111 # Additional options to fop.
1114 # html help compiler
1115 # Comment this out if you don't have hhc.exe or you don't want the docs in
1118 # Beware: hhc.exe is NOT part of the MSVC packages in HHC_DIR mentioned above,
1119 # so you'll need to install the HTML Help Workshop for this.
1120 HHC_EXE="$(HHC_DIR)\hhc.exe"
1122 # html to text converter for text version of release notes, e.g. elinks.
1123 # This could also be "lynx", or "true" if neither elinks nor lynx is installed
1124 # (cygwin: lynx works, elinks not available, links and true doesn't produce output)
1125 #HTML2TXT=elinks -dump -dump-width 72
1126 ##HTML2TXT=links -dump -width 72 ## XXX: Fails: For links -dump requires 'url' (filename) arg.
1127 #HTML2TXT=lynx -dump -width=72 -nolist -stdin
1130 HTML2TXT=$(PYTHON) $(TOOLS_DIR)\html2text.py --width=72 --no-links
1133 # the XSL processor (part of cygwin's libxslt package)
1136 # the XML validator (part of cygwin's libxml2 package)
1139 # Asciidoc converter (part of cygwin's asciidoc package). In order to build
1140 # the release notes you must have the Cygwin asciidoc and lynx packages
1145 ##############################################################################
1147 # You should not have to change anything below this comment.
1148 # If you do, it's a deficiency in the Makefile.nmake files;
1149 # either tell wireshark-dev@wireshark.org about it, including
1150 # details of why you had to change it, or fix config.nmake
1151 # and any Makefile.nmake files that need to be changed, and
1152 # send us the patches, along with details of why the change
1155 ##############################################################################
1158 # The RC_VERSION should be comma-separated, not dot-separated,
1159 # as per Graham Bloice's message in
1161 # http://www.ethereal.com/lists/ethereal-dev/200303/msg00283.html
1163 # "The RC_VERSION variable in config.nmake should be comma separated.
1164 # This allows the resources to be built correctly and the version
1165 # number to be correctly displayed in the explorer properties dialog
1166 # for the executables, and XP's tooltip, rather than 0.0.0.0."
1169 VERSION=$(VERSION_MAJOR).$(VERSION_MINOR).$(VERSION_MICRO)$(VERSION_EXTRA)
1170 RC_VERSION=$(VERSION_MAJOR),$(VERSION_MINOR),$(VERSION_MICRO),$(VERSION_BUILD)
1171 PRODUCT_VERSION=$(VERSION_MAJOR).$(VERSION_MINOR).$(VERSION_MICRO).$(VERSION_BUILD)
1173 WTAP_VERSION=$(WTAP_VERSION_MAJOR).$(WTAP_VERSION_MINOR).$(WTAP_VERSION_MICRO)
1174 RC_WTAP_VERSION=$(WTAP_VERSION_MAJOR),$(WTAP_VERSION_MINOR),$(WTAP_VERSION_MICRO)
1177 GLIB_CFLAGS=/I$(GTK_DIR)\include\glib-$(GLIB_VERSION) \
1178 /I$(GTK_DIR)\lib\glib-$(GLIB_VERSION)\include \
1179 -DG_DISABLE_DEPRECATED \
1180 -DG_DISABLE_SINGLE_INCLUDES
1181 GLIB_LIBS=$(GTK_DIR)\lib\glib-$(GLIB_VERSION).lib \
1182 $(GTK_DIR)\lib\gmodule-$(GLIB_VERSION).lib \
1183 $(GTK_DIR)\lib\gobject-$(GLIB_VERSION).lib
1184 GTHREAD_LIBS=$(GTK_DIR)\lib\gthread-$(GLIB_VERSION).lib
1187 # 2.18 was no good(Theming problem)
1188 !IF "$(GTK_INST_VERSION)" == "2.24" || "$(GTK_INST_VERSION)" == "2.22" || "$(GTK_INST_VERSION)" == "2.16" || "$(GTK_INST_VERSION)" == "2.14"
1191 GTK_CFLAGS=$(GLIB_CFLAGS) /I$(GTK_DIR)\include\gtk-2.0 \
1192 /I$(GTK_DIR)\include\gdk-pixbuf-2.0 \
1193 /I$(GTK_DIR)\lib\gtk-2.0\include \
1194 /I$(GTK_DIR)\include\atk-1.0 \
1195 /I$(GTK_DIR)\include\cairo \
1196 /I$(GTK_DIR)\include\pango-1.0 \
1197 -DGDK_DISABLE_DEPRECATED \
1198 -DGDK_PIXBUF_DISABLE_DEPRECATED \
1199 -DGTK_DISABLE_DEPRECATED \
1200 -DGTK_DISABLE_SINGLE_INCLUDES \
1202 GTK_LIBS=$(GTK_DIR)\lib\gtk-win32-2.0.lib \
1203 $(GTK_DIR)\lib\gdk-win32-2.0.lib \
1204 $(GTK_DIR)\lib\gdk_pixbuf-2.0.lib \
1205 $(GTK_DIR)\lib\cairo.lib \
1206 $(GTK_DIR)\lib\pango-1.0.lib \
1207 $(GTK_DIR)\lib\pangocairo-1.0.lib \
1222 # Pango >=1.24.5 Needs these:
1223 NEED_FREETYPE_DLL=USE
1224 NEED_FONTCONFIG_DLL=USE
1234 !ELSEIF "$(GTK_INST_VERSION)" == "3.4"
1237 GTK_CFLAGS=$(GLIB_CFLAGS) /I$(GTK_DIR)\include\gtk-3.0 \
1238 /I$(GTK_DIR)\include\gdk-pixbuf-2.0 \
1239 /I$(GTK_DIR)\lib\gtk-3.0\include \
1240 /I$(GTK_DIR)\include\atk-1.0 \
1241 /I$(GTK_DIR)\include\cairo \
1242 /I$(GTK_DIR)\include\pango-1.0 \
1243 -DGDK_DISABLE_DEPRECATED \
1244 -DGDK_PIXBUF_DISABLE_DEPRECATED \
1245 -DGTK_DISABLE_DEPRECATED \
1246 -DGTK_DISABLE_SINGLE_INCLUDES \
1248 GTK_LIBS=$(GTK_DIR)\lib\gtk-3.lib \
1249 $(GTK_DIR)\lib\gdk-3.lib \
1250 $(GTK_DIR)\lib\gdk_pixbuf-2.0.lib \
1251 $(GTK_DIR)\lib\cairo.lib \
1252 $(GTK_DIR)\lib\pango-1.0.lib \
1253 $(GTK_DIR)\lib\pangocairo-1.0.lib \
1261 NEED_CAIRO_GOBJECT_DLL=USE
1270 !IFDEF FONTCONFIG_DLL
1271 NEED_FONTCONFIG_DLL=USE
1274 NEED_FREETYPE_DLL=USE
1298 !ERROR ? Unknown or invalid GTK_INST_VERSION "$(GTK_INST_VERSION)"
1303 AIRPCAP_CONFIG=^#define HAVE_AIRPCAP 1
1304 #AIRPCAP_CFLAGS=/I$(AIRPCAP_DIR)\include
1307 WIRELESS_TOOLBAR_CONFIG=
1311 # Nmake uses carets to escape special characters
1312 WINPCAP_CONFIG=^#define HAVE_LIBPCAP 1
1314 # This requires that, if you're *building* Wireshark, you have
1315 # the most recent WinPcap's development package. If, at *run*
1316 # time, an older version of WinPcap, missing some routines,
1317 # is found, we work around that.
1319 PCAP_FINDALLDEVS_CONFIG=^#define HAVE_PCAP_FINDALLDEVS 1
1320 PCAP_DATALINK_NAME_TO_VAL_CONFIG=^#define HAVE_PCAP_DATALINK_NAME_TO_VAL 1
1321 PCAP_DATALINK_VAL_TO_NAME_CONFIG=^#define HAVE_PCAP_DATALINK_VAL_TO_NAME 1
1322 PCAP_DATALINK_VAL_TO_DESCRIPTION_CONFIG=^#define HAVE_PCAP_DATALINK_VAL_TO_DESCRIPTION 1
1323 # PCAP_BREAKLOOP won't have any benefit on Win32, but breaks compatibility with 3.0
1324 PCAP_BREAKLOOP_CONFIG=
1325 PCAP_LIST_DATALINKS_CONFIG=^#define HAVE_PCAP_LIST_DATALINKS 1
1326 PCAP_FREE_DATALINKS_CONFIG=^#define HAVE_PCAP_FREE_DATALINKS 1
1327 PCAP_SET_DATALINK_CONFIG=^#define HAVE_PCAP_SET_DATALINK 1
1328 PCAP_OPEN_DEAD_CONFIG=^#define HAVE_PCAP_OPEN_DEAD 1
1329 BPF_IMAGE_CONFIG=^#define HAVE_BPF_IMAGE 1
1331 # no WpdPack installed
1333 PCAP_FINDALLDEVS_CONFIG=
1334 PCAP_DATALINK_NAME_TO_VAL_CONFIG=
1335 PCAP_DATALINK_VAL_TO_NAME_CONFIG=
1336 PCAP_DATALINK_VAL_TO_DESCRIPTION_CONFIG=
1337 PCAP_BREAKLOOP_CONFIG=
1338 PCAP_LIST_DATALINKS_CONFIG=
1339 PCAP_FREE_DATALINKS_CONFIG=
1340 PCAP_SET_DATALINK_CONFIG=
1341 PCAP_OPEN_DEAD_CONFIG=
1345 !IF DEFINED(PCAP_DIR) && DEFINED(PCAP_REMOTE)
1346 PCAP_HAVE_REMOTE_CONFIG=^#define HAVE_REMOTE 1
1347 PCAP_REMOTE_CONFIG=^#define HAVE_PCAP_REMOTE 1
1348 PCAP_OPEN_CONFIG=^#define HAVE_PCAP_OPEN 1
1349 PCAP_SETSAMPLING_CONFIG=^#define HAVE_PCAP_SETSAMPLING 1
1351 PCAP_HAVE_REMOTE_CONFIG=
1354 PCAP_SETSAMPLING_CONFIG=
1358 ZLIB_PATH=$(ZLIB_DIR)
1359 ZLIB_CFLAGS=/I$(ZLIB_DIR)\include
1360 ZLIB_LIBS=$(ZLIB_DIR)\lib\zdll.lib
1361 ZLIB_DLL=$(ZLIB_DIR)\zlib1.dll
1362 # Nmake uses carets to escape special characters
1363 ZLIB_CONFIG=^#define HAVE_LIBZ 1
1373 C_ARES_DIR=$(WIRESHARK_LIB_DIR)\c-ares-$(C_ARES_PKG)-$(WIRESHARK_TARGET_PLATFORM)ws
1374 C_ARES_CFLAGS=/I$(C_ARES_DIR)/include
1375 C_ARES_LIBS=$(C_ARES_DIR)\lib\libcares-2.lib
1376 C_ARES_DLL=$(C_ARES_DIR)\bin\libcares-2.dll
1377 # Nmake uses carets to escape special characters
1378 C_ARES_CONFIG=^#define HAVE_C_ARES 1
1384 ADNS_PATH=$(ADNS_DIR)\adns_win32\lib
1385 ADNS_CFLAGS=/I$(ADNS_DIR)\src /I$(ADNS_DIR)\adns_win32
1386 ADNS_LIBS=$(WIRESHARK_LIB_DIR)\$(MSVC_VARIANT)\adns\adns_dll.lib
1387 ADNS_DLL=$(WIRESHARK_LIB_DIR)\$(MSVC_VARIANT)\adns\adns_dll.dll
1388 # Nmake uses carets to escape special characters
1389 ADNS_CONFIG=^#define HAVE_GNU_ADNS 1
1398 KFW_PATH=$(KFW_DIR)\bin
1399 KFW_CFLAGS=/I$(KFW_DIR)\include
1400 KFW_LIBS=$(KFW_DIR)\lib\krb5_32.lib
1401 # Nmake uses carets to escape special characters
1402 KFW_CONFIG=^#define HAVE_MIT_KERBEROS 1
1410 NETTLE_CFLAGS=/I$(NETTLE_DIR)
1411 NETTLE_LIBS=$(NETTLE_DIR)\libnettle.lib
1412 # Nmake uses carets to escape special characters
1413 NETTLE_CONFIG=^#define HAVE_LIBNETTLE 1
1421 GNUTLS_DIR=$(WIRESHARK_LIB_DIR)\gnutls-$(GNUTLS_PKG)-$(WIRESHARK_TARGET_PLATFORM)ws
1422 GNUTLS_PATH=$(GNUTLS_DIR)
1423 # /DNOCRYPT avoids inclusion of Wincrypt.h, avoiding a X509_NAME define clash
1424 GNUTLS_CFLAGS=/I$(GNUTLS_DIR)\include /DNOCRYPT /DIMPORT_LIGNUTLSDLL
1425 GCRYPT_LIBS = $(GNUTLS_DIR)\bin\libgcrypt-11.lib
1427 $(GNUTLS_DIR)\bin\libtasn1-3.lib \
1428 $(GNUTLS_DIR)\bin\libgpg-error-0.lib \
1430 $(GNUTLS_DIR)\bin\libgnutls-26.lib
1431 # Nmake uses carets to escape special characters
1432 GNUTLS_CONFIG=^#define HAVE_LIBGNUTLS 1
1433 LIBGCRYPT_CONFIG=^#define HAVE_LIBGCRYPT 1
1442 LUA_CFLAGS=/I$(LUA_DIR)\include
1443 LUA_LIBS=$(LUA_DIR)\lua5.1.lib
1444 # Nmake uses carets to escape special characters
1445 LUA_CONFIG=^#define HAVE_LUA 1
1446 LUA_VERSION=^#define HAVE_LUA 1
1453 !IF DEFINED(PYTHON_EMBED)
1454 PYTHON_CFLAGS=/I$(PYTHON_DIR)\include
1455 PYTHON_LIBS=$(PYTHON_DIR)\libs\python$(PYTHON_VER).lib
1456 # Nmake uses carets to escape special characters
1457 PYTHON_CONFIG=^#define HAVE_PYTHON 1
1464 !IFDEF PORTAUDIO_DIR
1465 # Nmake uses carets to escape special characters
1466 PORTAUDIO_CONFIG=^#define HAVE_LIBPORTAUDIO 1
1467 !IF "$(PORTAUDIO_VERSION)" == "18"
1468 # V18 uses API version 1 and v19 API version 2
1469 PORTAUDIO_CFLAGS=/I$(PORTAUDIO_DIR)\pa_common
1470 PORTAUDIO_API_CONFIG=^#define PORTAUDIO_API_1 1
1472 PORTAUDIO_CFLAGS=/I$(PORTAUDIO_DIR)\include /I$(PORTAUDIO_DIR)\src\common /I$(PORTAUDIO_DIR)\src\os\win /DPA_NO_DS /DPA_NO_ASIO
1480 HHC_CFLAGS=-DHHC_DIR
1481 HHC_LIBS=htmlhelp.lib
1488 SMI_DIR=$(WIRESHARK_LIB_DIR)\libsmi-$(SMI_PKG)-$(WIRESHARK_TARGET_PLATFORM)ws
1489 SMI_CONFIG=^#define HAVE_LIBSMI 1
1490 SMI_CFLAGS=/I$(SMI_DIR)\include
1491 SMI_LIBS=$(SMI_DIR)\lib\libsmi-2.lib
1500 GEOIP_DIR=$(WIRESHARK_LIB_DIR)\GeoIP-$(GEOIP_PKG)-$(WIRESHARK_TARGET_PLATFORM)ws
1501 GEOIP_CONFIG=^#define HAVE_GEOIP 1
1502 GEOIP_V6_CONFIG=^#define HAVE_GEOIP_V6 1
1503 GEOIP_CFLAGS=/I$(GEOIP_DIR)/include
1504 GEOIP_LIBS=$(GEOIP_DIR)\lib\libGeoIP-1.lib
1513 !IFDEF WINSPARKLE_PKG
1514 WINSPARKLE_DIR=$(WIRESHARK_LIB_DIR)\WinSparkle-$(WINSPARKLE_PKG)
1515 WINSPARKLE_CONFIG=^#define HAVE_SOFTWARE_UPDATE 1
1516 WINSPARKLE_CFLAGS=/I$(WINSPARKLE_DIR)
1517 WINSPARKLE_LIBS=$(WINSPARKLE_DIR)\WinSparkle.lib
1525 !IFDEF ENABLE_LIBWIRESHARK
1526 # Link plugins with the import library of libwireshark.dll
1527 LINK_PLUGINS_WITH_LIBWIRESHARK=USE
1529 LIBWIRESHARK_CONFIG=
1532 # Construct the path
1533 PATH=$(PATH);$(CYGWIN_PATH);$(GTK_DIR)\bin;$(GETTEXT_DIR)\bin;$(ZLIB_PATH);$(ADNS_PATH)
1535 INET6_CONFIG=^#define INET6 1
1537 NTDDNDIS_CONFIG=^#define HAVE_NTDDNDIS_H 1