RFR: JDK-8284726: Print active locale settings in hs_err reports and in VM.info

Kevin Walls kevinw at openjdk.java.net
Tue Apr 26 09:31:51 UTC 2022


On Tue, 12 Apr 2022 06:44:41 GMT, Thomas Stuefe <stuefe at openjdk.org> wrote:

> To analyze locale problems in native code - e.g. stemming from third-party code calling `setlocale(3)` - it would be useful to print the active locale settings in hs-err reports and in VM.info.
> 
> Patch notes: 
> - Posix is fuzzy about the exact role of LC_ALL. It defines LC_ALL as a way to set all locales in one go, but the implementation could still keep the individual categories separately and just let LC_ALL override the individual settings. Therefore I opted to print both, even though on glibc the information seems redundant.
> - Since this is Posix specific, callers require #ifndef _WIN32 in shared files. That's not nice, but the alternative would be an empty stub implementation for windows, which I find also unappealing.
> 
> Example output, Ubuntu 20.04:
> 
> Java started with LC_ALL=C:
> 
> thomas at starfish $ jcmd Simple VM.info | ack LC_
> LC_ALL=C
> LC_ALL=C
> LC_COLLATE=C
> LC_CTYPE=C
> LC_MESSAGES=C
> LC_MONETARY=C
> LC_NUMERIC=C
> LC_TIME=C
> 
> 
> Java started with my default system settings:
> 
> thomas at starfish $ jcmd Simple VM.info | ack LC_
> LC_ALL=LC_CTYPE=C;LC_NUMERIC=en_DK.UTF-8;LC_TIME=en_DK.UTF-8;LC_COLLATE=C;LC_MONETARY=en_DK.UTF-8;LC_MESSAGES=C;LC_PAPER=en_DK.UTF-8;LC_NAME=en_DK.UTF-8;LC_ADDRESS=en_DK.UTF-8;LC_TELEPHONE=en_DK.UTF-8;LC_MEASUREMENT=en_DK.UTF-8;LC_IDENTIFICATION=en_DK.UTF-8
> LC_COLLATE=C
> LC_CTYPE=C
> LC_MESSAGES=C
> LC_MONETARY=en_DK.UTF-8
> LC_NUMERIC=en_DK.UTF-8
> LC_TIME=en_DK.UTF-8

Do you want to separate them with a header?  ie. have print_active_locale do tty->print_cr "Active Local:" or similar, like when other info such as the environment is printed?  Currently they are separated from the env vars by a blank line, but maybe it's not clear they are not coming from the environment.

-------------

PR: https://git.openjdk.java.net/jdk/pull/8194


More information about the hotspot-dev mailing list