8184665: Skip name and alias checks for standard Charsets
Reviewed-by: sherman, rriggs, forax
This commit is contained in:
parent
c67a6c326c
commit
17fad0eecc
@ -25,6 +25,11 @@
|
|||||||
|
|
||||||
package java.nio.charset;
|
package java.nio.charset;
|
||||||
|
|
||||||
|
import jdk.internal.misc.VM;
|
||||||
|
import sun.nio.cs.StandardCharsets;
|
||||||
|
import sun.nio.cs.ThreadLocalCoders;
|
||||||
|
import sun.security.action.GetPropertyAction;
|
||||||
|
|
||||||
import java.nio.ByteBuffer;
|
import java.nio.ByteBuffer;
|
||||||
import java.nio.CharBuffer;
|
import java.nio.CharBuffer;
|
||||||
import java.nio.charset.spi.CharsetProvider;
|
import java.nio.charset.spi.CharsetProvider;
|
||||||
@ -38,15 +43,11 @@ import java.util.Locale;
|
|||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.NoSuchElementException;
|
import java.util.NoSuchElementException;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
import java.util.Set;
|
|
||||||
import java.util.ServiceLoader;
|
|
||||||
import java.util.ServiceConfigurationError;
|
import java.util.ServiceConfigurationError;
|
||||||
|
import java.util.ServiceLoader;
|
||||||
|
import java.util.Set;
|
||||||
import java.util.SortedMap;
|
import java.util.SortedMap;
|
||||||
import java.util.TreeMap;
|
import java.util.TreeMap;
|
||||||
import jdk.internal.misc.VM;
|
|
||||||
import sun.nio.cs.StandardCharsets;
|
|
||||||
import sun.nio.cs.ThreadLocalCoders;
|
|
||||||
import sun.security.action.GetPropertyAction;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -635,10 +636,19 @@ public abstract class Charset
|
|||||||
* If the canonical name or any of the aliases are illegal
|
* If the canonical name or any of the aliases are illegal
|
||||||
*/
|
*/
|
||||||
protected Charset(String canonicalName, String[] aliases) {
|
protected Charset(String canonicalName, String[] aliases) {
|
||||||
checkName(canonicalName);
|
|
||||||
String[] as = Objects.requireNonNullElse(aliases, zeroAliases);
|
String[] as = Objects.requireNonNullElse(aliases, zeroAliases);
|
||||||
for (int i = 0; i < as.length; i++)
|
|
||||||
checkName(as[i]);
|
// Skip checks for the standard, built-in Charsets we always load
|
||||||
|
// during initialization. Use of identity is intentional to be
|
||||||
|
// consistent with sun.nio.cs.StandardCharsets
|
||||||
|
if (canonicalName != StandardCharsets.ISO_8859_1
|
||||||
|
&& canonicalName != StandardCharsets.US_ASCII
|
||||||
|
&& canonicalName != StandardCharsets.UTF_8) {
|
||||||
|
checkName(canonicalName);
|
||||||
|
for (int i = 0; i < as.length; i++) {
|
||||||
|
checkName(as[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
this.name = canonicalName;
|
this.name = canonicalName;
|
||||||
this.aliases = as;
|
this.aliases = as;
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -42,7 +42,7 @@ class ISO_8859_1
|
|||||||
{
|
{
|
||||||
|
|
||||||
public ISO_8859_1() {
|
public ISO_8859_1() {
|
||||||
super("ISO-8859-1", StandardCharsets.aliases_ISO_8859_1);
|
super(StandardCharsets.ISO_8859_1, StandardCharsets.aliases_ISO_8859_1);
|
||||||
}
|
}
|
||||||
|
|
||||||
public String historicalName() {
|
public String historicalName() {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.
|
||||||
*
|
*
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
@ -51,6 +51,12 @@ public class StandardCharsets extends CharsetProvider {
|
|||||||
|
|
||||||
private static final String packagePrefix = "sun.nio.cs";
|
private static final String packagePrefix = "sun.nio.cs";
|
||||||
|
|
||||||
|
public static final String US_ASCII = "US-ASCII";
|
||||||
|
|
||||||
|
public static final String ISO_8859_1 = "ISO-8859-1";
|
||||||
|
|
||||||
|
public static final String UTF_8 = "UTF-8";
|
||||||
|
|
||||||
public StandardCharsets() {
|
public StandardCharsets() {
|
||||||
this.aliasMap = new Aliases();
|
this.aliasMap = new Aliases();
|
||||||
this.classMap = new Classes();
|
this.classMap = new Classes();
|
||||||
@ -103,13 +109,13 @@ public class StandardCharsets extends CharsetProvider {
|
|||||||
|
|
||||||
// As all charset class names added to classMap are string literals we
|
// As all charset class names added to classMap are string literals we
|
||||||
// can check identity here as an optimization
|
// can check identity here as an optimization
|
||||||
if (cln == "US_ASCII") {
|
if (cln == US_ASCII) {
|
||||||
return cache(csn, new US_ASCII());
|
return cache(csn, new US_ASCII());
|
||||||
}
|
}
|
||||||
if (cln == "ISO_8859_1") {
|
if (cln == ISO_8859_1) {
|
||||||
return cache(csn, new ISO_8859_1());
|
return cache(csn, new ISO_8859_1());
|
||||||
}
|
}
|
||||||
if (cln == "UTF_8") {
|
if (cln == UTF_8) {
|
||||||
return cache(csn, new UTF_8());
|
return cache(csn, new UTF_8());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2004, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -38,7 +38,7 @@ public class US_ASCII
|
|||||||
{
|
{
|
||||||
|
|
||||||
public US_ASCII() {
|
public US_ASCII() {
|
||||||
super("US-ASCII", StandardCharsets.aliases_US_ASCII);
|
super(StandardCharsets.US_ASCII, StandardCharsets.aliases_US_ASCII);
|
||||||
}
|
}
|
||||||
|
|
||||||
public String historicalName() {
|
public String historicalName() {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -57,7 +57,7 @@ import java.nio.charset.CodingErrorAction;
|
|||||||
class UTF_8 extends Unicode
|
class UTF_8 extends Unicode
|
||||||
{
|
{
|
||||||
public UTF_8() {
|
public UTF_8() {
|
||||||
super("UTF-8", StandardCharsets.aliases_UTF_8);
|
super(StandardCharsets.UTF_8, StandardCharsets.aliases_UTF_8);
|
||||||
}
|
}
|
||||||
|
|
||||||
public String historicalName() {
|
public String historicalName() {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2010, 2017, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -22,15 +22,12 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
/* @test
|
/* @test
|
||||||
* @bug 6330020
|
* @bug 6330020 8184665
|
||||||
* @summary Ensure Charset.forName/isSupport throws the correct exception
|
* @summary Ensure Charset.forName/isSupport throws the correct exception
|
||||||
* if the charset names passed in are illegal.
|
* if the charset names passed in are illegal.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import java.io.*;
|
|
||||||
import java.nio.*;
|
|
||||||
import java.nio.charset.*;
|
import java.nio.charset.*;
|
||||||
import java.util.*;
|
|
||||||
|
|
||||||
public class IllegalCharsetName {
|
public class IllegalCharsetName {
|
||||||
public static void main(String[] args) throws Exception {
|
public static void main(String[] args) throws Exception {
|
||||||
@ -59,5 +56,18 @@ public class IllegalCharsetName {
|
|||||||
} catch (IllegalCharsetNameException x) { //expected
|
} catch (IllegalCharsetNameException x) { //expected
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Standard charsets may bypass alias checking during startup, test that
|
||||||
|
// they're all well-behaved as a sanity test
|
||||||
|
checkAliases(StandardCharsets.ISO_8859_1);
|
||||||
|
checkAliases(StandardCharsets.US_ASCII);
|
||||||
|
checkAliases(StandardCharsets.UTF_8);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void checkAliases(Charset cs) {
|
||||||
|
for (String alias : cs.aliases()) {
|
||||||
|
Charset.forName(alias);
|
||||||
|
Charset.isSupported(alias);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user