3 # Some more informations about the settings in this file, can be found
4 # in the file README.win32.
6 # The current Ethereal version
10 # The RC_VERSION should be comma-separated, not dot-separated,
11 # as per Graham Bloice's message in
13 # http://www.ethereal.com/lists/ethereal-dev/200303/msg00283.html
15 # "The RC_VERSION variable in config.nmake should be comma separated.
16 # This allows the resources to be built correctly and the version
17 # number to be correctly displayed in the explorer properties dialog
18 # for the executables, and XP's tooltip, rather than 0.0.0.0."
22 # The version of the wiretap library
27 # If you're building with WinPcap 2.3, set WINPCAP_VERSION to 2.3; if
28 # you're building with WinPcap 3.0, set it to 3.0; if you're building
29 # with WinPcap 3.1, set it to 3.1.
31 # If you're not building with WinPcap at all, don't set it (comment
32 # out or remove the line that sets it).
37 # Directory, where your User's Guide reside, relative to the source dir.
40 # If you don't have the User's Guide, comment this line out, so that
41 # ETHEREAL_EUG_DIR isn't defined.
43 #ETHEREAL_EUG_DIR=docbook/eug_html_chunked
46 # Base directory, where your libraries reside, which needs to be
47 # compiling the sources. This is only inside this file.
49 ETHEREAL_LIBS=C:\ethereal-win32-libs
52 # Current versions of GTK+ 1.3 require GLib 2.0. Earlier versions of
53 # GTK+ 1.3 are buggy; we don't recommend using them, and we don't
54 # support them. Upgrade to the current version.
57 GLIB_DIR=$(ETHEREAL_LIBS)\glib
60 # This presumes that GTK+ 1.3 packages put header files and libraries
61 # directly in a "gtk+" directory, while GTK+ 2.x developer's packages
62 # put header files in an "include\gtk-{version}" directory and libraries
63 # in a "lib\gtk-{version}" directory.
65 # It's possible, to build both GTK version 1 and 2 at the same time,
66 # or only one of the versions. GTK version 1 is currently recommended.
68 # If you want building with GTK+ 1.3, set GTK1_DIR to the pathname of the
69 # "gtk+" directory; if you want building with GTK+ 2.x, set GTK2_DIR to
70 # the pathname of the directory in which the "include" and "lib" directories
73 GTK1_DIR=$(ETHEREAL_LIBS)\gtk+
74 GTK2_DIR=$(ETHEREAL_LIBS)\gtk2
76 # Declare the version of your gtk2 and pango. (MAJOR + MINOR Version number
77 # but without MICRO version number)
78 # These macros are used by the nsis installer script and by the setup target.
80 #GTK2_INST_VERSION=2.2
81 #PANGO_INST_VERSION=1.2
83 PANGO_INST_VERSION=1.4
84 # Support of GTK 2.6 is currently very experimental ...
85 #GTK2_INST_VERSION=2.6
86 #PANGO_INST_VERSION=1.8
89 # If you have GTK-Wimp, set this to the pathname of the directory in
90 # which the files are stored.
92 # If you don't have GTK-Wimp, comment this line out, so that GTK-Wimp isn't
95 GTK_WIMP_DIR=$(ETHEREAL_LIBS)\gtk-wimp
98 # If you have Zlib, set this to the pathname of the directory in
99 # which the Zlib headers and .lib file are stored.
101 # If you don't have Zlib, comment this line out, so that Zlib isn't
104 ZLIB_DIR=$(ETHEREAL_LIBS)\zlib123-dll
107 # Set PCAP_DIR to the pathname of the directory in which the WinPcap
108 # developer's pack resides
110 PCAP_DIR=$(ETHEREAL_LIBS)\WPdpack
113 # Set NET_SNMP_DIR to the pathname of the directory in which the
114 # Net-SNMP include files and library resides.
116 NET_SNMP_DIR=$(ETHEREAL_LIBS)\net-snmp-5.2.1.2
119 # If you have GNU ADNS, set this to the pathname of the directory in
120 # which the GNU ADNS .lib file is stored.
122 # If you don't have GNU ADNS, comment this line out, so that ADNS_DIR
125 ADNS_DIR=$(ETHEREAL_LIBS)\adns-1.0-win32-04
128 # If you have the PCRE (Perl Compatible Regular Expressions) library,
129 # set this to the pathname of the directory in which the GNUWIN32
130 # pcre-lib package has been extracted.
132 # If you don't have PCRE, comment this line out, so that PCRE_DIR
135 PCRE_DIR=$(ETHEREAL_LIBS)\pcre-6.3
138 # If you have the Nettle encryption library, set this to the pathname
139 # of the directory in which the nettle package has been extracted.
141 # If you don't have Nettle, comment this line out, so that NETTLE_DIR
144 # NETTLE_DIR=$(ETHEREAL_LIBS)\nettle-1.10
147 # Set ICONV_DIR to the pathname of the directory in which the
148 # ICONV include files and library resides.
150 ICONV_DIR=$(ETHEREAL_LIBS)\libiconv-1.9.1.bin.woe32
153 # Set GETTEXT_DIR to the pathname of the directory in which the
154 # GETTEXT include files and library resides.
156 GETTEXT_DIR=$(ETHEREAL_LIBS)\gettext-runtime-0.13.1
159 # /W3 warning level 3 (0 less - 4 most, 1 default)
160 # /Zi create .pdb file for debugging
164 # /DEBUG generate debug info
165 # /PROFILE generate map file(s) for profiling
168 # Set PDB_FILE according to your VC++ version
171 # Set up the path to the cygwin binaries
172 CYGWIN_PATH=c:\cygwin\bin
174 # Set up the path to some required DLLs
175 DLL_PATH=$(GLIB_DIR)\bin;$(GETTEXT_DIR)\bin;$(ICONV_DIR)\bin
178 # Set the following commands to find the tools.
179 # The easiest way is to use the corresponding packages from cygwin.
181 # command for a shell (typically cygwin's bash package)
184 # command for perl (typically cygwin's perl package)
187 # command for pod2man and pod2html (part of the perl package)
188 POD2MAN=$(SH) pod2man
189 POD2HTML=$(SH) pod2html
191 # command for python (native windows version)
192 #PYTHON="C:/python23/python.exe"
193 # add native python to the path (not needed if cygwin's python is used)
194 #PATH=c:\python23;$(PATH)
196 # command for python (typically cygwin's python package)
199 # command for lex/flexx (typically cygwin's flex package)
202 # command for yacc/bison (typically cygwin's bison package)
205 # To build the installer
206 MAKENSIS="C:/program files/nsis/makensis.exe"
208 # Choose modern style user interface for the installer.
209 # When using this, make sure you have a supported NSIS
210 # version installed. See "packaging\nsis\ethereal.nsi" for details.
212 # If you don't want the modern UI (or don't have a recent NSIS version),
213 # comment this line out, so that MAKENSIS_MODERN_UI isn't defined.
215 MAKENSIS_MODERN_UI=USE
217 # To build the developers documentation with doxygen and dot.
218 # Currently experimental only.
219 # You will have to download and install:
221 # Doxygen from: www.doxygen.org
222 # Graphviz from: http://www.research.att.com/sw/tools/graphviz/
224 # If you don't want the developers documentation (or don't have the tools),
225 # comment this line out, so that DOXYGEN isn't defined.
227 #DOXYGEN="C:/program files/doxygen/bin/doxygen.exe"
229 # To build compressed html help format .chm from doxygen output.
230 # Currently experimental only.
231 # You will have to download and install the html help compiler from:
233 # http://msdn.microsoft.com/library/default.asp?url=/library/en-us/htmlhelp/html
234 # /hwMicrosoftHTMLHelpDownloads.asp
236 # Then point HHC to the html help compiler exe.
238 # The .chm file(s) are not generated by default. You will have to generate the
239 # file(s) by calling the Makefile.nmake's target doxygen.chm in the submodules (epan/gk/...).
241 #HHC="C:/Program Files/HTML Help Workshop/hhc.exe"
243 # According to http://bugs.ethereal.com/bugzilla/show_bug.cgi?id=403
244 # XCOPY under Windows NT doesn't support the "/Y" flag. This works
246 # XXX - This apparently doesn't work for some versions of nmake:
247 # http://support.microsoft.com/default.aspx?scid=kb;en-us;86814
248 # It looks like we'll have to call "set copycmd=/y" before we run xcopy.
251 # If you don't want to build libethereal.dll, you should comment out the
252 # following line. (Note: for plugin support this option must stay activated)
253 ENABLE_LIBETHEREAL=USE
255 !IFDEF ENABLE_LIBETHEREAL
256 # Uncomment next line to link plugins with the import library of libethereal.dll
257 LINK_PLUGINS_WITH_LIBETHEREAL=USE
261 # You should not have to change anything below this comment.
262 # If you do, it's a deficiency in the Makefile.nmake files;
263 # either tell ethereal-dev@ethereal.com about it, including
264 # details of why you had to change it, or fix config.nmake
265 # and any Makefile.nmake files that need to be changed, and
266 # send us the patches, along with details of why the change
269 GLIB_CFLAGS=/I$(GLIB_DIR)\include\glib-$(GLIB_VERSION) \
270 /I$(GLIB_DIR)\lib\glib-$(GLIB_VERSION)\include
271 GCC_GLIB_CFLAGS=-I$(GLIB_DIR)\include\glib-$(GLIB_VERSION) \
272 -I$(GLIB_DIR)\lib\glib-$(GLIB_VERSION)\include
273 GLIB_LIBS=$(GLIB_DIR)\lib\glib-$(GLIB_VERSION).lib \
274 $(GLIB_DIR)\lib\gmodule-$(GLIB_VERSION).lib \
275 $(GLIB_DIR)\lib\gobject-$(GLIB_VERSION).lib
278 GTK1_CFLAGS=$(GLIB_CFLAGS) /I$(GTK1_DIR)\include /I$(GTK1_DIR)\include\gdk \
279 /I$(GTK1_DIR)\lib\gtk+\include
280 GTK1_LIBS=$(GTK1_DIR)\lib\gtk.lib \
281 $(GTK1_DIR)\lib\gdk.lib \
285 GTK2_CFLAGS=$(GLIB_CFLAGS) /I$(GTK2_DIR)\include\gtk-2.0 \
286 /I$(GTK2_DIR)\lib\gtk-2.0\include \
287 /I$(GTK2_DIR)\include\atk-1.0 \
288 /I$(GTK2_DIR)\include\pango-1.0
289 GTK2_LIBS=$(GTK2_DIR)\lib\gtk-win32-2.0.lib \
290 $(GTK2_DIR)\lib\gdk-win32-2.0.lib \
291 $(GTK2_DIR)\lib\gdk_pixbuf-2.0.lib \
292 $(GTK2_DIR)\lib\pango-1.0.lib \
295 # the lib dir of GTK2.6 didn't changed since 2.4.0
296 !IF "$(GTK2_INST_VERSION)" == "2.6"
298 !ELSEIF "$(GTK2_INST_VERSION)" == "2.4"
300 !ELSEIF "$(GTK2_INST_VERSION)" == "2.2"
304 # the lib dir of PANGO1.8 didn't changed since 1.4.0
305 !IF "$(PANGO_INST_VERSION)" == "1.8"
307 !ELSEIF "$(PANGO_INST_VERSION)" == "1.4"
309 !ELSEIF "$(PANGO_INST_VERSION)" == "1.2"
314 !IFDEF WINPCAP_VERSION
315 # Nmake uses carets to escape special characters
316 WINPCAP_CONFIG=^#define HAVE_LIBPCAP 1
317 !IF "$(WINPCAP_VERSION)" == "3.0" || "$(WINPCAP_VERSION)" == "3.1"
318 PCAP_FINDALLDEVS_CONFIG=^#define HAVE_PCAP_FINDALLDEVS 1
319 PCAP_DATALINK_NAME_TO_VAL_CONFIG=^#define HAVE_PCAP_DATALINK_NAME_TO_VAL 1
320 PCAP_DATALINK_VAL_TO_NAME_CONFIG=^#define HAVE_PCAP_DATALINK_VAL_TO_NAME 1
321 WPCAP_CONSTIFIED_CONFIG=^#define WPCAP_CONSTIFIED 1
323 PCAP_FINDALLDEVS_CONFIG=
324 PCAP_DATALINK_VAL_TO_NAME_CONFIG=
329 PCAP_FINDALLDEVS_CONFIG=
330 PCAP_DATALINK_NAME_TO_VAL_CONFIG=
331 PCAP_DATALINK_VAL_TO_NAME_CONFIG=
336 ZLIB_PATH=$(ZLIB_DIR)
337 ZLIB_CFLAGS=/I$(ZLIB_DIR)\include
338 ZLIB_LIBS=$(ZLIB_DIR)\lib\zdll.lib
339 # Nmake uses carets to escape special characters
340 ZLIB_CONFIG=^#define HAVE_LIBZ 1
348 ADNS_PATH=$(ADNS_DIR)\adns_win32\lib
349 ADNS_CFLAGS=/I$(ADNS_DIR)\src /I$(ADNS_DIR)\adns_win32
350 ADNS_LIBS=$(ADNS_DIR)\adns_win32\lib\adns_dll.lib
351 # Nmake uses carets to escape special characters
352 ADNS_CONFIG=^#define HAVE_GNU_ADNS 1
360 PCRE_PATH=$(PCRE_DIR)\bin
361 PCRE_CFLAGS=/I$(PCRE_DIR)\include
362 PCRE_LIBS=$(PCRE_DIR)\lib\pcre.lib
363 # Nmake uses carets to escape special characters
364 PCRE_CONFIG=^#define HAVE_LIBPCRE 1
372 NETTLE_CFLAGS=/I$(NETTLE_DIR)
373 NETTLE_LIBS=$(NETTLE_DIR)\libnettle.lib
374 # Nmake uses carets to escape special characters
375 NETTLE_CONFIG=^#define HAVE_LIBNETTLE 1
382 !IFDEF ENABLE_LIBETHEREAL
383 LIBETHEREAL_CONFIG=^#define HAVE_LIBETHEREALDLL 1
389 PATH=$(PATH);$(CYGWIN_PATH);$(DLL_PATH);$(ZLIB_PATH);$(ADNS_PATH)