comparison src/share/tools/MakeDeps/BuildConfig.java @ 0:a61af66fc99e jdk7-b24

Initial load
author duke
date Sat, 01 Dec 2007 00:00:00 +0000
parents
children 82e4d969e7cb
comparison
equal deleted inserted replaced
-1:000000000000 0:a61af66fc99e
1 /*
2 * Copyright 2005-2006 Sun Microsystems, Inc. All Rights Reserved.
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 *
5 * This code is free software; you can redistribute it and/or modify it
6 * under the terms of the GNU General Public License version 2 only, as
7 * published by the Free Software Foundation.
8 *
9 * This code is distributed in the hope that it will be useful, but WITHOUT
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
12 * version 2 for more details (a copy is included in the LICENSE file that
13 * accompanied this code).
14 *
15 * You should have received a copy of the GNU General Public License version
16 * 2 along with this work; if not, write to the Free Software Foundation,
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18 *
19 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
20 * CA 95054 USA or visit www.sun.com if you need additional information or
21 * have any questions.
22 *
23 */
24
25 import java.util.*;
26 import java.io.File;
27
28 class BuildConfig {
29 Hashtable vars;
30 Vector basicNames, basicPaths;
31 String[] context;
32
33 static CompilerInterface ci;
34 static CompilerInterface getCI() {
35 if (ci == null) {
36 String comp = (String)getField(null, "CompilerVersion");
37 try {
38 ci = (CompilerInterface)Class.forName("CompilerInterface" + comp).newInstance();
39 } catch (Exception cnfe) {
40 System.err.println("Cannot find support for compiler " + comp);
41 throw new RuntimeException(cnfe.toString());
42 }
43 }
44 return ci;
45 }
46
47 protected void initNames(String flavour, String build, String outDll) {
48 if (vars == null) vars = new Hashtable();
49
50 String flavourBuild = flavour + "_" + build;
51 put("Name", getCI().makeCfgName(flavourBuild));
52 put("Flavour", flavour);
53 put("Build", build);
54
55 // ones mentioned above were needed to expand format
56 String buildBase = expandFormat(getFieldString(null, "BuildBase"));
57 String jdkDir = getFieldString(null, "JdkTargetRoot");
58 String sourceBase = getFieldString(null, "SourceBase");
59 String outDir = buildBase;
60
61 put("Id", flavourBuild);
62 put("OutputDir", outDir);
63 put("SourceBase", sourceBase);
64 put("BuildBase", buildBase);
65 put("OutputDll", jdkDir + Util.sep + outDll);
66
67 context = new String [] {flavourBuild, flavour, build, null};
68 }
69
70 protected void init(Vector includes, Vector defines) {
71 initDefaultDefines(defines);
72 initDefaultCompilerFlags(includes);
73 initDefaultLinkerFlags();
74 handleDB((String)getFieldInContext("IncludeDB"));
75 }
76
77
78 protected void initDefaultCompilerFlags(Vector includes) {
79 Vector compilerFlags = new Vector();
80
81 compilerFlags.addAll(getCI().getBaseCompilerFlags(getV("Define"),
82 includes,
83 get("OutputDir")));
84
85 put("CompilerFlags", compilerFlags);
86 }
87
88 protected void initDefaultLinkerFlags() {
89 Vector linkerFlags = new Vector();
90
91 linkerFlags.addAll(getCI().getBaseLinkerFlags( get("OutputDir"), get("OutputDll")));
92
93 put("LinkerFlags", linkerFlags);
94 }
95
96 DirectoryTree getSourceTree(String sourceBase, String startAt) {
97 DirectoryTree tree = new DirectoryTree();
98
99 tree.addSubdirToIgnore("Codemgr_wsdata");
100 tree.addSubdirToIgnore("deleted_files");
101 tree.addSubdirToIgnore("SCCS");
102 tree.setVerbose(true);
103 if (startAt != null) {
104 tree.readDirectory(sourceBase + File.separator + startAt);
105 } else {
106 tree.readDirectory(sourceBase);
107 }
108
109 return tree;
110 }
111
112
113 Vector getPreferredPaths(Database currentDB) {
114 Vector preferredPaths = new Vector();
115 // In the case of multiple files with the same name in
116 // different subdirectories, prefer the versions specified in
117 // the platform file as the "os_family" and "arch" macros.
118 for (Iterator iter = currentDB.getMacros(); iter.hasNext(); ) {
119 Macro macro = (Macro) iter.next();
120 if (macro.name.equals("os_family") ||
121 macro.name.equals("arch")) {
122 preferredPaths.add(macro.contents);
123 }
124 }
125 // Also prefer "opto" over "adlc" for adlcVMDeps.hpp
126 preferredPaths.add("opto");
127
128 return preferredPaths;
129 }
130
131
132 void handleDB(String dbFile) {
133 WinGammaPlatform platform = (WinGammaPlatform)getField(null, "PlatformObject");
134 Database db = new Database(platform, platform.defaultGrandIncludeThreshold());
135
136 try {
137 File incls = new File(get("OutputDir")+Util.sep+"incls");
138 FileName oldInclTempl = platform.getInclFileTemplate();
139 FileName oldGITempl = platform.getGIFileTemplate();
140 FileName oldGDTempl = platform.getGDFileTemplate();
141
142 platform.setInclFileTemplate(new FileName(platform, incls.getPath()+Util.sep,
143 "_", "", ".incl", "", ""));
144 platform.setGIFileTemplate(new FileName(platform, incls.getPath()+Util.sep,
145 "", "_precompiled", ".incl", "", ""));
146
147 incls.mkdirs();
148
149 db.get(getFieldString(null, "Platform"), dbFile);
150 db.compute();
151
152 db.put();
153
154 //platform.setInclFileTemplate(oldInclTempl);
155 //platform.setGIFileTemplate(oldInclTempl);
156 } catch (Exception e) {
157 e.printStackTrace();
158 throw new RuntimeException("cannot do db: "+e);
159 }
160
161 putSpecificField("AllFilesHash", computeAllFiles(platform, db));
162 }
163
164
165 void addAll(Iterator i, Hashtable hash,
166 WinGammaPlatform platform, DirectoryTree tree,
167 Vector preferredPaths, Vector filesNotFound, Vector filesDuplicate) {
168 for (; i.hasNext(); ) {
169 String fileName = (String) i.next();
170 if (lookupHashFieldInContext("IgnoreFile", fileName) == null) {
171 String prefixedName = platform.envVarPrefixedFileName(fileName,
172 0, /* ignored */
173 tree,
174 preferredPaths,
175 filesNotFound,
176 filesDuplicate);
177 if (prefixedName != null) {
178 addTo(hash, Util.normalize(prefixedName), fileName);
179 }
180 }
181 }
182 }
183
184 void addTo(Hashtable ht, String key, String value) {
185 ht.put(expandFormat(key), expandFormat(value));
186 }
187
188 Hashtable computeAllFiles(WinGammaPlatform platform, Database db) {
189 Hashtable rv = new Hashtable();
190 DirectoryTree tree = getSourceTree(get("SourceBase"), getFieldString(null, "StartAt"));
191 Vector preferredPaths = getPreferredPaths(db);
192
193 // Hold errors until end
194 Vector filesNotFound = new Vector();
195 Vector filesDuplicate = new Vector();
196
197
198 // find all files
199 Vector dbFiles = new Vector();
200 for (Iterator i=db.getAllFiles().iterator(); i.hasNext(); ) {
201 FileList fl = (FileList) i.next();
202 dbFiles.add(fl.getName());
203 }
204 addAll(dbFiles.iterator(), rv,
205 platform, tree,
206 preferredPaths, filesNotFound, filesDuplicate);
207
208 Vector addFiles = new Vector();
209 collectRelevantVectors(addFiles, "AdditionalFile");
210 addAll(addFiles.iterator(), rv,
211 platform, tree,
212 preferredPaths, filesNotFound, filesDuplicate);
213
214 collectRelevantHashes(rv, "AdditionalGeneratedFile");
215
216 if ((filesNotFound.size() != 0) ||
217 (filesDuplicate.size() != 0)) {
218 System.err.println("Error: some files were not found or " +
219 "appeared in multiple subdirectories of " +
220 "directory " + get("SourceBase") + " and could not " +
221 "be resolved with the os_family and arch " +
222 "macros in the platform file.");
223 if (filesNotFound.size() != 0) {
224 System.err.println("Files not found:");
225 for (Iterator iter = filesNotFound.iterator();
226 iter.hasNext(); ) {
227 System.err.println(" " + (String) iter.next());
228 }
229 }
230 if (filesDuplicate.size() != 0) {
231 System.err.println("Duplicate files:");
232 for (Iterator iter = filesDuplicate.iterator();
233 iter.hasNext(); ) {
234 System.err.println(" " + (String) iter.next());
235 }
236 }
237 throw new RuntimeException();
238 }
239
240 return rv;
241 }
242
243 void initDefaultDefines(Vector defines) {
244 Vector sysDefines = new Vector();
245 sysDefines.add("WIN32");
246 sysDefines.add("_WINDOWS");
247 sysDefines.add("HOTSPOT_BUILD_USER="+System.getProperty("user.name"));
248 sysDefines.add("HOTSPOT_BUILD_TARGET=\\\""+get("Build")+"\\\"");
249 sysDefines.add("_JNI_IMPLEMENTATION_");
250
251 sysDefines.addAll(defines);
252
253 put("Define", sysDefines);
254 }
255
256 String get(String key) {
257 return (String)vars.get(key);
258 }
259
260 Vector getV(String key) {
261 return (Vector)vars.get(key);
262 }
263
264 Object getO(String key) {
265 return vars.get(key);
266 }
267
268 Hashtable getH(String key) {
269 return (Hashtable)vars.get(key);
270 }
271
272 Object getFieldInContext(String field) {
273 for (int i=0; i<context.length; i++) {
274 Object rv = getField(context[i], field);
275 if (rv != null) {
276 return rv;
277 }
278 }
279 return null;
280 }
281
282 Object lookupHashFieldInContext(String field, String key) {
283 for (int i=0; i<context.length; i++) {
284 Hashtable ht = (Hashtable)getField(context[i], field);
285 if (ht != null) {
286 Object rv = ht.get(key);
287 if (rv != null) {
288 return rv;
289 }
290 }
291 }
292 return null;
293 }
294
295 void put(String key, String value) {
296 vars.put(key, value);
297 }
298
299 void put(String key, Vector vvalue) {
300 vars.put(key, vvalue);
301 }
302
303 void add(String key, Vector vvalue) {
304 getV(key).addAll(vvalue);
305 }
306
307 String flavour() {
308 return get("Flavour");
309 }
310
311 String build() {
312 return get("Build");
313 }
314
315 Object getSpecificField(String field) {
316 return getField(get("Id"), field);
317 }
318
319 void putSpecificField(String field, Object value) {
320 putField(get("Id"), field, value);
321 }
322
323 void collectRelevantVectors(Vector rv, String field) {
324 for (int i = 0; i < context.length; i++) {
325 Vector v = getFieldVector(context[i], field);
326 if (v != null) {
327 for (Iterator j=v.iterator(); j.hasNext(); ) {
328 String val = (String)j.next();
329 rv.add(expandFormat(val));
330 }
331 }
332 }
333 }
334
335 void collectRelevantHashes(Hashtable rv, String field) {
336 for (int i = 0; i < context.length; i++) {
337 Hashtable v = (Hashtable)getField(context[i], field);
338 if (v != null) {
339 for (Enumeration e=v.keys(); e.hasMoreElements(); ) {
340 String key = (String)e.nextElement();
341 String val = (String)v.get(key);
342 addTo(rv, key, val);
343 }
344 }
345 }
346 }
347
348
349 Vector getDefines() {
350 Vector rv = new Vector();
351 collectRelevantVectors(rv, "Define");
352 return rv;
353 }
354
355 Vector getIncludes() {
356 Vector rv = new Vector();
357
358 // for generated includes
359 rv.add(get("OutputDir"));
360
361 collectRelevantVectors(rv, "AbsoluteInclude");
362
363 Vector ri = new Vector();
364 String sourceBase = getFieldString(null, "SourceBase");
365 collectRelevantVectors(ri, "RelativeInclude");
366 for (Iterator i = ri.iterator(); i.hasNext(); ) {
367 String f = (String)i.next();
368 rv.add(sourceBase + Util.sep + f);
369 }
370
371 return rv;
372 }
373
374 static Hashtable cfgData = new Hashtable();
375 static Hashtable globalData = new Hashtable();
376
377 static boolean appliesToTieredBuild(String cfg) {
378 return (cfg != null &&
379 (cfg.startsWith("compiler1") ||
380 cfg.startsWith("compiler2")));
381 }
382
383 // Filters out the IncludeDB statement, which is the only command-
384 // line argument we explicitly specialize for the tiered build
385 static boolean appliesToTieredBuild(String cfg, String key) {
386 return (appliesToTieredBuild(cfg) &&
387 (key != null &&
388 !key.equals("IncludeDB")));
389 }
390
391 static String getTieredBuildCfg(String cfg) {
392 assert appliesToTieredBuild(cfg) : "illegal configuration " + cfg;
393 return "tiered" + cfg.substring(9);
394 }
395
396 static Object getField(String cfg, String field) {
397 if (cfg == null) {
398 return globalData.get(field);
399 }
400
401 Hashtable ht = (Hashtable)cfgData.get(cfg);
402 return ht == null ? null : ht.get(field);
403 }
404
405 static String getFieldString(String cfg, String field) {
406 return (String)getField(cfg, field);
407 }
408
409 static Vector getFieldVector(String cfg, String field) {
410 return (Vector)getField(cfg, field);
411 }
412
413 static void putField(String cfg, String field, Object value) {
414 putFieldImpl(cfg, field, value);
415 if (appliesToTieredBuild(cfg, field)) {
416 putFieldImpl(getTieredBuildCfg(cfg), field, value);
417 }
418 }
419
420 private static void putFieldImpl(String cfg, String field, Object value) {
421 if (cfg == null) {
422 globalData.put(field, value);
423 return;
424 }
425
426 Hashtable ht = (Hashtable)cfgData.get(cfg);
427 if (ht == null) {
428 ht = new Hashtable();
429 cfgData.put(cfg, ht);
430 }
431
432 ht.put(field, value);
433 }
434
435 static Object getFieldHash(String cfg, String field, String name) {
436 Hashtable ht = (Hashtable)getField(cfg, field);
437
438 return ht == null ? null : ht.get(name);
439 }
440
441 static void putFieldHash(String cfg, String field, String name, Object val) {
442 putFieldHashImpl(cfg, field, name, val);
443 if (appliesToTieredBuild(cfg)) {
444 putFieldHashImpl(getTieredBuildCfg(cfg), field, name, val);
445 }
446 }
447
448 private static void putFieldHashImpl(String cfg, String field, String name, Object val) {
449 Hashtable ht = (Hashtable)getField(cfg, field);
450
451 if (ht == null) {
452 ht = new Hashtable();
453 putFieldImpl(cfg, field, ht);
454 }
455
456 ht.put(name, val);
457 }
458
459 static void addFieldVector(String cfg, String field, String element) {
460 addFieldVectorImpl(cfg, field, element);
461 if (appliesToTieredBuild(cfg)) {
462 addFieldVectorImpl(getTieredBuildCfg(cfg), field, element);
463 }
464 }
465
466 private static void addFieldVectorImpl(String cfg, String field, String element) {
467 Vector v = (Vector)getField(cfg, field);
468
469 if (v == null) {
470 v = new Vector();
471 putFieldImpl(cfg, field, v);
472 }
473
474 v.add(element);
475 }
476
477 String expandFormat(String format) {
478 if (format == null) {
479 return null;
480 }
481
482 if (format.indexOf('%') == -1) {
483 return format;
484 }
485
486 StringBuffer sb = new StringBuffer();
487 int len = format.length();
488 for (int i=0; i<len; i++) {
489 char ch = format.charAt(i);
490 if (ch == '%') {
491 char ch1 = format.charAt(i+1);
492 switch (ch1) {
493 case '%':
494 sb.append(ch1);
495 break;
496 case 'b':
497 sb.append(build());
498 break;
499 case 'f':
500 sb.append(flavour());
501 break;
502 default:
503 sb.append(ch);
504 sb.append(ch1);
505 }
506 i++;
507 } else {
508 sb.append(ch);
509 }
510 }
511
512 return sb.toString();
513 }
514 }
515
516 abstract class GenericDebugConfig extends BuildConfig {
517 abstract String getOptFlag();
518
519 protected void init(Vector includes, Vector defines) {
520 defines.add("_DEBUG");
521 defines.add("ASSERT");
522
523 super.init(includes, defines);
524
525 getV("CompilerFlags").addAll(getCI().getDebugCompilerFlags(getOptFlag()));
526 getV("LinkerFlags").addAll(getCI().getDebugLinkerFlags());
527 }
528 }
529
530 class C1DebugConfig extends GenericDebugConfig {
531 String getOptFlag() {
532 return getCI().getNoOptFlag();
533 }
534
535 C1DebugConfig() {
536 initNames("compiler1", "debug", "fastdebug\\jre\\bin\\client\\jvm.dll");
537 init(getIncludes(), getDefines());
538 }
539 }
540
541 class C1FastDebugConfig extends GenericDebugConfig {
542 String getOptFlag() {
543 return getCI().getOptFlag();
544 }
545
546 C1FastDebugConfig() {
547 initNames("compiler1", "fastdebug", "fastdebug\\jre\\bin\\client\\jvm.dll");
548 init(getIncludes(), getDefines());
549 }
550 }
551
552 class C2DebugConfig extends GenericDebugConfig {
553 String getOptFlag() {
554 return getCI().getNoOptFlag();
555 }
556
557 C2DebugConfig() {
558 initNames("compiler2", "debug", "fastdebug\\jre\\bin\\server\\jvm.dll");
559 init(getIncludes(), getDefines());
560 }
561 }
562
563 class C2FastDebugConfig extends GenericDebugConfig {
564 String getOptFlag() {
565 return getCI().getOptFlag();
566 }
567
568 C2FastDebugConfig() {
569 initNames("compiler2", "fastdebug", "fastdebug\\jre\\bin\\server\\jvm.dll");
570 init(getIncludes(), getDefines());
571 }
572 }
573
574 class TieredDebugConfig extends GenericDebugConfig {
575 String getOptFlag() {
576 return getCI().getNoOptFlag();
577 }
578
579 TieredDebugConfig() {
580 initNames("tiered", "debug", "fastdebug\\jre\\bin\\server\\jvm.dll");
581 init(getIncludes(), getDefines());
582 }
583 }
584
585 class TieredFastDebugConfig extends GenericDebugConfig {
586 String getOptFlag() {
587 return getCI().getOptFlag();
588 }
589
590 TieredFastDebugConfig() {
591 initNames("tiered", "fastdebug", "fastdebug\\jre\\bin\\server\\jvm.dll");
592 init(getIncludes(), getDefines());
593 }
594 }
595
596
597 abstract class ProductConfig extends BuildConfig {
598 protected void init(Vector includes, Vector defines) {
599 defines.add("NDEBUG");
600 defines.add("PRODUCT");
601
602 super.init(includes, defines);
603
604 getV("CompilerFlags").addAll(getCI().getProductCompilerFlags());
605 getV("LinkerFlags").addAll(getCI().getProductLinkerFlags());
606 }
607 }
608
609 class C1ProductConfig extends ProductConfig {
610 C1ProductConfig() {
611 initNames("compiler1", "product", "jre\\bin\\client\\jvm.dll");
612 init(getIncludes(), getDefines());
613 }
614 }
615
616 class C2ProductConfig extends ProductConfig {
617 C2ProductConfig() {
618 initNames("compiler2", "product", "jre\\bin\\server\\jvm.dll");
619 init(getIncludes(), getDefines());
620 }
621 }
622
623 class TieredProductConfig extends ProductConfig {
624 TieredProductConfig() {
625 initNames("tiered", "product", "jre\\bin\\server\\jvm.dll");
626 init(getIncludes(), getDefines());
627 }
628 }
629
630
631 class CoreDebugConfig extends GenericDebugConfig {
632 String getOptFlag() {
633 return getCI().getNoOptFlag();
634 }
635
636 CoreDebugConfig() {
637 initNames("core", "debug", "fastdebug\\jre\\bin\\core\\jvm.dll");
638 init(getIncludes(), getDefines());
639 }
640 }
641
642
643 class CoreFastDebugConfig extends GenericDebugConfig {
644 String getOptFlag() {
645 return getCI().getOptFlag();
646 }
647
648 CoreFastDebugConfig() {
649 initNames("core", "fastdebug", "fastdebug\\jre\\bin\\core\\jvm.dll");
650 init(getIncludes(), getDefines());
651 }
652 }
653
654
655 class CoreProductConfig extends ProductConfig {
656 CoreProductConfig() {
657 initNames("core", "product", "jre\\bin\\core\\jvm.dll");
658 init(getIncludes(), getDefines());
659 }
660 }
661
662 class KernelDebugConfig extends GenericDebugConfig {
663 String getOptFlag() {
664 return getCI().getNoOptFlag();
665 }
666
667 KernelDebugConfig() {
668 initNames("kernel", "debug", "fastdebug\\jre\\bin\\kernel\\jvm.dll");
669 init(getIncludes(), getDefines());
670 }
671 }
672
673
674 class KernelFastDebugConfig extends GenericDebugConfig {
675 String getOptFlag() {
676 return getCI().getOptFlag();
677 }
678
679 KernelFastDebugConfig() {
680 initNames("kernel", "fastdebug", "fastdebug\\jre\\bin\\kernel\\jvm.dll");
681 init(getIncludes(), getDefines());
682 }
683 }
684
685
686 class KernelProductConfig extends ProductConfig {
687 KernelProductConfig() {
688 initNames("kernel", "product", "jre\\bin\\kernel\\jvm.dll");
689 init(getIncludes(), getDefines());
690 }
691 }
692 abstract class CompilerInterface {
693 abstract Vector getBaseCompilerFlags(Vector defines, Vector includes, String outDir);
694 abstract Vector getBaseLinkerFlags(String outDir, String outDll);
695 abstract Vector getDebugCompilerFlags(String opt);
696 abstract Vector getDebugLinkerFlags();
697 abstract Vector getProductCompilerFlags();
698 abstract Vector getProductLinkerFlags();
699 abstract String getOptFlag();
700 abstract String getNoOptFlag();
701 abstract String makeCfgName(String flavourBuild);
702
703 void addAttr(Vector receiver, String attr, String value) {
704 receiver.add(attr); receiver.add(value);
705 }
706 }