replace *a lot* of file related calls by their GLib counterparts. This is necessary...
[obnox/wireshark/wip.git] / config.nmake
1 # $Id$
2
3 # Some more informations about the settings in this file, can be found 
4 # in the file README.win32.
5
6 # The current Ethereal version
7 VERSION=0.10.13
8
9 #
10 # The RC_VERSION should be comma-separated, not dot-separated, 
11 # as per Graham Bloice's message in
12 #
13 #       http://www.ethereal.com/lists/ethereal-dev/200303/msg00283.html
14 #
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."
19 #
20 RC_VERSION=0,10,13
21
22 # The version of the wiretap library
23 WTAP_VERSION=0.3
24 RC_WTAP_VERSION=0,3
25
26 #
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.
30 #
31 # If you're not building with WinPcap at all, don't set it (comment
32 # out or remove the line that sets it).
33 #
34 WINPCAP_VERSION=3.1
35
36
37 # Directory, where your User's Guide reside, relative to the source dir.
38 # (currently unused)
39 #
40 # If you don't have the User's Guide, comment this line out, so that 
41 # ETHEREAL_EUG_DIR isn't defined.
42 #
43 #ETHEREAL_EUG_DIR=docbook/eug_html_chunked
44
45
46 # Base directory, where your libraries reside, which needs to be 
47 # compiling the sources. This is only inside this file.
48 #
49 ETHEREAL_LIBS=C:\ethereal-win32-libs
50
51 #
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.
55 #
56 GLIB_VERSION=2.0
57 GLIB_DIR=$(ETHEREAL_LIBS)\glib
58
59 #
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.
64 #
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.
67
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 
71 # reside.
72 #
73 GTK1_DIR=$(ETHEREAL_LIBS)\gtk+
74 GTK2_DIR=$(ETHEREAL_LIBS)\gtk2
75
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.
79 #
80 #GTK2_INST_VERSION=2.2
81 #PANGO_INST_VERSION=1.2
82 GTK2_INST_VERSION=2.4
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
87
88 #
89 # If you have GTK-Wimp, set this to the pathname of the directory in
90 # which the files are stored.
91 #
92 # If you don't have GTK-Wimp, comment this line out, so that GTK-Wimp isn't
93 # defined.
94 #
95 GTK_WIMP_DIR=$(ETHEREAL_LIBS)\gtk-wimp
96
97 #
98 # If you have Zlib, set this to the pathname of the directory in
99 # which the Zlib headers and .lib file are stored.
100 #
101 # If you don't have Zlib, comment this line out, so that Zlib isn't
102 # defined.
103 #
104 ZLIB_DIR=$(ETHEREAL_LIBS)\zlib123-dll
105
106 #
107 # Set PCAP_DIR to the pathname of the directory in which the WinPcap
108 # developer's pack resides
109 #
110 PCAP_DIR=$(ETHEREAL_LIBS)\WPdpack
111
112 #
113 # Set NET_SNMP_DIR to the pathname of the directory in which the
114 # Net-SNMP include files and library resides.
115 #
116 NET_SNMP_DIR=$(ETHEREAL_LIBS)\net-snmp-5.2.1.2
117
118 #
119 # If you have GNU ADNS, set this to the pathname of the directory in
120 # which the GNU ADNS .lib file is stored.
121 #
122 # If you don't have GNU ADNS, comment this line out, so that ADNS_DIR
123 # isn't defined.
124 #
125 ADNS_DIR=$(ETHEREAL_LIBS)\adns-1.0-win32-04
126
127 #
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.
131 #
132 # If you don't have PCRE, comment this line out, so that PCRE_DIR
133 # isn't defined.
134 #
135 PCRE_DIR=$(ETHEREAL_LIBS)\pcre-6.3
136
137 #
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.
140 #
141 # If you don't have Nettle, comment this line out, so that NETTLE_DIR
142 # isn't defined.
143 #
144 # NETTLE_DIR=$(ETHEREAL_LIBS)\nettle-1.10
145
146 #
147 # Set ICONV_DIR to the pathname of the directory in which the
148 # ICONV include files and library resides.
149 #
150 ICONV_DIR=$(ETHEREAL_LIBS)\libiconv-1.9.1.bin.woe32
151
152 #
153 # Set GETTEXT_DIR to the pathname of the directory in which the
154 # GETTEXT include files and library resides.
155 #
156 GETTEXT_DIR=$(ETHEREAL_LIBS)\gettext-runtime-0.13.1
157
158 # Compiler flags
159 # /W3  warning level 3 (0 less - 4 most, 1 default)
160 # /Zi  create .pdb file for debugging
161 LOCAL_CFLAGS=/Zi /W3
162
163 # Linker flags
164 # /DEBUG  generate debug info
165 # /PROFILE generate map file(s) for profiling
166 LOCAL_LDFLAGS=/DEBUG
167
168 # Set PDB_FILE according to your VC++ version 
169 PDB_FILE=vc*.pdb
170
171 # Set up the path to the cygwin binaries
172 CYGWIN_PATH=c:\cygwin\bin
173
174 # Set up the path to some required DLLs
175 DLL_PATH=$(GLIB_DIR)\bin;$(GETTEXT_DIR)\bin;$(ICONV_DIR)\bin
176
177
178 # Set the following commands to find the tools.
179 # The easiest way is to use the corresponding packages from cygwin.
180
181 # command for a shell (typically cygwin's bash package)
182 SH=bash
183
184 # command for perl (typically cygwin's perl package)
185 PERL=perl
186
187 # command for pod2man and pod2html (part of the perl package)
188 POD2MAN=$(SH) pod2man
189 POD2HTML=$(SH) pod2html
190
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)
195
196 # command for python (typically cygwin's python package)
197 PYTHON=env python
198
199 # command for lex/flexx (typically cygwin's flex package)
200 LEX=flex
201
202 # command for yacc/bison (typically cygwin's bison package)
203 YACC=bison
204
205 # To build the installer
206 MAKENSIS="C:/program files/nsis/makensis.exe"
207
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.
211 #
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.
214 #
215 MAKENSIS_MODERN_UI=USE
216
217 # To build the developers documentation with doxygen and dot.
218 # Currently experimental only.
219 # You will have to download and install:
220 #
221 # Doxygen from: www.doxygen.org
222 # Graphviz from: http://www.research.att.com/sw/tools/graphviz/
223 #
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.
226 #
227 #DOXYGEN="C:/program files/doxygen/bin/doxygen.exe"
228
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:
232 #
233 # http://msdn.microsoft.com/library/default.asp?url=/library/en-us/htmlhelp/html
234 # /hwMicrosoftHTMLHelpDownloads.asp 
235 #
236 # Then point HHC to the html help compiler exe.
237 #
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/...).
240 #
241 #HHC="C:/Program Files/HTML Help Workshop/hhc.exe"
242
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
245 # around that bug.
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.
249 COPYCMD=/y
250
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
254
255 !IFDEF ENABLE_LIBETHEREAL
256 # Uncomment next line to link plugins with the import library of libethereal.dll 
257 LINK_PLUGINS_WITH_LIBETHEREAL=USE
258 !ENDIF
259
260 #
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
267 # was necessary.
268 #
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
276
277 # GTK+ 1.3
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 \
282         $(GLIB_LIBS)
283
284 # GTK+ 2.x
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 \
293         $(GLIB_LIBS)
294
295 # the lib dir of GTK2.6 didn't changed since 2.4.0
296 !IF "$(GTK2_INST_VERSION)" == "2.6"
297 GTK2_LIB_DIR=2.4.0
298 !ELSEIF "$(GTK2_INST_VERSION)" == "2.4"
299 GTK2_LIB_DIR=2.4.0
300 !ELSEIF "$(GTK2_INST_VERSION)" == "2.2"
301 GTK2_LIB_DIR=2.2.0
302 !ENDIF
303
304 # the lib dir of PANGO1.8 didn't changed since 1.4.0
305 !IF "$(PANGO_INST_VERSION)" == "1.8"
306 PANGO_LIB_DIR=1.4.0
307 !ELSEIF "$(PANGO_INST_VERSION)" == "1.4"
308 PANGO_LIB_DIR=1.4.0
309 !ELSEIF "$(PANGO_INST_VERSION)" == "1.2"
310 PANGO_LIB_DIR=1.2.0
311 !ENDIF
312
313
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
322 !ELSE
323 PCAP_FINDALLDEVS_CONFIG=
324 PCAP_DATALINK_VAL_TO_NAME_CONFIG=
325 WPCAP_CONSTIFIED=
326 !ENDIF
327 !ELSE
328 WINPCAP_CONFIG=
329 PCAP_FINDALLDEVS_CONFIG=
330 PCAP_DATALINK_NAME_TO_VAL_CONFIG=
331 PCAP_DATALINK_VAL_TO_NAME_CONFIG=
332 WPCAP_CONSTIFIED=
333 !ENDIF
334
335 !IFDEF ZLIB_DIR
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
341 !else
342 ZLIB_CFLAGS=
343 ZLIB_LIBS=
344 ZLIB_CONFIG=
345 !ENDIF
346
347 !IFDEF ADNS_DIR
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
353 !else
354 ADNS_CFLAGS=
355 ADNS_LIBS=
356 ADNS_CONFIG=
357 !ENDIF
358
359 !IFDEF PCRE_DIR
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
365 !else
366 PCRE_CFLAGS=
367 PCRE_LIBS=
368 PCRE_CONFIG=
369 !ENDIF
370
371 !IFDEF NETTLE_DIR
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
376 !else
377 NETTLE_CFLAGS=
378 NETTLE_LIBS=
379 NETTLE_CONFIG=
380 !ENDIF
381
382 !IFDEF ENABLE_LIBETHEREAL
383 LIBETHEREAL_CONFIG=^#define HAVE_LIBETHEREALDLL 1
384 !ELSE
385 LIBETHEREAL_CONFIG=
386 !ENDIF
387
388 # Construct the path
389 PATH=$(PATH);$(CYGWIN_PATH);$(DLL_PATH);$(ZLIB_PATH);$(ADNS_PATH)