From 4e96b310425de541675b28493fdbe195780623c3 Mon Sep 17 00:00:00 2001 From: Naoto Sato Date: Tue, 4 May 2021 17:30:14 +0000 Subject: [PATCH] 8265989: System property for the native character encoding name Reviewed-by: iris, joehw, rriggs --- .../share/classes/java/lang/System.java | 3 +++ .../jdk/internal/util/StaticProperty.java | 19 +++++++++++++++++-- .../jdk/internal/util/SystemProps.java | 11 ++++++----- test/jdk/java/lang/System/PropertyTest.java | 5 +++-- 4 files changed, 29 insertions(+), 9 deletions(-) diff --git a/src/java.base/share/classes/java/lang/System.java b/src/java.base/share/classes/java/lang/System.java index 7df68acd2a5..a037f09ef8c 100644 --- a/src/java.base/share/classes/java/lang/System.java +++ b/src/java.base/share/classes/java/lang/System.java @@ -699,6 +699,9 @@ public final class System { * User's home directory * {@systemProperty user.dir} * User's current working directory + * {@systemProperty native.encoding} + * Character encoding name derived from the host environment and/or + * the user's settings. Setting this system property has no effect. * * *

diff --git a/src/java.base/share/classes/jdk/internal/util/StaticProperty.java b/src/java.base/share/classes/jdk/internal/util/StaticProperty.java index d493f6653b2..5671f42dc46 100644 --- a/src/java.base/share/classes/jdk/internal/util/StaticProperty.java +++ b/src/java.base/share/classes/jdk/internal/util/StaticProperty.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018, 2020, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2018, 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 @@ -48,6 +48,7 @@ public final class StaticProperty { private static final String SUN_BOOT_LIBRARY_PATH; private static final String JDK_SERIAL_FILTER; private static final String JAVA_IO_TMPDIR; + private static final String NATIVE_ENCODING; private StaticProperty() {} @@ -61,6 +62,7 @@ public final class StaticProperty { JAVA_LIBRARY_PATH = getProperty(props, "java.library.path", ""); SUN_BOOT_LIBRARY_PATH = getProperty(props, "sun.boot.library.path", ""); JDK_SERIAL_FILTER = getProperty(props, "jdk.serialFilter", null); + NATIVE_ENCODING = getProperty(props, "native.encoding"); } private static String getProperty(Properties props, String key) { @@ -176,9 +178,22 @@ public final class StaticProperty { * in this method. The caller of this method should take care to ensure * that the returned property is not made accessible to untrusted code. * - * @return the {@code user.name} system property + * @return the {@code jdk.serialFilter} system property */ public static String jdkSerialFilter() { return JDK_SERIAL_FILTER; } + + /** + * Return the {@code native.encoding} system property. + * + * {@link SecurityManager#checkPropertyAccess} is NOT checked + * in this method. The caller of this method should take care to ensure + * that the returned property is not made accessible to untrusted code. + * + * @return the {@code native.encoding} system property + */ + public static String nativeEncoding() { + return NATIVE_ENCODING; + } } diff --git a/src/java.base/share/classes/jdk/internal/util/SystemProps.java b/src/java.base/share/classes/jdk/internal/util/SystemProps.java index d9d019975e4..bb4fd699450 100644 --- a/src/java.base/share/classes/jdk/internal/util/SystemProps.java +++ b/src/java.base/share/classes/jdk/internal/util/SystemProps.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2018, 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 @@ -63,12 +63,13 @@ public final class SystemProps { // Platform defined encoding cannot be overridden on the command line put(props, "sun.jnu.encoding", raw.propDefault(Raw._sun_jnu_encoding_NDX)); + var nativeEncoding = ((raw.propDefault(Raw._file_encoding_NDX) == null) + ? raw.propDefault(Raw._sun_jnu_encoding_NDX) + : raw.propDefault(Raw._file_encoding_NDX)); + put(props, "native.encoding", nativeEncoding); // Add properties that have not been overridden on the cmdline - putIfAbsent(props, "file.encoding", - ((raw.propDefault(Raw._file_encoding_NDX) == null) - ? raw.propDefault(Raw._sun_jnu_encoding_NDX) - : raw.propDefault(Raw._file_encoding_NDX))); + putIfAbsent(props, "file.encoding", nativeEncoding); // Use platform values if not overridden by a commandline -Dkey=value // In no particular order diff --git a/test/jdk/java/lang/System/PropertyTest.java b/test/jdk/java/lang/System/PropertyTest.java index 6fbd447e0ca..f70b2778dc3 100644 --- a/test/jdk/java/lang/System/PropertyTest.java +++ b/test/jdk/java/lang/System/PropertyTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2018, 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 @@ -40,7 +40,7 @@ import org.testng.annotations.Test; /* * @test - * @bug 4463345 4244670 8030781 + * @bug 4463345 4244670 8030781 8265989 * @summary Simple test of System getProperty, setProperty, clearProperty, * getProperties, and setProperties * @run testng/othervm PropertyTest @@ -80,6 +80,7 @@ public class PropertyTest { {"user.dir"}, {"java.runtime.version"}, {"java.runtime.name"}, + {"native.encoding"}, }; }