From 17888bc3c0d7638c1c688a66aa5420f4ef7bd380 Mon Sep 17 00:00:00 2001 From: Erik Joelsson Date: Mon, 19 Mar 2012 13:03:37 -0700 Subject: [PATCH] 7153266: Adjustments to corba strip property utility (neutral to builds) Fixes to sync up with jdk8 build-infra project. Reviewed-by: ohair, tbell, ohrstrom --- corba/make/common/internal/Resources.gmk | 4 +- ...perties.java => StripPropertiesCorba.java} | 78 ++++++++++--------- corba/make/tools/strip_properties/Makefile | 2 +- 3 files changed, 46 insertions(+), 38 deletions(-) rename corba/make/tools/src/build/tools/stripproperties/{StripProperties.java => StripPropertiesCorba.java} (80%) diff --git a/corba/make/common/internal/Resources.gmk b/corba/make/common/internal/Resources.gmk index 575fdf643e2..d9bc99bf2ca 100644 --- a/corba/make/common/internal/Resources.gmk +++ b/corba/make/common/internal/Resources.gmk @@ -149,8 +149,8 @@ strip_prop_options_clean: # Strip the properties files strip_all_props: $(STRIPPROPERTIES_JARFILE) $(STRIP_PROP_options) @if [ -s $(STRIP_PROP_options) ] ; then \ - $(ECHO) "$(BOOT_JAVA_CMD) -jar $(STRIPPROPERTIES_JARFILE) -optionsfile $(STRIP_PROP_options)" ; \ - $(BOOT_JAVA_CMD) -jar $(STRIPPROPERTIES_JARFILE) -optionsfile $(STRIP_PROP_options) ; \ + $(ECHO) "$(BOOT_JAVA_CMD) -jar $(STRIPPROPERTIES_JARFILE) @$(STRIP_PROP_options)" ; \ + $(BOOT_JAVA_CMD) -jar $(STRIPPROPERTIES_JARFILE) @$(STRIP_PROP_options) ; \ fi @$(java-vm-cleanup) diff --git a/corba/make/tools/src/build/tools/stripproperties/StripProperties.java b/corba/make/tools/src/build/tools/stripproperties/StripPropertiesCorba.java similarity index 80% rename from corba/make/tools/src/build/tools/stripproperties/StripProperties.java rename to corba/make/tools/src/build/tools/stripproperties/StripPropertiesCorba.java index dcf7114d331..4ff1ca13d8b 100644 --- a/corba/make/tools/src/build/tools/stripproperties/StripProperties.java +++ b/corba/make/tools/src/build/tools/stripproperties/StripPropertiesCorba.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2001, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2001, 2011, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -36,6 +36,7 @@ import java.io.IOException; import java.io.InputStream; import java.util.ArrayList; import java.util.Enumeration; +import java.util.Iterator; import java.util.List; import java.util.Properties; @@ -43,7 +44,7 @@ import java.util.Properties; * Reads a properties file from standard input and writes an equivalent * properties file without comments to standard output. */ -public class StripProperties { +public class StripPropertiesCorba { private static void error(String msg, Exception e) { System.err.println("ERROR: stripproperties: " + msg); @@ -53,82 +54,89 @@ public class StripProperties { } } - private static List parseOptions(String args[]) { - List files = new ArrayList(); + private static List infiles = new ArrayList(); + private static List outfiles = new ArrayList(); + + private static boolean parseOptions(String args[]) { + boolean ok = true; + for ( int i = 0; i < args.length ; i++ ) { - if ( "-optionsfile".equals(args[i]) && i+1 < args.length ) { - String filename = args[++i]; + if ( "-clean".equals(args[i]) && i+2 < args.length ) { + infiles.add(args[++i]); + outfiles.add(args[++i]); + } else if ( args[i].charAt(0)=='@') { + String filename = args[i].substring(1); FileInputStream finput = null; byte contents[] = null; try { finput = new FileInputStream(filename); int byteCount = finput.available(); if ( byteCount <= 0 ) { - error("The -optionsfile file is empty", null); - files = null; + error("The @file is empty", null); + ok = false; } else { contents = new byte[byteCount]; int bytesRead = finput.read(contents); if ( byteCount != bytesRead ) { - error("Cannot read all of -optionsfile file", null); - files = null; + error("Cannot read all of @file", null); + ok = false; } } } catch ( IOException e ) { error("cannot open " + filename, e); - files = null; + ok = false; } if ( finput != null ) { try { finput.close(); } catch ( IOException e ) { - files = null; + ok = false; error("cannot close " + filename, e); } } - if ( files != null && contents != null ) { + if ( ok && contents != null ) { String tokens[] = (new String(contents)).split("\\s+"); if ( tokens.length > 0 ) { - List ofiles = parseOptions(tokens); - if ( ofiles != null ) { - files.addAll(ofiles); - } else { - error("No files found in file", null); - files = null; - } + ok = parseOptions(tokens); } } - if ( files == null ) { + if ( !ok ) { break; } } else { - files.add(args[i]); + infiles.add(args[i]); + outfiles.add(args[i]); } } - return files; + return ok; } - private static boolean stripFiles(List files) { + private static boolean stripFiles(List infiles, List outfiles) { boolean ok = true; - for ( String file : files ) { + Iterator inIter = infiles.iterator(); + Iterator outIter = outfiles.iterator(); + + for (; inIter.hasNext(); ) { + String infile = inIter.next(); + String outfile = outIter.next(); Properties prop = new Properties(); InputStream in = null; try { - in = new BufferedInputStream(new FileInputStream(file)); + in = new BufferedInputStream(new FileInputStream(infile)); prop.load(in); } catch ( FileNotFoundException e ) { - error("Cannot access file " + file, e); + error("Cannot access file " + infile, e); ok = false; } catch ( IOException e ) { - error("IO exception processing file " + file, e); + error("IO exception processing file " + infile, e); ok = false; } if ( in != null ) { try { in.close(); } catch ( IOException e ) { - error("IO exception closing file " + file, e); + error("IO exception closing file " + infile, e); ok = false; } } @@ -138,18 +146,18 @@ public class StripProperties { OutputStream out = null; try { - out = new FileOutputStream(file); + out = new FileOutputStream(outfile); storeProperties(prop, out); out.flush(); } catch ( IOException e ) { - error("IO exception processing file " + file, e); + error("IO exception processing file " + outfile, e); ok = false; } if ( out != null ) { try { out.close(); } catch ( IOException e ) { - error("IO exception closing file " + file, e); + error("IO exception closing file " + outfile, e); ok = false; } } @@ -166,8 +174,8 @@ public class StripProperties { * @param args Names of properties files to process and replace contents */ public static void main(String args[]) { - List files = parseOptions(args); - if ( files == null || !stripFiles(files) ) { + boolean ok = parseOptions(args); + if ( !ok || !stripFiles(infiles, outfiles) ) { System.exit(1); } } @@ -246,7 +254,7 @@ public class StripProperties { throws IOException { BufferedWriter awriter; awriter = new BufferedWriter(new OutputStreamWriter(out, "8859_1")); - for (Enumeration e = properties.keys(); e.hasMoreElements();) { + for (Enumeration e = properties.keys(); e.hasMoreElements();) { String key = (String)e.nextElement(); String val = (String)properties.get(key); key = saveConvert(key, true); diff --git a/corba/make/tools/strip_properties/Makefile b/corba/make/tools/strip_properties/Makefile index 7c3a829a146..75eb2f1ffe6 100644 --- a/corba/make/tools/strip_properties/Makefile +++ b/corba/make/tools/strip_properties/Makefile @@ -34,7 +34,7 @@ PROGRAM = stripproperties include $(BUILDDIR)/common/Defs.gmk BUILDTOOL_SOURCE_ROOT = $(BUILDDIR)/tools/src -BUILDTOOL_MAIN = $(PKGDIR)/StripProperties.java +BUILDTOOL_MAIN = $(PKGDIR)/StripPropertiesCorba.java # # Build tool jar rules.