3 # Some more informations about the settings in this file, can be found
4 # in the file README.win32 and the Developer's Guide (available online).
6 ##### Target platform #####
7 # Only "win32" and "win64" are valid (for now).
8 # This can be defined in the system environment.
9 !IFNDEF WIRESHARK_TARGET_PLATFORM
10 WIRESHARK_TARGET_PLATFORM=win32
15 # The current Wireshark version
16 # It's highly recommended to leave MAJOR/MINOR/MICRO unchanged
21 # It's recommended to change VERSION_EXTRA for your own custom builds
25 # The version of the wiretap library (recommended: leave unchanged)
32 ##### Directories #####
35 # Base directory, where your libraries reside, which are needed to
36 # compile the sources. This setting is used only inside this file.
38 WIRESHARK_LIBS=C:\wireshark-$(WIRESHARK_TARGET_PLATFORM)-libs
41 # Base directory, where your programs reside.
42 # This setting is used only inside this file.
44 PROGRAM_FILES=$(PROGRAMFILES)
47 # Location of the "tools" directory. This affects HTML2TXT below and should
48 # be overridden by makefiles in any subdirectories that use HTML2TXT.
54 # Machine type for the compiler and linker
55 # TARGET_MACHINE (Used for link /MACHINE) should be one of "X86" or "X64"
56 # (sorry ARM, Alpha, MIPS, and Itanium fans).
57 # CPU (Used by win32.mak) should be one of "i386" or "AMD64".
58 !if "$(WIRESHARK_TARGET_PLATFORM)" == "win32"
62 !else if "$(WIRESHARK_TARGET_PLATFORM)" == "win64"
67 !error Your mysterious moon-man architecture "$(WIRESHARK_TARGET_PLATFORM)" frightens and confuses us.
71 ##### Microsoft Visual C / Studio Variant #####
72 # for the different Studios, see: http://en.wikipedia.org/wiki/Microsoft_Visual_Studio
73 # only one of the following MSVC_VARIANT settings should be used
74 # BTW: The "Microsoft Visual C++ Toolkit 2003" DOESN'T WORK for WS!
76 # "Microsoft Visual Studio 6.0"
77 # Visual C++ 6.0, _MSC_VER 1200, msvcrt.dll (version 6)
80 # "Microsoft Visual Studio .NET (2002)"
81 # Visual C++ 7.0, _MSC_VER 1300, msvcr70.dll
82 #MSVC_VARIANT=MSVC2002
84 # "Microsoft .Net Framework SDK Version 1.0"
85 # needs additional Platform SDK installation
86 # Visual C++ 7.0, _MSC_VER 1300, msvcr70.dll
87 #MSVC_VARIANT=DOTNET10
89 # "Microsoft Visual Studio .NET 2003"
90 # Visual C++ 7.1, _MSC_VER 1310, msvcr71.dll
91 #MSVC_VARIANT=MSVC2003
93 # "Microsoft .Net Framework SDK Version 1.1"
94 # needs additional Platform SDK installation
95 # Visual C++ 7.1, _MSC_VER 1310, msvcr71.dll
96 #MSVC_VARIANT=DOTNET11
98 # "Microsoft Visual Studio 2005"
99 # Visual C++ 8.0, _MSC_VER 1400, msvcr80.dll
100 #MSVC_VARIANT=MSVC2005
102 # "Microsoft Visual C++ 2005 Express Edition"
103 # needs additional Platform SDK installation
104 # Visual C++ 8.0, _MSC_VER 1400, msvcr80.dll
105 #MSVC_VARIANT=MSVC2005EE
107 # "Microsoft .Net Framework 2.0 SDK"
108 # needs additional Platform SDK installation
109 # Visual C++ 8.0, _MSC_VER 1400, msvcr80.dll
110 #MSVC_VARIANT=DOTNET20
112 # "Microsoft Visual Studio 2008"
113 # Visual C++ 9.0, _MSC_VER 1500, msvcr90.dll
114 MSVC_VARIANT=MSVC2008
116 # "Microsoft Visual C++ 2008 Express Edition"
117 # Visual C++ 9.0, _MSC_VER 1500, msvcr90.dll
118 #MSVC_VARIANT=MSVC2008EE
121 # Optional: To compile some time critical code from assembler instead of C
123 # If you have the NASM compiler, set this to the NASM executable.
124 # http://nasm.sourceforge.net/
126 # If you don't have NASM, comment this line out, so that NASM
129 NASM=$(WIRESHARK_LIBS)\nasm-2.02\nasm.exe
132 !if "$(WIRESHARK_TARGET_PLATFORM)" == "win32"
133 ##### Win32 Libraries #####
135 # Mandatory: GLib settings
137 # Please note: Since Wireshark release 1.0.0, we no longer support GLib1.x
140 GLIB_DIR=$(WIRESHARK_LIBS)\glib
141 # This macro is used by the setup target.
144 ##### To Use new packet list uncomment this line ####
145 ### Warning Experimental - work in progress
146 #NEW_PACKET_LIST_CONFIG=^#define NEW_PACKET_LIST 1
149 # Mandatory: GTK (& related libs) settings
151 # Please note: Since Wireshark release 1.0.0, we no longer support GTK1.x
153 # If you want building with GTK+, set GTK_DIR to the pathname of the
154 # directory in which the "include" and "lib" directories reside.
156 GTK_DIR=$(WIRESHARK_LIBS)\gtk2
157 # These macros are used by the nsis installer script and by the install target.
158 TIFF_DLL=libtiff3.dll
160 # These macros are used by the setup target.
165 TIFF_PKG=libtiff-3.8.2
166 JPEG_PKG=jpeg-6b-4-bin
170 # Mandatory: Version numbers of GTK and pango.
172 # (MAJOR + MINOR Version number but without MICRO version number)
173 # These macros are used by the nsis installer script and by the setup target.
175 # GTK 2.12 is the mainline since Wireshark 0.99.7
176 GTK_INST_VERSION=2.16
177 PANGO_INST_VERSION=1.24
180 # Mandatory for GTK >= 2: Gettext
182 # Set GETTEXT_DIR to the directory in which the
183 # GETTEXT include files and library resides.
185 GETTEXT_DIR=$(WIRESHARK_LIBS)\gettext-runtime-0.17-1
186 # This macro is used by the nsis installer script and by the install target.
188 # This macro is used by the setup target.
189 GETTEXT_PKG=-runtime-0.17-1
192 # Optional: WinPcap developer's pack to capture network traffic.
194 # If you have the WinPcap developer's pack (at least version 3.0),
195 # set this to the directory in which the WinPcap developer's pack resides.
197 # If you don't have the WPdpack, comment this line out, so that
198 # PCAP_DIR isn't defined.
200 PCAP_DIR=$(WIRESHARK_LIBS)\WPdpack
201 # This macro is used by the nsis installer script, by the u3/portable apps and by the setup target.
202 PCAP_VERSION=4_1_beta5
205 # Optional: WinPcap remote capture support and new API
206 # (pcap_open(), pcap_findalldevs_ex(), etc.)
211 # Optional: The ZLib enables unzipping of gzip compressed capture files
214 # If you have Zlib, set this to directory in which the Zlib headers
215 # and .lib file are stored.
217 # If you don't have Zlib, comment this line out, so that ZLIB_DIR isn't
220 ZLIB_DIR=$(WIRESHARK_LIBS)\zlib123
223 # Optional: the ADNS library enables asynchronous (nonblocking) DNS
226 # If you have GNU ADNS, set this to the directory in which the GNU ADNS
227 # .lib file is stored.
229 # If you don't have GNU ADNS, comment this line out, so that ADNS_DIR
232 # If C_ARES_DIR is defined below, it will override this setting.
234 #ADNS_DIR=$(WIRESHARK_LIBS)\adns-1.0-win32-05ws
237 # Optional: the c-ares library enables asynchronous (nonblocking) DNS
240 # If you have c-ares, set this to the directory in which the c-ares
241 # .lib file is stored. Setting this will override ADNS_DIR above. You
244 # If you're using Visual C++ 6.0, you'll have to use a platform SDK that
245 # defines socklen_t, such as Windows Server 2003 PSDK.
247 # If you don't have c-ares, comment this line out, so that C_ARES_DIR
250 C_ARES_DIR=$(WIRESHARK_LIBS)\c-ares-1.6.0ws
253 # Optional: the PCRE (Perl Compatible Regular Expressions) library
254 # enables regular expressions for display filters.
256 # If you have the PCRE library, set this to the directory in which
257 # the GNUWIN32 pcre-lib package is stored.
259 # If you don't have PCRE, comment this line out, so that PCRE_DIR
262 PCRE_DIR=$(WIRESHARK_LIBS)\pcre-7.0
265 # Optional: the GNUTLS library enables ssl decryption.
267 # If you have the GNUTLS library, set this to the directory where
268 # the lib and include files are stored.
270 # If you don't have GNUTLS, comment this line out, so that GNUTLS_DIR
273 # Platform SDK conflicts with openssl.h header
274 GNUTLS_DIR=$(WIRESHARK_LIBS)\gnutls-2.8.1-1
277 # Optional: the KFW library enables kerberos/sasl/dcerpc decryption.
279 # If you have the kerberos for windows (mit) library, set this to the
280 # directory where the kfw package is stored.
282 # If you don't have KFW, comment this line out, so that KFW_DIR
285 KFW_DIR=$(WIRESHARK_LIBS)\kfw-3.2.2-ws1
288 # Optional: the Nettle library enables ??? decryption.
290 # If you have the Nettle encryption library, set this to the
291 # directory in which the nettle package is stored.
293 # If you don't have Nettle, comment this line out, so that NETTLE_DIR
296 # NETTLE_DIR=$(WIRESHARK_LIBS)\nettle-1.10
299 # Optional: the LUA library enables scripting support.
301 # If you have the LUA library, set this to the directory in which
302 # the LUA package is stored.
304 # If you don't have LUA, comment this line out, so that LUA_DIR
307 LUA_DIST=5_1_4_Win32_dll6
308 LUA_DIR=$(WIRESHARK_LIBS)\lua5.1.4
311 # Optional: the PORTAUDIO library enables audio output for RTP streams.
313 # If you have the PORTAUDIO library (used for rtp_player), set this to
314 # the directory in which the PORTAUDIO library is stored.
316 # If you don't have PORTAUDIO, comment this line out, so that
317 # PORTAUDIO_DIR isn't defined.
319 #PORTAUDIO_DIR=$(WIRESHARK_LIBS)\portaudio_v18_1
320 PORTAUDIO_DIR=$(WIRESHARK_LIBS)\portaudio_v19_2
323 # Version number of PortAudio
325 #PORTAUDIO_VERSION=18
329 # Optional: AirPcap developer's pack to capture wireless network traffic
330 # incl. 802.11 management frames.
332 # If you have the AirPcap developer's pack, set this to the directory
333 # in which the AirPcap developer's pack resides.
335 # If you don't have the AirPcap developer's pack, comment this line out,
336 # so that AIRPCAP_DIR isn't defined.
338 AIRPCAP_DIR=$(WIRESHARK_LIBS)\AirPcap_Devpack_1_0_0_594\AirPcap_Devpack
341 # Optional: LIBSMI, System Management Interface
343 # Used for oid-name resolution for SNMP and other protocols
345 SMI_DIR=$(WIRESHARK_LIBS)\libsmi-0.4.8
348 # Optional: GeoIP, IP address database lookups
350 # Used to map IP addresses to MaxMind GeoIP database entries
352 # GeoIP requires IPv6 definitions that don't ship with Visual C++ 6.0.
353 # However, the Microsoft Platform SDK for Windows Server 2003 R2 provides
354 # these definitions. The SDK's SetEnv.bat script defines INETSDK.
355 !IF "$(MSVC_VARIANT)" != "MSVC6" || DEFINED(INETSDK)
356 GEOIP_DIR=$(WIRESHARK_LIBS)\GeoIP-1.4.5ws
360 ##### Win64 Libraries #####
362 # Mandatory: GLib settings
364 # Please note: Since Wireshark release 1.0.0, we no longer support GLib1.x
367 GLIB_DIR=$(WIRESHARK_LIBS)\glib
368 # This macro is used by the setup target.
371 ##### To Use new packet list uncomment this line ####
372 ### Warning Experimental - work in progress
373 #NEW_PACKET_LIST_CONFIG=^#define NEW_PACKET_LIST 1
376 # Mandatory: GTK (& related libs) settings
378 # Please note: Since Wireshark release 1.0.0, we no longer support GTK1.x
380 # If you want building with GTK+, set GTK_DIR to the pathname of the
381 # directory in which the "include" and "lib" directories reside.
383 GTK_DIR=$(WIRESHARK_LIBS)\gtk2
384 # These macros are used by the nsis installer script and by the install target.
386 JPEG_DLL=libjpeg-62.dll
387 # These macros are used by the setup target.
392 TIFF_PKG=libtiff_3.8.2-1_win64
393 JPEG_PKG=jpeg_6b-2_win64
397 # Mandatory: Version numbers of GTK and pango.
399 # (MAJOR + MINOR Version number but without MICRO version number)
400 # These macros are used by the nsis installer script and by the setup target.
402 GTK_INST_VERSION=2.16
403 PANGO_INST_VERSION=1.24
406 # Mandatory for GTK >= 2: Gettext
408 # Set GETTEXT_DIR to the directory in which the
409 # GETTEXT include files and library resides.
411 GETTEXT_DIR=$(WIRESHARK_LIBS)\gettext-0.17-1
412 # This macro is used by the nsis installer script and by the install target.
413 GETTEXT_DLL=libintl-8.dll
414 # This macro is used by the setup target.
415 GETTEXT_PKG=_0.17-1_win64
418 # Optional: WinPcap developer's pack to capture network traffic.
420 # If you have the WinPcap developer's pack (at least version 3.0),
421 # set this to the directory in which the WinPcap developer's pack resides.
423 # If you don't have the WPdpack, comment this line out, so that
424 # PCAP_DIR isn't defined.
426 PCAP_DIR=$(WIRESHARK_LIBS)\WPdpack
427 # This macro is used by the nsis installer script, by the u3/portable apps and by the setup target.
428 PCAP_VERSION=4_1_beta5
431 # Optional: WinPcap remote capture support and new API
432 # (pcap_open(), pcap_findalldevs_ex(), etc.)
437 # Optional: The ZLib enables unzipping of gzip compressed capture files
440 # If you have Zlib, set this to directory in which the Zlib headers
441 # and .lib file are stored.
443 # If you don't have Zlib, comment this line out, so that ZLIB_DIR isn't
446 ZLIB_DIR=$(WIRESHARK_LIBS)\zlib123
449 # Optional: the ADNS library enables asynchronous (nonblocking) DNS
452 # If you have GNU ADNS, set this to the directory in which the GNU ADNS
453 # .lib file is stored.
455 # If you don't have GNU ADNS, comment this line out, so that ADNS_DIR
458 # If C_ARES_DIR is defined below, it will override this setting.
460 #ADNS_DIR=$(WIRESHARK_LIBS)\adns-1.0-win32-05ws
463 # Optional: the c-ares library enables asynchronous (nonblocking) DNS
466 # If you have c-ares, set this to the directory in which the c-ares
467 # .lib file is stored. Setting this will override ADNS_DIR above. You
470 # If you're using Visual C++ 6.0, you'll have to use a platform SDK that
471 # defines socklen_t, such as Windows Server 2003 PSDK.
473 # If you don't have c-ares, comment this line out, so that C_ARES_DIR
476 #C_ARES_DIR=$(WIRESHARK_LIBS)\c-ares-1.5.2ws
479 # Optional: the PCRE (Perl Compatible Regular Expressions) library
480 # enables regular expressions for display filters.
482 # If you have the PCRE library, set this to the directory in which
483 # the GNUWIN32 pcre-lib package is stored.
485 # If you don't have PCRE, comment this line out, so that PCRE_DIR
488 #PCRE_DIR=$(WIRESHARK_LIBS)\pcre-7.0
491 # Optional: the GNUTLS library enables ssl decryption.
493 # If you have the GNUTLS library, set this to the directory where
494 # the lib and include files are stored.
496 # If you don't have GNUTLS, comment this line out, so that GNUTLS_DIR
499 # Platform SDK conflicts with openssl.h header
500 #GNUTLS_DIR=$(WIRESHARK_LIBS)\gnutls-2.8.1-1
503 # Optional: the KFW library enables kerberos/sasl/dcerpc decryption.
505 # If you have the kerberos for windows (mit) library, set this to the
506 # directory where the kfw package is stored.
508 # If you don't have KFW, comment this line out, so that KFW_DIR
511 #KFW_DIR=$(WIRESHARK_LIBS)\kfw-3.2.2-ws1
514 # Optional: the Nettle library enables ??? decryption.
516 # If you have the Nettle encryption library, set this to the
517 # directory in which the nettle package is stored.
519 # If you don't have Nettle, comment this line out, so that NETTLE_DIR
522 # NETTLE_DIR=$(WIRESHARK_LIBS)\nettle-1.10
525 # Optional: the LUA library enables scripting support.
527 # If you have the LUA library, set this to the directory in which
528 # the LUA package is stored.
530 # If you don't have LUA, comment this line out, so that LUA_DIR
533 LUA_DIST=5_1_4_Win64_dll9
534 LUA_DIR=$(WIRESHARK_LIBS)\lua5.1.4
537 # Optional: the PORTAUDIO library enables audio output for RTP streams.
539 # If you have the PORTAUDIO library (used for rtp_player), set this to
540 # the directory in which the PORTAUDIO library is stored.
542 # If you don't have PORTAUDIO, comment this line out, so that
543 # PORTAUDIO_DIR isn't defined.
545 #PORTAUDIO_DIR=$(WIRESHARK_LIBS)\portaudio_v18_1
546 PORTAUDIO_DIR=$(WIRESHARK_LIBS)\portaudio_v19_2
549 # Version number of PortAudio
551 #PORTAUDIO_VERSION=18
555 # Optional: AirPcap developer's pack to capture wireless network traffic
556 # incl. 802.11 management frames.
558 # If you have the AirPcap developer's pack, set this to the directory
559 # in which the AirPcap developer's pack resides.
561 # If you don't have the AirPcap developer's pack, comment this line out,
562 # so that AIRPCAP_DIR isn't defined.
564 #AIRPCAP_DIR=$(WIRESHARK_LIBS)\AirPcap_Devpack_1_0_0_594\AirPcap_Devpack
567 # Optional: LIBSMI, System Management Interface
569 # Used for oid-name resolution for SNMP and other protocols
571 #SMI_DIR=$(WIRESHARK_LIBS)\libsmi-0.4.8
574 # Optional: GeoIP, IP address database lookups
576 # Used to map IP addresses to MaxMind GeoIP database entries
578 # GeoIP requires IPv6 definitions that don't ship with Visual C++ 6.0.
579 # However, the Microsoft Platform SDK for Windows Server 2003 R2 provides
580 # these definitions. The SDK's SetEnv.bat script defines INETSDK.
581 !IF "$(MSVC_VARIANT)" != "MSVC6" || DEFINED(INETSDK)
582 #GEOIP_DIR=$(WIRESHARK_LIBS)\GeoIP-1.4.5ws
589 # Set the following mandatory commands to find the tools.
590 # The easiest way is to use the corresponding packages from cygwin.
592 # Set up the path to the cygwin binaries
593 CYGWIN_PATH=c:\cygwin\bin
595 # command for a shell (cygwin's bash package recommended)
598 # bash versions after 3.1.6 need the 'igncr' shell option to be able to
599 # process scripts in windows 'native format' (dos crlf format).
600 # The following !IF results in the option being used only if it is available
601 # since using it on bash version 3.1.6 (or earlier) is not required and
602 # will cause an error message.
603 !if "$(SH_PROG)"=="bash" && [$(CYGWIN_PATH)\bash -c "set -o igncr" 2>nul: ] == 0
607 SH=$(SH_PROG) $(SH_FLAGS)
610 # command for perl (cygwin's perl package recommended)
613 # command for pod2man and pod2html
614 # (part of the perl package, usually leave these unchanged)
615 POD2MAN=$(SH) pod2man
616 POD2HTML=$(SH) pod2html
618 # Command for native Windows Python (recommended)
619 # V2.4 to V2.6 should work
621 # If you want to specify your Python settings, uncomment the lines below.
622 #PYTHON="C:\Python26\python.exe"
623 #PATH=c:\Python26;$(PATH)
625 # Command for Cygwin's Python (not recommended)
628 # Otherwise, find Python automatically.
630 !IF EXIST(c:\Python26\python.exe)
631 PYTHON="C:\Python26\python.exe"
632 PATH=c:\Python26;$(PATH)
633 !ELSE IF EXIST(c:\Python25\python.exe)
634 PYTHON="C:\Python25\python.exe"
635 PATH=c:\Python25;$(PATH)
636 !ELSE IF EXIST(c:\Python24\python.exe)
637 PYTHON="C:\Python24\python.exe"
638 PATH=c:\Python24;$(PATH)
642 # command for lex/flexx (cygwin's flex recommended)
645 # command for yacc/bison (cygwin's bison recommended)
649 # Optional: To build the NSIS installer.
651 # If you have the NSIS package, set this to the NSIS executable.
653 # If you don't have NSIS, comment this line out, so that MAKENSIS
656 MAKENSIS="$(PROGRAM_FILES)\nsis\makensis.exe"
659 # Optional: To build the developers API documentation with doxygen and dot.
660 # Currently experimental, outdated and incomplete.
662 # You will have to download and install:
663 # Doxygen from: http://www.doxygen.org
664 # Graphviz from: http://www.research.att.com/sw/tools/graphviz/
666 # If you have doxygen, set this to the doxygen executable.
668 # If you don't want the developers documentation (or don't have the tools),
669 # comment this line out, so that DOXYGEN isn't defined.
671 #DOXYGEN="$(PROGRAM_FILES)/doxygen/bin/doxygen.exe"
674 # Recommended: Use the compressed html help format .chm as the Wireshark integrated help.
676 # The required htmlhelp.h and htmlhelp.lib should be included in MSVC_VARIANT > MSVC6.
678 # For MSVC_VARIANT == MSVC6 you will have to download and install the html help workshop from:
680 # http://msdn.microsoft.com/library/default.asp?url=/library/en-us/htmlhelp/html
681 # /hwMicrosoftHTMLHelpDownloads.asp
683 # Then point HHC_DIR to the html help dir (where hhc.exe resides).
685 # If you don't want the online help (or don't have the tools),
686 # comment this line out, so that HHC_DIR isn't defined.
688 HHC_DIR=$(PROGRAM_FILES)/HTML Help Workshop
691 # Optional: To reduce the size of dlls and exes, which is especially useful for USB device distributions (U3, PortableApps)
693 # If you have the UPX package, set this to the upx.exe executable.
695 # UPX can be downloaded from:
696 # http://upx.sourceforge.net/
698 # If you don't have UPX, or don't want to pack exes and dlls,
699 # comment this line out, so that UPX isn't defined.
702 UPX=$(WIRESHARK_LIBS)\upx303w\upx.exe
704 ##### Flags, PATHs and Miscellaneous #####
706 # "convert" the MSVC variant into the required MSC compiler version
707 !IF "$(MSVC_VARIANT)" == "MSVC6"
708 MSC_VER_REQUIRED=1200
709 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2002" || "$(MSVC_VARIANT)" == "DOTNET10"
710 MSC_VER_REQUIRED=1300
711 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2003" || "$(MSVC_VARIANT)" == "DOTNET11"
712 MSC_VER_REQUIRED=1310
713 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20"
714 MSC_VER_REQUIRED=1400
715 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2008" || "$(MSVC_VARIANT)" == "MSVC2008EE"
716 MSC_VER_REQUIRED=1500
718 !ERROR MSVC_VARIANT unknown
722 # /W3 warning level 3 (0 less - 4 most, 1 default)
723 # /Zi create .pdb file for debugging
724 # /MD use "Multithreading Debug" libraries
725 # /D_CRT_SECURE_NO_DEPRECATE Don't warn for "insecure" calls, see MSDN "Security Enhancements in the CRT"
726 # /D_CRT_NONSTDC_NO_DEPRECATE Don't warn for "Deprecated CRT Functions" as MSDN calls this
727 # /D_BIND_TO_CURRENT_CRT_VERSION=1 Make sure our CRT and manifest versions match (http://msdn.microsoft.com/en-us/library/cc664727.aspx)
728 # /DWIN32_LEAN_AND_MEAN Don't include unnecessary Windows include files (see windows.h)
729 # /MP [<number of processes>] [MSVC2008]: Compiles multiple source files by using multiple processes
730 # Add if desired for compile speedup on machines with 2 or more "effective processors"
731 # /MANIFEST:no Don't create a SxS manifest. Makes sure our plugins don't load a second copy of the CRT.
733 !IF "$(MSVC_VARIANT)" == "MSVC6" || "$(MSVC_VARIANT)" == "MSVC2002" || "$(MSVC_VARIANT)" == "DOTNET10" || "$(MSVC_VARIANT)" == "MSVC2003" || "$(MSVC_VARIANT)" == "DOTNET11"
734 LOCAL_CFLAGS=/Zi /W3 /MD /DWIN32_LEAN_AND_MEAN /DMSC_VER_REQUIRED=$(MSC_VER_REQUIRED)
735 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20" || "$(MSVC_VARIANT)" == "MSVC2008" || "$(MSVC_VARIANT)" == "MSVC2008EE"
736 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
738 !ERROR MSVC_VARIANT unknown
741 # http://msdn.microsoft.com/en-us/library/bb385193.aspx
742 # /MP (Build with Multiple Processes)
744 # If you omit the processMax argument, the compiler retrieves the number of effective processors
745 # on your computer from the operating system, and creates a process for each processor.
747 # The following compiler options and language features that are incompatible with the /MP option:
748 # #import preprocessor directive
754 !IF "$(MSVC_VARIANT)" == "MSVC2008" || "$(MSVC_VARIANT)" == "MSVC2008EE"
755 LOCAL_CFLAGS= $(LOCAL_CFLAGS) /MP
758 # /DEBUG generate debug info
759 # /PROFILE generate map file(s) for profiling
760 # /DEFAULTLIB:xxx use xxx as the standard C library
761 # /NODEFAULTLIB:xxx don't use xxx as the standard C library
763 LOCAL_LDFLAGS=/DEBUG /MACHINE:$(TARGET_MACHINE)
765 !IF $(MSC_VER_REQUIRED) >= 1400
766 DLL_LDFLAGS = /MANIFEST:no
769 PLUGIN_LDFLAGS = /NOLOGO /INCREMENTAL:no $(LOCAL_LDFLAGS) $(DLL_LDFLAGS)
772 # According to http://bugs.wireshark.org/bugzilla/show_bug.cgi?id=403
773 # XCOPY under Windows NT doesn't support the "/Y" flag. This works
775 # XXX - This apparently doesn't work for some versions of nmake:
776 # http://support.microsoft.com/default.aspx?scid=kb;en-us;86814
777 # It looks like we'll have to call "set copycmd=/y" before we run xcopy.
781 # If you don't want to build libwireshark.dll, you should comment out the
782 # following line. (Note: for plugin support this option must stay activated)
783 ENABLE_LIBWIRESHARK=USE
786 # install (debug) directory for Wireshark (relative to your source dir)
787 INSTALL_DIR=wireshark-gtk2
791 ##### C-Runtime Redistributable #####
793 # The C-Runtime since Version 7 must be shipped together with
794 # the program installer, to avoid missing msvcr*.dll files on
795 # the target machine.
797 # The location of these files differ on the various compiler
798 # packages, the following will use the default paths depending
799 # on the package version.
801 !IF "$(MSVC_VARIANT)" == "MSVC6"
802 # msvcrt.dll will already be available on target machines - nothing additional to install
804 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2002"
805 # you probably need to tweak this directory if you don't use the professional edition!
806 MSVCR_DLL=$(PROGRAM_FILES)\Microsoft Visual Studio .NET\Visual Studio .NET Professional - English\msvcr70.dll
808 !ELSEIF "$(MSVC_VARIANT)" == "DOTNET10"
809 # no redistributable available for this package!
811 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2003"
812 # you probably need to tweak this directory if you don't use the professional edition!
813 MSVCR_DLL=$(PROGRAM_FILES)\Microsoft Visual Studio .NET 2003\Visual Studio .NET Professional 2003 - English\msvcr71.dll
815 !ELSEIF "$(MSVC_VARIANT)" == "DOTNET11"
816 # no redistributable available for this package!
818 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2005"
819 MSVCR_DLL=$(PROGRAM_FILES)\Microsoft Visual Studio 8\VC\redist\$(VCREDIST_DLL)\Microsoft.VC80.CRT\*.*
821 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20" || "$(MSVC_VARIANT)" == "MSVC2008EE"
822 # you need to download the redistributable package vcredist_x86.exe from Microsoft first,
823 # and copy it to the lib folder!!!
824 VCREDIST_EXE=$(WIRESHARK_LIBS)\vcredist_$(TARGET_MACHINE).exe
826 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2008"
827 MSVCR_DLL=$(PROGRAM_FILES)\Microsoft Visual Studio 9.0\VC\redist\$(VCREDIST_DLL)\Microsoft.VC90.CRT\*.*
830 !ERROR MSVC_VARIANT unknown
835 ##### Advanced: Docbook/XML documentation generation #####
836 # If you want to generate the Docbook/XML based docs (User's and Developer's
837 # Guide, ...), you'll need some additional tools / libraries compared to the
838 # rest of the build process.
840 # FOR DETAILED INSTRUCTIONS TO GENERATE THE DOCS, SEE: docbook\readme.txt.
842 # If you don't call the Makefile.nmake in the docbook dir to generate the
843 # docs, the following settings in this section will have no effect.
845 # formatting objects processor executable
846 # Comment this out if you don't have fop installed or you don't want the docs
849 FOP=fop-0.20.5\fop.bat
852 # Additional options to fop.
856 # Comment this out if you don't have hhc.exe or you don't want the docs in
859 # Beware: hhc.exe is NOT part of the MSVC packages in HHC_DIR mentioned above,
860 # so you'll need to install the HTML Help Workshop for this.
861 HHC_EXE="$(HHC_DIR)\hhc.exe"
863 # html to text converter for text version of release notes, e.g. elinks.
864 # This could also be "lynx", or "true" if neither elinks nor lynx is installed
865 # (cygwin: lynx works, elinks not available, links and true doesn't produce output)
866 #HTML2TXT=elinks -dump -dump-width 72
867 #HTML2TXT=links -dump -width 72
868 #HTML2TXT=lynx -dump -width=72 -nolist -stdin
871 HTML2TXT=$(PYTHON) $(TOOLS_DIR)\html2text.py --width=72 --no-links
874 # the XSL processor (part of cygwin's libxslt package)
877 # the XML validator (part of cygwin's libxml2 package)
882 ##############################################################################
884 # You should not have to change anything below this comment.
885 # If you do, it's a deficiency in the Makefile.nmake files;
886 # either tell wireshark-dev@wireshark.org about it, including
887 # details of why you had to change it, or fix config.nmake
888 # and any Makefile.nmake files that need to be changed, and
889 # send us the patches, along with details of why the change
892 ##############################################################################
895 # The RC_VERSION should be comma-separated, not dot-separated,
896 # as per Graham Bloice's message in
898 # http://www.ethereal.com/lists/ethereal-dev/200303/msg00283.html
900 # "The RC_VERSION variable in config.nmake should be comma separated.
901 # This allows the resources to be built correctly and the version
902 # number to be correctly displayed in the explorer properties dialog
903 # for the executables, and XP's tooltip, rather than 0.0.0.0."
906 VERSION=$(VERSION_MAJOR).$(VERSION_MINOR).$(VERSION_MICRO)$(VERSION_EXTRA)
907 RC_VERSION=$(VERSION_MAJOR),$(VERSION_MINOR),$(VERSION_MICRO),$(VERSION_BUILD)
909 WTAP_VERSION=$(WTAP_VERSION_MAJOR).$(WTAP_VERSION_MINOR).$(WTAP_VERSION_MICRO)
910 RC_WTAP_VERSION=$(WTAP_VERSION_MAJOR),$(WTAP_VERSION_MINOR),$(WTAP_VERSION_MICRO)
913 GLIB_CFLAGS=/I$(GLIB_DIR)\include\glib-$(GLIB_VERSION) \
914 /I$(GLIB_DIR)\lib\glib-$(GLIB_VERSION)\include
915 GLIB_LIBS=$(GLIB_DIR)\lib\glib-$(GLIB_VERSION).lib \
916 $(GLIB_DIR)\lib\gmodule-$(GLIB_VERSION).lib \
917 $(GLIB_DIR)\lib\gobject-$(GLIB_VERSION).lib
918 GTHREAD_LIBS=$(GLIB_DIR)\lib\gthread-$(GLIB_VERSION).lib \
921 GTK_CFLAGS=$(GLIB_CFLAGS) /I$(GTK_DIR)\include\gtk-2.0 \
922 /I$(GTK_DIR)\lib\gtk-2.0\include \
923 /I$(GTK_DIR)\include\atk-1.0 \
924 /I$(GTK_DIR)\include\cairo \
925 /I$(GTK_DIR)\include\pango-1.0
926 GTK_LIBS=$(GTK_DIR)\lib\gtk-win32-2.0.lib \
927 $(GTK_DIR)\lib\gdk-win32-2.0.lib \
928 $(GTK_DIR)\lib\gdk_pixbuf-2.0.lib \
929 $(GTK_DIR)\lib\pango-1.0.lib \
932 !IF "$(GTK_INST_VERSION)" == "2.16" || "$(GTK_INST_VERSION)" == "2.14" || "$(GTK_INST_VERSION)" == "2.12"
938 GTK_WIMP_DLLSRC_DIR=$(GTK_DIR)\lib\gtk-2.0\2.10.0\engines
939 GTK_WIMP_DLLDST_DIR=lib\gtk-2.0\2.10.0\engines
940 GTK_WIMP_RCSRC_DIR=$(GTK_DIR)\share\themes\MS-Windows\gtk-2.0
941 GTK_WIMP_RCDST_DIR=etc\gtk-2.0
943 !ERROR ? Unknown or invalid GTK_INST_VERSION
946 !IF "$(PANGO_INST_VERSION)" == "1.24" || "$(PANGO_INST_VERSION)" == "1.22" || "$(PANGO_INST_VERSION)" == "1.18" || "$(PANGO_INST_VERSION)" == "1.16"
949 !ERROR ? Unknown or invalid PANGO_INST_VERSION
953 AIRPCAP_CONFIG=^#define HAVE_AIRPCAP 1
954 AIRPDCAP_CONFIG=^#define HAVE_AIRPDCAP 1
955 #AIRPCAP_CFLAGS=/I$(AIRPCAP_DIR)\include
962 # Nmake uses carets to escape special characters
963 WINPCAP_CONFIG=^#define HAVE_LIBPCAP 1
964 PCAP_FINDALLDEVS_CONFIG=^#define HAVE_PCAP_FINDALLDEVS 1
965 PCAP_DATALINK_NAME_TO_VAL_CONFIG=^#define HAVE_PCAP_DATALINK_NAME_TO_VAL 1
966 PCAP_DATALINK_VAL_TO_NAME_CONFIG=^#define HAVE_PCAP_DATALINK_VAL_TO_NAME 1
967 # PCAP_BREAKLOOP won't have any benefit on Win32, but breaks compatibility with 3.0
968 PCAP_BREAKLOOP_CONFIG=
970 # no WpdPack installed
972 PCAP_FINDALLDEVS_CONFIG=
973 PCAP_DATALINK_NAME_TO_VAL_CONFIG=
974 PCAP_DATALINK_VAL_TO_NAME_CONFIG=
975 PCAP_BREAKLOOP_CONFIG=
978 PCAP_LIST_DATALINKS_CONFIG=^#define HAVE_PCAP_LIST_DATALINKS 1
979 PCAP_SET_DATALINK_CONFIG=^#define HAVE_PCAP_SET_DATALINK 1
981 !IF DEFINED(PCAP_DIR) && DEFINED(PCAP_REMOTE)
982 PCAP_HAVE_REMOTE_CONFIG=^#define HAVE_REMOTE 1
983 PCAP_REMOTE_CONFIG=^#define HAVE_PCAP_REMOTE 1
984 PCAP_OPEN_CONFIG=^#define HAVE_PCAP_OPEN 1
985 PCAP_FINDALLDEVS_EX_CONFIG=^#define HAVE_PCAP_FINDALLDEVS_EX 1
986 PCAP_CREATESRCSTR_CONFIG=^#define HAVE_PCAP_CREATESRCSTR 1
987 PCAP_SETSAMPLING_CONFIG=^#define HAVE_PCAP_SETSAMPLING 1
989 PCAP_HAVE_REMOTE_CONFIG=
992 PCAP_FINDALLDEVS_EX_CONFIG=
993 PCAP_CREATESRCSTR_CONFIG=
994 PCAP_SETSAMPLING_CONFIG=
998 ZLIB_PATH=$(ZLIB_DIR)
999 ZLIB_CFLAGS=/I$(ZLIB_DIR)\include
1000 ZLIB_LIBS=$(ZLIB_DIR)\lib\zdll.lib
1001 ZLIB_DLL=$(ZLIB_DIR)\zlib1.dll
1002 # Nmake uses carets to escape special characters
1003 ZLIB_CONFIG=^#define HAVE_LIBZ 1
1013 C_ARES_CFLAGS=/I$(C_ARES_DIR)
1014 C_ARES_LIBS=$(C_ARES_DIR)\cares.lib
1015 C_ARES_DLL=$(C_ARES_DIR)\cares.dll
1016 # Nmake uses carets to escape special characters
1017 C_ARES_CONFIG=^#define HAVE_C_ARES 1
1023 ADNS_PATH=$(ADNS_DIR)\adns_win32\lib
1024 ADNS_CFLAGS=/I$(ADNS_DIR)\src /I$(ADNS_DIR)\adns_win32
1025 ADNS_LIBS=$(WIRESHARK_LIBS)\$(MSVC_VARIANT)\adns\adns_dll.lib
1026 ADNS_DLL=$(WIRESHARK_LIBS)\$(MSVC_VARIANT)\adns\adns_dll.dll
1027 # Nmake uses carets to escape special characters
1028 ADNS_CONFIG=^#define HAVE_GNU_ADNS 1
1037 KFW_PATH=$(KFW_DIR)\bin
1038 KFW_CFLAGS=/I$(KFW_DIR)\include
1039 KFW_LIBS=$(KFW_DIR)\lib\krb5_32.lib
1040 # Nmake uses carets to escape special characters
1041 KFW_CONFIG=^#define HAVE_MIT_KERBEROS 1
1049 PCRE_PATH=$(PCRE_DIR)\bin
1050 PCRE_CFLAGS=/I$(PCRE_DIR)\include
1051 PCRE_LIBS=$(PCRE_DIR)\lib\pcre.lib
1052 # Nmake uses carets to escape special characters
1053 PCRE_CONFIG=^#define HAVE_LIBPCRE 1
1061 NETTLE_CFLAGS=/I$(NETTLE_DIR)
1062 NETTLE_LIBS=$(NETTLE_DIR)\libnettle.lib
1063 # Nmake uses carets to escape special characters
1064 NETTLE_CONFIG=^#define HAVE_LIBNETTLE 1
1072 GNUTLS_PATH=$(GNUTLS_DIR)
1073 # /DNOCRYPT avoids inclusion of Wincrypt.h, avoiding a X509_NAME define clash
1074 GNUTLS_CFLAGS=/I$(GNUTLS_DIR)\include /DNOCRYPT /DIMPORT_LIGNUTLSDLL
1076 $(GNUTLS_DIR)\bin\libtasn1-3.lib \
1077 $(GNUTLS_DIR)\bin\libgpg-error-0.lib \
1078 $(GNUTLS_DIR)\bin\libgcrypt-11.lib \
1079 $(GNUTLS_DIR)\bin\libgnutls-26.lib
1080 # Nmake uses carets to escape special characters
1081 GNUTLS_CONFIG=^#define HAVE_LIBGNUTLS 1
1082 LIBGCRYPT_CONFIG=^#define HAVE_LIBGCRYPT 1
1091 LUA_CFLAGS=/I$(LUA_DIR)\include
1092 LUA_LIBS=$(LUA_DIR)\lua5.1.lib
1093 # Nmake uses carets to escape special characters
1094 LUA_CONFIG=^#define HAVE_LUA 1
1095 LUA_VERSION=^#define HAVE_LUA_5_1 1
1102 !IFDEF PORTAUDIO_DIR
1103 # Nmake uses carets to escape special characters
1104 PORTAUDIO_CONFIG=^#define HAVE_LIBPORTAUDIO 1
1105 !IF "$(PORTAUDIO_VERSION)" == "18"
1106 # V18 uses API version 1 and v19 API version 2
1107 PORTAUDIO_CFLAGS=/I$(PORTAUDIO_DIR)\pa_common
1108 PORTAUDIO_API_CONFIG=^#define PORTAUDIO_API_1 1
1110 PORTAUDIO_CFLAGS=/I$(PORTAUDIO_DIR)\include /I$(PORTAUDIO_DIR)\src\common /I$(PORTAUDIO_DIR)\src\os\win /DPA_NO_DS /DPA_NO_ASIO
1118 !IF "$(MSVC_VARIANT)" == "MSVC6"
1119 HHC_CFLAGS=/I"$(HHC_DIR)\include" -DHHC_DIR
1120 HHC_LIBS="$(HHC_DIR)\lib\htmlhelp.lib"
1122 HHC_CFLAGS=-DHHC_DIR
1123 HHC_LIBS=htmlhelp.lib
1131 SMI_CONFIG=^#define HAVE_LIBSMI 1
1132 SMI_CFLAGS=/I$(SMI_DIR)\include
1133 SMI_LIBS=$(SMI_DIR)\lib\smi.lib
1141 GEOIP_CONFIG=^#define HAVE_GEOIP 1
1142 GEOIP_CFLAGS=/I$(GEOIP_DIR)\libGeoIP
1143 GEOIP_LIBS=$(GEOIP_DIR)\libGeoIP\GeoIP.lib
1150 !IFDEF ENABLE_LIBWIRESHARK
1151 LIBWIRESHARK_CONFIG=^#define HAVE_LIBWIRESHARKDLL 1
1152 # Link plugins with the import library of libwireshark.dll
1153 LINK_PLUGINS_WITH_LIBWIRESHARK=USE
1155 LIBWIRESHARK_CONFIG=
1158 # Construct the path
1159 PATH=$(PATH);$(CYGWIN_PATH);$(GLIB_DIR)\bin;$(GETTEXT_DIR)\bin;$(ZLIB_PATH);$(ADNS_PATH)
1161 # We can't use a lot of IPv6 code with plain Visual C++ 6.0
1162 !IF "$(MSVC_VARIANT)" == "MSVC6" && !DEFINED(MSSDK)
1165 INET6_CONFIG=^#define INET6 1
1168 !IF "$(MSVC_VARIANT)" == "MSVC6" && !DEFINED(MSSDK)
1171 NTDDNDIS_CONFIG=^#define HAVE_NTDDNDIS_H 1