VirtualBox

source: vbox/trunk/src/libs/libxml2-2.6.30/win32/configure.js@ 19279

Last change on this file since 19279 was 6076, checked in by vboxsync, 17 years ago

Merged dmik/s2 branch (r25959:26751) to the trunk.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Date Revision Author Id
File size: 29.0 KB
Line 
1/* Configure script for libxml, specific for Windows with Scripting Host.
2 *
3 * This script will configure the libxml build process and create necessary files.
4 * Run it with an 'help', or an invalid option and it will tell you what options
5 * it accepts.
6 *
7 * March 2002, Igor Zlatkovic <igor@zlatkovic.com>
8 */
9
10/* The source directory, relative to the one where this file resides. */
11var srcDirXml = "..";
12var srcDirUtils = "..";
13/* Base name of what we are building. */
14var baseName = "libxml2";
15/* Configure file which contains the version and the output file where
16 we can store our build configuration. */
17var configFile = srcDirXml + "\\configure.in";
18var versionFile = ".\\config.msvc";
19/* Input and output files regarding the libxml features. */
20var optsFileIn = srcDirXml + "\\include\\libxml\\xmlversion.h.in";
21var optsFile = srcDirXml + "\\include\\libxml\\xmlversion.h";
22/* Version strings for the binary distribution. Will be filled later
23 in the code. */
24var verMajor;
25var verMinor;
26var verMicro;
27var verMicroSuffix;
28var verCvs;
29var useCvsVer = true;
30/* Libxml features. */
31var withTrio = false;
32var withThreads = "native";
33var withFtp = true;
34var withHttp = true;
35var withHtml = true;
36var withC14n = true;
37var withCatalog = true;
38var withDocb = true;
39var withXpath = true;
40var withXptr = true;
41var withXinclude = true;
42var withIconv = true;
43var withIso8859x = false;
44var withZlib = false;
45var withDebug = true;
46var withMemDebug = false;
47var withRunDebug = false;
48var withSchemas = true;
49var withSchematron = true;
50var withRegExps = true;
51var withModules = true;
52var withTree = true;
53var withReader = true;
54var withWriter = true;
55var withWalker = true;
56var withPattern = true;
57var withPush = true;
58var withValid = true;
59var withSax1 = true;
60var withLegacy = true;
61var withOutput = true;
62var withPython = false;
63/* Win32 build options. */
64var dirSep = "\\";
65var compiler = "msvc";
66var cruntime = "/MD";
67var dynruntime = true;
68var vcmanifest = false;
69var buildDebug = 0;
70var buildStatic = 0;
71var buildPrefix = ".";
72var buildBinPrefix = "";
73var buildIncPrefix = "";
74var buildLibPrefix = "";
75var buildSoPrefix = "";
76var buildInclude = ".";
77var buildLib = ".";
78/* Local stuff */
79var error = 0;
80
81/* Helper function, transforms the option variable into the 'Enabled'
82 or 'Disabled' string. */
83function boolToStr(opt)
84{
85 if (opt == false)
86 return "no";
87 else if (opt == true)
88 return "yes";
89 error = 1;
90 return "*** undefined ***";
91}
92
93/* Helper function, transforms the argument string into a boolean
94 value. */
95function strToBool(opt)
96{
97 if (opt == 0 || opt == "no")
98 return false;
99 else if (opt == 1 || opt == "yes")
100 return true;
101 error = 1;
102 return false;
103}
104
105/* Displays the details about how to use this script. */
106function usage()
107{
108 var txt;
109 txt = "Usage:\n";
110 txt += " cscript " + WScript.ScriptName + " <options>\n";
111 txt += " cscript " + WScript.ScriptName + " help\n\n";
112 txt += "Options can be specified in the form <option>=<value>, where the value is\n";
113 txt += "either 'yes' or 'no', if not stated otherwise.\n\n";
114 txt += "\nXML processor options, default value given in parentheses:\n\n";
115 txt += " trio: Enable TRIO string manipulator (" + (withTrio? "yes" : "no") + ")\n";
116 txt += " threads: Enable thread safety [no|ctls|native|posix] (" + (withThreads) + ") \n";
117 txt += " ftp: Enable FTP client (" + (withFtp? "yes" : "no") + ")\n";
118 txt += " http: Enable HTTP client (" + (withHttp? "yes" : "no") + ")\n";
119 txt += " html: Enable HTML processor (" + (withHtml? "yes" : "no") + ")\n";
120 txt += " c14n: Enable C14N support (" + (withC14n? "yes" : "no") + ")\n";
121 txt += " catalog: Enable catalog support (" + (withCatalog? "yes" : "no") + ")\n";
122 txt += " docb: Enable DocBook support (" + (withDocb? "yes" : "no") + ")\n";
123 txt += " xpath: Enable XPath support (" + (withXpath? "yes" : "no") + ")\n";
124 txt += " xptr: Enable XPointer support (" + (withXptr? "yes" : "no") + ")\n";
125 txt += " xinclude: Enable XInclude support (" + (withXinclude? "yes" : "no") + ")\n";
126 txt += " iconv: Enable iconv support (" + (withIconv? "yes" : "no") + ")\n";
127 txt += " iso8859x: Enable ISO8859X support (" + (withIso8859x? "yes" : "no") + ")\n";
128 txt += " zlib: Enable zlib support (" + (withZlib? "yes" : "no") + ")\n";
129 txt += " xml_debug: Enable XML debbugging module (" + (withDebug? "yes" : "no") + ")\n";
130 txt += " mem_debug: Enable memory debugger (" + (withMemDebug? "yes" : "no") + ")\n";
131 txt += " run_debug: Enable memory debugger (" + (withRunDebug? "yes" : "no") + ")\n";
132 txt += " regexps: Enable regular expressions (" + (withRegExps? "yes" : "no") + ")\n";
133 txt += " modules: Enable module support (" + (withModules? "yes" : "no") + ")\n";
134 txt += " tree: Enable tree api (" + (withTree? "yes" : "no") + ")\n";
135 txt += " reader: Enable xmlReader api (" + (withReader? "yes" : "no") + ")\n";
136 txt += " writer: Enable xmlWriter api (" + (withWriter? "yes" : "no") + ")\n";
137 txt += " walker: Enable xmlDocWalker api (" + (withWalker? "yes" : "no") + ")\n";
138 txt += " pattern: Enable xmlPattern api (" + (withPattern? "yes" : "no") + ")\n";
139 txt += " push: Enable push api (" + (withPush? "yes" : "no") + ")\n";
140 txt += " valid: Enable DTD validation support (" + (withValid? "yes" : "no") + ")\n";
141 txt += " sax1: Enable SAX1 api (" + (withSax1? "yes" : "no") + ")\n";
142 txt += " legacy: Enable Deprecated api's (" + (withLegacy? "yes" : "no") + ")\n";
143 txt += " output: Enable serialization support (" + (withOutput? "yes" : "no") + ")\n";
144 txt += " schemas: Enable XML Schema support (" + (withSchemas? "yes" : "no") + ")\n";
145 txt += " schematron: Enable Schematron support (" + (withSchematron? "yes" : "no") + ")\n";
146 txt += " python: Build Python bindings (" + (withPython? "yes" : "no") + ")\n";
147 txt += "\nWin32 build options, default value given in parentheses:\n\n";
148 txt += " compiler: Compiler to be used [msvc|mingw|bcb] (" + compiler + ")\n";
149 txt += " cruntime: C-runtime compiler option (only msvc) (" + cruntime + ")\n";
150 txt += " dynruntime: Use the dynamic RTL (only bcb) (" + dynruntime + ")\n";
151 txt += " vcmanifest: Embed VC manifest (only msvc) (" + (vcmanifest? "yes" : "no") + ")\n";
152 txt += " debug: Build unoptimised debug executables (" + (buildDebug? "yes" : "no") + ")\n";
153 txt += " static: Link xmllint statically to libxml2 (" + (buildStatic? "yes" : "no") + ")\n";
154 txt += " Note: automatically enabled if cruntime is not /MD or /MDd\n";
155 txt += " prefix: Base directory for the installation (" + buildPrefix + ")\n";
156 txt += " bindir: Directory where xmllint and friends should be installed\n";
157 txt += " (" + buildBinPrefix + ")\n";
158 txt += " incdir: Directory where headers should be installed\n";
159 txt += " (" + buildIncPrefix + ")\n";
160 txt += " libdir: Directory where static and import libraries should be\n";
161 txt += " installed (" + buildLibPrefix + ")\n";
162 txt += " sodir: Directory where shared libraries should be installed\n";
163 txt += " (" + buildSoPrefix + ")\n";
164 txt += " include: Additional search path for the compiler, particularily\n";
165 txt += " where iconv headers can be found (" + buildInclude + ")\n";
166 txt += " lib: Additional search path for the linker, particularily\n";
167 txt += " where iconv library can be found (" + buildLib + ")\n";
168 WScript.Echo(txt);
169}
170
171/* Discovers the version we are working with by reading the apropriate
172 configuration file. Despite its name, this also writes the configuration
173 file included by our makefile. */
174function discoverVersion()
175{
176 var fso, cf, vf, ln, s, iDot, iSlash;
177 fso = new ActiveXObject("Scripting.FileSystemObject");
178 verCvs = "";
179 if (useCvsVer && fso.FileExists("..\\CVS\\Entries")) {
180 cf = fso.OpenTextFile("..\\CVS\\Entries", 1);
181 while (cf.AtEndOfStream != true) {
182 ln = cf.ReadLine();
183 s = new String(ln);
184 if (s.search(/^\/ChangeLog\//) != -1) {
185 iDot = s.indexOf(".");
186 iSlash = s.indexOf("/", iDot);
187 verCvs = "CVS" + s.substring(iDot + 1, iSlash);
188 break;
189 }
190 }
191 cf.Close();
192 }
193 cf = fso.OpenTextFile(configFile, 1);
194 if (compiler == "msvc")
195 versionFile = ".\\config.msvc";
196 else if (compiler == "mingw")
197 versionFile = ".\\config.mingw";
198 else if (compiler == "bcb")
199 versionFile = ".\\config.bcb";
200 vf = fso.CreateTextFile(versionFile, true);
201 vf.WriteLine("# " + versionFile);
202 vf.WriteLine("# This file is generated automatically by " + WScript.ScriptName + ".");
203 vf.WriteBlankLines(1);
204 while (cf.AtEndOfStream != true) {
205 ln = cf.ReadLine();
206 s = new String(ln);
207 if (s.search(/^LIBXML_MAJOR_VERSION=/) != -1) {
208 vf.WriteLine(s);
209 verMajor = s.substring(s.indexOf("=") + 1, s.length)
210 } else if(s.search(/^LIBXML_MINOR_VERSION=/) != -1) {
211 vf.WriteLine(s);
212 verMinor = s.substring(s.indexOf("=") + 1, s.length)
213 } else if(s.search(/^LIBXML_MICRO_VERSION=/) != -1) {
214 vf.WriteLine(s);
215 verMicro = s.substring(s.indexOf("=") + 1, s.length)
216 } else if(s.search(/^LIBXML_MICRO_VERSION_SUFFIX=/) != -1) {
217 vf.WriteLine(s);
218 verMicroSuffix = s.substring(s.indexOf("=") + 1, s.length)
219 }
220 }
221 cf.Close();
222 vf.WriteLine("XML_SRCDIR=" + srcDirXml);
223 vf.WriteLine("UTILS_SRCDIR=" + srcDirUtils);
224 vf.WriteLine("WITH_TRIO=" + (withTrio? "1" : "0"));
225 vf.WriteLine("WITH_THREADS=" + withThreads);
226 vf.WriteLine("WITH_FTP=" + (withFtp? "1" : "0"));
227 vf.WriteLine("WITH_HTTP=" + (withHttp? "1" : "0"));
228 vf.WriteLine("WITH_HTML=" + (withHtml? "1" : "0"));
229 vf.WriteLine("WITH_C14N=" + (withC14n? "1" : "0"));
230 vf.WriteLine("WITH_CATALOG=" + (withCatalog? "1" : "0"));
231 vf.WriteLine("WITH_DOCB=" + (withDocb? "1" : "0"));
232 vf.WriteLine("WITH_XPATH=" + (withXpath? "1" : "0"));
233 vf.WriteLine("WITH_XPTR=" + (withXptr? "1" : "0"));
234 vf.WriteLine("WITH_XINCLUDE=" + (withXinclude? "1" : "0"));
235 vf.WriteLine("WITH_ICONV=" + (withIconv? "1" : "0"));
236 vf.WriteLine("WITH_ISO8859X=" + (withIso8859x? "1" : "0"));
237 vf.WriteLine("WITH_ZLIB=" + (withZlib? "1" : "0"));
238 vf.WriteLine("WITH_DEBUG=" + (withDebug? "1" : "0"));
239 vf.WriteLine("WITH_MEM_DEBUG=" + (withMemDebug? "1" : "0"));
240 vf.WriteLine("WITH_RUN_DEBUG=" + (withRunDebug? "1" : "0"));
241 vf.WriteLine("WITH_SCHEMAS=" + (withSchemas? "1" : "0"));
242 vf.WriteLine("WITH_SCHEMATRON=" + (withSchematron? "1" : "0"));
243 vf.WriteLine("WITH_REGEXPS=" + (withRegExps? "1" : "0"));
244 vf.WriteLine("WITH_MODULES=" + (withModules? "1" : "0"));
245 vf.WriteLine("WITH_TREE=" + (withTree? "1" : "0"));
246 vf.WriteLine("WITH_READER=" + (withReader? "1" : "0"));
247 vf.WriteLine("WITH_WRITER=" + (withWriter? "1" : "0"));
248 vf.WriteLine("WITH_WALKER=" + (withWalker? "1" : "0"));
249 vf.WriteLine("WITH_PATTERN=" + (withPattern? "1" : "0"));
250 vf.WriteLine("WITH_PUSH=" + (withPush? "1" : "0"));
251 vf.WriteLine("WITH_VALID=" + (withValid? "1" : "0"));
252 vf.WriteLine("WITH_SAX1=" + (withSax1? "1" : "0"));
253 vf.WriteLine("WITH_LEGACY=" + (withLegacy? "1" : "0"));
254 vf.WriteLine("WITH_OUTPUT=" + (withOutput? "1" : "0"));
255 vf.WriteLine("WITH_PYTHON=" + (withPython? "1" : "0"));
256 vf.WriteLine("DEBUG=" + (buildDebug? "1" : "0"));
257 vf.WriteLine("STATIC=" + (buildStatic? "1" : "0"));
258 vf.WriteLine("PREFIX=" + buildPrefix);
259 vf.WriteLine("BINPREFIX=" + buildBinPrefix);
260 vf.WriteLine("INCPREFIX=" + buildIncPrefix);
261 vf.WriteLine("LIBPREFIX=" + buildLibPrefix);
262 vf.WriteLine("SOPREFIX=" + buildSoPrefix);
263 if (compiler == "msvc") {
264 vf.WriteLine("INCLUDE=$(INCLUDE);" + buildInclude);
265 vf.WriteLine("LIB=$(LIB);" + buildLib);
266 vf.WriteLine("CRUNTIME=" + cruntime);
267 vf.WriteLine("VCMANIFEST=" + (vcmanifest? "1" : "0"));
268 } else if (compiler == "mingw") {
269 vf.WriteLine("INCLUDE+=;" + buildInclude);
270 vf.WriteLine("LIB+=;" + buildLib);
271 } else if (compiler == "bcb") {
272 vf.WriteLine("INCLUDE=" + buildInclude);
273 vf.WriteLine("LIB=" + buildLib);
274 vf.WriteLine("DYNRUNTIME=" + (dynruntime? "1" : "0"));
275 }
276 vf.Close();
277}
278
279/* Configures libxml. This one will generate xmlversion.h from xmlversion.h.in
280 taking what the user passed on the command line into account. */
281function configureLibxml()
282{
283 var fso, ofi, of, ln, s;
284 fso = new ActiveXObject("Scripting.FileSystemObject");
285 ofi = fso.OpenTextFile(optsFileIn, 1);
286 of = fso.CreateTextFile(optsFile, true);
287 while (ofi.AtEndOfStream != true) {
288 ln = ofi.ReadLine();
289 s = new String(ln);
290 if (s.search(/\@VERSION\@/) != -1) {
291 of.WriteLine(s.replace(/\@VERSION\@/,
292 verMajor + "." + verMinor + "." + verMicro + verMicroSuffix));
293 } else if (s.search(/\@LIBXML_VERSION_NUMBER\@/) != -1) {
294 of.WriteLine(s.replace(/\@LIBXML_VERSION_NUMBER\@/,
295 verMajor*10000 + verMinor*100 + verMicro*1));
296 } else if (s.search(/\@LIBXML_VERSION_EXTRA\@/) != -1) {
297 of.WriteLine(s.replace(/\@LIBXML_VERSION_EXTRA\@/, verCvs));
298 } else if (s.search(/\@WITH_TRIO\@/) != -1) {
299 of.WriteLine(s.replace(/\@WITH_TRIO\@/, withTrio? "1" : "0"));
300 } else if (s.search(/\@WITH_THREADS\@/) != -1) {
301 of.WriteLine(s.replace(/\@WITH_THREADS\@/, withThreads == "no"? "0" : "1"));
302 } else if (s.search(/\@WITH_FTP\@/) != -1) {
303 of.WriteLine(s.replace(/\@WITH_FTP\@/, withFtp? "1" : "0"));
304 } else if (s.search(/\@WITH_HTTP\@/) != -1) {
305 of.WriteLine(s.replace(/\@WITH_HTTP\@/, withHttp? "1" : "0"));
306 } else if (s.search(/\@WITH_HTML\@/) != -1) {
307 of.WriteLine(s.replace(/\@WITH_HTML\@/, withHtml? "1" : "0"));
308 } else if (s.search(/\@WITH_C14N\@/) != -1) {
309 of.WriteLine(s.replace(/\@WITH_C14N\@/, withC14n? "1" : "0"));
310 } else if (s.search(/\@WITH_CATALOG\@/) != -1) {
311 of.WriteLine(s.replace(/\@WITH_CATALOG\@/, withCatalog? "1" : "0"));
312 } else if (s.search(/\@WITH_DOCB\@/) != -1) {
313 of.WriteLine(s.replace(/\@WITH_DOCB\@/, withDocb? "1" : "0"));
314 } else if (s.search(/\@WITH_XPATH\@/) != -1) {
315 of.WriteLine(s.replace(/\@WITH_XPATH\@/, withXpath? "1" : "0"));
316 } else if (s.search(/\@WITH_XPTR\@/) != -1) {
317 of.WriteLine(s.replace(/\@WITH_XPTR\@/, withXptr? "1" : "0"));
318 } else if (s.search(/\@WITH_XINCLUDE\@/) != -1) {
319 of.WriteLine(s.replace(/\@WITH_XINCLUDE\@/, withXinclude? "1" : "0"));
320 } else if (s.search(/\@WITH_ICONV\@/) != -1) {
321 of.WriteLine(s.replace(/\@WITH_ICONV\@/, withIconv? "1" : "0"));
322 } else if (s.search(/\@WITH_ISO8859X\@/) != -1) {
323 of.WriteLine(s.replace(/\@WITH_ISO8859X\@/, withIso8859x? "1" : "0"));
324 } else if (s.search(/\@WITH_ZLIB\@/) != -1) {
325 of.WriteLine(s.replace(/\@WITH_ZLIB\@/, withZlib? "1" : "0"));
326 } else if (s.search(/\@WITH_DEBUG\@/) != -1) {
327 of.WriteLine(s.replace(/\@WITH_DEBUG\@/, withDebug? "1" : "0"));
328 } else if (s.search(/\@WITH_MEM_DEBUG\@/) != -1) {
329 of.WriteLine(s.replace(/\@WITH_MEM_DEBUG\@/, withMemDebug? "1" : "0"));
330 } else if (s.search(/\@WITH_RUN_DEBUG\@/) != -1) {
331 of.WriteLine(s.replace(/\@WITH_RUN_DEBUG\@/, withRunDebug? "1" : "0"));
332 } else if (s.search(/\@WITH_SCHEMAS\@/) != -1) {
333 of.WriteLine(s.replace(/\@WITH_SCHEMAS\@/, withSchemas? "1" : "0"));
334 } else if (s.search(/\@WITH_SCHEMATRON\@/) != -1) {
335 of.WriteLine(s.replace(/\@WITH_SCHEMATRON\@/, withSchematron? "1" : "0"));
336 } else if (s.search(/\@WITH_REGEXPS\@/) != -1) {
337 of.WriteLine(s.replace(/\@WITH_REGEXPS\@/, withRegExps? "1" : "0"));
338 } else if (s.search(/\@WITH_MODULES\@/) != -1) {
339 of.WriteLine(s.replace(/\@WITH_MODULES\@/, withModules? "1" : "0"));
340 } else if (s.search(/\@MODULE_EXTENSION\@/) != -1) {
341 of.WriteLine(s.replace(/\@MODULE_EXTENSION\@/, ".dll"));
342 } else if (s.search(/\@WITH_TREE\@/) != -1) {
343 of.WriteLine(s.replace(/\@WITH_TREE\@/, withTree? "1" : "0"));
344 } else if (s.search(/\@WITH_READER\@/) != -1) {
345 of.WriteLine(s.replace(/\@WITH_READER\@/, withReader? "1" : "0"));
346 } else if (s.search(/\@WITH_WRITER\@/) != -1) {
347 of.WriteLine(s.replace(/\@WITH_WRITER\@/, withWriter? "1" : "0"));
348 } else if (s.search(/\@WITH_WALKER\@/) != -1) {
349 of.WriteLine(s.replace(/\@WITH_WALKER\@/, withWalker? "1" : "0"));
350 } else if (s.search(/\@WITH_PATTERN\@/) != -1) {
351 of.WriteLine(s.replace(/\@WITH_PATTERN\@/, withPattern? "1" : "0"));
352 } else if (s.search(/\@WITH_PUSH\@/) != -1) {
353 of.WriteLine(s.replace(/\@WITH_PUSH\@/, withPush? "1" : "0"));
354 } else if (s.search(/\@WITH_VALID\@/) != -1) {
355 of.WriteLine(s.replace(/\@WITH_VALID\@/, withValid? "1" : "0"));
356 } else if (s.search(/\@WITH_SAX1\@/) != -1) {
357 of.WriteLine(s.replace(/\@WITH_SAX1\@/, withSax1? "1" : "0"));
358 } else if (s.search(/\@WITH_LEGACY\@/) != -1) {
359 of.WriteLine(s.replace(/\@WITH_LEGACY\@/, withLegacy? "1" : "0"));
360 } else if (s.search(/\@WITH_OUTPUT\@/) != -1) {
361 of.WriteLine(s.replace(/\@WITH_OUTPUT\@/, withOutput? "1" : "0"));
362 } else
363 of.WriteLine(ln);
364 }
365 ofi.Close();
366 of.Close();
367}
368/* Configures Python bindings. Otherwise identical to the above */
369function configureLibxmlPy()
370{
371 var pyOptsFileIn = srcDirXml + "\\python\\setup.py.in";
372 var pyOptsFile = srcDirXml + "\\python\\setup.py";
373 var fso, ofi, of, ln, s;
374 fso = new ActiveXObject("Scripting.FileSystemObject");
375 ofi = fso.OpenTextFile(pyOptsFileIn, 1);
376 of = fso.CreateTextFile(pyOptsFile, true);
377 while (ofi.AtEndOfStream != true) {
378 ln = ofi.ReadLine();
379 s = new String(ln);
380 if (s.search(/\@LIBXML_VERSION\@/) != -1) {
381 of.WriteLine(s.replace(/\@LIBXML_VERSION\@/,
382 verMajor + "." + verMinor + "." + verMicro));
383 } else if (s.search(/\@prefix\@/) != -1) {
384 of.WriteLine(s.replace(/\@prefix\@/, buildPrefix));
385 } else if (s.search(/\@WITH_THREADS\@/) != -1) {
386 of.WriteLine(s.replace(/\@WITH_THREADS\@/, withThreads == "no"? "0" : "1"));
387 } else
388 of.WriteLine(ln);
389 }
390 ofi.Close();
391 of.Close();
392}
393
394/* Creates the readme file for the binary distribution of 'bname', for the
395 version 'ver' in the file 'file'. This one is called from the Makefile when
396 generating a binary distribution. The parameters are passed by make. */
397function genReadme(bname, ver, file)
398{
399 var fso, f;
400 fso = new ActiveXObject("Scripting.FileSystemObject");
401 f = fso.CreateTextFile(file, true);
402 f.WriteLine(" " + bname + " " + ver);
403 f.WriteLine(" --------------");
404 f.WriteBlankLines(1);
405 f.WriteLine(" This is " + bname + ", version " + ver + ", binary package for the native Win32/IA32");
406 f.WriteLine("platform.");
407 f.WriteBlankLines(1);
408 f.WriteLine(" The files in this package do not require any special installation");
409 f.WriteLine("steps. Extract the contents of the archive whereever you wish and");
410 f.WriteLine("make sure that your tools which use " + bname + " can find it.");
411 f.WriteBlankLines(1);
412 f.WriteLine(" For example, if you want to run the supplied utilities from the command");
413 f.WriteLine("line, you can, if you wish, add the 'bin' subdirectory to the PATH");
414 f.WriteLine("environment variable.");
415 f.WriteLine(" If you want to make programmes in C which use " + bname + ", you'll");
416 f.WriteLine("likely know how to use the contents of this package. If you don't, please");
417 f.WriteLine("refer to your compiler's documentation.");
418 f.WriteBlankLines(1);
419 f.WriteLine(" If there is something you cannot keep for yourself, such as a problem,");
420 f.WriteLine("a cheer of joy, a comment or a suggestion, feel free to contact me using");
421 f.WriteLine("the address below.");
422 f.WriteBlankLines(1);
423 f.WriteLine(" Igor Zlatkovic (igor@zlatkovic.com)");
424 f.Close();
425}
426
427
428/*
429 * main(),
430 * Execution begins here.
431 */
432
433// Parse the command-line arguments.
434for (i = 0; (i < WScript.Arguments.length) && (error == 0); i++) {
435 var arg, opt;
436 arg = WScript.Arguments(i);
437 opt = arg.substring(0, arg.indexOf("="));
438 if (opt.length == 0)
439 opt = arg.substring(0, arg.indexOf(":"));
440 if (opt.length > 0) {
441 if (opt == "trio")
442 withTrio = strToBool(arg.substring(opt.length + 1, arg.length));
443 else if (opt == "threads")
444 withThreads = arg.substring(opt.length + 1, arg.length);
445 else if (opt == "ftp")
446 withFtp = strToBool(arg.substring(opt.length + 1, arg.length));
447 else if (opt == "http")
448 withHttp = strToBool(arg.substring(opt.length + 1, arg.length));
449 else if (opt == "html")
450 withHtml = strToBool(arg.substring(opt.length + 1, arg.length));
451 else if (opt == "c14n")
452 withC14n = strToBool(arg.substring(opt.length + 1, arg.length));
453 else if (opt == "catalog")
454 withCatalog = strToBool(arg.substring(opt.length + 1, arg.length));
455 else if (opt == "docb")
456 withDocb = strToBool(arg.substring(opt.length + 1, arg.length));
457 else if (opt == "xpath")
458 withXpath = strToBool(arg.substring(opt.length + 1, arg.length));
459 else if (opt == "xptr")
460 withXptr = strToBool(arg.substring(opt.length + 1, arg.length));
461 else if (opt == "xinclude")
462 withXinclude = strToBool(arg.substring(opt.length + 1, arg.length));
463 else if (opt == "iconv")
464 withIconv = strToBool(arg.substring(opt.length + 1, arg.length));
465 else if (opt == "iso8859x")
466 withIso8859x = strToBool(arg.substring(opt.length + 1, arg.length));
467 else if (opt == "zlib")
468 withZlib = strToBool(arg.substring(opt.length + 1, arg.length));
469 else if (opt == "xml_debug")
470 withDebug = strToBool(arg.substring(opt.length + 1, arg.length));
471 else if (opt == "mem_debug")
472 withMemDebug = strToBool(arg.substring(opt.length + 1, arg.length));
473 else if (opt == "run_debug")
474 withRunDebug = strToBool(arg.substring(opt.length + 1, arg.length));
475 else if (opt == "schemas")
476 withSchemas = strToBool(arg.substring(opt.length + 1, arg.length));
477 else if (opt == "schematron")
478 withSchematron = strToBool(arg.substring(opt.length + 1, arg.length));
479 else if (opt == "regexps")
480 withRegExps = strToBool(arg.substring(opt.length + 1, arg.length));
481 else if (opt == "modules")
482 withModules = strToBool(arg.substring(opt.length + 1, arg.length));
483 else if (opt == "tree")
484 withTree = strToBool(arg.substring(opt.length + 1, arg.length));
485 else if (opt == "reader")
486 withReader = strToBool(arg.substring(opt.length + 1, arg.length));
487 else if (opt == "writer")
488 withWriter = strToBool(arg.substring(opt.length + 1, arg.length));
489 else if (opt == "walker")
490 withWalker = strToBool(arg.substring(opt.length + 1, arg.length));
491 else if (opt == "pattern")
492 withPattern = strToBool(arg.substring(opt.length + 1, arg.length));
493 else if (opt == "push")
494 withPush = strToBool(arg.substring(opt.length + 1, arg.length));
495 else if (opt == "valid")
496 withValid = strToBool(arg.substring(opt.length + 1, arg.length));
497 else if (opt == "sax1")
498 withSax1 = strToBool(arg.substring(opt.length + 1, arg.length));
499 else if (opt == "legacy")
500 withLegacy = strToBool(arg.substring(opt.length + 1, arg.length));
501 else if (opt == "output")
502 withOutput = strToBool(arg.substring(opt.length + 1, arg.length));
503 else if (opt == "python")
504 withPython = strToBool(arg.substring(opt.length + 1, arg.length));
505 else if (opt == "compiler")
506 compiler = arg.substring(opt.length + 1, arg.length);
507 else if (opt == "cruntime")
508 cruntime = arg.substring(opt.length + 1, arg.length);
509 else if (opt == "dynruntime")
510 dynruntime = strToBool(arg.substring(opt.length + 1, arg.length));
511 else if (opt == "vcmanifest")
512 vcmanifest = strToBool(arg.substring(opt.length + 1, arg.length));
513 else if (opt == "debug")
514 buildDebug = strToBool(arg.substring(opt.length + 1, arg.length));
515 else if (opt == "static")
516 buildStatic = strToBool(arg.substring(opt.length + 1, arg.length));
517 else if (opt == "prefix")
518 buildPrefix = arg.substring(opt.length + 1, arg.length);
519 else if (opt == "incdir")
520 buildIncPrefix = arg.substring(opt.length + 1, arg.length);
521 else if (opt == "bindir")
522 buildBinPrefix = arg.substring(opt.length + 1, arg.length);
523 else if (opt == "libdir")
524 buildLibPrefix = arg.substring(opt.length + 1, arg.length);
525 else if (opt == "sodir")
526 buildSoPrefix = arg.substring(opt.length + 1, arg.length);
527 else if (opt == "incdir")
528 buildIncPrefix = arg.substring(opt.length + 1, arg.length);
529 else if (opt == "include")
530 buildInclude = arg.substring(opt.length + 1, arg.length);
531 else if (opt == "lib")
532 buildLib = arg.substring(opt.length + 1, arg.length);
533 else if (opt == "release")
534 useCvsVer = false;
535 else
536 error = 1;
537 } else if (i == 0) {
538 if (arg == "genreadme") {
539 // This command comes from the Makefile and will not be checked
540 // for errors, because Makefile will always supply right the parameters.
541 genReadme(WScript.Arguments(1), WScript.Arguments(2), WScript.Arguments(3));
542 WScript.Quit(0);
543 } else if (arg == "help") {
544 usage();
545 WScript.Quit(0);
546 }
547
548 } else {
549 error = 1;
550 }
551}
552
553
554// If we fail here, it is because the user supplied an unrecognised argument.
555if (error != 0) {
556 usage();
557 WScript.Quit(error);
558}
559
560// if user choses to link the c-runtime library statically into libxml2
561// with /MT and friends, then we need to enable static linking for xmllint
562if (cruntime == "/MT" || cruntime == "/MTd" ||
563 cruntime == "/ML" || cruntime == "/MLd") {
564 buildStatic = 1;
565}
566
567dirSep = "\\";
568if (buildBinPrefix == "")
569 buildBinPrefix = "$(PREFIX)" + dirSep + "bin";
570if (buildIncPrefix == "")
571 buildIncPrefix = "$(PREFIX)" + dirSep + "include";
572if (buildLibPrefix == "")
573 buildLibPrefix = "$(PREFIX)" + dirSep + "lib";
574if (buildSoPrefix == "")
575 buildSoPrefix = "$(PREFIX)" + dirSep + "lib";
576
577// Discover the version.
578discoverVersion();
579if (error != 0) {
580 WScript.Echo("Version discovery failed, aborting.");
581 WScript.Quit(error);
582}
583
584var outVerString = baseName + " version: " + verMajor + "." + verMinor + "." + verMicro;
585if (verMicroSuffix && verMicroSuffix != "")
586 outVerString += "-" + verMicroSuffix;
587if (verCvs && verCvs != "")
588 outVerString += "-" + verCvs;
589WScript.Echo(outVerString);
590
591// Configure libxml.
592configureLibxml();
593if (error != 0) {
594 WScript.Echo("Configuration failed, aborting.");
595 WScript.Quit(error);
596}
597
598if (withPython == true) {
599 configureLibxmlPy();
600 if (error != 0) {
601 WScript.Echo("Configuration failed, aborting.");
602 WScript.Quit(error);
603 }
604
605}
606
607// Create the makefile.
608var fso = new ActiveXObject("Scripting.FileSystemObject");
609var makefile = ".\\Makefile.msvc";
610if (compiler == "mingw")
611 makefile = ".\\Makefile.mingw";
612else if (compiler == "bcb")
613 makefile = ".\\Makefile.bcb";
614fso.CopyFile(makefile, ".\\Makefile", true);
615WScript.Echo("Created Makefile.");
616// Create the config.h.
617var confighsrc = "..\\include\\win32config.h";
618var configh = "..\\config.h";
619var f = fso.FileExists(configh);
620if (f) {
621 var t = fso.GetFile(configh);
622 t.Attributes =0;
623}
624fso.CopyFile(confighsrc, configh, true);
625WScript.Echo("Created config.h.");
626
627
628// Display the final configuration.
629var txtOut = "\nXML processor configuration\n";
630txtOut += "---------------------------\n";
631txtOut += " Trio: " + boolToStr(withTrio) + "\n";
632txtOut += " Thread safety: " + withThreads + "\n";
633txtOut += " FTP client: " + boolToStr(withFtp) + "\n";
634txtOut += " HTTP client: " + boolToStr(withHttp) + "\n";
635txtOut += " HTML processor: " + boolToStr(withHtml) + "\n";
636txtOut += " C14N support: " + boolToStr(withC14n) + "\n";
637txtOut += " Catalog support: " + boolToStr(withCatalog) + "\n";
638txtOut += " DocBook support: " + boolToStr(withDocb) + "\n";
639txtOut += " XPath support: " + boolToStr(withXpath) + "\n";
640txtOut += " XPointer support: " + boolToStr(withXptr) + "\n";
641txtOut += " XInclude support: " + boolToStr(withXinclude) + "\n";
642txtOut += " iconv support: " + boolToStr(withIconv) + "\n";
643txtOut += " iso8859x support: " + boolToStr(withIso8859x) + "\n";
644txtOut += " zlib support: " + boolToStr(withZlib) + "\n";
645txtOut += " Debugging module: " + boolToStr(withDebug) + "\n";
646txtOut += " Memory debugging: " + boolToStr(withMemDebug) + "\n";
647txtOut += " Runtime debugging: " + boolToStr(withRunDebug) + "\n";
648txtOut += " Regexp support: " + boolToStr(withRegExps) + "\n";
649txtOut += " Module support: " + boolToStr(withModules) + "\n";
650txtOut += " Tree support: " + boolToStr(withTree) + "\n";
651txtOut += " Reader support: " + boolToStr(withReader) + "\n";
652txtOut += " Writer support: " + boolToStr(withWriter) + "\n";
653txtOut += " Walker support: " + boolToStr(withWalker) + "\n";
654txtOut += " Pattern support: " + boolToStr(withPattern) + "\n";
655txtOut += " Push support: " + boolToStr(withPush) + "\n";
656txtOut += "Validation support: " + boolToStr(withValid) + "\n";
657txtOut += " SAX1 support: " + boolToStr(withSax1) + "\n";
658txtOut += " Legacy support: " + boolToStr(withLegacy) + "\n";
659txtOut += " Output support: " + boolToStr(withOutput) + "\n";
660txtOut += "XML Schema support: " + boolToStr(withSchemas) + "\n";
661txtOut += "Schematron support: " + boolToStr(withSchematron) + "\n";
662txtOut += " Python bindings: " + boolToStr(withPython) + "\n";
663txtOut += "\n";
664txtOut += "Win32 build configuration\n";
665txtOut += "-------------------------\n";
666txtOut += " Compiler: " + compiler + "\n";
667if (compiler == "msvc") {
668 txtOut += " C-Runtime option: " + cruntime + "\n";
669 txtOut += " Embed Manifest: " + boolToStr(vcmanifest) + "\n";
670} else if (compiler == "bcb")
671 txtOut += " Use dynamic RTL: " + dynruntime + "\n";
672txtOut += " Debug symbols: " + boolToStr(buildDebug) + "\n";
673txtOut += " Static xmllint: " + boolToStr(buildStatic) + "\n";
674txtOut += " Install prefix: " + buildPrefix + "\n";
675txtOut += " Put tools in: " + buildBinPrefix + "\n";
676txtOut += " Put headers in: " + buildIncPrefix + "\n";
677txtOut += "Put static libs in: " + buildLibPrefix + "\n";
678txtOut += "Put shared libs in: " + buildSoPrefix + "\n";
679txtOut += " Include path: " + buildInclude + "\n";
680txtOut += " Lib path: " + buildLib + "\n";
681WScript.Echo(txtOut);
682
683//
684
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette