Thu, 27 May 2010 19:08:38 -0700
6941466: Oracle rebranding changes for Hotspot repositories
Summary: Change all the Sun copyrights to Oracle copyright
Reviewed-by: ohair
duke@435 | 1 | /* |
trims@1907 | 2 | * Copyright (c) 1999, 2007, 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.*; |
duke@435 | 26 | import java.util.*; |
duke@435 | 27 | |
duke@435 | 28 | abstract class HsArgHandler extends ArgHandler { |
duke@435 | 29 | static final int STRING = 1; |
duke@435 | 30 | static final int VECTOR = 2; |
duke@435 | 31 | static final int HASH = 3; |
duke@435 | 32 | |
duke@435 | 33 | boolean nextNotKey(ArgIterator it) { |
duke@435 | 34 | if (it.next()) { |
duke@435 | 35 | String s = it.get(); |
duke@435 | 36 | return (s.length() == 0) || (s.charAt(0) != '-'); |
duke@435 | 37 | } else { |
duke@435 | 38 | return false; |
duke@435 | 39 | } |
duke@435 | 40 | } |
duke@435 | 41 | |
duke@435 | 42 | void empty(String key, String message) { |
duke@435 | 43 | if (key != null) { |
duke@435 | 44 | System.err.println("** Error: empty " + key); |
duke@435 | 45 | } |
duke@435 | 46 | if (message != null) { |
duke@435 | 47 | System.err.println(message); |
duke@435 | 48 | } |
duke@435 | 49 | WinGammaPlatform.usage(); |
duke@435 | 50 | } |
duke@435 | 51 | |
duke@435 | 52 | static String getCfg(String val) { |
duke@435 | 53 | int under = val.indexOf('_'); |
duke@435 | 54 | int len = val.length(); |
duke@435 | 55 | if (under != -1 && under < len - 1) { |
duke@435 | 56 | return val.substring(under+1, len); |
duke@435 | 57 | } else { |
duke@435 | 58 | return null; |
duke@435 | 59 | } |
duke@435 | 60 | } |
duke@435 | 61 | } |
duke@435 | 62 | |
duke@435 | 63 | class ArgRuleSpecific extends ArgRule { |
duke@435 | 64 | ArgRuleSpecific(String arg, ArgHandler handler) { |
duke@435 | 65 | super(arg, handler); |
duke@435 | 66 | } |
duke@435 | 67 | |
duke@435 | 68 | boolean match(String rulePattern, String arg) { |
duke@435 | 69 | return rulePattern.startsWith(arg); |
duke@435 | 70 | } |
duke@435 | 71 | } |
duke@435 | 72 | |
duke@435 | 73 | |
duke@435 | 74 | class SpecificHsArgHandler extends HsArgHandler { |
duke@435 | 75 | |
duke@435 | 76 | String message, argKey, valKey; |
duke@435 | 77 | int type; |
duke@435 | 78 | |
duke@435 | 79 | public void handle(ArgIterator it) { |
duke@435 | 80 | String cfg = getCfg(it.get()); |
duke@435 | 81 | if (nextNotKey(it)) { |
duke@435 | 82 | String val = it.get(); |
duke@435 | 83 | switch (type) { |
duke@435 | 84 | case VECTOR: |
duke@435 | 85 | BuildConfig.addFieldVector(cfg, valKey, val); |
duke@435 | 86 | break; |
duke@435 | 87 | case HASH: |
duke@435 | 88 | BuildConfig.putFieldHash(cfg, valKey, val, "1"); |
duke@435 | 89 | break; |
duke@435 | 90 | case STRING: |
duke@435 | 91 | BuildConfig.putField(cfg, valKey, val); |
duke@435 | 92 | break; |
duke@435 | 93 | default: |
duke@435 | 94 | empty(valKey, "Unknown type: "+type); |
duke@435 | 95 | } |
duke@435 | 96 | it.next(); |
duke@435 | 97 | |
duke@435 | 98 | } else { |
duke@435 | 99 | empty(argKey, message); |
duke@435 | 100 | } |
duke@435 | 101 | } |
duke@435 | 102 | |
duke@435 | 103 | SpecificHsArgHandler(String argKey, String valKey, String message, int type) { |
duke@435 | 104 | this.argKey = argKey; |
duke@435 | 105 | this.valKey = valKey; |
duke@435 | 106 | this.message = message; |
duke@435 | 107 | this.type = type; |
duke@435 | 108 | } |
duke@435 | 109 | } |
duke@435 | 110 | |
duke@435 | 111 | |
duke@435 | 112 | class HsArgRule extends ArgRuleSpecific { |
duke@435 | 113 | |
duke@435 | 114 | HsArgRule(String argKey, String valKey, String message, int type) { |
duke@435 | 115 | super(argKey, new SpecificHsArgHandler(argKey, valKey, message, type)); |
duke@435 | 116 | } |
duke@435 | 117 | |
duke@435 | 118 | } |
duke@435 | 119 | |
duke@435 | 120 | public abstract class WinGammaPlatform extends Platform { |
duke@435 | 121 | public void setupFileTemplates() { |
duke@435 | 122 | inclFileTemplate = new FileName(this, |
duke@435 | 123 | "incls\\", "_", "", ".incl", "", "" |
duke@435 | 124 | ); |
duke@435 | 125 | giFileTemplate = new FileName(this, |
duke@435 | 126 | "incls\\", "", "_precompiled", ".incl", "", "" |
duke@435 | 127 | ); |
duke@435 | 128 | gdFileTemplate = new FileName(this, |
duke@435 | 129 | "", "", "Dependencies", "", "", "" |
duke@435 | 130 | ); |
duke@435 | 131 | } |
duke@435 | 132 | |
duke@435 | 133 | private static String[] suffixes = { ".cpp", ".c" }; |
duke@435 | 134 | |
duke@435 | 135 | public String[] outerSuffixes() { |
duke@435 | 136 | return suffixes; |
duke@435 | 137 | } |
duke@435 | 138 | |
duke@435 | 139 | public String objFileSuffix() { |
duke@435 | 140 | return ".obj"; |
duke@435 | 141 | } |
duke@435 | 142 | |
duke@435 | 143 | public String asmFileSuffix() { |
duke@435 | 144 | return ".i"; |
duke@435 | 145 | } |
duke@435 | 146 | |
duke@435 | 147 | public String dependentPrefix() { |
duke@435 | 148 | return "$(VM_PATH)"; |
duke@435 | 149 | } |
duke@435 | 150 | |
duke@435 | 151 | public boolean includeGIInEachIncl() { |
duke@435 | 152 | return false; |
duke@435 | 153 | } |
duke@435 | 154 | |
duke@435 | 155 | public boolean fileNameStringEquality(String s1, String s2) { |
duke@435 | 156 | return s1.equalsIgnoreCase(s2); |
duke@435 | 157 | } |
duke@435 | 158 | |
duke@435 | 159 | static void usage() throws IllegalArgumentException { |
duke@435 | 160 | System.err.println("WinGammaPlatform platform-specific options:"); |
duke@435 | 161 | System.err.println(" -sourceBase <path to directory (workspace) " + |
duke@435 | 162 | "containing source files; no trailing slash>"); |
duke@435 | 163 | System.err.println(" -projectFileName <full pathname to which project file " + |
duke@435 | 164 | "will be written; all parent directories must " + |
duke@435 | 165 | "already exist>"); |
duke@435 | 166 | System.err.println(" If any of the above are specified, "+ |
duke@435 | 167 | "they must all be."); |
duke@435 | 168 | System.err.println(" Additional, optional arguments, which can be " + |
duke@435 | 169 | "specified multiple times:"); |
duke@435 | 170 | System.err.println(" -absoluteInclude <string containing absolute " + |
duke@435 | 171 | "path to include directory>"); |
duke@435 | 172 | System.err.println(" -relativeInclude <string containing include " + |
duke@435 | 173 | "directory relative to -sourceBase>"); |
duke@435 | 174 | System.err.println(" -define <preprocessor flag to be #defined " + |
duke@435 | 175 | "(note: doesn't yet support " + |
duke@435 | 176 | "#define (flag) (value))>"); |
duke@435 | 177 | System.err.println(" -startAt <subdir of sourceBase>"); |
duke@435 | 178 | System.err.println(" -additionalFile <file not in database but " + |
duke@435 | 179 | "which should show up in project file, like " + |
duke@435 | 180 | "includeDB_core>"); |
duke@435 | 181 | System.err.println(" -additionalGeneratedFile <absolute path to " + |
duke@435 | 182 | "directory containing file; no trailing slash> " + |
duke@435 | 183 | "<name of file generated later in the build process>"); |
duke@435 | 184 | throw new IllegalArgumentException(); |
duke@435 | 185 | } |
duke@435 | 186 | |
duke@435 | 187 | |
duke@435 | 188 | public void addPerFileLine(Hashtable table, |
duke@435 | 189 | String fileName, |
duke@435 | 190 | String line) { |
duke@435 | 191 | Vector v = (Vector) table.get(fileName); |
duke@435 | 192 | if (v != null) { |
duke@435 | 193 | v.add(line); |
duke@435 | 194 | } else { |
duke@435 | 195 | v = new Vector(); |
duke@435 | 196 | v.add(line); |
duke@435 | 197 | table.put(fileName, v); |
duke@435 | 198 | } |
duke@435 | 199 | } |
duke@435 | 200 | |
duke@435 | 201 | protected static class PerFileCondData { |
duke@435 | 202 | public String releaseString; |
duke@435 | 203 | public String debugString; |
duke@435 | 204 | } |
duke@435 | 205 | |
duke@435 | 206 | protected void addConditionalPerFileLine(Hashtable table, |
duke@435 | 207 | String fileName, |
duke@435 | 208 | String releaseLine, |
duke@435 | 209 | String debugLine) { |
duke@435 | 210 | PerFileCondData data = new PerFileCondData(); |
duke@435 | 211 | data.releaseString = releaseLine; |
duke@435 | 212 | data.debugString = debugLine; |
duke@435 | 213 | Vector v = (Vector) table.get(fileName); |
duke@435 | 214 | if (v != null) { |
duke@435 | 215 | v.add(data); |
duke@435 | 216 | } else { |
duke@435 | 217 | v = new Vector(); |
duke@435 | 218 | v.add(data); |
duke@435 | 219 | table.put(fileName, v); |
duke@435 | 220 | } |
duke@435 | 221 | } |
duke@435 | 222 | |
duke@435 | 223 | protected static class PrelinkCommandData { |
duke@435 | 224 | String description; |
duke@435 | 225 | String commands; |
duke@435 | 226 | } |
duke@435 | 227 | |
duke@435 | 228 | protected void addPrelinkCommand(Hashtable table, |
duke@435 | 229 | String build, |
duke@435 | 230 | String description, |
duke@435 | 231 | String commands) { |
duke@435 | 232 | PrelinkCommandData data = new PrelinkCommandData(); |
duke@435 | 233 | data.description = description; |
duke@435 | 234 | data.commands = commands; |
duke@435 | 235 | table.put(build, data); |
duke@435 | 236 | } |
duke@435 | 237 | |
duke@435 | 238 | public boolean findString(Vector v, String s) { |
duke@435 | 239 | for (Iterator iter = v.iterator(); iter.hasNext(); ) { |
duke@435 | 240 | if (((String) iter.next()).equals(s)) { |
duke@435 | 241 | return true; |
duke@435 | 242 | } |
duke@435 | 243 | } |
duke@435 | 244 | |
duke@435 | 245 | return false; |
duke@435 | 246 | } |
duke@435 | 247 | |
duke@435 | 248 | /* This returns a String containing the full path to the passed |
duke@435 | 249 | file name, or null if an error occurred. If the file was not |
duke@435 | 250 | found or was a duplicate and couldn't be resolved using the |
duke@435 | 251 | preferred paths, the file name is added to the appropriate |
duke@435 | 252 | Vector of Strings. */ |
duke@435 | 253 | private String findFileInDirectory(String fileName, |
duke@435 | 254 | DirectoryTree directory, |
duke@435 | 255 | Vector preferredPaths, |
duke@435 | 256 | Vector filesNotFound, |
duke@435 | 257 | Vector filesDuplicate) { |
duke@435 | 258 | List locationsInTree = directory.findFile(fileName); |
duke@435 | 259 | int rootNameLength = directory.getRootNodeName().length(); |
duke@435 | 260 | String name = null; |
duke@435 | 261 | if ((locationsInTree == null) || |
duke@435 | 262 | (locationsInTree.size() == 0)) { |
duke@435 | 263 | filesNotFound.add(fileName); |
duke@435 | 264 | } else if (locationsInTree.size() > 1) { |
duke@435 | 265 | // We shouldn't have duplicate file names in our workspace. |
duke@435 | 266 | System.err.println(); |
duke@435 | 267 | System.err.println("There are multiple files named as: " + fileName); |
duke@435 | 268 | System.exit(-1); |
duke@435 | 269 | // The following code could be safely removed if we don't need duplicate |
duke@435 | 270 | // file names. |
duke@435 | 271 | |
duke@435 | 272 | // Iterate through them, trying to find one with a |
duke@435 | 273 | // preferred path |
duke@435 | 274 | search: |
duke@435 | 275 | { |
duke@435 | 276 | for (Iterator locIter = locationsInTree.iterator(); |
duke@435 | 277 | locIter.hasNext(); ) { |
duke@435 | 278 | DirectoryTreeNode node = |
duke@435 | 279 | (DirectoryTreeNode) locIter.next(); |
duke@435 | 280 | String tmpName = node.getName(); |
duke@435 | 281 | for (Iterator prefIter = preferredPaths.iterator(); |
duke@435 | 282 | prefIter.hasNext(); ) { |
duke@435 | 283 | // We need to make sure the preferred path is |
duke@435 | 284 | // found from the file path not including the root node name. |
duke@435 | 285 | if (tmpName.indexOf((String)prefIter.next(), |
duke@435 | 286 | rootNameLength) != -1) { |
duke@435 | 287 | name = tmpName; |
duke@435 | 288 | break search; |
duke@435 | 289 | } |
duke@435 | 290 | } |
duke@435 | 291 | } |
duke@435 | 292 | } |
duke@435 | 293 | |
duke@435 | 294 | if (name == null) { |
duke@435 | 295 | filesDuplicate.add(fileName); |
duke@435 | 296 | } |
duke@435 | 297 | } else { |
duke@435 | 298 | name = ((DirectoryTreeNode) locationsInTree.get(0)).getName(); |
duke@435 | 299 | } |
duke@435 | 300 | |
duke@435 | 301 | return name; |
duke@435 | 302 | } |
duke@435 | 303 | |
duke@435 | 304 | protected boolean databaseAllFilesEqual(Database previousDB, |
duke@435 | 305 | Database currentDB) { |
duke@435 | 306 | Iterator i1 = previousDB.getAllFiles().iterator(); |
duke@435 | 307 | Iterator i2 = currentDB.getAllFiles().iterator(); |
duke@435 | 308 | |
duke@435 | 309 | while (i1.hasNext() && i2.hasNext()) { |
duke@435 | 310 | FileList fl1 = (FileList) i1.next(); |
duke@435 | 311 | FileList fl2 = (FileList) i2.next(); |
duke@435 | 312 | if (!fl1.getName().equals(fl2.getName())) { |
duke@435 | 313 | return false; |
duke@435 | 314 | } |
duke@435 | 315 | } |
duke@435 | 316 | |
duke@435 | 317 | if (i1.hasNext() != i2.hasNext()) { |
duke@435 | 318 | // Different lengths |
duke@435 | 319 | return false; |
duke@435 | 320 | } |
duke@435 | 321 | |
duke@435 | 322 | return true; |
duke@435 | 323 | } |
duke@435 | 324 | |
duke@435 | 325 | protected String envVarPrefixedFileName(String fileName, |
duke@435 | 326 | int sourceBaseLen, |
duke@435 | 327 | DirectoryTree tree, |
duke@435 | 328 | Vector preferredPaths, |
duke@435 | 329 | Vector filesNotFound, |
duke@435 | 330 | Vector filesDuplicate) { |
duke@435 | 331 | String fullName = findFileInDirectory(fileName, |
duke@435 | 332 | tree, |
duke@435 | 333 | preferredPaths, |
duke@435 | 334 | filesNotFound, |
duke@435 | 335 | filesDuplicate); |
duke@435 | 336 | return fullName; |
duke@435 | 337 | } |
duke@435 | 338 | |
duke@435 | 339 | String getProjectName(String fullPath, String extension) |
duke@435 | 340 | throws IllegalArgumentException, IOException { |
duke@435 | 341 | File file = new File(fullPath).getCanonicalFile(); |
duke@435 | 342 | fullPath = file.getCanonicalPath(); |
duke@435 | 343 | String parent = file.getParent(); |
duke@435 | 344 | |
duke@435 | 345 | if (!fullPath.endsWith(extension)) { |
duke@435 | 346 | throw new IllegalArgumentException("project file name \"" + |
duke@435 | 347 | fullPath + |
duke@435 | 348 | "\" does not end in "+extension); |
duke@435 | 349 | } |
duke@435 | 350 | |
duke@435 | 351 | if ((parent != null) && |
duke@435 | 352 | (!fullPath.startsWith(parent))) { |
duke@435 | 353 | throw new RuntimeException( |
duke@435 | 354 | "Internal error: parent of file name \"" + parent + |
duke@435 | 355 | "\" does not match file name \"" + fullPath + "\"" |
duke@435 | 356 | ); |
duke@435 | 357 | } |
duke@435 | 358 | |
duke@435 | 359 | int len = parent.length(); |
duke@435 | 360 | if (!parent.endsWith(Util.sep)) { |
duke@435 | 361 | len += Util.sep.length(); |
duke@435 | 362 | } |
duke@435 | 363 | |
duke@435 | 364 | int end = fullPath.length() - extension.length(); |
duke@435 | 365 | |
duke@435 | 366 | if (len == end) { |
duke@435 | 367 | throw new RuntimeException( |
duke@435 | 368 | "Internal error: file name was empty" |
duke@435 | 369 | ); |
duke@435 | 370 | } |
duke@435 | 371 | |
duke@435 | 372 | return fullPath.substring(len, end); |
duke@435 | 373 | } |
duke@435 | 374 | |
duke@435 | 375 | protected abstract String getProjectExt(); |
duke@435 | 376 | |
duke@435 | 377 | public void writePlatformSpecificFiles(Database previousDB, |
duke@435 | 378 | Database currentDB, String[] args) |
duke@435 | 379 | throws IllegalArgumentException, IOException { |
duke@435 | 380 | |
duke@435 | 381 | parseArguments(args); |
duke@435 | 382 | |
duke@435 | 383 | String projectFileName = BuildConfig.getFieldString(null, "ProjectFileName"); |
duke@435 | 384 | String ext = getProjectExt(); |
duke@435 | 385 | |
duke@435 | 386 | // Compare contents of allFiles of previousDB and includeDB. |
duke@435 | 387 | // If these haven't changed, then skip writing the .vcproj file. |
duke@435 | 388 | if (false && databaseAllFilesEqual(previousDB, currentDB) && |
duke@435 | 389 | new File(projectFileName).exists()) { |
duke@435 | 390 | System.out.println( |
duke@435 | 391 | " Databases unchanged; skipping overwrite of "+ext+" file." |
duke@435 | 392 | ); |
duke@435 | 393 | return; |
duke@435 | 394 | } |
duke@435 | 395 | |
duke@435 | 396 | String projectName = getProjectName(projectFileName, ext); |
duke@435 | 397 | |
duke@435 | 398 | writeProjectFile(projectFileName, projectName, createAllConfigs()); |
duke@435 | 399 | } |
duke@435 | 400 | |
duke@435 | 401 | protected void writePrologue(String[] args) { |
duke@435 | 402 | System.err.println("WinGammaPlatform platform-specific arguments:"); |
duke@435 | 403 | for (int i = 0; i < args.length; i++) { |
duke@435 | 404 | System.err.print(args[i] + " "); |
duke@435 | 405 | } |
duke@435 | 406 | System.err.println(); |
duke@435 | 407 | } |
duke@435 | 408 | |
duke@435 | 409 | |
duke@435 | 410 | void setInclFileTemplate(FileName val) { |
duke@435 | 411 | this.inclFileTemplate = val; |
duke@435 | 412 | } |
duke@435 | 413 | |
duke@435 | 414 | void setGIFileTemplate(FileName val) { |
duke@435 | 415 | this.giFileTemplate = val; |
duke@435 | 416 | } |
duke@435 | 417 | |
duke@435 | 418 | |
duke@435 | 419 | void parseArguments(String[] args) { |
duke@435 | 420 | new ArgsParser(args, |
duke@435 | 421 | new ArgRule[] |
duke@435 | 422 | { |
duke@435 | 423 | new HsArgRule("-sourceBase", |
duke@435 | 424 | "SourceBase", |
duke@435 | 425 | " (Did you set the HotSpotWorkSpace environment variable?)", |
duke@435 | 426 | HsArgHandler.STRING |
duke@435 | 427 | ), |
duke@435 | 428 | |
duke@435 | 429 | new HsArgRule("-buildBase", |
duke@435 | 430 | "BuildBase", |
duke@435 | 431 | " (Did you set the HotSpotBuildSpace environment variable?)", |
duke@435 | 432 | HsArgHandler.STRING |
duke@435 | 433 | ), |
duke@435 | 434 | |
duke@435 | 435 | new HsArgRule("-projectFileName", |
duke@435 | 436 | "ProjectFileName", |
duke@435 | 437 | null, |
duke@435 | 438 | HsArgHandler.STRING |
duke@435 | 439 | ), |
duke@435 | 440 | |
duke@435 | 441 | new HsArgRule("-jdkTargetRoot", |
duke@435 | 442 | "JdkTargetRoot", |
duke@435 | 443 | " (Did you set the HotSpotJDKDist environment variable?)", |
duke@435 | 444 | HsArgHandler.STRING |
duke@435 | 445 | ), |
duke@435 | 446 | |
duke@435 | 447 | new HsArgRule("-compiler", |
duke@435 | 448 | "CompilerVersion", |
duke@435 | 449 | " (Did you set the VcVersion correctly?)", |
duke@435 | 450 | HsArgHandler.STRING |
duke@435 | 451 | ), |
duke@435 | 452 | |
duke@435 | 453 | new HsArgRule("-platform", |
duke@435 | 454 | "Platform", |
duke@435 | 455 | null, |
duke@435 | 456 | HsArgHandler.STRING |
duke@435 | 457 | ), |
duke@435 | 458 | |
duke@435 | 459 | new HsArgRule("-absoluteInclude", |
duke@435 | 460 | "AbsoluteInclude", |
duke@435 | 461 | null, |
duke@435 | 462 | HsArgHandler.VECTOR |
duke@435 | 463 | ), |
duke@435 | 464 | |
duke@435 | 465 | new HsArgRule("-relativeInclude", |
duke@435 | 466 | "RelativeInclude", |
duke@435 | 467 | null, |
duke@435 | 468 | HsArgHandler.VECTOR |
duke@435 | 469 | ), |
duke@435 | 470 | |
duke@435 | 471 | new HsArgRule("-define", |
duke@435 | 472 | "Define", |
duke@435 | 473 | null, |
duke@435 | 474 | HsArgHandler.VECTOR |
duke@435 | 475 | ), |
duke@435 | 476 | |
duke@435 | 477 | new HsArgRule("-useToGeneratePch", |
duke@435 | 478 | "UseToGeneratePch", |
duke@435 | 479 | null, |
duke@435 | 480 | HsArgHandler.STRING |
duke@435 | 481 | ), |
duke@435 | 482 | |
duke@435 | 483 | new ArgRuleSpecific("-perFileLine", |
duke@435 | 484 | new HsArgHandler() { |
duke@435 | 485 | public void handle(ArgIterator it) { |
duke@435 | 486 | String cfg = getCfg(it.get()); |
duke@435 | 487 | if (nextNotKey(it)) { |
duke@435 | 488 | String fileName = it.get(); |
duke@435 | 489 | if (nextNotKey(it)) { |
duke@435 | 490 | String line = it.get(); |
duke@435 | 491 | BuildConfig.putFieldHash(cfg, "PerFileLine", fileName, line); |
duke@435 | 492 | it.next(); |
duke@435 | 493 | return; |
duke@435 | 494 | } |
duke@435 | 495 | } |
duke@435 | 496 | empty(null, "** Error: wrong number of args to -perFileLine"); |
duke@435 | 497 | } |
duke@435 | 498 | } |
duke@435 | 499 | ), |
duke@435 | 500 | |
duke@435 | 501 | new ArgRuleSpecific("-conditionalPerFileLine", |
duke@435 | 502 | new HsArgHandler() { |
duke@435 | 503 | public void handle(ArgIterator it) { |
duke@435 | 504 | String cfg = getCfg(it.get()); |
duke@435 | 505 | if (nextNotKey(it)) { |
duke@435 | 506 | String fileName = it.get(); |
duke@435 | 507 | if (nextNotKey(it)) { |
duke@435 | 508 | String productLine = it.get(); |
duke@435 | 509 | if (nextNotKey(it)) { |
duke@435 | 510 | String debugLine = it.get(); |
duke@435 | 511 | BuildConfig.putFieldHash(cfg+"_debug", "CondPerFileLine", |
duke@435 | 512 | fileName, debugLine); |
duke@435 | 513 | BuildConfig.putFieldHash(cfg+"_product", "CondPerFileLine", |
duke@435 | 514 | fileName, productLine); |
duke@435 | 515 | it.next(); |
duke@435 | 516 | return; |
duke@435 | 517 | } |
duke@435 | 518 | } |
duke@435 | 519 | } |
duke@435 | 520 | |
duke@435 | 521 | empty(null, "** Error: wrong number of args to -conditionalPerFileLine"); |
duke@435 | 522 | } |
duke@435 | 523 | } |
duke@435 | 524 | ), |
duke@435 | 525 | |
duke@435 | 526 | new HsArgRule("-disablePch", |
duke@435 | 527 | "DisablePch", |
duke@435 | 528 | null, |
duke@435 | 529 | HsArgHandler.HASH |
duke@435 | 530 | ), |
duke@435 | 531 | |
duke@435 | 532 | new ArgRule("-startAt", |
duke@435 | 533 | new HsArgHandler() { |
duke@435 | 534 | public void handle(ArgIterator it) { |
duke@435 | 535 | if (BuildConfig.getField(null, "StartAt") != null) { |
duke@435 | 536 | empty(null, "** Error: multiple -startAt"); |
duke@435 | 537 | } |
duke@435 | 538 | if (nextNotKey(it)) { |
duke@435 | 539 | BuildConfig.putField(null, "StartAt", it.get()); |
duke@435 | 540 | it.next(); |
duke@435 | 541 | } else { |
duke@435 | 542 | empty("-startAt", null); |
duke@435 | 543 | } |
duke@435 | 544 | } |
duke@435 | 545 | } |
duke@435 | 546 | ), |
duke@435 | 547 | |
duke@435 | 548 | new HsArgRule("-ignoreFile", |
duke@435 | 549 | "IgnoreFile", |
duke@435 | 550 | null, |
duke@435 | 551 | HsArgHandler.HASH |
duke@435 | 552 | ), |
duke@435 | 553 | |
duke@435 | 554 | new HsArgRule("-additionalFile", |
duke@435 | 555 | "AdditionalFile", |
duke@435 | 556 | null, |
duke@435 | 557 | HsArgHandler.VECTOR |
duke@435 | 558 | ), |
duke@435 | 559 | |
duke@435 | 560 | new ArgRuleSpecific("-additionalGeneratedFile", |
duke@435 | 561 | new HsArgHandler() { |
duke@435 | 562 | public void handle(ArgIterator it) { |
duke@435 | 563 | String cfg = getCfg(it.get()); |
duke@435 | 564 | if (nextNotKey(it)) { |
duke@435 | 565 | String dir = it.get(); |
duke@435 | 566 | if (nextNotKey(it)) { |
duke@435 | 567 | String fileName = it.get(); |
duke@435 | 568 | // we ignore files that we know are generated, so we coudn't |
duke@435 | 569 | // find them in sources |
duke@435 | 570 | BuildConfig.putFieldHash(cfg, "IgnoreFile", fileName, "1"); |
duke@435 | 571 | BuildConfig.putFieldHash(cfg, "AdditionalGeneratedFile", |
duke@435 | 572 | Util.normalize(dir + Util.sep + fileName), |
duke@435 | 573 | fileName); |
duke@435 | 574 | it.next(); |
duke@435 | 575 | return; |
duke@435 | 576 | } |
duke@435 | 577 | } |
duke@435 | 578 | empty(null, "** Error: wrong number of args to -additionalGeneratedFile"); |
duke@435 | 579 | } |
duke@435 | 580 | } |
duke@435 | 581 | ), |
duke@435 | 582 | |
duke@435 | 583 | new HsArgRule("-includeDB", |
duke@435 | 584 | "IncludeDB", |
duke@435 | 585 | null, |
duke@435 | 586 | HsArgHandler.STRING |
duke@435 | 587 | ), |
duke@435 | 588 | |
duke@435 | 589 | new ArgRule("-prelink", |
duke@435 | 590 | new HsArgHandler() { |
duke@435 | 591 | public void handle(ArgIterator it) { |
duke@435 | 592 | if (nextNotKey(it)) { |
duke@435 | 593 | String build = it.get(); |
duke@435 | 594 | if (nextNotKey(it)) { |
duke@435 | 595 | String description = it.get(); |
duke@435 | 596 | if (nextNotKey(it)) { |
duke@435 | 597 | String command = it.get(); |
duke@435 | 598 | BuildConfig.putField(null, "PrelinkDescription", description); |
duke@435 | 599 | BuildConfig.putField(null, "PrelinkCommand", command); |
duke@435 | 600 | it.next(); |
duke@435 | 601 | return; |
duke@435 | 602 | } |
duke@435 | 603 | } |
duke@435 | 604 | } |
duke@435 | 605 | |
duke@435 | 606 | empty(null, "** Error: wrong number of args to -prelink"); |
duke@435 | 607 | } |
duke@435 | 608 | } |
duke@435 | 609 | ) |
duke@435 | 610 | }, |
duke@435 | 611 | new ArgHandler() { |
duke@435 | 612 | public void handle(ArgIterator it) { |
duke@435 | 613 | |
duke@435 | 614 | throw new RuntimeException("Arg Parser: unrecognized option "+it.get()); |
duke@435 | 615 | } |
duke@435 | 616 | } |
duke@435 | 617 | ); |
duke@435 | 618 | if (BuildConfig.getField(null, "SourceBase") == null || |
duke@435 | 619 | BuildConfig.getField(null, "BuildBase") == null || |
duke@435 | 620 | BuildConfig.getField(null, "ProjectFileName") == null || |
duke@435 | 621 | BuildConfig.getField(null, "CompilerVersion") == null) { |
duke@435 | 622 | usage(); |
duke@435 | 623 | } |
duke@435 | 624 | |
duke@435 | 625 | if (BuildConfig.getField(null, "UseToGeneratePch") == null) { |
duke@435 | 626 | throw new RuntimeException("ERROR: need to specify one file to compute PCH, with -useToGeneratePch flag"); |
duke@435 | 627 | } |
duke@435 | 628 | |
duke@435 | 629 | BuildConfig.putField(null, "PlatformObject", this); |
duke@435 | 630 | } |
duke@435 | 631 | |
duke@435 | 632 | Vector createAllConfigs() { |
duke@435 | 633 | Vector allConfigs = new Vector(); |
duke@435 | 634 | |
duke@435 | 635 | allConfigs.add(new C1DebugConfig()); |
duke@435 | 636 | |
duke@435 | 637 | boolean b = true; |
duke@435 | 638 | if (b) { |
duke@435 | 639 | allConfigs.add(new C1FastDebugConfig()); |
duke@435 | 640 | allConfigs.add(new C1ProductConfig()); |
duke@435 | 641 | |
duke@435 | 642 | allConfigs.add(new C2DebugConfig()); |
duke@435 | 643 | allConfigs.add(new C2FastDebugConfig()); |
duke@435 | 644 | allConfigs.add(new C2ProductConfig()); |
duke@435 | 645 | |
duke@435 | 646 | allConfigs.add(new TieredDebugConfig()); |
duke@435 | 647 | allConfigs.add(new TieredFastDebugConfig()); |
duke@435 | 648 | allConfigs.add(new TieredProductConfig()); |
duke@435 | 649 | |
duke@435 | 650 | allConfigs.add(new CoreDebugConfig()); |
duke@435 | 651 | allConfigs.add(new CoreFastDebugConfig()); |
duke@435 | 652 | allConfigs.add(new CoreProductConfig()); |
duke@435 | 653 | |
duke@435 | 654 | allConfigs.add(new KernelDebugConfig()); |
duke@435 | 655 | allConfigs.add(new KernelFastDebugConfig()); |
duke@435 | 656 | allConfigs.add(new KernelProductConfig()); |
duke@435 | 657 | } |
duke@435 | 658 | |
duke@435 | 659 | return allConfigs; |
duke@435 | 660 | } |
duke@435 | 661 | |
duke@435 | 662 | class FileAttribute { |
duke@435 | 663 | int numConfigs; |
duke@435 | 664 | Vector configs; |
duke@435 | 665 | String shortName; |
duke@435 | 666 | boolean noPch, pchRoot; |
duke@435 | 667 | |
duke@435 | 668 | FileAttribute(String shortName, BuildConfig cfg, int numConfigs) { |
duke@435 | 669 | this.shortName = shortName; |
duke@435 | 670 | this.noPch = (cfg.lookupHashFieldInContext("DisablePch", shortName) != null); |
duke@435 | 671 | this.pchRoot = shortName.equals(BuildConfig.getFieldString(null, "UseToGeneratePch")); |
duke@435 | 672 | this.numConfigs = numConfigs; |
duke@435 | 673 | |
duke@435 | 674 | configs = new Vector(); |
duke@435 | 675 | add(cfg.get("Name")); |
duke@435 | 676 | } |
duke@435 | 677 | |
duke@435 | 678 | void add(String confName) { |
duke@435 | 679 | configs.add(confName); |
duke@435 | 680 | |
duke@435 | 681 | // if presented in all configs |
duke@435 | 682 | if (configs.size() == numConfigs) { |
duke@435 | 683 | configs = null; |
duke@435 | 684 | } |
duke@435 | 685 | } |
duke@435 | 686 | } |
duke@435 | 687 | |
duke@435 | 688 | class FileInfo implements Comparable { |
duke@435 | 689 | String full; |
duke@435 | 690 | FileAttribute attr; |
duke@435 | 691 | |
duke@435 | 692 | FileInfo(String full, FileAttribute attr) { |
duke@435 | 693 | this.full = full; |
duke@435 | 694 | this.attr = attr; |
duke@435 | 695 | } |
duke@435 | 696 | |
duke@435 | 697 | public int compareTo(Object o) { |
duke@435 | 698 | FileInfo oo = (FileInfo)o; |
duke@435 | 699 | // Don't squelch identical short file names where the full |
duke@435 | 700 | // paths are different |
duke@435 | 701 | if (!attr.shortName.equals(oo.attr.shortName)) |
duke@435 | 702 | return attr.shortName.compareTo(oo.attr.shortName); |
duke@435 | 703 | return full.compareTo(oo.full); |
duke@435 | 704 | } |
duke@435 | 705 | |
duke@435 | 706 | boolean isHeader() { |
duke@435 | 707 | return attr.shortName.endsWith(".h") || attr.shortName.endsWith(".hpp"); |
duke@435 | 708 | } |
duke@435 | 709 | } |
duke@435 | 710 | |
duke@435 | 711 | |
duke@435 | 712 | TreeSet sortFiles(Hashtable allFiles) { |
duke@435 | 713 | TreeSet rv = new TreeSet(); |
duke@435 | 714 | Enumeration e = allFiles.keys(); |
duke@435 | 715 | while (e.hasMoreElements()) { |
duke@435 | 716 | String fullPath = (String)e.nextElement(); |
duke@435 | 717 | rv.add(new FileInfo(fullPath, (FileAttribute)allFiles.get(fullPath))); |
duke@435 | 718 | } |
duke@435 | 719 | return rv; |
duke@435 | 720 | } |
duke@435 | 721 | |
duke@435 | 722 | Hashtable computeAttributedFiles(Vector allConfigs) { |
duke@435 | 723 | Hashtable ht = new Hashtable(); |
duke@435 | 724 | int numConfigs = allConfigs.size(); |
duke@435 | 725 | |
duke@435 | 726 | for (Iterator i = allConfigs.iterator(); i.hasNext(); ) { |
duke@435 | 727 | BuildConfig bc = (BuildConfig)i.next(); |
duke@435 | 728 | Hashtable confFiles = (Hashtable)bc.getSpecificField("AllFilesHash"); |
duke@435 | 729 | String confName = bc.get("Name"); |
duke@435 | 730 | |
duke@435 | 731 | for (Enumeration e=confFiles.keys(); e.hasMoreElements(); ) { |
duke@435 | 732 | String filePath = (String)e.nextElement(); |
duke@435 | 733 | FileAttribute fa = (FileAttribute)ht.get(filePath); |
duke@435 | 734 | |
duke@435 | 735 | if (fa == null) { |
duke@435 | 736 | fa = new FileAttribute((String)confFiles.get(filePath), bc, numConfigs); |
duke@435 | 737 | ht.put(filePath, fa); |
duke@435 | 738 | } else { |
duke@435 | 739 | fa.add(confName); |
duke@435 | 740 | } |
duke@435 | 741 | } |
duke@435 | 742 | } |
duke@435 | 743 | |
duke@435 | 744 | return ht; |
duke@435 | 745 | } |
duke@435 | 746 | |
duke@435 | 747 | Hashtable computeAttributedFiles(BuildConfig bc) { |
duke@435 | 748 | Hashtable ht = new Hashtable(); |
duke@435 | 749 | Hashtable confFiles = (Hashtable)bc.getSpecificField("AllFilesHash"); |
duke@435 | 750 | |
duke@435 | 751 | for (Enumeration e = confFiles.keys(); e.hasMoreElements(); ) { |
duke@435 | 752 | String filePath = (String)e.nextElement(); |
duke@435 | 753 | ht.put(filePath, new FileAttribute((String)confFiles.get(filePath), bc, 1)); |
duke@435 | 754 | } |
duke@435 | 755 | |
duke@435 | 756 | return ht; |
duke@435 | 757 | } |
duke@435 | 758 | |
duke@435 | 759 | PrintWriter printWriter; |
duke@435 | 760 | |
duke@435 | 761 | public void writeProjectFile(String projectFileName, String projectName, |
duke@435 | 762 | Vector allConfigs) throws IOException { |
duke@435 | 763 | throw new RuntimeException("use compiler version specific version"); |
duke@435 | 764 | } |
duke@435 | 765 | } |