8253497: Core Libs Terminology Refresh

Reviewed-by: naoto, kcr, rriggs, joehw, bpb, smarks, alanb
This commit is contained in:
Brent Christian 2020-12-16 23:09:20 +00:00
parent a244b82293
commit b2f035549a
15 changed files with 82 additions and 81 deletions

View File

@ -132,7 +132,7 @@ public class EquivMapsGenerator {
+ " A region/variant subtag \"" + preferred + " A region/variant subtag \"" + preferred
+ "\" is registered for more than one subtags."); + "\" is registered for more than one subtags.");
} }
} else { // language, extlang, grandfathered, and redundant } else { // language, extlang, legacy, and redundant
if (!initialLanguageMap.containsKey(preferred)) { if (!initialLanguageMap.containsKey(preferred)) {
sb = new StringBuilder(preferred); sb = new StringBuilder(preferred);
sb.append(','); sb.append(',');

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2016, 2019, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2016, 2020, 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
@ -64,7 +64,7 @@ import jdk.internal.util.StaticProperty;
* {@link Status#UNDECIDED UNDECIDED}. * {@link Status#UNDECIDED UNDECIDED}.
* Filters should be designed for the specific use case and expected types. * Filters should be designed for the specific use case and expected types.
* A filter designed for a particular use may be passed a class that is outside * A filter designed for a particular use may be passed a class that is outside
* of the scope of the filter. If the purpose of the filter is to black-list classes * of the scope of the filter. If the purpose of the filter is to reject classes
* then it can reject a candidate class that matches and report UNDECIDED for others. * then it can reject a candidate class that matches and report UNDECIDED for others.
* A filter may be called with class equals {@code null}, {@code arrayLength} equal -1, * A filter may be called with class equals {@code null}, {@code arrayLength} equal -1,
* the depth, number of references, and stream size and return a status * the depth, number of references, and stream size and return a status

View File

@ -1645,18 +1645,19 @@ public final class Locale implements Cloneable, Serializable {
* </pre></ul> * </pre></ul>
* *
* <p>This implements the 'Language-Tag' production of BCP47, and * <p>This implements the 'Language-Tag' production of BCP47, and
* so supports grandfathered (regular and irregular) as well as * so supports legacy (regular and irregular, referred to as
* "Type: grandfathered" in BCP47) as well as
* private use language tags. Stand alone private use tags are * private use language tags. Stand alone private use tags are
* represented as empty language and extension 'x-whatever', * represented as empty language and extension 'x-whatever',
* and grandfathered tags are converted to their canonical replacements * and legacy tags are converted to their canonical replacements
* where they exist. * where they exist.
* *
* <p>Grandfathered tags with canonical replacements are as follows: * <p>Legacy tags with canonical replacements are as follows:
* *
* <table class="striped"> * <table class="striped">
* <caption style="display:none">Grandfathered tags with canonical replacements</caption> * <caption style="display:none">Legacy tags with canonical replacements</caption>
* <thead style="text-align:center"> * <thead style="text-align:center">
* <tr><th scope="col" style="padding: 0 2px">grandfathered tag</th><th scope="col" style="padding: 0 2px">modern replacement</th></tr> * <tr><th scope="col" style="padding: 0 2px">legacy tag</th><th scope="col" style="padding: 0 2px">modern replacement</th></tr>
* </thead> * </thead>
* <tbody style="text-align:center"> * <tbody style="text-align:center">
* <tr><th scope="row">art-lojban</th><td>jbo</td></tr> * <tr><th scope="row">art-lojban</th><td>jbo</td></tr>
@ -1682,13 +1683,13 @@ public final class Locale implements Cloneable, Serializable {
* </tbody> * </tbody>
* </table> * </table>
* *
* <p>Grandfathered tags with no modern replacement will be * <p>Legacy tags with no modern replacement will be
* converted as follows: * converted as follows:
* *
* <table class="striped"> * <table class="striped">
* <caption style="display:none">Grandfathered tags with no modern replacement</caption> * <caption style="display:none">Legacy tags with no modern replacement</caption>
* <thead style="text-align:center"> * <thead style="text-align:center">
* <tr><th scope="col" style="padding: 0 2px">grandfathered tag</th><th scope="col" style="padding: 0 2px">converts to</th></tr> * <tr><th scope="col" style="padding: 0 2px">legacy tag</th><th scope="col" style="padding: 0 2px">converts to</th></tr>
* </thead> * </thead>
* <tbody style="text-align:center"> * <tbody style="text-align:center">
* <tr><th scope="row">cel-gaulish</th><td>xtg-x-cel-gaulish</td></tr> * <tr><th scope="row">cel-gaulish</th><td>xtg-x-cel-gaulish</td></tr>
@ -1700,7 +1701,7 @@ public final class Locale implements Cloneable, Serializable {
* </tbody> * </tbody>
* </table> * </table>
* *
* <p>For a list of all grandfathered tags, see the * <p>For a list of all legacy tags, see the
* IANA Language Subtag Registry (search for "Type: grandfathered"). * IANA Language Subtag Registry (search for "Type: grandfathered").
* *
* <p><b>Note</b>: there is no guarantee that {@code toLanguageTag} * <p><b>Note</b>: there is no guarantee that {@code toLanguageTag}
@ -2586,7 +2587,7 @@ public final class Locale implements Cloneable, Serializable {
* Resets the Builder to match the provided IETF BCP 47 * Resets the Builder to match the provided IETF BCP 47
* language tag. Discards the existing state. Null and the * language tag. Discards the existing state. Null and the
* empty string cause the builder to be reset, like {@link * empty string cause the builder to be reset, like {@link
* #clear}. Grandfathered tags (see {@link * #clear}. Legacy tags (see {@link
* Locale#forLanguageTag}) are converted to their canonical * Locale#forLanguageTag}) are converted to their canonical
* form before being processed. Otherwise, the language tag * form before being processed. Otherwise, the language tag
* must be well-formed (see {@link Locale}) or an exception is * must be well-formed (see {@link Locale}) or an exception is
@ -2838,7 +2839,7 @@ public final class Locale implements Cloneable, Serializable {
* on this builder. * on this builder.
* *
* <p>This applies the conversions listed in {@link Locale#forLanguageTag} * <p>This applies the conversions listed in {@link Locale#forLanguageTag}
* when constructing a Locale. (Grandfathered tags are handled in * when constructing a Locale. (Legacy tags are handled in
* {@link #setLanguageTag}.) * {@link #setLanguageTag}.)
* *
* @return A Locale. * @return A Locale.

View File

@ -847,7 +847,7 @@ public final class BootstrapLogger implements Logger, PlatformLogger.Bridge,
else return VM.isBooted(); else return VM.isBooted();
} }
// A bit of black magic. We try to find out the nature of the logging // A bit of magic. We try to find out the nature of the logging
// backend without actually loading it. // backend without actually loading it.
private static enum LoggingBackend { private static enum LoggingBackend {
// There is no LoggerFinder and JUL is not present // There is no LoggerFinder and JUL is not present

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2010, 2013, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2010, 2020, 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
@ -60,10 +60,10 @@ public class LanguageTag {
private List<String> variants = Collections.emptyList(); // variant subtags private List<String> variants = Collections.emptyList(); // variant subtags
private List<String> extensions = Collections.emptyList(); // extensions private List<String> extensions = Collections.emptyList(); // extensions
// Map contains grandfathered tags and its preferred mappings from // Map contains legacy language tags and its preferred mappings from
// http://www.ietf.org/rfc/rfc5646.txt // http://www.ietf.org/rfc/rfc5646.txt
// Keys are lower-case strings. // Keys are lower-case strings.
private static final Map<String, String[]> GRANDFATHERED = new HashMap<>(); private static final Map<String, String[]> LEGACY = new HashMap<>();
static { static {
// grandfathered = irregular ; non-redundant tags registered // grandfathered = irregular ; non-redundant tags registered
@ -127,7 +127,7 @@ public class LanguageTag {
{"zh-xiang", "hsn"}, {"zh-xiang", "hsn"},
}; };
for (String[] e : entries) { for (String[] e : entries) {
GRANDFATHERED.put(LocaleUtils.toLowerString(e[0]), e); LEGACY.put(LocaleUtils.toLowerString(e[0]), e);
} }
} }
@ -188,8 +188,8 @@ public class LanguageTag {
StringTokenIterator itr; StringTokenIterator itr;
// Check if the tag is grandfathered // Check if the tag is a legacy language tag
String[] gfmap = GRANDFATHERED.get(LocaleUtils.toLowerString(languageTag)); String[] gfmap = LEGACY.get(LocaleUtils.toLowerString(languageTag));
if (gfmap != null) { if (gfmap != null) {
// use preferred mapping // use preferred mapping
itr = new StringTokenIterator(gfmap[1], SEP); itr = new StringTokenIterator(gfmap[1], SEP);

View File

@ -132,7 +132,7 @@ public class RMIConnectorServer extends JMXConnectorServer {
* the serial form of any deserialized object. * the serial form of any deserialized object.
* The pattern must be in same format as used in * The pattern must be in same format as used in
* {@link java.io.ObjectInputFilter.Config#createFilter}. * {@link java.io.ObjectInputFilter.Config#createFilter}.
* It may define a white list of permitted classes, a black list of * It may define an allow-list of permitted classes, a reject-list of
* rejected classes, a maximum depth for the deserialized objects, * rejected classes, a maximum depth for the deserialized objects,
* etc. * etc.
* <p> * <p>
@ -149,7 +149,7 @@ public class RMIConnectorServer extends JMXConnectorServer {
* classes they use in their serial form. * classes they use in their serial form.
* <p> * <p>
* Care must be taken when defining such a filter, as defining * Care must be taken when defining such a filter, as defining
* a white list too restrictive or a too wide a black list may * an allow-list that is too narrow or a reject-list that is too wide may
* prevent legitimate clients from interoperating with the * prevent legitimate clients from interoperating with the
* {@code JMXConnectorServer}. * {@code JMXConnectorServer}.
*/ */

View File

@ -441,7 +441,7 @@ public class RegistryImpl extends java.rmi.server.RemoteServer
if (registryFilter != null) { if (registryFilter != null) {
ObjectInputFilter.Status status = registryFilter.checkInput(filterInfo); ObjectInputFilter.Status status = registryFilter.checkInput(filterInfo);
if (status != ObjectInputFilter.Status.UNDECIDED) { if (status != ObjectInputFilter.Status.UNDECIDED) {
// The Registry filter can override the built-in white-list // The Registry filter can override the built-in allow-list
return status; return status;
} }
} }

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 1996, 2016, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 1996, 2020, 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
@ -382,7 +382,7 @@ final class DGCImpl implements DGC {
if (dgcFilter != null) { if (dgcFilter != null) {
ObjectInputFilter.Status status = dgcFilter.checkInput(filterInfo); ObjectInputFilter.Status status = dgcFilter.checkInput(filterInfo);
if (status != ObjectInputFilter.Status.UNDECIDED) { if (status != ObjectInputFilter.Status.UNDECIDED) {
// The DGC filter can override the built-in white-list // The DGC filter can override the built-in allow-list
return status; return status;
} }
} }

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2000, 2014, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2000, 2020, 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
@ -62,7 +62,7 @@ public class Assert {
int[] switches = new int[7]; int[] switches = new int[7];
int switchSource = 0; int switchSource = 0;
if (args.length == 0) { // This is master version if (args.length == 0) { // This is the controller
// This code is for an exhaustive test // This code is for an exhaustive test
//while(switchSource < 2187) { //while(switchSource < 2187) {
@ -92,7 +92,7 @@ public class Assert {
new InputStreamReader(p.getInputStream())); new InputStreamReader(p.getInputStream()));
String outString = blah.readLine(); String outString = blah.readLine();
while (outString != null) { while (outString != null) {
System.out.println("from slave:"+outString); System.out.println("from BufferedReader:"+outString);
outString = blah.readLine(); outString = blah.readLine();
} }
} }

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2003, 2015, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2003, 2020, 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
@ -119,9 +119,9 @@ class SimpleOne {}
class SimpleTwo {} class SimpleTwo {}
class Chain { class Chain {
Slave slave = new Slave(); Worker worker = new Worker();
} }
class Slave {} class Worker {}
class LeftHand extends ClassLoader { class LeftHand extends ClassLoader {
public LeftHand() { public LeftHand() {

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2008, 2010, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2008, 2020, 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
@ -45,13 +45,13 @@ public class Lock {
static final Random rand = new Random(); static final Random rand = new Random();
public static void main(String[] args) throws Exception { public static void main(String[] args) throws Exception {
if (args.length > 0 && args[0].equals("-lockslave")) { if (args.length > 0 && args[0].equals("-lockworker")) {
int port = Integer.parseInt(args[1]); int port = Integer.parseInt(args[1]);
runLockSlave(port); runLockWorker(port);
System.exit(0); System.exit(0);
} }
LockSlaveMirror slave = startLockSlave(); LockWorkerMirror worker = startLockWorker();
try { try {
// create temporary file // create temporary file
@ -59,31 +59,31 @@ public class Lock {
blah.deleteOnExit(); blah.deleteOnExit();
// run tests // run tests
testLockProtocol(blah, slave); testLockProtocol(blah, worker);
testAsyncClose(blah, slave); testAsyncClose(blah, worker);
// eagerly clean-up // eagerly clean-up
blah.delete(); blah.delete();
} finally { } finally {
slave.shutdown(); worker.shutdown();
} }
} }
// test locking protocol // test locking protocol
static void testLockProtocol(File file, LockSlaveMirror slave) static void testLockProtocol(File file, LockWorkerMirror worker)
throws Exception throws Exception
{ {
FileLock fl; FileLock fl;
// slave VM opens file and acquires exclusive lock // worker VM opens file and acquires exclusive lock
slave.open(file.getPath()).lock(); worker.open(file.getPath()).lock();
AsynchronousFileChannel ch = AsynchronousFileChannel AsynchronousFileChannel ch = AsynchronousFileChannel
.open(file.toPath(), READ, WRITE); .open(file.toPath(), READ, WRITE);
// this VM tries to acquire lock // this VM tries to acquire lock
// (lock should not be acquire until released by slave VM) // (lock should not be acquire until released by worker VM)
Future<FileLock> result = ch.lock(); Future<FileLock> result = ch.lock();
try { try {
result.get(2, TimeUnit.SECONDS); result.get(2, TimeUnit.SECONDS);
@ -91,15 +91,15 @@ public class Lock {
} catch (TimeoutException x) { } catch (TimeoutException x) {
} }
// slave VM releases lock // worker VM releases lock
slave.unlock(); worker.unlock();
// this VM should now acquire lock // this VM should now acquire lock
fl = result.get(); fl = result.get();
fl.release(); fl.release();
// slave VM acquires lock on range // worker VM acquires lock on range
slave.lock(0, 10, false); worker.lock(0, 10, false);
// this VM acquires lock on non-overlapping range // this VM acquires lock on non-overlapping range
fl = ch.lock(10, 10, false).get(); fl = ch.lock(10, 10, false).get();
@ -107,19 +107,19 @@ public class Lock {
// done // done
ch.close(); ch.close();
slave.close(); worker.close();
} }
// test close of channel with outstanding lock operation // test close of channel with outstanding lock operation
static void testAsyncClose(File file, LockSlaveMirror slave) throws Exception { static void testAsyncClose(File file, LockWorkerMirror worker) throws Exception {
// slave VM opens file and acquires exclusive lock // worker VM opens file and acquires exclusive lock
slave.open(file.getPath()).lock(); worker.open(file.getPath()).lock();
for (int i=0; i<100; i++) { for (int i=0; i<100; i++) {
AsynchronousFileChannel ch = AsynchronousFileChannel AsynchronousFileChannel ch = AsynchronousFileChannel
.open(file.toPath(), READ, WRITE); .open(file.toPath(), READ, WRITE);
// try to lock file (should not complete because file is locked by slave) // try to lock file (should not complete because file is locked by worker)
Future<FileLock> result = ch.lock(); Future<FileLock> result = ch.lock();
try { try {
result.get(rand.nextInt(100), TimeUnit.MILLISECONDS); result.get(rand.nextInt(100), TimeUnit.MILLISECONDS);
@ -142,12 +142,12 @@ public class Lock {
} }
} }
slave.close(); worker.close();
} }
// starts a "lock slave" in another process, returning a mirror object to // starts a "lock worker" in another process, returning a mirror object to
// control the slave // control the worker
static LockSlaveMirror startLockSlave() throws Exception { static LockWorkerMirror startLockWorker() throws Exception {
ServerSocketChannel ssc = ServerSocketChannel.open() ServerSocketChannel ssc = ServerSocketChannel.open()
.bind(new InetSocketAddress(0)); .bind(new InetSocketAddress(0));
int port = ((InetSocketAddress)(ssc.getLocalAddress())).getPort(); int port = ((InetSocketAddress)(ssc.getLocalAddress())).getPort();
@ -159,29 +159,29 @@ public class Lock {
String testClasses = System.getProperty("test.classes"); String testClasses = System.getProperty("test.classes");
if (testClasses != null) if (testClasses != null)
command += " -cp " + testClasses; command += " -cp " + testClasses;
command += " Lock -lockslave " + port; command += " Lock -lockworker " + port;
Process p = Runtime.getRuntime().exec(command); Process p = Runtime.getRuntime().exec(command);
IOHandler.handle(p.getInputStream()); IOHandler.handle(p.getInputStream());
IOHandler.handle(p.getErrorStream()); IOHandler.handle(p.getErrorStream());
// wait for slave to connect // wait for worker to connect
SocketChannel sc = ssc.accept(); SocketChannel sc = ssc.accept();
return new LockSlaveMirror(sc); return new LockWorkerMirror(sc);
} }
// commands that the slave understands // commands that the worker understands
static final String OPEN_CMD = "open"; static final String OPEN_CMD = "open";
static final String CLOSE_CMD = "close"; static final String CLOSE_CMD = "close";
static final String LOCK_CMD = "lock"; static final String LOCK_CMD = "lock";
static final String UNLOCK_CMD = "unlock"; static final String UNLOCK_CMD = "unlock";
static final char TERMINATOR = ';'; static final char TERMINATOR = ';';
// provides a proxy to a "lock slave" // provides a proxy to a "lock worker"
static class LockSlaveMirror { static class LockWorkerMirror {
private final SocketChannel sc; private final SocketChannel sc;
LockSlaveMirror(SocketChannel sc) { LockWorkerMirror(SocketChannel sc) {
this.sc = sc; this.sc = sc;
} }
@ -207,7 +207,7 @@ public class Lock {
throw new RuntimeException("Terminated expected"); throw new RuntimeException("Terminated expected");
} }
LockSlaveMirror open(String file) throws IOException { LockWorkerMirror open(String file) throws IOException {
sendCommand(OPEN_CMD, file); sendCommand(OPEN_CMD, file);
return this; return this;
} }
@ -216,20 +216,20 @@ public class Lock {
sendCommand(CLOSE_CMD); sendCommand(CLOSE_CMD);
} }
LockSlaveMirror lock() throws IOException { LockWorkerMirror lock() throws IOException {
sendCommand(LOCK_CMD); sendCommand(LOCK_CMD);
return this; return this;
} }
LockSlaveMirror lock(long position, long size, boolean shared) LockWorkerMirror lock(long position, long size, boolean shared)
throws IOException throws IOException
{ {
sendCommand(LOCK_CMD, position + "," + size + "," + shared); sendCommand(LOCK_CMD, position + "," + size + "," + shared);
return this; return this;
} }
LockSlaveMirror unlock() throws IOException { LockWorkerMirror unlock() throws IOException {
sendCommand(UNLOCK_CMD); sendCommand(UNLOCK_CMD);
return this; return this;
} }
@ -268,8 +268,8 @@ public class Lock {
} }
} }
// slave process that responds to simple commands a socket connection // worker process that responds to simple commands a socket connection
static void runLockSlave(int port) throws Exception { static void runLockWorker(int port) throws Exception {
// establish connection to parent // establish connection to parent
SocketChannel sc = SocketChannel.open(new InetSocketAddress(port)); SocketChannel sc = SocketChannel.open(new InetSocketAddress(port));

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2005, 2019, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2005, 2020, 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,8 +42,8 @@ public class CloseRegisteredChannel {
SocketChannel client = SocketChannel.open (); SocketChannel client = SocketChannel.open ();
client.connect (new InetSocketAddress (InetAddress.getLoopbackAddress(), port)); client.connect (new InetSocketAddress (InetAddress.getLoopbackAddress(), port));
SocketChannel slave = server.accept (); SocketChannel peer = server.accept();
slave.configureBlocking (true); peer.configureBlocking(true);
Selector selector = Selector.open (); Selector selector = Selector.open ();
client.configureBlocking (false); client.configureBlocking (false);
@ -53,7 +53,7 @@ public class CloseRegisteredChannel {
client.close(); client.close();
//System.out.println ("client.isOpen = " + client.isOpen()); //System.out.println ("client.isOpen = " + client.isOpen());
System.out.println ("Will hang here..."); System.out.println ("Will hang here...");
int nb = slave.read (ByteBuffer.allocate (1024)); int nb = peer.read(ByteBuffer.allocate (1024));
//System.out.println("read nb=" + nb); //System.out.println("read nb=" + nb);
selector.close(); selector.close();

View File

@ -151,7 +151,7 @@ public class LSRDataTest {
+ " A region/variant subtag \"" + preferred + " A region/variant subtag \"" + preferred
+ "\" is registered for more than one subtags."); + "\" is registered for more than one subtags.");
} }
} else { // language, extlang, grandfathered, and redundant } else { // language, extlang, legacy, and redundant
if (!singleLangEquivMap.containsKey(preferred) if (!singleLangEquivMap.containsKey(preferred)
&& !multiLangEquivsMap.containsKey(preferred)) { && !multiLangEquivsMap.containsKey(preferred)) {
// new entry add it into single equiv map // new entry add it into single equiv map

View File

@ -504,7 +504,7 @@ public class LocaleEnhanceTest extends IntlTest {
public void testForLanguageTag() { public void testForLanguageTag() {
// forLanguageTag implements the 'Language-Tag' production of // forLanguageTag implements the 'Language-Tag' production of
// BCP47, so it handles private use and grandfathered tags, // BCP47, so it handles private use and legacy language tags,
// unlike locale builder. Tags listed below (except for the // unlike locale builder. Tags listed below (except for the
// sample private use tags) come from 4646bis Feb 29, 2009. // sample private use tags) come from 4646bis Feb 29, 2009.
@ -514,7 +514,7 @@ public class LocaleEnhanceTest extends IntlTest {
{ "x-a-b-c", "x-a-b-c" }, { "x-a-b-c", "x-a-b-c" },
{ "x-a-12345678", "x-a-12345678" }, { "x-a-12345678", "x-a-12345678" },
// grandfathered tags with preferred mappings // legacy language tags with preferred mappings
{ "i-ami", "ami" }, { "i-ami", "ami" },
{ "i-bnn", "bnn" }, { "i-bnn", "bnn" },
{ "i-hak", "hak" }, { "i-hak", "hak" },
@ -536,7 +536,7 @@ public class LocaleEnhanceTest extends IntlTest {
{ "zh-min-nan", "nan" }, { "zh-min-nan", "nan" },
{ "zh-xiang", "hsn" }, { "zh-xiang", "hsn" },
// grandfathered irregular tags, no preferred mappings, drop illegal fields // irregular legacy language tags, no preferred mappings, drop illegal fields
// from end. If no subtag is mappable, fallback to 'und' // from end. If no subtag is mappable, fallback to 'und'
{ "i-default", "en-x-i-default" }, { "i-default", "en-x-i-default" },
{ "i-enochian", "x-i-enochian" }, { "i-enochian", "x-i-enochian" },
@ -548,7 +548,7 @@ public class LocaleEnhanceTest extends IntlTest {
for (int i = 0; i < tests.length; ++i) { for (int i = 0; i < tests.length; ++i) {
String[] test = tests[i]; String[] test = tests[i];
Locale locale = Locale.forLanguageTag(test[0]); Locale locale = Locale.forLanguageTag(test[0]);
assertEquals("grandfathered case " + i, test[1], locale.toLanguageTag()); assertEquals("legacy language tag case " + i, test[1], locale.toLanguageTag());
} }
// forLanguageTag ignores everything past the first place it encounters // forLanguageTag ignores everything past the first place it encounters

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2016, 2018, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2016, 2020, 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
@ -238,7 +238,7 @@ public class DefaultAgentFilterTest {
boolean retry = false; boolean retry = false;
do { do {
try { try {
// blacklist String // filter DefaultAgentFilterTest$MyTestObject
testDefaultAgent("mgmt1.properties"); testDefaultAgent("mgmt1.properties");
System.out.println("----\tTest FAILED !!"); System.out.println("----\tTest FAILED !!");
throw new RuntimeException("---" + DefaultAgentFilterTest.class.getName() + " - No exception reported"); throw new RuntimeException("---" + DefaultAgentFilterTest.class.getName() + " - No exception reported");
@ -264,7 +264,7 @@ public class DefaultAgentFilterTest {
retry = false; retry = false;
do { do {
try { try {
// blacklist non-existent class // filter non-existent class
testDefaultAgent("mgmt2.properties"); testDefaultAgent("mgmt2.properties");
System.out.println("----\tTest PASSED !!"); System.out.println("----\tTest PASSED !!");
} catch (Exception ex) { } catch (Exception ex) {