Fix Dead Store (Dead assignement/Dead increment) Warning found by Clang
[obnox/wireshark/wip.git] / config.nmake
1 # $Id$
2
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).
5
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
11 !ENDIF
12
13 ##### Versions #####
14
15 # The current Wireshark version
16 # It's highly recommended to leave MAJOR/MINOR/MICRO unchanged
17 VERSION_MAJOR=1
18 VERSION_MINOR=5
19 VERSION_MICRO=2
20 VERSION_BUILD=0
21 # It's recommended to change VERSION_EXTRA for your own custom builds
22 # e.g. "-SVN-12345"
23 VERSION_EXTRA=
24
25 # The version of the wiretap library (recommended: leave unchanged)
26 WTAP_VERSION_MAJOR=0
27 WTAP_VERSION_MINOR=3
28 WTAP_VERSION_MICRO=1
29
30
31
32 ##### Directories #####
33
34 #
35 # Base directory, where your libraries reside, which are needed to
36 # compile the sources. This setting is used only inside this file.
37 #
38 WIRESHARK_LIBS=C:\wireshark-$(WIRESHARK_TARGET_PLATFORM)-libs
39
40 #
41 # Base directory, where your programs reside.
42 # This setting is used only inside this file.
43 #
44 PROGRAM_FILES=$(PROGRAMFILES)
45
46 #
47 # Location of the "tools" directory. This affects HTML2TXT below and should
48 # be overridden by makefiles in any subdirectories that use HTML2TXT.
49 !IFNDEF TOOLS_DIR
50 TOOLS_DIR=tools
51 !ENDIF
52
53 #
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 # PROCESSOR_ARCHITECTURE (Used for redistributable packages and
59 # manifests) should be one of "x86" or "amd64".
60 !if "$(WIRESHARK_TARGET_PLATFORM)" == "win32"
61 TARGET_MACHINE=x86
62 CPU=i386
63 PROCESSOR_ARCHITECTURE=x86
64 !else if "$(WIRESHARK_TARGET_PLATFORM)" == "win64"
65 TARGET_MACHINE=x64
66 CPU=AMD64
67 PROCESSOR_ARCHITECTURE=amd64
68 !else
69 !error Your mysterious moon-man architecture "$(WIRESHARK_TARGET_PLATFORM)" frightens and confuses us.
70 !endif
71
72
73 ##### Microsoft Visual C / Studio Variant #####
74 # For the different Studios, see: http://en.wikipedia.org/wiki/Microsoft_Visual_Studio
75 # only one of the following MSVC_VARIANT settings should be used
76 # BTW: The "Microsoft Visual C++ Toolkit 2003" DOESN'T WORK for WS!
77
78 # "Microsoft Visual Studio 6.0"
79 # Visual C++ 6.0, _MSC_VER 1200, msvcrt.dll (version 6)
80 #MSVC_VARIANT=MSVC6
81
82 # "Microsoft Visual Studio .NET (2002)"
83 # Visual C++ 7.0, _MSC_VER 1300, msvcr70.dll
84 #MSVC_VARIANT=MSVC2002
85
86 # "Microsoft .Net Framework SDK Version 1.0"
87 # needs additional Platform SDK installation
88 # Visual C++ 7.0, _MSC_VER 1300, msvcr70.dll
89 #MSVC_VARIANT=DOTNET10
90
91 # "Microsoft Visual Studio .NET 2003"
92 # Visual C++ 7.1, _MSC_VER 1310, msvcr71.dll
93 #MSVC_VARIANT=MSVC2003
94
95 # "Microsoft .Net Framework SDK Version 1.1"
96 # needs additional Platform SDK installation
97 # Visual C++ 7.1, _MSC_VER 1310, msvcr71.dll
98 #MSVC_VARIANT=DOTNET11
99
100 # "Microsoft Visual Studio 2005"
101 # Visual C++ 8.0, _MSC_VER 1400, msvcr80.dll
102 #MSVC_VARIANT=MSVC2005
103
104 # "Microsoft Visual C++ 2005 Express Edition"
105 # needs additional Platform SDK installation
106 # Visual C++ 8.0, _MSC_VER 1400, msvcr80.dll
107 #MSVC_VARIANT=MSVC2005EE
108
109 # "Microsoft .Net Framework 2.0 SDK"
110 # needs additional Platform SDK installation
111 # Visual C++ 8.0, _MSC_VER 1400, msvcr80.dll
112 #MSVC_VARIANT=DOTNET20
113
114 # "Microsoft Visual Studio 2008"
115 # Visual C++ 9.0, _MSC_VER 1500, msvcr90.dll
116 #MSVC_VARIANT=MSVC2008
117
118 # "Microsoft Visual C++ 2008 Express Edition"
119 # Visual C++ 9.0, _MSC_VER 1500, msvcr90.dll
120 #MSVC_VARIANT=MSVC2008EE
121
122 # "Microsoft Visual Studio 2010"
123 # Visual C++ 10.0, _MSC_VER 1600, msvcr100.dll
124 #MSVC_VARIANT=MSVC2010
125
126 # "Microsoft Visual C++ 2010 Express Edition"
127 # Visual C++ 10.0, _MSC_VER 1600, msvcr100.dll
128 #MSVC_VARIANT=MSVC2010EE
129
130 # The default if we haven't set a system environment variable or
131 # uncommented an entry above.
132 !IFNDEF MSVC_VARIANT
133 MSVC_VARIANT=MSVC2008
134 !ENDIF
135
136 #
137 # Optional: To compile some time critical code from assembler instead of C
138 #
139 # If you have the NASM compiler, set this to the NASM executable.
140 # http://nasm.sourceforge.net/
141 #
142 # If you don't have NASM, comment this line out, so that NASM
143 # isn't defined.
144 #
145 NASM=$(WIRESHARK_LIBS)\nasm-2.09.08\nasm.exe
146
147 #
148 # Optional: the Python library enables scripting support.
149 #
150 # If you don't have the Python library, comment this line out, so that
151 # PYTHON_EMBED isn't defined.
152 #
153 # NOTE: The Python library must have been compiled with the same
154 # compiler (MSVC_VARIANT) as Wireshark. Known python.org Python
155 # CRT versions:
156 #
157 # Python version    CRT (32-bit)    CRT (64-bit)
158 # 2.4.4             7.1             ?
159 # 2.6.1             9.0             ?
160 # 2.6.2                             9.0
161 #
162 # If you versions of Python and Visual C++ use different CRTs
163 # comment this out.
164 #
165 # XXX The DLL path in epan/wspython/wspy_libws.py likely needs to
166 # be fixed before this is enabled by default.
167 #PYTHON_EMBED=1
168
169 #
170 # Optional: the Python interpreter is used as part of the buildsystem
171 #
172 # This will override the automatic detection below.
173 #PYTHON_VER=27
174 #PYTHON_DIR=C:\Python$(PYTHON_VER)
175
176 #
177 # If you don't have the native Python package installed, you can use
178 # the Cygwin version (not recommended)
179 #
180 #PYTHON=env python
181
182 # Santity check: native vs Cygwin Python options
183 !IF DEFINED(PYTHON) && DEFINED(PYTHON_DIR)
184 !ERROR PYTHON and PYTHON_DIR cannot be specified at the same time
185 !ENDIF
186
187 # Find native Python automatically if PYTHON(_DIR) wasn't defined
188 !IF !DEFINED(PYTHON) && !DEFINED(PYTHON_DIR)
189 !IF EXIST(c:\Python27\python.exe)
190 PYTHON_VER=27
191 !ELSE IF EXIST(c:\Python26\python.exe)
192 PYTHON_VER=26
193 !ELSE IF EXIST(c:\Python25\python.exe)
194 PYTHON_VER=25
195 !ELSE IF EXIST(c:\Python24\python.exe)
196 PYTHON_VER=24
197 !ENDIF
198
199 !IF DEFINED(PYTHON_VER)
200 PYTHON_DIR=C:\Python$(PYTHON_VER)
201 !ENDIF
202 !ENDIF
203
204 !IF DEFINED(PYTHON_DIR)
205 PYTHON="$(PYTHON_DIR)\python.exe"
206 PATH=$(PYTHON_DIR);$(PATH)
207 !ENDIF
208
209 !if "$(WIRESHARK_TARGET_PLATFORM)" == "win32"
210 ##### Win32 Libraries #####
211 #
212 # Mandatory: GLib settings
213 #
214 # Please note: Since Wireshark release 1.0.0, we no longer support GLib1.x
215 #
216 GLIB_VERSION=2.0
217
218 #
219 # Mandatory: GLib, GTK & related library settings
220 #
221 # Please note: Since Wireshark release 1.0.0, we no longer support GTK1.x
222 #
223 # If you want building with GTK+, set GTK_DIR to the pathname of the
224 # directory in which the "include" and "lib" directories reside.
225 #
226 GTK_DIR=$(WIRESHARK_LIBS)\gtk2
227 # These macros are used by the nsis installer script and by the install target.
228 PNG_DLL=libpng14-14.dll
229 FREETYPE_DLL=freetype6.dll
230 FONTCONFIG_DLL=libfontconfig-1.dll
231 EXPAT_DLL=libexpat-1.dll
232 INTL_DLL=intl.dll
233 # This macro is used by the setup target.
234 #GTK_PKG=2.16.6-20100912
235 GTK_PKG=2.22.1-20101227
236
237 #
238 # Mandatory: Version numbers of GTK and pango.
239 #
240 # (MAJOR + MINOR Version number but without MICRO version number)
241 # These macros are used by the nsis installer script and by the setup target.
242 #
243 #GTK_INST_VERSION=2.16
244 GTK_INST_VERSION=2.22
245
246 #
247 # Optional: WinPcap developer's pack to capture network traffic.
248 #
249 # If you have the WinPcap developer's pack (at least version 3.0),
250 # set this to the directory in which the WinPcap developer's pack resides.
251 #
252 # If you don't have the WPdpack, comment this line out, so that
253 # PCAP_DIR isn't defined.
254 #
255 PCAP_DIR=$(WIRESHARK_LIBS)\WPdpack
256 # This macro is used by the nsis installer script, by the u3/portable apps and by the setup target.
257 PCAP_VERSION=4_1_2
258
259 #
260 # Optional: WinPcap remote capture support and new API
261 # (pcap_open(), pcap_findalldevs_ex(), etc.)
262 #
263 PCAP_REMOTE=1
264
265 #
266 # Optional: The ZLib enables unzipping of gzip compressed capture files
267 # "on the fly".
268 #
269 # If you have Zlib, set this to directory in which the Zlib headers
270 # and .lib file are stored.
271 #
272 # If you don't have Zlib, comment this line out, so that ZLIB_DIR isn't
273 # defined.
274 # EXperimental only use zlib 1.2.5 on win32 for now
275 ZLIB_DIR=$(WIRESHARK_LIBS)\zlib125
276
277 #
278 # Optional: the ADNS library enables asynchronous (nonblocking) DNS
279 # name resolvings.
280 #
281 # If you have GNU ADNS, set this to the directory in which the GNU ADNS
282 # .lib file is stored.
283 #
284 # If you don't have GNU ADNS, comment this line out, so that ADNS_DIR
285 # isn't defined.
286 #
287 # If C_ARES_DIR is defined below, it will override this setting.
288 #
289 #ADNS_DIR=$(WIRESHARK_LIBS)\adns-1.0-win32-05ws
290
291 #
292 # Optional: the c-ares library enables asynchronous (nonblocking) DNS
293 # name resolvings.
294 #
295 # If you have c-ares, set this to the directory in which the c-ares
296 # .lib file is stored. Setting this will override ADNS_DIR above. You
297 # can't have both.
298 #
299 # If you're using Visual C++ 6.0, you'll have to use a platform SDK that
300 # defines socklen_t, such as Windows Server 2003 PSDK.
301 #
302 # If you don't have c-ares, comment this line out, so that C_ARES_DIR
303 # isn't defined.
304 #
305 C_ARES_PKG=1.7.1
306
307 #
308 # Optional: the PCRE (Perl Compatible Regular Expressions) library
309 # enables regular expressions for display filters.
310 #
311 # If you have the PCRE library, set this to the directory in which
312 # the GNUWIN32 pcre-lib package is stored.
313 #
314 # If you don't have PCRE, comment this line out, so that PCRE_DIR
315 # isn't defined.
316 #
317 #PCRE_DIR=$(WIRESHARK_LIBS)\pcre-7.0
318
319 #
320 # Optional: the GNUTLS library enables ssl decryption.
321 #
322 # If you have the GNUTLS library, set this to the package version.
323 #
324 # If you don't have GNUTLS, comment this line out, so that GNUTLS_PKG
325 # isn't defined.
326 #
327 # Platform SDK conflicts with openssl.h header
328 GNUTLS_PKG=2.10.3-1.11
329
330 #
331 # Optional: the KFW library enables kerberos/sasl/dcerpc decryption.
332 #
333 # If you have the kerberos for windows (mit) library, set this to the
334 # directory where the kfw package is stored.
335 #
336 # If you don't have KFW, comment this line out, so that KFW_DIR
337 # isn't defined.
338 #
339 KFW_DIR=$(WIRESHARK_LIBS)\kfw-3-2-2-i386-ws-vc6
340
341 #
342 # Optional: the Nettle library enables ??? decryption.
343 #
344 # If you have the Nettle encryption library, set this to the
345 # directory in which the nettle package is stored.
346 #
347 # If you don't have Nettle, comment this line out, so that NETTLE_DIR
348 # isn't defined.
349 #
350 # NETTLE_DIR=$(WIRESHARK_LIBS)\nettle-1.10
351
352 #
353 # Optional: the LUA library enables scripting support.
354 #
355 # If you have the LUA library, set this to the directory in which
356 # the LUA package is stored.
357 #
358 # If you don't have LUA, comment this line out, so that LUA_DIR
359 # isn't defined.
360 #
361 LUA_DIST=5_1_4_Win32_dll6
362 LUA_DIR=$(WIRESHARK_LIBS)\lua5.1.4
363
364 #
365 # Optional: the PORTAUDIO library enables audio output for RTP streams.
366 #
367 # If you have the PORTAUDIO library (used for rtp_player), set this to
368 # the directory in which the PORTAUDIO library is stored.
369 #
370 # If you don't have PORTAUDIO, comment this line out, so that
371 # PORTAUDIO_DIR isn't defined.
372 #
373 #PORTAUDIO_DIR=$(WIRESHARK_LIBS)\portaudio_v18_1
374 PORTAUDIO_DIR=$(WIRESHARK_LIBS)\portaudio_v19_2
375
376 #
377 # Version number of PortAudio
378 #
379 #PORTAUDIO_VERSION=18
380 PORTAUDIO_VERSION=19
381
382 #
383 # Optional: AirPcap developer's pack to capture wireless network traffic
384 # incl. 802.11 management frames.
385 #
386 # If you have the AirPcap developer's pack, set this to the directory
387 # in which the AirPcap developer's pack resides.
388 #
389 # If you don't have the AirPcap developer's pack, comment this line out,
390 # so that AIRPCAP_DIR isn't defined.
391 #
392 AIRPCAP_DIR=$(WIRESHARK_LIBS)\AirPcap_Devpack_4_1_0_1622\AirPcap_Devpack
393
394 #
395 # Optional: LIBSMI, System Management Interface
396 #
397 # Used for oid-name resolution for SNMP and other protocols
398 #
399 SMI_DIR=$(WIRESHARK_LIBS)\libsmi-0.4.8
400
401 #
402 # Optional: GeoIP, IP address database lookups
403 #
404 # Used to map IP addresses to MaxMind GeoIP database entries
405 #
406 # GeoIP requires IPv6 definitions that don't ship with Visual C++ 6.0.
407 # However, the Microsoft Platform SDK for Windows Server 2003 R2 provides
408 # these definitions. The SDK's SetEnv.bat script defines INETSDK.
409 !IF "$(MSVC_VARIANT)" != "MSVC6" || DEFINED(INETSDK)
410 GEOIP_DIR=$(WIRESHARK_LIBS)\GeoIP-1.4.6-win32ws\libGeoIP
411 !ENDIF
412
413 !else
414 ##### Win64 Libraries #####
415 #
416 # Mandatory: GLib settings
417 #
418 # Please note: Since Wireshark release 1.0.0, we no longer support GLib1.x
419 #
420 GLIB_VERSION=2.0
421
422 #
423 # Mandatory: GLib, GTK & related library settings
424 #
425 # Please note: Since Wireshark release 1.0.0, we no longer support GTK1.x
426 #
427 # If you want building with GTK+, set GTK_DIR to the pathname of the
428 # directory in which the "include" and "lib" directories reside.
429 #
430 GTK_DIR=$(WIRESHARK_LIBS)\gtk2
431 # These macros are used by the nsis installer script and by the install target.
432 PNG_DLL=libpng14-14.dll
433 #TIFF_DLL=libtiff-3.dll
434 #JPEG_DLL=libjpeg-7.dll
435 FREETYPE_DLL=libfreetype-6.dll
436 FONTCONFIG_DLL=libfontconfig-1.dll
437 EXPAT_DLL=libexpat-1.dll
438 INTL_DLL=libintl-8.dll
439
440 # These macros are used by the setup target.
441 #GTK_PKG=2.16.6-20100912
442 GTK_PKG=2.22.1-20101229
443
444 #
445 # Mandatory: Version numbers of GTK and pango.
446 #
447 # (MAJOR + MINOR Version number but without MICRO version number)
448 # These macros are used by the nsis installer script and by the setup target.
449 #
450 #GTK_INST_VERSION=2.16
451 GTK_INST_VERSION=2.22
452
453 #
454 # Optional: WinPcap developer's pack to capture network traffic.
455 #
456 # If you have the WinPcap developer's pack (at least version 3.0),
457 # set this to the directory in which the WinPcap developer's pack resides.
458 #
459 # If you don't have the WPdpack, comment this line out, so that
460 # PCAP_DIR isn't defined.
461 #
462 PCAP_DIR=$(WIRESHARK_LIBS)\WPdpack
463 # This macro is used by the nsis installer script, by the u3/portable apps and by the setup target.
464 PCAP_VERSION=4_1_2
465
466 #
467 # Optional: WinPcap remote capture support and new API
468 # (pcap_open(), pcap_findalldevs_ex(), etc.)
469 #
470 PCAP_REMOTE=1
471
472 #
473 # Optional: The ZLib enables unzipping of gzip compressed capture files
474 # "on the fly".
475 #
476 # If you have Zlib, set this to directory in which the Zlib headers
477 # and .lib file are stored.
478 #
479 # If you don't have Zlib, comment this line out, so that ZLIB_DIR isn't
480 # defined.
481 #
482 ZLIB_DIR=$(WIRESHARK_LIBS)\zlib125
483
484 #
485 # Optional: the ADNS library enables asynchronous (nonblocking) DNS
486 # name resolvings.
487 #
488 # If you have GNU ADNS, set this to the directory in which the GNU ADNS
489 # .lib file is stored.
490 #
491 # If you don't have GNU ADNS, comment this line out, so that ADNS_DIR
492 # isn't defined.
493 #
494 # If C_ARES_DIR is defined below, it will override this setting.
495 #
496 #ADNS_DIR=$(WIRESHARK_LIBS)\adns-1.0-win32-05ws
497
498 #
499 # Optional: the c-ares library enables asynchronous (nonblocking) DNS
500 # name resolvings.
501 #
502 # If you have c-ares, set this to the directory in which the c-ares
503 # .lib file is stored. Setting this will override ADNS_DIR above. You
504 # can't have both.
505 #
506 # If you're using Visual C++ 6.0, you'll have to use a platform SDK that
507 # defines socklen_t, such as Windows Server 2003 PSDK.
508 #
509 # If you don't have c-ares, comment this line out, so that C_ARES_DIR
510 # isn't defined.
511 #
512 C_ARES_PKG=1.7.1
513
514 #
515 # Optional: the PCRE (Perl Compatible Regular Expressions) library
516 # enables regular expressions for display filters.
517 #
518 # If you have the PCRE library, set this to the directory in which
519 # the GNUWIN32 pcre-lib package is stored.
520 #
521 # If you don't have PCRE, comment this line out, so that PCRE_DIR
522 # isn't defined.
523 #
524 #PCRE_DIR=$(WIRESHARK_LIBS)\pcre-7.0
525
526 #
527 # Optional: the GNUTLS library enables ssl decryption.
528 #
529 # If you have the GNUTLS library, set this to the package version.
530 #
531 # If you don't have GNUTLS, comment this line out, so that GNUTLS_PKG
532 # isn't defined.
533 #
534 # Platform SDK conflicts with openssl.h header
535 GNUTLS_PKG=2.10.3-1.7
536
537 #
538 # Optional: the KFW library enables kerberos/sasl/dcerpc decryption.
539 #
540 # If you have the kerberos for windows (mit) library, set this to the
541 # directory where the kfw package is stored.
542 #
543 # If you don't have KFW, comment this line out, so that KFW_DIR
544 # isn't defined.
545 #
546 #KFW_DIR=$(WIRESHARK_LIBS)\kfw-3.2.2-ws1
547
548 #
549 # Optional: the Nettle library enables ??? decryption.
550 #
551 # If you have the Nettle encryption library, set this to the
552 # directory in which the nettle package is stored.
553 #
554 # If you don't have Nettle, comment this line out, so that NETTLE_DIR
555 # isn't defined.
556 #
557 # NETTLE_DIR=$(WIRESHARK_LIBS)\nettle-1.10
558
559 #
560 # Optional: the LUA library enables scripting support.
561 #
562 # If you have the LUA library, set this to the directory in which
563 # the LUA package is stored.
564 #
565 # If you don't have LUA, comment this line out, so that LUA_DIR
566 # isn't defined.
567 #
568 LUA_DIST=5_1_4_Win64_dll9
569 LUA_DIR=$(WIRESHARK_LIBS)\lua5.1.4
570
571 #
572 # Optional: the PORTAUDIO library enables audio output for RTP streams.
573 #
574 # If you have the PORTAUDIO library (used for rtp_player), set this to
575 # the directory in which the PORTAUDIO library is stored.
576 #
577 # If you don't have PORTAUDIO, comment this line out, so that
578 # PORTAUDIO_DIR isn't defined.
579 #
580 #PORTAUDIO_DIR=$(WIRESHARK_LIBS)\portaudio_v18_1
581 PORTAUDIO_DIR=$(WIRESHARK_LIBS)\portaudio_v19_2
582
583 #
584 # Version number of PortAudio
585 #
586 #PORTAUDIO_VERSION=18
587 PORTAUDIO_VERSION=19
588
589 #
590 # Optional: AirPcap developer's pack to capture wireless network traffic
591 # incl. 802.11 management frames.
592 #
593 # If you have the AirPcap developer's pack, set this to the directory
594 # in which the AirPcap developer's pack resides.
595 #
596 # If you don't have the AirPcap developer's pack, comment this line out,
597 # so that AIRPCAP_DIR isn't defined.
598 #
599 AIRPCAP_DIR=$(WIRESHARK_LIBS)\AirPcap_Devpack_4_1_0_1622\AirPcap_Devpack
600
601 #
602 # Optional: LIBSMI, System Management Interface
603 #
604 # Used for oid-name resolution for SNMP and other protocols
605 #
606 #SMI_DIR=$(WIRESHARK_LIBS)\libsmi-0.4.8
607
608 #
609 # Optional: GeoIP, IP address database lookups
610 #
611 # Used to map IP addresses to MaxMind GeoIP database entries
612 #
613 GEOIP_DIR=$(WIRESHARK_LIBS)\GeoIP-1.4.6-win64ws\libGeoIP
614
615 !endif
616
617 ##### Tools #####
618
619 # Set the following mandatory commands to find the tools.
620 # The easiest way is to use the corresponding packages from cygwin.
621
622 # Set up the path to the cygwin binaries
623 CYGWIN_PATH=c:\cygwin\bin
624
625 # command for a shell (cygwin's bash package recommended)
626 SH_PROG=bash
627
628 # bash versions after 3.1.6 need the 'igncr' shell option to be able to
629 #  process scripts in windows 'native format' (dos crlf format).
630 # The following !IF results in the option being used only if it is available
631 #  since using it on bash version 3.1.6 (or earlier) is not required and
632 #  will cause an error message.
633 !if "$(SH_PROG)"=="bash" && [$(CYGWIN_PATH)\bash -c "set -o igncr" 2>nul: ] == 0
634 SH_FLAGS=-o igncr
635 !endif
636
637 SH=$(SH_PROG) $(SH_FLAGS)
638
639
640 # command for perl (cygwin's perl package recommended)
641 PERL=perl
642
643 # command for pod2man and pod2html
644 # (part of the perl package, usually leave these unchanged)
645 POD2MAN=$(SH) pod2man
646 POD2HTML=$(SH) pod2html
647
648 # command for lex/flexx (cygwin's flex recommended)
649 LEX=flex
650
651 # command for yacc/bison (cygwin's bison recommended)
652 YACC=bison
653
654 # Commands to convert UNIX line endings to DOS/Windows
655 UNIX2DOS=u2d
656 TEXTIFY=$(SH) $(TOOLS_DIR)/textify.sh
657
658 #
659 # Optional: To build the NSIS installer.
660 #
661 # If you have the NSIS package, set this to the NSIS executable.
662 #
663 # If you don't have NSIS, comment this line out, so that MAKENSIS
664 # isn't defined.
665 #
666 MAKENSIS="$(PROGRAM_FILES)\NSIS\makensis.exe"
667
668 #
669 # Optional: To build the NSIS PortableApps installer.
670 #
671 # If you have the NSIS Unicode package, set this to the NSIS Unicode executable.
672 #
673 # If you don't have NSIS Unicode, comment this line out, so that
674 # MAKENSIS_UNICODE isn't defined.
675 #
676 MAKENSIS_UNICODE="$(PROGRAM_FILES)\NSIS\Unicode\makensis.exe"
677
678 #
679 # Optional: To build the developers API documentation with doxygen and dot.
680 # Currently experimental, outdated and incomplete.
681 #
682 # You will have to download and install:
683 # Doxygen from: http://www.doxygen.org
684 # Graphviz from: http://www.research.att.com/sw/tools/graphviz/
685 #
686 # If you have doxygen, set this to the doxygen executable.
687 #
688 # If you don't want the developers documentation (or don't have the tools),
689 # comment this line out, so that DOXYGEN isn't defined.
690 #
691 #DOXYGEN="$(PROGRAM_FILES)/doxygen/bin/doxygen.exe"
692
693 #
694 # Recommended: Use the compressed html help format .chm as the Wireshark integrated help.
695 #
696 # The required htmlhelp.h and htmlhelp.lib should be included in MSVC_VARIANT > MSVC6.
697 #
698 # For MSVC_VARIANT == MSVC6 you will have to download and install the html help workshop from:
699 #
700 # http://msdn.microsoft.com/library/default.asp?url=/library/en-us/htmlhelp/html
701 # /hwMicrosoftHTMLHelpDownloads.asp
702 #
703 # Then point HHC_DIR to the html help dir (where hhc.exe resides).
704 #
705 # If you don't want the online help (or don't have the tools),
706 # comment this line out, so that HHC_DIR isn't defined.
707 #
708 HHC_DIR=$(PROGRAM_FILES)/HTML Help Workshop
709
710 #
711 # Optional: To reduce the size of dlls and exes, which is especially useful for USB device distributions (U3, PortableApps)
712 #
713 # If you have the UPX package, set this to the upx.exe executable.
714 #
715 # UPX can be downloaded from:
716 #   http://upx.sourceforge.net/
717 #
718 # If you don't have UPX, or don't want to pack exes and dlls,
719 # comment this line out, so that UPX isn't defined.
720 #
721
722 UPX=$(WIRESHARK_LIBS)\upx303w\upx.exe
723
724 ##### Flags, PATHs and Miscellaneous #####
725
726 # Santity check: Python embedding requires a valid PYTHON_DIR
727 !IF DEFINED(PYTHON_EMBED) && !DEFINED(PYTHON_DIR)
728 !ERROR PYTHON_EMBED requires that PYTHON_DIR is defined
729 !ENDIF
730
731 # "convert" the MSVC variant into the required MSC compiler version
732 !IF "$(MSVC_VARIANT)" == "MSVC6"
733 MSC_VER_REQUIRED=1200
734 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2002" || "$(MSVC_VARIANT)" == "DOTNET10"
735 MSC_VER_REQUIRED=1300
736 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2003" || "$(MSVC_VARIANT)" == "DOTNET11"
737 MSC_VER_REQUIRED=1310
738 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2005" || "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20"
739 MSC_VER_REQUIRED=1400
740 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2008" ||  "$(MSVC_VARIANT)" == "MSVC2008EE"
741 MSC_VER_REQUIRED=1500
742 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2010" ||  "$(MSVC_VARIANT)" == "MSVC2010EE"
743 MSC_VER_REQUIRED=1600
744 !ELSE
745 !ERROR MSVC_VARIANT unknown
746 !ENDIF
747
748 ## Manifest processing is not needed for VC10 (Visual Studio 2010 C)
749 ## See: http://msdn.microsoft.com/en-us/library/dd293574.aspx
750 !IF ($(MSC_VER_REQUIRED) >= 1400) && ($(MSC_VER_REQUIRED) < 1600)
751 MANIFEST_INFO_REQUIRED=1
752 !ENDIF
753
754 # Compiler flags:
755 # /W3                               Warning level 3 (0 less - 4 most, 1 default)
756 # /Zi                               Create .pdb file for debugging
757 # /MD                               Use "multithread- and DLL-specific version" of run-time libraries
758 #                                    msvc documentation states that /MD causes _MT and _DLL to be defined
759 #                                    See: http://msdn.microsoft.com/en-us/library/2kzt1wy3%28v=VS.90%29.aspx
760 # /D_CRT_SECURE_NO_DEPRECATE        Don't warn for "insecure" calls,
761 #                                     see MSDN "Security Enhancements in the CRT"
762 # /D_CRT_NONSTDC_NO_DEPRECATE       Don't warn for "Deprecated CRT Functions" as MSDN calls this
763 # /D_BIND_TO_CURRENT_CRT_VERSION=1  Make sure our CRT and manifest versions match
764 #                                    (http://msdn.microsoft.com/en-us/library/cc664727.aspx)
765 # /DWIN32_LEAN_AND_MEAN             Don't include unnecessary Windows include files (see windows.h)
766 # /MANIFEST:no                      Don't create a SxS manifest. Makes sure our plugins don't load
767 #                                     a second copy of the CRT.
768 #
769 ##Note: LOCAL_CFLAGS are flags used for *all* compilations
770 ##      STANDARD_CFLAGS (see below) are flags used just for *Wireshark* compilations
771 !IF     "$(MSVC_VARIANT)" == "MSVC6"      || \
772         "$(MSVC_VARIANT)" == "MSVC2002"   || \
773         "$(MSVC_VARIANT)" == "DOTNET10"   || \
774         "$(MSVC_VARIANT)" == "MSVC2003"   || \
775         "$(MSVC_VARIANT)" == "DOTNET11"
776 LOCAL_CFLAGS=/Zi /W3 /MD /DWIN32_LEAN_AND_MEAN /DMSC_VER_REQUIRED=$(MSC_VER_REQUIRED)
777
778 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2005"   || \
779         "$(MSVC_VARIANT)" == "MSVC2005EE" || \
780         "$(MSVC_VARIANT)" == "DOTNET20"   || \
781         "$(MSVC_VARIANT)" == "MSVC2008"   || \
782         "$(MSVC_VARIANT)" == "MSVC2008EE" || \
783         "$(MSVC_VARIANT)" == "MSVC2010"   || \
784         "$(MSVC_VARIANT)" == "MSVC2010EE"
785 LOCAL_CFLAGS=/Zi /W3 /MD /DWIN32_LEAN_AND_MEAN /DMSC_VER_REQUIRED=$(MSC_VER_REQUIRED) \
786              /D_CRT_SECURE_NO_DEPRECATE /D_CRT_NONSTDC_NO_DEPRECATE
787
788 !IF "$(WIRESHARK_TARGET_PLATFORM)" != "win64"
789 LOCAL_CFLAGS=$(LOCAL_CFLAGS) /D_BIND_TO_CURRENT_CRT_VERSION=1
790 !ENDIF
791
792 # Additional compiler warnings to be treated as "Level 3"
793 #  when compiling Wireshark sources. (Selected from "level 4" warnings).
794 ## 4295: array is too small to include a terminating null character
795 WARNINGS_CFLAGS=/w34295
796
797 !ELSE
798 !ERROR MSVC_VARIANT unknown
799 !ENDIF
800
801 # http://msdn.microsoft.com/en-us/library/bb385193.aspx
802 # /MP               Compiles multiple source files by using multiple processes
803 # /MP[processMax]   If you omit the processMax argument, the compiler retrieves the number of effective processors
804 #                   on your computer from the operating system, and creates a process for each processor.
805 #
806 # The following compiler options and language features that are incompatible with the /MP option:
807 #
808 # * #import preprocessor directive
809 # * /E, /EP
810 # * /Gm
811 # * /showIncludes
812 # * /Yc
813 #
814 !IF     "$(MSVC_VARIANT)" == "MSVC2008"   || \
815         "$(MSVC_VARIANT)" == "MSVC2008EE" || \
816         "$(MSVC_VARIANT)" == "MSVC2010"   || \
817         "$(MSVC_VARIANT)" == "MSVC2010EE"
818 LOCAL_CFLAGS= $(LOCAL_CFLAGS) /MP
819 !ENDIF
820
821 # Optional: Static analysis. Only supported in the full-frontal MSVC editions.
822 # http://msdn.microsoft.com/en-us/library/ms182025.aspx
823
824 !IFDEF ENABLE_CODE_ANALYSIS
825 LOCAL_CFLAGS= $(LOCAL_CFLAGS) /analyze:WX-
826 !ENDIF
827
828 #STANDARD_CFLAGS are flags used for *Wireshark* compiles (not stuff like lemon, etc)
829 STANDARD_CFLAGS=-DHAVE_CONFIG_H -D_U_="" $(LOCAL_CFLAGS) $(WARNINGS_CFLAGS)
830
831 #Comment out the following if warnings are not to be treated as errors
832 WARNINGS_ARE_ERRORS=-WX
833
834 ## XXX: _MT and _DLL are defined when /MD is used so CVARSDLL is apparently unneeded
835 ##CVARSDLL=-D_MT -D_DLL
836
837 # Linker flags:
838 # /DEBUG  generate debug info
839 # /PROFILE generate map file(s) for profiling
840 # /DEFAULTLIB:xxx use xxx as the standard C library
841 # /NODEFAULTLIB:xxx don't use xxx as the standard C library
842 #
843 LOCAL_LDFLAGS=/DEBUG /MACHINE:$(TARGET_MACHINE)
844 DLL_LDFLAGS =
845 !IFDEF MANIFEST_INFO_REQUIRED
846 DLL_LDFLAGS = /MANIFEST:no
847 !ENDIF
848
849 # Enable Safe Exception Handler.
850 # http://msdn.microsoft.com/en-us/magazine/cc337897.aspx
851 !IF $(MSC_VER_REQUIRED) >= 1300
852 LOCAL_CFLAGS= $(LOCAL_CFLAGS) /GS
853 !IF "$(WIRESHARK_TARGET_PLATFORM)" != "win64"
854 LOCAL_LDFLAGS= $(LOCAL_LDFLAGS) /SafeSEH
855 !ENDIF
856 !ENDIF
857
858 # Enable ASLR. Requires VS2008 or later.
859 # http://blogs.msdn.com/b/vcblog/archive/2009/05/21/dynamicbase-and-nxcompat.aspx
860 # DEP (/NXCompat) is handled in init_process_policies() via SetProcessDEPPolicy.
861
862 # ASLR http://msdn.microsoft.com/en-us/library/bb384887.aspx
863 !IF $(MSC_VER_REQUIRED) >= 1500
864 LOCAL_LDFLAGS= $(LOCAL_LDFLAGS) /DYNAMICBASE /FIXED:no
865 !ENDIF
866
867 PLUGIN_LDFLAGS = /NOLOGO /INCREMENTAL:no $(LOCAL_LDFLAGS) $(DLL_LDFLAGS)
868
869 #
870 # According to http://bugs.wireshark.org/bugzilla/show_bug.cgi?id=403
871 # XCOPY under Windows NT doesn't support the "/Y" flag.  This works
872 # around that bug.
873 # XXX - This apparently doesn't work for some versions of nmake:
874 # http://support.microsoft.com/default.aspx?scid=kb;en-us;86814
875 # It looks like we'll have to call "set copycmd=/y" before we run xcopy.
876 COPYCMD=/y
877
878 #
879 # If you don't want to build libwireshark.dll, you should comment out the
880 # following line. (Note: for plugin support this option must stay activated)
881 ENABLE_LIBWIRESHARK=USE
882
883 #
884 # install (debug) directory for Wireshark (relative to your source dir)
885 INSTALL_DIR=wireshark-gtk2
886
887
888
889 ##### C-Runtime Redistributable #####
890 #
891 # The C-Runtime since Version 7 must be shipped together with
892 # the program installer, to avoid missing msvcr*.dll files on
893 # the target machine.
894 #
895 # The location of these files differ on the various compiler
896 # packages, the following will use the default paths depending
897 # on the package version.
898 #
899 !IF "$(MSVC_VARIANT)" == "MSVC6"
900 # msvcrt.dll will already be available on target machines - nothing additional to install
901
902 !ELSEIF "$(WIRESHARK_TARGET_PLATFORM)" == "win64"
903 # We're not creating portable packages and therefore don't have to worry about
904 # "deploying using xcopy"
905 VCREDIST_EXE=$(WIRESHARK_LIBS)\vcredist_$(TARGET_MACHINE).exe
906
907 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2002"
908 # you probably need to tweak this directory if you don't use the professional edition!
909 MSVCR_DLL=$(PROGRAM_FILES)\Microsoft Visual Studio .NET\Visual Studio .NET Professional - English\msvcr70.dll
910
911 !ELSEIF "$(MSVC_VARIANT)" == "DOTNET10"
912 # no redistributable available for this package!
913
914 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2003"
915 # you probably need to tweak this directory if you don't use the professional edition!
916 MSVCR_DLL=$(PROGRAM_FILES)\Microsoft Visual Studio .NET 2003\Visual Studio .NET Professional 2003 - English\msvcr71.dll
917
918 !ELSEIF "$(MSVC_VARIANT)" == "DOTNET11"
919 # no redistributable available for this package!
920
921 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2005"
922 MSVCR_DLL=$(PROGRAM_FILES)\Microsoft Visual Studio 8\VC\redist\$(PROCESSOR_ARCHITECTURE)\Microsoft.VC80.CRT\*.*
923
924 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2005EE" || "$(MSVC_VARIANT)" == "DOTNET20" || "$(MSVC_VARIANT)" == "MSVC2008EE"
925 # you need to download the redistributable package vcredist_x86.exe from Microsoft first,
926 # and copy it to the lib folder!!!
927 VCREDIST_EXE=$(WIRESHARK_LIBS)\vcredist_$(TARGET_MACHINE).exe
928
929 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2008"
930 MSVCR_DLL=$(PROGRAM_FILES)\Microsoft Visual Studio 9.0\VC\redist\$(PROCESSOR_ARCHITECTURE)\Microsoft.VC90.CRT\*.*
931
932 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2010EE"
933 # you need to download the redistributable package vcredist_x86.exe from Microsoft first,
934 # and copy it to the lib folder!!!
935 VCREDIST_EXE=$(WIRESHARK_LIBS)\vcredist_$(TARGET_MACHINE).exe
936 !ELSEIF "$(MSVC_VARIANT)" == "MSVC2010"
937 MSVCR_DLL=$(PROGRAM_FILES)\Microsoft Visual Studio 10.0\VC\redist\$(TARGET_MACHINE)\Microsoft.VC100.CRT\*.*
938
939 !ELSE
940 !ERROR MSVC_VARIANT unknown
941 !ENDIF
942
943 !IF DEFINED(VCREDIST_EXE) && ! EXIST("$(VCREDIST_EXE)")
944 !ERROR Can't find $(VCREDIST_EXE). Have you downloaded it from Microsoft? \
945 See the developer's guide section "C-Runtime "Redistributable" files" for details how to get it
946 !ENDIF
947
948 ##### Advanced: Docbook/XML documentation generation #####
949 # If you want to generate the Docbook/XML based docs (User's and Developer's
950 # Guide, ...), you'll need some additional tools / libraries compared to the
951 # rest of the build process.
952 #
953 # FOR DETAILED INSTRUCTIONS TO GENERATE THE DOCS, SEE: docbook\README.txt.
954 #
955 # If you don't call the Makefile.nmake in the docbook dir to generate the
956 # docs, the following settings in this section will have no effect.
957
958 # formatting objects processor executable
959 # Comment this out if you don't have fop installed or you don't want the docs
960 # in PDF format.
961 #
962 # You may want to install the FOP hyphenation patterns from
963 # http://offo.sourceforge.net/hyphenation/
964 !IFNDEF FOP
965 FOP=fop-0.95\fop.bat
966 !ENDIF
967
968 # Additional options to fop.
969 FOP_OPTS=-Xmx256m
970
971 # html help compiler
972 # Comment this out if you don't have hhc.exe or you don't want the docs in
973 # .chm format.
974 #
975 # Beware: hhc.exe is NOT part of the MSVC packages in HHC_DIR mentioned above,
976 # so you'll need to install the HTML Help Workshop for this.
977 HHC_EXE="$(HHC_DIR)\hhc.exe"
978
979 # html to text converter for text version of release notes, e.g. elinks.
980 # This could also be "lynx", or "true" if neither elinks nor lynx is installed
981 # (cygwin: lynx works, elinks not available, links and true doesn't produce output)
982 #HTML2TXT=elinks -dump -dump-width 72
983 ##HTML2TXT=links -dump -width 72 ## XXX: Fails: For links -dump requires 'url' (filename) arg.
984 #HTML2TXT=lynx -dump -width=72 -nolist -stdin
985
986 !IFNDEF HTML2TXT
987 HTML2TXT=$(PYTHON) $(TOOLS_DIR)\html2text.py --width=72 --no-links
988 !ENDIF
989
990 # the XSL processor (part of cygwin's libxslt package)
991 XSLTPROC="xsltproc"
992
993 # the XML validator (part of cygwin's libxml2 package)
994 XMLLINT="xmllint"
995
996
997
998 ##############################################################################
999 #
1000 # You should not have to change anything below this comment.
1001 # If you do, it's a deficiency in the Makefile.nmake files;
1002 # either tell wireshark-dev@wireshark.org about it, including
1003 # details of why you had to change it, or fix config.nmake
1004 # and any Makefile.nmake files that need to be changed, and
1005 # send us the patches, along with details of why the change
1006 # was necessary.
1007 #
1008 ##############################################################################
1009
1010 #
1011 # The RC_VERSION should be comma-separated, not dot-separated,
1012 # as per Graham Bloice's message in
1013 #
1014 #       http://www.ethereal.com/lists/ethereal-dev/200303/msg00283.html
1015 #
1016 # "The RC_VERSION variable in config.nmake should be comma separated.
1017 # This allows the resources to be built correctly and the version
1018 # number to be correctly displayed in the explorer properties dialog
1019 # for the executables, and XP's tooltip, rather than 0.0.0.0."
1020 #
1021
1022 VERSION=$(VERSION_MAJOR).$(VERSION_MINOR).$(VERSION_MICRO)$(VERSION_EXTRA)
1023 RC_VERSION=$(VERSION_MAJOR),$(VERSION_MINOR),$(VERSION_MICRO),$(VERSION_BUILD)
1024 PRODUCT_VERSION=$(VERSION_MAJOR).$(VERSION_MINOR).$(VERSION_MICRO).$(VERSION_BUILD)
1025
1026 WTAP_VERSION=$(WTAP_VERSION_MAJOR).$(WTAP_VERSION_MINOR).$(WTAP_VERSION_MICRO)
1027 RC_WTAP_VERSION=$(WTAP_VERSION_MAJOR),$(WTAP_VERSION_MINOR),$(WTAP_VERSION_MICRO)
1028
1029 # GLib
1030 GLIB_CFLAGS=/I$(GTK_DIR)\include\glib-$(GLIB_VERSION) \
1031         /I$(GTK_DIR)\lib\glib-$(GLIB_VERSION)\include
1032 GLIB_LIBS=$(GTK_DIR)\lib\glib-$(GLIB_VERSION).lib \
1033         $(GTK_DIR)\lib\gmodule-$(GLIB_VERSION).lib \
1034         $(GTK_DIR)\lib\gobject-$(GLIB_VERSION).lib
1035 GTHREAD_LIBS=$(GTK_DIR)\lib\gthread-$(GLIB_VERSION).lib
1036
1037 # GTK+
1038 GTK_CFLAGS=$(GLIB_CFLAGS) /I$(GTK_DIR)\include\gtk-2.0 \
1039         /I$(GTK_DIR)\include\gdk-pixbuf-2.0 \
1040         /I$(GTK_DIR)\lib\gtk-2.0\include \
1041         /I$(GTK_DIR)\include\atk-1.0 \
1042         /I$(GTK_DIR)\include\cairo \
1043         /I$(GTK_DIR)\include\pango-1.0
1044 GTK_LIBS=$(GTK_DIR)\lib\gtk-win32-2.0.lib \
1045         $(GTK_DIR)\lib\gdk-win32-2.0.lib \
1046         $(GTK_DIR)\lib\gdk_pixbuf-2.0.lib \
1047         $(GTK_DIR)\lib\pango-1.0.lib \
1048         $(GLIB_LIBS)
1049
1050 # 2.18 was no good(Theming problem)
1051 !IF "$(GTK_INST_VERSION)" == "2.22" || "$(GTK_INST_VERSION)" == "2.16" || "$(GTK_INST_VERSION)" == "2.14"
1052 GTK_LIB_DIR=2.10.0
1053
1054 !IFDEF PNG_DLL
1055 NEED_LIBPNG_DLL=USE
1056 !ENDIF
1057 !IFDEF JPEG_DLL
1058 NEED_LIBJPEG_DLL=USE
1059 !ENDIF
1060 !IFDEF TIFF_DLL
1061 NEED_LIBTIFF_DLL=USE
1062 !ENDIF
1063 NEED_CAIRO_DLL=USE
1064 # Pango >=1.24.5 Needs these:
1065 NEED_FREETYPE_DLL=USE
1066 NEED_FONTCONFIG_DLL=USE
1067 NEED_EXPAT_DLL=USE
1068
1069 GTK_WIMP_DLLSRC_DIR=$(GTK_DIR)\lib\gtk-2.0\2.10.0\engines
1070 GTK_WIMP_DLLDST_DIR=lib\gtk-2.0\2.10.0\engines
1071 GTK_WIMP_RCSRC_DIR=$(GTK_DIR)\share\themes\MS-Windows\gtk-2.0
1072 GTK_WIMP_RCDST_DIR=etc\gtk-2.0
1073 !ELSE
1074 !ERROR ? Unknown or invalid GTK_INST_VERSION
1075 !ENDIF
1076
1077
1078 !IFDEF AIRPCAP_DIR
1079 AIRPCAP_CONFIG=^#define HAVE_AIRPCAP 1
1080 AIRPDCAP_CONFIG=^#define HAVE_AIRPDCAP 1
1081 #AIRPCAP_CFLAGS=/I$(AIRPCAP_DIR)\include
1082 !ELSE
1083 AIRPCAP_CONFIG=
1084 AIRPDCAP_CONFIG=
1085 !ENDIF
1086
1087 !IFDEF PCAP_DIR
1088 # Nmake uses carets to escape special characters
1089 WINPCAP_CONFIG=^#define HAVE_LIBPCAP 1
1090 #
1091 # This requires that, if you're *building* Wireshark, you have
1092 # the most recent WinPcap's development package.  If, at *run*
1093 # time, an older version of WinPcap, missing some routines,
1094 # is found, we work around that.
1095 #
1096 PCAP_FINDALLDEVS_CONFIG=^#define HAVE_PCAP_FINDALLDEVS 1
1097 PCAP_DATALINK_NAME_TO_VAL_CONFIG=^#define HAVE_PCAP_DATALINK_NAME_TO_VAL 1
1098 PCAP_DATALINK_VAL_TO_NAME_CONFIG=^#define HAVE_PCAP_DATALINK_VAL_TO_NAME 1
1099 PCAP_DATALINK_VAL_TO_DESCRIPTION_CONFIG=^#define HAVE_PCAP_DATALINK_VAL_TO_DESCRIPTION 1
1100 # PCAP_BREAKLOOP won't have any benefit on Win32, but breaks compatibility with 3.0
1101 PCAP_BREAKLOOP_CONFIG=
1102 PCAP_LIST_DATALINKS_CONFIG=^#define HAVE_PCAP_LIST_DATALINKS 1
1103 PCAP_FREE_DATALINKS_CONFIG=^#define HAVE_PCAP_FREE_DATALINKS 1
1104 PCAP_SET_DATALINK_CONFIG=^#define HAVE_PCAP_SET_DATALINK 1
1105 PCAP_OPEN_DEAD_CONFIG=^#define HAVE_PCAP_OPEN_DEAD 1
1106 BPF_IMAGE_CONFIG=^#define HAVE_BPF_IMAGE 1
1107 !ELSE
1108 # no WpdPack installed
1109 WINPCAP_CONFIG=
1110 PCAP_FINDALLDEVS_CONFIG=
1111 PCAP_DATALINK_NAME_TO_VAL_CONFIG=
1112 PCAP_DATALINK_VAL_TO_NAME_CONFIG=
1113 PCAP_DATALINK_VAL_TO_DESCRIPTION_CONFIG=
1114 PCAP_BREAKLOOP_CONFIG=
1115 PCAP_LIST_DATALINKS_CONFIG=
1116 PCAP_FREE_DATALINKS_CONFIG=
1117 PCAP_SET_DATALINK_CONFIG=
1118 PCAP_OPEN_DEAD_CONFIG=
1119 BPF_IMAGE_CONFIG=
1120 !ENDIF
1121
1122 !IF DEFINED(PCAP_DIR) && DEFINED(PCAP_REMOTE)
1123 PCAP_HAVE_REMOTE_CONFIG=^#define HAVE_REMOTE 1
1124 PCAP_REMOTE_CONFIG=^#define HAVE_PCAP_REMOTE 1
1125 PCAP_OPEN_CONFIG=^#define HAVE_PCAP_OPEN 1
1126 PCAP_SETSAMPLING_CONFIG=^#define HAVE_PCAP_SETSAMPLING 1
1127 !ELSE
1128 PCAP_HAVE_REMOTE_CONFIG=
1129 PCAP_REMOTE_CONFIG=
1130 PCAP_OPEN_CONFIG=
1131 PCAP_SETSAMPLING_CONFIG=
1132 !ENDIF
1133
1134 !IFDEF ZLIB_DIR
1135 ZLIB_PATH=$(ZLIB_DIR)
1136 ZLIB_CFLAGS=/I$(ZLIB_DIR)\include
1137 ZLIB_LIBS=$(ZLIB_DIR)\lib\zdll.lib
1138 ZLIB_DLL=$(ZLIB_DIR)\zlib1.dll
1139 # Nmake uses carets to escape special characters
1140 ZLIB_CONFIG=^#define HAVE_LIBZ 1
1141 ZLIB_GZCLEARERR_CONFIG=^#define HAVE_GZCLEARERR 1
1142 !else
1143 ZLIB_CFLAGS=
1144 ZLIB_LIBS=
1145 ZLIB_DLL=
1146 ZLIB_CONFIG=
1147 !ENDIF
1148
1149 !IFDEF C_ARES_PKG
1150 !UNDEF ADNS_DIR
1151 C_ARES_DIR=$(WIRESHARK_LIBS)\c-ares-$(C_ARES_PKG)-$(WIRESHARK_TARGET_PLATFORM)ws
1152 C_ARES_CFLAGS=/I$(C_ARES_DIR)/include
1153 C_ARES_LIBS=$(C_ARES_DIR)\lib\libcares-2.lib
1154 C_ARES_DLL=$(C_ARES_DIR)\bin\libcares-2.dll
1155 # Nmake uses carets to escape special characters
1156 C_ARES_CONFIG=^#define HAVE_C_ARES 1
1157 !else
1158 C_ARES_CFLAGS=
1159 C_ARES_LIBS=
1160 C_ARES_CONFIG=
1161 !IFDEF ADNS_DIR
1162 ADNS_PATH=$(ADNS_DIR)\adns_win32\lib
1163 ADNS_CFLAGS=/I$(ADNS_DIR)\src /I$(ADNS_DIR)\adns_win32
1164 ADNS_LIBS=$(WIRESHARK_LIBS)\$(MSVC_VARIANT)\adns\adns_dll.lib
1165 ADNS_DLL=$(WIRESHARK_LIBS)\$(MSVC_VARIANT)\adns\adns_dll.dll
1166 # Nmake uses carets to escape special characters
1167 ADNS_CONFIG=^#define HAVE_GNU_ADNS 1
1168 !else
1169 ADNS_CFLAGS=
1170 ADNS_LIBS=
1171 ADNS_CONFIG=
1172 !ENDIF # ADNS
1173 !ENDIF # C_ARES
1174
1175 !IFDEF KFW_DIR
1176 KFW_PATH=$(KFW_DIR)\bin
1177 KFW_CFLAGS=/I$(KFW_DIR)\include
1178 KFW_LIBS=$(KFW_DIR)\lib\krb5_32.lib
1179 # Nmake uses carets to escape special characters
1180 KFW_CONFIG=^#define HAVE_MIT_KERBEROS 1
1181 !else
1182 KFW_CFLAGS=
1183 KFW_LIBS=
1184 KFW_CONFIG=
1185 !ENDIF
1186
1187 !IFDEF PCRE_DIR
1188 PCRE_PATH=$(PCRE_DIR)\bin
1189 PCRE_CFLAGS=/I$(PCRE_DIR)\include
1190 PCRE_LIBS=$(PCRE_DIR)\lib\pcre.lib
1191 # Nmake uses carets to escape special characters
1192 PCRE_CONFIG=^#define HAVE_LIBPCRE 1
1193 !else
1194 PCRE_CFLAGS=
1195 PCRE_LIBS=
1196 PCRE_CONFIG=
1197 !ENDIF
1198
1199 !IFDEF NETTLE_DIR
1200 NETTLE_CFLAGS=/I$(NETTLE_DIR)
1201 NETTLE_LIBS=$(NETTLE_DIR)\libnettle.lib
1202 # Nmake uses carets to escape special characters
1203 NETTLE_CONFIG=^#define HAVE_LIBNETTLE 1
1204 !else
1205 NETTLE_CFLAGS=
1206 NETTLE_LIBS=
1207 NETTLE_CONFIG=
1208 !ENDIF
1209
1210 !IFDEF GNUTLS_PKG
1211 GNUTLS_DIR=$(WIRESHARK_LIBS)\gnutls-$(GNUTLS_PKG)-$(WIRESHARK_TARGET_PLATFORM)ws
1212 GNUTLS_PATH=$(GNUTLS_DIR)
1213 # /DNOCRYPT avoids inclusion of Wincrypt.h, avoiding a X509_NAME define clash
1214 GNUTLS_CFLAGS=/I$(GNUTLS_DIR)\include /DNOCRYPT /DIMPORT_LIGNUTLSDLL
1215 GCRYPT_LIBS = $(GNUTLS_DIR)\bin\libgcrypt-11.lib
1216 GNUTLS_LIBS=\
1217         $(GNUTLS_DIR)\bin\libtasn1-3.lib        \
1218         $(GNUTLS_DIR)\bin\libgpg-error-0.lib    \
1219         $(GCRYPT_LIBS) \
1220         $(GNUTLS_DIR)\bin\libgnutls-26.lib
1221 # Nmake uses carets to escape special characters
1222 GNUTLS_CONFIG=^#define HAVE_LIBGNUTLS 1
1223 LIBGCRYPT_CONFIG=^#define HAVE_LIBGCRYPT 1
1224 !else
1225 GNUTLS_CFLAGS=
1226 GNUTLS_LIBS=
1227 GNUTLS_CONFIG=
1228 LIBGCRYPT_CONFIG=
1229 !ENDIF
1230
1231 !IFDEF LUA_DIR
1232 LUA_CFLAGS=/I$(LUA_DIR)\include
1233 LUA_LIBS=$(LUA_DIR)\lua5.1.lib
1234 # Nmake uses carets to escape special characters
1235 LUA_CONFIG=^#define HAVE_LUA 1
1236 LUA_VERSION=^#define HAVE_LUA_5_1 1
1237 !else
1238 LUA_CFLAGS=
1239 LUA_LIBS=
1240 LUA_CONFIG=
1241 !ENDIF
1242
1243 !IF DEFINED(PYTHON_EMBED)
1244 PYTHON_CFLAGS=/I$(PYTHON_DIR)\include
1245 PYTHON_LIBS=$(PYTHON_DIR)\libs\python$(PYTHON_VER).lib
1246 # Nmake uses carets to escape special characters
1247 PYTHON_CONFIG=^#define HAVE_PYTHON 1
1248 !else
1249 PYTHON_CFLAGS=
1250 PYTHON_LIBS=
1251 PYTHON_CONFIG=
1252 !ENDIF
1253
1254 !IFDEF PORTAUDIO_DIR
1255 # Nmake uses carets to escape special characters
1256 PORTAUDIO_CONFIG=^#define HAVE_LIBPORTAUDIO 1
1257 !IF "$(PORTAUDIO_VERSION)" == "18"
1258 # V18 uses API version 1 and v19 API version 2
1259 PORTAUDIO_CFLAGS=/I$(PORTAUDIO_DIR)\pa_common
1260 PORTAUDIO_API_CONFIG=^#define PORTAUDIO_API_1 1
1261 !ELSE
1262 PORTAUDIO_CFLAGS=/I$(PORTAUDIO_DIR)\include /I$(PORTAUDIO_DIR)\src\common /I$(PORTAUDIO_DIR)\src\os\win /DPA_NO_DS /DPA_NO_ASIO
1263 !ENDIF
1264 !ELSE
1265 PORTAUDIO_CFLAGS=
1266 PORTAUDIO_CONFIG=
1267 !ENDIF
1268
1269 !IFDEF HHC_DIR
1270 !IF "$(MSVC_VARIANT)" == "MSVC6"
1271 HHC_CFLAGS=/I"$(HHC_DIR)\include" -DHHC_DIR
1272 HHC_LIBS="$(HHC_DIR)\lib\htmlhelp.lib"
1273 !ELSE
1274 HHC_CFLAGS=-DHHC_DIR
1275 HHC_LIBS=htmlhelp.lib
1276 !ENDIF
1277 !ELSE
1278 HHC_CFLAGS=
1279 HHC_LIBS=
1280 !ENDIF
1281
1282 !IFDEF SMI_DIR
1283 SMI_CONFIG=^#define HAVE_LIBSMI 1
1284 SMI_CFLAGS=/I$(SMI_DIR)\include
1285 SMI_LIBS=$(SMI_DIR)\lib\smi.lib
1286 !ELSE
1287 SMI_LIBS=
1288 SMI_CFLAGS=
1289 SMI_CONFIG=
1290 !ENDIF
1291
1292 !IFDEF GEOIP_DIR
1293 GEOIP_CONFIG=^#define HAVE_GEOIP 1
1294 GEOIP_CFLAGS=/I$(GEOIP_DIR)
1295 GEOIP_LIBS=$(GEOIP_DIR)\GeoIP.lib
1296 !ELSE
1297 GeoIP_LIBS=
1298 GeoIP_CFLAGS=
1299 GeoIP_CONFIG=
1300 !ENDIF
1301
1302 !IFDEF ENABLE_LIBWIRESHARK
1303 LIBWIRESHARK_CONFIG=^#define HAVE_LIBWIRESHARKDLL 1
1304 # Link plugins with the import library of libwireshark.dll
1305 LINK_PLUGINS_WITH_LIBWIRESHARK=USE
1306 !ELSE
1307 LIBWIRESHARK_CONFIG=
1308 !ENDIF
1309
1310 # Construct the path
1311 PATH=$(PATH);$(CYGWIN_PATH);$(GTK_DIR)\bin;$(GETTEXT_DIR)\bin;$(ZLIB_PATH);$(ADNS_PATH)
1312
1313 # We can't use a lot of IPv6 code with plain Visual C++ 6.0
1314 !IF "$(MSVC_VARIANT)" == "MSVC6" && !DEFINED(MSSDK)
1315 INET6_CONFIG=
1316 !ELSE
1317 INET6_CONFIG=^#define INET6 1
1318 !ENDIF
1319
1320 !IF "$(MSVC_VARIANT)" == "MSVC6" && !DEFINED(MSSDK)
1321 NTDDNDIS_CONFIG=
1322 !ELSE
1323 NTDDNDIS_CONFIG=^#define HAVE_NTDDNDIS_H 1
1324 !ENDIF