diff --git a/src/java.base/share/classes/com/sun/java/util/jar/pack/Driver.java b/src/java.base/share/classes/com/sun/java/util/jar/pack/Driver.java index ac04e677ffe..b9fe2147b74 100644 --- a/src/java.base/share/classes/com/sun/java/util/jar/pack/Driver.java +++ b/src/java.base/share/classes/com/sun/java/util/jar/pack/Driver.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2019, 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 @@ -25,6 +25,8 @@ package com.sun.java.util.jar.pack; +import sun.nio.cs.UTF_8; + import java.io.BufferedInputStream; import java.io.BufferedOutputStream; import java.io.File; @@ -443,7 +445,7 @@ class Driver { // Skip sig4, disks4, entries4, clen4, coff4, cmt2 i += 4+4+4+4+4+2; if (i < tail.length) - return new String(tail, i, tail.length-i, "UTF8"); + return new String(tail, i, tail.length-i, UTF_8.INSTANCE); return ""; } } diff --git a/src/java.base/share/classes/com/sun/security/ntlm/NTLM.java b/src/java.base/share/classes/com/sun/security/ntlm/NTLM.java index 2d455046d42..3982d7f20c0 100644 --- a/src/java.base/share/classes/com/sun/security/ntlm/NTLM.java +++ b/src/java.base/share/classes/com/sun/security/ntlm/NTLM.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2010, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2010, 2019, 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 @@ -29,7 +29,7 @@ import sun.security.action.GetBooleanAction; import static com.sun.security.ntlm.Version.*; import java.io.IOException; -import java.io.UnsupportedEncodingException; +import java.nio.charset.StandardCharsets; import java.security.InvalidKeyException; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; @@ -182,13 +182,9 @@ class NTLM { String readSecurityBuffer(int offset, boolean unicode) throws NTLMException { byte[] raw = readSecurityBuffer(offset); - try { - return raw == null ? null : new String( - raw, unicode ? "UnicodeLittleUnmarked" : "ISO8859_1"); - } catch (UnsupportedEncodingException ex) { - throw new NTLMException(NTLMException.PACKET_READ_ERROR, - "Invalid input encoding"); - } + return raw == null ? null : new String( + raw, unicode ? StandardCharsets.UTF_16LE + : StandardCharsets.ISO_8859_1); } } @@ -247,12 +243,9 @@ class NTLM { } void writeSecurityBuffer(int offset, String str, boolean unicode) { - try { - writeSecurityBuffer(offset, str == null ? null : str.getBytes( - unicode ? "UnicodeLittleUnmarked" : "ISO8859_1")); - } catch (UnsupportedEncodingException ex) { - assert false; - } + writeSecurityBuffer(offset, str == null ? null : str.getBytes( + unicode ? StandardCharsets.UTF_16LE + : StandardCharsets.ISO_8859_1)); } byte[] getBytes() { @@ -380,20 +373,14 @@ class NTLM { } byte[] calcV2(byte[] nthash, String text, byte[] blob, byte[] challenge) { - try { - byte[] ntlmv2hash = hmacMD5(nthash, - text.getBytes("UnicodeLittleUnmarked")); - byte[] cn = new byte[blob.length+8]; - System.arraycopy(challenge, 0, cn, 0, 8); - System.arraycopy(blob, 0, cn, 8, blob.length); - byte[] result = new byte[16+blob.length]; - System.arraycopy(hmacMD5(ntlmv2hash, cn), 0, result, 0, 16); - System.arraycopy(blob, 0, result, 16, blob.length); - return result; - } catch (UnsupportedEncodingException ex) { - assert false; - } - return null; + byte[] ntlmv2hash = hmacMD5(nthash, text.getBytes(StandardCharsets.UTF_16LE)); + byte[] cn = new byte[blob.length+8]; + System.arraycopy(challenge, 0, cn, 0, 8); + System.arraycopy(blob, 0, cn, 8, blob.length); + byte[] result = new byte[16+blob.length]; + System.arraycopy(hmacMD5(ntlmv2hash, cn), 0, result, 0, 16); + System.arraycopy(blob, 0, result, 16, blob.length); + return result; } // NTLM2 LM/NTLM @@ -412,19 +399,11 @@ class NTLM { // Password in ASCII and UNICODE static byte[] getP1(char[] password) { - try { - return new String(password).toUpperCase( - Locale.ENGLISH).getBytes("ISO8859_1"); - } catch (UnsupportedEncodingException ex) { - return null; - } + return new String(password).toUpperCase(Locale.ENGLISH) + .getBytes(StandardCharsets.ISO_8859_1); } static byte[] getP2(char[] password) { - try { - return new String(password).getBytes("UnicodeLittleUnmarked"); - } catch (UnsupportedEncodingException ex) { - return null; - } + return new String(password).getBytes(StandardCharsets.UTF_16LE); } } diff --git a/src/java.base/share/classes/java/io/InputStreamReader.java b/src/java.base/share/classes/java/io/InputStreamReader.java index a5fbc7036c9..cf2650592a2 100644 --- a/src/java.base/share/classes/java/io/InputStreamReader.java +++ b/src/java.base/share/classes/java/io/InputStreamReader.java @@ -70,12 +70,8 @@ public class InputStreamReader extends Reader { */ public InputStreamReader(InputStream in) { super(in); - try { - sd = StreamDecoder.forInputStreamReader(in, this, (String)null); // ## check lock object - } catch (UnsupportedEncodingException e) { - // The default encoding should always be available - throw new Error(e); - } + sd = StreamDecoder.forInputStreamReader(in, this, + Charset.defaultCharset()); // ## check lock object } /** diff --git a/src/java.base/share/classes/java/io/OutputStreamWriter.java b/src/java.base/share/classes/java/io/OutputStreamWriter.java index 96277de385e..d263ec44a5f 100644 --- a/src/java.base/share/classes/java/io/OutputStreamWriter.java +++ b/src/java.base/share/classes/java/io/OutputStreamWriter.java @@ -106,11 +106,8 @@ public class OutputStreamWriter extends Writer { */ public OutputStreamWriter(OutputStream out) { super(out); - try { - se = StreamEncoder.forOutputStreamWriter(out, this, (String)null); - } catch (UnsupportedEncodingException e) { - throw new Error(e); - } + se = StreamEncoder.forOutputStreamWriter(out, this, + Charset.defaultCharset()); } /** diff --git a/src/java.base/share/classes/java/lang/CharacterName.java b/src/java.base/share/classes/java/lang/CharacterName.java index 2e8b93c7a6c..7dd83feecd1 100644 --- a/src/java.base/share/classes/java/lang/CharacterName.java +++ b/src/java.base/share/classes/java/lang/CharacterName.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2010, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2010, 2019, 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 @@ -151,7 +151,7 @@ class CharacterName { } public int getCodePoint(String name) { - byte[] bname = name.getBytes(java.nio.charset.StandardCharsets.ISO_8859_1); + byte[] bname = name.getBytes(sun.nio.cs.ISO_8859_1.INSTANCE); int hsh = hashN(bname, 0, bname.length); int idx = hsIndices[(hsh & 0x7fffffff) % hsIndices.length]; while (idx != -1) { diff --git a/src/java.base/share/classes/java/net/InetAddress.java b/src/java.base/share/classes/java/net/InetAddress.java index daf3237d105..e967032f541 100644 --- a/src/java.base/share/classes/java/net/InetAddress.java +++ b/src/java.base/share/classes/java/net/InetAddress.java @@ -31,7 +31,6 @@ import java.util.Objects; import java.util.Scanner; import java.security.AccessController; import java.io.File; -import java.io.FileNotFoundException; import java.io.ObjectStreamException; import java.io.ObjectStreamField; import java.io.IOException; @@ -52,6 +51,7 @@ import jdk.internal.access.SharedSecrets; import sun.security.action.*; import sun.net.InetAddressCachePolicy; import sun.net.util.IPAddressUtil; +import sun.nio.cs.UTF_8; /** * This class represents an Internet Protocol (IP) address. @@ -984,7 +984,9 @@ public class InetAddress implements java.io.Serializable { String hostEntry; String host = null; - try (Scanner hostsFileScanner = new Scanner(new File(hostsFile), "UTF-8")) { + try (Scanner hostsFileScanner = new Scanner(new File(hostsFile), + UTF_8.INSTANCE)) + { while (hostsFileScanner.hasNextLine()) { hostEntry = hostsFileScanner.nextLine(); if (!hostEntry.startsWith("#")) { @@ -997,7 +999,7 @@ public class InetAddress implements java.io.Serializable { } } } - } catch (FileNotFoundException e) { + } catch (IOException e) { throw new UnknownHostException("Unable to resolve address " + Arrays.toString(addr) + " as hosts file " + hostsFile + " not found "); @@ -1033,7 +1035,9 @@ public class InetAddress implements java.io.Serializable { ArrayList inetAddresses = null; // lookup the file and create a list InetAddress for the specified host - try (Scanner hostsFileScanner = new Scanner(new File(hostsFile), "UTF-8")) { + try (Scanner hostsFileScanner = new Scanner(new File(hostsFile), + UTF_8.INSTANCE)) + { while (hostsFileScanner.hasNextLine()) { hostEntry = hostsFileScanner.nextLine(); if (!hostEntry.startsWith("#")) { @@ -1052,7 +1056,7 @@ public class InetAddress implements java.io.Serializable { } } } - } catch (FileNotFoundException e) { + } catch (IOException e) { throw new UnknownHostException("Unable to resolve host " + host + " as hosts file " + hostsFile + " not found "); } diff --git a/src/java.base/share/classes/java/net/SocksSocketImpl.java b/src/java.base/share/classes/java/net/SocksSocketImpl.java index 11abda42ca8..46e117f4c11 100644 --- a/src/java.base/share/classes/java/net/SocksSocketImpl.java +++ b/src/java.base/share/classes/java/net/SocksSocketImpl.java @@ -28,6 +28,7 @@ import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import java.io.BufferedOutputStream; +import java.nio.charset.StandardCharsets; import java.security.AccessController; import java.util.Iterator; @@ -166,18 +167,10 @@ class SocksSocketImpl extends DelegatingSocketImpl implements SocksConsts { return false; out.write(1); out.write(userName.length()); - try { - out.write(userName.getBytes("ISO-8859-1")); - } catch (java.io.UnsupportedEncodingException uee) { - assert false; - } + out.write(userName.getBytes(StandardCharsets.ISO_8859_1)); if (password != null) { out.write(password.length()); - try { - out.write(password.getBytes("ISO-8859-1")); - } catch (java.io.UnsupportedEncodingException uee) { - assert false; - } + out.write(password.getBytes(StandardCharsets.ISO_8859_1)); } else out.write(0); out.flush(); @@ -208,11 +201,7 @@ class SocksSocketImpl extends DelegatingSocketImpl implements SocksConsts { out.write((endpoint.getPort() >> 0) & 0xff); out.write(endpoint.getAddress().getAddress()); String userName = getUserName(); - try { - out.write(userName.getBytes("ISO-8859-1")); - } catch (java.io.UnsupportedEncodingException uee) { - assert false; - } + out.write(userName.getBytes(StandardCharsets.ISO_8859_1)); out.write(0); out.flush(); byte[] data = new byte[8]; @@ -427,11 +416,7 @@ class SocksSocketImpl extends DelegatingSocketImpl implements SocksConsts { if (epoint.isUnresolved()) { out.write(DOMAIN_NAME); out.write(epoint.getHostName().length()); - try { - out.write(epoint.getHostName().getBytes("ISO-8859-1")); - } catch (java.io.UnsupportedEncodingException uee) { - assert false; - } + out.write(epoint.getHostName().getBytes(StandardCharsets.ISO_8859_1)); out.write((epoint.getPort() >> 8) & 0xff); out.write((epoint.getPort() >> 0) & 0xff); } else if (epoint.getAddress() instanceof Inet6Address) { diff --git a/src/java.base/share/classes/java/net/URI.java b/src/java.base/share/classes/java/net/URI.java index b2729789714..a9b28319b81 100644 --- a/src/java.base/share/classes/java/net/URI.java +++ b/src/java.base/share/classes/java/net/URI.java @@ -42,11 +42,11 @@ import java.text.Normalizer; import jdk.internal.access.JavaNetUriAccess; import jdk.internal.access.SharedSecrets; import sun.nio.cs.ThreadLocalCoders; +import sun.nio.cs.UTF_8; import java.lang.Character; // for javadoc import java.lang.NullPointerException; // for javadoc - /** * Represents a Uniform Resource Identifier (URI) reference. * @@ -2739,7 +2739,7 @@ public final class URI private static void appendEncoded(StringBuilder sb, char c) { ByteBuffer bb = null; try { - bb = ThreadLocalCoders.encoderFor("UTF-8") + bb = ThreadLocalCoders.encoderFor(UTF_8.INSTANCE) .encode(CharBuffer.wrap("" + c)); } catch (CharacterCodingException x) { assert false; @@ -2807,7 +2807,7 @@ public final class URI String ns = Normalizer.normalize(s, Normalizer.Form.NFC); ByteBuffer bb = null; try { - bb = ThreadLocalCoders.encoderFor("UTF-8") + bb = ThreadLocalCoders.encoderFor(UTF_8.INSTANCE) .encode(CharBuffer.wrap(ns)); } catch (CharacterCodingException x) { assert false; @@ -2865,7 +2865,7 @@ public final class URI StringBuilder sb = new StringBuilder(n); ByteBuffer bb = ByteBuffer.allocate(n); CharBuffer cb = CharBuffer.allocate(n); - CharsetDecoder dec = ThreadLocalCoders.decoderFor("UTF-8") + CharsetDecoder dec = ThreadLocalCoders.decoderFor(UTF_8.INSTANCE) .onMalformedInput(CodingErrorAction.REPLACE) .onUnmappableCharacter(CodingErrorAction.REPLACE); diff --git a/src/java.base/share/classes/java/nio/file/FileChannelLinesSpliterator.java b/src/java.base/share/classes/java/nio/file/FileChannelLinesSpliterator.java index dab526e8d2b..7ec7220d8f9 100644 --- a/src/java.base/share/classes/java/nio/file/FileChannelLinesSpliterator.java +++ b/src/java.base/share/classes/java/nio/file/FileChannelLinesSpliterator.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2019, 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 @@ -24,6 +24,10 @@ */ package java.nio.file; +import sun.nio.cs.ISO_8859_1; +import sun.nio.cs.UTF_8; +import sun.nio.cs.US_ASCII; + import java.io.BufferedReader; import java.io.IOException; import java.io.UncheckedIOException; @@ -32,7 +36,6 @@ import java.nio.channels.Channels; import java.nio.channels.FileChannel; import java.nio.channels.ReadableByteChannel; import java.nio.charset.Charset; -import java.nio.charset.StandardCharsets; import java.util.HashSet; import java.util.Set; import java.util.Spliterator; @@ -66,9 +69,9 @@ final class FileChannelLinesSpliterator implements Spliterator { static final Set SUPPORTED_CHARSET_NAMES; static { SUPPORTED_CHARSET_NAMES = new HashSet<>(); - SUPPORTED_CHARSET_NAMES.add(StandardCharsets.UTF_8.name()); - SUPPORTED_CHARSET_NAMES.add(StandardCharsets.ISO_8859_1.name()); - SUPPORTED_CHARSET_NAMES.add(StandardCharsets.US_ASCII.name()); + SUPPORTED_CHARSET_NAMES.add(UTF_8.INSTANCE.name()); + SUPPORTED_CHARSET_NAMES.add(ISO_8859_1.INSTANCE.name()); + SUPPORTED_CHARSET_NAMES.add(US_ASCII.INSTANCE.name()); } private final FileChannel fc; diff --git a/src/java.base/share/classes/java/nio/file/Files.java b/src/java.base/share/classes/java/nio/file/Files.java index 84ad4514535..e436c191c9d 100644 --- a/src/java.base/share/classes/java/nio/file/Files.java +++ b/src/java.base/share/classes/java/nio/file/Files.java @@ -79,6 +79,7 @@ import java.util.stream.StreamSupport; import jdk.internal.util.ArraysSupport; import sun.nio.ch.FileChannelImpl; +import sun.nio.cs.UTF_8; import sun.nio.fs.AbstractFileSystemProvider; /** @@ -2944,7 +2945,7 @@ public final class Files { * @since 1.8 */ public static BufferedReader newBufferedReader(Path path) throws IOException { - return newBufferedReader(path, StandardCharsets.UTF_8); + return newBufferedReader(path, UTF_8.INSTANCE); } /** @@ -3036,7 +3037,7 @@ public final class Files { public static BufferedWriter newBufferedWriter(Path path, OpenOption... options) throws IOException { - return newBufferedWriter(path, StandardCharsets.UTF_8, options); + return newBufferedWriter(path, UTF_8.INSTANCE, options); } /** @@ -3305,7 +3306,7 @@ public final class Files { * @since 11 */ public static String readString(Path path) throws IOException { - return readString(path, StandardCharsets.UTF_8); + return readString(path, UTF_8.INSTANCE); } /** @@ -3430,7 +3431,7 @@ public final class Files { * @since 1.8 */ public static List readAllLines(Path path) throws IOException { - return readAllLines(path, StandardCharsets.UTF_8); + return readAllLines(path, UTF_8.INSTANCE); } /** @@ -3601,7 +3602,7 @@ public final class Files { OpenOption... options) throws IOException { - return write(path, lines, StandardCharsets.UTF_8, options); + return write(path, lines, UTF_8.INSTANCE, options); } /** @@ -3641,7 +3642,7 @@ public final class Files { public static Path writeString(Path path, CharSequence csq, OpenOption... options) throws IOException { - return writeString(path, csq, StandardCharsets.UTF_8, options); + return writeString(path, csq, UTF_8.INSTANCE, options); } /** @@ -4188,6 +4189,6 @@ public final class Files { * @since 1.8 */ public static Stream lines(Path path) throws IOException { - return lines(path, StandardCharsets.UTF_8); + return lines(path, UTF_8.INSTANCE); } } diff --git a/src/java.base/share/classes/java/util/Base64.java b/src/java.base/share/classes/java/util/Base64.java index d525e253d9b..1f262edb815 100644 --- a/src/java.base/share/classes/java/util/Base64.java +++ b/src/java.base/share/classes/java/util/Base64.java @@ -31,6 +31,9 @@ import java.io.IOException; import java.io.OutputStream; import java.nio.ByteBuffer; import java.nio.charset.StandardCharsets; + +import sun.nio.cs.ISO_8859_1; + import jdk.internal.HotSpotIntrinsicCandidate; /** @@ -584,7 +587,7 @@ public class Base64 { * if {@code src} is not in valid Base64 scheme */ public byte[] decode(String src) { - return decode(src.getBytes(StandardCharsets.ISO_8859_1)); + return decode(src.getBytes(ISO_8859_1.INSTANCE)); } /** diff --git a/src/java.base/share/classes/java/util/Properties.java b/src/java.base/share/classes/java/util/Properties.java index a1471436456..9e6fe2e0bc5 100644 --- a/src/java.base/share/classes/java/util/Properties.java +++ b/src/java.base/share/classes/java/util/Properties.java @@ -46,6 +46,9 @@ import java.util.function.BiConsumer; import java.util.function.BiFunction; import java.util.function.Function; +import sun.nio.cs.ISO_8859_1; +import sun.nio.cs.UTF_8; + import jdk.internal.access.SharedSecrets; import jdk.internal.misc.Unsafe; import jdk.internal.util.ArraysSupport; @@ -909,7 +912,7 @@ public class Properties extends Hashtable { public void store(OutputStream out, String comments) throws IOException { - store0(new BufferedWriter(new OutputStreamWriter(out, "8859_1")), + store0(new BufferedWriter(new OutputStreamWriter(out, ISO_8859_1.INSTANCE)), comments, true); } @@ -1001,7 +1004,7 @@ public class Properties extends Hashtable { public void storeToXML(OutputStream os, String comment) throws IOException { - storeToXML(os, comment, "UTF-8"); + storeToXML(os, comment, UTF_8.INSTANCE); } /** diff --git a/src/java.base/share/classes/java/util/PropertyResourceBundle.java b/src/java.base/share/classes/java/util/PropertyResourceBundle.java index a7055718c9a..48e800369e4 100644 --- a/src/java.base/share/classes/java/util/PropertyResourceBundle.java +++ b/src/java.base/share/classes/java/util/PropertyResourceBundle.java @@ -44,8 +44,8 @@ import java.io.InputStreamReader; import java.io.Reader; import java.io.IOException; import java.nio.charset.MalformedInputException; -import java.nio.charset.StandardCharsets; import java.nio.charset.UnmappableCharacterException; +import sun.nio.cs.ISO_8859_1; import sun.security.action.GetPropertyAction; import sun.util.PropertyResourceBundleCharset; import sun.util.ResourceBundleEnumeration; @@ -176,7 +176,7 @@ public class PropertyResourceBundle extends ResourceBundle { public PropertyResourceBundle (InputStream stream) throws IOException { this(new InputStreamReader(stream, "ISO-8859-1".equals(encoding) ? - StandardCharsets.ISO_8859_1.newDecoder() : + ISO_8859_1.INSTANCE.newDecoder() : new PropertyResourceBundleCharset("UTF-8".equals(encoding)).newDecoder())); } diff --git a/src/java.base/share/classes/java/util/ServiceLoader.java b/src/java.base/share/classes/java/util/ServiceLoader.java index c64d6de1df7..ae71fef86ec 100644 --- a/src/java.base/share/classes/java/util/ServiceLoader.java +++ b/src/java.base/share/classes/java/util/ServiceLoader.java @@ -45,6 +45,8 @@ import java.util.function.Supplier; import java.util.stream.Stream; import java.util.stream.StreamSupport; +import sun.nio.cs.UTF_8; + import jdk.internal.loader.BootLoader; import jdk.internal.loader.ClassLoaders; import jdk.internal.access.JavaLangAccess; @@ -55,7 +57,6 @@ import jdk.internal.module.ServicesCatalog.ServiceProvider; import jdk.internal.reflect.CallerSensitive; import jdk.internal.reflect.Reflection; - /** * A facility to load implementations of a service. * @@ -1164,7 +1165,7 @@ public final class ServiceLoader uc.setUseCaches(false); try (InputStream in = uc.getInputStream(); BufferedReader r - = new BufferedReader(new InputStreamReader(in, "utf-8"))) + = new BufferedReader(new InputStreamReader(in, UTF_8.INSTANCE))) { int lc = 1; while ((lc = parseLine(u, r, lc, names)) >= 0); diff --git a/src/java.base/share/classes/java/util/jar/Attributes.java b/src/java.base/share/classes/java/util/jar/Attributes.java index 1367be0c0f8..db8217dfbd8 100644 --- a/src/java.base/share/classes/java/util/jar/Attributes.java +++ b/src/java.base/share/classes/java/util/jar/Attributes.java @@ -36,9 +36,9 @@ import java.util.Set; import jdk.internal.misc.VM; import jdk.internal.vm.annotation.Stable; -import sun.util.logging.PlatformLogger; -import static java.nio.charset.StandardCharsets.UTF_8; +import sun.nio.cs.UTF_8; +import sun.util.logging.PlatformLogger; /** * The Attributes class maps Manifest attribute names to associated string @@ -337,7 +337,7 @@ public class Attributes implements Map, Cloneable { buffer.append(vername); buffer.append(": "); buffer.append(version); - out.write(buffer.toString().getBytes(UTF_8)); + out.write(buffer.toString().getBytes(UTF_8.INSTANCE)); Manifest.println(out); } @@ -399,7 +399,7 @@ public class Attributes implements Map, Cloneable { lastline = buf; continue; } - value = new String(buf, 0, buf.length, UTF_8); + value = new String(buf, 0, buf.length, UTF_8.INSTANCE); lastline = null; } else { while (lbuf[i++] != ':') { @@ -412,13 +412,13 @@ public class Attributes implements Map, Cloneable { throw new IOException("invalid header field (" + Manifest.getErrorPosition(filename, lineNumber) + ")"); } - name = new String(lbuf, 0, i - 2, UTF_8); + name = new String(lbuf, 0, i - 2, UTF_8.INSTANCE); if (is.peek() == ' ') { lastline = new byte[len - i]; System.arraycopy(lbuf, i, lastline, 0, len - i); continue; } - value = new String(lbuf, i, len - i, UTF_8); + value = new String(lbuf, i, len - i, UTF_8.INSTANCE); } try { if ((putValue(name, value) != null) && (!lineContinued)) { diff --git a/src/java.base/share/classes/java/util/jar/Manifest.java b/src/java.base/share/classes/java/util/jar/Manifest.java index bc747493907..fc2e5f03d88 100644 --- a/src/java.base/share/classes/java/util/jar/Manifest.java +++ b/src/java.base/share/classes/java/util/jar/Manifest.java @@ -33,10 +33,9 @@ import java.io.OutputStream; import java.util.HashMap; import java.util.Map; +import sun.nio.cs.UTF_8; import sun.security.util.SecurityProperties; -import static java.nio.charset.StandardCharsets.UTF_8; - /** * The Manifest class is used to maintain Manifest entry names and their * associated Attributes. There are main Manifest Attributes as well as @@ -237,7 +236,7 @@ public class Manifest implements Cloneable { */ static void println72(OutputStream out, String line) throws IOException { if (!line.isEmpty()) { - byte[] lineBytes = line.getBytes(UTF_8); + byte[] lineBytes = line.getBytes(UTF_8.INSTANCE); int length = lineBytes.length; // first line can hold one byte more than subsequent lines which // start with a continuation line break space @@ -337,7 +336,7 @@ public class Manifest implements Cloneable { lastline = buf; continue; } - name = new String(buf, 0, buf.length, UTF_8); + name = new String(buf, 0, buf.length, UTF_8.INSTANCE); lastline = null; } Attributes attr = getAttributes(name); @@ -362,11 +361,7 @@ public class Manifest implements Cloneable { if (toLower(lbuf[0]) == 'n' && toLower(lbuf[1]) == 'a' && toLower(lbuf[2]) == 'm' && toLower(lbuf[3]) == 'e' && lbuf[4] == ':' && lbuf[5] == ' ') { - try { - return new String(lbuf, 6, len - 6, UTF_8); - } - catch (Exception e) { - } + return new String(lbuf, 6, len - 6, UTF_8.INSTANCE); } return null; } diff --git a/src/java.base/share/classes/java/util/zip/ZipCoder.java b/src/java.base/share/classes/java/util/zip/ZipCoder.java index 8434c052ec2..d5a06292969 100644 --- a/src/java.base/share/classes/java/util/zip/ZipCoder.java +++ b/src/java.base/share/classes/java/util/zip/ZipCoder.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2009, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2009, 2019, 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 @@ -33,7 +33,7 @@ import java.nio.charset.CharsetEncoder; import java.nio.charset.CharacterCodingException; import java.nio.charset.CodingErrorAction; -import static java.nio.charset.StandardCharsets.UTF_8; +import sun.nio.cs.UTF_8; /** * Utility class for zipfile name and comment decoding and encoding @@ -67,10 +67,10 @@ class ZipCoder { } // UTF_8.ArrayEn/Decoder is stateless, so make it singleton. - private static ZipCoder utf8 = new UTF8(UTF_8); + private static ZipCoder utf8 = new UTF8(UTF_8.INSTANCE); public static ZipCoder get(Charset charset) { - if (charset == UTF_8) + if (charset == UTF_8.INSTANCE) return utf8; return new ZipCoder(charset); } diff --git a/src/java.base/share/classes/java/util/zip/ZipFile.java b/src/java.base/share/classes/java/util/zip/ZipFile.java index 6435f4691e7..274e8788d11 100644 --- a/src/java.base/share/classes/java/util/zip/ZipFile.java +++ b/src/java.base/share/classes/java/util/zip/ZipFile.java @@ -34,7 +34,6 @@ import java.io.RandomAccessFile; import java.io.UncheckedIOException; import java.lang.ref.Cleaner.Cleanable; import java.nio.charset.Charset; -import java.nio.charset.StandardCharsets; import java.nio.file.InvalidPathException; import java.nio.file.attribute.BasicFileAttributes; import java.nio.file.Files; @@ -65,6 +64,7 @@ import jdk.internal.misc.VM; import jdk.internal.perf.PerfCounter; import jdk.internal.ref.CleanerFactory; import jdk.internal.vm.annotation.Stable; +import sun.nio.cs.UTF_8; import static java.util.zip.ZipConstants64.*; import static java.util.zip.ZipUtils.*; @@ -165,7 +165,7 @@ public class ZipFile implements ZipConstants, Closeable { * @since 1.3 */ public ZipFile(File file, int mode) throws IOException { - this(file, mode, StandardCharsets.UTF_8); + this(file, mode, UTF_8.INSTANCE); } /** @@ -1042,7 +1042,7 @@ public class ZipFile implements ZipConstants, Closeable { for (int i = 0; i < names.length; i++) { int pos = zsrc.metanames[i]; names[i] = new String(cen, pos + CENHDR, CENNAM(cen, pos), - StandardCharsets.UTF_8); + UTF_8.INSTANCE); } return names; } diff --git a/src/java.base/share/classes/java/util/zip/ZipInputStream.java b/src/java.base/share/classes/java/util/zip/ZipInputStream.java index 0f335e25bec..f5a2b5eb034 100644 --- a/src/java.base/share/classes/java/util/zip/ZipInputStream.java +++ b/src/java.base/share/classes/java/util/zip/ZipInputStream.java @@ -30,7 +30,9 @@ import java.io.IOException; import java.io.EOFException; import java.io.PushbackInputStream; import java.nio.charset.Charset; -import java.nio.charset.StandardCharsets; + +import sun.nio.cs.UTF_8; + import static java.util.zip.ZipConstants64.*; import static java.util.zip.ZipUtils.*; @@ -77,7 +79,7 @@ public class ZipInputStream extends InflaterInputStream implements ZipConstants * @param in the actual input stream */ public ZipInputStream(InputStream in) { - this(in, StandardCharsets.UTF_8); + this(in, UTF_8.INSTANCE); } /** diff --git a/src/java.base/share/classes/java/util/zip/ZipOutputStream.java b/src/java.base/share/classes/java/util/zip/ZipOutputStream.java index 6b8802693a1..03672e590ad 100644 --- a/src/java.base/share/classes/java/util/zip/ZipOutputStream.java +++ b/src/java.base/share/classes/java/util/zip/ZipOutputStream.java @@ -28,11 +28,11 @@ package java.util.zip; import java.io.OutputStream; import java.io.IOException; import java.nio.charset.Charset; -import java.nio.charset.StandardCharsets; import java.util.Vector; import java.util.HashSet; import static java.util.zip.ZipConstants64.*; import static java.util.zip.ZipUtils.*; +import sun.nio.cs.UTF_8; import sun.security.action.GetPropertyAction; /** @@ -116,7 +116,7 @@ public class ZipOutputStream extends DeflaterOutputStream implements ZipConstant * @param out the actual output stream */ public ZipOutputStream(OutputStream out) { - this(out, StandardCharsets.UTF_8); + this(out, UTF_8.INSTANCE); } /** diff --git a/src/java.base/share/classes/jdk/internal/module/IllegalAccessMaps.java b/src/java.base/share/classes/jdk/internal/module/IllegalAccessMaps.java index 00ed66d2945..bec2841af83 100644 --- a/src/java.base/share/classes/jdk/internal/module/IllegalAccessMaps.java +++ b/src/java.base/share/classes/jdk/internal/module/IllegalAccessMaps.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2019, 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 @@ -24,6 +24,8 @@ */ package jdk.internal.module; +import sun.nio.cs.UTF_8; + import java.io.BufferedReader; import java.io.IOException; import java.io.InputStream; @@ -37,8 +39,6 @@ import java.util.HashSet; import java.util.Map; import java.util.Set; -import static java.nio.charset.StandardCharsets.*; - /** * Generates the maps of concealed and exported packages to open at run-time. * @@ -90,7 +90,9 @@ public class IllegalAccessMaps { if (in == null) { throw new InternalError(rn + " not found"); } - try (BufferedReader br = new BufferedReader(new InputStreamReader(in, UTF_8))) { + try (BufferedReader br = new BufferedReader( + new InputStreamReader(in, UTF_8.INSTANCE))) + { br.lines() .filter(line -> !line.isEmpty() && !line.startsWith("#")) .forEach(pn -> { diff --git a/src/java.base/share/classes/jdk/internal/module/ModulePath.java b/src/java.base/share/classes/jdk/internal/module/ModulePath.java index 0718336093b..0accaaeac03 100644 --- a/src/java.base/share/classes/jdk/internal/module/ModulePath.java +++ b/src/java.base/share/classes/jdk/internal/module/ModulePath.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2019, 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 @@ -61,6 +61,8 @@ import java.util.stream.Collectors; import java.util.zip.ZipException; import java.util.zip.ZipFile; +import sun.nio.cs.UTF_8; + import jdk.internal.jmod.JmodFile; import jdk.internal.jmod.JmodFile.Section; import jdk.internal.perf.PerfCounter; @@ -543,7 +545,7 @@ public class ModulePath implements ModuleFinder { List providerClasses = new ArrayList<>(); try (InputStream in = jf.getInputStream(entry)) { BufferedReader reader - = new BufferedReader(new InputStreamReader(in, "UTF-8")); + = new BufferedReader(new InputStreamReader(in, UTF_8.INSTANCE)); String cn; while ((cn = nextLine(reader)) != null) { if (!cn.isEmpty()) { diff --git a/src/java.base/share/classes/jdk/internal/perf/Perf.java b/src/java.base/share/classes/jdk/internal/perf/Perf.java index e660cdf3ebe..3cc7adea344 100644 --- a/src/java.base/share/classes/jdk/internal/perf/Perf.java +++ b/src/java.base/share/classes/jdk/internal/perf/Perf.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2002, 2006, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2002, 2019, 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 @@ -28,7 +28,9 @@ import java.nio.ByteBuffer; import java.security.Permission; import java.security.PrivilegedAction; import java.io.IOException; -import java.io.UnsupportedEncodingException; + +import sun.nio.cs.UTF_8; + import jdk.internal.ref.CleanerFactory; /** @@ -413,7 +415,7 @@ public final class Perf { public ByteBuffer createString(String name, int variability, int units, String value, int maxLength) { - byte[] v = getBytes(value); + byte[] v = value.getBytes(UTF_8.INSTANCE); byte[] v1 = new byte[v.length+1]; System.arraycopy(v, 0, v1, 0, v.length); v1[v.length] = '\0'; @@ -452,7 +454,7 @@ public final class Perf { public ByteBuffer createString(String name, int variability, int units, String value) { - byte[] v = getBytes(value); + byte[] v = value.getBytes(UTF_8.INSTANCE); byte[] v1 = new byte[v.length+1]; System.arraycopy(v, 0, v1, 0, v.length); v1[v.length] = '\0'; @@ -491,24 +493,6 @@ public final class Perf { int units, byte[] value, int maxLength); - - /** - * convert string to an array of UTF-8 bytes - */ - private static byte[] getBytes(String s) - { - byte[] bytes = null; - - try { - bytes = s.getBytes("UTF-8"); - } - catch (UnsupportedEncodingException e) { - // ignore, UTF-8 encoding is always known - } - - return bytes; - } - /** * Return the value of the High Resolution Counter. * diff --git a/src/java.base/share/classes/jdk/internal/util/jar/JarIndex.java b/src/java.base/share/classes/jdk/internal/util/jar/JarIndex.java index d41b09f5fce..2261ec28790 100644 --- a/src/java.base/share/classes/jdk/internal/util/jar/JarIndex.java +++ b/src/java.base/share/classes/jdk/internal/util/jar/JarIndex.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2019, 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 @@ -25,10 +25,13 @@ package jdk.internal.util.jar; +import sun.nio.cs.UTF_8; + import java.io.*; import java.util.*; import java.util.jar.*; import java.util.zip.*; + import static sun.security.action.GetPropertyAction.privilegedGetProperty; /** @@ -250,7 +253,7 @@ public class JarIndex { */ public void write(OutputStream out) throws IOException { BufferedWriter bw = new BufferedWriter - (new OutputStreamWriter(out, "UTF8")); + (new OutputStreamWriter(out, UTF_8.INSTANCE)); bw.write("JarIndex-Version: 1.0\n\n"); if (jarFiles != null) { @@ -280,7 +283,7 @@ public class JarIndex { */ public void read(InputStream is) throws IOException { BufferedReader br = new BufferedReader - (new InputStreamReader(is, "UTF8")); + (new InputStreamReader(is, UTF_8.INSTANCE)); String line = null; String currentJar = null; diff --git a/src/java.base/share/classes/sun/net/www/ParseUtil.java b/src/java.base/share/classes/sun/net/www/ParseUtil.java index 7b29128501c..f8963225348 100644 --- a/src/java.base/share/classes/sun/net/www/ParseUtil.java +++ b/src/java.base/share/classes/sun/net/www/ParseUtil.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2007, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2019, 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 @@ -26,19 +26,20 @@ package sun.net.www; import java.io.File; -import java.net.URL; import java.net.MalformedURLException; import java.net.URI; import java.net.URISyntaxException; +import java.net.URL; import java.nio.ByteBuffer; import java.nio.CharBuffer; import java.nio.charset.CharacterCodingException; - -import sun.nio.cs.ThreadLocalCoders; import java.nio.charset.CharsetDecoder; import java.nio.charset.CoderResult; import java.nio.charset.CodingErrorAction; +import sun.nio.cs.ThreadLocalCoders; +import sun.nio.cs.UTF_8; + /** * A class that contains useful routines common to sun.net.www * @author Mike McCloskey @@ -176,7 +177,7 @@ public final class ParseUtil { StringBuilder sb = new StringBuilder(n); ByteBuffer bb = ByteBuffer.allocate(n); CharBuffer cb = CharBuffer.allocate(n); - CharsetDecoder dec = ThreadLocalCoders.decoderFor("UTF-8") + CharsetDecoder dec = ThreadLocalCoders.decoderFor(UTF_8.INSTANCE) .onMalformedInput(CodingErrorAction.REPORT) .onUnmappableCharacter(CodingErrorAction.REPORT); @@ -496,7 +497,7 @@ public final class ParseUtil { private static void appendEncoded(StringBuilder sb, char c) { ByteBuffer bb = null; try { - bb = ThreadLocalCoders.encoderFor("UTF-8") + bb = ThreadLocalCoders.encoderFor(UTF_8.INSTANCE) .encode(CharBuffer.wrap("" + c)); } catch (CharacterCodingException x) { assert false; diff --git a/src/java.base/share/classes/sun/net/www/http/ChunkedInputStream.java b/src/java.base/share/classes/sun/net/www/http/ChunkedInputStream.java index 8f1eb192fb1..2c3d8ab2490 100644 --- a/src/java.base/share/classes/sun/net/www/http/ChunkedInputStream.java +++ b/src/java.base/share/classes/sun/net/www/http/ChunkedInputStream.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2019, 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 @@ -29,6 +29,7 @@ import java.util.*; import sun.net.*; import sun.net.www.*; +import sun.nio.cs.US_ASCII; /** * A ChunkedInputStream provides a stream for reading a body of @@ -307,7 +308,8 @@ class ChunkedInputStream extends InputStream implements Hurryable { /* * Extract the chunk size from the header (ignoring extensions). */ - String header = new String(rawData, rawPos, pos-rawPos+1, "US-ASCII"); + String header = new String(rawData, rawPos, pos-rawPos+1, + US_ASCII.INSTANCE); for (i=0; i < header.length(); i++) { if (Character.digit(header.charAt(i), 16) == -1) break; @@ -461,7 +463,8 @@ class ChunkedInputStream extends InputStream implements Hurryable { * Extract any tailers and append them to the message * headers. */ - String trailer = new String(rawData, rawPos, pos-rawPos, "US-ASCII"); + String trailer = new String(rawData, rawPos, pos-rawPos, + US_ASCII.INSTANCE); i = trailer.indexOf(':'); if (i == -1) { throw new IOException("Malformed tailer - format should be key:value"); diff --git a/src/java.base/share/classes/sun/net/www/http/ChunkedOutputStream.java b/src/java.base/share/classes/sun/net/www/http/ChunkedOutputStream.java index aa5040f33fe..f21bfbf6f65 100644 --- a/src/java.base/share/classes/sun/net/www/http/ChunkedOutputStream.java +++ b/src/java.base/share/classes/sun/net/www/http/ChunkedOutputStream.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2004, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2004, 2019, 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 @@ -26,6 +26,8 @@ package sun.net.www.http; import java.io.*; +import sun.nio.cs.US_ASCII; + /** * OutputStream that sends the output to the underlying stream using chunked * encoding as specified in RFC 2068. @@ -67,20 +69,15 @@ public class ChunkedOutputStream extends PrintStream { } /* return a header for a particular chunk size */ - private static byte[] getHeader(int size){ - try { - String hexStr = Integer.toHexString(size); - byte[] hexBytes = hexStr.getBytes("US-ASCII"); - byte[] header = new byte[getHeaderSize(size)]; - for (int i=0; iCachedRowSet interface. * @@ -2348,14 +2350,10 @@ public class CachedRowSetImpl extends BaseRowSet implements RowSet, RowSetIntern return null; } - try { - if (isString(RowSetMD.getColumnType(columnIndex))) { - asciiStream = new ByteArrayInputStream(((String)value).getBytes("ASCII")); - } else { - throw new SQLException(resBundle.handleGetObject("cachedrowsetimpl.dtypemismt").toString()); - } - } catch (java.io.UnsupportedEncodingException ex) { - throw new SQLException(ex.getMessage()); + if (isString(RowSetMD.getColumnType(columnIndex))) { + asciiStream = new ByteArrayInputStream(((String)value).getBytes(US_ASCII)); + } else { + throw new SQLException(resBundle.handleGetObject("cachedrowsetimpl.dtypemismt").toString()); } return asciiStream; diff --git a/test/jdk/java/lang/reflect/AccessibleObject/TrySetAccessibleTest.java b/test/jdk/java/lang/reflect/AccessibleObject/TrySetAccessibleTest.java index 923ca0b69da..7ef24b66c8b 100644 --- a/test/jdk/java/lang/reflect/AccessibleObject/TrySetAccessibleTest.java +++ b/test/jdk/java/lang/reflect/AccessibleObject/TrySetAccessibleTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2019, 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 @@ -25,6 +25,7 @@ * @test * @build TrySetAccessibleTest * @modules java.base/java.lang:open + * java.base/jdk.internal.module * java.base/jdk.internal.perf * java.base/jdk.internal.misc:+open * @run testng/othervm --illegal-access=deny TrySetAccessibleTest @@ -38,6 +39,7 @@ import java.lang.reflect.InvocationTargetException; import java.lang.reflect.Method; import jdk.internal.misc.Unsafe; +import jdk.internal.module.ModulePath; import jdk.internal.perf.Perf; import org.testng.annotations.Test; @@ -80,7 +82,7 @@ public class TrySetAccessibleTest { * Invoke a private method on a public class in an exported package */ public void testPrivateMethodInExportedPackage() throws Exception { - Method m = Perf.class.getDeclaredMethod("getBytes", String.class); + Method m = ModulePath.class.getDeclaredMethod("packageName", String.class); try { m.invoke(null); assertTrue(false);