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