8270490: Charset.forName() taking fallback default value

Reviewed-by: joehw, rriggs, serb, dfuchs
This commit is contained in:
Naoto Sato 2021-10-27 12:39:46 +00:00
parent a29273336b
commit 168081efc8
3 changed files with 109 additions and 8 deletions

View File

@ -582,17 +582,12 @@ public final class Console implements Flushable
csname = GetPropertyAction.privilegedGetProperty("sun.stdout.encoding"); csname = GetPropertyAction.privilegedGetProperty("sun.stdout.encoding");
} }
if (csname != null) { if (csname != null) {
try { cs = Charset.forName(csname, null);
cs = Charset.forName(csname);
} catch (Exception ignored) { }
} }
} }
if (cs == null) { if (cs == null) {
try { cs = Charset.forName(StaticProperty.nativeEncoding(),
cs = Charset.forName(StaticProperty.nativeEncoding()); Charset.defaultCharset());
} catch (Exception ignored) {
cs = Charset.defaultCharset();
}
} }
CHARSET = cs; CHARSET = cs;

View File

@ -527,6 +527,39 @@ public abstract class Charset
throw new UnsupportedCharsetException(charsetName); throw new UnsupportedCharsetException(charsetName);
} }
/**
* Returns a charset object for the named charset. If the charset object
* for the named charset is not available or {@code charsetName} is not a
* legal charset name, then {@code fallback} is returned.
*
* @param charsetName
* The name of the requested charset; may be either
* a canonical name or an alias
*
* @param fallback
* fallback charset in case the charset object for the named
* charset is not available or {@code charsetName} is not a legal
* charset name. May be {@code null}
*
* @return A charset object for the named charset, or {@code fallback}
* in case the charset object for the named charset is not
* available or {@code charsetName} is not a legal charset name
*
* @throws IllegalArgumentException
* If the given {@code charsetName} is {@code null}
*
* @since 18
*/
public static Charset forName(String charsetName,
Charset fallback) {
try {
Charset cs = lookup(charsetName);
return cs != null ? cs : fallback;
} catch (IllegalCharsetNameException icne) {
return fallback;
}
}
// Fold charsets from the given iterator into the given map, ignoring // Fold charsets from the given iterator into the given map, ignoring
// charsets whose names already have entries in the map. // charsets whose names already have entries in the map.
// //

View File

@ -0,0 +1,73 @@
/*
* Copyright (c) 2021, 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
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/* @test
* @summary Unit test for forName(String, Charset)
* @bug 8270490
* @modules jdk.charsets
* @run testng ForName
*/
import java.nio.charset.Charset;
import java.nio.charset.IllegalCharsetNameException;
import java.nio.charset.StandardCharsets;
import org.testng.annotations.DataProvider;
import org.testng.annotations.Test;
import static org.testng.Assert.assertEquals;
@Test
public class ForName {
@DataProvider
Object[][] params() {
return new Object[][] {
{"UTF-8", null, StandardCharsets.UTF_8},
{"UTF-8", StandardCharsets.US_ASCII, StandardCharsets.UTF_8},
{"windows-31j", StandardCharsets.US_ASCII, Charset.forName("windows-31j")},
{"foo", StandardCharsets.US_ASCII, StandardCharsets.US_ASCII},
{"foo", null, null},
{"\u3042", null, null},
{"\u3042", StandardCharsets.UTF_8, StandardCharsets.UTF_8},
};
}
@DataProvider
Object[][] paramsIAE() {
return new Object[][] {
{null, null},
{null, StandardCharsets.UTF_8},
};
}
@Test(dataProvider="params")
public void testForName_2arg(String name, Charset fallback, Charset expected) throws Exception {
var cs = Charset.forName(name, fallback);
assertEquals(cs, expected);
}
@Test(dataProvider="paramsIAE", expectedExceptions=IllegalArgumentException.class)
public void testForName_2arg_IAE(String name, Charset fallback) throws Exception {
Charset.forName(name, fallback);
}
}