8253497: Core Libs Terminology Refresh
Reviewed-by: naoto, kcr, rriggs, joehw, bpb, smarks, alanb
This commit is contained in:
parent
a244b82293
commit
b2f035549a
@ -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(',');
|
||||||
|
@ -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
|
||||||
|
@ -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.
|
||||||
|
@ -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
|
||||||
|
@ -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);
|
||||||
|
@ -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}.
|
||||||
*/
|
*/
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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() {
|
||||||
|
@ -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));
|
||||||
|
@ -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();
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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) {
|
||||||
|
Loading…
Reference in New Issue
Block a user