From 434bea45ac4dc0233f84c471caa6daf66d1ef4fa Mon Sep 17 00:00:00 2001 From: Paul Sandoz Date: Thu, 20 Jun 2013 10:45:46 +0200 Subject: [PATCH 001/127] 8016308: Updates to j.u.stream.Node/Nodes Co-authored-by: Brian Goetz Reviewed-by: mduigou --- .../share/classes/java/util/stream/Node.java | 343 ++++--- .../share/classes/java/util/stream/Nodes.java | 844 ++++++------------ .../classes/java/util/stream/SliceOps.java | 199 +++-- .../java/util/stream/DoubleNodeTest.java | 4 +- .../java/util/stream/IntNodeTest.java | 4 +- .../java/util/stream/LongNodeTest.java | 4 +- 6 files changed, 550 insertions(+), 848 deletions(-) diff --git a/jdk/src/share/classes/java/util/stream/Node.java b/jdk/src/share/classes/java/util/stream/Node.java index 3cd765a6922..bf4c2c6340a 100644 --- a/jdk/src/share/classes/java/util/stream/Node.java +++ b/jdk/src/share/classes/java/util/stream/Node.java @@ -104,6 +104,32 @@ interface Node { throw new IndexOutOfBoundsException(); } + /** + * Return a node describing a subsequence of the elements of this node, + * starting at the given inclusive start offset and ending at the given + * exclusive end offset. + * + * @param from The (inclusive) starting offset of elements to include, must + * be in range 0..count(). + * @param to The (exclusive) end offset of elements to include, must be + * in range 0..count(). + * @param generator A function to be used to create a new array, if needed, + * for reference nodes. + * @return the truncated node + */ + default Node truncate(long from, long to, IntFunction generator) { + if (from == 0 && to == count()) + return this; + Spliterator spliterator = spliterator(); + long size = to - from; + Node.Builder nodeBuilder = Nodes.builder(size, generator); + nodeBuilder.begin(size); + for (int i = 0; i < from && spliterator.tryAdvance(e -> { }); i++) { } + for (int i = 0; (i < size) && spliterator.tryAdvance(nodeBuilder); i++) { } + nodeBuilder.end(); + return nodeBuilder.build(); + } + /** * Provides an array view of the contents of this node. * @@ -192,19 +218,90 @@ interface Node { } } - /** - * Specialized {@code Node} for int elements - */ - interface OfInt extends Node { + public interface OfPrimitive, + T_NODE extends OfPrimitive> + extends Node { /** * {@inheritDoc} * - * @return a {@link Spliterator.OfInt} describing the elements of this - * node + * @return a {@link Spliterator.OfPrimitive} describing the elements of + * this node */ @Override - Spliterator.OfInt spliterator(); + T_SPLITR spliterator(); + + /** + * Traverses the elements of this node, and invoke the provided + * {@code action} with each element. + * + * @param action a consumer that is to be invoked with each + * element in this {@code Node.OfPrimitive} + */ + void forEach(T_CONS action); + + @Override + default T_NODE getChild(int i) { + throw new IndexOutOfBoundsException(); + } + + T_NODE truncate(long from, long to, IntFunction generator); + + /** + * {@inheritDoc} + * + * @implSpec the default implementation invokes the generator to create + * an instance of a boxed primitive array with a length of + * {@link #count()} and then invokes {@link #copyInto(T[], int)} with + * that array at an offset of 0. + */ + @Override + default T[] asArray(IntFunction generator) { + T[] boxed = generator.apply((int) count()); + copyInto(boxed, 0); + return boxed; + } + + /** + * Views this node as a primitive array. + * + *

Depending on the underlying implementation this may return a + * reference to an internal array rather than a copy. It is the callers + * responsibility to decide if either this node or the array is utilized + * as the primary reference for the data.

+ * + * @return an array containing the contents of this {@code Node} + */ + T_ARR asPrimitiveArray(); + + /** + * Creates a new primitive array. + * + * @param count the length of the primitive array. + * @return the new primitive array. + */ + T_ARR newArray(int count); + + /** + * Copies the content of this {@code Node} into a primitive array, + * starting at a given offset into the array. It is the caller's + * responsibility to ensure there is sufficient room in the array. + * + * @param array the array into which to copy the contents of this + * {@code Node} + * @param offset the starting offset within the array + * @throws IndexOutOfBoundsException if copying would cause access of + * data outside array bounds + * @throws NullPointerException if {@code array} is {@code null} + */ + void copyInto(T_ARR array, int offset); + } + + /** + * Specialized {@code Node} for int elements + */ + interface OfInt extends OfPrimitive { /** * {@inheritDoc} @@ -226,38 +323,13 @@ interface Node { } } - /** - * Traverses the elements of this node, and invoke the provided - * {@code IntConsumer} with each element. - * - * @param consumer a {@code IntConsumer} that is to be invoked with each - * element in this {@code Node} - */ - void forEach(IntConsumer consumer); - - /** - * {@inheritDoc} - * - * @implSpec the default implementation invokes the generator to create - * an instance of an Integer[] array with a length of {@link #count()} - * and then invokes {@link #copyInto(Integer[], int)} with that - * Integer[] array at an offset of 0. This is not efficient and it is - * recommended to invoke {@link #asPrimitiveArray()}. - */ - @Override - default Integer[] asArray(IntFunction generator) { - Integer[] boxed = generator.apply((int) count()); - copyInto(boxed, 0); - return boxed; - } - /** * {@inheritDoc} * * @implSpec the default implementation invokes {@link #asPrimitiveArray()} to * obtain an int[] array then and copies the elements from that int[] * array into the boxed Integer[] array. This is not efficient and it - * is recommended to invoke {@link #copyInto(int[], int)}. + * is recommended to invoke {@link #copyInto(Object, int)}. */ @Override default void copyInto(Integer[] boxed, int offset) { @@ -271,35 +343,23 @@ interface Node { } @Override - default Node.OfInt getChild(int i) { - throw new IndexOutOfBoundsException(); + default Node.OfInt truncate(long from, long to, IntFunction generator) { + if (from == 0 && to == count()) + return this; + long size = to - from; + Spliterator.OfInt spliterator = spliterator(); + Node.Builder.OfInt nodeBuilder = Nodes.intBuilder(size); + nodeBuilder.begin(size); + for (int i = 0; i < from && spliterator.tryAdvance((IntConsumer) e -> { }); i++) { } + for (int i = 0; (i < size) && spliterator.tryAdvance((IntConsumer) nodeBuilder); i++) { } + nodeBuilder.end(); + return nodeBuilder.build(); } - /** - * Views this node as an int[] array. - * - *

Depending on the underlying implementation this may return a - * reference to an internal array rather than a copy. It is the callers - * responsibility to decide if either this node or the array is utilized - * as the primary reference for the data.

- * - * @return an array containing the contents of this {@code Node} - */ - int[] asPrimitiveArray(); - - /** - * Copies the content of this {@code Node} into an int[] array, starting - * at a given offset into the array. It is the caller's responsibility - * to ensure there is sufficient room in the array. - * - * @param array the array into which to copy the contents of this - * {@code Node} - * @param offset the starting offset within the array - * @throws IndexOutOfBoundsException if copying would cause access of - * data outside array bounds - * @throws NullPointerException if {@code array} is {@code null} - */ - void copyInto(int[] array, int offset); + @Override + default int[] newArray(int count) { + return new int[count]; + } /** * {@inheritDoc} @@ -309,22 +369,12 @@ interface Node { default StreamShape getShape() { return StreamShape.INT_VALUE; } - } /** * Specialized {@code Node} for long elements */ - interface OfLong extends Node { - - /** - * {@inheritDoc} - * - * @return a {@link Spliterator.OfLong} describing the elements of this - * node - */ - @Override - Spliterator.OfLong spliterator(); + interface OfLong extends OfPrimitive { /** * {@inheritDoc} @@ -346,38 +396,13 @@ interface Node { } } - /** - * Traverses the elements of this node, and invoke the provided - * {@code LongConsumer} with each element. - * - * @param consumer a {@code LongConsumer} that is to be invoked with - * each element in this {@code Node} - */ - void forEach(LongConsumer consumer); - - /** - * {@inheritDoc} - * - * @implSpec the default implementation invokes the generator to create - * an instance of a Long[] array with a length of {@link #count()} and - * then invokes {@link #copyInto(Long[], int)} with that Long[] array at - * an offset of 0. This is not efficient and it is recommended to - * invoke {@link #asPrimitiveArray()}. - */ - @Override - default Long[] asArray(IntFunction generator) { - Long[] boxed = generator.apply((int) count()); - copyInto(boxed, 0); - return boxed; - } - /** * {@inheritDoc} * * @implSpec the default implementation invokes {@link #asPrimitiveArray()} * to obtain a long[] array then and copies the elements from that * long[] array into the boxed Long[] array. This is not efficient and - * it is recommended to invoke {@link #copyInto(long[], int)}. + * it is recommended to invoke {@link #copyInto(Object, int)}. */ @Override default void copyInto(Long[] boxed, int offset) { @@ -391,35 +416,23 @@ interface Node { } @Override - default Node.OfLong getChild(int i) { - throw new IndexOutOfBoundsException(); + default Node.OfLong truncate(long from, long to, IntFunction generator) { + if (from == 0 && to == count()) + return this; + long size = to - from; + Spliterator.OfLong spliterator = spliterator(); + Node.Builder.OfLong nodeBuilder = Nodes.longBuilder(size); + nodeBuilder.begin(size); + for (int i = 0; i < from && spliterator.tryAdvance((LongConsumer) e -> { }); i++) { } + for (int i = 0; (i < size) && spliterator.tryAdvance((LongConsumer) nodeBuilder); i++) { } + nodeBuilder.end(); + return nodeBuilder.build(); } - /** - * Views this node as a long[] array. - * - *

Depending on the underlying implementation this may return a - * reference to an internal array rather than a copy. It is the callers - * responsibility to decide if either this node or the array is utilized - * as the primary reference for the data. - * - * @return an array containing the contents of this {@code Node} - */ - long[] asPrimitiveArray(); - - /** - * Copies the content of this {@code Node} into a long[] array, starting - * at a given offset into the array. It is the caller's responsibility - * to ensure there is sufficient room in the array. - * - * @param array the array into which to copy the contents of this - * {@code Node} - * @param offset the starting offset within the array - * @throws IndexOutOfBoundsException if copying would cause access of - * data outside array bounds - * @throws NullPointerException if {@code array} is {@code null} - */ - void copyInto(long[] array, int offset); + @Override + default long[] newArray(int count) { + return new long[count]; + } /** * {@inheritDoc} @@ -429,23 +442,12 @@ interface Node { default StreamShape getShape() { return StreamShape.LONG_VALUE; } - - } /** * Specialized {@code Node} for double elements */ - interface OfDouble extends Node { - - /** - * {@inheritDoc} - * - * @return A {@link Spliterator.OfDouble} describing the elements of - * this node - */ - @Override - Spliterator.OfDouble spliterator(); + interface OfDouble extends OfPrimitive { /** * {@inheritDoc} @@ -467,40 +469,15 @@ interface Node { } } - /** - * Traverses the elements of this node, and invoke the provided - * {@code DoubleConsumer} with each element. - * - * @param consumer A {@code DoubleConsumer} that is to be invoked with - * each element in this {@code Node} - */ - void forEach(DoubleConsumer consumer); - // - /** - * {@inheritDoc} - * - * @implSpec the default implementation invokes the generator to create - * an instance of a Double[] array with a length of {@link #count()} and - * then invokes {@link #copyInto(Double[], int)} with that Double[] - * array at an offset of 0. This is not efficient and it is recommended - * to invoke {@link #asPrimitiveArray()}. - */ - @Override - default Double[] asArray(IntFunction generator) { - Double[] boxed = generator.apply((int) count()); - copyInto(boxed, 0); - return boxed; - } - /** * {@inheritDoc} * * @implSpec the default implementation invokes {@link #asPrimitiveArray()} * to obtain a double[] array then and copies the elements from that * double[] array into the boxed Double[] array. This is not efficient - * and it is recommended to invoke {@link #copyInto(double[], int)}. + * and it is recommended to invoke {@link #copyInto(Object, int)}. */ @Override default void copyInto(Double[] boxed, int offset) { @@ -514,35 +491,23 @@ interface Node { } @Override - default Node.OfDouble getChild(int i) { - throw new IndexOutOfBoundsException(); + default Node.OfDouble truncate(long from, long to, IntFunction generator) { + if (from == 0 && to == count()) + return this; + long size = to - from; + Spliterator.OfDouble spliterator = spliterator(); + Node.Builder.OfDouble nodeBuilder = Nodes.doubleBuilder(size); + nodeBuilder.begin(size); + for (int i = 0; i < from && spliterator.tryAdvance((DoubleConsumer) e -> { }); i++) { } + for (int i = 0; (i < size) && spliterator.tryAdvance((DoubleConsumer) nodeBuilder); i++) { } + nodeBuilder.end(); + return nodeBuilder.build(); } - /** - * Views this node as a double[] array. - * - *

Depending on the underlying implementation this may return a - * reference to an internal array rather than a copy. It is the callers - * responsibility to decide if either this node or the array is utilized - * as the primary reference for the data. - * - * @return an array containing the contents of this {@code Node} - */ - double[] asPrimitiveArray(); - - /** - * Copies the content of this {@code Node} into a double[] array, starting - * at a given offset into the array. It is the caller's responsibility - * to ensure there is sufficient room in the array. - * - * @param array the array into which to copy the contents of this - * {@code Node} - * @param offset the starting offset within the array - * @throws IndexOutOfBoundsException if copying would cause access of - * data outside array bounds - * @throws NullPointerException if {@code array} is {@code null} - */ - void copyInto(double[] array, int offset); + @Override + default double[] newArray(int count) { + return new double[count]; + } /** * {@inheritDoc} diff --git a/jdk/src/share/classes/java/util/stream/Nodes.java b/jdk/src/share/classes/java/util/stream/Nodes.java index e4ccfb96f9a..f79a88c470b 100644 --- a/jdk/src/share/classes/java/util/stream/Nodes.java +++ b/jdk/src/share/classes/java/util/stream/Nodes.java @@ -33,11 +33,13 @@ import java.util.Objects; import java.util.Spliterator; import java.util.Spliterators; import java.util.concurrent.CountedCompleter; +import java.util.function.BinaryOperator; import java.util.function.Consumer; import java.util.function.DoubleConsumer; import java.util.function.IntConsumer; import java.util.function.IntFunction; import java.util.function.LongConsumer; +import java.util.function.LongFunction; /** * Factory methods for constructing implementations of {@link Node} and @@ -97,131 +99,28 @@ final class Nodes { * * @param the type of elements of the concatenated node * @param shape the shape of the concatenated node to be created - * @param nodes the input nodes + * @param left the left input node + * @param right the right input node * @return a {@code Node} covering the elements of the input nodes * @throws IllegalStateException if all {@link Node} elements of the list * are an not instance of type supported by this factory. */ @SuppressWarnings("unchecked") - static Node conc(StreamShape shape, List> nodes) { - int size = nodes.size(); - if (size == 0) - return emptyNode(shape); - else if (size == 1) - return nodes.get(0); - else { - // Create a right-balanced tree when there are more that 2 nodes - switch (shape) { - case REFERENCE: { - List> refNodes = (List>) nodes; - ConcNode c = new ConcNode<>(refNodes.get(size - 2), refNodes.get(size - 1)); - for (int i = size - 3; i >= 0; i--) { - c = new ConcNode<>(refNodes.get(i), c); - } - return c; - } - case INT_VALUE: { - List intNodes = (List) nodes; - IntConcNode c = new IntConcNode(intNodes.get(size - 2), intNodes.get(size - 1)); - for (int i = size - 3; i >= 0; i--) { - c = new IntConcNode(intNodes.get(i), c); - } - return (Node) c; - } - case LONG_VALUE: { - List longNodes = (List) nodes; - LongConcNode c = new LongConcNode(longNodes.get(size - 2), longNodes.get(size - 1)); - for (int i = size - 3; i >= 0; i--) { - c = new LongConcNode(longNodes.get(i), c); - } - return (Node) c; - } - case DOUBLE_VALUE: { - List doubleNodes = (List) nodes; - DoubleConcNode c = new DoubleConcNode(doubleNodes.get(size - 2), doubleNodes.get(size - 1)); - for (int i = size - 3; i >= 0; i--) { - c = new DoubleConcNode(doubleNodes.get(i), c); - } - return (Node) c; - } - default: - throw new IllegalStateException("Unknown shape " + shape); - } - } - - } - - /** - * Truncate a {@link Node}, returning a node describing a subsequence of - * the contents of the input node. - * - * @param the type of elements of the input node and truncated node - * @param input the input node - * @param from the starting offset to include in the truncated node (inclusive) - * @param to the ending offset ot include in the truncated node (exclusive) - * @param generator the array factory (only used for reference nodes) - * @return the truncated node - */ - @SuppressWarnings("unchecked") - static Node truncateNode(Node input, long from, long to, IntFunction generator) { - StreamShape shape = input.getShape(); - long size = truncatedSize(input.count(), from, to); - if (size == 0) - return emptyNode(shape); - else if (from == 0 && to >= input.count()) - return input; - + static Node conc(StreamShape shape, Node left, Node right) { switch (shape) { - case REFERENCE: { - Spliterator spliterator = input.spliterator(); - Node.Builder nodeBuilder = Nodes.builder(size, generator); - nodeBuilder.begin(size); - for (int i = 0; i < from && spliterator.tryAdvance(e -> { }); i++) { } - for (int i = 0; (i < size) && spliterator.tryAdvance(nodeBuilder); i++) { } - nodeBuilder.end(); - return nodeBuilder.build(); - } - case INT_VALUE: { - Spliterator.OfInt spliterator = ((Node.OfInt) input).spliterator(); - Node.Builder.OfInt nodeBuilder = Nodes.intBuilder(size); - nodeBuilder.begin(size); - for (int i = 0; i < from && spliterator.tryAdvance((IntConsumer) e -> { }); i++) { } - for (int i = 0; (i < size) && spliterator.tryAdvance((IntConsumer) nodeBuilder); i++) { } - nodeBuilder.end(); - return (Node) nodeBuilder.build(); - } - case LONG_VALUE: { - Spliterator.OfLong spliterator = ((Node.OfLong) input).spliterator(); - Node.Builder.OfLong nodeBuilder = Nodes.longBuilder(size); - nodeBuilder.begin(size); - for (int i = 0; i < from && spliterator.tryAdvance((LongConsumer) e -> { }); i++) { } - for (int i = 0; (i < size) && spliterator.tryAdvance((LongConsumer) nodeBuilder); i++) { } - nodeBuilder.end(); - return (Node) nodeBuilder.build(); - } - case DOUBLE_VALUE: { - Spliterator.OfDouble spliterator = ((Node.OfDouble) input).spliterator(); - Node.Builder.OfDouble nodeBuilder = Nodes.doubleBuilder(size); - nodeBuilder.begin(size); - for (int i = 0; i < from && spliterator.tryAdvance((DoubleConsumer) e -> { }); i++) { } - for (int i = 0; (i < size) && spliterator.tryAdvance((DoubleConsumer) nodeBuilder); i++) { } - nodeBuilder.end(); - return (Node) nodeBuilder.build(); - } + case REFERENCE: + return new ConcNode<>(left, right); + case INT_VALUE: + return (Node) new ConcNode.OfInt((Node.OfInt) left, (Node.OfInt) right); + case LONG_VALUE: + return (Node) new ConcNode.OfLong((Node.OfLong) left, (Node.OfLong) right); + case DOUBLE_VALUE: + return (Node) new ConcNode.OfDouble((Node.OfDouble) left, (Node.OfDouble) right); default: throw new IllegalStateException("Unknown shape " + shape); } } - private static long truncatedSize(long size, long from, long to) { - if (from >= 0) - size = Math.max(0, size - from); - long limit = to - from; - if (limit >= 0) - size = Math.min(size, limit); - return size; - } - // Reference-based node methods /** @@ -422,7 +321,7 @@ final class Nodes { new SizedCollectorTask.OfRef<>(spliterator, helper, array).invoke(); return node(array); } else { - Node node = new CollectorTask<>(helper, generator, spliterator).invoke(); + Node node = new CollectorTask.OfRef<>(helper, generator, spliterator).invoke(); return flattenTree ? flatten(node, generator) : node; } } @@ -460,7 +359,7 @@ final class Nodes { return node(array); } else { - Node.OfInt node = new IntCollectorTask<>(helper, spliterator).invoke(); + Node.OfInt node = new CollectorTask.OfInt<>(helper, spliterator).invoke(); return flattenTree ? flattenInt(node) : node; } } @@ -498,7 +397,7 @@ final class Nodes { return node(array); } else { - Node.OfLong node = new LongCollectorTask<>(helper, spliterator).invoke(); + Node.OfLong node = new CollectorTask.OfLong<>(helper, spliterator).invoke(); return flattenTree ? flattenLong(node) : node; } } @@ -536,7 +435,7 @@ final class Nodes { return node(array); } else { - Node.OfDouble node = new DoubleCollectorTask<>(helper, spliterator).invoke(); + Node.OfDouble node = new CollectorTask.OfDouble<>(helper, spliterator).invoke(); return flattenTree ? flattenDouble(node) : node; } } @@ -763,8 +662,6 @@ final class Nodes { return curSize; } - // Traversable - @Override public void forEach(Consumer consumer) { for (int i = 0; i < curSize; i++) { @@ -829,13 +726,12 @@ final class Nodes { /** * Node class for an internal node with two or more children */ - static final class ConcNode implements Node { - private final Node left; - private final Node right; - + private static abstract class AbstractConcNode> implements Node { + protected final T_NODE left; + protected final T_NODE right; private final long size; - ConcNode(Node left, Node right) { + AbstractConcNode(T_NODE left, T_NODE right) { this.left = left; this.right = right; // The Node count will be required when the Node spliterator is @@ -845,25 +741,37 @@ final class Nodes { this.size = left.count() + right.count(); } - // Node - - @Override - public Spliterator spliterator() { - return new Nodes.InternalNodeSpliterator.OfRef<>(this); - } - @Override public int getChildCount() { return 2; } @Override - public Node getChild(int i) { + public T_NODE getChild(int i) { if (i == 0) return left; if (i == 1) return right; throw new IndexOutOfBoundsException(); } + @Override + public long count() { + return size; + } + } + + static final class ConcNode + extends AbstractConcNode> + implements Node { + + ConcNode(Node left, Node right) { + super(left, right); + } + + @Override + public Spliterator spliterator() { + return new Nodes.InternalNodeSpliterator.OfRef<>(this); + } + @Override public void copyInto(T[] array, int offset) { Objects.requireNonNull(array); @@ -878,17 +786,27 @@ final class Nodes { return array; } - @Override - public long count() { - return size; - } - @Override public void forEach(Consumer consumer) { left.forEach(consumer); right.forEach(consumer); } + @Override + public Node truncate(long from, long to, IntFunction generator) { + if (from == 0 && to == count()) + return this; + long leftCount = left.count(); + if (from >= leftCount) + return right.truncate(from - leftCount, to - leftCount, generator); + else if (to <= leftCount) + return left.truncate(from, to, generator); + else { + return Nodes.conc(getShape(), left.truncate(from, leftCount, generator), + right.truncate(0, to - leftCount, generator)); + } + } + @Override public String toString() { if (count() < 32) { @@ -897,12 +815,92 @@ final class Nodes { return String.format("ConcNode[size=%d]", count()); } } + + private abstract static class OfPrimitive, + T_NODE extends Node.OfPrimitive> + extends AbstractConcNode + implements Node.OfPrimitive { + + OfPrimitive(T_NODE left, T_NODE right) { + super(left, right); + } + + @Override + public void forEach(T_CONS consumer) { + left.forEach(consumer); + right.forEach(consumer); + } + + @Override + public void copyInto(T_ARR array, int offset) { + left.copyInto(array, offset); + right.copyInto(array, offset + (int) left.count()); + } + + @Override + public T_ARR asPrimitiveArray() { + T_ARR array = newArray((int) count()); + copyInto(array, 0); + return array; + } + + @Override + public String toString() { + if (count() < 32) + return String.format("%s[%s.%s]", this.getClass().getName(), left, right); + else + return String.format("%s[size=%d]", this.getClass().getName(), count()); + } + } + + static final class OfInt + extends ConcNode.OfPrimitive + implements Node.OfInt { + + OfInt(Node.OfInt left, Node.OfInt right) { + super(left, right); + } + + @Override + public Spliterator.OfInt spliterator() { + return new InternalNodeSpliterator.OfInt(this); + } + } + + static final class OfLong + extends ConcNode.OfPrimitive + implements Node.OfLong { + + OfLong(Node.OfLong left, Node.OfLong right) { + super(left, right); + } + + @Override + public Spliterator.OfLong spliterator() { + return new InternalNodeSpliterator.OfLong(this); + } + } + + static final class OfDouble + extends ConcNode.OfPrimitive + implements Node.OfDouble { + + OfDouble(Node.OfDouble left, Node.OfDouble right) { + super(left, right); + } + + @Override + public Spliterator.OfDouble spliterator() { + return new InternalNodeSpliterator.OfDouble(this); + } + } } /** Abstract class for spliterator for all internal node classes */ private static abstract class InternalNodeSpliterator, - N extends Node, C> + N extends Node> implements Spliterator { // Node we are pointing to // null if full traversal has occurred @@ -960,7 +958,7 @@ final class Nodes { return null; } - protected final boolean internalTryAdvance(C consumer) { + protected final boolean initTryAdvance() { if (curNode == null) return false; @@ -981,29 +979,12 @@ final class Nodes { else tryAdvanceSpliterator = lastNodeSpliterator; } - - boolean hasNext = tryAdvance(tryAdvanceSpliterator, consumer); - if (!hasNext) { - if (lastNodeSpliterator == null) { - // Advance to the spliterator of the next non-empty leaf node - Node leaf = findNextLeafNode(tryAdvanceStack); - if (leaf != null) { - tryAdvanceSpliterator = (S) leaf.spliterator(); - // Since the node is not-empty the spliterator can be advanced - return tryAdvance(tryAdvanceSpliterator, consumer); - } - } - // No more elements to traverse - curNode = null; - } - return hasNext; + return true; } - protected abstract boolean tryAdvance(S spliterator, C consumer); - @Override @SuppressWarnings("unchecked") - public S trySplit() { + public final S trySplit() { if (curNode == null || tryAdvanceSpliterator != null) return null; // Cannot split if fully or partially traversed else if (lastNodeSpliterator != null) @@ -1024,7 +1005,7 @@ final class Nodes { } @Override - public long estimateSize() { + public final long estimateSize() { if (curNode == null) return 0; @@ -1041,12 +1022,12 @@ final class Nodes { } @Override - public int characteristics() { + public final int characteristics() { return Spliterator.SIZED; } private static final class OfRef - extends InternalNodeSpliterator, Node, Consumer> { + extends InternalNodeSpliterator, Node> { OfRef(Node curNode) { super(curNode); @@ -1054,13 +1035,24 @@ final class Nodes { @Override public boolean tryAdvance(Consumer consumer) { - return internalTryAdvance(consumer); - } + if (!initTryAdvance()) + return false; - @Override - protected boolean tryAdvance(Spliterator spliterator, - Consumer consumer) { - return spliterator.tryAdvance(consumer); + boolean hasNext = tryAdvanceSpliterator.tryAdvance(consumer); + if (!hasNext) { + if (lastNodeSpliterator == null) { + // Advance to the spliterator of the next non-empty leaf node + Node leaf = findNextLeafNode(tryAdvanceStack); + if (leaf != null) { + tryAdvanceSpliterator = leaf.spliterator(); + // Since the node is not-empty the spliterator can be advanced + return tryAdvanceSpliterator.tryAdvance(consumer); + } + } + // No more elements to traverse + curNode = null; + } + return hasNext; } @Override @@ -1085,127 +1077,85 @@ final class Nodes { } } + private static abstract class OfPrimitive, + N extends Node.OfPrimitive> + extends InternalNodeSpliterator + implements Spliterator.OfPrimitive { + + OfPrimitive(N cur) { + super(cur); + } + + @Override + public boolean tryAdvance(T_CONS consumer) { + if (!initTryAdvance()) + return false; + + boolean hasNext = tryAdvanceSpliterator.tryAdvance(consumer); + if (!hasNext) { + if (lastNodeSpliterator == null) { + // Advance to the spliterator of the next non-empty leaf node + N leaf = findNextLeafNode(tryAdvanceStack); + if (leaf != null) { + tryAdvanceSpliterator = leaf.spliterator(); + // Since the node is not-empty the spliterator can be advanced + return tryAdvanceSpliterator.tryAdvance(consumer); + } + } + // No more elements to traverse + curNode = null; + } + return hasNext; + } + + @Override + public void forEachRemaining(T_CONS consumer) { + if (curNode == null) + return; + + if (tryAdvanceSpliterator == null) { + if (lastNodeSpliterator == null) { + Deque stack = initStack(); + N leaf; + while ((leaf = findNextLeafNode(stack)) != null) { + leaf.forEach(consumer); + } + curNode = null; + } + else + lastNodeSpliterator.forEachRemaining(consumer); + } + else + while(tryAdvance(consumer)) { } + } + } + private static final class OfInt - extends InternalNodeSpliterator + extends OfPrimitive implements Spliterator.OfInt { OfInt(Node.OfInt cur) { super(cur); } - - @Override - public boolean tryAdvance(IntConsumer consumer) { - return internalTryAdvance(consumer); - } - - @Override - protected boolean tryAdvance(Spliterator.OfInt spliterator, - IntConsumer consumer) { - return spliterator.tryAdvance(consumer); - } - - @Override - public void forEachRemaining(IntConsumer consumer) { - if (curNode == null) - return; - - if (tryAdvanceSpliterator == null) { - if (lastNodeSpliterator == null) { - Deque stack = initStack(); - Node.OfInt leaf; - while ((leaf = findNextLeafNode(stack)) != null) { - leaf.forEach(consumer); - } - curNode = null; - } - else - lastNodeSpliterator.forEachRemaining(consumer); - } - else - while(tryAdvance(consumer)) { } - } } private static final class OfLong - extends InternalNodeSpliterator + extends OfPrimitive implements Spliterator.OfLong { OfLong(Node.OfLong cur) { super(cur); } - - @Override - public boolean tryAdvance(LongConsumer consumer) { - return internalTryAdvance(consumer); - } - - @Override - protected boolean tryAdvance(Spliterator.OfLong spliterator, - LongConsumer consumer) { - return spliterator.tryAdvance(consumer); - } - - @Override - public void forEachRemaining(LongConsumer consumer) { - if (curNode == null) - return; - - if (tryAdvanceSpliterator == null) { - if (lastNodeSpliterator == null) { - Deque stack = initStack(); - Node.OfLong leaf; - while ((leaf = findNextLeafNode(stack)) != null) { - leaf.forEach(consumer); - } - curNode = null; - } - else - lastNodeSpliterator.forEachRemaining(consumer); - } - else - while(tryAdvance(consumer)) { } - } } private static final class OfDouble - extends InternalNodeSpliterator + extends OfPrimitive implements Spliterator.OfDouble { OfDouble(Node.OfDouble cur) { super(cur); } - - @Override - public boolean tryAdvance(DoubleConsumer consumer) { - return internalTryAdvance(consumer); - } - - @Override - protected boolean tryAdvance(Spliterator.OfDouble spliterator, - DoubleConsumer consumer) { - return spliterator.tryAdvance(consumer); - } - - @Override - public void forEachRemaining(DoubleConsumer consumer) { - if (curNode == null) - return; - - if (tryAdvanceSpliterator == null) { - if (lastNodeSpliterator == null) { - Deque stack = initStack(); - Node.OfDouble leaf; - while ((leaf = findNextLeafNode(stack)) != null) { - leaf.forEach(consumer); - } - curNode = null; - } - else - lastNodeSpliterator.forEachRemaining(consumer); - } - else - while(tryAdvance(consumer)) { } - } } } @@ -1330,47 +1280,6 @@ final class Nodes { private static final long[] EMPTY_LONG_ARRAY = new long[0]; private static final double[] EMPTY_DOUBLE_ARRAY = new double[0]; - private abstract static class AbstractPrimitiveConcNode> - implements Node { - final N left; - final N right; - final long size; - - AbstractPrimitiveConcNode(N left, N right) { - this.left = left; - this.right = right; - // The Node count will be required when the Node spliterator is - // obtained and it is cheaper to aggressively calculate bottom up as - // the tree is built rather than later on by traversing the tree - this.size = left.count() + right.count(); - } - - @Override - public int getChildCount() { - return 2; - } - - @Override - public N getChild(int i) { - if (i == 0) return left; - if (i == 1) return right; - throw new IndexOutOfBoundsException(); - } - - @Override - public long count() { - return size; - } - - @Override - public String toString() { - if (count() < 32) - return String.format("%s[%s.%s]", this.getClass().getName(), left, right); - else - return String.format("%s[size=%d]", this.getClass().getName(), count()); - } - } - private static class IntArrayNode implements Node.OfInt { final int[] array; int curSize; @@ -1535,105 +1444,6 @@ final class Nodes { } } - static final class IntConcNode - extends AbstractPrimitiveConcNode - implements Node.OfInt { - - IntConcNode(Node.OfInt left, Node.OfInt right) { - super(left, right); - } - - @Override - public void forEach(IntConsumer consumer) { - left.forEach(consumer); - right.forEach(consumer); - } - - @Override - public Spliterator.OfInt spliterator() { - return new InternalNodeSpliterator.OfInt(this); - } - - @Override - public void copyInto(int[] array, int offset) { - left.copyInto(array, offset); - right.copyInto(array, offset + (int) left.count()); - } - - @Override - public int[] asPrimitiveArray() { - int[] array = new int[(int) count()]; - copyInto(array, 0); - return array; - } - } - - static final class LongConcNode - extends AbstractPrimitiveConcNode - implements Node.OfLong { - - LongConcNode(Node.OfLong left, Node.OfLong right) { - super(left, right); - } - - @Override - public void forEach(LongConsumer consumer) { - left.forEach(consumer); - right.forEach(consumer); - } - - @Override - public Spliterator.OfLong spliterator() { - return new InternalNodeSpliterator.OfLong(this); - } - - @Override - public void copyInto(long[] array, int offset) { - left.copyInto(array, offset); - right.copyInto(array, offset + (int) left.count()); - } - - @Override - public long[] asPrimitiveArray() { - long[] array = new long[(int) count()]; - copyInto(array, 0); - return array; - } - } - - static final class DoubleConcNode - extends AbstractPrimitiveConcNode - implements Node.OfDouble { - - DoubleConcNode(Node.OfDouble left, Node.OfDouble right) { - super(left, right); - } - - @Override - public void forEach(DoubleConsumer consumer) { - left.forEach(consumer); - right.forEach(consumer); - } - - @Override - public Spliterator.OfDouble spliterator() { - return new InternalNodeSpliterator.OfDouble(this); - } - - @Override - public void copyInto(double[] array, int offset) { - left.copyInto(array, offset); - right.copyInto(array, offset + (int) left.count()); - } - - @Override - public double[] asPrimitiveArray() { - double[] array = new double[(int) count()]; - copyInto(array, 0); - return array; - } - } - private static final class IntFixedNodeBuilder extends IntArrayNode implements Node.Builder.OfInt { @@ -2245,23 +2055,25 @@ final class Nodes { } } - private static final class OfInt - extends ToArrayTask { - private final int[] array; + private static class OfPrimitive, + T_NODE extends Node.OfPrimitive> + extends ToArrayTask> { + private final T_ARR array; - private OfInt(Node.OfInt node, int[] array, int offset) { + private OfPrimitive(T_NODE node, T_ARR array, int offset) { super(node, offset); this.array = array; } - private OfInt(OfInt parent, Node.OfInt node, int offset) { + private OfPrimitive(OfPrimitive parent, T_NODE node, int offset) { super(parent, node, offset); this.array = parent.array; } @Override - OfInt makeChild(int childIndex, int offset) { - return new OfInt(this, node.getChild(childIndex), offset); + OfPrimitive makeChild(int childIndex, int offset) { + return new OfPrimitive<>(this, node.getChild(childIndex), offset); } @Override @@ -2270,198 +2082,98 @@ final class Nodes { } } + private static final class OfInt + extends OfPrimitive { + private OfInt(Node.OfInt node, int[] array, int offset) { + super(node, array, offset); + } + } + private static final class OfLong - extends ToArrayTask { - private final long[] array; - + extends OfPrimitive { private OfLong(Node.OfLong node, long[] array, int offset) { - super(node, offset); - this.array = array; - } - - private OfLong(OfLong parent, Node.OfLong node, int offset) { - super(parent, node, offset); - this.array = parent.array; - } - - @Override - OfLong makeChild(int childIndex, int offset) { - return new OfLong(this, node.getChild(childIndex), offset); - } - - @Override - void copyNodeToArray() { - node.copyInto(array, offset); + super(node, array, offset); } } private static final class OfDouble - extends ToArrayTask { - private final double[] array; - + extends OfPrimitive { private OfDouble(Node.OfDouble node, double[] array, int offset) { - super(node, offset); - this.array = array; - } - - private OfDouble(OfDouble parent, Node.OfDouble node, int offset) { - super(parent, node, offset); - this.array = parent.array; - } - - @Override - OfDouble makeChild(int childIndex, int offset) { - return new OfDouble(this, node.getChild(childIndex), offset); - } - - @Override - void copyNodeToArray() { - node.copyInto(array, offset); + super(node, array, offset); } } } - private static final class CollectorTask - extends AbstractTask, CollectorTask> { - private final PipelineHelper helper; - private final IntFunction generator; + private static class CollectorTask, T_BUILDER extends Node.Builder> + extends AbstractTask> { + protected final PipelineHelper helper; + protected final LongFunction builderFactory; + protected final BinaryOperator concFactory; CollectorTask(PipelineHelper helper, - IntFunction generator, - Spliterator spliterator) { + Spliterator spliterator, + LongFunction builderFactory, + BinaryOperator concFactory) { super(helper, spliterator); this.helper = helper; - this.generator = generator; + this.builderFactory = builderFactory; + this.concFactory = concFactory; } - CollectorTask(CollectorTask parent, Spliterator spliterator) { + CollectorTask(CollectorTask parent, + Spliterator spliterator) { super(parent, spliterator); helper = parent.helper; - generator = parent.generator; + builderFactory = parent.builderFactory; + concFactory = parent.concFactory; } @Override - protected CollectorTask makeChild(Spliterator spliterator) { + protected CollectorTask makeChild(Spliterator spliterator) { return new CollectorTask<>(this, spliterator); } @Override - protected Node doLeaf() { - Node.Builder builder - = builder(helper.exactOutputSizeIfKnown(spliterator), - generator); - return helper.wrapAndCopyInto(builder, spliterator).build(); + protected T_NODE doLeaf() { + T_BUILDER builder = builderFactory.apply(helper.exactOutputSizeIfKnown(spliterator)); + return (T_NODE) helper.wrapAndCopyInto(builder, spliterator).build(); } @Override public void onCompletion(CountedCompleter caller) { - if (!isLeaf()) { - setLocalResult(new ConcNode<>(leftChild.getLocalResult(), rightChild.getLocalResult())); - } + if (!isLeaf()) + setLocalResult(concFactory.apply(leftChild.getLocalResult(), rightChild.getLocalResult())); super.onCompletion(caller); } - } - private static final class IntCollectorTask - extends AbstractTask> { - private final PipelineHelper helper; - - IntCollectorTask(PipelineHelper helper, Spliterator spliterator) { - super(helper, spliterator); - this.helper = helper; - } - - IntCollectorTask(IntCollectorTask parent, Spliterator spliterator) { - super(parent, spliterator); - helper = parent.helper; - } - - @Override - protected IntCollectorTask makeChild(Spliterator spliterator) { - return new IntCollectorTask<>(this, spliterator); - } - - @Override - protected Node.OfInt doLeaf() { - Node.Builder.OfInt builder = intBuilder(helper.exactOutputSizeIfKnown(spliterator)); - return helper.wrapAndCopyInto(builder, spliterator).build(); - } - - @Override - public void onCompletion(CountedCompleter caller) { - if (!isLeaf()) { - setLocalResult(new IntConcNode(leftChild.getLocalResult(), rightChild.getLocalResult())); + private static final class OfRef + extends CollectorTask, Node.Builder> { + OfRef(PipelineHelper helper, + IntFunction generator, + Spliterator spliterator) { + super(helper, spliterator, s -> builder(s, generator), ConcNode::new); } - super.onCompletion(caller); - } - } - - private static final class LongCollectorTask - extends AbstractTask> { - private final PipelineHelper helper; - - LongCollectorTask(PipelineHelper helper, Spliterator spliterator) { - super(helper, spliterator); - this.helper = helper; } - LongCollectorTask(LongCollectorTask parent, Spliterator spliterator) { - super(parent, spliterator); - helper = parent.helper; - } - - @Override - protected LongCollectorTask makeChild(Spliterator spliterator) { - return new LongCollectorTask<>(this, spliterator); - } - - @Override - protected Node.OfLong doLeaf() { - Node.Builder.OfLong builder = longBuilder(helper.exactOutputSizeIfKnown(spliterator)); - return helper.wrapAndCopyInto(builder, spliterator).build(); - } - - @Override - public void onCompletion(CountedCompleter caller) { - if (!isLeaf()) { - setLocalResult(new LongConcNode(leftChild.getLocalResult(), rightChild.getLocalResult())); + private static final class OfInt + extends CollectorTask { + OfInt(PipelineHelper helper, Spliterator spliterator) { + super(helper, spliterator, Nodes::intBuilder, ConcNode.OfInt::new); } - super.onCompletion(caller); - } - } - - private static final class DoubleCollectorTask - extends AbstractTask> { - private final PipelineHelper helper; - - DoubleCollectorTask(PipelineHelper helper, Spliterator spliterator) { - super(helper, spliterator); - this.helper = helper; } - DoubleCollectorTask(DoubleCollectorTask parent, Spliterator spliterator) { - super(parent, spliterator); - helper = parent.helper; - } - - @Override - protected DoubleCollectorTask makeChild(Spliterator spliterator) { - return new DoubleCollectorTask<>(this, spliterator); - } - - @Override - protected Node.OfDouble doLeaf() { - Node.Builder.OfDouble builder - = doubleBuilder(helper.exactOutputSizeIfKnown(spliterator)); - return helper.wrapAndCopyInto(builder, spliterator).build(); - } - - @Override - public void onCompletion(CountedCompleter caller) { - if (!isLeaf()) { - setLocalResult(new DoubleConcNode(leftChild.getLocalResult(), rightChild.getLocalResult())); + private static final class OfLong + extends CollectorTask { + OfLong(PipelineHelper helper, Spliterator spliterator) { + super(helper, spliterator, Nodes::longBuilder, ConcNode.OfLong::new); + } + } + + private static final class OfDouble + extends CollectorTask { + OfDouble(PipelineHelper helper, Spliterator spliterator) { + super(helper, spliterator, Nodes::doubleBuilder, ConcNode.OfDouble::new); } - super.onCompletion(caller); } } } diff --git a/jdk/src/share/classes/java/util/stream/SliceOps.java b/jdk/src/share/classes/java/util/stream/SliceOps.java index 4dc26ce04c9..31c6bd82446 100644 --- a/jdk/src/share/classes/java/util/stream/SliceOps.java +++ b/jdk/src/share/classes/java/util/stream/SliceOps.java @@ -28,7 +28,10 @@ import java.util.ArrayList; import java.util.List; import java.util.Spliterator; import java.util.concurrent.CountedCompleter; +import java.util.function.DoubleConsumer; +import java.util.function.IntConsumer; import java.util.function.IntFunction; +import java.util.function.LongConsumer; /** * Factory for instances of a short-circuiting stateful intermediate operations @@ -352,7 +355,7 @@ final class SliceOps { else // This will create a tree of depth 1 and will not be a sub-tree // for leaf nodes within the require range - result = Nodes.conc(op.getOutputShape(), nodes); + result = conc(op.getOutputShape(), nodes); setLocalResult(result); } } @@ -418,94 +421,116 @@ final class SliceOps { if (skipLeft == 0 && skipRight == 0) return input; else { - return Nodes.truncateNode(input, skipLeft, thisNodeSize - skipRight, generator); + return truncateNode(input, skipLeft, thisNodeSize - skipRight, generator); } } + /** + * Truncate a {@link Node}, returning a node describing a subsequence of + * the contents of the input node. + * + * @param the type of elements of the input node and truncated node + * @param input the input node + * @param from the starting offset to include in the truncated node (inclusive) + * @param to the ending offset ot include in the truncated node (exclusive) + * @param generator the array factory (only used for reference nodes) + * @return the truncated node + */ + @SuppressWarnings("unchecked") + private static Node truncateNode(Node input, long from, long to, IntFunction generator) { + StreamShape shape = input.getShape(); + long size = truncatedSize(input.count(), from, to); + if (size == 0) + return Nodes.emptyNode(shape); + else if (from == 0 && to >= input.count()) + return input; + + switch (shape) { + case REFERENCE: { + Spliterator spliterator = input.spliterator(); + Node.Builder nodeBuilder = Nodes.builder(size, generator); + nodeBuilder.begin(size); + for (int i = 0; i < from && spliterator.tryAdvance(e -> { }); i++) { } + for (int i = 0; (i < size) && spliterator.tryAdvance(nodeBuilder); i++) { } + nodeBuilder.end(); + return nodeBuilder.build(); + } + case INT_VALUE: { + Spliterator.OfInt spliterator = ((Node.OfInt) input).spliterator(); + Node.Builder.OfInt nodeBuilder = Nodes.intBuilder(size); + nodeBuilder.begin(size); + for (int i = 0; i < from && spliterator.tryAdvance((IntConsumer) e -> { }); i++) { } + for (int i = 0; (i < size) && spliterator.tryAdvance((IntConsumer) nodeBuilder); i++) { } + nodeBuilder.end(); + return (Node) nodeBuilder.build(); + } + case LONG_VALUE: { + Spliterator.OfLong spliterator = ((Node.OfLong) input).spliterator(); + Node.Builder.OfLong nodeBuilder = Nodes.longBuilder(size); + nodeBuilder.begin(size); + for (int i = 0; i < from && spliterator.tryAdvance((LongConsumer) e -> { }); i++) { } + for (int i = 0; (i < size) && spliterator.tryAdvance((LongConsumer) nodeBuilder); i++) { } + nodeBuilder.end(); + return (Node) nodeBuilder.build(); + } + case DOUBLE_VALUE: { + Spliterator.OfDouble spliterator = ((Node.OfDouble) input).spliterator(); + Node.Builder.OfDouble nodeBuilder = Nodes.doubleBuilder(size); + nodeBuilder.begin(size); + for (int i = 0; i < from && spliterator.tryAdvance((DoubleConsumer) e -> { }); i++) { } + for (int i = 0; (i < size) && spliterator.tryAdvance((DoubleConsumer) nodeBuilder); i++) { } + nodeBuilder.end(); + return (Node) nodeBuilder.build(); + } + default: + throw new IllegalStateException("Unknown shape " + shape); + } + } + + private static long truncatedSize(long size, long from, long to) { + if (from >= 0) + size = Math.max(0, size - from); + long limit = to - from; + if (limit >= 0) + size = Math.min(size, limit); + return size; + } + + /** + * Produces a concatenated {@link Node} that has two or more children. + *

The count of the concatenated node is equal to the sum of the count + * of each child. Traversal of the concatenated node traverses the content + * of each child in encounter order of the list of children. Splitting a + * spliterator obtained from the concatenated node preserves the encounter + * order of the list of children. + * + *

The result may be a concatenated node, the input sole node if the size + * of the list is 1, or an empty node. + * + * @param the type of elements of the concatenated node + * @param shape the shape of the concatenated node to be created + * @param nodes the input nodes + * @return a {@code Node} covering the elements of the input nodes + * @throws IllegalStateException if all {@link Node} elements of the list + * are an not instance of type supported by this factory. + */ + @SuppressWarnings("unchecked") + private static Node conc(StreamShape shape, List> nodes) { + int size = nodes.size(); + if (size == 0) + return Nodes.emptyNode(shape); + else if (size == 1) + return nodes.get(0); + else { + // Create a right-balanced tree when there are more that 2 nodes + List> refNodes = (List>) nodes; + Node c = Nodes.conc(shape, refNodes.get(size - 2), refNodes.get(size - 1)); + for (int i = size - 3; i >= 0; i--) { + c = Nodes.conc(shape, refNodes.get(i), c); + } + return c; + } + } + } - // @@@ Currently unused -- optimization for when all sizes are known -// private static class SizedSliceTask extends AbstractShortCircuitTask, SizedSliceTask> { -// private final int targetOffset, targetSize; -// private final int offset, size; -// -// private SizedSliceTask(ParallelPipelineHelper helper, int offset, int size) { -// super(helper); -// targetOffset = offset; -// targetSize = size; -// this.offset = 0; -// this.size = spliterator.getSizeIfKnown(); -// } -// -// private SizedSliceTask(SizedSliceTask parent, Spliterator spliterator) { -// // Makes assumptions about order in which siblings are created and linked into parent! -// super(parent, spliterator); -// targetOffset = parent.targetOffset; -// targetSize = parent.targetSize; -// int siblingSizes = 0; -// for (SizedSliceTask sibling = parent.children; sibling != null; sibling = sibling.nextSibling) -// siblingSizes += sibling.size; -// size = spliterator.getSizeIfKnown(); -// offset = parent.offset + siblingSizes; -// } -// -// @Override -// protected SizedSliceTask makeChild(Spliterator spliterator) { -// return new SizedSliceTask<>(this, spliterator); -// } -// -// @Override -// protected Node getEmptyResult() { -// return Nodes.emptyNode(); -// } -// -// @Override -// public boolean taskCanceled() { -// if (offset > targetOffset+targetSize || offset+size < targetOffset) -// return true; -// else -// return super.taskCanceled(); -// } -// -// @Override -// protected Node doLeaf() { -// int skipLeft = Math.max(0, targetOffset - offset); -// int skipRight = Math.max(0, offset + size - (targetOffset + targetSize)); -// if (skipLeft == 0 && skipRight == 0) -// return helper.into(Nodes.makeBuilder(spliterator.getSizeIfKnown())).build(); -// else { -// // If we're the first or last node that intersects the target range, peel off irrelevant elements -// int truncatedSize = size - skipLeft - skipRight; -// NodeBuilder builder = Nodes.makeBuilder(truncatedSize); -// Sink wrappedSink = helper.wrapSink(builder); -// wrappedSink.begin(truncatedSize); -// Iterator iterator = spliterator.iterator(); -// for (int i=0; i caller) { -// if (!isLeaf()) { -// Node result = null; -// for (SizedSliceTask child = children.nextSibling; child != null; child = child.nextSibling) { -// Node childResult = child.getRawResult(); -// if (childResult == null) -// continue; -// else if (result == null) -// result = childResult; -// else -// result = Nodes.node(result, childResult); -// } -// setRawResult(result); -// if (offset <= targetOffset && offset+size >= targetOffset+targetSize) -// shortCircuit(result); -// } -// } -// } - } diff --git a/jdk/test/java/util/stream/boottest/java/util/stream/DoubleNodeTest.java b/jdk/test/java/util/stream/boottest/java/util/stream/DoubleNodeTest.java index f0d5380984d..23eee7d749a 100644 --- a/jdk/test/java/util/stream/boottest/java/util/stream/DoubleNodeTest.java +++ b/jdk/test/java/util/stream/boottest/java/util/stream/DoubleNodeTest.java @@ -102,7 +102,7 @@ public class DoubleNodeTest extends OpTestCase { double i = it.nextDouble(); if (it.hasNext()) { - return new Nodes.DoubleConcNode(Nodes.node(new double[] {i}), degenerateTree(it)); + return new Nodes.ConcNode.OfDouble(Nodes.node(new double[] {i}), degenerateTree(it)); } else { return Nodes.node(new double[] {i}); @@ -114,7 +114,7 @@ public class DoubleNodeTest extends OpTestCase { return m.apply(l); } else { - return new Nodes.DoubleConcNode( + return new Nodes.ConcNode.OfDouble( tree(l.subList(0, l.size() / 2), m), tree(l.subList(l.size() / 2, l.size()), m)); } diff --git a/jdk/test/java/util/stream/boottest/java/util/stream/IntNodeTest.java b/jdk/test/java/util/stream/boottest/java/util/stream/IntNodeTest.java index 7b91f8ea8ad..17e50bb1e03 100644 --- a/jdk/test/java/util/stream/boottest/java/util/stream/IntNodeTest.java +++ b/jdk/test/java/util/stream/boottest/java/util/stream/IntNodeTest.java @@ -102,7 +102,7 @@ public class IntNodeTest extends OpTestCase { int i = it.nextInt(); if (it.hasNext()) { - return new Nodes.IntConcNode(Nodes.node(new int[] {i}), degenerateTree(it)); + return new Nodes.ConcNode.OfInt(Nodes.node(new int[] {i}), degenerateTree(it)); } else { return Nodes.node(new int[] {i}); @@ -114,7 +114,7 @@ public class IntNodeTest extends OpTestCase { return m.apply(l); } else { - return new Nodes.IntConcNode( + return new Nodes.ConcNode.OfInt( tree(l.subList(0, l.size() / 2), m), tree(l.subList(l.size() / 2, l.size()), m)); } diff --git a/jdk/test/java/util/stream/boottest/java/util/stream/LongNodeTest.java b/jdk/test/java/util/stream/boottest/java/util/stream/LongNodeTest.java index 877517ebd6f..6d1392316ce 100644 --- a/jdk/test/java/util/stream/boottest/java/util/stream/LongNodeTest.java +++ b/jdk/test/java/util/stream/boottest/java/util/stream/LongNodeTest.java @@ -102,7 +102,7 @@ public class LongNodeTest extends OpTestCase { long i = it.nextLong(); if (it.hasNext()) { - return new Nodes.LongConcNode(Nodes.node(new long[] {i}), degenerateTree(it)); + return new Nodes.ConcNode.OfLong(Nodes.node(new long[] {i}), degenerateTree(it)); } else { return Nodes.node(new long[] {i}); @@ -114,7 +114,7 @@ public class LongNodeTest extends OpTestCase { return m.apply(l); } else { - return new Nodes.LongConcNode( + return new Nodes.ConcNode.OfLong( tree(l.subList(0, l.size() / 2), m), tree(l.subList(l.size() / 2, l.size()), m)); } From ae0d33346e0e96f888d1e377509a125551df0c5c Mon Sep 17 00:00:00 2001 From: Brian Goetz Date: Thu, 20 Jun 2013 11:02:28 +0200 Subject: [PATCH 002/127] 8016324: filter/flatMap pipeline sinks should pass size information to downstream sink Reviewed-by: chegar, mduigou --- .../java/util/stream/DoublePipeline.java | 11 +++++++ .../classes/java/util/stream/IntPipeline.java | 11 +++++++ .../java/util/stream/LongPipeline.java | 11 +++++++ .../java/util/stream/ReferencePipeline.java | 29 +++++++++++++++++++ 4 files changed, 62 insertions(+) diff --git a/jdk/src/share/classes/java/util/stream/DoublePipeline.java b/jdk/src/share/classes/java/util/stream/DoublePipeline.java index c934445b8f0..52fd60f4163 100644 --- a/jdk/src/share/classes/java/util/stream/DoublePipeline.java +++ b/jdk/src/share/classes/java/util/stream/DoublePipeline.java @@ -258,6 +258,12 @@ abstract class DoublePipeline @Override Sink opWrapSink(int flags, Sink sink) { return new Sink.ChainedDouble(sink) { + @Override + public void begin(long size) { + downstream.begin(-1); + } + + @Override public void accept(double t) { // We can do better that this too; optimize for depth=0 case and just grab spliterator and forEach it DoubleStream result = mapper.apply(t); @@ -289,6 +295,11 @@ abstract class DoublePipeline @Override Sink opWrapSink(int flags, Sink sink) { return new Sink.ChainedDouble(sink) { + @Override + public void begin(long size) { + downstream.begin(-1); + } + @Override public void accept(double t) { if (predicate.test(t)) diff --git a/jdk/src/share/classes/java/util/stream/IntPipeline.java b/jdk/src/share/classes/java/util/stream/IntPipeline.java index aa7155abbde..10cfb890719 100644 --- a/jdk/src/share/classes/java/util/stream/IntPipeline.java +++ b/jdk/src/share/classes/java/util/stream/IntPipeline.java @@ -294,6 +294,12 @@ abstract class IntPipeline @Override Sink opWrapSink(int flags, Sink sink) { return new Sink.ChainedInt(sink) { + @Override + public void begin(long size) { + downstream.begin(-1); + } + + @Override public void accept(int t) { // We can do better that this too; optimize for depth=0 case and just grab spliterator and forEach it IntStream result = mapper.apply(t); @@ -325,6 +331,11 @@ abstract class IntPipeline @Override Sink opWrapSink(int flags, Sink sink) { return new Sink.ChainedInt(sink) { + @Override + public void begin(long size) { + downstream.begin(-1); + } + @Override public void accept(int t) { if (predicate.test(t)) diff --git a/jdk/src/share/classes/java/util/stream/LongPipeline.java b/jdk/src/share/classes/java/util/stream/LongPipeline.java index 9cbc9785be4..e52a5cade16 100644 --- a/jdk/src/share/classes/java/util/stream/LongPipeline.java +++ b/jdk/src/share/classes/java/util/stream/LongPipeline.java @@ -275,6 +275,12 @@ abstract class LongPipeline @Override Sink opWrapSink(int flags, Sink sink) { return new Sink.ChainedLong(sink) { + @Override + public void begin(long size) { + downstream.begin(-1); + } + + @Override public void accept(long t) { // We can do better that this too; optimize for depth=0 case and just grab spliterator and forEach it LongStream result = mapper.apply(t); @@ -306,6 +312,11 @@ abstract class LongPipeline @Override Sink opWrapSink(int flags, Sink sink) { return new Sink.ChainedLong(sink) { + @Override + public void begin(long size) { + downstream.begin(-1); + } + @Override public void accept(long t) { if (predicate.test(t)) diff --git a/jdk/src/share/classes/java/util/stream/ReferencePipeline.java b/jdk/src/share/classes/java/util/stream/ReferencePipeline.java index 92a139fa618..6e3beca1f11 100644 --- a/jdk/src/share/classes/java/util/stream/ReferencePipeline.java +++ b/jdk/src/share/classes/java/util/stream/ReferencePipeline.java @@ -165,6 +165,11 @@ abstract class ReferencePipeline @Override Sink opWrapSink(int flags, Sink sink) { return new Sink.ChainedReference(sink) { + @Override + public void begin(long size) { + downstream.begin(-1); + } + @Override public void accept(P_OUT u) { if (predicate.test(u)) @@ -252,6 +257,12 @@ abstract class ReferencePipeline @Override Sink opWrapSink(int flags, Sink sink) { return new Sink.ChainedReference(sink) { + @Override + public void begin(long size) { + downstream.begin(-1); + } + + @Override public void accept(P_OUT u) { // We can do better that this too; optimize for depth=0 case and just grab spliterator and forEach it Stream result = mapper.apply(u); @@ -273,6 +284,12 @@ abstract class ReferencePipeline Sink opWrapSink(int flags, Sink sink) { return new Sink.ChainedReference(sink) { IntConsumer downstreamAsInt = downstream::accept; + @Override + public void begin(long size) { + downstream.begin(-1); + } + + @Override public void accept(P_OUT u) { // We can do better that this too; optimize for depth=0 case and just grab spliterator and forEach it IntStream result = mapper.apply(u); @@ -294,6 +311,12 @@ abstract class ReferencePipeline Sink opWrapSink(int flags, Sink sink) { return new Sink.ChainedReference(sink) { DoubleConsumer downstreamAsDouble = downstream::accept; + @Override + public void begin(long size) { + downstream.begin(-1); + } + + @Override public void accept(P_OUT u) { // We can do better that this too; optimize for depth=0 case and just grab spliterator and forEach it DoubleStream result = mapper.apply(u); @@ -315,6 +338,12 @@ abstract class ReferencePipeline Sink opWrapSink(int flags, Sink sink) { return new Sink.ChainedReference(sink) { LongConsumer downstreamAsLong = downstream::accept; + @Override + public void begin(long size) { + downstream.begin(-1); + } + + @Override public void accept(P_OUT u) { // We can do better that this too; optimize for depth=0 case and just grab spliterator and forEach it LongStream result = mapper.apply(u); From 6cb8fc5c5f2f56fd911104c80700dc3dd00ee2d2 Mon Sep 17 00:00:00 2001 From: Paul Sandoz Date: Thu, 20 Jun 2013 11:15:23 +0200 Subject: [PATCH 003/127] 8016455: Sync stream tests from lambda to tl Co-authored-by: Brian Goetz Reviewed-by: mduigou --- .../stream/IntStreamTestDataProvider.java | 1 - .../java/util/stream/LambdaTestHelpers.java | 2 +- .../java/util/stream/LoggingTestCase.java | 67 ++++++++ .../bootlib/java/util/stream/OpTestCase.java | 131 +++++++-------- .../util/stream/SpliteratorTestHelper.java | 6 +- .../java/util/stream/DoubleNodeTest.java | 14 ++ .../java/util/stream/IntNodeTest.java | 14 ++ .../java/util/stream/LongNodeTest.java | 14 ++ .../boottest/java/util/stream/NodeTest.java | 14 ++ .../java/util/stream/UnorderedTest.java | 2 - .../java/util/stream/DistinctOpTest.java | 1 - .../tests/java/util/stream/ForEachOpTest.java | 27 +++- .../tests/java/util/stream/GroupByOpTest.java | 13 +- .../java/util/stream/IntSliceOpTest.java | 5 + .../tests/java/util/stream/IntUniqOpTest.java | 1 - .../tests/java/util/stream/MatchOpTest.java | 145 +++++++++++------ .../tests/java/util/stream/RangeTest.java | 8 + .../java/util/stream/ReduceByOpTest.java | 5 +- .../java/util/stream/SequentialOpTest.java | 34 +++- .../tests/java/util/stream/SliceOpTest.java | 152 ++++++++++++------ .../java/util/stream/StreamLinkTest.java | 4 + .../util/stream/StreamSpliteratorTest.java | 44 +++-- .../java/util/stream/TabulatorsTest.java | 22 ++- .../tests/java/util/stream/ToArrayOpTest.java | 43 ++++- 24 files changed, 553 insertions(+), 216 deletions(-) create mode 100644 jdk/test/java/util/stream/bootlib/java/util/stream/LoggingTestCase.java diff --git a/jdk/test/java/util/stream/bootlib/java/util/stream/IntStreamTestDataProvider.java b/jdk/test/java/util/stream/bootlib/java/util/stream/IntStreamTestDataProvider.java index 2ddad65f539..dded670d167 100644 --- a/jdk/test/java/util/stream/bootlib/java/util/stream/IntStreamTestDataProvider.java +++ b/jdk/test/java/util/stream/bootlib/java/util/stream/IntStreamTestDataProvider.java @@ -129,7 +129,6 @@ public class IntStreamTestDataProvider { () -> IntStream.range(0, ints.length).spliterator())); spliterators.add(splitDescr("IntStream.intRangeClosed(0,l):" + name, () -> IntStream.rangeClosed(0, ints.length).spliterator())); - // Need more! } spliteratorTestData = spliterators.toArray(new Object[0][]); diff --git a/jdk/test/java/util/stream/bootlib/java/util/stream/LambdaTestHelpers.java b/jdk/test/java/util/stream/bootlib/java/util/stream/LambdaTestHelpers.java index f1d8ffe81c6..225cbf147f6 100644 --- a/jdk/test/java/util/stream/bootlib/java/util/stream/LambdaTestHelpers.java +++ b/jdk/test/java/util/stream/bootlib/java/util/stream/LambdaTestHelpers.java @@ -269,7 +269,7 @@ public class LambdaTestHelpers { Set uniq = new HashSet<>(); while(iter.hasNext()) { T each = iter.next(); - assertTrue(!uniq.contains(each)); + assertTrue(!uniq.contains(each), "Not unique"); uniq.add(each); } } diff --git a/jdk/test/java/util/stream/bootlib/java/util/stream/LoggingTestCase.java b/jdk/test/java/util/stream/bootlib/java/util/stream/LoggingTestCase.java new file mode 100644 index 00000000000..a0f221929ad --- /dev/null +++ b/jdk/test/java/util/stream/bootlib/java/util/stream/LoggingTestCase.java @@ -0,0 +1,67 @@ +/* + * Copyright (c) 2013, 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. + */ +package java.util.stream; + +import java.util.ArrayList; +import java.util.Collections; +import java.util.HashMap; +import java.util.List; +import java.util.Map; + +import org.testng.Assert; +import org.testng.ITestResult; +import org.testng.annotations.AfterMethod; +import org.testng.annotations.BeforeMethod; +import org.testng.annotations.Test; + +/** + * LoggingTestCase + * + */ +@Test +public class LoggingTestCase extends Assert { + private Map context = new HashMap<>(); + + @BeforeMethod + public void before() { + context.clear(); + } + + @AfterMethod + public void after(ITestResult result) { + if (!result.isSuccess()) { + List list = new ArrayList<>(); + Collections.addAll(list, result.getParameters()); + list.add(context.toString()); + result.setParameters(list.toArray(new Object[list.size()])); + } + } + + protected void setContext(String key, Object value) { + context.put(key, value); + } + + protected void clearContext(String key) { + context.remove(key); + } +} diff --git a/jdk/test/java/util/stream/bootlib/java/util/stream/OpTestCase.java b/jdk/test/java/util/stream/bootlib/java/util/stream/OpTestCase.java index 763b8838b5d..84a574480b5 100644 --- a/jdk/test/java/util/stream/bootlib/java/util/stream/OpTestCase.java +++ b/jdk/test/java/util/stream/bootlib/java/util/stream/OpTestCase.java @@ -50,7 +50,7 @@ import org.testng.annotations.Test; * ways and asserts that they produce equivalent results. */ @Test -public abstract class OpTestCase extends Assert { +public abstract class OpTestCase extends LoggingTestCase { private final Map> testScenarios; @@ -67,6 +67,25 @@ public abstract class OpTestCase extends Assert { return ((AbstractPipeline) s).getStreamFlags(); } + /** + * An asserter for results produced when exercising of stream or terminal + * tests. + * + * @param the type of result to assert on + */ + public interface ResultAsserter { + /** + * Assert a result produced when exercising of stream or terminal + * test. + * + * @param actual the actual result + * @param excepted the expected result + * @param isOrdered true if the pipeline is ordered + * @param isParallel true if the pipeline is parallel + */ + void assertResult(R actual, R excepted, boolean isOrdered, boolean isParallel); + } + // Exercise stream operations public interface BaseStreamTestScenario { @@ -190,14 +209,19 @@ public abstract class OpTestCase extends Assert { Set testSet = new HashSet<>(); Collection refResult; - boolean isOrdered; Consumer> before = LambdaTestHelpers.bEmpty; Consumer> after = LambdaTestHelpers.bEmpty; - BiConsumer, Iterable> sequentialEqualityAsserter = LambdaTestHelpers::assertContentsEqual; - BiConsumer, Iterable> parallelEqualityAsserter = LambdaTestHelpers::assertContentsEqual; + ResultAsserter> resultAsserter = (act, exp, ord, par) -> { + if (par & !ord) { + LambdaTestHelpers.assertContentsUnordered(act, exp); + } + else { + LambdaTestHelpers.assertContentsEqual(act, exp); + } + }; private ExerciseDataStreamBuilder(TestData data, Function m) { this.data = data; @@ -211,10 +235,6 @@ public abstract class OpTestCase extends Assert { testSet.addAll(testScenarios.get(shape)); } - public BiConsumer, Iterable> getEqualityAsserter(BaseStreamTestScenario t) { - return t.isParallel() ? parallelEqualityAsserter : sequentialEqualityAsserter; - } - // public > ExerciseDataStreamBuilder expectedResult(I expectedResult) { @@ -299,29 +319,15 @@ public abstract class OpTestCase extends Assert { return this; } - public ExerciseDataStreamBuilder sequentialEqualityAsserter(BiConsumer, Iterable> equalator) { - this.sequentialEqualityAsserter = equalator; - return this; - } - - public ExerciseDataStreamBuilder parallelEqualityAsserter(BiConsumer, Iterable> equalator) { - this.parallelEqualityAsserter = equalator; + public ExerciseDataStreamBuilder resultAsserter(ResultAsserter> resultAsserter) { + this.resultAsserter = resultAsserter; return this; } // Build method - private long count(StreamShape shape, BaseStream s) { - switch (shape) { - case REFERENCE: return ((Stream) s).count(); - case INT_VALUE: return ((IntStream) s).count(); - case LONG_VALUE: return ((LongStream) s).count(); - case DOUBLE_VALUE: return ((DoubleStream) s).count(); - default: throw new IllegalStateException("Unknown shape: " + shape); - } - } - public Collection exercise() { + final boolean isOrdered; if (refResult == null) { // Induce the reference result before.accept(data); @@ -330,9 +336,10 @@ public abstract class OpTestCase extends Assert { Node refNodeResult = ((AbstractPipeline) sOut).evaluateToArrayNode(size -> (U[]) new Object[size]); refResult = LambdaTestHelpers.toBoxedList(refNodeResult.spliterator()); after.accept(data); - S_OUT anotherCopy = m.apply(data.stream()); - long count = count(((AbstractPipeline) anotherCopy).getOutputShape(), anotherCopy); - assertEquals(count, refNodeResult.count()); + } + else { + S_OUT sOut = m.apply(data.stream()); + isOrdered = StreamOpFlag.ORDERED.isKnown(((AbstractPipeline) sOut).getStreamFlags()); } List errors = new ArrayList<>(); @@ -343,16 +350,20 @@ public abstract class OpTestCase extends Assert { List result = new ArrayList<>(); test.run(data, LambdaTestHelpers.toBoxingConsumer(result::add), m); - Runnable asserter = () -> getEqualityAsserter(test).accept(result, refResult); - if (test.isParallel() && !isOrdered) - asserter = () -> LambdaTestHelpers.assertContentsUnordered(result, refResult); - LambdaTestHelpers.launderAssertion( - asserter, - () -> String.format("%n%s: %s != %s", test, refResult, result)); + Runnable asserter = () -> resultAsserter.assertResult(result, refResult, isOrdered, test.isParallel()); + + if (refResult.size() > 1000) { + LambdaTestHelpers.launderAssertion( + asserter, + () -> String.format("%n%s: [actual size=%d] != [expected size=%d]", test, result.size(), refResult.size())); + } + else { + LambdaTestHelpers.launderAssertion( + asserter, + () -> String.format("%n%s: [actual] %s != [expected] %s", test, result, refResult)); + } after.accept(data); -// } catch (AssertionError ae) { -// errors.add(ae); } catch (Throwable t) { errors.add(new Error(String.format("%s: %s", test, t), t)); } @@ -406,8 +417,7 @@ public abstract class OpTestCase extends Assert { Set testSet = EnumSet.allOf(TerminalTestScenario.class); - Function> sequentialEqualityAsserter = s -> LambdaTestHelpers::assertContentsEqual; - Function> parallelEqualityAsserter = s -> LambdaTestHelpers::assertContentsEqual; + ResultAsserter resultAsserter = (act, exp, ord, par) -> LambdaTestHelpers.assertContentsEqual(act, exp); private ExerciseDataTerminalBuilder(TestData data, Function streamF, Function terminalF) { this.data = data; @@ -423,23 +433,12 @@ public abstract class OpTestCase extends Assert { } public ExerciseDataTerminalBuilder equalator(BiConsumer equalityAsserter) { - this.sequentialEqualityAsserter = s -> equalityAsserter; - this.parallelEqualityAsserter = s -> equalityAsserter; + resultAsserter = (act, exp, ord, par) -> equalityAsserter.accept(act, exp); return this; } - public ExerciseDataTerminalBuilder sequentialEqualityAsserter(BiConsumer equalityAsserter) { - this.sequentialEqualityAsserter = s -> equalityAsserter; - return this; - } - - public ExerciseDataTerminalBuilder parallelEqualityAsserter(BiConsumer equalityAsserter) { - this.parallelEqualityAsserter = s -> equalityAsserter; - return this; - } - - public ExerciseDataTerminalBuilder parallelEqualityAsserter(Function> equalatorProvider) { - this.parallelEqualityAsserter = equalatorProvider; + public ExerciseDataTerminalBuilder resultAsserter(ResultAsserter resultAsserter) { + this.resultAsserter = resultAsserter; return this; } @@ -467,8 +466,9 @@ public abstract class OpTestCase extends Assert { // Build method public R exercise() { - S_OUT out = streamF.apply(data.stream()); + S_OUT out = streamF.apply(data.stream()).sequential(); AbstractPipeline ap = (AbstractPipeline) out; + boolean isOrdered = StreamOpFlag.ORDERED.isKnown(ap.getStreamFlags()); StreamShape shape = ap.getOutputShape(); Node node = ap.evaluateToArrayNode(size -> (U[]) new Object[size]); @@ -481,9 +481,8 @@ public abstract class OpTestCase extends Assert { S_OUT source = (S_OUT) createPipeline(shape, node.spliterator(), StreamOpFlag.IS_ORDERED | StreamOpFlag.IS_SIZED, false); - BiConsumer asserter = sequentialEqualityAsserter.apply(source); R result = terminalF.apply(source); - LambdaTestHelpers.launderAssertion(() -> asserter.accept(refResult, result), + LambdaTestHelpers.launderAssertion(() -> resultAsserter.assertResult(result, refResult, isOrdered, false), () -> String.format("Single sequential: %s != %s", refResult, result)); } @@ -491,11 +490,10 @@ public abstract class OpTestCase extends Assert { S_OUT source = (S_OUT) createPipeline(shape, node.spliterator(), StreamOpFlag.IS_ORDERED | StreamOpFlag.IS_SIZED, false); - // Force short-curcuit + // Force short-circuit source = (S_OUT) chain(source, new ShortCircuitOp(shape)); - BiConsumer asserter = sequentialEqualityAsserter.apply(source); R result = terminalF.apply(source); - LambdaTestHelpers.launderAssertion(() -> asserter.accept(refResult, result), + LambdaTestHelpers.launderAssertion(() -> resultAsserter.assertResult(result, refResult, isOrdered, false), () -> String.format("Single sequential pull: %s != %s", refResult, result)); } @@ -503,44 +501,39 @@ public abstract class OpTestCase extends Assert { S_OUT source = (S_OUT) createPipeline(shape, node.spliterator(), StreamOpFlag.IS_ORDERED | StreamOpFlag.IS_SIZED, true); - BiConsumer asserter = parallelEqualityAsserter.apply(source); R result = terminalF.apply(source); - LambdaTestHelpers.launderAssertion(() -> asserter.accept(refResult, result), + LambdaTestHelpers.launderAssertion(() -> resultAsserter.assertResult(result, refResult, isOrdered, true), () -> String.format("Single parallel: %s != %s", refResult, result)); } if (testSet.contains(TerminalTestScenario.ALL_SEQUENTIAL)) { // This may forEach or tryAdvance depending on the terminal op implementation S_OUT source = streamF.apply(data.stream()); - BiConsumer asserter = sequentialEqualityAsserter.apply(source); R result = terminalF.apply(source); - LambdaTestHelpers.launderAssertion(() -> asserter.accept(refResult, result), + LambdaTestHelpers.launderAssertion(() -> resultAsserter.assertResult(result, refResult, isOrdered, false), () -> String.format("All sequential: %s != %s", refResult, result)); } if (testSet.contains(TerminalTestScenario.ALL_SEQUENTIAL_SHORT_CIRCUIT)) { S_OUT source = streamF.apply(data.stream()); - // Force short-curcuit + // Force short-circuit source = (S_OUT) chain(source, new ShortCircuitOp(shape)); - BiConsumer asserter = sequentialEqualityAsserter.apply(source); R result = terminalF.apply(source); - LambdaTestHelpers.launderAssertion(() -> asserter.accept(refResult, result), + LambdaTestHelpers.launderAssertion(() -> resultAsserter.assertResult(result, refResult, isOrdered, false), () -> String.format("All sequential pull: %s != %s", refResult, result)); } if (testSet.contains(TerminalTestScenario.ALL_PARALLEL)) { S_OUT source = streamF.apply(data.parallelStream()); - BiConsumer asserter = parallelEqualityAsserter.apply(source); R result = terminalF.apply(source); - LambdaTestHelpers.launderAssertion(() -> asserter.accept(refResult, result), + LambdaTestHelpers.launderAssertion(() -> resultAsserter.assertResult(result, refResult, isOrdered, true), () -> String.format("All parallel: %s != %s", refResult, result)); } if (testSet.contains(TerminalTestScenario.ALL_PARALLEL_SEQUENTIAL)) { S_OUT source = streamF.apply(data.parallelStream()); - BiConsumer asserter = parallelEqualityAsserter.apply(source); R result = terminalF.apply(source.sequential()); - LambdaTestHelpers.launderAssertion(() -> asserter.accept(refResult, result), + LambdaTestHelpers.launderAssertion(() -> resultAsserter.assertResult(result, refResult, isOrdered, false), () -> String.format("All parallel then sequential: %s != %s", refResult, result)); } diff --git a/jdk/test/java/util/stream/bootlib/java/util/stream/SpliteratorTestHelper.java b/jdk/test/java/util/stream/bootlib/java/util/stream/SpliteratorTestHelper.java index 8cadf5fd824..7ba82a64616 100644 --- a/jdk/test/java/util/stream/bootlib/java/util/stream/SpliteratorTestHelper.java +++ b/jdk/test/java/util/stream/bootlib/java/util/stream/SpliteratorTestHelper.java @@ -65,7 +65,7 @@ public class SpliteratorTestHelper { } } - testSpliterator(supplier, c -> new BoxingAdapter(c)); + testSpliterator(supplier, BoxingAdapter::new); } public static void testLongSpliterator(Supplier supplier) { @@ -87,7 +87,7 @@ public class SpliteratorTestHelper { } } - testSpliterator(supplier, c -> new BoxingAdapter(c)); + testSpliterator(supplier, BoxingAdapter::new); } public static void testDoubleSpliterator(Supplier supplier) { @@ -109,7 +109,7 @@ public class SpliteratorTestHelper { } } - testSpliterator(supplier, c -> new BoxingAdapter(c)); + testSpliterator(supplier, BoxingAdapter::new); } static > void testSpliterator(Supplier supplier, diff --git a/jdk/test/java/util/stream/boottest/java/util/stream/DoubleNodeTest.java b/jdk/test/java/util/stream/boottest/java/util/stream/DoubleNodeTest.java index 23eee7d749a..c1e8a309e89 100644 --- a/jdk/test/java/util/stream/boottest/java/util/stream/DoubleNodeTest.java +++ b/jdk/test/java/util/stream/boottest/java/util/stream/DoubleNodeTest.java @@ -162,4 +162,18 @@ public class DoubleNodeTest extends OpTestCase { public void testSpliterator(double[] array, Node.OfDouble n) { SpliteratorTestHelper.testDoubleSpliterator(n::spliterator); } + + @Test(dataProvider = "nodes") + public void testTruncate(double[] array, Node.OfDouble n) { + int[] nums = new int[] { 0, 1, array.length / 2, array.length - 1, array.length }; + for (int start : nums) + for (int end : nums) { + if (start < 0 || end < 0 || end < start || end > array.length) + continue; + Node.OfDouble slice = n.truncate(start, end, Double[]::new); + double[] asArray = slice.asPrimitiveArray(); + for (int k = start; k < end; k++) + assertEquals(array[k], asArray[k - start]); + } + } } diff --git a/jdk/test/java/util/stream/boottest/java/util/stream/IntNodeTest.java b/jdk/test/java/util/stream/boottest/java/util/stream/IntNodeTest.java index 17e50bb1e03..e050e63d37b 100644 --- a/jdk/test/java/util/stream/boottest/java/util/stream/IntNodeTest.java +++ b/jdk/test/java/util/stream/boottest/java/util/stream/IntNodeTest.java @@ -160,4 +160,18 @@ public class IntNodeTest extends OpTestCase { public void testSpliterator(int[] array, Node.OfInt n) { SpliteratorTestHelper.testIntSpliterator(n::spliterator); } + + @Test(dataProvider = "nodes") + public void testTruncate(int[] array, Node.OfInt n) { + int[] nums = new int[] { 0, 1, array.length / 2, array.length - 1, array.length }; + for (int start : nums) + for (int end : nums) { + if (start < 0 || end < 0 || end < start || end > array.length) + continue; + Node.OfInt slice = n.truncate(start, end, Integer[]::new); + int[] asArray = slice.asPrimitiveArray(); + for (int k = start; k < end; k++) + assertEquals(array[k], asArray[k - start]); + } + } } diff --git a/jdk/test/java/util/stream/boottest/java/util/stream/LongNodeTest.java b/jdk/test/java/util/stream/boottest/java/util/stream/LongNodeTest.java index 6d1392316ce..d266fd7d04e 100644 --- a/jdk/test/java/util/stream/boottest/java/util/stream/LongNodeTest.java +++ b/jdk/test/java/util/stream/boottest/java/util/stream/LongNodeTest.java @@ -161,4 +161,18 @@ public class LongNodeTest extends OpTestCase { public void testSpliterator(long[] array, Node.OfLong n) { SpliteratorTestHelper.testLongSpliterator(n::spliterator); } + + @Test(dataProvider = "nodes") + public void testTruncate(long[] array, Node.OfLong n) { + int[] nums = new int[] { 0, 1, array.length / 2, array.length - 1, array.length }; + for (int start : nums) + for (int end : nums) { + if (start < 0 || end < 0 || end < start || end > array.length) + continue; + Node.OfLong slice = n.truncate(start, end, Long[]::new); + long[] asArray = slice.asPrimitiveArray(); + for (int k = start; k < end; k++) + assertEquals(array[k], asArray[k - start]); + } + } } diff --git a/jdk/test/java/util/stream/boottest/java/util/stream/NodeTest.java b/jdk/test/java/util/stream/boottest/java/util/stream/NodeTest.java index 8f5bff5cb66..da710033fda 100644 --- a/jdk/test/java/util/stream/boottest/java/util/stream/NodeTest.java +++ b/jdk/test/java/util/stream/boottest/java/util/stream/NodeTest.java @@ -137,4 +137,18 @@ public class NodeTest extends OpTestCase { public void testSpliterator(Integer[] array, Node n) { SpliteratorTestHelper.testSpliterator(n::spliterator); } + + @Test(dataProvider = "nodes") + public void testTruncate(Integer[] array, Node n) { + int[] nums = new int[] { 0, 1, array.length / 2, array.length - 1, array.length }; + for (int start : nums) + for (int end : nums) { + if (start < 0 || end < 0 || end < start || end > array.length) + continue; + Node slice = n.truncate(start, end, Integer[]::new); + Integer[] asArray = slice.asArray(Integer[]::new); + for (int k = start; k < end; k++) + assertEquals(array[k], asArray[k - start]); + } + } } diff --git a/jdk/test/java/util/stream/boottest/java/util/stream/UnorderedTest.java b/jdk/test/java/util/stream/boottest/java/util/stream/UnorderedTest.java index 48b4e7576e1..47eb533d8a2 100644 --- a/jdk/test/java/util/stream/boottest/java/util/stream/UnorderedTest.java +++ b/jdk/test/java/util/stream/boottest/java/util/stream/UnorderedTest.java @@ -184,7 +184,6 @@ public class UnorderedTest extends OpTestCase { UnaryOperator fi = interpose(f, (S s) -> (S) chain(s, checkClearOrderedOp)); withData(data). terminal(fi, terminalF). - without(TerminalTestScenario.ALL_PARALLEL_SEQUENTIAL). equalator(equalityAsserter). exercise(); } @@ -195,7 +194,6 @@ public class UnorderedTest extends OpTestCase { UnaryOperator fi = interpose(f, (S s) -> (S) chain(s, checkSetOrderedOp)); withData(data). terminal(fi, s -> terminalF.apply(s.sequential())). - without(TerminalTestScenario.ALL_PARALLEL_SEQUENTIAL). equalator(equalityAsserter). exercise(); } diff --git a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/DistinctOpTest.java b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/DistinctOpTest.java index cb492f8003a..ddadacc5a1d 100644 --- a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/DistinctOpTest.java +++ b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/DistinctOpTest.java @@ -64,7 +64,6 @@ public class DistinctOpTest extends OpTestCase { node = withData(data). stream(s -> s.unordered().distinct()). - parallelEqualityAsserter(LambdaTestHelpers::assertContentsUnordered). exercise(); assertUnique(node); diff --git a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/ForEachOpTest.java b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/ForEachOpTest.java index 99f4fdd82f5..d5bb72cda5b 100644 --- a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/ForEachOpTest.java +++ b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/ForEachOpTest.java @@ -58,6 +58,17 @@ public class ForEachOpTest extends OpTestCase { 55); } + private ResultAsserter> resultAsserter() { + return (act, exp, ord, par) -> { + if (par) { + LambdaTestHelpers.assertContentsUnordered(act, exp); + } + else { + LambdaTestHelpers.assertContents(act, exp); + } + }; + } + @Test public void testForEachOrdered() { List input = countTo(10000); @@ -93,13 +104,13 @@ public class ForEachOpTest extends OpTestCase { // Test head withData(data). terminal(terminalFunc). - parallelEqualityAsserter(LambdaTestHelpers::assertContentsUnordered). + resultAsserter(resultAsserter()). exercise(); // Test multiple stages withData(data). terminal(s -> s.map(LambdaTestHelpers.identity()), terminalFunc). - parallelEqualityAsserter(LambdaTestHelpers::assertContentsUnordered). + resultAsserter(resultAsserter()). exercise(); } @@ -141,13 +152,13 @@ public class ForEachOpTest extends OpTestCase { // Test head withData(data). terminal(terminalFunc). - parallelEqualityAsserter(LambdaTestHelpers::assertContentsUnordered). + resultAsserter(resultAsserter()). exercise(); // Test multiple stages withData(data). terminal(s -> s.map(i -> i), terminalFunc). - parallelEqualityAsserter(LambdaTestHelpers::assertContentsUnordered). + resultAsserter(resultAsserter()). exercise(); } @@ -189,13 +200,13 @@ public class ForEachOpTest extends OpTestCase { // Test head withData(data). terminal(terminalFunc). - parallelEqualityAsserter(LambdaTestHelpers::assertContentsUnordered). + resultAsserter(resultAsserter()). exercise(); // Test multiple stages withData(data). terminal(s -> s.map(i -> i), terminalFunc). - parallelEqualityAsserter(LambdaTestHelpers::assertContentsUnordered). + resultAsserter(resultAsserter()). exercise(); } @@ -237,13 +248,13 @@ public class ForEachOpTest extends OpTestCase { // Test head withData(data). terminal(terminalFunc). - parallelEqualityAsserter(LambdaTestHelpers::assertContentsUnordered). + resultAsserter(resultAsserter()). exercise(); // Test multiple stages withData(data). terminal(s -> s.map(i -> i), terminalFunc). - parallelEqualityAsserter(LambdaTestHelpers::assertContentsUnordered). + resultAsserter(resultAsserter()). exercise(); } diff --git a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/GroupByOpTest.java b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/GroupByOpTest.java index 7c6d6953c18..ce48d27734a 100644 --- a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/GroupByOpTest.java +++ b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/GroupByOpTest.java @@ -133,9 +133,16 @@ public class GroupByOpTest extends OpTestCase { Collector>> tab = Collectors.groupingBy(md.m); Map> result = withData(data) - .terminal(s -> s, s -> s.collect(tab)) - .parallelEqualityAsserter(s -> StreamOpFlagTestHelper.isStreamOrdered(s) ? GroupByOpTest::assertObjectEquals : GroupByOpTest::assertMultiMapEquals) - .exercise(); + .terminal(s -> s, s -> s.collect(tab)) + .resultAsserter((act, exp, ord, par) -> { + if (par & !ord) { + GroupByOpTest.assertMultiMapEquals(act, exp); + } + else { + GroupByOpTest.assertObjectEquals(act, exp); + } + }) + .exercise(); assertEquals(result.keySet().size(), md.expectedSize); } } diff --git a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/IntSliceOpTest.java b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/IntSliceOpTest.java index 6521f8b7abd..0d74f487325 100644 --- a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/IntSliceOpTest.java +++ b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/IntSliceOpTest.java @@ -145,6 +145,7 @@ public class IntSliceOpTest extends OpTestCase { List skips = sizes(data.size()); for (int s : skips) { + setContext("skip", s); Collection sr = exerciseOps(data, st -> st.substream(s)); assertEquals(sr.size(), sliceSize(data.size(), s)); @@ -159,7 +160,9 @@ public class IntSliceOpTest extends OpTestCase { List limits = skips; for (int s : skips) { + setContext("skip", s); for (int limit : limits) { + setContext("limit", limit); Collection sr = exerciseOps(data, st -> st.substream(s).limit(limit)); assertEquals(sr.size(), sliceSize(sliceSize(data.size(), s), 0, limit)); @@ -174,6 +177,7 @@ public class IntSliceOpTest extends OpTestCase { List limits = sizes(data.size()); for (int limit : limits) { + setContext("limit", limit); Collection sr = exerciseOps(data, st -> st.limit(limit)); assertEquals(sr.size(), sliceSize(data.size(), 0, limit)); @@ -189,6 +193,7 @@ public class IntSliceOpTest extends OpTestCase { @Test(groups = { "serialization-hostile" }) public void testLimitShortCircuit() { for (int l : Arrays.asList(0, 10)) { + setContext("limit", l); AtomicInteger ai = new AtomicInteger(); IntStream.range(1, 101) .peek(i -> ai.getAndIncrement()) diff --git a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/IntUniqOpTest.java b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/IntUniqOpTest.java index 8205d4d510d..3ec5d219a23 100644 --- a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/IntUniqOpTest.java +++ b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/IntUniqOpTest.java @@ -60,7 +60,6 @@ public class IntUniqOpTest extends OpTestCase { public void testOpSorted(String name, TestData.OfInt data) { Collection result = withData(data). stream(s -> s.sorted().distinct().boxed()). - parallelEqualityAsserter(LambdaTestHelpers::assertContentsUnordered). exercise(); assertUnique(result); diff --git a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/MatchOpTest.java b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/MatchOpTest.java index 84c43d0a748..e88a8d95e93 100644 --- a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/MatchOpTest.java +++ b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/MatchOpTest.java @@ -23,19 +23,16 @@ package org.openjdk.tests.java.util.stream; import java.util.Arrays; -import java.util.Collections; import java.util.HashMap; import java.util.Iterator; import java.util.List; import java.util.Map; import java.util.PrimitiveIterator; +import java.util.Spliterators; import java.util.function.DoublePredicate; -import java.util.function.DoubleSupplier; import java.util.function.Function; import java.util.function.IntPredicate; -import java.util.function.IntSupplier; import java.util.function.LongPredicate; -import java.util.function.LongSupplier; import java.util.function.Predicate; import java.util.function.Supplier; import java.util.stream.DoubleStream; @@ -46,6 +43,7 @@ import java.util.stream.LongStream; import java.util.stream.LongStreamTestDataProvider; import java.util.stream.OpTestCase; import java.util.stream.Stream; +import java.util.stream.StreamSupport; import java.util.stream.StreamTestDataProvider; import java.util.stream.TestData; @@ -97,6 +95,7 @@ public class MatchOpTest extends OpTestCase { private void assertPredicates(List source, Kind kind, Predicate[] predicates, boolean... answers) { for (int i = 0; i < predicates.length; i++) { + setContext("i", i); boolean match = this.kinds().get(kind).apply(predicates[i]).apply(source.stream()); assertEquals(answers[i], match, kind.toString() + predicates[i].toString()); } @@ -119,7 +118,9 @@ public class MatchOpTest extends OpTestCase { @Test(dataProvider = "StreamTestData", dataProviderClass = StreamTestDataProvider.class) public void testStream(String name, TestData.OfRef data) { for (Predicate p : INTEGER_PREDICATES) { + setContext("p", p); for (Kind kind : Kind.values()) { + setContext("kind", kind); exerciseTerminalOps(data, this.kinds().get(kind).apply(p)); exerciseTerminalOps(data, s -> s.filter(pFalse), this.kinds().get(kind).apply(p)); exerciseTerminalOps(data, s -> s.filter(pEven), this.kinds().get(kind).apply(p)); @@ -128,29 +129,40 @@ public class MatchOpTest extends OpTestCase { } public void testInfinite() { - class CycleSupplier implements Supplier { - final Iterable source; - Iterator i = Collections.emptyIterator(); + class CycleIterator implements Iterator { + final Supplier> source; + Iterator i = null; - CycleSupplier(Iterable source) { + CycleIterator(Supplier> source) { this.source = source; } @Override - public T get() { - if (!i.hasNext()) { - i = source.iterator(); + public Integer next() { + if (i == null || !i.hasNext()) { + i = source.get(); } return i.next(); } + + @Override + public boolean hasNext() { + if (i == null || !i.hasNext()) { + i = source.get(); + } + return i.hasNext(); + } } - assertFalse(Stream.generate(new CycleSupplier<>(Arrays.asList(1, 2, 3, 4))).allMatch(i -> i > 3)); - assertTrue(Stream.generate(new CycleSupplier<>(Arrays.asList(1, 2, 3, 4))).anyMatch(i -> i > 3)); - assertFalse(Stream.generate(new CycleSupplier<>(Arrays.asList(1, 2, 3, 4))).noneMatch(i -> i > 3)); - assertFalse(Stream.generate(new CycleSupplier<>(Arrays.asList(1, 2, 3, 4))).parallel().allMatch(i -> i > 3)); - assertTrue(Stream.generate(new CycleSupplier<>(Arrays.asList(1, 2, 3, 4))).parallel().anyMatch(i -> i > 3)); - assertFalse(Stream.generate(new CycleSupplier<>(Arrays.asList(1, 2, 3, 4))).parallel().noneMatch(i -> i > 3)); + Supplier> source = () -> Arrays.asList(1, 2, 3, 4).iterator(); + Supplier> s = () -> StreamSupport.stream(Spliterators.spliteratorUnknownSize(new CycleIterator(source), 0)); + + assertFalse(s.get().allMatch(i -> i > 3)); + assertTrue(s.get().anyMatch(i -> i > 3)); + assertFalse(s.get().noneMatch(i -> i > 3)); + assertFalse(s.get().parallel().allMatch(i -> i > 3)); + assertTrue(s.get().parallel().anyMatch(i -> i > 3)); + assertFalse(s.get().parallel().noneMatch(i -> i > 3)); } // @@ -168,6 +180,7 @@ public class MatchOpTest extends OpTestCase { private void assertIntPredicates(Supplier source, Kind kind, IntPredicate[] predicates, boolean... answers) { for (int i = 0; i < predicates.length; i++) { + setContext("i", i); boolean match = intKinds.get(kind).apply(predicates[i]).apply(source.get()); assertEquals(answers[i], match, kind.toString() + predicates[i].toString()); } @@ -189,40 +202,52 @@ public class MatchOpTest extends OpTestCase { @Test(dataProvider = "IntStreamTestData", dataProviderClass = IntStreamTestDataProvider.class) public void testIntStream(String name, TestData.OfInt data) { - for (IntPredicate p : INT_PREDICATES) + for (IntPredicate p : INT_PREDICATES) { + setContext("p", p); for (Kind kind : Kind.values()) { + setContext("kind", kind); exerciseTerminalOps(data, intKinds.get(kind).apply(p)); exerciseTerminalOps(data, s -> s.filter(ipFalse), intKinds.get(kind).apply(p)); exerciseTerminalOps(data, s -> s.filter(ipEven), intKinds.get(kind).apply(p)); } + } } public void testIntInfinite() { - class CycleSupplier implements IntSupplier { + class CycleIterator implements PrimitiveIterator.OfInt { final Supplier source; PrimitiveIterator.OfInt i = null; - CycleSupplier(Supplier source) { + CycleIterator(Supplier source) { this.source = source; } @Override - public int getAsInt() { + public int nextInt() { if (i == null || !i.hasNext()) { i = source.get(); } return i.nextInt(); } + + @Override + public boolean hasNext() { + if (i == null || !i.hasNext()) { + i = source.get(); + } + return i.hasNext(); + } } Supplier source = () -> Arrays.stream(new int[]{1, 2, 3, 4}).iterator(); + Supplier s = () -> StreamSupport.intStream(Spliterators.spliteratorUnknownSize(new CycleIterator(source), 0)); - assertFalse(IntStream.generate(new CycleSupplier(source)).allMatch(i -> i > 3)); - assertTrue(IntStream.generate(new CycleSupplier(source)).anyMatch(i -> i > 3)); - assertFalse(IntStream.generate(new CycleSupplier(source)).noneMatch(i -> i > 3)); - assertFalse(IntStream.generate(new CycleSupplier(source)).parallel().allMatch(i -> i > 3)); - assertTrue(IntStream.generate(new CycleSupplier(source)).parallel().anyMatch(i -> i > 3)); - assertFalse(IntStream.generate(new CycleSupplier(source)).parallel().noneMatch(i -> i > 3)); + assertFalse(s.get().allMatch(i -> i > 3)); + assertTrue(s.get().anyMatch(i -> i > 3)); + assertFalse(s.get().noneMatch(i -> i > 3)); + assertFalse(s.get().parallel().allMatch(i -> i > 3)); + assertTrue(s.get().parallel().anyMatch(i -> i > 3)); + assertFalse(s.get().parallel().noneMatch(i -> i > 3)); } // @@ -240,6 +265,7 @@ public class MatchOpTest extends OpTestCase { private void assertLongPredicates(Supplier source, Kind kind, LongPredicate[] predicates, boolean... answers) { for (int i = 0; i < predicates.length; i++) { + setContext("i", i); boolean match = longKinds.get(kind).apply(predicates[i]).apply(source.get()); assertEquals(answers[i], match, kind.toString() + predicates[i].toString()); } @@ -261,40 +287,52 @@ public class MatchOpTest extends OpTestCase { @Test(dataProvider = "LongStreamTestData", dataProviderClass = LongStreamTestDataProvider.class) public void testLongStream(String name, TestData.OfLong data) { - for (LongPredicate p : LONG_PREDICATES) + for (LongPredicate p : LONG_PREDICATES) { + setContext("p", p); for (Kind kind : Kind.values()) { + setContext("kind", kind); exerciseTerminalOps(data, longKinds.get(kind).apply(p)); exerciseTerminalOps(data, s -> s.filter(lpFalse), longKinds.get(kind).apply(p)); exerciseTerminalOps(data, s -> s.filter(lpEven), longKinds.get(kind).apply(p)); } + } } public void testLongInfinite() { - class CycleSupplier implements LongSupplier { + class CycleIterator implements PrimitiveIterator.OfLong { final Supplier source; PrimitiveIterator.OfLong i = null; - CycleSupplier(Supplier source) { + CycleIterator(Supplier source) { this.source = source; } @Override - public long getAsLong() { + public long nextLong() { if (i == null || !i.hasNext()) { i = source.get(); } return i.nextLong(); } + + @Override + public boolean hasNext() { + if (i == null || !i.hasNext()) { + i = source.get(); + } + return i.hasNext(); + } } Supplier source = () -> Arrays.stream(new long[]{1, 2, 3, 4}).iterator(); + Supplier s = () -> StreamSupport.longStream(Spliterators.spliteratorUnknownSize(new CycleIterator(source), 0)); - assertFalse(LongStream.generate(new CycleSupplier(source)).allMatch(i -> i > 3)); - assertTrue(LongStream.generate(new CycleSupplier(source)).anyMatch(i -> i > 3)); - assertFalse(LongStream.generate(new CycleSupplier(source)).noneMatch(i -> i > 3)); - assertFalse(LongStream.generate(new CycleSupplier(source)).parallel().allMatch(i -> i > 3)); - assertTrue(LongStream.generate(new CycleSupplier(source)).parallel().anyMatch(i -> i > 3)); - assertFalse(LongStream.generate(new CycleSupplier(source)).parallel().noneMatch(i -> i > 3)); + assertFalse(s.get().allMatch(i -> i > 3)); + assertTrue(s.get().anyMatch(i -> i > 3)); + assertFalse(s.get().noneMatch(i -> i > 3)); + assertFalse(s.get().parallel().allMatch(i -> i > 3)); + assertTrue(s.get().parallel().anyMatch(i -> i > 3)); + assertFalse(s.get().parallel().noneMatch(i -> i > 3)); } // @@ -312,6 +350,7 @@ public class MatchOpTest extends OpTestCase { private void assertDoublePredicates(Supplier source, Kind kind, DoublePredicate[] predicates, boolean... answers) { for (int i = 0; i < predicates.length; i++) { + setContext("i", i); boolean match = doubleKinds.get(kind).apply(predicates[i]).apply(source.get()); assertEquals(answers[i], match, kind.toString() + predicates[i].toString()); } @@ -333,39 +372,51 @@ public class MatchOpTest extends OpTestCase { @Test(dataProvider = "DoubleStreamTestData", dataProviderClass = DoubleStreamTestDataProvider.class) public void testDoubleStream(String name, TestData.OfDouble data) { - for (DoublePredicate p : DOUBLE_PREDICATES) + for (DoublePredicate p : DOUBLE_PREDICATES) { + setContext("p", p); for (Kind kind : Kind.values()) { + setContext("kind", kind); exerciseTerminalOps(data, doubleKinds.get(kind).apply(p)); exerciseTerminalOps(data, s -> s.filter(dpFalse), doubleKinds.get(kind).apply(p)); exerciseTerminalOps(data, s -> s.filter(dpEven), doubleKinds.get(kind).apply(p)); } + } } public void testDoubleInfinite() { - class CycleSupplier implements DoubleSupplier { + class CycleIterator implements PrimitiveIterator.OfDouble { final Supplier source; PrimitiveIterator.OfDouble i = null; - CycleSupplier(Supplier source) { + CycleIterator(Supplier source) { this.source = source; } @Override - public double getAsDouble() { + public double nextDouble() { if (i == null || !i.hasNext()) { i = source.get(); } return i.nextDouble(); } + + @Override + public boolean hasNext() { + if (i == null || !i.hasNext()) { + i = source.get(); + } + return i.hasNext(); + } } Supplier source = () -> Arrays.stream(new double[]{1, 2, 3, 4}).iterator(); + Supplier s = () -> StreamSupport.doubleStream(Spliterators.spliteratorUnknownSize(new CycleIterator(source), 0)); - assertFalse(DoubleStream.generate(new CycleSupplier(source)).allMatch(i -> i > 3)); - assertTrue(DoubleStream.generate(new CycleSupplier(source)).anyMatch(i -> i > 3)); - assertFalse(DoubleStream.generate(new CycleSupplier(source)).noneMatch(i -> i > 3)); - assertFalse(DoubleStream.generate(new CycleSupplier(source)).parallel().allMatch(i -> i > 3)); - assertTrue(DoubleStream.generate(new CycleSupplier(source)).parallel().anyMatch(i -> i > 3)); - assertFalse(DoubleStream.generate(new CycleSupplier(source)).parallel().noneMatch(i -> i > 3)); + assertFalse(s.get().allMatch(i -> i > 3)); + assertTrue(s.get().anyMatch(i -> i > 3)); + assertFalse(s.get().noneMatch(i -> i > 3)); + assertFalse(s.get().parallel().allMatch(i -> i > 3)); + assertTrue(s.get().parallel().anyMatch(i -> i > 3)); + assertFalse(s.get().parallel().noneMatch(i -> i > 3)); } } diff --git a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/RangeTest.java b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/RangeTest.java index 9109e036f74..1e6b343fc60 100644 --- a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/RangeTest.java +++ b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/RangeTest.java @@ -58,7 +58,9 @@ public class RangeTest extends OpTestCase { public void testIntRange() { // Half-open for (int start : Arrays.asList(1, 10, -1, -10)) { + setContext("start", start); for (int end : Arrays.asList(1, 10, -1, -10)) { + setContext("end", end); int size = (start < end) ? end - start : 0; int[] exp = new int[size]; for (int i = start, p = 0; i < end; i++, p++) { @@ -76,7 +78,9 @@ public class RangeTest extends OpTestCase { // Closed for (int start : Arrays.asList(1, 10, -1, -10)) { + setContext("start", start); for (int end : Arrays.asList(1, 10, -1, -10)) { + setContext("end", end); int size = (start <= end) ? end - start + 1 : 0; int[] exp = new int[size]; for (int i = start, p = 0; i <= end; i++, p++) { @@ -144,7 +148,9 @@ public class RangeTest extends OpTestCase { public void testLongRange() { // Half-open for (long start : Arrays.asList(1, 1000, -1, -1000)) { + setContext("start", start); for (long end : Arrays.asList(1, 1000, -1, -1000)) { + setContext("end", end); long size = start < end ? end - start : 0; long[] exp = new long[(int) size]; for (long i = start, p = 0; i < end; i++, p++) { @@ -162,7 +168,9 @@ public class RangeTest extends OpTestCase { // Closed for (long start : Arrays.asList(1, 1000, -1, -1000)) { + setContext("start", start); for (long end : Arrays.asList(1, 1000, -1, -1000)) { + setContext("end", end); long size = start <= end ? end - start + 1: 0; long[] exp = new long[(int) size]; for (long i = start, p = 0; i <= end; i++, p++) { diff --git a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/ReduceByOpTest.java b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/ReduceByOpTest.java index 539ed9beada..3fcb4691701 100644 --- a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/ReduceByOpTest.java +++ b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/ReduceByOpTest.java @@ -51,6 +51,7 @@ public class ReduceByOpTest extends OpTestCase { Map result = data.stream().collect(groupingBy(LambdaTestHelpers.forPredicate(pEven, true, false), reducing(0, rPlus))); assertEquals(result.size(), gbResult.size()); for (Map.Entry entry : result.entrySet()) { + setContext("entry", entry); Boolean key = entry.getKey(); assertEquals(entry.getValue(), data.stream().filter(e -> pEven.test(e) == key).reduce(0, rPlus)); } @@ -59,7 +60,9 @@ public class ReduceByOpTest extends OpTestCase { Map> mgResult = exerciseTerminalOps(data, s -> s.collect(groupingBy(mId))); Map miResult = exerciseTerminalOps(data, s -> s.collect(groupingBy(mId, reducing(0, e -> 1, Integer::sum)))); assertEquals(miResult.keySet().size(), uniqueSize); - for (Map.Entry entry : miResult.entrySet()) + for (Map.Entry entry : miResult.entrySet()) { + setContext("entry", entry); assertEquals((int) entry.getValue(), mgResult.get(entry.getKey()).size()); + } } } diff --git a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/SequentialOpTest.java b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/SequentialOpTest.java index e74810002fb..793b31daed4 100644 --- a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/SequentialOpTest.java +++ b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/SequentialOpTest.java @@ -22,13 +22,14 @@ */ package org.openjdk.tests.java.util.stream; +import java.util.Comparators; import java.util.stream.LambdaTestHelpers; import java.util.stream.OpTestCase; import java.util.stream.StreamTestDataProvider; import org.testng.annotations.Test; -import java.util.Comparators; import java.util.Iterator; +import java.util.Comparator; import java.util.concurrent.atomic.AtomicInteger; import java.util.function.Function; import java.util.function.Supplier; @@ -64,8 +65,12 @@ public class SequentialOpTest extends OpTestCase { (UnaryOperator>) s -> s.parallel().map(id).peek(e -> { counter.incrementAndGet(); }).map(id) }; - for (Supplier> supp : suppliers) - for (UnaryOperator> config : configs) { + for (int i = 0; i < suppliers.length; i++) { + setContext("supplierIndex", i); + Supplier> supp = suppliers[i]; + for (int j = 0; j < configs.length; j++) { + setContext("configIndex", j); + UnaryOperator> config = configs[j]; counter.set(0); Stream stream = config.apply(supp.get()); assertEquals(0, counter.get()); @@ -86,6 +91,7 @@ public class SequentialOpTest extends OpTestCase { }); assertTrue(data.size() == 0 || counter.get() > 0); } + } } @SuppressWarnings({"rawtypes", "unchecked"}) @@ -96,7 +102,8 @@ public class SequentialOpTest extends OpTestCase { = new UnaryOperator[] { (UnaryOperator>) s -> s, (UnaryOperator>) s -> s.sequential(), - (UnaryOperator>) s -> s.parallel() + (UnaryOperator>) s -> s.parallel(), + (UnaryOperator>) s -> s.unordered() }; UnaryOperator>[] stuff = new UnaryOperator[] { @@ -107,12 +114,23 @@ public class SequentialOpTest extends OpTestCase { (UnaryOperator>) s -> s.filter(LambdaTestHelpers.pEven).sorted(Comparators.naturalOrder()).map(id), }; - for (UnaryOperator> c1 : changers) - for (UnaryOperator> s1 : stuff) - for (UnaryOperator> c2 : changers) - for (UnaryOperator> s2 : stuff) { + for (int c1Index = 0; c1Index < changers.length; c1Index++) { + setContext("c1Index", c1Index); + UnaryOperator> c1 = changers[c1Index]; + for (int s1Index = 0; s1Index < stuff.length; s1Index++) { + setContext("s1Index", s1Index); + UnaryOperator> s1 = stuff[s1Index]; + for (int c2Index = 0; c2Index < changers.length; c2Index++) { + setContext("c2Index", c2Index); + UnaryOperator> c2 = changers[c2Index]; + for (int s2Index = 0; s2Index < stuff.length; s2Index++) { + setContext("s2Index", s2Index); + UnaryOperator> s2 = stuff[s2Index]; UnaryOperator> composed = s -> s2.apply(c2.apply(s1.apply(c1.apply(s)))); exerciseOps(data, composed); } + } + } + } } } diff --git a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/SliceOpTest.java b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/SliceOpTest.java index 5074ce93c03..ff940035980 100644 --- a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/SliceOpTest.java +++ b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/SliceOpTest.java @@ -26,7 +26,11 @@ import org.testng.annotations.Test; import java.util.*; import java.util.concurrent.atomic.AtomicInteger; -import java.util.stream.Collectors; +import java.util.function.Function; +import java.util.stream.DoubleStream; +import java.util.stream.IntStream; +import java.util.stream.LambdaTestHelpers; +import java.util.stream.LongStream; import java.util.stream.OpTestCase; import java.util.stream.Stream; import java.util.stream.StreamTestDataProvider; @@ -145,19 +149,20 @@ public class SliceOpTest extends OpTestCase { List skips = sizes(data.size()); for (int s : skips) { - Collection sr = exerciseOpsInt(data, - st -> st.substream(s), - st -> st.substream(s), - st -> st.substream(s), - st -> st.substream(s)); - assertEquals(sr.size(), sliceSize(data.size(), s)); + setContext("skip", s); + testSliceMulti(data, + sliceSize(data.size(), s), + st -> st.substream(s), + st -> st.substream(s), + st -> st.substream(s), + st -> st.substream(s)); - sr = exerciseOpsInt(data, - st -> st.substream(s).substream(s / 2), - st -> st.substream(s).substream(s / 2), - st -> st.substream(s).substream(s / 2), - st -> st.substream(s).substream(s / 2)); - assertEquals(sr.size(), sliceSize(sliceSize(data.size(), s), s/2)); + testSliceMulti(data, + sliceSize(sliceSize(data.size(), s), s/2), + st -> st.substream(s).substream(s / 2), + st -> st.substream(s).substream(s / 2), + st -> st.substream(s).substream(s / 2), + st -> st.substream(s).substream(s / 2)); } } @@ -167,20 +172,22 @@ public class SliceOpTest extends OpTestCase { List limits = skips; for (int s : skips) { - for (int limit : limits) { - Collection sr = exerciseOpsInt(data, - st -> st.substream(s).limit(limit), - st -> st.substream(s).limit(limit), - st -> st.substream(s).limit(limit), - st -> st.substream(s).limit(limit)); - assertEquals(sr.size(), sliceSize(sliceSize(data.size(), s), 0, limit)); + setContext("skip", s); + for (int l : limits) { + setContext("limit", l); + testSliceMulti(data, + sliceSize(sliceSize(data.size(), s), 0, l), + st -> st.substream(s).limit(l), + st -> st.substream(s).limit(l), + st -> st.substream(s).limit(l), + st -> st.substream(s).limit(l)); - sr = exerciseOpsInt(data, - st -> st.substream(s, limit+s), - st -> st.substream(s, limit+s), - st -> st.substream(s, limit+s), - st -> st.substream(s, limit+s)); - assertEquals(sr.size(), sliceSize(data.size(), s, limit)); + testSliceMulti(data, + sliceSize(data.size(), s, l), + st -> st.substream(s, l+s), + st -> st.substream(s, l+s), + st -> st.substream(s, l+s), + st -> st.substream(s, l+s)); } } } @@ -189,20 +196,74 @@ public class SliceOpTest extends OpTestCase { public void testLimitOps(String name, TestData.OfRef data) { List limits = sizes(data.size()); - for (int limit : limits) { - Collection sr = exerciseOpsInt(data, - st -> st.limit(limit), - st -> st.limit(limit), - st -> st.limit(limit), - st -> st.limit(limit)); - assertEquals(sr.size(), sliceSize(data.size(), 0, limit)); + for (int l : limits) { + setContext("limit", l); + testSliceMulti(data, + sliceSize(data.size(), 0, l), + st -> st.limit(l), + st -> st.limit(l), + st -> st.limit(l), + st -> st.limit(l)); + } - sr = exerciseOpsInt(data, - st -> st.limit(limit).limit(limit / 2), - st -> st.limit(limit).limit(limit / 2), - st -> st.limit(limit).limit(limit / 2), - st -> st.limit(limit).limit(limit / 2)); - assertEquals(sr.size(), sliceSize(sliceSize(data.size(), 0, limit), 0, limit/2)); + for (int l : limits) { + setContext("limit", l); + testSliceMulti(data, + sliceSize(sliceSize(data.size(), 0, l), 0, l / 2), + st -> st.limit(l).limit(l / 2), + st -> st.limit(l).limit(l / 2), + st -> st.limit(l).limit(l / 2), + st -> st.limit(l).limit(l / 2)); + } + } + + private ResultAsserter> sliceResultAsserter(Iterable data, + int expectedSize) { + return (act, exp, ord, par) -> { + if (par & !ord) { + List expected = new ArrayList<>(); + data.forEach(expected::add); + + List actual = new ArrayList<>(); + act.forEach(actual::add); + + assertEquals(actual.size(), expectedSize); + assertTrue(expected.containsAll(actual)); + } + else { + LambdaTestHelpers.assertContents(act, exp); + } + }; + } + + private void testSliceMulti(TestData.OfRef data, + int expectedSize, + Function, Stream> mRef, + Function mInt, + Function mLong, + Function mDouble) { + + @SuppressWarnings({ "rawtypes", "unchecked" }) + Function, Stream>[] ms = new Function[4]; + ms[0] = mRef; + ms[1] = s -> mInt.apply(s.mapToInt(e -> e)).mapToObj(e -> e); + ms[2] = s -> mLong.apply(s.mapToLong(e -> e)).mapToObj(e -> (int) e); + ms[3] = s -> mDouble.apply(s.mapToDouble(e -> e)).mapToObj(e -> (int) e); + testSliceMulti(data, expectedSize, ms); + } + + @SafeVarargs + private final void testSliceMulti(TestData.OfRef data, + int expectedSize, + Function, Stream>... ms) { + for (int i = 0; i < ms.length; i++) { + setContext("mIndex", i); + Function, Stream> m = ms[i]; + Collection sr = withData(data) + .stream(m) + .resultAsserter(sliceResultAsserter(data, expectedSize)) + .exercise(); + assertEquals(sr.size(), expectedSize); } } @@ -215,6 +276,7 @@ public class SliceOpTest extends OpTestCase { @Test(groups = { "serialization-hostile" }) public void testLimitShortCircuit() { for (int l : Arrays.asList(0, 10)) { + setContext("l", l); AtomicInteger ai = new AtomicInteger(); countTo(100).stream() .peek(i -> ai.getAndIncrement()) @@ -224,18 +286,6 @@ public class SliceOpTest extends OpTestCase { } } - public void testSkipParallel() { - List l = countTo(1000).parallelStream().substream(200).limit(200).sequential().collect(Collectors.toList()); - assertEquals(l.size(), 200); - assertEquals(l.get(l.size() -1).intValue(), 400); - } - - public void testLimitParallel() { - List l = countTo(1000).parallelStream().limit(500).sequential().collect(Collectors.toList()); - assertEquals(l.size(), 500); - assertEquals(l.get(l.size() -1).intValue(), 500); - } - private List sizes(int size) { if (size < 4) { return Arrays.asList(0, 1, 2, 3, 4, 6); diff --git a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/StreamLinkTest.java b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/StreamLinkTest.java index e7629adae88..b4cae8946c9 100644 --- a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/StreamLinkTest.java +++ b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/StreamLinkTest.java @@ -47,6 +47,7 @@ public class StreamLinkTest extends OpTestCase { @Test(dataProvider = "StreamTestData", dataProviderClass = StreamTestDataProvider.class) public void testManyStreams(String name, TestData.OfRef data) { for (int n : sizes) { + setContext("n", n); List expected = data.stream().map(e -> (Integer) (e + n)).collect(Collectors.toList()); withData(data). @@ -59,6 +60,7 @@ public class StreamLinkTest extends OpTestCase { @Test(dataProvider = "IntStreamTestData", dataProviderClass = IntStreamTestDataProvider.class) public void testIntManyStreams(String name, TestData.OfInt data) { for (int n : sizes) { + setContext("n", n); int[] expected = data.stream().map(e -> e + n).toArray(); withData(data). @@ -71,6 +73,7 @@ public class StreamLinkTest extends OpTestCase { @Test(dataProvider = "LongStreamTestData", dataProviderClass = LongStreamTestDataProvider.class) public void testLongManyStreams(String name, TestData.OfLong data) { for (int n : sizes) { + setContext("n", n); long[] expected = data.stream().map(e -> e + n).toArray(); withData(data). @@ -83,6 +86,7 @@ public class StreamLinkTest extends OpTestCase { @Test(dataProvider = "DoubleStreamTestData", dataProviderClass = DoubleStreamTestDataProvider.class) public void testDoubleManyStreams(String name, TestData.OfDouble data) { for (int n : sizes) { + setContext("n", n); double[] expected = data.stream().map(e -> accumulate(e, n)).toArray(); withData(data). diff --git a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/StreamSpliteratorTest.java b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/StreamSpliteratorTest.java index 8a4d502dc2b..bd111cfdb27 100644 --- a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/StreamSpliteratorTest.java +++ b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/StreamSpliteratorTest.java @@ -256,9 +256,14 @@ public class StreamSpliteratorTest extends OpTestCase { s -> s.map(LambdaTestHelpers.identity()).parallel() ); - for (Consumer> terminalOp : terminalOps) { - for (UnaryOperator> intermediateOp : intermediateOps) { - for (boolean proxyEstimateSize : new boolean[]{false, true}) { + for (int i = 0; i < terminalOps.size(); i++) { + setContext("termOpIndex", i); + Consumer> terminalOp = terminalOps.get(i); + for (int j = 0; j < intermediateOps.size(); j++) { + setContext("intOpIndex", j); + UnaryOperator> intermediateOp = intermediateOps.get(j); + for (boolean proxyEstimateSize : new boolean[] {false, true}) { + setContext("proxyEstimateSize", proxyEstimateSize); Spliterator sp = intermediateOp.apply(l.stream()).spliterator(); ProxyNoExactSizeSpliterator psp = new ProxyNoExactSizeSpliterator<>(sp, proxyEstimateSize); Stream s = StreamSupport.parallelStream(psp); @@ -345,9 +350,14 @@ public class StreamSpliteratorTest extends OpTestCase { s -> s.map(i -> i).parallel() ); - for (Consumer terminalOp : terminalOps) { - for (UnaryOperator intermediateOp : intermediateOps) { - for (boolean proxyEstimateSize : new boolean[]{false, true}) { + for (int i = 0; i < terminalOps.size(); i++) { + setContext("termOpIndex", i); + Consumer terminalOp = terminalOps.get(i); + for (int j = 0; j < intermediateOps.size(); j++) { + setContext("intOpIndex", j); + UnaryOperator intermediateOp = intermediateOps.get(j); + for (boolean proxyEstimateSize : new boolean[] {false, true}) { + setContext("proxyEstimateSize", proxyEstimateSize); // Size is assumed to be larger than the target size for no splitting // @@@ Need way to obtain the target size Spliterator.OfInt sp = intermediateOp.apply(IntStream.range(0, 1000)).spliterator(); @@ -433,9 +443,14 @@ public class StreamSpliteratorTest extends OpTestCase { s -> s.map(i -> i).parallel() ); - for (Consumer terminalOp : terminalOps) { - for (UnaryOperator intermediateOp : intermediateOps) { - for (boolean proxyEstimateSize : new boolean[]{false, true}) { + for (int i = 0; i < terminalOps.size(); i++) { + Consumer terminalOp = terminalOps.get(i); + setContext("termOpIndex", i); + for (int j = 0; j < intermediateOps.size(); j++) { + setContext("intOpIndex", j); + UnaryOperator intermediateOp = intermediateOps.get(j); + for (boolean proxyEstimateSize : new boolean[] {false, true}) { + setContext("proxyEstimateSize", proxyEstimateSize); // Size is assumed to be larger than the target size for no splitting // @@@ Need way to obtain the target size Spliterator.OfLong sp = intermediateOp.apply(LongStream.range(0, 1000)).spliterator(); @@ -521,9 +536,14 @@ public class StreamSpliteratorTest extends OpTestCase { s -> s.map(i -> i).parallel() ); - for (Consumer terminalOp : terminalOps) { - for (UnaryOperator intermediateOp : intermediateOps) { - for (boolean proxyEstimateSize : new boolean[]{false, true}) { + for (int i = 0; i < terminalOps.size(); i++) { + Consumer terminalOp = terminalOps.get(i); + setContext("termOpIndex", i); + for (int j = 0; j < intermediateOps.size(); j++) { + UnaryOperator intermediateOp = intermediateOps.get(j); + setContext("intOpIndex", j); + for (boolean proxyEstimateSize : new boolean[] {false, true}) { + setContext("proxyEstimateSize", proxyEstimateSize); // Size is assumed to be larger than the target size for no splitting // @@@ Need way to obtain the target size Spliterator.OfDouble sp = intermediateOp.apply(IntStream.range(0, 1000).asDoubleStream()).spliterator(); diff --git a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/TabulatorsTest.java b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/TabulatorsTest.java index 2dd8c55016e..b9087415c98 100644 --- a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/TabulatorsTest.java +++ b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/TabulatorsTest.java @@ -202,26 +202,38 @@ public class TabulatorsTest extends OpTestCase { } } + private ResultAsserter mapTabulationAsserter(boolean ordered) { + return (act, exp, ord, par) -> { + if (par & (!ordered || !ord)) { + TabulatorsTest.nestedMapEqualityAssertion(act, exp); + } + else { + LambdaTestHelpers.assertContentsEqual(act, exp); + } + }; + } + private void exerciseMapTabulation(TestData> data, Collector collector, TabulationAssertion assertion) throws ReflectiveOperationException { - boolean ordered = data.isOrdered() - && !collector.characteristics().contains(Collector.Characteristics.UNORDERED); + boolean ordered = !collector.characteristics().contains(Collector.Characteristics.UNORDERED); + M m = withData(data) .terminal(s -> s.collect(collector)) - .parallelEqualityAsserter(ordered ? LambdaTestHelpers::assertContentsEqual : this::nestedMapEqualityAssertion) + .resultAsserter(mapTabulationAsserter(ordered)) .exercise(); assertion.assertValue(m, () -> data.stream(), ordered); + m = withData(data) .terminal(s -> s.unordered().collect(collector)) - .parallelEqualityAsserter(this::nestedMapEqualityAssertion) + .resultAsserter(mapTabulationAsserter(ordered)) .exercise(); assertion.assertValue(m, () -> data.stream(), false); } - private void nestedMapEqualityAssertion(Object o1, Object o2) { + private static void nestedMapEqualityAssertion(Object o1, Object o2) { if (o1 instanceof Map) { Map m1 = (Map) o1; Map m2 = (Map) o2; diff --git a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/ToArrayOpTest.java b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/ToArrayOpTest.java index 0971e89fcf1..04475e87260 100644 --- a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/ToArrayOpTest.java +++ b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/ToArrayOpTest.java @@ -29,6 +29,7 @@ import java.util.function.Function; import java.util.stream.*; import static java.util.stream.LambdaTestHelpers.*; +import static org.testng.Assert.assertEquals; /** @@ -134,15 +135,51 @@ public class ToArrayOpTest extends OpTestCase { s -> s.sorted() )); + private ResultAsserter statefulOpResultAsserter(TestData.OfRef data) { + return (act, exp, ord, par) -> { + if (par) { + if (!data.isOrdered()) { + // Relax the checking if the data source is unordered + // It is not exactly possible to determine if the limit + // operation is present and if it is before or after + // the sorted operation + // If the limit operation is present and before the sorted + // operation then the sub-set output after limit is a + // non-deterministic sub-set of the source + List expected = new ArrayList<>(); + data.forEach(expected::add); + + List actual = Arrays.asList(act); + + assertEquals(actual.size(), exp.length); + assertTrue(expected.containsAll(actual)); + return; + } + else if (!ord) { + LambdaTestHelpers.assertContentsUnordered(Arrays.asList(act), + Arrays.asList(exp)); + return; + } + } + assertEquals(act, exp); + }; + } + @Test(dataProvider = "StreamTestData", dataProviderClass = StreamTestDataProvider.class) public void testStatefulOpPermutations(String name, TestData.OfRef data) { for (Function, Stream> f : statefulOpPermutations) { - exerciseTerminalOps(data, f, s -> s.toArray()); + withData(data).terminal(f, s -> s.toArray()) + .resultAsserter(statefulOpResultAsserter(data)) + .exercise(); - Integer[] is = exerciseTerminalOps(data, f, s -> s.toArray(Integer[]::new)); + Integer[] is = withData(data).terminal(f, s -> s.toArray(Integer[]::new)) + .resultAsserter(statefulOpResultAsserter(data)) + .exercise(); assertEquals(is.getClass(), Integer[].class); - Number[] ns = exerciseTerminalOps(data, f, s -> s.toArray(Number[]::new)); + Number[] ns = withData(data).terminal(f, s -> s.toArray(Number[]::new)) + .resultAsserter(statefulOpResultAsserter(data)) + .exercise(); assertEquals(ns.getClass(), Number[].class); if (data.size() > 0) { From 338bfbd857a8cb472938ffc9c8be3e909951a02c Mon Sep 17 00:00:00 2001 From: Paul Sandoz Date: Thu, 20 Jun 2013 11:21:13 +0200 Subject: [PATCH 004/127] 8016139: PrimitiveIterator.forEachRemaining Reviewed-by: alanb --- .../classes/java/util/PrimitiveIterator.java | 28 +++++++++++++++---- 1 file changed, 23 insertions(+), 5 deletions(-) diff --git a/jdk/src/share/classes/java/util/PrimitiveIterator.java b/jdk/src/share/classes/java/util/PrimitiveIterator.java index f05d9e06605..6689614b337 100644 --- a/jdk/src/share/classes/java/util/PrimitiveIterator.java +++ b/jdk/src/share/classes/java/util/PrimitiveIterator.java @@ -55,16 +55,34 @@ import java.util.function.LongConsumer; * is set to {@code true} then diagnostic warnings are reported if boxing of * primitive values occur when operating on primitive subtype specializations. * - * @param the boxed type of the primitive type + * @param the type of elements returned by this PrimitiveIterator. The + * type must be a wrapper type for a primitive type, such as + * {@code Integer} for the primitive {@code int} type. + * @param the type of primitive consumer. The type must be a + * primitive specialization of {@link java.util.function.Consumer} for + * {@code T}, such as {@link java.util.function.IntConsumer} for + * {@code Integer}. + * * @since 1.8 */ -public interface PrimitiveIterator extends Iterator { +public interface PrimitiveIterator extends Iterator { + + /** + * Performs the given action for each remaining element, in the order + * elements occur when iterating, until all elements have been processed + * or the action throws an exception. Errors or runtime exceptions + * thrown by the action are relayed to the caller. + * + * @param action The action to be performed for each element + * @throws NullPointerException if the specified action is null + */ + void forEachRemaining(T_CONS action); /** * An Iterator specialized for {@code int} values. * @since 1.8 */ - public static interface OfInt extends PrimitiveIterator { + public static interface OfInt extends PrimitiveIterator { /** * Returns the next {@code int} element in the iteration. @@ -138,7 +156,7 @@ public interface PrimitiveIterator extends Iterator { * An Iterator specialized for {@code long} values. * @since 1.8 */ - public static interface OfLong extends PrimitiveIterator { + public static interface OfLong extends PrimitiveIterator { /** * Returns the next {@code long} element in the iteration. @@ -211,7 +229,7 @@ public interface PrimitiveIterator extends Iterator { * An Iterator specialized for {@code double} values. * @since 1.8 */ - public static interface OfDouble extends PrimitiveIterator { + public static interface OfDouble extends PrimitiveIterator { /** * Returns the next {@code double} element in the iteration. From 3377e0da574c89b0131998cea8d3505ad4cf6f42 Mon Sep 17 00:00:00 2001 From: Mike Duigou Date: Thu, 20 Jun 2013 07:23:51 -0700 Subject: [PATCH 005/127] 8017088: Map/HashMap.compute() incorrect with key mapping to null value Reviewed-by: dl, dholmes, plevart --- jdk/src/share/classes/java/util/HashMap.java | 36 ++++++------ jdk/src/share/classes/java/util/Map.java | 40 +++++++++---- jdk/test/java/util/Map/Defaults.java | 61 +++++++++++++++++--- 3 files changed, 102 insertions(+), 35 deletions(-) diff --git a/jdk/src/share/classes/java/util/HashMap.java b/jdk/src/share/classes/java/util/HashMap.java index a13c4f8be11..eab47e3776d 100644 --- a/jdk/src/share/classes/java/util/HashMap.java +++ b/jdk/src/share/classes/java/util/HashMap.java @@ -1749,25 +1749,25 @@ public class HashMap V oldValue = pEntry.value; if (oldValue != null) { V newValue = remappingFunction.apply(key, oldValue); - if (newValue == null) { // remove mapping - modCount++; - size--; - tb.deleteTreeNode(p); - pEntry.recordRemoval(this); - if (tb.root == null || tb.first == null) { - // assert tb.root == null && tb.first == null : - // "TreeBin.first and root should both be null"; - // TreeBin is now empty, we should blank this bin - table[i] = null; - } - } else { - pEntry.value = newValue; - pEntry.recordAccess(this); + if (newValue == null) { // remove mapping + modCount++; + size--; + tb.deleteTreeNode(p); + pEntry.recordRemoval(this); + if (tb.root == null || tb.first == null) { + // assert tb.root == null && tb.first == null : + // "TreeBin.first and root should both be null"; + // TreeBin is now empty, we should blank this bin + table[i] = null; } - return newValue; + } else { + pEntry.value = newValue; + pEntry.recordAccess(this); } + return newValue; } } + } return null; } @@ -1779,7 +1779,7 @@ public class HashMap if (key == null) { V oldValue = nullKeyEntry == null ? null : nullKeyEntry.value; V newValue = remappingFunction.apply(key, oldValue); - if (newValue != oldValue) { + if (newValue != oldValue || (oldValue == null && nullKeyEntry != null)) { if (newValue == null) { removeNullKey(); } else { @@ -1803,7 +1803,7 @@ public class HashMap if (e.hash == hash && Objects.equals(e.key, key)) { V oldValue = e.value; V newValue = remappingFunction.apply(key, oldValue); - if (newValue != oldValue) { + if (newValue != oldValue || oldValue == null) { if (newValue == null) { modCount++; size--; @@ -1829,7 +1829,7 @@ public class HashMap TreeNode p = tb.getTreeNode(hash, key); V oldValue = p == null ? null : (V)p.entry.value; V newValue = remappingFunction.apply(key, oldValue); - if (newValue != oldValue) { + if (newValue != oldValue || (oldValue == null && p != null)) { if (newValue == null) { Entry pEntry = (Entry)p.entry; modCount++; diff --git a/jdk/src/share/classes/java/util/Map.java b/jdk/src/share/classes/java/util/Map.java index 40219ba04c3..bfb72d7f10b 100644 --- a/jdk/src/share/classes/java/util/Map.java +++ b/jdk/src/share/classes/java/util/Map.java @@ -640,7 +640,7 @@ public interface Map { * @param key key with which the specified value is to be associated * @param value value to be associated with the specified key * @return the previous value associated with the specified key, or - * {@code 1} if there was no mapping for the key. + * {@code null} if there was no mapping for the key. * (A {@code null} return can also indicate that the map * previously associated {@code null} with the key, * if the implementation supports null values.) @@ -994,20 +994,40 @@ public interface Map { V oldValue = get(key); for (;;) { V newValue = remappingFunction.apply(key, oldValue); - if (oldValue != null) { - if (newValue != null) { - if (replace(key, oldValue, newValue)) - return newValue; - } else if (remove(key, oldValue)) { + if (newValue == null) { + // delete mapping + if(oldValue != null || containsKey(key)) { + // something to remove + if (remove(key, oldValue)) { + // removed the old value as expected + return null; + } + + // some other value replaced old value. try again. + oldValue = get(key); + } else { + // nothing to do. Leave things as they were. return null; } - oldValue = get(key); } else { - if (newValue != null) { - if ((oldValue = putIfAbsent(key, newValue)) == null) + // add or replace old mapping + if (oldValue != null) { + // replace + if (replace(key, oldValue, newValue)) { + // replaced as expected. return newValue; + } + + // some other value replaced old value. try again. + oldValue = get(key); } else { - return null; + // add (replace if oldValue was null) + if ((oldValue = putIfAbsent(key, newValue)) == null) { + // replaced + return newValue; + } + + // some other value replaced old value. try again. } } } diff --git a/jdk/test/java/util/Map/Defaults.java b/jdk/test/java/util/Map/Defaults.java index 3cd677aa84a..48a93525b7f 100644 --- a/jdk/test/java/util/Map/Defaults.java +++ b/jdk/test/java/util/Map/Defaults.java @@ -271,14 +271,21 @@ public class Defaults { @Test(dataProvider = "Map rw=true keys=withNull values=withNull") public void testComputeIfPresentNulls(String description, Map map) { - assertTrue(map.containsKey(null)); - assertNull(map.get(null)); + assertTrue(map.containsKey(null), description + ": null key absent"); + assertNull(map.get(null), description + ": value not null"); assertSame(map.computeIfPresent(null, (k, v) -> { - fail(); + fail(description + ": null value is not deemed present"); return EXTRA_VALUE; }), null, description); assertTrue(map.containsKey(null)); - assertSame(map.get(null), null, description); + assertNull(map.get(null), description); + assertNull(map.remove(EXTRA_KEY), description + ": unexpected mapping"); + assertNull(map.put(EXTRA_KEY, null), description + ": unexpected value"); + assertSame(map.computeIfPresent(EXTRA_KEY, (k, v) -> { + fail(description + ": null value is not deemed present"); + return EXTRA_VALUE; + }), null, description); + assertNull(map.get(EXTRA_KEY), description + ": null mapping gone"); } @Test(dataProvider = "Map rw=true keys=all values=all") @@ -306,6 +313,12 @@ public class Defaults { public void testComputeNulls(String description, Map map) { assertTrue(map.containsKey(null), "null key absent"); assertNull(map.get(null), "value not null"); + assertSame(map.compute(null, (k, v) -> { + assertNull(k); + assertNull(v); + return null; + }), null, description); + assertFalse(map.containsKey(null), description + ": null key present."); assertSame(map.compute(null, (k, v) -> { assertSame(k, null); assertNull(v); @@ -313,13 +326,47 @@ public class Defaults { }), EXTRA_VALUE, description); assertTrue(map.containsKey(null)); assertSame(map.get(null), EXTRA_VALUE, description); - assertSame(map.remove(null), EXTRA_VALUE, "removed value not expected"); - assertFalse(map.containsKey(null), "null key present"); + assertSame(map.remove(null), EXTRA_VALUE, description + ": removed value not expected"); + // no mapping before and after + assertFalse(map.containsKey(null), description + ": null key present"); assertSame(map.compute(null, (k, v) -> { - assertSame(k, null); + assertNull(k); + assertNull(v); + return null; + }), null, description + ": expected null result" ); + assertFalse(map.containsKey(null), description + ": null key present"); + // compute with map not containing value + assertNull(map.remove(EXTRA_KEY), description + ": unexpected mapping"); + assertFalse(map.containsKey(EXTRA_KEY), description + ": key present"); + assertSame(map.compute(EXTRA_KEY, (k, v) -> { + assertSame(k, EXTRA_KEY); assertNull(v); return null; }), null, description); + assertFalse(map.containsKey(EXTRA_KEY), description + ": null key present"); + // ensure removal. + assertNull(map.put(EXTRA_KEY, EXTRA_VALUE)); + assertSame(map.compute(EXTRA_KEY, (k, v) -> { + assertSame(k, EXTRA_KEY); + assertSame(v, EXTRA_VALUE); + return null; + }), null, description + ": null resulted expected"); + assertFalse(map.containsKey(EXTRA_KEY), description + ": null key present"); + // compute with map containing null value + assertNull(map.put(EXTRA_KEY, null), description + ": unexpected value"); + assertSame(map.compute(EXTRA_KEY, (k, v) -> { + assertSame(k, EXTRA_KEY); + assertNull(v); + return null; + }), null, description); + assertFalse(map.containsKey(EXTRA_KEY), description + ": null key present"); + assertNull(map.put(EXTRA_KEY, null), description + ": unexpected value"); + assertSame(map.compute(EXTRA_KEY, (k, v) -> { + assertSame(k, EXTRA_KEY); + assertNull(v); + return EXTRA_VALUE; + }), EXTRA_VALUE, description); + assertTrue(map.containsKey(EXTRA_KEY), "null key present"); } @Test(dataProvider = "Map rw=true keys=all values=all") From b0246ef1ae68f6210d950ad8890d0f685cc3da4e Mon Sep 17 00:00:00 2001 From: Xue-Lei Andrew Fan Date: Thu, 20 Jun 2013 07:48:49 -0700 Subject: [PATCH 006/127] 8017157: catch more exception in test RejectClientRenego Reviewed-by: vinnie --- .../ssl/internal/ssl/SSLSocketImpl/RejectClientRenego.java | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/jdk/test/sun/security/ssl/com/sun/net/ssl/internal/ssl/SSLSocketImpl/RejectClientRenego.java b/jdk/test/sun/security/ssl/com/sun/net/ssl/internal/ssl/SSLSocketImpl/RejectClientRenego.java index 65f6f6f1c66..29f80d9e15b 100644 --- a/jdk/test/sun/security/ssl/com/sun/net/ssl/internal/ssl/SSLSocketImpl/RejectClientRenego.java +++ b/jdk/test/sun/security/ssl/com/sun/net/ssl/internal/ssl/SSLSocketImpl/RejectClientRenego.java @@ -131,7 +131,7 @@ public class RejectClientRenego implements sslOS.flush(); } throw new Exception("Not reject client initialized renegotiation"); - } catch (SSLHandshakeException she) { + } catch (IOException ioe) { System.out.println("Got the expected exception"); } finally { sslSocket.close(); @@ -181,7 +181,7 @@ public class RejectClientRenego implements sslIS.read(); } throw new Exception("Not reject client initialized renegotiation"); - } catch (SSLHandshakeException she) { + } catch (IOException ioe) { System.out.println("Got the expected exception"); } finally { sslSocket.close(); From 92d31ec9c35e7858d41291f610853d7d76744b13 Mon Sep 17 00:00:00 2001 From: Chris Hegarty Date: Thu, 20 Jun 2013 18:53:57 +0100 Subject: [PATCH 007/127] 8014499: MulticastSocket should enable IP_MULTICAST_ALL (lnx) Co-authored-by: John Zavgren Reviewed-by: alanb, chegar --- .../native/java/net/PlainDatagramSocketImpl.c | 19 +++ .../java/net/MulticastSocket/Promiscuous.java | 137 ++++++++++++++++++ 2 files changed, 156 insertions(+) create mode 100644 jdk/test/java/net/MulticastSocket/Promiscuous.java diff --git a/jdk/src/solaris/native/java/net/PlainDatagramSocketImpl.c b/jdk/src/solaris/native/java/net/PlainDatagramSocketImpl.c index 27c78f23a42..9ef598460b6 100644 --- a/jdk/src/solaris/native/java/net/PlainDatagramSocketImpl.c +++ b/jdk/src/solaris/native/java/net/PlainDatagramSocketImpl.c @@ -43,7 +43,14 @@ #ifndef SO_BSDCOMPAT #define SO_BSDCOMPAT 14 #endif +/** + * IP_MULTICAST_ALL has been supported since kernel version 2.6.31 + * but we may be building on a machine that is older than that. + */ +#ifndef IP_MULTICAST_ALL +#define IP_MULTICAST_ALL 49 #endif +#endif // __linux__` #ifndef IPTOS_TOS_MASK #define IPTOS_TOS_MASK 0x1e @@ -980,6 +987,18 @@ Java_java_net_PlainDatagramSocketImpl_datagramSocketCreate(JNIEnv *env, setsockopt(fd, SOL_SOCKET, SO_BROADCAST, (char*) &t, sizeof(int)); +#if defined(__linux__) + arg = 0; + int level = (domain == AF_INET6) ? IPPROTO_IPV6 : IPPROTO_IP; + if ((setsockopt(fd, level, IP_MULTICAST_ALL, (char*)&arg, sizeof(arg)) < 0) && + (errno != ENOPROTOOPT)) { + JNU_ThrowByName(env, JNU_JAVANETPKG "SocketException", + strerror(errno)); + close(fd); + return; + } +#endif + #if defined (__linux__) && defined (AF_INET6) /* * On Linux for IPv6 sockets we must set the hop limit diff --git a/jdk/test/java/net/MulticastSocket/Promiscuous.java b/jdk/test/java/net/MulticastSocket/Promiscuous.java new file mode 100644 index 00000000000..ce0a1033156 --- /dev/null +++ b/jdk/test/java/net/MulticastSocket/Promiscuous.java @@ -0,0 +1,137 @@ +/* + * Copyright (c) 2013, 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 + * @bug 8014499 + * @summary Test for interference when two sockets are bound to the same + * port but joined to different multicast groups + * @run main Promiscuous + * @run main/othervm -Djava.net.preferIPv4Stack=true Promiscuous + */ + +import java.io.IOException; +import static java.lang.System.out; +import java.net.*; + +public class Promiscuous { + + static final int TIMEOUT = 5 * 1000; // 5 secs + static int id = 1000; + + static void receive(MulticastSocket mc, boolean datagramExpected, int id) + throws IOException + { + byte[] ba = new byte[100]; + DatagramPacket p = new DatagramPacket(ba, ba.length); + try { + mc.receive(p); + int recvId = Integer.parseInt( + new String(p.getData(), 0, p.getLength(), "UTF-8")); + if (datagramExpected) { + if (recvId != id) + throw new RuntimeException("Unexpected id, got " + recvId + + ", expected: " + id); + out.printf("Received message as expected, %s\n", p.getAddress()); + } else { + throw new RuntimeException("Unexpected message received, " + + p.getAddress()); + } + } catch (SocketTimeoutException e) { + if (datagramExpected) + throw new RuntimeException("Expected message not received, " + + e.getMessage()); + else + out.printf("Message not received, as expected\n"); + } + } + + static void test(InetAddress group1, InetAddress group2) + throws IOException + { + try (MulticastSocket mc1 = new MulticastSocket(); + MulticastSocket mc2 = new MulticastSocket(mc1.getLocalPort()); + DatagramSocket ds = new DatagramSocket()) { + final int port = mc1.getLocalPort(); + out.printf("Using port: %d\n", port); + + mc1.setSoTimeout(TIMEOUT); + mc2.setSoTimeout(TIMEOUT); + int nextId = id; + byte[] msg = Integer.toString(nextId).getBytes("UTF-8"); + DatagramPacket p = new DatagramPacket(msg, msg.length); + p.setAddress(group1); + p.setPort(port); + + mc1.joinGroup(group1); + out.printf("mc1 joined the MC group: %s\n", group1); + mc2.joinGroup(group2); + out.printf("mc2 joined the MC group: %s\n", group2); + + out.printf("Sending datagram to: %s/%d\n", group1, port); + ds.send(p); + + // the packet should be received by mc1 only + receive(mc1, true, nextId); + receive(mc2, false, 0); + + nextId = ++id; + msg = Integer.toString(nextId).getBytes("UTF-8"); + p = new DatagramPacket(msg, msg.length); + p.setAddress(group2); + p.setPort(port); + + out.printf("Sending datagram to: %s/%d\n", group2, port); + ds.send(p); + + // the packet should be received by mc2 only + receive(mc2, true, nextId); + receive(mc1, false, 0); + + mc1.leaveGroup(group1); + mc2.leaveGroup(group2); + } + } + + public static void main(String args[]) throws IOException { + String os = System.getProperty("os.name"); + + // Requires IP_MULTICAST_ALL on Linux (new since 2.6.31) so skip + // on older kernels. Note that we skip on <= version 3 to keep the + // parsing simple + if (os.equals("Linux")) { + String osversion = System.getProperty("os.version"); + String[] vers = osversion.split("\\.", 0); + int major = Integer.parseInt(vers[0]); + if (major < 3) { + System.out.format("Kernel version is %s, test skipped%n", osversion); + return; + } + } + + // multicast groups used for the test + InetAddress ip4Group1 = InetAddress.getByName("224.7.8.9"); + InetAddress ip4Group2 = InetAddress.getByName("225.4.5.6"); + + test(ip4Group1, ip4Group2); + } +} From a7f93a548005138b484bbb8247e288f5fc4c0072 Mon Sep 17 00:00:00 2001 From: Alan Bateman Date: Thu, 20 Jun 2013 19:14:30 +0100 Subject: [PATCH 008/127] 8014377: (dc) DatagramChannel should set IP_MULTICAST_ALL=0 (lnx) Reviewed-by: chegar, jzavgren --- jdk/src/solaris/native/sun/nio/ch/Net.c | 35 ++- .../channels/DatagramChannel/Promiscuous.java | 214 ++++++++++++++++++ 2 files changed, 245 insertions(+), 4 deletions(-) create mode 100644 jdk/test/java/nio/channels/DatagramChannel/Promiscuous.java diff --git a/jdk/src/solaris/native/sun/nio/ch/Net.c b/jdk/src/solaris/native/sun/nio/ch/Net.c index 0163fb6dc9f..679a9d8d0da 100644 --- a/jdk/src/solaris/native/sun/nio/ch/Net.c +++ b/jdk/src/solaris/native/sun/nio/ch/Net.c @@ -40,6 +40,17 @@ #include "nio.h" #include "sun_nio_ch_PollArrayWrapper.h" + +/** + * IP_MULTICAST_ALL supported since 2.6.31 but may not be available at + * build time. + */ +#ifdef __linux__ + #ifndef IP_MULTICAST_ALL + #define IP_MULTICAST_ALL 49 + #endif +#endif + #ifdef _ALLBSD_SOURCE #ifndef IP_BLOCK_SOURCE @@ -175,7 +186,7 @@ Java_sun_nio_ch_Net_socket0(JNIEnv *env, jclass cl, jboolean preferIPv6, sizeof(int)) < 0) { JNU_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "sun.nio.ch.Net.setIntOption"); + "Unable to set IPV6_V6ONLY"); close(fd); return -1; } @@ -188,11 +199,27 @@ Java_sun_nio_ch_Net_socket0(JNIEnv *env, jclass cl, jboolean preferIPv6, sizeof(arg)) < 0) { JNU_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "sun.nio.ch.Net.setIntOption"); + "Unable to set SO_REUSEADDR"); close(fd); return -1; } } + +#if defined(__linux__) + if (type == SOCK_DGRAM) { + int arg = 0; + int level = (domain == AF_INET6) ? IPPROTO_IPV6 : IPPROTO_IP; + if ((setsockopt(fd, level, IP_MULTICAST_ALL, (char*)&arg, sizeof(arg)) < 0) && + (errno != ENOPROTOOPT)) { + JNU_ThrowByNameWithLastError(env, + JNU_JAVANETPKG "SocketException", + "Unable to set IP_MULTICAST_ALL"); + close(fd); + return -1; + } + } +#endif + #if defined(__linux__) && defined(AF_INET6) /* By default, Linux uses the route default */ if (domain == AF_INET6 && type == SOCK_DGRAM) { @@ -201,7 +228,7 @@ Java_sun_nio_ch_Net_socket0(JNIEnv *env, jclass cl, jboolean preferIPv6, sizeof(arg)) < 0) { JNU_ThrowByNameWithLastError(env, JNU_JAVANETPKG "SocketException", - "sun.nio.ch.Net.setIntOption"); + "Unable to set IPV6_MULTICAST_HOPS"); close(fd); return -1; } @@ -646,7 +673,7 @@ Java_sun_nio_ch_Net_poll(JNIEnv* env, jclass this, jobject fdo, jint events, jlo return pfd.revents; } else if (errno == EINTR) { return IOS_INTERRUPTED; - } else if (rv < 0) { + } else { handleSocketError(env, errno); return IOS_THROWN; } diff --git a/jdk/test/java/nio/channels/DatagramChannel/Promiscuous.java b/jdk/test/java/nio/channels/DatagramChannel/Promiscuous.java new file mode 100644 index 00000000000..027b4b79eea --- /dev/null +++ b/jdk/test/java/nio/channels/DatagramChannel/Promiscuous.java @@ -0,0 +1,214 @@ +/* + * Copyright (c) 2013, 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 + * @bug 8014377 + * @summary Test for interference when two sockets are bound to the same + * port but joined to different multicast groups + * @build Promiscuous NetworkConfiguration + * @run main Promiscuous + * @run main/othervm -Djava.net.preferIPv4Stack=true Promiscuous + */ + +import java.nio.ByteBuffer; +import java.nio.channels.*; +import java.net.*; +import static java.net.StandardProtocolFamily.*; +import java.util.*; +import java.io.IOException; + +public class Promiscuous { + + static final Random rand = new Random(); + + static final ProtocolFamily UNSPEC = new ProtocolFamily() { + public String name() { + return "UNSPEC"; + } + }; + + /** + * Sends a datagram to the given multicast group + */ + static int sendDatagram(NetworkInterface nif, + InetAddress group, + int port) + throws IOException + { + ProtocolFamily family = (group instanceof Inet6Address) ? + StandardProtocolFamily.INET6 : StandardProtocolFamily.INET; + DatagramChannel dc = DatagramChannel.open(family) + .setOption(StandardSocketOptions.IP_MULTICAST_IF, nif); + int id = rand.nextInt(); + byte[] msg = Integer.toString(id).getBytes("UTF-8"); + ByteBuffer buf = ByteBuffer.wrap(msg); + System.out.format("Send message -> group %s (id=0x%x)\n", + group.getHostAddress(), id); + dc.send(buf, new InetSocketAddress(group, port)); + dc.close(); + return id; + } + + /** + * Wait (with timeout) for datagram. The {@code datagramExepcted} + * parameter indicates whether a datagram is expected, and if + * {@true} then {@code id} is the identifier in the payload. + */ + static void receiveDatagram(DatagramChannel dc, + String name, + boolean datagramExepcted, + int id) + throws IOException + { + System.out.println("Checking if received by " + name); + + Selector sel = Selector.open(); + dc.configureBlocking(false); + dc.register(sel, SelectionKey.OP_READ); + ByteBuffer buf = ByteBuffer.allocateDirect(100); + + try { + for (;;) { + System.out.println("Waiting to receive message"); + sel.select(5*1000); + SocketAddress sa = dc.receive(buf); + + // no datagram received + if (sa == null) { + if (datagramExepcted) { + throw new RuntimeException("Expected message not recieved"); + } + System.out.println("No message received (correct)"); + return; + } + + // datagram received + + InetAddress sender = ((InetSocketAddress)sa).getAddress(); + buf.flip(); + byte[] bytes = new byte[buf.remaining()]; + buf.get(bytes); + int receivedId = Integer.parseInt(new String(bytes)); + + System.out.format("Received message from %s (id=0x%x)\n", + sender, receivedId); + + if (!datagramExepcted) { + if (receivedId == id) + throw new RuntimeException("Message not expected"); + System.out.println("Message ignored (has wrong id)"); + } else { + if (receivedId == id) { + System.out.println("Message expected"); + return; + } + System.out.println("Message ignored (wrong sender)"); + } + + sel.selectedKeys().clear(); + buf.rewind(); + } + } finally { + sel.close(); + } + } + + static void test(ProtocolFamily family, + NetworkInterface nif, + InetAddress group1, + InetAddress group2) + throws IOException + { + + System.out.format("%nTest family=%s%n", family.name()); + + DatagramChannel dc1 = (family == UNSPEC) ? + DatagramChannel.open() : DatagramChannel.open(family); + DatagramChannel dc2 = (family == UNSPEC) ? + DatagramChannel.open() : DatagramChannel.open(family); + + try { + dc1.setOption(StandardSocketOptions.SO_REUSEADDR, true); + dc2.setOption(StandardSocketOptions.SO_REUSEADDR, true); + + dc1.bind(new InetSocketAddress(0)); + int port = dc1.socket().getLocalPort(); + dc2.bind(new InetSocketAddress(port)); + + System.out.format("dc1 joining [%s]:%d @ %s\n", + group1.getHostAddress(), port, nif.getName()); + System.out.format("dc2 joining [%s]:%d @ %s\n", + group2.getHostAddress(), port, nif.getName()); + + dc1.join(group1, nif); + dc2.join(group2, nif); + + int id = sendDatagram(nif, group1, port); + + receiveDatagram(dc1, "dc1", true, id); + receiveDatagram(dc2, "dc2", false, id); + + id = sendDatagram(nif, group2, port); + + receiveDatagram(dc1, "dc1", false, id); + receiveDatagram(dc2, "dc2", true, id); + + } finally { + dc1.close(); + dc2.close(); + } + } + + public static void main(String[] args) throws IOException { + String os = System.getProperty("os.name"); + + // Requires IP_MULTICAST_ALL on Linux (new since 2.6.31) so skip + // on older kernels. Note that we skip on <= version 3 to keep the + // parsing simple + if (os.equals("Linux")) { + String osversion = System.getProperty("os.version"); + String[] vers = osversion.split("\\.", 0); + int major = Integer.parseInt(vers[0]); + if (major < 3) { + System.out.format("Kernel version is %s, test skipped%n", osversion); + return; + } + } + + // get local network configuration to use + NetworkConfiguration config = NetworkConfiguration.probe(); + + // multicast groups used for the test + InetAddress ip4Group1 = InetAddress.getByName("225.4.5.6"); + InetAddress ip4Group2 = InetAddress.getByName("225.4.6.6"); + + for (NetworkInterface nif: config.ip4Interfaces()) { + InetAddress source = config.ip4Addresses(nif).iterator().next(); + test(INET, nif, ip4Group1, ip4Group2); + + // Solaris and Linux allow IPv6 sockets join IPv4 multicast groups + if (os.equals("SunOS") || os.equals("Linux")) + test(UNSPEC, nif, ip4Group1, ip4Group2); + } + } +} From af996219c70027429a2ae317e6e7259c0e3a2bc9 Mon Sep 17 00:00:00 2001 From: Weijun Wang Date: Fri, 21 Jun 2013 18:26:13 +0800 Subject: [PATCH 009/127] 8001326: Improve Kerberos caching Reviewed-by: valeriep --- .../jgss/krb5/AcceptSecContextToken.java | 27 +- .../sun/security/krb5/EncryptionKey.java | 6 +- .../classes/sun/security/krb5/KrbApRep.java | 8 +- .../classes/sun/security/krb5/KrbApReq.java | 46 ++- .../security/krb5/internal/ReplayCache.java | 72 ++++ .../krb5/internal/rcache/AuthList.java | 144 +++++++ .../krb5/internal/rcache/AuthTime.java | 133 +++++-- .../internal/rcache/AuthTimeWithHash.java | 124 ++++++ .../krb5/internal/rcache/DflCache.java | 365 ++++++++++++++++++ .../{CacheTable.java => MemoryCache.java} | 70 ++-- .../krb5/internal/rcache/ReplayCache.java | 143 ------- jdk/test/java/security/testlibrary/Proc.java | 325 ++++++++++++++++ .../security/krb5/auto/AcceptorSubKey.java | 14 +- .../sun/security/krb5/auto/BasicProc.java | 192 +++++++++ jdk/test/sun/security/krb5/auto/Context.java | 8 +- jdk/test/sun/security/krb5/auto/KDC.java | 2 +- .../krb5/auto/NoneReplayCacheTest.java | 70 ++++ .../krb5/auto/ReplayCacheExpunge.java | 79 ++++ .../krb5/auto/ReplayCachePrecise.java | 84 ++++ ...{ReplayCache.java => ReplayCacheTest.java} | 25 +- .../krb5/auto/ReplayCacheTestProc.java | 327 ++++++++++++++++ .../sun/security/krb5/ccache/EmptyCC.java | 34 +- 22 files changed, 2005 insertions(+), 293 deletions(-) create mode 100644 jdk/src/share/classes/sun/security/krb5/internal/ReplayCache.java create mode 100644 jdk/src/share/classes/sun/security/krb5/internal/rcache/AuthList.java create mode 100644 jdk/src/share/classes/sun/security/krb5/internal/rcache/AuthTimeWithHash.java create mode 100644 jdk/src/share/classes/sun/security/krb5/internal/rcache/DflCache.java rename jdk/src/share/classes/sun/security/krb5/internal/rcache/{CacheTable.java => MemoryCache.java} (51%) delete mode 100644 jdk/src/share/classes/sun/security/krb5/internal/rcache/ReplayCache.java create mode 100644 jdk/test/java/security/testlibrary/Proc.java create mode 100644 jdk/test/sun/security/krb5/auto/BasicProc.java create mode 100644 jdk/test/sun/security/krb5/auto/NoneReplayCacheTest.java create mode 100644 jdk/test/sun/security/krb5/auto/ReplayCacheExpunge.java create mode 100644 jdk/test/sun/security/krb5/auto/ReplayCachePrecise.java rename jdk/test/sun/security/krb5/auto/{ReplayCache.java => ReplayCacheTest.java} (72%) create mode 100644 jdk/test/sun/security/krb5/auto/ReplayCacheTestProc.java diff --git a/jdk/src/share/classes/sun/security/jgss/krb5/AcceptSecContextToken.java b/jdk/src/share/classes/sun/security/jgss/krb5/AcceptSecContextToken.java index 80da88eadb5..35882bc3fdc 100644 --- a/jdk/src/share/classes/sun/security/jgss/krb5/AcceptSecContextToken.java +++ b/jdk/src/share/classes/sun/security/jgss/krb5/AcceptSecContextToken.java @@ -27,9 +27,10 @@ package sun.security.jgss.krb5; import org.ietf.jgss.*; import java.io.InputStream; -import java.io.OutputStream; import java.io.IOException; -import java.io.ByteArrayInputStream; +import java.security.AccessController; + +import sun.security.action.GetBooleanAction; import sun.security.krb5.*; class AcceptSecContextToken extends InitialToken { @@ -42,23 +43,19 @@ class AcceptSecContextToken extends InitialToken { */ public AcceptSecContextToken(Krb5Context context, KrbApReq apReq) - throws KrbException, IOException { + throws KrbException, IOException, GSSException { - /* - * RFC 1964, section 1.2 states: - * (1) context key: uses Kerberos session key (or subkey, if - * present in authenticator emitted by context initiator) directly - * - * This does not mention context acceptor. Hence we will not - * generate a subkey on the acceptor side. Note: Our initiator will - * still allow another acceptor to generate a subkey, even though - * our acceptor does not do so. - */ - boolean useSubkey = false; + boolean useSubkey = AccessController.doPrivileged( + new GetBooleanAction("sun.security.krb5.acceptor.subkey")); boolean useSequenceNumber = true; - apRep = new KrbApRep(apReq, useSequenceNumber, useSubkey); + EncryptionKey subKey = null; + if (useSubkey) { + subKey = new EncryptionKey(apReq.getCreds().getSessionKey()); + context.setKey(Krb5Context.ACCEPTOR_SUBKEY, subKey); + } + apRep = new KrbApRep(apReq, useSequenceNumber, subKey); context.resetMySequenceNumber(apRep.getSeqNumber().intValue()); diff --git a/jdk/src/share/classes/sun/security/krb5/EncryptionKey.java b/jdk/src/share/classes/sun/security/krb5/EncryptionKey.java index 155ccf67138..08fd9d2675e 100644 --- a/jdk/src/share/classes/sun/security/krb5/EncryptionKey.java +++ b/jdk/src/share/classes/sun/security/krb5/EncryptionKey.java @@ -297,9 +297,11 @@ public class EncryptionKey /** * Generates a sub-sessionkey from a given session key. + * + * Used in AcceptSecContextToken and KrbApReq by acceptor- and initiator- + * side respectively. */ - // Used in KrbApRep, KrbApReq - EncryptionKey(EncryptionKey key) throws KrbCryptoException { + public EncryptionKey(EncryptionKey key) throws KrbCryptoException { // generate random sub-session key keyValue = Confounder.bytes(key.keyValue.length); for (int i = 0; i < keyValue.length; i++) { diff --git a/jdk/src/share/classes/sun/security/krb5/KrbApRep.java b/jdk/src/share/classes/sun/security/krb5/KrbApRep.java index 2b994f7ea3a..792e5ae7659 100644 --- a/jdk/src/share/classes/sun/security/krb5/KrbApRep.java +++ b/jdk/src/share/classes/sun/security/krb5/KrbApRep.java @@ -53,12 +53,10 @@ public class KrbApRep { */ // Used in AcceptSecContextToken public KrbApRep(KrbApReq incomingReq, - boolean useSeqNumber, - boolean useSubKey) throws KrbException, IOException { + boolean useSeqNumber, + EncryptionKey subKey) + throws KrbException, IOException { - EncryptionKey subKey = - (useSubKey? - new EncryptionKey(incomingReq.getCreds().getSessionKey()):null); SeqNumber seqNum = new LocalSeqNumber(); init(incomingReq, subKey, seqNum); diff --git a/jdk/src/share/classes/sun/security/krb5/KrbApReq.java b/jdk/src/share/classes/sun/security/krb5/KrbApReq.java index 7ea5d85bf36..d05ee69c44e 100644 --- a/jdk/src/share/classes/sun/security/krb5/KrbApReq.java +++ b/jdk/src/share/classes/sun/security/krb5/KrbApReq.java @@ -33,12 +33,14 @@ package sun.security.krb5; import sun.security.krb5.internal.*; import sun.security.krb5.internal.crypto.*; -import sun.security.krb5.internal.rcache.*; import sun.security.jgss.krb5.Krb5AcceptCredential; import java.net.InetAddress; import sun.security.util.*; import java.io.IOException; import java.util.Arrays; +import java.security.MessageDigest; +import java.security.NoSuchAlgorithmException; +import sun.security.krb5.internal.rcache.AuthTimeWithHash; /** * This class encapsulates a KRB-AP-REQ that a client sends to a @@ -53,11 +55,23 @@ public class KrbApReq { private Credentials creds; private APReq apReqMessg; - private static CacheTable table = new CacheTable(); + // Used by acceptor side + private static ReplayCache rcache = ReplayCache.getInstance(); private static boolean DEBUG = Krb5.DEBUG; + private static final char[] hexConst = "0123456789ABCDEF".toCharArray(); + + private static final MessageDigest md; + + static { + try { + md = MessageDigest.getInstance("MD5"); + } catch (NoSuchAlgorithmException ex) { + throw new RuntimeException("Impossible"); + } + } /** - * Contructs a AP-REQ message to send to the peer. + * Constructs an AP-REQ message to send to the peer. * @param tgsCred the Credentials to be used to construct the * AP Request protocol message. * @param mutualRequired Whether mutual authentication is required @@ -81,7 +95,7 @@ public class KrbApReq { */ /** - * Contructs a AP-REQ message to send to the peer. + * Constructs an AP-REQ message to send to the peer. * @param tgsCred the Credentials to be used to construct the * AP Request protocol message. * @param mutualRequired Whether mutual authentication is required @@ -125,7 +139,7 @@ public class KrbApReq { } /** - * Contructs a AP-REQ message from the bytes received from the + * Constructs an AP-REQ message from the bytes received from the * peer. * @param message The message received from the peer * @param keys EncrtyptionKeys to decrypt the message; @@ -146,7 +160,7 @@ public class KrbApReq { } /** - * Contructs a AP-REQ message from the bytes received from the + * Constructs an AP-REQ message from the bytes received from the * peer. * @param value The DerValue that contains the * DER enoded AP-REQ protocol message @@ -297,15 +311,19 @@ public class KrbApReq { if (!authenticator.ctime.inClockSkew()) throw new KrbApErrException(Krb5.KRB_AP_ERR_SKEW); - // start to check if it is a replay attack. - AuthTime time = - new AuthTime(authenticator.ctime.getTime(), authenticator.cusec); - String client = authenticator.cname.toString(); - if (table.get(time, authenticator.cname.toString()) != null) { - throw new KrbApErrException(Krb5.KRB_AP_ERR_REPEAT); - } else { - table.put(client, time, System.currentTimeMillis()); + byte[] hash = md.digest(apReqMessg.authenticator.cipher); + char[] h = new char[hash.length * 2]; + for (int i=0; i>4]; + h[2*i+1] = hexConst[hash[i]&0xf]; } + AuthTimeWithHash time = new AuthTimeWithHash( + authenticator.cname.toString(), + apReqMessg.ticket.sname.toString(), + authenticator.ctime.getSeconds(), + authenticator.cusec, + new String(h)); + rcache.checkAndStore(KerberosTime.now(), time); if (initiator != null) { // sender host address diff --git a/jdk/src/share/classes/sun/security/krb5/internal/ReplayCache.java b/jdk/src/share/classes/sun/security/krb5/internal/ReplayCache.java new file mode 100644 index 00000000000..f6dc5702c47 --- /dev/null +++ b/jdk/src/share/classes/sun/security/krb5/internal/ReplayCache.java @@ -0,0 +1,72 @@ +/* + * Copyright (c) 2013, 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. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * 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. + */ + +package sun.security.krb5.internal; + +import sun.security.action.GetPropertyAction; +import sun.security.krb5.internal.rcache.AuthTimeWithHash; +import sun.security.krb5.internal.rcache.MemoryCache; +import sun.security.krb5.internal.rcache.DflCache; + +import java.security.AccessController; + +/** + * Models the replay cache of an acceptor as described in + * RFC 4120 3.2.3. + * @since 1.8 + */ +public abstract class ReplayCache { + public static ReplayCache getInstance(String type) { + if (type == null) { + return new MemoryCache(); + } else if (type.equals("dfl") || type.startsWith("dfl:")) { + return new DflCache(type); + } else if (type.equals("none")) { + return new ReplayCache() { + @Override + public void checkAndStore(KerberosTime currTime, AuthTimeWithHash time) + throws KrbApErrException { + // no check at all + } + }; + } else { + throw new IllegalArgumentException("Unknown type: " + type); + } + } + public static ReplayCache getInstance() { + String type = AccessController.doPrivileged( + new GetPropertyAction("sun.security.krb5.rcache")); + return getInstance(type); + } + + /** + * Accepts or rejects an AuthTime. + * @param currTime the current time + * @param time AuthTimeWithHash object calculated from authenticator + * @throws KrbApErrException if the authenticator is a replay + */ + public abstract void checkAndStore(KerberosTime currTime, AuthTimeWithHash time) + throws KrbApErrException; +} diff --git a/jdk/src/share/classes/sun/security/krb5/internal/rcache/AuthList.java b/jdk/src/share/classes/sun/security/krb5/internal/rcache/AuthList.java new file mode 100644 index 00000000000..8ec8e3ec8d3 --- /dev/null +++ b/jdk/src/share/classes/sun/security/krb5/internal/rcache/AuthList.java @@ -0,0 +1,144 @@ +/* + * Copyright (c) 2000, 2012, 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. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * 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. + */ + +/* + * + * (C) Copyright IBM Corp. 1999 All Rights Reserved. + * Copyright 1997 The Open Group Research Institute. All rights reserved. + */ + +package sun.security.krb5.internal.rcache; + +import sun.security.krb5.internal.Krb5; + +import java.util.Iterator; +import java.util.LinkedList; +import java.util.ListIterator; +import sun.security.krb5.internal.KerberosTime; +import sun.security.krb5.internal.KrbApErrException; + +/** + * This class provides an efficient caching mechanism to store AuthTimeWithHash + * from client authenticators. The cache minimizes the memory usage by doing + * self-cleanup of expired items in the cache. + * + * AuthTimeWithHash objects inside a cache are always sorted from big (new) to + * small (old) as determined by {@see AuthTimeWithHash#compareTo}. In the most + * common case a newcomer should be newer than the first element. + * + * @author Yanni Zhang + */ +public class AuthList { + + private final LinkedList entries; + private final int lifespan; + + /** + * Constructs a AuthList. + */ + public AuthList(int lifespan) { + this.lifespan = lifespan; + entries = new LinkedList<>(); + } + + /** + * Puts the authenticator timestamp into the cache in descending order, + * and throw an exception if it's already there. + */ + public void put(AuthTimeWithHash t, KerberosTime currentTime) + throws KrbApErrException { + + if (entries.isEmpty()) { + entries.addFirst(t); + } else { + AuthTimeWithHash temp = entries.getFirst(); + int cmp = temp.compareTo(t); + if (cmp < 0) { + // This is the most common case, newly received authenticator + // has larger timestamp. + entries.addFirst(t); + } else if (cmp == 0) { + throw new KrbApErrException(Krb5.KRB_AP_ERR_REPEAT); + } else { + //unless client clock being re-adjusted. + ListIterator it = entries.listIterator(1); + boolean found = false; + while (it.hasNext()) { + temp = it.next(); + cmp = temp.compareTo(t); + if (cmp < 0) { + // Find an older one, put in front of it + entries.add(entries.indexOf(temp), t); + found = true; + break; + } else if (cmp == 0) { + throw new KrbApErrException(Krb5.KRB_AP_ERR_REPEAT); + } + } + if (!found) { + // All is newer than the newcomer. Sigh. + entries.addLast(t); + } + } + } + + // let us cleanup while we are here + long timeLimit = currentTime.getSeconds() - lifespan; + ListIterator it = entries.listIterator(0); + AuthTimeWithHash temp = null; + int index = -1; + while (it.hasNext()) { + // search expired timestamps. + temp = it.next(); + if (temp.ctime < timeLimit) { + index = entries.indexOf(temp); + break; + } + } + // It would be nice if LinkedList has a method called truncate(index). + if (index > -1) { + do { + // remove expired timestamps from the list. + entries.removeLast(); + } while(entries.size() > index); + } + } + + public boolean isEmpty() { + return entries.isEmpty(); + } + + public String toString() { + StringBuilder sb = new StringBuilder(); + Iterator iter = entries.descendingIterator(); + int pos = entries.size(); + while (iter.hasNext()) { + AuthTimeWithHash at = iter.next(); + sb.append('#').append(pos--).append(": ") + .append(at.toString()).append('\n'); + } + return sb.toString(); + } +} diff --git a/jdk/src/share/classes/sun/security/krb5/internal/rcache/AuthTime.java b/jdk/src/share/classes/sun/security/krb5/internal/rcache/AuthTime.java index e7ebb7e08ec..7183d7d5c05 100644 --- a/jdk/src/share/classes/sun/security/krb5/internal/rcache/AuthTime.java +++ b/jdk/src/share/classes/sun/security/krb5/internal/rcache/AuthTime.java @@ -1,4 +1,5 @@ /* + * Copyright (c) 2013, 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 @@ -30,54 +31,126 @@ package sun.security.krb5.internal.rcache; -import sun.security.krb5.internal.KerberosTime; +import java.io.IOException; +import java.nio.BufferUnderflowException; +import java.nio.ByteBuffer; +import java.nio.ByteOrder; +import java.nio.channels.SeekableByteChannel; +import java.nio.charset.StandardCharsets; +import java.util.StringTokenizer; /** - * The class represents the timestamp in authenticator. + * The class represents an old style replay cache entry. It is only used in + * a dfl file. * + * @author Sun/Oracle * @author Yanni Zhang */ public class AuthTime { - long kerberosTime; - int cusec; + final int ctime; + final int cusec; + final String client; + final String server; /** - * Constructs a new AuthTime. - * @param time time from the Authenticator. - * @param cusec microsecond field from the Authenticator. + * Constructs an AuthTime. */ - public AuthTime(long time, int c) { - kerberosTime = time; - cusec = c; + public AuthTime(String client, String server, + int ctime, int cusec) { + this.ctime = ctime; + this.cusec = cusec; + this.client = client; + this.server = server; } + @Override + public String toString() { + return String.format("%d/%06d/----/%s", ctime, cusec, client); + } + + // Methods used when saved in a dfl file. See DflCache.java + /** - * Compares if an object equals to an AuthTime object. - * @param o an object. - * @return true if two objects are equivalent, otherwise, return false. + * Reads an LC style string from a channel, which is a int32 length + * plus a UTF-8 encoded string possibly ends with \0. + * @throws IOException if there is a format error + * @throws BufferUnderflowException if goes beyond the end */ - public boolean equals(Object o) { - if (o instanceof AuthTime) { - if ((((AuthTime)o).kerberosTime == kerberosTime) - && (((AuthTime)o).cusec == cusec)) { - return true; - } + private static String readStringWithLength(SeekableByteChannel chan) + throws IOException { + ByteBuffer bb = ByteBuffer.allocate(4); + bb.order(ByteOrder.nativeOrder()); + chan.read(bb); + bb.flip(); + int len = bb.getInt(); + if (len > 1024) { + // Memory attack? The string should be fairly short. + throw new IOException("Invalid string length"); } - return false; + bb = ByteBuffer.allocate(len); + if (chan.read(bb) != len) { + throw new IOException("Not enough string"); + } + byte[] data = bb.array(); + return (data[len-1] == 0)? + new String(data, 0, len-1, StandardCharsets.UTF_8): + new String(data, StandardCharsets.UTF_8); } /** - * Returns a hash code for this AuthTime object. - * - * @return a hash code value for this object. + * Reads an AuthTime or AuthTimeWithHash object from a channel. + * @throws IOException if there is a format error + * @throws BufferUnderflowException if goes beyond the end */ - public int hashCode() { - int result = 17; - - result = 37 * result + (int)(kerberosTime ^ (kerberosTime >>> 32)); - result = 37 * result + cusec; - - return result; + public static AuthTime readFrom(SeekableByteChannel chan) + throws IOException { + String client = readStringWithLength(chan); + String server = readStringWithLength(chan); + ByteBuffer bb = ByteBuffer.allocate(8); + chan.read(bb); + bb.order(ByteOrder.nativeOrder()); + int cusec = bb.getInt(0); + int ctime = bb.getInt(4); + if (client.isEmpty()) { + StringTokenizer st = new StringTokenizer(server, " :"); + if (st.countTokens() != 6) { + throw new IOException("Incorrect rcache style"); + } + st.nextToken(); + String hash = st.nextToken(); + st.nextToken(); + client = st.nextToken(); + st.nextToken(); + server = st.nextToken(); + return new AuthTimeWithHash( + client, server, ctime, cusec, hash); + } else { + return new AuthTime( + client, server, ctime, cusec); + } } + /** + * Encodes to be used in a dfl file + */ + protected byte[] encode0(String cstring, String sstring) { + byte[] c = cstring.getBytes(StandardCharsets.UTF_8);; + byte[] s = sstring.getBytes(StandardCharsets.UTF_8);; + byte[] zero = new byte[1]; + int len = 4 + c.length + 1 + 4 + s.length + 1 + 4 + 4; + ByteBuffer bb = ByteBuffer.allocate(len) + .order(ByteOrder.nativeOrder()); + bb.putInt(c.length+1).put(c).put(zero) + .putInt(s.length+1).put(s).put(zero) + .putInt(cusec).putInt(ctime); + return bb.array(); + } + + /** + * Encodes to be used in a dfl file + * @param withHash useless here + */ + public byte[] encode(boolean withHash) { + return encode0(client, server); + } } diff --git a/jdk/src/share/classes/sun/security/krb5/internal/rcache/AuthTimeWithHash.java b/jdk/src/share/classes/sun/security/krb5/internal/rcache/AuthTimeWithHash.java new file mode 100644 index 00000000000..52bc8a8260b --- /dev/null +++ b/jdk/src/share/classes/sun/security/krb5/internal/rcache/AuthTimeWithHash.java @@ -0,0 +1,124 @@ +/* + * Copyright (c) 2013, 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. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * 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. + */ + +package sun.security.krb5.internal.rcache; + +import java.util.Objects; + +/** + * The class represents a new style replay cache entry. It can be either used + * inside memory or in a dfl file. + */ +public class AuthTimeWithHash extends AuthTime + implements Comparable { + + final String hash; + + /** + * Constructs a new AuthTimeWithHash. + */ + public AuthTimeWithHash(String client, String server, + int ctime, int cusec, String hash) { + super(client, server, ctime, cusec); + this.hash = hash; + } + + /** + * Compares if an object equals to an AuthTimeWithHash object. + * @param o an object. + * @return true if two objects are equivalent, otherwise, return false. + */ + @Override + public boolean equals(Object o) { + if (this == o) return true; + if (!(o instanceof AuthTimeWithHash)) return false; + AuthTimeWithHash that = (AuthTimeWithHash)o; + return Objects.equals(hash, that.hash) + && Objects.equals(client, that.client) + && Objects.equals(server, that.server) + && ctime == that.ctime + && cusec == that.cusec; + } + + /** + * Returns a hash code for this AuthTimeWithHash object. + */ + @Override + public int hashCode() { + return Objects.hash(hash); + } + + @Override + public String toString() { + return String.format("%d/%06d/%s/%s", ctime, cusec, hash, client); + } + + @Override + public int compareTo(AuthTimeWithHash other) { + int cmp = 0; + if (ctime != other.ctime) { + cmp = Integer.compare(ctime, other.ctime); + } else if (cusec != other.cusec) { + cmp = Integer.compare(cusec, other.cusec); + } else { + cmp = hash.compareTo(other.hash); + } + return cmp; + } + + /** + * Compares with a possibly old style object. Used + * in DflCache$Storage#loadAndCheck. + * @return true if all AuthTime fields are the same + */ + public boolean isSameIgnoresHash(AuthTime old) { + return client.equals(old.client) && + server.equals(old.server) && + ctime == old.ctime && + cusec == old.cusec; + } + + // Methods used when saved in a dfl file. See DflCache.java + + /** + * Encodes to be used in a dfl file + * @param withHash write new style if true + */ + @Override + public byte[] encode(boolean withHash) { + String cstring; + String sstring; + if (withHash) { + cstring = ""; + sstring = String.format("HASH:%s %d:%s %d:%s", hash, + client.length(), client, + server.length(), server); + } else { + cstring = client; + sstring = server; + } + return encode0(cstring, sstring); + } +} diff --git a/jdk/src/share/classes/sun/security/krb5/internal/rcache/DflCache.java b/jdk/src/share/classes/sun/security/krb5/internal/rcache/DflCache.java new file mode 100644 index 00000000000..6c5d124f0cb --- /dev/null +++ b/jdk/src/share/classes/sun/security/krb5/internal/rcache/DflCache.java @@ -0,0 +1,365 @@ +/* + * Copyright (c) 2013, 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. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * 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. + */ + + +package sun.security.krb5.internal.rcache; + +import java.io.*; +import java.nio.BufferUnderflowException; +import java.nio.ByteBuffer; +import java.nio.ByteOrder; +import java.nio.channels.SeekableByteChannel; +import java.nio.file.Files; +import java.nio.file.Path; +import java.nio.file.StandardCopyOption; +import java.nio.file.StandardOpenOption; +import java.nio.file.attribute.PosixFilePermission; +import java.security.AccessController; +import java.util.*; + +import sun.security.action.GetPropertyAction; +import sun.security.krb5.internal.KerberosTime; +import sun.security.krb5.internal.Krb5; +import sun.security.krb5.internal.KrbApErrException; +import sun.security.krb5.internal.ReplayCache; + + +/** + * A dfl file is used to sustores AuthTime entries when the system property + * sun.security.krb5.rcache is set to + * + * dfl(|:path/|:path/name|:name) + * + * The file will be path/name. If path is not given, it will be + * + * System.getProperty("java.io.tmpdir") + * + * If name is not given, it will be + * + * service_euid + * + * Java does not have a method to get euid, so uid is used instead. This + * should normally to be since a Java program is seldom used as a setuid app. + * + * The file has a header: + * + * i16 0x0501 (KRB5_RC_VNO) in network order + * i32 number of seconds for lifespan (in native order, same below) + * + * followed by cache entries concatenated, which can be encoded in + * 2 styles: + * + * The traditional style is: + * + * LC of client principal + * LC of server principal + * i32 cusec of Authenticator + * i32 ctime of Authenticator + * + * The new style has a hash: + * + * LC of "" + * LC of "HASH:%s %lu:%s %lu:%s" of (hash, clientlen, client, serverlen, + * server) where msghash is 32 char (lower case) text mode md5sum + * of the ciphertext of authenticator. + * i32 cusec of Authenticator + * i32 ctime of Authenticator + * + * where LC of a string means + * + * i32 strlen(string) + 1 + * octets of string, with the \0x00 ending + * + * The old style block is always created by MIT krb5 used even if a new style + * is available, which means there can be 2 entries for a single Authenticator. + * Java also does this way. + * + * See src/lib/krb5/rcache/rc_io.c and src/lib/krb5/rcache/rc_dfl.c. + */ +public class DflCache extends ReplayCache { + + private static final int KRB5_RV_VNO = 0x501; + private static final int EXCESSREPS = 30; // if missed-hit>this, recreate + + private final String source; + + private static int uid; + static { + try { + // Available on Solaris, Linux and Mac. Otherwise, no _euid suffix + Class clazz = Class.forName("com.sun.security.auth.module.UnixSystem"); + uid = (int)(long)(Long) + clazz.getMethod("getUid").invoke(clazz.newInstance()); + } catch (Exception e) { + uid = -1; + } + } + + public DflCache (String source) { + this.source = source; + } + + private static String defaultPath() { + return AccessController.doPrivileged( + new GetPropertyAction("java.io.tmpdir")); + } + + private static String defaultFile(String server) { + // service/host@REALM -> service + int slash = server.indexOf('/'); + if (slash == -1) { + // A normal principal? say, dummy@REALM + slash = server.indexOf('@'); + } + if (slash != -1) { + // Should not happen, but be careful + server= server.substring(0, slash); + } + if (uid != -1) { + server += "_" + uid; + } + return server; + } + + private static Path getFileName(String source, String server) { + String path, file; + if (source.equals("dfl")) { + path = defaultPath(); + file = defaultFile(server); + } else if (source.startsWith("dfl:")) { + source = source.substring(4); + int pos = source.lastIndexOf('/'); + int pos1 = source.lastIndexOf('\\'); + if (pos1 > pos) pos = pos1; + if (pos == -1) { + // Only file name + path = defaultPath(); + file = source; + } else if (new File(source).isDirectory()) { + // Only path + path = source; + file = defaultFile(server); + } else { + // Full pathname + path = null; + file = source; + } + } else { + throw new IllegalArgumentException(); + } + return new File(path, file).toPath(); + } + + @Override + public void checkAndStore(KerberosTime currTime, AuthTimeWithHash time) + throws KrbApErrException { + try { + checkAndStore0(currTime, time); + } catch (IOException ioe) { + KrbApErrException ke = new KrbApErrException(Krb5.KRB_ERR_GENERIC); + ke.initCause(ioe); + throw ke; + } + } + + private synchronized void checkAndStore0(KerberosTime currTime, AuthTimeWithHash time) + throws IOException, KrbApErrException { + Path p = getFileName(source, time.server); + int missed = 0; + try (Storage s = new Storage()) { + try { + missed = s.loadAndCheck(p, time, currTime); + } catch (IOException ioe) { + // Non-existing or invalid file + Storage.create(p); + missed = s.loadAndCheck(p, time, currTime); + } + s.append(time); + } + if (missed > EXCESSREPS) { + Storage.expunge(p, currTime); + } + } + + + private static class Storage implements Closeable { + // Static methods + @SuppressWarnings("try") + private static void create(Path p) throws IOException { + try (SeekableByteChannel newChan = createNoClose(p)) { + // Do nothing, wait for close + } + makeMine(p); + } + + private static void makeMine(Path p) throws IOException { + // chmod to owner-rw only, otherwise MIT krb5 rejects + try { + Set attrs = new HashSet<>(); + attrs.add(PosixFilePermission.OWNER_READ); + attrs.add(PosixFilePermission.OWNER_WRITE); + Files.setPosixFilePermissions(p, attrs); + } catch (UnsupportedOperationException uoe) { + // No POSIX permission. That's OK. + } + } + + private static SeekableByteChannel createNoClose(Path p) + throws IOException { + SeekableByteChannel newChan = Files.newByteChannel( + p, StandardOpenOption.CREATE, + StandardOpenOption.TRUNCATE_EXISTING, + StandardOpenOption.WRITE); + ByteBuffer buffer = ByteBuffer.allocate(6); + buffer.putShort((short)KRB5_RV_VNO); + buffer.order(ByteOrder.nativeOrder()); + buffer.putInt(KerberosTime.getDefaultSkew()); + buffer.flip(); + newChan.write(buffer); + return newChan; + } + + private static void expunge(Path p, KerberosTime currTime) + throws IOException { + Path p2 = Files.createTempFile(p.getParent(), "rcache", null); + try (SeekableByteChannel oldChan = Files.newByteChannel(p); + SeekableByteChannel newChan = createNoClose(p2)) { + long timeLimit = currTime.getSeconds() - readHeader(oldChan); + while (true) { + try { + AuthTime at = AuthTime.readFrom(oldChan); + if (at.ctime > timeLimit) { + ByteBuffer bb = ByteBuffer.wrap(at.encode(true)); + newChan.write(bb); + } + } catch (BufferUnderflowException e) { + break; + } + } + } + makeMine(p2); + Files.move(p2, p, + StandardCopyOption.REPLACE_EXISTING, + StandardCopyOption.ATOMIC_MOVE); + } + + // Instance methods + SeekableByteChannel chan; + private int loadAndCheck(Path p, AuthTimeWithHash time, + KerberosTime currTime) + throws IOException, KrbApErrException { + int missed = 0; + if (Files.isSymbolicLink(p)) { + throw new IOException("Symlink not accepted"); + } + try { + Set perms = + Files.getPosixFilePermissions(p); + if (uid != -1 && + (Integer)Files.getAttribute(p, "unix:uid") != uid) { + throw new IOException("Not mine"); + } + if (perms.contains(PosixFilePermission.GROUP_READ) || + perms.contains(PosixFilePermission.GROUP_WRITE) || + perms.contains(PosixFilePermission.GROUP_EXECUTE) || + perms.contains(PosixFilePermission.OTHERS_READ) || + perms.contains(PosixFilePermission.OTHERS_WRITE) || + perms.contains(PosixFilePermission.OTHERS_EXECUTE)) { + throw new IOException("Accessible by someone else"); + } + } catch (UnsupportedOperationException uoe) { + // No POSIX permissions? Ignore it. + } + chan = Files.newByteChannel(p, StandardOpenOption.WRITE, + StandardOpenOption.READ); + + long timeLimit = currTime.getSeconds() - readHeader(chan); + + long pos = 0; + boolean seeNewButNotSame = false; + while (true) { + try { + pos = chan.position(); + AuthTime a = AuthTime.readFrom(chan); + if (a instanceof AuthTimeWithHash) { + if (time.equals(a)) { + // Exact match, must be a replay + throw new KrbApErrException(Krb5.KRB_AP_ERR_REPEAT); + } else if (time.isSameIgnoresHash(a)) { + // Two different authenticators in the same second. + // Remember it + seeNewButNotSame = true; + } + } else { + if (time.isSameIgnoresHash(a)) { + // Two authenticators in the same second. Considered + // same if we haven't seen a new style version of it + if (!seeNewButNotSame) { + throw new KrbApErrException(Krb5.KRB_AP_ERR_REPEAT); + } + } + } + if (a.ctime < timeLimit) { + missed++; + } else { + missed--; + } + } catch (BufferUnderflowException e) { + // Half-written file? + chan.position(pos); + break; + } + } + return missed; + } + + private static int readHeader(SeekableByteChannel chan) + throws IOException { + ByteBuffer bb = ByteBuffer.allocate(6); + chan.read(bb); + if (bb.getShort(0) != KRB5_RV_VNO) { + throw new IOException("Not correct rcache version"); + } + bb.order(ByteOrder.nativeOrder()); + return bb.getInt(2); + } + + private void append(AuthTimeWithHash at) throws IOException { + // Write an entry with hash, to be followed by one without it, + // for the benefit of old implementations. + ByteBuffer bb; + bb = ByteBuffer.wrap(at.encode(true)); + chan.write(bb); + bb = ByteBuffer.wrap(at.encode(false)); + chan.write(bb); + } + + @Override + public void close() throws IOException { + if (chan != null) chan.close(); + chan = null; + } + } +} diff --git a/jdk/src/share/classes/sun/security/krb5/internal/rcache/CacheTable.java b/jdk/src/share/classes/sun/security/krb5/internal/rcache/MemoryCache.java similarity index 51% rename from jdk/src/share/classes/sun/security/krb5/internal/rcache/CacheTable.java rename to jdk/src/share/classes/sun/security/krb5/internal/rcache/MemoryCache.java index ac1879adba7..403d97f8319 100644 --- a/jdk/src/share/classes/sun/security/krb5/internal/rcache/CacheTable.java +++ b/jdk/src/share/classes/sun/security/krb5/internal/rcache/MemoryCache.java @@ -1,4 +1,5 @@ /* + * Copyright (c) 2013, 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 @@ -30,62 +31,55 @@ package sun.security.krb5.internal.rcache; -import java.util.Hashtable; +import java.util.*; +import sun.security.krb5.internal.KerberosTime; +import sun.security.krb5.internal.KrbApErrException; +import sun.security.krb5.internal.ReplayCache; /** - * This class implements Hashtable to store the replay caches. + * This class stores replay caches. AuthTimeWithHash objects are categorized + * into AuthLists keyed by the names of client and server. * * @author Yanni Zhang */ -public class CacheTable extends Hashtable { +public class MemoryCache extends ReplayCache { - private static final long serialVersionUID = -4695501354546664910L; + // TODO: One day we'll need to read dynamic krb5.conf. + private static final int lifespan = KerberosTime.getDefaultSkew(); + private static final boolean DEBUG = sun.security.krb5.internal.Krb5.DEBUG; - private boolean DEBUG = sun.security.krb5.internal.Krb5.DEBUG; - public CacheTable () { - } + private final Map content = new HashMap<>(); - /** - * Puts the client timestamp in replay cache. - * @params principal the client's principal name. - * @params time authenticator timestamp. - */ - public synchronized void put(String principal, AuthTime time, long currTime) { - ReplayCache rc = super.get(principal); + @Override + public synchronized void checkAndStore(KerberosTime currTime, AuthTimeWithHash time) + throws KrbApErrException { + String key = time.client + "|" + time.server; + AuthList rc = content.get(key); + if (DEBUG) { + System.out.println("MemoryCache: add " + time + " to " + key); + } if (rc == null) { - if (DEBUG) { - System.out.println("replay cache for " + principal + " is null."); - } - rc = new ReplayCache(principal, this); + rc = new AuthList(lifespan); rc.put(time, currTime); if (!rc.isEmpty()) { - super.put(principal, rc); + content.put(key, rc); + } + } else { + if (DEBUG) { + System.out.println("MemoryCache: Existing AuthList:\n" + rc); } - } - else { rc.put(time, currTime); if (rc.isEmpty()) { - super.remove(rc); - } - if (DEBUG) { - System.out.println("replay cache found."); + content.remove(key); } } - } - /** - * This method tests if replay cache keeps a record of the authenticator's time stamp. - * If there is a record (replay attack detected), the server should reject the client request. - * @params principal the client's principal name. - * @params time authenticator timestamp. - * @return null if no record found, else return an AuthTime object. - */ - public Object get(AuthTime time, String principal) { - ReplayCache rc = super.get(principal); - if ((rc != null) && (rc.contains(time))) { - return time; + public String toString() { + StringBuilder sb = new StringBuilder(); + for (AuthList rc: content.values()) { + sb.append(rc.toString()); } - return null; + return sb.toString(); } } diff --git a/jdk/src/share/classes/sun/security/krb5/internal/rcache/ReplayCache.java b/jdk/src/share/classes/sun/security/krb5/internal/rcache/ReplayCache.java deleted file mode 100644 index 6993c186230..00000000000 --- a/jdk/src/share/classes/sun/security/krb5/internal/rcache/ReplayCache.java +++ /dev/null @@ -1,143 +0,0 @@ -/* - * Copyright (c) 2000, 2012, 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. Oracle designates this - * particular file as subject to the "Classpath" exception as provided - * by Oracle in the LICENSE file that accompanied this code. - * - * 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. - */ - -/* - * - * (C) Copyright IBM Corp. 1999 All Rights Reserved. - * Copyright 1997 The Open Group Research Institute. All rights reserved. - */ - -package sun.security.krb5.internal.rcache; - -import sun.security.krb5.internal.Krb5; -import java.util.LinkedList; -import java.util.ListIterator; -import sun.security.krb5.internal.KerberosTime; - -/** - * This class provides an efficient caching mechanism to store the timestamp of client authenticators. - * The cache minimizes the memory usage by doing self-cleanup of expired items in the cache. - * - * @author Yanni Zhang - */ -public class ReplayCache extends LinkedList { - - private static final long serialVersionUID = 2997933194993803994L; - - // These 3 fields are now useless, keep for serialization compatibility - private String principal; - private CacheTable table; - private int nap = 10 * 60 * 1000; //10 minutes break - - private boolean DEBUG = Krb5.DEBUG; - - /** - * Constructs a ReplayCache for a client principal in specified CacheTable. - * @param p client principal name. - * @param ct CacheTable. - */ - public ReplayCache (String p, CacheTable ct) { - principal = p; - table = ct; - } - - /** - * Puts the authenticator timestamp into the cache in descending order. - * @param t AuthTime - */ - public synchronized void put(AuthTime t, long currentTime) { - - if (this.size() == 0) { - addFirst(t); - } - else { - AuthTime temp = getFirst(); - if (temp.kerberosTime < t.kerberosTime) { - // in most cases, newly received authenticator has - // larger timestamp. - addFirst(t); - } - else if (temp.kerberosTime == t.kerberosTime) { - if (temp.cusec < t.cusec) { - addFirst(t); - } - } - else { - //unless client clock being re-adjusted. - ListIterator it = listIterator(1); - while (it.hasNext()) { - temp = it.next(); - if (temp.kerberosTime < t.kerberosTime) { - add(indexOf(temp), t); - break; - //we always put the bigger timestamp at the front. - } - else if (temp.kerberosTime == t.kerberosTime) { - if (temp.cusec < t.cusec) { - add(indexOf(temp), t); - break; - } - } - } - } - } - - // let us cleanup while we are here - long timeLimit = currentTime - KerberosTime.getDefaultSkew() * 1000L; - ListIterator it = listIterator(0); - AuthTime temp = null; - int index = -1; - while (it.hasNext()) { - //search expired timestamps. - temp = it.next(); - if (temp.kerberosTime < timeLimit) { - index = indexOf(temp); - break; - } - } - if (index > -1) { - do { - //remove expired timestamps from the list. - removeLast(); - } while(size() > index); - } - if (DEBUG) { - printList(); - } - } - - - /** - * Prints out the debug message. - */ - private void printList() { - Object[] total = toArray(); - for (int i = 0; i < total.length; i++) { - System.out.println("object " + i + ": " + ((AuthTime)total[i]).kerberosTime + "/" - + ((AuthTime)total[i]).cusec); - } - } - -} diff --git a/jdk/test/java/security/testlibrary/Proc.java b/jdk/test/java/security/testlibrary/Proc.java new file mode 100644 index 00000000000..1ab58bf5212 --- /dev/null +++ b/jdk/test/java/security/testlibrary/Proc.java @@ -0,0 +1,325 @@ +/* + * Copyright (c) 2013, 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. + */ + +import java.io.BufferedReader; +import java.io.File; +import java.io.IOException; +import java.io.InputStreamReader; +import java.net.URL; +import java.net.URLClassLoader; +import java.nio.file.Files; +import java.nio.file.Path; +import java.nio.file.Paths; +import java.security.Permission; +import java.util.ArrayList; +import java.util.Base64; +import java.util.HashMap; +import java.util.List; +import java.util.Map; +import java.util.Map.Entry; + +/** + * This is a test library that makes writing a Java test that spawns multiple + * Java processes easily. + * + * Usage: + * + * Proc.create("Clazz") // The class to launch + * .args("x") // with args + * .env("env", "value") // and an environment variable + * .prop("key","value") // and a system property + * .perm(perm) // with granted permissions + * .start(); // and start + * + * create/start must be called, args/env/prop/perm can be called zero or + * multiple times between create and start. + * + * The controller can call inheritIO to share its I/O to the process. + * Otherwise, it can send data into a proc's stdin with write/println, and + * read its stdout with readLine. stderr is always redirected to DFILE + * unless nodump() is called. A protocol is designed to make + * data exchange among the controller and the processes super easy, in which + * useful data are always printed with a special prefix ("PROCISFUN:"). + * If the data is binary, make it BASE64. + * + * For example: + * + * - A producer Proc calls Proc.binOut() or Proc.textOut() to send out data. + * This method would prints to the stdout something like + * + * PROCISFUN:[raw text or base64 binary] + * + * - The controller calls producer.readData() to get the content. This method + * ignores all other output and only reads lines starting with "PROCISFUN:". + * + * - The controller does not care if the context is text or base64, it simply + * feeds the data to a consumer Proc by calling consumer.println(data). + * This will be printed into System.in of the consumer process. + * + * - The consumer Proc calls Proc.binIn() or Proc.textIn() to read the data. + * The first method de-base64 the input and return a byte[] block. + * + * Please note only plain ASCII is supported in raw text at the moment. + * + * As the Proc objects are hidden so deeply, two static methods, d(String) and + * d(Throwable) are provided to output info into stderr, where they will + * normally be appended messages to DFILE (unless nodump() is called). + * Developers can view the messages in real time by calling + * + * tail -f proc.debug + * + * TODO: + * + * . launch java tools, say, keytool + * . launch another version of java + * . start in another directory + * . start and finish using one method + * + * This is not a test, but is the core of + * JDK-8009977: A test library to launch multiple Java processes + */ +public class Proc { + private Process p; + private BufferedReader br; // the stdout of a process + private String launcher; // Optional: the java program + + private List perms = new ArrayList<>(); + private List args = new ArrayList<>(); + private Map env = new HashMap<>(); + private Map prop = new HashMap(); + private boolean inheritIO = false; + private boolean noDump = false; + + private String clazz; // Class to launch + private String debug; // debug flag, controller will show data + // transfer between procs + + final private static String PREFIX = "PROCISFUN:"; + final private static String DFILE = "proc.debug"; + + // The following methods are called by controllers + + // Creates a Proc by the Java class name, launcher is an optional + // argument to specify the java program + public static Proc create(String clazz, String... launcher) { + Proc pc = new Proc(); + pc.clazz = clazz; + if (launcher.length > 0) { + pc.launcher = launcher[0]; + } + return pc; + } + // Sets inheritIO flag to proc. If set, proc will same I/O channels as + // teh controller. Otherwise, its stdin/stdout is untouched, and its + // stderr is redirected to DFILE. + public Proc inheritIO() { + inheritIO = true; + return this; + } + // When called, stderr inherits parent stderr, otherwise, append to a file + public Proc nodump() { + noDump = true; + return this; + } + // Specifies some args. Can be called multiple times. + public Proc args(String... args) { + for (String c: args) { + this.args.add(c); + } + return this; + } + // Returns debug prefix + public String debug() { + return debug; + } + // Enables debug with prefix + public Proc debug(String title) { + debug = title; + return this; + } + // Specifies an env var. Can be called multiple times. + public Proc env(String a, String b) { + env.put(a, b); + return this; + } + // Specifies a Java system property. Can be called multiple times. + public Proc prop(String a, String b) { + prop.put(a, b); + return this; + } + // Adds a perm to policy. Can be called multiple times. In order to make it + // effective, please also call prop("java.security.manager", ""). + public Proc perm(Permission p) { + perms.add(p); + return this; + } + // Starts the proc + public Proc start() throws IOException { + List cmd = new ArrayList<>(); + if (launcher != null) { + cmd.add(launcher); + } else { + cmd.add(new File(new File(System.getProperty("java.home"), "bin"), + "java").getPath()); + } + cmd.add("-cp"); + StringBuilder cp = new StringBuilder(); + for (URL url: ((URLClassLoader)Proc.class.getClassLoader()).getURLs()) { + if (cp.length() != 0) { + cp.append(File.pathSeparatorChar); + } + cp.append(url.getFile()); + } + cmd.add(cp.toString()); + for (Entry e: prop.entrySet()) { + cmd.add("-D" + e.getKey() + "=" + e.getValue()); + } + if (!perms.isEmpty()) { + Path p = Files.createTempFile( + Paths.get(".").toAbsolutePath(), "policy", null); + StringBuilder sb = new StringBuilder(); + sb.append("grant {\n"); + for (Permission perm: perms) { + // Sometimes a permission has no name or actions. + // but it's safe to use an empty string. + String s = String.format("%s \"%s\", \"%s\"", + perm.getClass().getCanonicalName(), + perm.getName() + .replace("\\", "\\\\").replace("\"", "\\\""), + perm.getActions()); + sb.append(" permission ").append(s).append(";\n"); + } + sb.append("};\n"); + Files.write(p, sb.toString().getBytes()); + cmd.add("-Djava.security.policy=" + p.toString()); + } + cmd.add(clazz); + for (String s: args) { + cmd.add(s); + } + if (debug != null) { + System.out.println("PROC: " + debug + " cmdline: " + cmd); + } + ProcessBuilder pb = new ProcessBuilder(cmd); + for (Entry e: env.entrySet()) { + pb.environment().put(e.getKey(), e.getValue()); + } + if (inheritIO) { + pb.inheritIO(); + } else if (noDump) { + pb.redirectError(ProcessBuilder.Redirect.INHERIT); + } else { + pb.redirectError(ProcessBuilder.Redirect.appendTo(new File(DFILE))); + } + p = pb.start(); + br = new BufferedReader(new InputStreamReader(p.getInputStream())); + return this; + } + // Reads a line from stdout of proc + public String readLine() throws IOException { + String s = br.readLine(); + if (debug != null) { + System.out.println("PROC: " + debug + " readline: " + + (s == null ? "" : s)); + } + return s; + } + // Reads a special line from stdout of proc + public String readData() throws Exception { + while (true) { + String s = readLine(); + if (s == null) { + if (p.waitFor() != 0) { + throw new Exception("Proc abnormal end"); + } else { + return s; + } + } + if (s.startsWith(PREFIX)) { + return s.substring(PREFIX.length()); + } + } + } + // Writes text into stdin of proc + public void println(String s) throws IOException { + if (debug != null) { + System.out.println("PROC: " + debug + " println: " + s); + } + write((s + "\n").getBytes()); + } + // Writes data into stdin of proc + public void write(byte[] b) throws IOException { + p.getOutputStream().write(b); + p.getOutputStream().flush(); + } + // Reads all output and wait for process end + public int waitFor() throws Exception { + while (true) { + String s = readLine(); + if (s == null) { + break; + } + } + return p.waitFor(); + } + + // The following methods are used inside a proc + + // Writes out a BASE64 binary with a prefix + public static void binOut(byte[] data) { + System.out.println(PREFIX + Base64.getEncoder().encodeToString(data)); + } + // Reads in a line of BASE64 binary + public static byte[] binIn() throws Exception { + return Base64.getDecoder().decode(textIn()); + } + // Writes out a text with a prefix + public static void textOut(String data) { + System.out.println(PREFIX + data); + } + // Reads in a line of text + public static String textIn() throws Exception { + StringBuilder sb = new StringBuilder(); + boolean isEmpty = true; + while (true) { + int i = System.in.read(); + if (i == -1) break; + isEmpty = false; + if (i == '\n') break; + if (i != 13) { + // Force it to a char, so only simple ASCII works. + sb.append((char)i); + } + } + return isEmpty ? null : sb.toString(); + } + // Sends string to stderr. If inheritIO is not called, they will + // be collected into DFILE + public static void d(String s) throws IOException { + System.err.println(s); + } + // Sends an exception to stderr + public static void d(Throwable e) throws IOException { + e.printStackTrace(); + } +} diff --git a/jdk/test/sun/security/krb5/auto/AcceptorSubKey.java b/jdk/test/sun/security/krb5/auto/AcceptorSubKey.java index 9aba5e48582..26b1fbda724 100644 --- a/jdk/test/sun/security/krb5/auto/AcceptorSubKey.java +++ b/jdk/test/sun/security/krb5/auto/AcceptorSubKey.java @@ -26,10 +26,10 @@ * @bug 7077646 * @summary gssapi wrap for CFX per-message tokens always set FLAG_ACCEPTOR_SUBKEY * @compile -XDignore.symbol.file AcceptorSubKey.java - * @run main/othervm AcceptorSubKey + * @run main/othervm AcceptorSubKey 0 + * @run main/othervm AcceptorSubKey 4 */ -import java.util.Arrays; import sun.security.jgss.GSSUtil; // The basic krb5 test skeleton you can copy from @@ -37,8 +37,14 @@ public class AcceptorSubKey { public static void main(String[] args) throws Exception { + int expected = Integer.parseInt(args[0]); + new OneKDC(null).writeJAASConf(); + if (expected != 0) { + System.setProperty("sun.security.krb5.acceptor.subkey", "true"); + } + Context c, s; c = Context.fromJAAS("client"); s = Context.fromJAAS("server"); @@ -53,8 +59,8 @@ public class AcceptorSubKey { // FLAG_ACCEPTOR_SUBKEY is 4 int flagOn = wrapped[2] & 4; - if (flagOn != 0) { - throw new Exception("Java GSS should not have set acceptor subkey"); + if (flagOn != expected) { + throw new Exception("not expected"); } s.dispose(); diff --git a/jdk/test/sun/security/krb5/auto/BasicProc.java b/jdk/test/sun/security/krb5/auto/BasicProc.java new file mode 100644 index 00000000000..54b204fb420 --- /dev/null +++ b/jdk/test/sun/security/krb5/auto/BasicProc.java @@ -0,0 +1,192 @@ +/* + * Copyright (c) 2013, 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 + * @bug 8009977 + * @summary A test library to launch multiple Java processes + * @library ../../../../java/security/testlibrary/ + * @compile -XDignore.symbol.file BasicProc.java + * @run main/othervm BasicProc + */ + +import java.io.File; +import org.ietf.jgss.Oid; + +import javax.security.auth.PrivateCredentialPermission; + +public class BasicProc { + + static String CONF = "krb5.conf"; + static String KTAB = "ktab"; + public static void main(String[] args) throws Exception { + String HOST = "localhost"; + String SERVER = "server/" + HOST; + String BACKEND = "backend/" + HOST; + String USER = "user"; + char[] PASS = "password".toCharArray(); + String REALM = "REALM"; + + Oid oid = new Oid("1.2.840.113554.1.2.2"); + + if (args.length == 0) { + System.setProperty("java.security.krb5.conf", CONF); + KDC kdc = KDC.create(REALM, HOST, 0, true); + kdc.addPrincipal(USER, PASS); + kdc.addPrincipalRandKey("krbtgt/" + REALM); + kdc.addPrincipalRandKey(SERVER); + kdc.addPrincipalRandKey(BACKEND); + + String cwd = System.getProperty("user.dir"); + kdc.writeKtab(KTAB); + KDC.saveConfig(CONF, kdc, "forwardable = true"); + + Proc pc = Proc.create("BasicProc") + .args("client") + .prop("java.security.krb5.conf", CONF) + .prop("java.security.manager", "") + .perm(new java.util.PropertyPermission( + "sun.security.krb5.principal", "read")) + .perm(new javax.security.auth.AuthPermission( + "modifyPrincipals")) + .perm(new javax.security.auth.AuthPermission( + "modifyPrivateCredentials")) + .perm(new javax.security.auth.AuthPermission("doAs")) + .perm(new javax.security.auth.kerberos.ServicePermission( + "krbtgt/" + REALM + "@" + REALM, "initiate")) + .perm(new javax.security.auth.kerberos.ServicePermission( + "server/localhost@" + REALM, "initiate")) + .perm(new javax.security.auth.kerberos.DelegationPermission( + "\"server/localhost@" + REALM + "\" " + + "\"krbtgt/" + REALM + "@" + REALM + "\"")) + .debug("C") + .start(); + Proc ps = Proc.create("BasicProc") + .args("server") + .prop("java.security.krb5.conf", CONF) + .prop("java.security.manager", "") + .perm(new java.util.PropertyPermission( + "sun.security.krb5.principal", "read")) + .perm(new javax.security.auth.AuthPermission( + "modifyPrincipals")) + .perm(new javax.security.auth.AuthPermission( + "modifyPrivateCredentials")) + .perm(new javax.security.auth.AuthPermission("doAs")) + .perm(new PrivateCredentialPermission( + "javax.security.auth.kerberos.KeyTab * \"*\"", + "read")) + .perm(new javax.security.auth.kerberos.ServicePermission( + "server/localhost@" + REALM, "accept")) + .perm(new java.io.FilePermission( + cwd + File.separator + KTAB, "read")) + .perm(new javax.security.auth.kerberos.ServicePermission( + "backend/localhost@" + REALM, "initiate")) + .debug("S") + .start(); + Proc pb = Proc.create("BasicProc") + .args("backend") + .prop("java.security.krb5.conf", CONF) + .prop("java.security.manager", "") + .perm(new java.util.PropertyPermission( + "sun.security.krb5.principal", "read")) + .perm(new javax.security.auth.AuthPermission( + "modifyPrincipals")) + .perm(new javax.security.auth.AuthPermission( + "modifyPrivateCredentials")) + .perm(new javax.security.auth.AuthPermission("doAs")) + .perm(new PrivateCredentialPermission( + "javax.security.auth.kerberos.KeyTab * \"*\"", + "read")) + .perm(new javax.security.auth.kerberos.ServicePermission( + "backend/localhost@" + REALM, "accept")) + .perm(new java.io.FilePermission( + cwd + File.separator + KTAB, "read")) + .debug("B") + .start(); + + // Client and server handshake + String token = pc.readData(); + ps.println(token); + token = ps.readData(); + pc.println(token); + // Server and backend handshake + token = ps.readData(); + pb.println(token); + token = pb.readData(); + ps.println(token); + // wrap/unwrap/getMic/verifyMic and plain text + token = ps.readData(); + pb.println(token); + token = pb.readData(); + ps.println(token); + token = pb.readData(); + ps.println(token); + + if ((pc.waitFor() | ps.waitFor() | pb.waitFor()) != 0) { + throw new Exception(); + } + } else if (args[0].equals("client")) { + Context c = Context.fromUserPass(USER, PASS, false); + c.startAsClient(SERVER, oid); + c.x().requestCredDeleg(true); + Proc.binOut(c.take(new byte[0])); + byte[] token = Proc.binIn(); + c.take(token); + } else if (args[0].equals("server")) { + Context s = Context.fromUserKtab(SERVER, KTAB, true); + s.startAsServer(oid); + byte[] token = Proc.binIn(); + token = s.take(token); + Proc.binOut(token); + Context s2 = s.delegated(); + s2.startAsClient(BACKEND, oid); + Proc.binOut(s2.take(new byte[0])); + token = Proc.binIn(); + s2.take(token); + byte[] msg = "Hello".getBytes(); + Proc.binOut(s2.wrap(msg, true)); + s2.verifyMic(Proc.binIn(), msg); + String in = Proc.textIn(); + if (!in.equals("Hello")) { + throw new Exception(); + } + } else if (args[0].equals("backend")) { + Context b = Context.fromUserKtab(BACKEND, KTAB, true); + b.startAsServer(oid); + byte[] token = Proc.binIn(); + Proc.binOut(b.take(token)); + byte[] msg = b.unwrap(Proc.binIn(), true); + Proc.binOut(b.getMic(msg)); + Proc.textOut(new String(msg)); + } + } + // create a native server + private static Proc ns(Proc p) throws Exception { + return p + .env("KRB5_CONFIG", CONF) + .env("KRB5_KTNAME", KTAB) + .prop("sun.security.jgss.native", "true") + .prop("javax.security.auth.useSubjectCredsOnly", "false") + .prop("sun.security.nativegss.debug", "true"); + } +} diff --git a/jdk/test/sun/security/krb5/auto/Context.java b/jdk/test/sun/security/krb5/auto/Context.java index 738f2c3d4e3..cb3d6e98def 100644 --- a/jdk/test/sun/security/krb5/auto/Context.java +++ b/jdk/test/sun/security/krb5/auto/Context.java @@ -195,6 +195,7 @@ public class Context { Krb5LoginModule krb5 = new Krb5LoginModule(); Map map = new HashMap<>(); + map.put("isInitiator", "false"); map.put("doNotPrompt", "true"); map.put("useTicketCache", "false"); map.put("useKeyTab", "true"); @@ -616,9 +617,10 @@ public class Context { */ static public void handshake(final Context c, final Context s) throws Exception { byte[] t = new byte[0]; - while (!c.x.isEstablished() || !s.x.isEstablished()) { - t = c.take(t); - t = s.take(t); + while (true) { + if (t != null || !c.x.isEstablished()) t = c.take(t); + if (t != null || !s.x.isEstablished()) t = s.take(t); + if (c.x.isEstablished() && s.x.isEstablished()) break; } } } diff --git a/jdk/test/sun/security/krb5/auto/KDC.java b/jdk/test/sun/security/krb5/auto/KDC.java index 44330dfc723..0157a930909 100644 --- a/jdk/test/sun/security/krb5/auto/KDC.java +++ b/jdk/test/sun/security/krb5/auto/KDC.java @@ -1137,7 +1137,7 @@ public class KDC { * @return REALM.NAME = { kdc = host:port } */ private static String realmLineForKDC(KDC kdc) { - return String.format(" %s = {\n kdc = %s:%d\n }\n", + return String.format("%s = {\n kdc = %s:%d\n}\n", kdc.realm, kdc.kdc, kdc.port); diff --git a/jdk/test/sun/security/krb5/auto/NoneReplayCacheTest.java b/jdk/test/sun/security/krb5/auto/NoneReplayCacheTest.java new file mode 100644 index 00000000000..b92ad20395a --- /dev/null +++ b/jdk/test/sun/security/krb5/auto/NoneReplayCacheTest.java @@ -0,0 +1,70 @@ +/* + * Copyright 2013 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, + * CA 95054 USA or visit www.sun.com if you need additional information or + * have any questions. + */ + +/* + * @test + * @bug 8001326 + * @run main/othervm NoneReplayCacheTest + * @summary the replaycache type none cannot stop an authenticator replay, + * but it can stop a message replay when s.s.k.acceptor.subkey is true. + * You should not really use none in production environment. This test merely + * shows there can be other protections when replay cache is not working fine. + */ + +import org.ietf.jgss.GSSException; +import sun.security.jgss.GSSUtil; + +public class NoneReplayCacheTest { + + public static void main(String[] args) + throws Exception { + + new OneKDC(null); + + System.setProperty("sun.security.krb5.rcache", "none"); + System.setProperty("sun.security.krb5.acceptor.subkey", "true"); + + Context c, s; + c = Context.fromUserPass(OneKDC.USER, OneKDC.PASS, false); + s = Context.fromUserKtab(OneKDC.SERVER, OneKDC.KTAB, true); + + c.startAsClient(OneKDC.SERVER, GSSUtil.GSS_KRB5_MECH_OID); + s.startAsServer(GSSUtil.GSS_KRB5_MECH_OID); + + byte[] first = c.take(new byte[0]); + + c.take(s.take(first)); + + byte[] msg = c.wrap("hello".getBytes(), true); + s.unwrap(msg, true); + + s.startAsServer(GSSUtil.GSS_KRB5_MECH_OID); + s.take(first); // apreq replay not detectable + try { + s.unwrap(msg, true); // msg replay detectable + throw new Exception("This method should fail"); + } catch (GSSException gsse) { + gsse.printStackTrace(); + } + } +} diff --git a/jdk/test/sun/security/krb5/auto/ReplayCacheExpunge.java b/jdk/test/sun/security/krb5/auto/ReplayCacheExpunge.java new file mode 100644 index 00000000000..8c00d809517 --- /dev/null +++ b/jdk/test/sun/security/krb5/auto/ReplayCacheExpunge.java @@ -0,0 +1,79 @@ +/* + * Copyright (c) 2013, 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 + * @bug 8001326 + * @run main/othervm ReplayCacheExpunge 16 + * @run main/othervm/fail ReplayCacheExpunge 15 + * @summary when number of expired entries minus number of good entries + * is more than 30, expunge occurs, and expired entries are forgotten. +*/ + +import java.util.Random; +import sun.security.krb5.internal.KerberosTime; +import sun.security.krb5.internal.ReplayCache; +import sun.security.krb5.internal.rcache.AuthTimeWithHash; + +public class ReplayCacheExpunge { + static final String client = "dummy@REALM"; + static final String server = "server/localhost@REALM"; + static final Random rand = new Random(); + + public static void main(String[] args) throws Exception { + int count = Integer.parseInt(args[0]); + ReplayCache cache = ReplayCache.getInstance("dfl:./"); + AuthTimeWithHash a1 = + new AuthTimeWithHash(client, server, time(-400), 0, hash("1")); + AuthTimeWithHash a2 = + new AuthTimeWithHash(client, server, time(0), 0, hash("4")); + KerberosTime now = new KerberosTime(time(0)*1000L); + KerberosTime then = new KerberosTime(time(-300)*1000L); + + // Once upon a time, we added a lot of events + for (int i=0; i reqs = new ArrayList<>(); + private static String HOST = "localhost"; + + // Where should the rcache be saved. It seems KRB5RCACHEDIR is not + // recognized on Solaris. Maybe version too low? I see 1.6. + private static String cwd = + System.getProperty("os.name").startsWith("SunOS") ? + "/var/krb5/rcache/" : + System.getProperty("user.dir"); + + + private static int uid; + + public static void main0(String[] args) throws Exception { + System.setProperty("java.security.krb5.conf", OneKDC.KRB5_CONF); + if (args.length == 0) { // The controller + int ns = 5; // number of servers + int nu = 5; // number of users + int nx = 50; // number of experiments + int np = 5; // number of peers (services) + int mode = 0; // native(1), random(0), java(-1) + boolean random = true; // random experiments choreograph + + try { + Class clazz = Class.forName( + "com.sun.security.auth.module.UnixSystem"); + uid = (int)(long)(Long) + clazz.getMethod("getUid").invoke(clazz.newInstance()); + } catch (Exception e) { + uid = -1; + } + + KDC kdc = KDC.create(OneKDC.REALM, HOST, 0, true); + for (int i=0; i>4]; + h[2*i+1] = hexConst[hash[i]&0xf]; + } + return new String(h); + } + // return size of dfl file, excluding the null hash ones + private static int csize(int p) throws Exception { + try (SeekableByteChannel chan = Files.newByteChannel( + Paths.get(dfl(p)), StandardOpenOption.READ)) { + chan.position(6); + int cc = 0; + while (true) { + try { + if (AuthTime.readFrom(chan) != null) cc++; + } catch (BufferUnderflowException e) { + break; + } + } + return cc; + } catch (IOException ioe) { + return 0; + } + } + // models an experiement + private static class Ex { + int i; // # + boolean expected; // expected result + boolean actual; // actual output + int old; // which ap-req to send + String server; // which server to send to + String hash; // the hash of req + int user; // which initiator + int peer; // which acceptor + int csize; // size of rcache after test + } + // models a saved ap-req msg + private static class Req { + String msg; // based64-ed req + int user; // which initiator + int peer; // which accceptor + Req(int user, int peer, String msg) { + this.msg = msg; + this.user= user; + this.peer = peer; + } + } +} diff --git a/jdk/test/sun/security/krb5/ccache/EmptyCC.java b/jdk/test/sun/security/krb5/ccache/EmptyCC.java index a0cd759373d..f70df4f010a 100644 --- a/jdk/test/sun/security/krb5/ccache/EmptyCC.java +++ b/jdk/test/sun/security/krb5/ccache/EmptyCC.java @@ -26,15 +26,12 @@ * @bug 7158329 * @bug 8001208 * @summary NPE in sun.security.krb5.Credentials.acquireDefaultCreds() + * @library ../../../../java/security/testlibrary/ * @compile -XDignore.symbol.file EmptyCC.java * @run main EmptyCC tmpcc * @run main EmptyCC FILE:tmpcc */ import java.io.File; -import java.io.InputStream; -import java.util.ArrayList; -import java.util.Arrays; -import java.util.List; import sun.security.krb5.Credentials; import sun.security.krb5.PrincipalName; import sun.security.krb5.internal.ccache.CredentialsCache; @@ -48,32 +45,9 @@ public class EmptyCC { // Main process, write the ccache and launch sub process CredentialsCache cache = CredentialsCache.create(pn, ccache); cache.save(); - - // java -cp $test.classes EmptyCC readcc - ProcessBuilder pb = new ProcessBuilder( - new File(new File(System.getProperty("java.home"), "bin"), - "java").getPath(), - "-cp", - System.getProperty("test.classes"), - "EmptyCC", - ccache, - "readcc" - ); - - pb.environment().put("KRB5CCNAME", ccache); - pb.redirectErrorStream(true); - - Process p = pb.start(); - try (InputStream ins = p.getInputStream()) { - byte[] buf = new byte[8192]; - int n; - while ((n = ins.read(buf)) > 0) { - System.out.write(buf, 0, n); - } - } - if (p.waitFor() != 0) { - throw new Exception("Test failed"); - } + Proc p = Proc.create("EmptyCC").args(ccache, "readcc") + .env("KRB5CCNAME", ccache).start(); + p.waitFor(); } else { // Sub process, read the ccache String cc = System.getenv("KRB5CCNAME"); From f52ad64ccc0ccdea3f126a550c9cb239182abf5d Mon Sep 17 00:00:00 2001 From: Dmitry Nadezhin Date: Fri, 21 Jun 2013 11:12:18 -0700 Subject: [PATCH 010/127] 7192954: Fix Float.parseFloat to round correctly and preserve monotonicity 4396272: Parsing doubles fails to follow IEEE for largest decimal that should yield 0 7039391: Use Math.ulp in FloatingDecimal Correct rounding and monotonicity problems in floats and doubles Co-authored-by: Louis Wasserman Reviewed-by: bpb, martin --- .../share/classes/sun/misc/FDBigInteger.java | 4 +- .../classes/sun/misc/FloatingDecimal.java | 507 ++++++++++-------- jdk/test/java/lang/Double/ParseDouble.java | 157 +++++- jdk/test/java/lang/Float/ParseFloat.java | 126 ++++- .../FloatingDecimal/TestFDBigInteger.java | 8 + 5 files changed, 553 insertions(+), 249 deletions(-) diff --git a/jdk/src/share/classes/sun/misc/FDBigInteger.java b/jdk/src/share/classes/sun/misc/FDBigInteger.java index d575c350b4d..77d6fbc08b6 100644 --- a/jdk/src/share/classes/sun/misc/FDBigInteger.java +++ b/jdk/src/share/classes/sun/misc/FDBigInteger.java @@ -782,7 +782,7 @@ public /*@ spec_bigint_math @*/ class FDBigInteger { assert this.size() >= subtrahend.size() : "result should be positive"; FDBigInteger minuend; if (this.isImmutable) { - minuend = new FDBigInteger(this.data, this.offset); + minuend = new FDBigInteger(this.data.clone(), this.offset); } else { minuend = this; } @@ -851,7 +851,7 @@ public /*@ spec_bigint_math @*/ class FDBigInteger { assert this.size() >= subtrahend.size() : "result should be positive"; FDBigInteger minuend = this; if (subtrahend.isImmutable) { - subtrahend = new FDBigInteger(subtrahend.data, subtrahend.offset); + subtrahend = new FDBigInteger(subtrahend.data.clone(), subtrahend.offset); } int offsetDiff = minuend.offset - subtrahend.offset; int[] sData = subtrahend.data; diff --git a/jdk/src/share/classes/sun/misc/FloatingDecimal.java b/jdk/src/share/classes/sun/misc/FloatingDecimal.java index f2fe492c496..0daaaadc496 100644 --- a/jdk/src/share/classes/sun/misc/FloatingDecimal.java +++ b/jdk/src/share/classes/sun/misc/FloatingDecimal.java @@ -49,12 +49,14 @@ public class FloatingDecimal{ static final int MAX_DECIMAL_EXPONENT = 308; static final int MIN_DECIMAL_EXPONENT = -324; static final int BIG_DECIMAL_EXPONENT = 324; // i.e. abs(MIN_DECIMAL_EXPONENT) + static final int MAX_NDIGITS = 1100; static final int SINGLE_EXP_SHIFT = FloatConsts.SIGNIFICAND_WIDTH - 1; static final int SINGLE_FRACT_HOB = 1<ASCIIToBinaryConverter. @@ -1038,7 +1036,6 @@ public class FloatingDecimal{ int decExponent; char digits[]; int nDigits; - int roundDir = 0; // set by doubleValue ASCIIToBinaryBuffer( boolean negSign, int decExponent, char[] digits, int n) { @@ -1048,41 +1045,7 @@ public class FloatingDecimal{ this.nDigits = n; } - @Override - public double doubleValue() { - return doubleValue(false); - } - - /** - * Computes a number that is the ULP of the given value, - * for purposes of addition/subtraction. Generally easy. - * More difficult if subtracting and the argument - * is a normalized a power of 2, as the ULP changes at these points. - */ - private static double ulp(double dval, boolean subtracting) { - long lbits = Double.doubleToLongBits(dval) & ~DoubleConsts.SIGN_BIT_MASK; - int binexp = (int) (lbits >>> EXP_SHIFT); - double ulpval; - if (subtracting && (binexp >= EXP_SHIFT) && ((lbits & DoubleConsts.SIGNIF_BIT_MASK) == 0L)) { - // for subtraction from normalized, powers of 2, - // use next-smaller exponent - binexp -= 1; - } - if (binexp > EXP_SHIFT) { - ulpval = Double.longBitsToDouble(((long) (binexp - EXP_SHIFT)) << EXP_SHIFT); - } else if (binexp == 0) { - ulpval = Double.MIN_VALUE; - } else { - ulpval = Double.longBitsToDouble(1L << (binexp - 1)); - } - if (subtracting) { - ulpval = -ulpval; - } - - return ulpval; - } - - /** + /* * Takes a FloatingDecimal, which we presumably just scanned in, * and finds out what its value is, as a double. * @@ -1090,15 +1053,9 @@ public class FloatingDecimal{ * ROUNDING DIRECTION in case the result is really destined * for a single-precision float. */ - private strictfp double doubleValue(boolean mustSetRoundDir) { + @Override + public double doubleValue() { int kDigits = Math.min(nDigits, MAX_DECIMAL_DIGITS + 1); - long lValue; - double dValue; - double rValue; - - if (mustSetRoundDir) { - roundDir = 0; - } // // convert the lead kDigits to a long integer. // @@ -1108,11 +1065,11 @@ public class FloatingDecimal{ for (int i = 1; i < iDigits; i++) { iValue = iValue * 10 + (int) digits[i] - (int) '0'; } - lValue = (long) iValue; + long lValue = (long) iValue; for (int i = iDigits; i < kDigits; i++) { lValue = lValue * 10L + (long) ((int) digits[i] - (int) '0'); } - dValue = (double) lValue; + double dValue = (double) lValue; int exp = decExponent - kDigits; // // lValue now contains a long integer with the value of @@ -1140,13 +1097,7 @@ public class FloatingDecimal{ // Can get the answer with one operation, // thus one roundoff. // - rValue = dValue * SMALL_10_POW[exp]; - if (mustSetRoundDir) { - double tValue = rValue / SMALL_10_POW[exp]; - roundDir = (tValue == dValue) ? 0 - : (tValue < dValue) ? 1 - : -1; - } + double rValue = dValue * SMALL_10_POW[exp]; return (isNegative) ? -rValue : rValue; } int slop = MAX_DECIMAL_DIGITS - kDigits; @@ -1158,14 +1109,7 @@ public class FloatingDecimal{ // with one rounding. // dValue *= SMALL_10_POW[slop]; - rValue = dValue * SMALL_10_POW[exp - slop]; - - if (mustSetRoundDir) { - double tValue = rValue / SMALL_10_POW[exp - slop]; - roundDir = (tValue == dValue) ? 0 - : (tValue < dValue) ? 1 - : -1; - } + double rValue = dValue * SMALL_10_POW[exp - slop]; return (isNegative) ? -rValue : rValue; } // @@ -1176,13 +1120,7 @@ public class FloatingDecimal{ // // Can get the answer in one division. // - rValue = dValue / SMALL_10_POW[-exp]; - if (mustSetRoundDir) { - double tValue = rValue * SMALL_10_POW[-exp]; - roundDir = (tValue == dValue) ? 0 - : (tValue < dValue) ? 1 - : -1; - } + double rValue = dValue / SMALL_10_POW[-exp]; return (isNegative) ? -rValue : rValue; } // @@ -1303,9 +1241,14 @@ public class FloatingDecimal{ // Formulate the EXACT big-number result as // bigD0 * 10^exp // + if (nDigits > MAX_NDIGITS) { + nDigits = MAX_NDIGITS + 1; + digits[MAX_NDIGITS] = '1'; + } FDBigInteger bigD0 = new FDBigInteger(lValue, digits, kDigits, nDigits); exp = decExponent - nDigits; + long ieeeBits = Double.doubleToRawLongBits(dValue); // IEEE-754 bits of double candidate final int B5 = Math.max(0, -exp); // powers of 5 in bigB, value is not modified inside correctionLoop final int D5 = Math.max(0, exp); // powers of 5 in bigD, value is not modified inside correctionLoop bigD0 = bigD0.multByPow52(D5, 0); @@ -1315,10 +1258,9 @@ public class FloatingDecimal{ correctionLoop: while (true) { - // here dValue can't be NaN, Infinity or zero - long bigBbits = Double.doubleToRawLongBits(dValue) & ~DoubleConsts.SIGN_BIT_MASK; - int binexp = (int) (bigBbits >>> EXP_SHIFT); - bigBbits &= DoubleConsts.SIGNIF_BIT_MASK; + // here ieeeBits can't be NaN, Infinity or zero + int binexp = (int) (ieeeBits >>> EXP_SHIFT); + long bigBbits = ieeeBits & DoubleConsts.SIGNIF_BIT_MASK; if (binexp > 0) { bigBbits |= FRACT_HOB; } else { // Normalize denormalized numbers. @@ -1358,7 +1300,7 @@ public class FloatingDecimal{ if (binexp <= -DoubleConsts.EXP_BIAS) { // This is going to be a denormalized number // (if not actually zero). - // half an ULP is at 2^-(expBias+EXP_SHIFT+1) + // half an ULP is at 2^-(DoubleConsts.EXP_BIAS+EXP_SHIFT+1) hulpbias = binexp + lowOrderZeros + DoubleConsts.EXP_BIAS; } else { hulpbias = 1 + lowOrderZeros; @@ -1422,17 +1364,12 @@ public class FloatingDecimal{ if ((cmpResult) < 0) { // difference is small. // this is close enough - if (mustSetRoundDir) { - roundDir = overvalue ? -1 : 1; - } break correctionLoop; } else if (cmpResult == 0) { // difference is exactly half an ULP // round to some other value maybe, then finish - dValue += 0.5 * ulp(dValue, overvalue); - // should check for bigIntNBits == 1 here?? - if (mustSetRoundDir) { - roundDir = overvalue ? -1 : 1; + if ((ieeeBits & 1) != 0) { // half ties to even + ieeeBits += overvalue ? -1 : 1; // nextDown or nextUp } break correctionLoop; } else { @@ -1440,15 +1377,18 @@ public class FloatingDecimal{ // could scale addend by ratio of difference to // halfUlp here, if we bothered to compute that difference. // Most of the time ( I hope ) it is about 1 anyway. - dValue += ulp(dValue, overvalue); - if (dValue == 0.0 || dValue == Double.POSITIVE_INFINITY) { + ieeeBits += overvalue ? -1 : 1; // nextDown or nextUp + if (ieeeBits == 0 || ieeeBits == DoubleConsts.EXP_BIT_MASK) { // 0.0 or Double.POSITIVE_INFINITY break correctionLoop; // oops. Fell off end of range. } continue; // try again. } } - return (isNegative) ? -dValue : dValue; + if (isNegative) { + ieeeBits |= DoubleConsts.SIGN_BIT_MASK; + } + return Double.longBitsToDouble(ieeeBits); } /** @@ -1461,18 +1401,16 @@ public class FloatingDecimal{ * ( because of the preference to a zero low-order bit ). */ @Override - public strictfp float floatValue() { + public float floatValue() { int kDigits = Math.min(nDigits, SINGLE_MAX_DECIMAL_DIGITS + 1); - int iValue; - float fValue; // // convert the lead kDigits to an integer. // - iValue = (int) digits[0] - (int) '0'; + int iValue = (int) digits[0] - (int) '0'; for (int i = 1; i < kDigits; i++) { iValue = iValue * 10 + (int) digits[i] - (int) '0'; } - fValue = (float) iValue; + float fValue = (float) iValue; int exp = decExponent - kDigits; // // iValue now contains an integer with the value of @@ -1505,7 +1443,7 @@ public class FloatingDecimal{ int slop = SINGLE_MAX_DECIMAL_DIGITS - kDigits; if (exp <= SINGLE_MAX_SMALL_TEN + slop) { // - // We can multiply dValue by 10^(slop) + // We can multiply fValue by 10^(slop) // and it is still "small" and exact. // Then we can multiply by 10^(exp-slop) // with one rounding. @@ -1555,38 +1493,208 @@ public class FloatingDecimal{ // The sum of digits plus exponent is greater than // what we think we can do with one error. // - // Start by weeding out obviously out-of-range - // results, then convert to double and go to - // common hard-case code. + // Start by approximating the right answer by, + // naively, scaling by powers of 10. + // Scaling uses doubles to avoid overflow/underflow. // - if (decExponent > SINGLE_MAX_DECIMAL_EXPONENT + 1) { - // - // Lets face it. This is going to be - // Infinity. Cut to the chase. - // - return (isNegative) ? Float.NEGATIVE_INFINITY : Float.POSITIVE_INFINITY; - } else if (decExponent < SINGLE_MIN_DECIMAL_EXPONENT - 1) { - // - // Lets face it. This is going to be - // zero. Cut to the chase. - // - return (isNegative) ? -0.0f : 0.0f; + double dValue = fValue; + if (exp > 0) { + if (decExponent > SINGLE_MAX_DECIMAL_EXPONENT + 1) { + // + // Lets face it. This is going to be + // Infinity. Cut to the chase. + // + return (isNegative) ? Float.NEGATIVE_INFINITY : Float.POSITIVE_INFINITY; + } + if ((exp & 15) != 0) { + dValue *= SMALL_10_POW[exp & 15]; + } + if ((exp >>= 4) != 0) { + int j; + for (j = 0; exp > 0; j++, exp >>= 1) { + if ((exp & 1) != 0) { + dValue *= BIG_10_POW[j]; + } + } + } + } else if (exp < 0) { + exp = -exp; + if (decExponent < SINGLE_MIN_DECIMAL_EXPONENT - 1) { + // + // Lets face it. This is going to be + // zero. Cut to the chase. + // + return (isNegative) ? -0.0f : 0.0f; + } + if ((exp & 15) != 0) { + dValue /= SMALL_10_POW[exp & 15]; + } + if ((exp >>= 4) != 0) { + int j; + for (j = 0; exp > 0; j++, exp >>= 1) { + if ((exp & 1) != 0) { + dValue *= TINY_10_POW[j]; + } + } + } } + fValue = Math.max(Float.MIN_VALUE, Math.min(Float.MAX_VALUE, (float) dValue)); // - // Here, we do 'way too much work, but throwing away - // our partial results, and going and doing the whole - // thing as double, then throwing away half the bits that computes - // when we convert back to float. + // fValue is now approximately the result. + // The hard part is adjusting it, by comparison + // with FDBigInteger arithmetic. + // Formulate the EXACT big-number result as + // bigD0 * 10^exp // - // The alternative is to reproduce the whole multiple-precision - // algorithm for float precision, or to try to parameterize it - // for common usage. The former will take about 400 lines of code, - // and the latter I tried without success. Thus the semi-hack - // answer here. - // - double dValue = doubleValue(true); - return stickyRound(dValue, roundDir); + if (nDigits > SINGLE_MAX_NDIGITS) { + nDigits = SINGLE_MAX_NDIGITS + 1; + digits[SINGLE_MAX_NDIGITS] = '1'; + } + FDBigInteger bigD0 = new FDBigInteger(iValue, digits, kDigits, nDigits); + exp = decExponent - nDigits; + + int ieeeBits = Float.floatToRawIntBits(fValue); // IEEE-754 bits of float candidate + final int B5 = Math.max(0, -exp); // powers of 5 in bigB, value is not modified inside correctionLoop + final int D5 = Math.max(0, exp); // powers of 5 in bigD, value is not modified inside correctionLoop + bigD0 = bigD0.multByPow52(D5, 0); + bigD0.makeImmutable(); // prevent bigD0 modification inside correctionLoop + FDBigInteger bigD = null; + int prevD2 = 0; + + correctionLoop: + while (true) { + // here ieeeBits can't be NaN, Infinity or zero + int binexp = ieeeBits >>> SINGLE_EXP_SHIFT; + int bigBbits = ieeeBits & FloatConsts.SIGNIF_BIT_MASK; + if (binexp > 0) { + bigBbits |= SINGLE_FRACT_HOB; + } else { // Normalize denormalized numbers. + assert bigBbits != 0 : bigBbits; // floatToBigInt(0.0) + int leadingZeros = Integer.numberOfLeadingZeros(bigBbits); + int shift = leadingZeros - (31 - SINGLE_EXP_SHIFT); + bigBbits <<= shift; + binexp = 1 - shift; + } + binexp -= FloatConsts.EXP_BIAS; + int lowOrderZeros = Integer.numberOfTrailingZeros(bigBbits); + bigBbits >>>= lowOrderZeros; + final int bigIntExp = binexp - SINGLE_EXP_SHIFT + lowOrderZeros; + final int bigIntNBits = SINGLE_EXP_SHIFT + 1 - lowOrderZeros; + + // + // Scale bigD, bigB appropriately for + // big-integer operations. + // Naively, we multiply by powers of ten + // and powers of two. What we actually do + // is keep track of the powers of 5 and + // powers of 2 we would use, then factor out + // common divisors before doing the work. + // + int B2 = B5; // powers of 2 in bigB + int D2 = D5; // powers of 2 in bigD + int Ulp2; // powers of 2 in halfUlp. + if (bigIntExp >= 0) { + B2 += bigIntExp; + } else { + D2 -= bigIntExp; + } + Ulp2 = B2; + // shift bigB and bigD left by a number s. t. + // halfUlp is still an integer. + int hulpbias; + if (binexp <= -FloatConsts.EXP_BIAS) { + // This is going to be a denormalized number + // (if not actually zero). + // half an ULP is at 2^-(FloatConsts.EXP_BIAS+SINGLE_EXP_SHIFT+1) + hulpbias = binexp + lowOrderZeros + FloatConsts.EXP_BIAS; + } else { + hulpbias = 1 + lowOrderZeros; + } + B2 += hulpbias; + D2 += hulpbias; + // if there are common factors of 2, we might just as well + // factor them out, as they add nothing useful. + int common2 = Math.min(B2, Math.min(D2, Ulp2)); + B2 -= common2; + D2 -= common2; + Ulp2 -= common2; + // do multiplications by powers of 5 and 2 + FDBigInteger bigB = FDBigInteger.valueOfMulPow52(bigBbits, B5, B2); + if (bigD == null || prevD2 != D2) { + bigD = bigD0.leftShift(D2); + prevD2 = D2; + } + // + // to recap: + // bigB is the scaled-big-int version of our floating-point + // candidate. + // bigD is the scaled-big-int version of the exact value + // as we understand it. + // halfUlp is 1/2 an ulp of bigB, except for special cases + // of exact powers of 2 + // + // the plan is to compare bigB with bigD, and if the difference + // is less than halfUlp, then we're satisfied. Otherwise, + // use the ratio of difference to halfUlp to calculate a fudge + // factor to add to the floating value, then go 'round again. + // + FDBigInteger diff; + int cmpResult; + boolean overvalue; + if ((cmpResult = bigB.cmp(bigD)) > 0) { + overvalue = true; // our candidate is too big. + diff = bigB.leftInplaceSub(bigD); // bigB is not user further - reuse + if ((bigIntNBits == 1) && (bigIntExp > -FloatConsts.EXP_BIAS + 1)) { + // candidate is a normalized exact power of 2 and + // is too big (larger than Float.MIN_NORMAL). We will be subtracting. + // For our purposes, ulp is the ulp of the + // next smaller range. + Ulp2 -= 1; + if (Ulp2 < 0) { + // rats. Cannot de-scale ulp this far. + // must scale diff in other direction. + Ulp2 = 0; + diff = diff.leftShift(1); + } + } + } else if (cmpResult < 0) { + overvalue = false; // our candidate is too small. + diff = bigD.rightInplaceSub(bigB); // bigB is not user further - reuse + } else { + // the candidate is exactly right! + // this happens with surprising frequency + break correctionLoop; + } + cmpResult = diff.cmpPow52(B5, Ulp2); + if ((cmpResult) < 0) { + // difference is small. + // this is close enough + break correctionLoop; + } else if (cmpResult == 0) { + // difference is exactly half an ULP + // round to some other value maybe, then finish + if ((ieeeBits & 1) != 0) { // half ties to even + ieeeBits += overvalue ? -1 : 1; // nextDown or nextUp + } + break correctionLoop; + } else { + // difference is non-trivial. + // could scale addend by ratio of difference to + // halfUlp here, if we bothered to compute that difference. + // Most of the time ( I hope ) it is about 1 anyway. + ieeeBits += overvalue ? -1 : 1; // nextDown or nextUp + if (ieeeBits == 0 || ieeeBits == FloatConsts.EXP_BIT_MASK) { // 0.0 or Float.POSITIVE_INFINITY + break correctionLoop; // oops. Fell off end of range. + } + continue; // try again. + } + + } + if (isNegative) { + ieeeBits |= FloatConsts.SIGN_BIT_MASK; + } + return Float.intBitsToFloat(ieeeBits); } @@ -1935,32 +2043,6 @@ public class FloatingDecimal{ throw new NumberFormatException("For input string: \"" + in + "\""); } - /** - * Rounds a double to a float. - * In addition to the fraction bits of the double, - * look at the class instance variable roundDir, - * which should help us avoid double-rounding error. - * roundDir was set in hardValueOf if the estimate was - * close enough, but not exact. It tells us which direction - * of rounding is preferred. - */ - static float stickyRound( double dval, int roundDirection ){ - if(roundDirection!=0) { - long lbits = Double.doubleToRawLongBits( dval ); - long binexp = lbits & DoubleConsts.EXP_BIT_MASK; - if ( binexp == 0L || binexp == DoubleConsts.EXP_BIT_MASK ){ - // what we have here is special. - // don't worry, the right thing will happen. - return (float) dval; - } - lbits += (long)roundDirection; // hack-o-matic. - return (float)Double.longBitsToDouble( lbits ); - } else { - return (float)dval; - } - } - - private static class HexFloatPattern { /** * Grammar is compatible with hexadecimal floating-point constants @@ -2282,6 +2364,39 @@ public class FloatingDecimal{ // else all of string was seen, round and sticky are // correct as false. + // Float calculations + int floatBits = isNegative ? FloatConsts.SIGN_BIT_MASK : 0; + if (exponent >= FloatConsts.MIN_EXPONENT) { + if (exponent > FloatConsts.MAX_EXPONENT) { + // Float.POSITIVE_INFINITY + floatBits |= FloatConsts.EXP_BIT_MASK; + } else { + int threshShift = DoubleConsts.SIGNIFICAND_WIDTH - FloatConsts.SIGNIFICAND_WIDTH - 1; + boolean floatSticky = (significand & ((1L << threshShift) - 1)) != 0 || round || sticky; + int iValue = (int) (significand >>> threshShift); + if ((iValue & 3) != 1 || floatSticky) { + iValue++; + } + floatBits |= (((((int) exponent) + (FloatConsts.EXP_BIAS - 1))) << SINGLE_EXP_SHIFT) + (iValue >> 1); + } + } else { + if (exponent < FloatConsts.MIN_SUB_EXPONENT - 1) { + // 0 + } else { + // exponent == -127 ==> threshShift = 53 - 2 + (-149) - (-127) = 53 - 24 + int threshShift = (int) ((DoubleConsts.SIGNIFICAND_WIDTH - 2 + FloatConsts.MIN_SUB_EXPONENT) - exponent); + assert threshShift >= DoubleConsts.SIGNIFICAND_WIDTH - FloatConsts.SIGNIFICAND_WIDTH; + assert threshShift < DoubleConsts.SIGNIFICAND_WIDTH; + boolean floatSticky = (significand & ((1L << threshShift) - 1)) != 0 || round || sticky; + int iValue = (int) (significand >>> threshShift); + if ((iValue & 3) != 1 || floatSticky) { + iValue++; + } + floatBits |= iValue >> 1; + } + } + float fValue = Float.intBitsToFloat(floatBits); + // Check for overflow and update exponent accordingly. if (exponent > DoubleConsts.MAX_EXPONENT) { // Infinite result // overflow to properly signed infinity @@ -2390,87 +2505,7 @@ public class FloatingDecimal{ Double.longBitsToDouble(significand | DoubleConsts.SIGN_BIT_MASK) : Double.longBitsToDouble(significand ); - int roundDir = 0; - // - // Set roundingDir variable field of fd properly so - // that the input string can be properly rounded to a - // float value. There are two cases to consider: - // - // 1. rounding to double discards sticky bit - // information that would change the result of a float - // rounding (near halfway case between two floats) - // - // 2. rounding to double rounds up when rounding up - // would not occur when rounding to float. - // - // For former case only needs to be considered when - // the bits rounded away when casting to float are all - // zero; otherwise, float round bit is properly set - // and sticky will already be true. - // - // The lower exponent bound for the code below is the - // minimum (normalized) subnormal exponent - 1 since a - // value with that exponent can round up to the - // minimum subnormal value and the sticky bit - // information must be preserved (i.e. case 1). - // - if ((exponent >= FloatConsts.MIN_SUB_EXPONENT - 1) && - (exponent <= FloatConsts.MAX_EXPONENT)) { - // Outside above exponent range, the float value - // will be zero or infinity. - - // - // If the low-order 28 bits of a rounded double - // significand are 0, the double could be a - // half-way case for a rounding to float. If the - // double value is a half-way case, the double - // significand may have to be modified to round - // the the right float value (see the stickyRound - // method). If the rounding to double has lost - // what would be float sticky bit information, the - // double significand must be incremented. If the - // double value's significand was itself - // incremented, the float value may end up too - // large so the increment should be undone. - // - if ((significand & 0xfffffffL) == 0x0L) { - // For negative values, the sign of the - // roundDir is the same as for positive values - // since adding 1 increasing the significand's - // magnitude and subtracting 1 decreases the - // significand's magnitude. If neither round - // nor sticky is true, the double value is - // exact and no adjustment is required for a - // proper float rounding. - if (round || sticky) { - if (leastZero) { // prerounding lsb is 0 - // If round and sticky were both true, - // and the least significant - // significand bit were 0, the rounded - // significand would not have its - // low-order bits be zero. Therefore, - // we only need to adjust the - // significand if round XOR sticky is - // true. - if (round ^ sticky) { - roundDir = 1; - } - } else { // prerounding lsb is 1 - // If the prerounding lsb is 1 and the - // resulting significand has its - // low-order bits zero, the significand - // was incremented. Here, we undo the - // increment, which will ensure the - // right guard and sticky bits for the - // float rounding. - if (round) { - roundDir = -1; - } - } - } - } - } - return new PreparedASCIIToBinaryBuffer(value,roundDir); + return new PreparedASCIIToBinaryBuffer(value, fValue); } } } diff --git a/jdk/test/java/lang/Double/ParseDouble.java b/jdk/test/java/lang/Double/ParseDouble.java index 504f5bc3dc0..6cefad6ee02 100644 --- a/jdk/test/java/lang/Double/ParseDouble.java +++ b/jdk/test/java/lang/Double/ParseDouble.java @@ -23,20 +23,106 @@ /* * @test - * @bug 4160406 4705734 4707389 4826774 4895911 4421494 7021568 7039369 + * @bug 4160406 4705734 4707389 4826774 4895911 4421494 6358355 7021568 7039369 4396272 * @summary Test for Double.parseDouble method and acceptance regex */ -import java.util.regex.*; import java.math.BigDecimal; +import java.math.BigInteger; +import java.util.regex.*; public class ParseDouble { + private static final BigDecimal HALF = BigDecimal.valueOf(0.5); + + private static void fail(String val, double n) { + throw new RuntimeException("Double.parseDouble failed. String:" + + val + " Result:" + n); + } + + private static void check(String val) { + double n = Double.parseDouble(val); + boolean isNegativeN = n < 0 || n == 0 && 1/n < 0; + double na = Math.abs(n); + String s = val.trim().toLowerCase(); + switch (s.charAt(s.length() - 1)) { + case 'd': + case 'f': + s = s.substring(0, s.length() - 1); + break; + } + boolean isNegative = false; + if (s.charAt(0) == '+') { + s = s.substring(1); + } else if (s.charAt(0) == '-') { + s = s.substring(1); + isNegative = true; + } + if (s.equals("nan")) { + if (!Double.isNaN(n)) { + fail(val, n); + } + return; + } + if (Double.isNaN(n)) { + fail(val, n); + } + if (isNegativeN != isNegative) + fail(val, n); + if (s.equals("infinity")) { + if (na != Double.POSITIVE_INFINITY) { + fail(val, n); + } + return; + } + BigDecimal bd; + if (s.startsWith("0x")) { + s = s.substring(2); + int indP = s.indexOf('p'); + long exp = Long.parseLong(s.substring(indP + 1)); + int indD = s.indexOf('.'); + String significand; + if (indD >= 0) { + significand = s.substring(0, indD) + s.substring(indD + 1, indP); + exp -= 4*(indP - indD - 1); + } else { + significand = s.substring(0, indP); + } + bd = new BigDecimal(new BigInteger(significand, 16)); + if (exp >= 0) { + bd = bd.multiply(BigDecimal.valueOf(2).pow((int)exp)); + } else { + bd = bd.divide(BigDecimal.valueOf(2).pow((int)-exp)); + } + } else { + bd = new BigDecimal(s); + } + BigDecimal l, u; + if (Double.isInfinite(na)) { + l = new BigDecimal(Double.MAX_VALUE).add(new BigDecimal(Math.ulp(Double.MAX_VALUE)).multiply(HALF)); + u = null; + } else { + l = new BigDecimal(na).subtract(new BigDecimal(Math.ulp(Math.nextUp(-na))).multiply(HALF)); + u = new BigDecimal(na).add(new BigDecimal(Math.ulp(n)).multiply(HALF)); + } + int cmpL = bd.compareTo(l); + int cmpU = u != null ? bd.compareTo(u) : -1; + if ((Double.doubleToLongBits(n) & 1) != 0) { + if (cmpL <= 0 || cmpU >= 0) { + fail(val, n); + } + } else { + if (cmpL < 0 || cmpU > 0) { + fail(val, n); + } + } + } + private static void check(String val, double expected) { double n = Double.parseDouble(val); if (n != expected) - throw new RuntimeException("Double.parseDouble failed. String:" + - val + " Result:" + n); + fail(val, n); + check(val); } private static void rudimentaryTest() { @@ -460,6 +546,7 @@ public class ParseDouble { try { d = Double.parseDouble(input[i]); + check(input[i]); } catch (NumberFormatException e) { if (! exceptionalInput) { @@ -560,12 +647,13 @@ public class ParseDouble { * region that should convert to that value. */ private static void testSubnormalPowers() { + boolean failed = false; BigDecimal TWO = BigDecimal.valueOf(2); // An ulp is the same for all subnormal values BigDecimal ulp_BD = new BigDecimal(Double.MIN_VALUE); - // Test subnormal powers of two - for(int i = -1074; i <= -1022; i++) { + // Test subnormal powers of two (except Double.MIN_VALUE) + for(int i = -1073; i <= -1022; i++) { double d = Math.scalb(1.0, i); /* @@ -578,17 +666,69 @@ public class ParseDouble { double convertedLowerBound = Double.parseDouble(lowerBound.toString()); double convertedUpperBound = Double.parseDouble(upperBound.toString()); + if (convertedLowerBound != d) { + failed = true; + System.out.printf("2^%d lowerBound converts as %a %s%n", + i, convertedLowerBound, lowerBound); + } + if (convertedUpperBound != d) { + failed = true; + System.out.printf("2^%d upperBound converts as %a %s%n", + i, convertedUpperBound, upperBound); + } } + /* + * Double.MIN_VALUE + * The region ]0.5*Double.MIN_VALUE, 1.5*Double.MIN_VALUE[ should round to Double.MIN_VALUE . + */ + BigDecimal minValue = new BigDecimal(Double.MIN_VALUE); + if (Double.parseDouble(minValue.multiply(new BigDecimal(0.5)).toString()) != 0.0) { + failed = true; + System.out.printf("0.5*MIN_VALUE doesn't convert 0%n"); + } + if (Double.parseDouble(minValue.multiply(new BigDecimal(0.50000000001)).toString()) != Double.MIN_VALUE) { + failed = true; + System.out.printf("0.50000000001*MIN_VALUE doesn't convert to MIN_VALUE%n"); + } + if (Double.parseDouble(minValue.multiply(new BigDecimal(1.49999999999)).toString()) != Double.MIN_VALUE) { + failed = true; + System.out.printf("1.49999999999*MIN_VALUE doesn't convert to MIN_VALUE%n"); + } + if (Double.parseDouble(minValue.multiply(new BigDecimal(1.5)).toString()) != 2*Double.MIN_VALUE) { + failed = true; + System.out.printf("1.5*MIN_VALUE doesn't convert to 2*MIN_VALUE%n"); + } + + if (failed) + throw new RuntimeException("Inconsistent conversion"); } + /** + * For each power of two, test at boundaries of + * region that should convert to that value. + */ + private static void testPowers() { + for(int i = -1074; i <= +1023; i++) { + double d = Math.scalb(1.0, i); + BigDecimal d_BD = new BigDecimal(d); + + BigDecimal lowerBound = d_BD.subtract(new BigDecimal(Math.ulp(Math.nextUp(-d))).multiply(HALF)); + BigDecimal upperBound = d_BD.add(new BigDecimal(Math.ulp(d)).multiply(HALF)); + + check(lowerBound.toString()); + check(upperBound.toString()); + } + check(new BigDecimal(Double.MAX_VALUE).add(new BigDecimal(Math.ulp(Double.MAX_VALUE)).multiply(HALF)).toString()); + } private static void testStrictness() { - final double expected = 0x0.0000008000001p-1022; + final double expected = 0x0.0000008000000p-1022; +// final double expected = 0x0.0000008000001p-1022; boolean failed = false; double conversion = 0.0; double sum = 0.0; // Prevent conversion from being optimized away - //2^-1047 + 2^-1075 + //2^-1047 + 2^-1075 rounds to 2^-1047 String decimal = "6.631236871469758276785396630275967243399099947355303144249971758736286630139265439618068200788048744105960420552601852889715006376325666595539603330361800519107591783233358492337208057849499360899425128640718856616503093444922854759159988160304439909868291973931426625698663157749836252274523485312442358651207051292453083278116143932569727918709786004497872322193856150225415211997283078496319412124640111777216148110752815101775295719811974338451936095907419622417538473679495148632480391435931767981122396703443803335529756003353209830071832230689201383015598792184172909927924176339315507402234836120730914783168400715462440053817592702766213559042115986763819482654128770595766806872783349146967171293949598850675682115696218943412532098591327667236328125E-316"; for(int i = 0; i <= 12_000; i++) { @@ -620,6 +760,7 @@ public class ParseDouble { testRegex(paddedBadStrings, true); testSubnormalPowers(); + testPowers(); testStrictness(); } } diff --git a/jdk/test/java/lang/Float/ParseFloat.java b/jdk/test/java/lang/Float/ParseFloat.java index 4d646668f9c..f78cef77d03 100644 --- a/jdk/test/java/lang/Float/ParseFloat.java +++ b/jdk/test/java/lang/Float/ParseFloat.java @@ -23,17 +23,105 @@ /* * @test - * @bug 4160406 4705734 4707389 + * @bug 4160406 4705734 4707389 6358355 7032154 * @summary Tests for Float.parseFloat method */ +import java.math.BigDecimal; +import java.math.BigInteger; + public class ParseFloat { + private static final BigDecimal HALF = BigDecimal.valueOf(0.5); + + private static void fail(String val, float n) { + throw new RuntimeException("Float.parseFloat failed. String:" + + val + " Result:" + n); + } + + private static void check(String val) { + float n = Float.parseFloat(val); + boolean isNegativeN = n < 0 || n == 0 && 1/n < 0; + float na = Math.abs(n); + String s = val.trim().toLowerCase(); + switch (s.charAt(s.length() - 1)) { + case 'd': + case 'f': + s = s.substring(0, s.length() - 1); + break; + } + boolean isNegative = false; + if (s.charAt(0) == '+') { + s = s.substring(1); + } else if (s.charAt(0) == '-') { + s = s.substring(1); + isNegative = true; + } + if (s.equals("nan")) { + if (!Float.isNaN(n)) { + fail(val, n); + } + return; + } + if (Float.isNaN(n)) { + fail(val, n); + } + if (isNegativeN != isNegative) + fail(val, n); + if (s.equals("infinity")) { + if (na != Float.POSITIVE_INFINITY) { + fail(val, n); + } + return; + } + BigDecimal bd; + if (s.startsWith("0x")) { + s = s.substring(2); + int indP = s.indexOf('p'); + long exp = Long.parseLong(s.substring(indP + 1)); + int indD = s.indexOf('.'); + String significand; + if (indD >= 0) { + significand = s.substring(0, indD) + s.substring(indD + 1, indP); + exp -= 4*(indP - indD - 1); + } else { + significand = s.substring(0, indP); + } + bd = new BigDecimal(new BigInteger(significand, 16)); + if (exp >= 0) { + bd = bd.multiply(BigDecimal.valueOf(2).pow((int)exp)); + } else { + bd = bd.divide(BigDecimal.valueOf(2).pow((int)-exp)); + } + } else { + bd = new BigDecimal(s); + } + BigDecimal l, u; + if (Float.isInfinite(na)) { + l = new BigDecimal(Float.MAX_VALUE).add(new BigDecimal(Math.ulp(Float.MAX_VALUE)).multiply(HALF)); + u = null; + } else { + l = new BigDecimal(na).subtract(new BigDecimal(Math.ulp(-Math.nextUp(-na))).multiply(HALF)); + u = new BigDecimal(na).add(new BigDecimal(Math.ulp(n)).multiply(HALF)); + } + int cmpL = bd.compareTo(l); + int cmpU = u != null ? bd.compareTo(u) : -1; + if ((Float.floatToIntBits(n) & 1) != 0) { + if (cmpL <= 0 || cmpU >= 0) { + fail(val, n); + } + } else { + if (cmpL < 0 || cmpU > 0) { + fail(val, n); + } + } + } + private static void check(String val, float expected) { float n = Float.parseFloat(val); if (n != expected) - throw new RuntimeException("Float.parseFloat failed. String:" + - val + " Result:" + n); + fail(val, n); + check(val); } private static void rudimentaryTest() { @@ -47,6 +135,17 @@ public class ParseFloat { check("-10", (float) -10.0); check("-10.00", (float) -10.0); check("-10.01", (float) -10.01); + + // bug 6358355 + check("144115196665790480", 0x1.000002p57f); + check("144115196665790481", 0x1.000002p57f); + check("0.050000002607703203", 0.05f); + check("0.050000002607703204", 0.05f); + check("0.050000002607703205", 0.05f); + check("0.050000002607703206", 0.05f); + check("0.050000002607703207", 0.05f); + check("0.050000002607703208", 0.05f); + check("0.050000002607703209", 0.050000004f); } static String badStrings[] = { @@ -182,6 +281,7 @@ public class ParseFloat { try { d = Float.parseFloat(input[i]); + check(input[i]); } catch (NumberFormatException e) { if (! exceptionalInput) { @@ -199,6 +299,24 @@ public class ParseFloat { } } + /** + * For each power of two, test at boundaries of + * region that should convert to that value. + */ + private static void testPowers() { + for(int i = -149; i <= +127; i++) { + float f = Math.scalb(1.0f, i); + BigDecimal f_BD = new BigDecimal(f); + + BigDecimal lowerBound = f_BD.subtract(new BigDecimal(Math.ulp(-Math.nextUp(-f))).multiply(HALF)); + BigDecimal upperBound = f_BD.add(new BigDecimal(Math.ulp(f)).multiply(HALF)); + + check(lowerBound.toString()); + check(upperBound.toString()); + } + check(new BigDecimal(Float.MAX_VALUE).add(new BigDecimal(Math.ulp(Float.MAX_VALUE)).multiply(HALF)).toString()); + } + public static void main(String[] args) throws Exception { rudimentaryTest(); @@ -206,5 +324,7 @@ public class ParseFloat { testParsing(paddedGoodStrings, false); testParsing(badStrings, true); testParsing(paddedBadStrings, true); + + testPowers(); } } diff --git a/jdk/test/sun/misc/FloatingDecimal/TestFDBigInteger.java b/jdk/test/sun/misc/FloatingDecimal/TestFDBigInteger.java index 5818e9402bd..cfdb7b84982 100644 --- a/jdk/test/sun/misc/FloatingDecimal/TestFDBigInteger.java +++ b/jdk/test/sun/misc/FloatingDecimal/TestFDBigInteger.java @@ -351,6 +351,10 @@ public class TestFDBigInteger { if (!isImmutable && diff != left) { throw new Exception("leftInplaceSub of doesn't reuse its argument"); } + if (isImmutable) { + check(biLeft, left, "leftInplaceSub corrupts its left immutable argument"); + } + check(biRight, right, "leftInplaceSub corrupts its right argument"); check(biLeft.subtract(biRight), diff, "leftInplaceSub returns wrong result"); } @@ -381,6 +385,10 @@ public class TestFDBigInteger { if (!isImmutable && diff != right) { throw new Exception("rightInplaceSub of doesn't reuse its argument"); } + check(biLeft, left, "leftInplaceSub corrupts its left argument"); + if (isImmutable) { + check(biRight, right, "leftInplaceSub corrupts its right immutable argument"); + } try { check(biLeft.subtract(biRight), diff, "rightInplaceSub returns wrong result"); } catch (Exception e) { From 90aebf1cf930c126e830e70f2c9afc29b79473e6 Mon Sep 17 00:00:00 2001 From: Louis Wasserman Date: Fri, 21 Jun 2013 11:50:45 -0700 Subject: [PATCH 011/127] 7131192: BigInteger.doubleValue() is depressingly slow In doubleValue() and floatValue() replace converting to String and parsing to Double or Float with direct conversion into IEEE 754 bits. Reviewed-by: bpb, drchase, martin --- .../share/classes/java/math/BigInteger.java | 146 +++++++++++++++++- .../BigInteger/PrimitiveConversionTests.java | 105 +++++++++++++ 2 files changed, 247 insertions(+), 4 deletions(-) create mode 100644 jdk/test/java/math/BigInteger/PrimitiveConversionTests.java diff --git a/jdk/src/share/classes/java/math/BigInteger.java b/jdk/src/share/classes/java/math/BigInteger.java index 4c8b7816d08..8972ac76ef9 100644 --- a/jdk/src/share/classes/java/math/BigInteger.java +++ b/jdk/src/share/classes/java/math/BigInteger.java @@ -35,6 +35,8 @@ import java.io.ObjectOutputStream; import java.io.ObjectStreamField; import java.util.Arrays; import java.util.Random; +import sun.misc.DoubleConsts; +import sun.misc.FloatConsts; /** * Immutable arbitrary-precision integers. All operations behave as if @@ -3452,8 +3454,72 @@ public class BigInteger extends Number implements Comparable { * @return this BigInteger converted to a {@code float}. */ public float floatValue() { - // Somewhat inefficient, but guaranteed to work. - return Float.parseFloat(this.toString()); + if (signum == 0) { + return 0.0f; + } + + int exponent = ((mag.length - 1) << 5) + bitLengthForInt(mag[0]) - 1; + + // exponent == floor(log2(abs(this))) + if (exponent < Long.SIZE - 1) { + return longValue(); + } else if (exponent > Float.MAX_EXPONENT) { + return signum > 0 ? Float.POSITIVE_INFINITY : Float.NEGATIVE_INFINITY; + } + + /* + * We need the top SIGNIFICAND_WIDTH bits, including the "implicit" + * one bit. To make rounding easier, we pick out the top + * SIGNIFICAND_WIDTH + 1 bits, so we have one to help us round up or + * down. twiceSignifFloor will contain the top SIGNIFICAND_WIDTH + 1 + * bits, and signifFloor the top SIGNIFICAND_WIDTH. + * + * It helps to consider the real number signif = abs(this) * + * 2^(SIGNIFICAND_WIDTH - 1 - exponent). + */ + int shift = exponent - FloatConsts.SIGNIFICAND_WIDTH; + + int twiceSignifFloor; + // twiceSignifFloor will be == abs().shiftRight(shift).intValue() + // We do the shift into an int directly to improve performance. + + int nBits = shift & 0x1f; + int nBits2 = 32 - nBits; + + if (nBits == 0) { + twiceSignifFloor = mag[0]; + } else { + twiceSignifFloor = mag[0] >>> nBits; + if (twiceSignifFloor == 0) { + twiceSignifFloor = (mag[0] << nBits2) | (mag[1] >>> nBits); + } + } + + int signifFloor = twiceSignifFloor >> 1; + signifFloor &= FloatConsts.SIGNIF_BIT_MASK; // remove the implied bit + + /* + * We round up if either the fractional part of signif is strictly + * greater than 0.5 (which is true if the 0.5 bit is set and any lower + * bit is set), or if the fractional part of signif is >= 0.5 and + * signifFloor is odd (which is true if both the 0.5 bit and the 1 bit + * are set). This is equivalent to the desired HALF_EVEN rounding. + */ + boolean increment = (twiceSignifFloor & 1) != 0 + && ((signifFloor & 1) != 0 || abs().getLowestSetBit() < shift); + int signifRounded = increment ? signifFloor + 1 : signifFloor; + int bits = ((exponent + FloatConsts.EXP_BIAS)) + << (FloatConsts.SIGNIFICAND_WIDTH - 1); + bits += signifRounded; + /* + * If signifRounded == 2^24, we'd need to set all of the significand + * bits to zero and add 1 to the exponent. This is exactly the behavior + * we get from just adding signifRounded to bits directly. If the + * exponent is Float.MAX_EXPONENT, we round up (correctly) to + * Float.POSITIVE_INFINITY. + */ + bits |= signum & FloatConsts.SIGN_BIT_MASK; + return Float.intBitsToFloat(bits); } /** @@ -3472,8 +3538,80 @@ public class BigInteger extends Number implements Comparable { * @return this BigInteger converted to a {@code double}. */ public double doubleValue() { - // Somewhat inefficient, but guaranteed to work. - return Double.parseDouble(this.toString()); + if (signum == 0) { + return 0.0; + } + + int exponent = ((mag.length - 1) << 5) + bitLengthForInt(mag[0]) - 1; + + // exponent == floor(log2(abs(this))Double) + if (exponent < Long.SIZE - 1) { + return longValue(); + } else if (exponent > Double.MAX_EXPONENT) { + return signum > 0 ? Double.POSITIVE_INFINITY : Double.NEGATIVE_INFINITY; + } + + /* + * We need the top SIGNIFICAND_WIDTH bits, including the "implicit" + * one bit. To make rounding easier, we pick out the top + * SIGNIFICAND_WIDTH + 1 bits, so we have one to help us round up or + * down. twiceSignifFloor will contain the top SIGNIFICAND_WIDTH + 1 + * bits, and signifFloor the top SIGNIFICAND_WIDTH. + * + * It helps to consider the real number signif = abs(this) * + * 2^(SIGNIFICAND_WIDTH - 1 - exponent). + */ + int shift = exponent - DoubleConsts.SIGNIFICAND_WIDTH; + + long twiceSignifFloor; + // twiceSignifFloor will be == abs().shiftRight(shift).longValue() + // We do the shift into a long directly to improve performance. + + int nBits = shift & 0x1f; + int nBits2 = 32 - nBits; + + int highBits; + int lowBits; + if (nBits == 0) { + highBits = mag[0]; + lowBits = mag[1]; + } else { + highBits = mag[0] >>> nBits; + lowBits = (mag[0] << nBits2) | (mag[1] >>> nBits); + if (highBits == 0) { + highBits = lowBits; + lowBits = (mag[1] << nBits2) | (mag[2] >>> nBits); + } + } + + twiceSignifFloor = ((highBits & LONG_MASK) << 32) + | (lowBits & LONG_MASK); + + long signifFloor = twiceSignifFloor >> 1; + signifFloor &= DoubleConsts.SIGNIF_BIT_MASK; // remove the implied bit + + /* + * We round up if either the fractional part of signif is strictly + * greater than 0.5 (which is true if the 0.5 bit is set and any lower + * bit is set), or if the fractional part of signif is >= 0.5 and + * signifFloor is odd (which is true if both the 0.5 bit and the 1 bit + * are set). This is equivalent to the desired HALF_EVEN rounding. + */ + boolean increment = (twiceSignifFloor & 1) != 0 + && ((signifFloor & 1) != 0 || abs().getLowestSetBit() < shift); + long signifRounded = increment ? signifFloor + 1 : signifFloor; + long bits = (long) ((exponent + DoubleConsts.EXP_BIAS)) + << (DoubleConsts.SIGNIFICAND_WIDTH - 1); + bits += signifRounded; + /* + * If signifRounded == 2^53, we'd need to set all of the significand + * bits to zero and add 1 to the exponent. This is exactly the behavior + * we get from just adding signifRounded to bits directly. If the + * exponent is Double.MAX_EXPONENT, we round up (correctly) to + * Double.POSITIVE_INFINITY. + */ + bits |= signum & DoubleConsts.SIGN_BIT_MASK; + return Double.longBitsToDouble(bits); } /** diff --git a/jdk/test/java/math/BigInteger/PrimitiveConversionTests.java b/jdk/test/java/math/BigInteger/PrimitiveConversionTests.java new file mode 100644 index 00000000000..d459fe54cf0 --- /dev/null +++ b/jdk/test/java/math/BigInteger/PrimitiveConversionTests.java @@ -0,0 +1,105 @@ +/* + * Copyright (c) 1998, 2013, 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. + */ + +import static java.math.BigInteger.ONE; + +import java.math.BigInteger; +import java.util.ArrayList; +import java.util.Arrays; +import java.util.Collections; +import java.util.List; +import java.util.Random; + +/** + * @test + * @bug 7131192 + * @summary This test ensures that BigInteger.floatValue() and + * BigInteger.doubleValue() behave correctly. + * @author Louis Wasserman + */ +public class PrimitiveConversionTests { + static final List ALL_BIGINTEGER_CANDIDATES; + + static { + List samples = new ArrayList<>(); + // Now add values near 2^N for lots of values of N. + for (int exponent : Arrays.asList(0, 1, 2, 3, 4, 5, 6, 7, 31, 32, 33, + 34, 62, 63, 64, 65, 71, 72, 73, 79, 80, 81, 255, 256, 257, 511, + 512, 513, Double.MAX_EXPONENT - 1, Double.MAX_EXPONENT, + Double.MAX_EXPONENT + 1, 2000, 2001, 2002)) { + BigInteger x = ONE.shiftLeft(exponent); + for (BigInteger y : Arrays.asList(x, x.add(ONE), x.subtract(ONE))) { + samples.add(y); + samples.add(y.negate()); + } + } + + Random rng = new Random(1234567); + for (int i = 0; i < 2000; i++) { + samples.add(new BigInteger(rng.nextInt(2000), rng)); + } + + ALL_BIGINTEGER_CANDIDATES = Collections.unmodifiableList(samples); + } + + public static int testDoubleValue() { + int failures = 0; + for (BigInteger big : ALL_BIGINTEGER_CANDIDATES) { + double expected = Double.parseDouble(big.toString()); + double actual = big.doubleValue(); + + // should be bitwise identical + if (Double.doubleToRawLongBits(expected) != Double + .doubleToRawLongBits(actual)) { + System.out.println(big); + failures++; + } + } + return failures; + } + + public static int testFloatValue() { + int failures = 0; + for (BigInteger big : ALL_BIGINTEGER_CANDIDATES) { + float expected = Float.parseFloat(big.toString()); + float actual = big.floatValue(); + + // should be bitwise identical + if (Float.floatToRawIntBits(expected) != Float + .floatToRawIntBits(actual)) { + System.out.println(big + " " + expected + " " + actual); + failures++; + } + } + return failures; + } + + public static void main(String[] args) { + int failures = testDoubleValue(); + failures += testFloatValue(); + if (failures > 0) { + throw new RuntimeException("Incurred " + failures + + " failures while testing primitive conversions."); + } + } +} From feace4506dad6a9b8dd11190bb2ec2493ca58bf4 Mon Sep 17 00:00:00 2001 From: Naoto Sato Date: Fri, 21 Jun 2013 13:42:55 -0700 Subject: [PATCH 012/127] 6863624: java/util/Currency/PropertiesTest.sh writable check is incorrect Reviewed-by: alanb --- jdk/test/java/util/Currency/PropertiesTest.sh | 34 ++++++++++++------- .../java/util/Locale/LocaleProviders.java | 2 +- jdk/test/java/util/Locale/LocaleProviders.sh | 2 +- 3 files changed, 23 insertions(+), 15 deletions(-) diff --git a/jdk/test/java/util/Currency/PropertiesTest.sh b/jdk/test/java/util/Currency/PropertiesTest.sh index 6c16851062e..65ab89da2e0 100644 --- a/jdk/test/java/util/Currency/PropertiesTest.sh +++ b/jdk/test/java/util/Currency/PropertiesTest.sh @@ -23,7 +23,7 @@ # # @test -# @bug 6332666 7180362 8003846 +# @bug 6332666 6863624 7180362 8003846 # @summary tests the capability of replacing the currency data with user # specified currency properties file # @build PropertiesTest @@ -56,10 +56,15 @@ case "$OS" in PS=":" FS="/" ;; - Windows* | CYGWIN* ) + Windows* ) PS=";" FS="/" ;; + CYGWIN* ) + PS=";" + FS="/" + TESTJAVA=`cygpath -u ${TESTJAVA}` + ;; * ) echo "Unrecognized system!" exit 1; @@ -92,24 +97,27 @@ run PropertiesTest -c dump1 dump2 ${PROPS} # Dump built-in currency data + overrides in properties file copied into # JRE image. -# copy the test properties file +# Copy the test properties file. If testjava is not a typical jdk-image +# or testjava is not writable, make a private copy of it. COPIED=0 -if [ -w $TESTJAVA ] +if [ -w ${TESTJAVA}${FS}jre${FS}lib ] then WRITABLEJDK=$TESTJAVA -else - WRITABLEJDK=.${FS}testjava - cp -r $TESTJAVA $WRITABLEJDK - COPIED=1 -fi - -if [ -d ${WRITABLEJDK}${FS}jre ] -then PROPLOCATION=${WRITABLEJDK}${FS}jre${FS}lib else - PROPLOCATION=${WRITABLEJDK}${FS}lib + WRITABLEJDK=.${FS}testjava + if [ -d ${TESTJAVA}${FS}jre ] + then + PROPLOCATION=${WRITABLEJDK}${FS}jre${FS}lib + else + PROPLOCATION=${WRITABLEJDK}${FS}lib + fi + cp -r $TESTJAVA $WRITABLEJDK + chmod -R +w $WRITABLEJDK + COPIED=1 fi cp ${PROPS} $PROPLOCATION +echo "Properties location: ${PROPLOCATION}" # run echo '' diff --git a/jdk/test/java/util/Locale/LocaleProviders.java b/jdk/test/java/util/Locale/LocaleProviders.java index 22533f90670..811e78ff3ab 100644 --- a/jdk/test/java/util/Locale/LocaleProviders.java +++ b/jdk/test/java/util/Locale/LocaleProviders.java @@ -207,7 +207,7 @@ public class LocaleProviders { String jreResult = "\u5e73\u6210 16.11.03 (\u6c34) \u5348\u524d 11:53:47"; Locale l = new Locale("ja", "JP", "JP"); SimpleDateFormat sdf = new SimpleDateFormat("GGGG yyyy.MMM.dd '('E')' a hh:mm:ss", l); - sdf.setTimeZone(TimeZone.getTimeZone("PST")); + sdf.setTimeZone(TimeZone.getTimeZone("America/Los_Angeles")); String result = sdf.format(sampleDate); System.out.println(result); if (LocaleProviderAdapter.getAdapterPreference() diff --git a/jdk/test/java/util/Locale/LocaleProviders.sh b/jdk/test/java/util/Locale/LocaleProviders.sh index 7c238caafe6..bf8b7af2b32 100644 --- a/jdk/test/java/util/Locale/LocaleProviders.sh +++ b/jdk/test/java/util/Locale/LocaleProviders.sh @@ -24,7 +24,7 @@ # # @test # @bug 6336885 7196799 7197573 7198834 8000245 8000615 8001440 8010666 -# 8013086 8013233 8013903 +# 8013086 8013233 8013903 8015960 # @summary tests for "java.locale.providers" system property # @compile -XDignore.symbol.file LocaleProviders.java # @run shell/timeout=600 LocaleProviders.sh From a294d4b6a4bc3caa9b0538d62d03fe74dd576eb5 Mon Sep 17 00:00:00 2001 From: Chris Hegarty Date: Sat, 22 Jun 2013 08:14:54 +0100 Subject: [PATCH 013/127] 8017271: Crash may occur in java.net.DualStackPlainSocketImpl::initIDs due to unchecked values returned from JNI functions Reviewed-by: alanb, khazra --- jdk/src/solaris/native/java/net/PlainDatagramSocketImpl.c | 2 +- jdk/src/windows/native/java/net/DualStackPlainSocketImpl.c | 1 + 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/jdk/src/solaris/native/java/net/PlainDatagramSocketImpl.c b/jdk/src/solaris/native/java/net/PlainDatagramSocketImpl.c index 9ef598460b6..981bf534a66 100644 --- a/jdk/src/solaris/native/java/net/PlainDatagramSocketImpl.c +++ b/jdk/src/solaris/native/java/net/PlainDatagramSocketImpl.c @@ -50,7 +50,7 @@ #ifndef IP_MULTICAST_ALL #define IP_MULTICAST_ALL 49 #endif -#endif // __linux__` +#endif // __linux__ #ifndef IPTOS_TOS_MASK #define IPTOS_TOS_MASK 0x1e diff --git a/jdk/src/windows/native/java/net/DualStackPlainSocketImpl.c b/jdk/src/windows/native/java/net/DualStackPlainSocketImpl.c index 2c796edab1b..37bd53d76c0 100644 --- a/jdk/src/windows/native/java/net/DualStackPlainSocketImpl.c +++ b/jdk/src/windows/native/java/net/DualStackPlainSocketImpl.c @@ -43,6 +43,7 @@ JNIEXPORT void JNICALL Java_java_net_DualStackPlainSocketImpl_initIDs (JNIEnv *env, jclass clazz) { jclass cls = (*env)->FindClass(env, "java/net/InetSocketAddress"); + CHECK_NULL(cls); isa_class = (*env)->NewGlobalRef(env, cls); isa_ctorID = (*env)->GetMethodID(env, cls, "", "(Ljava/net/InetAddress;I)V"); From 14ddb9177d5afde479fc5654bb59d3066b295be8 Mon Sep 17 00:00:00 2001 From: Andreas Rieber Date: Sat, 22 Jun 2013 08:20:11 +0100 Subject: [PATCH 014/127] 7157360: HttpURLConnection: HTTP method DELETE doesn't support output Reviewed-by: chegar --- .../sun/net/www/http/PosterOutputStream.java | 4 +- .../www/protocol/http/HttpURLConnection.java | 7 +- .../http/HttpURLConnection/PostOnDelete.java | 118 ++++++++++++++++++ 3 files changed, 123 insertions(+), 6 deletions(-) create mode 100644 jdk/test/sun/net/www/http/HttpURLConnection/PostOnDelete.java diff --git a/jdk/src/share/classes/sun/net/www/http/PosterOutputStream.java b/jdk/src/share/classes/sun/net/www/http/PosterOutputStream.java index eedd77ec193..df2dc8efc87 100644 --- a/jdk/src/share/classes/sun/net/www/http/PosterOutputStream.java +++ b/jdk/src/share/classes/sun/net/www/http/PosterOutputStream.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2001, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2001, 2013, 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 @@ -30,7 +30,7 @@ import java.net.*; /** * Instances of this class are returned to applications for the purpose of - * sending user data for a HTTP POST or PUT request. This class is used + * sending user data for a HTTP request (excluding TRACE). This class is used * when the content-length will be specified in the header of the request. * The semantics of ByteArrayOutputStream are extended so that * when close() is called, it is no longer possible to write diff --git a/jdk/src/share/classes/sun/net/www/protocol/http/HttpURLConnection.java b/jdk/src/share/classes/sun/net/www/protocol/http/HttpURLConnection.java index 76745e0c022..201e236210c 100644 --- a/jdk/src/share/classes/sun/net/www/protocol/http/HttpURLConnection.java +++ b/jdk/src/share/classes/sun/net/www/protocol/http/HttpURLConnection.java @@ -1167,7 +1167,7 @@ public class HttpURLConnection extends java.net.HttpURLConnection { /* * Allowable input/output sequences: - * [interpreted as POST/PUT] + * [interpreted as request entity] * - get output, [write output,] get input, [read input] * - get output, [write output] * [interpreted as GET] @@ -1209,9 +1209,8 @@ public class HttpURLConnection extends java.net.HttpURLConnection { if (method.equals("GET")) { method = "POST"; // Backward compatibility } - if (!"POST".equals(method) && !"PUT".equals(method) && - "http".equals(url.getProtocol())) { - throw new ProtocolException("HTTP method " + method + + if ("TRACE".equals(method) && "http".equals(url.getProtocol())) { + throw new ProtocolException("HTTP method TRACE" + " doesn't support output"); } diff --git a/jdk/test/sun/net/www/http/HttpURLConnection/PostOnDelete.java b/jdk/test/sun/net/www/http/HttpURLConnection/PostOnDelete.java new file mode 100644 index 00000000000..07d353cba85 --- /dev/null +++ b/jdk/test/sun/net/www/http/HttpURLConnection/PostOnDelete.java @@ -0,0 +1,118 @@ +/* + * Copyright (c) 2013, 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. + */ + +import com.sun.net.httpserver.*; +import java.io.IOException; +import java.io.InputStream; +import java.io.OutputStream; +import java.net.*; + +/* + * @test + * @bug 7157360 + * @summary HttpURLConnection: HTTP method DELETE doesn't support output + */ +public class PostOnDelete { + + /* string to send */ + private static String msg = "Hello Server"; + /* length of the string to verify */ + private int len = msg.length(); + + public static void main(String[] args) throws Exception { + new PostOnDelete().runTest(); + } + + public void runTest() throws Exception { + Server s = null; + try { + s = new Server(); + s.startServer(); + URL url = new URL("http://localhost:" + s.getPort()); + HttpURLConnection urlConnection = (HttpURLConnection)url.openConnection(); + urlConnection.setRequestMethod("DELETE"); + urlConnection.setDoOutput(true); + OutputStream os = urlConnection.getOutputStream(); + os.write(msg.getBytes()); + os.close(); + int code = urlConnection.getResponseCode(); + + if (code != 200) { + throw new RuntimeException("Request entity for DELETE failed!"); + } + } finally { + s.stopServer(); + } + } + + class Server { + HttpServer server; + + public void startServer() { + InetSocketAddress addr = new InetSocketAddress(0); + try { + server = HttpServer.create(addr, 0); + } catch (IOException ioe) { + throw new RuntimeException("Server could not be created"); + } + + server.createContext("/", new EmptyPathHandler()); + server.start(); + } + + public int getPort() { + return server.getAddress().getPort(); + } + + public void stopServer() { + server.stop(0); + } + } + + class EmptyPathHandler implements HttpHandler { + + @Override + public void handle(HttpExchange exchange) throws IOException { + String requestMethod = exchange.getRequestMethod(); + + if (requestMethod.equalsIgnoreCase("DELETE")) { + InputStream is = exchange.getRequestBody(); + + int count = 0; + while (is.read() != -1) { + count++; + } + is.close(); + + Headers responseHeaders = exchange.getResponseHeaders(); + responseHeaders.set("Content-Type", "text/plain"); + exchange.sendResponseHeaders((count == len) ? 200 : 400, 0); + OutputStream os = exchange.getResponseBody(); + String str = "Hello from server!"; + os.write(str.getBytes()); + os.flush(); + os.close(); + } + } + } +} From cb9be51085548930d0be4996395610ebd468b9cf Mon Sep 17 00:00:00 2001 From: Weijun Wang Date: Mon, 24 Jun 2013 16:25:28 +0800 Subject: [PATCH 015/127] 8017453: ReplayCache tests fail on multiple platforms Reviewed-by: xuelei --- jdk/test/sun/security/krb5/auto/ReplayCacheExpunge.java | 3 +++ jdk/test/sun/security/krb5/auto/ReplayCacheTestProc.java | 6 ++++++ 2 files changed, 9 insertions(+) diff --git a/jdk/test/sun/security/krb5/auto/ReplayCacheExpunge.java b/jdk/test/sun/security/krb5/auto/ReplayCacheExpunge.java index 8c00d809517..da68ec3b7e1 100644 --- a/jdk/test/sun/security/krb5/auto/ReplayCacheExpunge.java +++ b/jdk/test/sun/security/krb5/auto/ReplayCacheExpunge.java @@ -41,6 +41,9 @@ public class ReplayCacheExpunge { static final Random rand = new Random(); public static void main(String[] args) throws Exception { + // Make sure clockskew is default value + System.setProperty("java.security.krb5.conf", "nothing"); + int count = Integer.parseInt(args[0]); ReplayCache cache = ReplayCache.getInstance("dfl:./"); AuthTimeWithHash a1 = diff --git a/jdk/test/sun/security/krb5/auto/ReplayCacheTestProc.java b/jdk/test/sun/security/krb5/auto/ReplayCacheTestProc.java index a9ee283c02a..bbd2cb68495 100644 --- a/jdk/test/sun/security/krb5/auto/ReplayCacheTestProc.java +++ b/jdk/test/sun/security/krb5/auto/ReplayCacheTestProc.java @@ -71,6 +71,12 @@ public class ReplayCacheTestProc { int mode = 0; // native(1), random(0), java(-1) boolean random = true; // random experiments choreograph + // Do not test interop with native GSS on some platforms + String os = System.getProperty("os.name", "???"); + if (!os.startsWith("SunOS") && !os.startsWith("Linux")) { + mode = -1; + } + try { Class clazz = Class.forName( "com.sun.security.auth.module.UnixSystem"); From fbf2d36771451cfca53e16d35ab9e3a6af007ed0 Mon Sep 17 00:00:00 2001 From: Alan Bateman Date: Mon, 24 Jun 2013 11:26:51 +0100 Subject: [PATCH 016/127] 8017477: Remove TimeZone.DisplayNames, no longer used Reviewed-by: okutsu --- jdk/src/share/classes/java/util/TimeZone.java | 11 ----------- 1 file changed, 11 deletions(-) diff --git a/jdk/src/share/classes/java/util/TimeZone.java b/jdk/src/share/classes/java/util/TimeZone.java index b49d8d210ef..ba4abb91f2c 100644 --- a/jdk/src/share/classes/java/util/TimeZone.java +++ b/jdk/src/share/classes/java/util/TimeZone.java @@ -419,17 +419,6 @@ abstract public class TimeZone implements Serializable, Cloneable { return ZoneInfoFile.toCustomID(offset); } - private static class DisplayNames { - // Cache for managing display names per timezone per locale - // The structure is: - // Map(key=id, value=SoftReference(Map(key=locale, value=displaynames))) - private static final Map>> CACHE = - new ConcurrentHashMap<>(); - - private DisplayNames() { - } - } - private static String[] getDisplayNames(String id, Locale locale) { return TimeZoneNameUtility.retrieveDisplayNames(id, locale); } From 650898839b024902567d67d2b0171544a56e7678 Mon Sep 17 00:00:00 2001 From: Naoto Sato Date: Mon, 24 Jun 2013 16:21:32 -0700 Subject: [PATCH 017/127] 8017468: typo in javadoc: " ResourceBunlde " Reviewed-by: okutsu --- jdk/src/share/classes/java/util/spi/LocaleServiceProvider.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/jdk/src/share/classes/java/util/spi/LocaleServiceProvider.java b/jdk/src/share/classes/java/util/spi/LocaleServiceProvider.java index b59dba1978c..c490dbadf85 100644 --- a/jdk/src/share/classes/java/util/spi/LocaleServiceProvider.java +++ b/jdk/src/share/classes/java/util/spi/LocaleServiceProvider.java @@ -94,7 +94,7 @@ import java.util.Locale; * supports the requested locale, the methods go through a list of candidate * locales and repeat the availability check for each until a match is found. * The algorithm used for creating a list of candidate locales is same as - * the one used by ResourceBunlde by default (see + * the one used by ResourceBundle by default (see * {@link java.util.ResourceBundle.Control#getCandidateLocales getCandidateLocales} * for the details). Even if a locale is resolved from the candidate list, * methods that return requested objects or names are invoked with the original From 9c0605b8e626d810e49bc0b289257096005a1edd Mon Sep 17 00:00:00 2001 From: Brian Burkhalter Date: Mon, 24 Jun 2013 14:17:14 -0700 Subject: [PATCH 018/127] 6469160: (fmt) general (%g) formatting of zero (0.0) with precision 0 or 1 throws ArrayOutOfBoundsException For zero value ensure than an unpadded zero character is passed to Formatter.addZeros() Reviewed-by: iris, darcy --- .../share/classes/java/util/Formatter.java | 19 +++++++++++++++---- .../classes/sun/misc/FloatingDecimal.java | 2 +- .../java/util/Formatter/Basic-X.java.template | 7 +++++++ jdk/test/java/util/Formatter/Basic.java | 2 +- .../java/util/Formatter/BasicBigDecimal.java | 7 +++++++ jdk/test/java/util/Formatter/BasicDouble.java | 16 ++++++++++++++++ .../util/Formatter/BasicDoubleObject.java | 16 ++++++++++++++++ jdk/test/java/util/Formatter/BasicFloat.java | 16 ++++++++++++++++ .../java/util/Formatter/BasicFloatObject.java | 16 ++++++++++++++++ 9 files changed, 95 insertions(+), 6 deletions(-) diff --git a/jdk/src/share/classes/java/util/Formatter.java b/jdk/src/share/classes/java/util/Formatter.java index 11020fdc411..7906c763fe2 100644 --- a/jdk/src/share/classes/java/util/Formatter.java +++ b/jdk/src/share/classes/java/util/Formatter.java @@ -3297,18 +3297,29 @@ public final class Formatter implements Closeable, Flushable { else if (precision == 0) prec = 1; - FormattedFloatingDecimal fd + char[] exp; + char[] mant; + int expRounded; + if (value == 0.0) { + exp = null; + mant = new char[] {'0'}; + expRounded = 0; + } else { + FormattedFloatingDecimal fd = FormattedFloatingDecimal.valueOf(value, prec, FormattedFloatingDecimal.Form.GENERAL); + exp = fd.getExponent(); + mant = fd.getMantissa(); + expRounded = fd.getExponentRounded(); + } - char[] exp = fd.getExponent(); if (exp != null) { prec -= 1; } else { - prec = prec - (value == 0 ? 0 : fd.getExponentRounded()) - 1; + prec -= expRounded + 1; } - char[] mant = addZeros(fd.getMantissa(), prec); + mant = addZeros(mant, prec); // If the precision is zero and the '#' flag is set, add the // requested decimal point. if (f.contains(Flags.ALTERNATE) && (prec == 0)) diff --git a/jdk/src/share/classes/sun/misc/FloatingDecimal.java b/jdk/src/share/classes/sun/misc/FloatingDecimal.java index 0daaaadc496..ddd8790bc14 100644 --- a/jdk/src/share/classes/sun/misc/FloatingDecimal.java +++ b/jdk/src/share/classes/sun/misc/FloatingDecimal.java @@ -1045,7 +1045,7 @@ public class FloatingDecimal{ this.nDigits = n; } - /* + /** * Takes a FloatingDecimal, which we presumably just scanned in, * and finds out what its value is, as a double. * diff --git a/jdk/test/java/util/Formatter/Basic-X.java.template b/jdk/test/java/util/Formatter/Basic-X.java.template index 831c49212f0..a2d586a8958 100644 --- a/jdk/test/java/util/Formatter/Basic-X.java.template +++ b/jdk/test/java/util/Formatter/Basic-X.java.template @@ -1177,6 +1177,13 @@ public class Basic$Type$ extends Basic { test("%.3G", "1.00E-05", recip(create(100000.0))); test("%.3G", "-1.00E-05", recip(create(-100000.0))); + test("%.1g", "-0", -0.0); + test("%3.0g", " -0", -0.0); + test("%.1g", "0", 0.0); + test("%3.0g", " 0", 0.0); + test("%.1g", "0", +0.0); + test("%3.0g", " 0", +0.0); + test("%3.0g", "1e-06", 0.000001); test("%3.0g", "1e-05", 0.00001); test("%3.0g", "1e-05", 0.0000099); diff --git a/jdk/test/java/util/Formatter/Basic.java b/jdk/test/java/util/Formatter/Basic.java index 7afed1d5b4d..79123a19bca 100644 --- a/jdk/test/java/util/Formatter/Basic.java +++ b/jdk/test/java/util/Formatter/Basic.java @@ -25,7 +25,7 @@ * @summary Unit test for formatter * @bug 4906370 4962433 4973103 4989961 5005818 5031150 4970931 4989491 5002937 * 5005104 5007745 5061412 5055180 5066788 5088703 6317248 6318369 6320122 - * 6344623 6369500 6534606 6282094 6286592 6476425 5063507 + * 6344623 6369500 6534606 6282094 6286592 6476425 5063507 6469160 * * @run shell/timeout=240 Basic.sh */ diff --git a/jdk/test/java/util/Formatter/BasicBigDecimal.java b/jdk/test/java/util/Formatter/BasicBigDecimal.java index 6f36201aa34..9549441da87 100644 --- a/jdk/test/java/util/Formatter/BasicBigDecimal.java +++ b/jdk/test/java/util/Formatter/BasicBigDecimal.java @@ -1177,6 +1177,13 @@ public class BasicBigDecimal extends Basic { test("%.3G", "1.00E-05", recip(create(100000.0))); test("%.3G", "-1.00E-05", recip(create(-100000.0))); + test("%.1g", "-0", -0.0); + test("%3.0g", " -0", -0.0); + test("%.1g", "0", 0.0); + test("%3.0g", " 0", 0.0); + test("%.1g", "0", +0.0); + test("%3.0g", " 0", +0.0); + test("%3.0g", "1e-06", 0.000001); test("%3.0g", "1e-05", 0.00001); test("%3.0g", "1e-05", 0.0000099); diff --git a/jdk/test/java/util/Formatter/BasicDouble.java b/jdk/test/java/util/Formatter/BasicDouble.java index d33eb4d6c5f..4c86c29c198 100644 --- a/jdk/test/java/util/Formatter/BasicDouble.java +++ b/jdk/test/java/util/Formatter/BasicDouble.java @@ -1113,6 +1113,15 @@ public class BasicDouble extends Basic { + + + + + + + + + @@ -1168,6 +1177,13 @@ public class BasicDouble extends Basic { test("%.3G", "1.00E-05", recip(create(100000.0))); test("%.3G", "-1.00E-05", recip(create(-100000.0))); + test("%.1g", "-0", -0.0); + test("%3.0g", " -0", -0.0); + test("%.1g", "0", 0.0); + test("%3.0g", " 0", 0.0); + test("%.1g", "0", +0.0); + test("%3.0g", " 0", +0.0); + test("%3.0g", "1e-06", 0.000001); test("%3.0g", "1e-05", 0.00001); test("%3.0g", "1e-05", 0.0000099); diff --git a/jdk/test/java/util/Formatter/BasicDoubleObject.java b/jdk/test/java/util/Formatter/BasicDoubleObject.java index 63cec1afe6a..674bf2beffd 100644 --- a/jdk/test/java/util/Formatter/BasicDoubleObject.java +++ b/jdk/test/java/util/Formatter/BasicDoubleObject.java @@ -1113,6 +1113,15 @@ public class BasicDoubleObject extends Basic { + + + + + + + + + @@ -1168,6 +1177,13 @@ public class BasicDoubleObject extends Basic { test("%.3G", "1.00E-05", recip(create(100000.0))); test("%.3G", "-1.00E-05", recip(create(-100000.0))); + test("%.1g", "-0", -0.0); + test("%3.0g", " -0", -0.0); + test("%.1g", "0", 0.0); + test("%3.0g", " 0", 0.0); + test("%.1g", "0", +0.0); + test("%3.0g", " 0", +0.0); + test("%3.0g", "1e-06", 0.000001); test("%3.0g", "1e-05", 0.00001); test("%3.0g", "1e-05", 0.0000099); diff --git a/jdk/test/java/util/Formatter/BasicFloat.java b/jdk/test/java/util/Formatter/BasicFloat.java index d4e3d7434ca..7ed68c3eddd 100644 --- a/jdk/test/java/util/Formatter/BasicFloat.java +++ b/jdk/test/java/util/Formatter/BasicFloat.java @@ -1096,6 +1096,15 @@ public class BasicFloat extends Basic { + + + + + + + + + @@ -1168,6 +1177,13 @@ public class BasicFloat extends Basic { test("%.3G", "1.00E-05", recip(create(100000.0))); test("%.3G", "-1.00E-05", recip(create(-100000.0))); + test("%.1g", "-0", -0.0); + test("%3.0g", " -0", -0.0); + test("%.1g", "0", 0.0); + test("%3.0g", " 0", 0.0); + test("%.1g", "0", +0.0); + test("%3.0g", " 0", +0.0); + test("%3.0g", "1e-06", 0.000001); test("%3.0g", "1e-05", 0.00001); test("%3.0g", "1e-05", 0.0000099); diff --git a/jdk/test/java/util/Formatter/BasicFloatObject.java b/jdk/test/java/util/Formatter/BasicFloatObject.java index e0deba7050e..db77cef27b3 100644 --- a/jdk/test/java/util/Formatter/BasicFloatObject.java +++ b/jdk/test/java/util/Formatter/BasicFloatObject.java @@ -1129,6 +1129,15 @@ public class BasicFloatObject extends Basic { + + + + + + + + + @@ -1168,6 +1177,13 @@ public class BasicFloatObject extends Basic { test("%.3G", "1.00E-05", recip(create(100000.0))); test("%.3G", "-1.00E-05", recip(create(-100000.0))); + test("%.1g", "-0", -0.0); + test("%3.0g", " -0", -0.0); + test("%.1g", "0", 0.0); + test("%3.0g", " 0", 0.0); + test("%.1g", "0", +0.0); + test("%3.0g", " 0", +0.0); + test("%3.0g", "1e-06", 0.000001); test("%3.0g", "1e-05", 0.00001); test("%3.0g", "1e-05", 0.0000099); From e751cc77ad5efb791a56a2f1980bb459b00df8c0 Mon Sep 17 00:00:00 2001 From: Joe Darcy Date: Mon, 24 Jun 2013 23:40:31 -0700 Subject: [PATCH 019/127] 8017550: Fix doclint issues in java.lang and subpackages Reviewed-by: alanb, chegar --- jdk/src/share/classes/java/lang/Boolean.java | 6 +++--- jdk/src/share/classes/java/lang/Byte.java | 6 +++--- jdk/src/share/classes/java/lang/Class.java | 4 ++++ jdk/src/share/classes/java/lang/Double.java | 12 +++++------- jdk/src/share/classes/java/lang/Float.java | 4 ++-- jdk/src/share/classes/java/lang/Integer.java | 13 +++++++++++++ jdk/src/share/classes/java/lang/Long.java | 16 ++++++++++++++-- jdk/src/share/classes/java/lang/Package.java | 14 +++++++------- jdk/src/share/classes/java/lang/Runtime.java | 6 +++--- jdk/src/share/classes/java/lang/Short.java | 7 ++++--- jdk/src/share/classes/java/lang/StrictMath.java | 4 +++- .../classes/java/lang/SuppressWarnings.java | 1 + jdk/src/share/classes/java/lang/System.java | 2 ++ .../classes/java/lang/annotation/Annotation.java | 3 ++- .../classes/java/lang/annotation/Repeatable.java | 3 ++- .../classes/java/lang/annotation/Retention.java | 4 ++++ .../classes/java/lang/annotation/Target.java | 6 ++++++ .../java/lang/reflect/AnnotatedElement.java | 5 +++++ .../classes/java/lang/reflect/Executable.java | 13 +++++++++++++ .../share/classes/java/lang/reflect/Field.java | 2 ++ .../classes/java/lang/reflect/Parameter.java | 2 ++ .../classes/java/lang/reflect/TypeVariable.java | 1 + 22 files changed, 101 insertions(+), 33 deletions(-) diff --git a/jdk/src/share/classes/java/lang/Boolean.java b/jdk/src/share/classes/java/lang/Boolean.java index fbbeba72ce0..a9293ba1459 100644 --- a/jdk/src/share/classes/java/lang/Boolean.java +++ b/jdk/src/share/classes/java/lang/Boolean.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1994, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1994, 2013, 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 @@ -205,9 +205,9 @@ public final class Boolean implements java.io.Serializable, * Returns a hash code for a {@code boolean} value; compatible with * {@code Boolean.hashCode()}. * - * @since 1.8 - * + * @param value the value to hash * @return a hash code value for a {@code boolean} value. + * @since 1.8 */ public static int hashCode(boolean value) { return value ? 1231 : 1237; diff --git a/jdk/src/share/classes/java/lang/Byte.java b/jdk/src/share/classes/java/lang/Byte.java index 43a558ade43..275e33de5a7 100644 --- a/jdk/src/share/classes/java/lang/Byte.java +++ b/jdk/src/share/classes/java/lang/Byte.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2013, 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 @@ -398,9 +398,9 @@ public final class Byte extends Number implements Comparable { * Returns a hash code for a {@code byte} value; compatible with * {@code Byte.hashCode()}. * - * @since 1.8 - * + * @param value the value to hash * @return a hash code value for a {@code byte} value. + * @since 1.8 */ public static int hashCode(byte value) { return (int)value; diff --git a/jdk/src/share/classes/java/lang/Class.java b/jdk/src/share/classes/java/lang/Class.java index 113a2b39717..df4d457367d 100644 --- a/jdk/src/share/classes/java/lang/Class.java +++ b/jdk/src/share/classes/java/lang/Class.java @@ -3250,6 +3250,8 @@ public final class Class implements java.io.Serializable, * could not be checked at runtime (because generic types are implemented * by erasure). * + * @param the type to cast this class object to + * @param clazz the class of the type to cast this class object to * @return this {@code Class} object, cast to represent a subclass of * the specified class object. * @throws ClassCastException if this {@code Class} object does not @@ -3405,6 +3407,7 @@ public final class Class implements java.io.Serializable, * If this Class represents either the Object class, an interface type, an * array type, a primitive type, or void, the return value is null. * + * @return an object representing the superclass * @since 1.8 */ public AnnotatedType getAnnotatedSuperclass() { @@ -3436,6 +3439,7 @@ public final class Class implements java.io.Serializable, * If this Class represents either the Object class, an array type, a * primitive type, or void, the return value is an array of length 0. * + * @return an array representing the superinterfaces * @since 1.8 */ public AnnotatedType[] getAnnotatedInterfaces() { diff --git a/jdk/src/share/classes/java/lang/Double.java b/jdk/src/share/classes/java/lang/Double.java index 3f0e2cddd0f..113cdf81a4c 100644 --- a/jdk/src/share/classes/java/lang/Double.java +++ b/jdk/src/share/classes/java/lang/Double.java @@ -453,8 +453,7 @@ public final class Double extends Number implements Comparable { * a {@code NumberFormatException} be thrown, the regular * expression below can be used to screen the input string: * - * - *
+     * 
{@code
      *  final String Digits     = "(\\p{Digit}+)";
      *  final String HexDigits  = "(\\p{XDigit}+)";
      *  // an exponent is 'e' or 'E' followed by an optionally
@@ -474,7 +473,7 @@ public final class Double extends Number implements Comparable {
      *       // in addition to strings of floating-point literals, the
      *       // two sub-patterns below are simplifications of the grammar
      *       // productions from section 3.10.2 of
-     *       // The Java™ Language Specification.
+     *       // The Java Language Specification.
      *
      *       // Digits ._opt Digits_opt ExponentPart_opt FloatTypeSuffix_opt
      *       "((("+Digits+"(\\.)?("+Digits+"?)("+Exp+")?)|"+
@@ -499,8 +498,7 @@ public final class Double extends Number implements Comparable {
      *  else {
      *      // Perform suitable alternative action
      *  }
-     * 
- *
+ * }
* * @param s the string to be parsed. * @return a {@code Double} object holding the value @@ -756,9 +754,9 @@ public final class Double extends Number implements Comparable { * Returns a hash code for a {@code double} value; compatible with * {@code Double.hashCode()}. * - * @since 1.8 - * + * @param value the value to hash * @return a hash code value for a {@code double} value. + * @since 1.8 */ public static int hashCode(double value) { long bits = doubleToLongBits(value); diff --git a/jdk/src/share/classes/java/lang/Float.java b/jdk/src/share/classes/java/lang/Float.java index e46dff02a3b..2f2b6b22444 100644 --- a/jdk/src/share/classes/java/lang/Float.java +++ b/jdk/src/share/classes/java/lang/Float.java @@ -664,9 +664,9 @@ public final class Float extends Number implements Comparable { * Returns a hash code for a {@code float} value; compatible with * {@code Float.hashCode()}. * - * @since 1.8 - * + * @param value the value to hash * @return a hash code value for a {@code float} value. + * @since 1.8 */ public static int hashCode(float value) { return floatToIntBits(value); diff --git a/jdk/src/share/classes/java/lang/Integer.java b/jdk/src/share/classes/java/lang/Integer.java index 4a08f4740ec..7ee4b48855e 100644 --- a/jdk/src/share/classes/java/lang/Integer.java +++ b/jdk/src/share/classes/java/lang/Integer.java @@ -951,6 +951,7 @@ public final class Integer extends Number implements Comparable { * Returns a hash code for a {@code int} value; compatible with * {@code Integer.hashCode()}. * + * @param value the value to hash * @since 1.8 * * @return a hash code value for a {@code int} value. @@ -1336,6 +1337,7 @@ public final class Integer extends Number implements Comparable { * one-bits in its two's complement binary representation, that is, if it * is equal to zero. * + * @param i the value whose highest one bit is to be computed * @return an {@code int} value with a single one-bit, in the position * of the highest-order one-bit in the specified value, or zero if * the specified value is itself equal to zero. @@ -1358,6 +1360,7 @@ public final class Integer extends Number implements Comparable { * one-bits in its two's complement binary representation, that is, if it * is equal to zero. * + * @param i the value whose lowest one bit is to be computed * @return an {@code int} value with a single one-bit, in the position * of the lowest-order one-bit in the specified value, or zero if * the specified value is itself equal to zero. @@ -1382,6 +1385,7 @@ public final class Integer extends Number implements Comparable { *
  • ceil(log2(x)) = {@code 32 - numberOfLeadingZeros(x - 1)} * * + * @param i the value whose number of leading zeros is to be computed * @return the number of zero bits preceding the highest-order * ("leftmost") one-bit in the two's complement binary representation * of the specified {@code int} value, or 32 if the value @@ -1408,6 +1412,7 @@ public final class Integer extends Number implements Comparable { * one-bits in its two's complement representation, in other words if it is * equal to zero. * + * @param i the value whose number of trailing zeros is to be computed * @return the number of zero bits following the lowest-order ("rightmost") * one-bit in the two's complement binary representation of the * specified {@code int} value, or 32 if the value is equal @@ -1431,6 +1436,7 @@ public final class Integer extends Number implements Comparable { * representation of the specified {@code int} value. This function is * sometimes referred to as the population count. * + * @param i the value whose bits are to be counted * @return the number of one-bits in the two's complement binary * representation of the specified {@code int} value. * @since 1.5 @@ -1458,6 +1464,8 @@ public final class Integer extends Number implements Comparable { * ignored, even if the distance is negative: {@code rotateLeft(val, * distance) == rotateLeft(val, distance & 0x1F)}. * + * @param i the value whose bits are to be rotated left + * @param distance the number of bit positions to rotate left * @return the value obtained by rotating the two's complement binary * representation of the specified {@code int} value left by the * specified number of bits. @@ -1480,6 +1488,8 @@ public final class Integer extends Number implements Comparable { * ignored, even if the distance is negative: {@code rotateRight(val, * distance) == rotateRight(val, distance & 0x1F)}. * + * @param i the value whose bits are to be rotated right + * @param distance the number of bit positions to rotate right * @return the value obtained by rotating the two's complement binary * representation of the specified {@code int} value right by the * specified number of bits. @@ -1494,6 +1504,7 @@ public final class Integer extends Number implements Comparable { * two's complement binary representation of the specified {@code int} * value. * + * @param i the value to be reversed * @return the value obtained by reversing order of the bits in the * specified {@code int} value. * @since 1.5 @@ -1513,6 +1524,7 @@ public final class Integer extends Number implements Comparable { * return value is -1 if the specified value is negative; 0 if the * specified value is zero; and 1 if the specified value is positive.) * + * @param i the value whose signum is to be computed * @return the signum function of the specified {@code int} value. * @since 1.5 */ @@ -1525,6 +1537,7 @@ public final class Integer extends Number implements Comparable { * Returns the value obtained by reversing the order of the bytes in the * two's complement representation of the specified {@code int} value. * + * @param i the value whose bytes are to be reversed * @return the value obtained by reversing the bytes in the specified * {@code int} value. * @since 1.5 diff --git a/jdk/src/share/classes/java/lang/Long.java b/jdk/src/share/classes/java/lang/Long.java index 80967aca5de..bfaf0c4412f 100644 --- a/jdk/src/share/classes/java/lang/Long.java +++ b/jdk/src/share/classes/java/lang/Long.java @@ -1053,9 +1053,9 @@ public final class Long extends Number implements Comparable { * Returns a hash code for a {@code long} value; compatible with * {@code Long.hashCode()}. * - * @since 1.8 - * + * @param value the value to hash * @return a hash code value for a {@code long} value. + * @since 1.8 */ public static int hashCode(long value) { return (int)(value ^ (value >>> 32)); @@ -1357,6 +1357,7 @@ public final class Long extends Number implements Comparable { * one-bits in its two's complement binary representation, that is, if it * is equal to zero. * + * @param i the value whose highest one bit is to be computed * @return a {@code long} value with a single one-bit, in the position * of the highest-order one-bit in the specified value, or zero if * the specified value is itself equal to zero. @@ -1380,6 +1381,7 @@ public final class Long extends Number implements Comparable { * one-bits in its two's complement binary representation, that is, if it * is equal to zero. * + * @param i the value whose lowest one bit is to be computed * @return a {@code long} value with a single one-bit, in the position * of the lowest-order one-bit in the specified value, or zero if * the specified value is itself equal to zero. @@ -1404,6 +1406,7 @@ public final class Long extends Number implements Comparable { *
  • ceil(log2(x)) = {@code 64 - numberOfLeadingZeros(x - 1)} * * + * @param i the value whose number of leading zeros is to be computed * @return the number of zero bits preceding the highest-order * ("leftmost") one-bit in the two's complement binary representation * of the specified {@code long} value, or 64 if the value @@ -1432,6 +1435,7 @@ public final class Long extends Number implements Comparable { * one-bits in its two's complement representation, in other words if it is * equal to zero. * + * @param i the value whose number of trailing zeros is to be computed * @return the number of zero bits following the lowest-order ("rightmost") * one-bit in the two's complement binary representation of the * specified {@code long} value, or 64 if the value is equal @@ -1456,6 +1460,7 @@ public final class Long extends Number implements Comparable { * representation of the specified {@code long} value. This function is * sometimes referred to as the population count. * + * @param i the value whose bits are to be counted * @return the number of one-bits in the two's complement binary * representation of the specified {@code long} value. * @since 1.5 @@ -1484,6 +1489,8 @@ public final class Long extends Number implements Comparable { * ignored, even if the distance is negative: {@code rotateLeft(val, * distance) == rotateLeft(val, distance & 0x3F)}. * + * @param i the value whose bits are to be rotated left + * @param distance the number of bit positions to rotate left * @return the value obtained by rotating the two's complement binary * representation of the specified {@code long} value left by the * specified number of bits. @@ -1506,6 +1513,8 @@ public final class Long extends Number implements Comparable { * ignored, even if the distance is negative: {@code rotateRight(val, * distance) == rotateRight(val, distance & 0x3F)}. * + * @param i the value whose bits are to be rotated right + * @param distance the number of bit positions to rotate right * @return the value obtained by rotating the two's complement binary * representation of the specified {@code long} value right by the * specified number of bits. @@ -1520,6 +1529,7 @@ public final class Long extends Number implements Comparable { * two's complement binary representation of the specified {@code long} * value. * + * @param i the value to be reversed * @return the value obtained by reversing order of the bits in the * specified {@code long} value. * @since 1.5 @@ -1540,6 +1550,7 @@ public final class Long extends Number implements Comparable { * return value is -1 if the specified value is negative; 0 if the * specified value is zero; and 1 if the specified value is positive.) * + * @param i the value whose signum is to be computed * @return the signum function of the specified {@code long} value. * @since 1.5 */ @@ -1552,6 +1563,7 @@ public final class Long extends Number implements Comparable { * Returns the value obtained by reversing the order of the bytes in the * two's complement representation of the specified {@code long} value. * + * @param i the value whose bytes are to be reversed * @return the value obtained by reversing the bytes in the specified * {@code long} value. * @since 1.5 diff --git a/jdk/src/share/classes/java/lang/Package.java b/jdk/src/share/classes/java/lang/Package.java index d22e3ece462..e55d72bc038 100644 --- a/jdk/src/share/classes/java/lang/Package.java +++ b/jdk/src/share/classes/java/lang/Package.java @@ -77,18 +77,18 @@ import java.lang.annotation.Annotation; * by the following formal grammar: *
    *
    - *
    SpecificationVersion: - *
    Digits RefinedVersionopt + *
    SpecificationVersion: + *
    Digits RefinedVersionopt - *

    RefinedVersion: + *
    RefinedVersion: *
    {@code .} Digits *
    {@code .} Digits RefinedVersion * - *

    Digits: - *
    Digit - *
    Digits + *
    Digits: + *
    Digit + *
    Digits * - *

    Digit: + *
    Digit: *
    any character for which {@link Character#isDigit} returns {@code true}, * e.g. 0, 1, 2, ... *
    diff --git a/jdk/src/share/classes/java/lang/Runtime.java b/jdk/src/share/classes/java/lang/Runtime.java index 6275e2859d0..5ff1aac0bce 100644 --- a/jdk/src/share/classes/java/lang/Runtime.java +++ b/jdk/src/share/classes/java/lang/Runtime.java @@ -117,11 +117,11 @@ public class Runtime { * *
      * - *

    • The program exits normally, when the last non-daemon + *
    • The program exits normally, when the last non-daemon * thread exits or when the {@link #exit exit} (equivalently, - * {@link System#exit(int) System.exit}) method is invoked, or + * {@link System#exit(int) System.exit}) method is invoked, or * - *

    • The virtual machine is terminated in response to a + *
    • The virtual machine is terminated in response to a * user interrupt, such as typing ^C, or a system-wide event, * such as user logoff or system shutdown. * diff --git a/jdk/src/share/classes/java/lang/Short.java b/jdk/src/share/classes/java/lang/Short.java index 6042b13f905..c7641807c56 100644 --- a/jdk/src/share/classes/java/lang/Short.java +++ b/jdk/src/share/classes/java/lang/Short.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2013, 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 @@ -403,9 +403,9 @@ public final class Short extends Number implements Comparable { * Returns a hash code for a {@code short} value; compatible with * {@code Short.hashCode()}. * - * @since 1.8 - * + * @param value the value to hash * @return a hash code value for a {@code short} value. + * @since 1.8 */ public static int hashCode(short value) { return (int)value; @@ -482,6 +482,7 @@ public final class Short extends Number implements Comparable { * Returns the value obtained by reversing the order of the bytes in the * two's complement representation of the specified {@code short} value. * + * @param i the value whose bytes are to be reversed * @return the value obtained by reversing (or, equivalently, swapping) * the bytes in the specified {@code short} value. * @since 1.5 diff --git a/jdk/src/share/classes/java/lang/StrictMath.java b/jdk/src/share/classes/java/lang/StrictMath.java index e59c8d07781..eb202d53202 100644 --- a/jdk/src/share/classes/java/lang/StrictMath.java +++ b/jdk/src/share/classes/java/lang/StrictMath.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2013, 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 @@ -1419,6 +1419,7 @@ public final class StrictMath { * {@link Float#MIN_EXPONENT} -1. *
    * @param f a {@code float} value + * @return the unbiased exponent of the argument * @since 1.6 */ public static int getExponent(float f) { @@ -1436,6 +1437,7 @@ public final class StrictMath { * {@link Double#MIN_EXPONENT} -1. * * @param d a {@code double} value + * @return the unbiased exponent of the argument * @since 1.6 */ public static int getExponent(double d) { diff --git a/jdk/src/share/classes/java/lang/SuppressWarnings.java b/jdk/src/share/classes/java/lang/SuppressWarnings.java index 22895dc7b2c..d315ddb7881 100644 --- a/jdk/src/share/classes/java/lang/SuppressWarnings.java +++ b/jdk/src/share/classes/java/lang/SuppressWarnings.java @@ -66,6 +66,7 @@ public @interface SuppressWarnings { * additional warning names they support in conjunction with this * annotation type. They are encouraged to cooperate to ensure * that the same names work across multiple compilers. + * @return the set of warnings to be suppressed */ String[] value(); } diff --git a/jdk/src/share/classes/java/lang/System.java b/jdk/src/share/classes/java/lang/System.java index bd72188c6b0..52a5e0de823 100644 --- a/jdk/src/share/classes/java/lang/System.java +++ b/jdk/src/share/classes/java/lang/System.java @@ -634,6 +634,8 @@ public final class System { * *

    On UNIX systems, it returns {@code "\n"}; on Microsoft * Windows systems it returns {@code "\r\n"}. + * + * @return the system-dependent line separator string * @since 1.7 */ public static String lineSeparator() { diff --git a/jdk/src/share/classes/java/lang/annotation/Annotation.java b/jdk/src/share/classes/java/lang/annotation/Annotation.java index 538d45a2265..bea407be8eb 100644 --- a/jdk/src/share/classes/java/lang/annotation/Annotation.java +++ b/jdk/src/share/classes/java/lang/annotation/Annotation.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -126,6 +126,7 @@ public interface Annotation { /** * Returns the annotation type of this annotation. + * @return the annotation type of this annotation */ Class annotationType(); } diff --git a/jdk/src/share/classes/java/lang/annotation/Repeatable.java b/jdk/src/share/classes/java/lang/annotation/Repeatable.java index 570ed0fa5da..7a2daa82278 100644 --- a/jdk/src/share/classes/java/lang/annotation/Repeatable.java +++ b/jdk/src/share/classes/java/lang/annotation/Repeatable.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2013, 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 @@ -43,6 +43,7 @@ public @interface Repeatable { /** * Indicates the containing annotation type for the * repeatable annotation type. + * @return the containing annotation type */ Class value(); } diff --git a/jdk/src/share/classes/java/lang/annotation/Retention.java b/jdk/src/share/classes/java/lang/annotation/Retention.java index 1c27ca0871e..5efa43ff05c 100644 --- a/jdk/src/share/classes/java/lang/annotation/Retention.java +++ b/jdk/src/share/classes/java/lang/annotation/Retention.java @@ -44,5 +44,9 @@ package java.lang.annotation; @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.ANNOTATION_TYPE) public @interface Retention { + /** + * Returns the retention policy. + * @return the retention policy + */ RetentionPolicy value(); } diff --git a/jdk/src/share/classes/java/lang/annotation/Target.java b/jdk/src/share/classes/java/lang/annotation/Target.java index cdf4a748ae5..1ceec380680 100644 --- a/jdk/src/share/classes/java/lang/annotation/Target.java +++ b/jdk/src/share/classes/java/lang/annotation/Target.java @@ -67,5 +67,11 @@ package java.lang.annotation; @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.ANNOTATION_TYPE) public @interface Target { + /** + * Returns an array of the kinds of elements an annotation type + * can be applied to. + * @return an array of the kinds of elements an annotation type + * can be applied to + */ ElementType[] value(); } diff --git a/jdk/src/share/classes/java/lang/reflect/AnnotatedElement.java b/jdk/src/share/classes/java/lang/reflect/AnnotatedElement.java index b2c43de3d7b..6bc894efaba 100644 --- a/jdk/src/share/classes/java/lang/reflect/AnnotatedElement.java +++ b/jdk/src/share/classes/java/lang/reflect/AnnotatedElement.java @@ -130,6 +130,7 @@ public interface AnnotatedElement { * Returns this element's annotation for the specified type if * such an annotation is present, else null. * + * @param the type of the annotation to query for and return if present * @param annotationClass the Class object corresponding to the * annotation type * @return this element's annotation for the specified annotation type if @@ -154,6 +155,7 @@ public interface AnnotatedElement { * The caller of this method is free to modify the returned array; it will * have no effect on the arrays returned to other callers. * + * @param the type of the annotation to query for and return if present * @param annotationClass the Class object corresponding to the * annotation type * @return all this element's annotations for the specified annotation type if @@ -184,6 +186,7 @@ public interface AnnotatedElement { * This method ignores inherited annotations. (Returns null if no * annotations are directly present on this element.) * + * @param the type of the annotation to query for and return if present * @param annotationClass the Class object corresponding to the * annotation type * @return this element's annotation for the specified annotation type if @@ -209,6 +212,8 @@ public interface AnnotatedElement { * The caller of this method is free to modify the returned array; it will * have no effect on the arrays returned to other callers. * + * @param the type of the annotation to query for and return + * if directly present * @param annotationClass the Class object corresponding to the * annotation type * @return all this element's annotations for the specified annotation type if diff --git a/jdk/src/share/classes/java/lang/reflect/Executable.java b/jdk/src/share/classes/java/lang/reflect/Executable.java index 00e08a64375..2501fd68d5d 100644 --- a/jdk/src/share/classes/java/lang/reflect/Executable.java +++ b/jdk/src/share/classes/java/lang/reflect/Executable.java @@ -384,6 +384,8 @@ public abstract class Executable extends AccessibleObject /** * Returns a string describing this {@code Executable}, including * any type parameters. + * @return a string describing this {@code Executable}, including + * any type parameters */ public abstract String toGenericString(); @@ -496,6 +498,8 @@ public abstract class Executable extends AccessibleObject * If this Executable represents a method, the AnnotatedType object * represents the use of a type to specify the return type of the method. * + * @return an object representing the return type of this method + * or constructor * @since 1.8 */ public abstract AnnotatedType getAnnotatedReturnType(); @@ -531,6 +535,9 @@ public abstract class Executable extends AccessibleObject * * Returns null if this Executable represents a static method. * + * @return an object representing the receiver type of the + * method or constructor represented by this Executable + * * @since 1.8 */ public AnnotatedType getAnnotatedReceiverType() { @@ -553,6 +560,9 @@ public abstract class Executable extends AccessibleObject * Returns an array of length 0 if the method/constructor declares no * parameters. * + * @return an array of objects representing the types of the + * formal parameters of this method or constructor + * * @since 1.8 */ public AnnotatedType[] getAnnotatedParameterTypes() { @@ -575,6 +585,9 @@ public abstract class Executable extends AccessibleObject * Returns an array of length 0 if the method/constructor declares no * exceptions. * + * @return an array of objects representing the declared + * exceptions of this method or constructor + * * @since 1.8 */ public AnnotatedType[] getAnnotatedExceptionTypes() { diff --git a/jdk/src/share/classes/java/lang/reflect/Field.java b/jdk/src/share/classes/java/lang/reflect/Field.java index 8b2603a663e..4052e06e804 100644 --- a/jdk/src/share/classes/java/lang/reflect/Field.java +++ b/jdk/src/share/classes/java/lang/reflect/Field.java @@ -1151,6 +1151,8 @@ class Field extends AccessibleObject implements Member { /** * Returns an AnnotatedType object that represents the use of a type to specify * the declared type of the field represented by this Field. + * @return an object representing the declared type of the field + * represented by this Field * * @since 1.8 */ diff --git a/jdk/src/share/classes/java/lang/reflect/Parameter.java b/jdk/src/share/classes/java/lang/reflect/Parameter.java index c50e0febe41..20969347255 100644 --- a/jdk/src/share/classes/java/lang/reflect/Parameter.java +++ b/jdk/src/share/classes/java/lang/reflect/Parameter.java @@ -152,6 +152,8 @@ public final class Parameter implements AnnotatedElement { * defined in a class file, then that name will be returned by * this method. Otherwise, this method will synthesize a name of * the form argN, where N is the index of the parameter. + * + * @return the name of the parameter */ public String getName() { // Note: empty strings as paramete names are now outlawed. diff --git a/jdk/src/share/classes/java/lang/reflect/TypeVariable.java b/jdk/src/share/classes/java/lang/reflect/TypeVariable.java index 42027e0041c..39ffe4bf3c0 100644 --- a/jdk/src/share/classes/java/lang/reflect/TypeVariable.java +++ b/jdk/src/share/classes/java/lang/reflect/TypeVariable.java @@ -95,6 +95,7 @@ public interface TypeVariable extends Type, Annota * * Returns an array of length 0 if the type parameter declares no bounds. * + * @return an array of objects representing the upper bounds of the type variable * @since 1.8 */ AnnotatedType[] getAnnotatedBounds(); From 980d06ca5fcc9e5381ba213fde90a8e79f7c161c Mon Sep 17 00:00:00 2001 From: Alan Bateman Date: Tue, 25 Jun 2013 13:53:23 +0100 Subject: [PATCH 020/127] 8017570: jfr.jar should not be in compact3 (for now) Reviewed-by: erikj --- jdk/makefiles/profile-includes.txt | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/jdk/makefiles/profile-includes.txt b/jdk/makefiles/profile-includes.txt index 8a137b8b462..f4876284b73 100644 --- a/jdk/makefiles/profile-includes.txt +++ b/jdk/makefiles/profile-includes.txt @@ -125,13 +125,11 @@ PROFILE_3_JRE_LIB_FILES := \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jaas_unix$(SHARED_LIBRARY_SUFFIX) \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)java_crw_demo$(SHARED_LIBRARY_SUFFIX) \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)java_crw_demo.diz \ - $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jfr$(SHARED_LIBRARY_SUFFIX) \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jsdt$(SHARED_LIBRARY_SUFFIX) \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jsdt.diz \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)management$(SHARED_LIBRARY_SUFFIX) \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)management.diz \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)sctp$(SHARED_LIBRARY_SUFFIX) \ - jfr.jar \ jvm.hprof.txt \ management-agent.jar \ management/jmxremote.access \ @@ -164,6 +162,7 @@ FULL_JRE_LIB_FILES := \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)fontmanager$(SHARED_LIBRARY_SUFFIX) \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jawt$(SHARED_LIBRARY_SUFFIX) \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jdwp$(SHARED_LIBRARY_SUFFIX) \ + $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jfr$(SHARED_LIBRARY_SUFFIX) \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jpeg$(SHARED_LIBRARY_SUFFIX) \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jsound$(SHARED_LIBRARY_SUFFIX) \ $(OPENJDK_TARGET_CPU_LEGACY_LIB)/$(LIBRARY_PREFIX)jsoundalsa$(SHARED_LIBRARY_SUFFIX) \ @@ -214,6 +213,7 @@ FULL_JRE_LIB_FILES := \ images/cursors/motif_MoveDrop32x32.gif \ images/cursors/motif_MoveNoDrop32x32.gif \ jexec \ + jfr.jar \ oblique-fonts/LucidaSansDemiOblique.ttf \ oblique-fonts/LucidaSansOblique.ttf \ oblique-fonts/LucidaTypewriterBoldOblique.ttf \ From 5a0793018c8c6390594f60ef52fb60df932995b1 Mon Sep 17 00:00:00 2001 From: Alan Eliasen Date: Thu, 20 Jun 2013 12:15:24 -0700 Subject: [PATCH 021/127] 4641897: Faster string conversion of large integers Accelerate conversion to string by means of Schoenhage recursive base conversion. Reviewed-by: bpb, alanb --- .../share/classes/java/math/BigInteger.java | 136 +++++++++++++++++- .../java/math/BigInteger/BigIntegerTest.java | 32 ++++- 2 files changed, 166 insertions(+), 2 deletions(-) diff --git a/jdk/src/share/classes/java/math/BigInteger.java b/jdk/src/share/classes/java/math/BigInteger.java index 8972ac76ef9..48354a9559c 100644 --- a/jdk/src/share/classes/java/math/BigInteger.java +++ b/jdk/src/share/classes/java/math/BigInteger.java @@ -33,6 +33,7 @@ import java.io.IOException; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; import java.io.ObjectStreamField; +import java.util.ArrayList; import java.util.Arrays; import java.util.Random; import sun.misc.DoubleConsts; @@ -213,6 +214,16 @@ public class BigInteger extends Number implements Comparable { */ private static final int TOOM_COOK_SQUARE_THRESHOLD = 140; + /** + * The threshold value for using Schoenhage recursive base conversion. If + * the number of ints in the number are larger than this value, + * the Schoenhage algorithm will be used. In practice, it appears that the + * Schoenhage routine is faster for any threshold down to 2, and is + * relatively flat for thresholds between 2-25, so this choice may be + * varied within this range for very small effect. + */ + private static final int SCHOENHAGE_BASE_CONVERSION_THRESHOLD = 8; + //Constructors /** @@ -1026,6 +1037,19 @@ public class BigInteger extends Number implements Comparable { private static BigInteger posConst[] = new BigInteger[MAX_CONSTANT+1]; private static BigInteger negConst[] = new BigInteger[MAX_CONSTANT+1]; + /** + * The cache of powers of each radix. This allows us to not have to + * recalculate powers of radix^(2^n) more than once. This speeds + * Schoenhage recursive base conversion significantly. + */ + private static ArrayList[] powerCache; + + /** The cache of logarithms of radices for base conversion. */ + private static final double[] logCache; + + /** The natural log of 2. This is used in computing cache indices. */ + private static final double LOG_TWO = Math.log(2.0); + static { for (int i = 1; i <= MAX_CONSTANT; i++) { int[] magnitude = new int[1]; @@ -1033,6 +1057,22 @@ public class BigInteger extends Number implements Comparable { posConst[i] = new BigInteger(magnitude, 1); negConst[i] = new BigInteger(magnitude, -1); } + + /* + * Initialize the cache of radix^(2^x) values used for base conversion + * with just the very first value. Additional values will be created + * on demand. + */ + powerCache = (ArrayList[]) + new ArrayList[Character.MAX_RADIX+1]; + logCache = new double[Character.MAX_RADIX+1]; + + for (int i=Character.MIN_RADIX; i<=Character.MAX_RADIX; i++) + { + powerCache[i] = new ArrayList(1); + powerCache[i].add(BigInteger.valueOf(i)); + logCache[i] = Math.log(i); + } } /** @@ -1357,7 +1397,7 @@ public class BigInteger extends Number implements Comparable { if ((xlen < TOOM_COOK_THRESHOLD) && (ylen < TOOM_COOK_THRESHOLD)) return multiplyKaratsuba(this, val); else - return multiplyToomCook3(this, val); + return multiplyToomCook3(this, val); } private static BigInteger multiplyByInt(int[] x, int y, int sign) { @@ -3299,6 +3339,28 @@ public class BigInteger extends Number implements Comparable { if (radix < Character.MIN_RADIX || radix > Character.MAX_RADIX) radix = 10; + // If it's small enough, use smallToString. + if (mag.length <= SCHOENHAGE_BASE_CONVERSION_THRESHOLD) + return smallToString(radix); + + // Otherwise use recursive toString, which requires positive arguments. + // The results will be concatenated into this StringBuilder + StringBuilder sb = new StringBuilder(); + if (signum < 0) { + toString(this.negate(), sb, radix, 0); + sb.insert(0, '-'); + } + else + toString(this, sb, radix, 0); + + return sb.toString(); + } + + /** This method is used to perform toString when arguments are small. */ + private String smallToString(int radix) { + if (signum == 0) + return "0"; + // Compute upper bound on number of digit groups and allocate space int maxNumDigitGroups = (4*mag.length + 6)/7; String digitGroup[] = new String[maxNumDigitGroups]; @@ -3337,6 +3399,78 @@ public class BigInteger extends Number implements Comparable { return buf.toString(); } + /** + * Converts the specified BigInteger to a string and appends to + * sb. This implements the recursive Schoenhage algorithm + * for base conversions. + *

    + * See Knuth, Donald, _The Art of Computer Programming_, Vol. 2, + * Answers to Exercises (4.4) Question 14. + * + * @param u The number to convert to a string. + * @param sb The StringBuilder that will be appended to in place. + * @param radix The base to convert to. + * @param digits The minimum number of digits to pad to. + */ + private static void toString(BigInteger u, StringBuilder sb, int radix, + int digits) { + /* If we're smaller than a certain threshold, use the smallToString + method, padding with leading zeroes when necessary. */ + if (u.mag.length <= SCHOENHAGE_BASE_CONVERSION_THRESHOLD) { + String s = u.smallToString(radix); + + // Pad with internal zeros if necessary. + // Don't pad if we're at the beginning of the string. + if ((s.length() < digits) && (sb.length() > 0)) + for (int i=s.length(); i + * This could be changed to a more complicated caching method using + * Future. + */ + private static synchronized BigInteger getRadixConversionCache(int radix, + int exponent) { + BigInteger retVal = null; + ArrayList cacheLine = powerCache[radix]; + int oldSize = cacheLine.size(); + if (exponent >= oldSize) { + cacheLine.ensureCapacity(exponent+1); + for (int i=oldSize; i<=exponent; i++) { + retVal = cacheLine.get(i-1).square(); + cacheLine.add(i, retVal); + } + } + else + retVal = cacheLine.get(exponent); + + return retVal; + } /* zero[i] is a string of i consecutive zeros. */ private static String zeros[] = new String[64]; diff --git a/jdk/test/java/math/BigInteger/BigIntegerTest.java b/jdk/test/java/math/BigInteger/BigIntegerTest.java index 4522d4440bf..17c58bce981 100644 --- a/jdk/test/java/math/BigInteger/BigIntegerTest.java +++ b/jdk/test/java/math/BigInteger/BigIntegerTest.java @@ -61,10 +61,13 @@ public class BigIntegerTest { // KARATSUBA_SQUARE_THRESHOLD = 90 ints = 2880 bits // TOOM_COOK_SQUARE_THRESHOLD = 140 ints = 4480 bits // + // SCHOENHAGE_BASE_CONVERSION_THRESHOLD = 8 ints = 256 bits + // static final int BITS_KARATSUBA = 1600; static final int BITS_TOOM_COOK = 2400; static final int BITS_KARATSUBA_SQUARE = 2880; static final int BITS_TOOM_COOK_SQUARE = 4480; + static final int BITS_SCHOENHAGE_BASE = 256; static final int ORDER_SMALL = 60; static final int ORDER_MEDIUM = 100; @@ -467,12 +470,13 @@ public class BigIntegerTest { public static void stringConv() { int failCount = 0; + // Generic string conversion. for (int i=0; i<100; i++) { byte xBytes[] = new byte[Math.abs(rnd.nextInt())%100+1]; rnd.nextBytes(xBytes); BigInteger x = new BigInteger(xBytes); - for (int radix=2; radix < 37; radix++) { + for (int radix=Character.MIN_RADIX; radix < Character.MAX_RADIX; radix++) { String result = x.toString(radix); BigInteger test = new BigInteger(result, radix); if (!test.equals(x)) { @@ -483,6 +487,32 @@ public class BigIntegerTest { } } } + + // String conversion straddling the Schoenhage algorithm crossover + // threshold, and at twice and four times the threshold. + for (int k = 0; k <= 2; k++) { + int factor = 1 << k; + int upper = factor * BITS_SCHOENHAGE_BASE + 33; + int lower = upper - 35; + + for (int bits = upper; bits >= lower; bits--) { + for (int i = 0; i < 50; i++) { + BigInteger x = BigInteger.ONE.shiftLeft(bits - 1).or(new BigInteger(bits - 2, rnd)); + + for (int radix = Character.MIN_RADIX; radix < Character.MAX_RADIX; radix++) { + String result = x.toString(radix); + BigInteger test = new BigInteger(result, radix); + if (!test.equals(x)) { + failCount++; + System.err.println("BigInteger toString: " + x); + System.err.println("Test: " + test); + System.err.println(radix); + } + } + } + } + } + report("String Conversion", failCount); } From b158c095ac8303d9cba2f2da74b34438f76c25b6 Mon Sep 17 00:00:00 2001 From: Artem Smotrakov Date: Tue, 25 Jun 2013 21:51:11 +0800 Subject: [PATCH 022/127] 8016051: Possible ClassCastException in KdcComm Reviewed-by: weijun --- .../classes/sun/security/krb5/KdcComm.java | 77 +++++++++++-------- 1 file changed, 43 insertions(+), 34 deletions(-) diff --git a/jdk/src/share/classes/sun/security/krb5/KdcComm.java b/jdk/src/share/classes/sun/security/krb5/KdcComm.java index 80c0af48e00..141592f11c3 100644 --- a/jdk/src/share/classes/sun/security/krb5/KdcComm.java +++ b/jdk/src/share/classes/sun/security/krb5/KdcComm.java @@ -46,6 +46,7 @@ import java.util.ArrayList; import java.util.List; import java.util.Set; import java.util.HashSet; +import java.util.Iterator; import sun.security.krb5.internal.KRBError; /** @@ -203,7 +204,6 @@ public final class KdcComm { if (obuf == null) return null; - Exception savedException = null; Config cfg = Config.getInstance(); if (realm == null) { @@ -218,42 +218,51 @@ public final class KdcComm { if (kdcList == null) { throw new KrbException("Cannot get kdc for realm " + realm); } - String tempKdc = null; // may include the port number also - byte[] ibuf = null; - for (String tmp: KdcAccessibility.list(kdcList)) { - tempKdc = tmp; - try { - ibuf = send(obuf,tempKdc,useTCP); - KRBError ke = null; + // tempKdc may include the port number also + Iterator tempKdc = KdcAccessibility.list(kdcList).iterator(); + if (!tempKdc.hasNext()) { + throw new KrbException("Cannot get kdc for realm " + realm); + } + try { + return sendIfPossible(obuf, tempKdc.next(), useTCP); + } catch(Exception first) { + while(tempKdc.hasNext()) { try { - ke = new KRBError(ibuf); - } catch (Exception e) { - // OK - } - if (ke != null && ke.getErrorCode() == - Krb5.KRB_ERR_RESPONSE_TOO_BIG) { - ibuf = send(obuf, tempKdc, true); - } - KdcAccessibility.removeBad(tempKdc); - break; + return sendIfPossible(obuf, tempKdc.next(), useTCP); + } catch(Exception ignore) {} + } + throw first; + } + } + + // send the AS Request to the specified KDC + // failover to using TCP if useTCP is not set and response is too big + private byte[] sendIfPossible(byte[] obuf, String tempKdc, boolean useTCP) + throws IOException, KrbException { + + try { + byte[] ibuf = send(obuf, tempKdc, useTCP); + KRBError ke = null; + try { + ke = new KRBError(ibuf); } catch (Exception e) { - if (DEBUG) { - System.out.println(">>> KrbKdcReq send: error trying " + - tempKdc); - e.printStackTrace(System.out); - } - KdcAccessibility.addBad(tempKdc); - savedException = e; + // OK } - } - if (ibuf == null && savedException != null) { - if (savedException instanceof IOException) { - throw (IOException) savedException; - } else { - throw (KrbException) savedException; + if (ke != null && ke.getErrorCode() == + Krb5.KRB_ERR_RESPONSE_TOO_BIG) { + ibuf = send(obuf, tempKdc, true); } + KdcAccessibility.removeBad(tempKdc); + return ibuf; + } catch(Exception e) { + if (DEBUG) { + System.out.println(">>> KrbKdcReq send: error trying " + + tempKdc); + e.printStackTrace(System.out); + } + KdcAccessibility.addBad(tempKdc); + throw e; } - return ibuf; } // send the AS Request to the specified KDC @@ -496,7 +505,7 @@ public final class KdcComm { } // Returns a preferred KDC list by putting the bad ones at the end - private static synchronized String[] list(String kdcList) { + private static synchronized List list(String kdcList) { StringTokenizer st = new StringTokenizer(kdcList); List list = new ArrayList<>(); if (badPolicy == BpType.TRY_LAST) { @@ -515,7 +524,7 @@ public final class KdcComm { list.add(st.nextToken()); } } - return list.toArray(new String[list.size()]); + return list; } } } From 32b2aa918360bbeb500604ae8623833e9e068c87 Mon Sep 17 00:00:00 2001 From: Aleksey Shipilev Date: Tue, 25 Jun 2013 20:06:09 +0100 Subject: [PATCH 023/127] 8014233: java.lang.Thread should have @Contended on TLR fields Add the @Contended over three TLR fields. Reviewed-by: psandoz, chegar, dholmes, dl --- jdk/src/share/classes/java/lang/Thread.java | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/jdk/src/share/classes/java/lang/Thread.java b/jdk/src/share/classes/java/lang/Thread.java index bb175ff89ad..eb89670d149 100644 --- a/jdk/src/share/classes/java/lang/Thread.java +++ b/jdk/src/share/classes/java/lang/Thread.java @@ -1993,12 +1993,21 @@ class Thread implements Runnable { // The following three initially uninitialized fields are exclusively - // managed by class java.util.concurrent.ThreadLocalRandom. + // managed by class java.util.concurrent.ThreadLocalRandom. These + // fields are used to build the high-performance PRNGs in the + // concurrent code, and we can not risk accidental false sharing. + // Hence, the fields are isolated with @Contended. + /** The current seed for a ThreadLocalRandom */ + @sun.misc.Contended("tlr") long threadLocalRandomSeed; + /** Probe hash value; nonzero if threadLocalRandomSeed initialized */ + @sun.misc.Contended("tlr") int threadLocalRandomProbe; + /** Secondary seed isolated from public ThreadLocalRandom sequence */ + @sun.misc.Contended("tlr") int threadLocalRandomSecondarySeed; /* Some private helper methods */ From 1b06c50919f26bee3a2cf3ac0cd418ee96de84b0 Mon Sep 17 00:00:00 2001 From: Jason Uh Date: Tue, 25 Jun 2013 14:31:29 -0700 Subject: [PATCH 024/127] 8017325: Cleanup of the javadoc tag in java.security.cert Convert javadoc ... and ... tags to {@code ...} Reviewed-by: darcy --- .../java/security/cert/CRLException.java | 14 +- .../java/security/cert/CRLSelector.java | 18 +- .../classes/java/security/cert/CertPath.java | 140 ++--- .../java/security/cert/CertPathBuilder.java | 56 +- .../cert/CertPathBuilderException.java | 26 +- .../security/cert/CertPathBuilderResult.java | 12 +- .../security/cert/CertPathBuilderSpi.java | 18 +- .../security/cert/CertPathParameters.java | 10 +- .../java/security/cert/CertPathValidator.java | 72 +-- .../cert/CertPathValidatorException.java | 62 +- .../cert/CertPathValidatorResult.java | 6 +- .../security/cert/CertPathValidatorSpi.java | 32 +- .../java/security/cert/CertSelector.java | 20 +- .../classes/java/security/cert/CertStore.java | 178 +++--- .../security/cert/CertStoreException.java | 24 +- .../security/cert/CertStoreParameters.java | 40 +- .../java/security/cert/CertStoreSpi.java | 90 +-- .../java/security/cert/Certificate.java | 10 +- .../cert/CertificateEncodingException.java | 14 +- .../security/cert/CertificateException.java | 14 +- .../cert/CertificateExpiredException.java | 6 +- .../security/cert/CertificateFactory.java | 110 ++-- .../security/cert/CertificateFactorySpi.java | 100 ++-- .../cert/CertificateNotYetValidException.java | 6 +- .../cert/CertificateParsingException.java | 14 +- .../cert/CertificateRevokedException.java | 28 +- .../cert/CollectionCertStoreParameters.java | 64 +-- .../classes/java/security/cert/Extension.java | 6 +- .../cert/LDAPCertStoreParameters.java | 24 +- .../security/cert/PKIXBuilderParameters.java | 74 +-- .../cert/PKIXCertPathBuilderResult.java | 38 +- .../security/cert/PKIXCertPathChecker.java | 72 +-- .../cert/PKIXCertPathValidatorResult.java | 38 +- .../java/security/cert/PKIXParameters.java | 244 ++++---- .../java/security/cert/PKIXReason.java | 6 +- .../java/security/cert/PolicyNode.java | 36 +- .../security/cert/PolicyQualifierInfo.java | 38 +- .../java/security/cert/TrustAnchor.java | 62 +- .../classes/java/security/cert/X509CRL.java | 50 +- .../java/security/cert/X509CRLEntry.java | 8 +- .../java/security/cert/X509CRLSelector.java | 192 +++---- .../java/security/cert/X509CertSelector.java | 538 +++++++++--------- .../java/security/cert/X509Certificate.java | 146 ++--- .../java/security/cert/X509Extension.java | 26 +- 44 files changed, 1391 insertions(+), 1391 deletions(-) diff --git a/jdk/src/share/classes/java/security/cert/CRLException.java b/jdk/src/share/classes/java/security/cert/CRLException.java index ca5b689d07c..7a854316bbd 100644 --- a/jdk/src/share/classes/java/security/cert/CRLException.java +++ b/jdk/src/share/classes/java/security/cert/CRLException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -57,13 +57,13 @@ public class CRLException extends GeneralSecurityException { } /** - * Creates a CRLException with the specified + * Creates a {@code CRLException} with the specified * detail message and cause. * * @param message the detail message (which is saved for later retrieval * by the {@link #getMessage()} method). * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause()} method). (A null value is permitted, + * {@link #getCause()} method). (A {@code null} value is permitted, * and indicates that the cause is nonexistent or unknown.) * @since 1.5 */ @@ -72,13 +72,13 @@ public class CRLException extends GeneralSecurityException { } /** - * Creates a CRLException with the specified cause - * and a detail message of (cause==null ? null : cause.toString()) + * Creates a {@code CRLException} with the specified cause + * and a detail message of {@code (cause==null ? null : cause.toString())} * (which typically contains the class and detail message of - * cause). + * {@code cause}). * * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause()} method). (A null value is permitted, + * {@link #getCause()} method). (A {@code null} value is permitted, * and indicates that the cause is nonexistent or unknown.) * @since 1.5 */ diff --git a/jdk/src/share/classes/java/security/cert/CRLSelector.java b/jdk/src/share/classes/java/security/cert/CRLSelector.java index 2c00f10bca7..7ab181d48c5 100644 --- a/jdk/src/share/classes/java/security/cert/CRLSelector.java +++ b/jdk/src/share/classes/java/security/cert/CRLSelector.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2001, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -26,9 +26,9 @@ package java.security.cert; /** - * A selector that defines a set of criteria for selecting CRLs. + * A selector that defines a set of criteria for selecting {@code CRL}s. * Classes that implement this interface are often used to specify - * which CRLs should be retrieved from a CertStore. + * which {@code CRL}s should be retrieved from a {@code CertStore}. *

    * Concurrent Access *

    @@ -48,19 +48,19 @@ package java.security.cert; public interface CRLSelector extends Cloneable { /** - * Decides whether a CRL should be selected. + * Decides whether a {@code CRL} should be selected. * - * @param crl the CRL to be checked - * @return true if the CRL should be selected, - * false otherwise + * @param crl the {@code CRL} to be checked + * @return {@code true} if the {@code CRL} should be selected, + * {@code false} otherwise */ boolean match(CRL crl); /** - * Makes a copy of this CRLSelector. Changes to the + * Makes a copy of this {@code CRLSelector}. Changes to the * copy will not affect the original and vice versa. * - * @return a copy of this CRLSelector + * @return a copy of this {@code CRLSelector} */ Object clone(); } diff --git a/jdk/src/share/classes/java/security/cert/CertPath.java b/jdk/src/share/classes/java/security/cert/CertPath.java index 052be2043c9..8717f948203 100644 --- a/jdk/src/share/classes/java/security/cert/CertPath.java +++ b/jdk/src/share/classes/java/security/cert/CertPath.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -36,59 +36,59 @@ import java.util.List; * An immutable sequence of certificates (a certification path). *

    * This is an abstract class that defines the methods common to all - * CertPaths. Subclasses can handle different kinds of + * {@code CertPath}s. Subclasses can handle different kinds of * certificates (X.509, PGP, etc.). *

    - * All CertPath objects have a type, a list of - * Certificates, and one or more supported encodings. Because the - * CertPath class is immutable, a CertPath cannot + * All {@code CertPath} objects have a type, a list of + * {@code Certificate}s, and one or more supported encodings. Because the + * {@code CertPath} class is immutable, a {@code CertPath} cannot * change in any externally visible way after being constructed. This * stipulation applies to all public fields and methods of this class and any * added or overridden by subclasses. *

    - * The type is a String that identifies the type of - * Certificates in the certification path. For each - * certificate cert in a certification path certPath, - * cert.getType().equals(certPath.getType()) must be - * true. + * The type is a {@code String} that identifies the type of + * {@code Certificate}s in the certification path. For each + * certificate {@code cert} in a certification path {@code certPath}, + * {@code cert.getType().equals(certPath.getType())} must be + * {@code true}. *

    - * The list of Certificates is an ordered List of - * zero or more Certificates. This List and all - * of the Certificates contained in it must be immutable. + * The list of {@code Certificate}s is an ordered {@code List} of + * zero or more {@code Certificate}s. This {@code List} and all + * of the {@code Certificate}s contained in it must be immutable. *

    - * Each CertPath object must support one or more encodings + * Each {@code CertPath} object must support one or more encodings * so that the object can be translated into a byte array for storage or * transmission to other parties. Preferably, these encodings should be * well-documented standards (such as PKCS#7). One of the encodings supported - * by a CertPath is considered the default encoding. This + * by a {@code CertPath} is considered the default encoding. This * encoding is used if no encoding is explicitly requested (for the * {@link #getEncoded() getEncoded()} method, for instance). *

    - * All CertPath objects are also Serializable. - * CertPath objects are resolved into an alternate + * All {@code CertPath} objects are also {@code Serializable}. + * {@code CertPath} objects are resolved into an alternate * {@link CertPathRep CertPathRep} object during serialization. This allows - * a CertPath object to be serialized into an equivalent + * a {@code CertPath} object to be serialized into an equivalent * representation regardless of its underlying implementation. *

    - * CertPath objects can be created with a - * CertificateFactory or they can be returned by other classes, - * such as a CertPathBuilder. + * {@code CertPath} objects can be created with a + * {@code CertificateFactory} or they can be returned by other classes, + * such as a {@code CertPathBuilder}. *

    - * By convention, X.509 CertPaths (consisting of - * X509Certificates), are ordered starting with the target + * By convention, X.509 {@code CertPath}s (consisting of + * {@code X509Certificate}s), are ordered starting with the target * certificate and ending with a certificate issued by the trust anchor. That * is, the issuer of one certificate is the subject of the following one. The * certificate representing the {@link TrustAnchor TrustAnchor} should not be - * included in the certification path. Unvalidated X.509 CertPaths - * may not follow these conventions. PKIX CertPathValidators will + * included in the certification path. Unvalidated X.509 {@code CertPath}s + * may not follow these conventions. PKIX {@code CertPathValidator}s will * detect any departure from these conventions that cause the certification - * path to be invalid and throw a CertPathValidatorException. + * path to be invalid and throw a {@code CertPathValidatorException}. * *

    Every implementation of the Java platform is required to support the - * following standard CertPath encodings: + * following standard {@code CertPath} encodings: *

      - *
    • PKCS7
    • - *
    • PkiPath
    • + *
    • {@code PKCS7}
    • + *
    • {@code PkiPath}
    • *
    * These encodings are described in the @@ -99,17 +99,17 @@ import java.util.List; *

    * Concurrent Access *

    - * All CertPath objects must be thread-safe. That is, multiple + * All {@code CertPath} objects must be thread-safe. That is, multiple * threads may concurrently invoke the methods defined in this class on a - * single CertPath object (or more than one) with no - * ill effects. This is also true for the List returned by - * CertPath.getCertificates. + * single {@code CertPath} object (or more than one) with no + * ill effects. This is also true for the {@code List} returned by + * {@code CertPath.getCertificates}. *

    - * Requiring CertPath objects to be immutable and thread-safe + * Requiring {@code CertPath} objects to be immutable and thread-safe * allows them to be passed around to various pieces of code without worrying * about coordinating access. Providing this thread-safety is - * generally not difficult, since the CertPath and - * List objects in question are immutable. + * generally not difficult, since the {@code CertPath} and + * {@code List} objects in question are immutable. * * @see CertificateFactory * @see CertPathBuilder @@ -124,25 +124,25 @@ public abstract class CertPath implements Serializable { private String type; // the type of certificates in this chain /** - * Creates a CertPath of the specified type. + * Creates a {@code CertPath} of the specified type. *

    * This constructor is protected because most users should use a - * CertificateFactory to create CertPaths. + * {@code CertificateFactory} to create {@code CertPath}s. * * @param type the standard name of the type of - * Certificates in this path + * {@code Certificate}s in this path */ protected CertPath(String type) { this.type = type; } /** - * Returns the type of Certificates in this certification + * Returns the type of {@code Certificate}s in this certification * path. This is the same string that would be returned by * {@link java.security.cert.Certificate#getType() cert.getType()} - * for all Certificates in the certification path. + * for all {@code Certificate}s in the certification path. * - * @return the type of Certificates in this certification + * @return the type of {@code Certificate}s in this certification * path (never null) */ public String getType() { @@ -152,21 +152,21 @@ public abstract class CertPath implements Serializable { /** * Returns an iteration of the encodings supported by this certification * path, with the default encoding first. Attempts to modify the returned - * Iterator via its remove method result in an - * UnsupportedOperationException. + * {@code Iterator} via its {@code remove} method result in an + * {@code UnsupportedOperationException}. * - * @return an Iterator over the names of the supported + * @return an {@code Iterator} over the names of the supported * encodings (as Strings) */ public abstract Iterator getEncodings(); /** * Compares this certification path for equality with the specified - * object. Two CertPaths are equal if and only if their - * types are equal and their certificate Lists (and by - * implication the Certificates in those Lists) - * are equal. A CertPath is never equal to an object that is - * not a CertPath. + * object. Two {@code CertPath}s are equal if and only if their + * types are equal and their certificate {@code List}s (and by + * implication the {@code Certificate}s in those {@code List}s) + * are equal. A {@code CertPath} is never equal to an object that is + * not a {@code CertPath}. *

    * This algorithm is implemented by this method. If it is overridden, * the behavior specified here must be maintained. @@ -195,14 +195,14 @@ public abstract class CertPath implements Serializable { * Returns the hashcode for this certification path. The hash code of * a certification path is defined to be the result of the following * calculation: - *

    
    +     * 
    {@code
          *  hashCode = path.getType().hashCode();
          *  hashCode = 31*hashCode + path.getCertificates().hashCode();
    -     * 
    - * This ensures that path1.equals(path2) implies that - * path1.hashCode()==path2.hashCode() for any two certification - * paths, path1 and path2, as required by the - * general contract of Object.hashCode. + * }
    + * This ensures that {@code path1.equals(path2)} implies that + * {@code path1.hashCode()==path2.hashCode()} for any two certification + * paths, {@code path1} and {@code path2}, as required by the + * general contract of {@code Object.hashCode}. * * @return the hashcode value for this certification path */ @@ -214,8 +214,8 @@ public abstract class CertPath implements Serializable { /** * Returns a string representation of this certification path. - * This calls the toString method on each of the - * Certificates in the path. + * This calls the {@code toString} method on each of the + * {@code Certificate}s in the path. * * @return a string representation of this certification path */ @@ -266,20 +266,20 @@ public abstract class CertPath implements Serializable { /** * Returns the list of certificates in this certification path. - * The List returned must be immutable and thread-safe. + * The {@code List} returned must be immutable and thread-safe. * - * @return an immutable List of Certificates + * @return an immutable {@code List} of {@code Certificate}s * (may be empty, but not null) */ public abstract List getCertificates(); /** - * Replaces the CertPath to be serialized with a - * CertPathRep object. + * Replaces the {@code CertPath} to be serialized with a + * {@code CertPathRep} object. * - * @return the CertPathRep to be serialized + * @return the {@code CertPathRep} to be serialized * - * @throws ObjectStreamException if a CertPathRep object + * @throws ObjectStreamException if a {@code CertPathRep} object * representing this certification path could not be created */ protected Object writeReplace() throws ObjectStreamException { @@ -295,7 +295,7 @@ public abstract class CertPath implements Serializable { } /** - * Alternate CertPath class for serialization. + * Alternate {@code CertPath} class for serialization. * @since 1.4 */ protected static class CertPathRep implements Serializable { @@ -308,10 +308,10 @@ public abstract class CertPath implements Serializable { private byte[] data; /** - * Creates a CertPathRep with the specified + * Creates a {@code CertPathRep} with the specified * type and encoded form of a certification path. * - * @param type the standard name of a CertPath type + * @param type the standard name of a {@code CertPath} type * @param data the encoded form of the certification path */ protected CertPathRep(String type, byte[] data) { @@ -320,11 +320,11 @@ public abstract class CertPath implements Serializable { } /** - * Returns a CertPath constructed from the type and data. + * Returns a {@code CertPath} constructed from the type and data. * - * @return the resolved CertPath object + * @return the resolved {@code CertPath} object * - * @throws ObjectStreamException if a CertPath could not + * @throws ObjectStreamException if a {@code CertPath} could not * be constructed */ protected Object readResolve() throws ObjectStreamException { diff --git a/jdk/src/share/classes/java/security/cert/CertPathBuilder.java b/jdk/src/share/classes/java/security/cert/CertPathBuilder.java index 998477b4814..6008e9ec180 100644 --- a/jdk/src/share/classes/java/security/cert/CertPathBuilder.java +++ b/jdk/src/share/classes/java/security/cert/CertPathBuilder.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -41,16 +41,16 @@ import sun.security.jca.GetInstance.Instance; * A class for building certification paths (also known as certificate chains). *

    * This class uses a provider-based architecture. - * To create a CertPathBuilder, call - * one of the static getInstance methods, passing in the - * algorithm name of the CertPathBuilder desired and optionally + * To create a {@code CertPathBuilder}, call + * one of the static {@code getInstance} methods, passing in the + * algorithm name of the {@code CertPathBuilder} desired and optionally * the name of the provider desired. * - *

    Once a CertPathBuilder object has been created, certification + *

    Once a {@code CertPathBuilder} object has been created, certification * paths can be constructed by calling the {@link #build build} method and * passing it an algorithm-specific set of parameters. If successful, the - * result (including the CertPath that was built) is returned - * in an object that implements the CertPathBuilderResult + * result (including the {@code CertPath} that was built) is returned + * in an object that implements the {@code CertPathBuilderResult} * interface. * *

    The {@link #getRevocationChecker} method allows an application to specify @@ -67,9 +67,9 @@ import sun.security.jca.GetInstance.Instance; * * *

    Every implementation of the Java platform is required to support the - * following standard CertPathBuilder algorithm: + * following standard {@code CertPathBuilder} algorithm: *

      - *
    • PKIX
    • + *
    • {@code PKIX}
    • *
    * This algorithm is described in the
    @@ -87,9 +87,9 @@ import sun.security.jca.GetInstance.Instance; *

    * However, this is not true for the non-static methods defined by this class. * Unless otherwise documented by a specific provider, threads that need to - * access a single CertPathBuilder instance concurrently should + * access a single {@code CertPathBuilder} instance concurrently should * synchronize amongst themselves and provide the necessary locking. Multiple - * threads each manipulating a different CertPathBuilder instance + * threads each manipulating a different {@code CertPathBuilder} instance * need not synchronize. * * @see CertPath @@ -114,7 +114,7 @@ public class CertPathBuilder { private final String algorithm; /** - * Creates a CertPathBuilder object of the given algorithm, + * Creates a {@code CertPathBuilder} object of the given algorithm, * and encapsulates the given provider implementation (SPI object) in it. * * @param builderSpi the provider implementation @@ -130,7 +130,7 @@ public class CertPathBuilder { } /** - * Returns a CertPathBuilder object that implements the + * Returns a {@code CertPathBuilder} object that implements the * specified algorithm. * *

    This method traverses the list of registered security Providers, @@ -142,13 +142,13 @@ public class CertPathBuilder { *

    Note that the list of registered providers may be retrieved via * the {@link Security#getProviders() Security.getProviders()} method. * - * @param algorithm the name of the requested CertPathBuilder + * @param algorithm the name of the requested {@code CertPathBuilder} * algorithm. See the CertPathBuilder section in the * Java Cryptography Architecture Standard Algorithm Name Documentation * for information about standard algorithm names. * - * @return a CertPathBuilder object that implements the + * @return a {@code CertPathBuilder} object that implements the * specified algorithm. * * @throws NoSuchAlgorithmException if no Provider supports a @@ -166,7 +166,7 @@ public class CertPathBuilder { } /** - * Returns a CertPathBuilder object that implements the + * Returns a {@code CertPathBuilder} object that implements the * specified algorithm. * *

    A new CertPathBuilder object encapsulating the @@ -177,7 +177,7 @@ public class CertPathBuilder { *

    Note that the list of registered providers may be retrieved via * the {@link Security#getProviders() Security.getProviders()} method. * - * @param algorithm the name of the requested CertPathBuilder + * @param algorithm the name of the requested {@code CertPathBuilder} * algorithm. See the CertPathBuilder section in the * Java Cryptography Architecture Standard Algorithm Name Documentation @@ -185,7 +185,7 @@ public class CertPathBuilder { * * @param provider the name of the provider. * - * @return a CertPathBuilder object that implements the + * @return a {@code CertPathBuilder} object that implements the * specified algorithm. * * @throws NoSuchAlgorithmException if a CertPathBuilderSpi @@ -195,7 +195,7 @@ public class CertPathBuilder { * @throws NoSuchProviderException if the specified provider is not * registered in the security provider list. * - * @exception IllegalArgumentException if the provider is + * @exception IllegalArgumentException if the {@code provider} is * null or empty. * * @see java.security.Provider @@ -209,7 +209,7 @@ public class CertPathBuilder { } /** - * Returns a CertPathBuilder object that implements the + * Returns a {@code CertPathBuilder} object that implements the * specified algorithm. * *

    A new CertPathBuilder object encapsulating the @@ -217,7 +217,7 @@ public class CertPathBuilder { * object is returned. Note that the specified Provider object * does not have to be registered in the provider list. * - * @param algorithm the name of the requested CertPathBuilder + * @param algorithm the name of the requested {@code CertPathBuilder} * algorithm. See the CertPathBuilder section in the * Java Cryptography Architecture Standard Algorithm Name Documentation @@ -225,14 +225,14 @@ public class CertPathBuilder { * * @param provider the provider. * - * @return a CertPathBuilder object that implements the + * @return a {@code CertPathBuilder} object that implements the * specified algorithm. * * @exception NoSuchAlgorithmException if a CertPathBuilderSpi * implementation for the specified algorithm is not available * from the specified Provider object. * - * @exception IllegalArgumentException if the provider is + * @exception IllegalArgumentException if the {@code provider} is * null. * * @see java.security.Provider @@ -246,18 +246,18 @@ public class CertPathBuilder { } /** - * Returns the provider of this CertPathBuilder. + * Returns the provider of this {@code CertPathBuilder}. * - * @return the provider of this CertPathBuilder + * @return the provider of this {@code CertPathBuilder} */ public final Provider getProvider() { return this.provider; } /** - * Returns the name of the algorithm of this CertPathBuilder. + * Returns the name of the algorithm of this {@code CertPathBuilder}. * - * @return the name of the algorithm of this CertPathBuilder + * @return the name of the algorithm of this {@code CertPathBuilder} */ public final String getAlgorithm() { return this.algorithm; @@ -272,7 +272,7 @@ public class CertPathBuilder { * @throws CertPathBuilderException if the builder is unable to construct * a certification path that satisfies the specified parameters * @throws InvalidAlgorithmParameterException if the specified parameters - * are inappropriate for this CertPathBuilder + * are inappropriate for this {@code CertPathBuilder} */ public final CertPathBuilderResult build(CertPathParameters params) throws CertPathBuilderException, InvalidAlgorithmParameterException diff --git a/jdk/src/share/classes/java/security/cert/CertPathBuilderException.java b/jdk/src/share/classes/java/security/cert/CertPathBuilderException.java index 4d460c66db9..cf95847922b 100644 --- a/jdk/src/share/classes/java/security/cert/CertPathBuilderException.java +++ b/jdk/src/share/classes/java/security/cert/CertPathBuilderException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -29,9 +29,9 @@ import java.security.GeneralSecurityException; /** * An exception indicating one of a variety of problems encountered when - * building a certification path with a CertPathBuilder. + * building a certification path with a {@code CertPathBuilder}. *

    - * A CertPathBuilderException provides support for wrapping + * A {@code CertPathBuilderException} provides support for wrapping * exceptions. The {@link #getCause getCause} method returns the throwable, * if any, that caused this exception to be thrown. *

    @@ -53,7 +53,7 @@ public class CertPathBuilderException extends GeneralSecurityException { private static final long serialVersionUID = 5316471420178794402L; /** - * Creates a CertPathBuilderException with null + * Creates a {@code CertPathBuilderException} with {@code null} * as its detail message. */ public CertPathBuilderException() { @@ -61,8 +61,8 @@ public class CertPathBuilderException extends GeneralSecurityException { } /** - * Creates a CertPathBuilderException with the given - * detail message. The detail message is a String that + * Creates a {@code CertPathBuilderException} with the given + * detail message. The detail message is a {@code String} that * describes this particular exception in more detail. * * @param msg the detail message @@ -72,16 +72,16 @@ public class CertPathBuilderException extends GeneralSecurityException { } /** - * Creates a CertPathBuilderException that wraps the specified + * Creates a {@code CertPathBuilderException} that wraps the specified * throwable. This allows any exception to be converted into a - * CertPathBuilderException, while retaining information + * {@code CertPathBuilderException}, while retaining information * about the wrapped exception, which may be useful for debugging. The - * detail message is set to (cause==null ? null : cause.toString() - * ) (which typically contains the class and detail message of + * detail message is set to ({@code cause==null ? null : cause.toString()}) + * (which typically contains the class and detail message of * cause). * * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause getCause()} method). (A null value is + * {@link #getCause getCause()} method). (A {@code null} value is * permitted, and indicates that the cause is nonexistent or unknown.) */ public CertPathBuilderException(Throwable cause) { @@ -89,12 +89,12 @@ public class CertPathBuilderException extends GeneralSecurityException { } /** - * Creates a CertPathBuilderException with the specified + * Creates a {@code CertPathBuilderException} with the specified * detail message and cause. * * @param msg the detail message * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause getCause()} method). (A null value is + * {@link #getCause getCause()} method). (A {@code null} value is * permitted, and indicates that the cause is nonexistent or unknown.) */ public CertPathBuilderException(String msg, Throwable cause) { diff --git a/jdk/src/share/classes/java/security/cert/CertPathBuilderResult.java b/jdk/src/share/classes/java/security/cert/CertPathBuilderResult.java index 71eed201ac4..ecf53bbe750 100644 --- a/jdk/src/share/classes/java/security/cert/CertPathBuilderResult.java +++ b/jdk/src/share/classes/java/security/cert/CertPathBuilderResult.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2001, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -30,8 +30,8 @@ package java.security.cert; * All results returned by the {@link CertPathBuilder#build * CertPathBuilder.build} method must implement this interface. *

    - * At a minimum, a CertPathBuilderResult contains the - * CertPath built by the CertPathBuilder instance. + * At a minimum, a {@code CertPathBuilderResult} contains the + * {@code CertPath} built by the {@code CertPathBuilder} instance. * Implementations of this interface may add methods to return implementation * or algorithm specific information, such as debugging information or * certification path validation results. @@ -54,15 +54,15 @@ public interface CertPathBuilderResult extends Cloneable { /** * Returns the built certification path. * - * @return the certification path (never null) + * @return the certification path (never {@code null}) */ CertPath getCertPath(); /** - * Makes a copy of this CertPathBuilderResult. Changes to the + * Makes a copy of this {@code CertPathBuilderResult}. Changes to the * copy will not affect the original and vice versa. * - * @return a copy of this CertPathBuilderResult + * @return a copy of this {@code CertPathBuilderResult} */ Object clone(); } diff --git a/jdk/src/share/classes/java/security/cert/CertPathBuilderSpi.java b/jdk/src/share/classes/java/security/cert/CertPathBuilderSpi.java index 49a35b36e90..87908c03bd9 100644 --- a/jdk/src/share/classes/java/security/cert/CertPathBuilderSpi.java +++ b/jdk/src/share/classes/java/security/cert/CertPathBuilderSpi.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -30,23 +30,23 @@ import java.security.InvalidAlgorithmParameterException; /** * The Service Provider Interface (SPI) * for the {@link CertPathBuilder CertPathBuilder} class. All - * CertPathBuilder implementations must include a class (the - * SPI class) that extends this class (CertPathBuilderSpi) and + * {@code CertPathBuilder} implementations must include a class (the + * SPI class) that extends this class ({@code CertPathBuilderSpi}) and * implements all of its methods. In general, instances of this class should - * only be accessed through the CertPathBuilder class. For + * only be accessed through the {@code CertPathBuilder} class. For * details, see the Java Cryptography Architecture. *

    * Concurrent Access *

    * Instances of this class need not be protected against concurrent * access from multiple threads. Threads that need to access a single - * CertPathBuilderSpi instance concurrently should synchronize + * {@code CertPathBuilderSpi} instance concurrently should synchronize * amongst themselves and provide the necessary locking before calling the - * wrapping CertPathBuilder object. + * wrapping {@code CertPathBuilder} object. *

    - * However, implementations of CertPathBuilderSpi may still + * However, implementations of {@code CertPathBuilderSpi} may still * encounter concurrency issues, since multiple threads each - * manipulating a different CertPathBuilderSpi instance need not + * manipulating a different {@code CertPathBuilderSpi} instance need not * synchronize. * * @since 1.4 @@ -68,7 +68,7 @@ public abstract class CertPathBuilderSpi { * @throws CertPathBuilderException if the builder is unable to construct * a certification path that satisfies the specified parameters * @throws InvalidAlgorithmParameterException if the specified parameters - * are inappropriate for this CertPathBuilder + * are inappropriate for this {@code CertPathBuilder} */ public abstract CertPathBuilderResult engineBuild(CertPathParameters params) throws CertPathBuilderException, InvalidAlgorithmParameterException; diff --git a/jdk/src/share/classes/java/security/cert/CertPathParameters.java b/jdk/src/share/classes/java/security/cert/CertPathParameters.java index 46f9d8841bc..ace1b21f63f 100644 --- a/jdk/src/share/classes/java/security/cert/CertPathParameters.java +++ b/jdk/src/share/classes/java/security/cert/CertPathParameters.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2001, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -28,8 +28,8 @@ package java.security.cert; /** * A specification of certification path algorithm parameters. * The purpose of this interface is to group (and provide type safety for) - * all CertPath parameter specifications. All - * CertPath parameter specifications must implement this + * all {@code CertPath} parameter specifications. All + * {@code CertPath} parameter specifications must implement this * interface. * * @author Yassir Elley @@ -40,10 +40,10 @@ package java.security.cert; public interface CertPathParameters extends Cloneable { /** - * Makes a copy of this CertPathParameters. Changes to the + * Makes a copy of this {@code CertPathParameters}. Changes to the * copy will not affect the original and vice versa. * - * @return a copy of this CertPathParameters + * @return a copy of this {@code CertPathParameters} */ Object clone(); } diff --git a/jdk/src/share/classes/java/security/cert/CertPathValidator.java b/jdk/src/share/classes/java/security/cert/CertPathValidator.java index 99ecb1e1603..bd2ff56dd0c 100644 --- a/jdk/src/share/classes/java/security/cert/CertPathValidator.java +++ b/jdk/src/share/classes/java/security/cert/CertPathValidator.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -42,17 +42,17 @@ import sun.security.jca.GetInstance.Instance; * chains). *

    * This class uses a provider-based architecture. - * To create a CertPathValidator, - * call one of the static getInstance methods, passing in the - * algorithm name of the CertPathValidator desired and + * To create a {@code CertPathValidator}, + * call one of the static {@code getInstance} methods, passing in the + * algorithm name of the {@code CertPathValidator} desired and * optionally the name of the provider desired. * - *

    Once a CertPathValidator object has been created, it can + *

    Once a {@code CertPathValidator} object has been created, it can * be used to validate certification paths by calling the {@link #validate - * validate} method and passing it the CertPath to be validated + * validate} method and passing it the {@code CertPath} to be validated * and an algorithm-specific set of parameters. If successful, the result is * returned in an object that implements the - * CertPathValidatorResult interface. + * {@code CertPathValidatorResult} interface. * *

    The {@link #getRevocationChecker} method allows an application to specify * additional algorithm-specific parameters and options used by the @@ -69,9 +69,9 @@ import sun.security.jca.GetInstance.Instance; * * *

    Every implementation of the Java platform is required to support the - * following standard CertPathValidator algorithm: + * following standard {@code CertPathValidator} algorithm: *

      - *
    • PKIX
    • + *
    • {@code PKIX}
    • *
    * This algorithm is described in the @@ -89,9 +89,9 @@ import sun.security.jca.GetInstance.Instance; *

    * However, this is not true for the non-static methods defined by this class. * Unless otherwise documented by a specific provider, threads that need to - * access a single CertPathValidator instance concurrently should + * access a single {@code CertPathValidator} instance concurrently should * synchronize amongst themselves and provide the necessary locking. Multiple - * threads each manipulating a different CertPathValidator + * threads each manipulating a different {@code CertPathValidator} * instance need not synchronize. * * @see CertPath @@ -115,7 +115,7 @@ public class CertPathValidator { private final String algorithm; /** - * Creates a CertPathValidator object of the given algorithm, + * Creates a {@code CertPathValidator} object of the given algorithm, * and encapsulates the given provider implementation (SPI object) in it. * * @param validatorSpi the provider implementation @@ -131,7 +131,7 @@ public class CertPathValidator { } /** - * Returns a CertPathValidator object that implements the + * Returns a {@code CertPathValidator} object that implements the * specified algorithm. * *

    This method traverses the list of registered security Providers, @@ -143,13 +143,13 @@ public class CertPathValidator { *

    Note that the list of registered providers may be retrieved via * the {@link Security#getProviders() Security.getProviders()} method. * - * @param algorithm the name of the requested CertPathValidator + * @param algorithm the name of the requested {@code CertPathValidator} * algorithm. See the CertPathValidator section in the * Java Cryptography Architecture Standard Algorithm Name Documentation * for information about standard algorithm names. * - * @return a CertPathValidator object that implements the + * @return a {@code CertPathValidator} object that implements the * specified algorithm. * * @exception NoSuchAlgorithmException if no Provider supports a @@ -167,7 +167,7 @@ public class CertPathValidator { } /** - * Returns a CertPathValidator object that implements the + * Returns a {@code CertPathValidator} object that implements the * specified algorithm. * *

    A new CertPathValidator object encapsulating the @@ -178,7 +178,7 @@ public class CertPathValidator { *

    Note that the list of registered providers may be retrieved via * the {@link Security#getProviders() Security.getProviders()} method. * - * @param algorithm the name of the requested CertPathValidator + * @param algorithm the name of the requested {@code CertPathValidator} * algorithm. See the CertPathValidator section in the * Java Cryptography Architecture Standard Algorithm Name Documentation @@ -186,7 +186,7 @@ public class CertPathValidator { * * @param provider the name of the provider. * - * @return a CertPathValidator object that implements the + * @return a {@code CertPathValidator} object that implements the * specified algorithm. * * @exception NoSuchAlgorithmException if a CertPathValidatorSpi @@ -196,7 +196,7 @@ public class CertPathValidator { * @exception NoSuchProviderException if the specified provider is not * registered in the security provider list. * - * @exception IllegalArgumentException if the provider is + * @exception IllegalArgumentException if the {@code provider} is * null or empty. * * @see java.security.Provider @@ -211,7 +211,7 @@ public class CertPathValidator { } /** - * Returns a CertPathValidator object that implements the + * Returns a {@code CertPathValidator} object that implements the * specified algorithm. * *

    A new CertPathValidator object encapsulating the @@ -219,7 +219,7 @@ public class CertPathValidator { * object is returned. Note that the specified Provider object * does not have to be registered in the provider list. * - * @param algorithm the name of the requested CertPathValidator + * @param algorithm the name of the requested {@code CertPathValidator} * algorithm. See the CertPathValidator section in the * Java Cryptography Architecture Standard Algorithm Name Documentation @@ -227,14 +227,14 @@ public class CertPathValidator { * * @param provider the provider. * - * @return a CertPathValidator object that implements the + * @return a {@code CertPathValidator} object that implements the * specified algorithm. * * @exception NoSuchAlgorithmException if a CertPathValidatorSpi * implementation for the specified algorithm is not available * from the specified Provider object. * - * @exception IllegalArgumentException if the provider is + * @exception IllegalArgumentException if the {@code provider} is * null. * * @see java.security.Provider @@ -248,19 +248,19 @@ public class CertPathValidator { } /** - * Returns the Provider of this - * CertPathValidator. + * Returns the {@code Provider} of this + * {@code CertPathValidator}. * - * @return the Provider of this CertPathValidator + * @return the {@code Provider} of this {@code CertPathValidator} */ public final Provider getProvider() { return this.provider; } /** - * Returns the algorithm name of this CertPathValidator. + * Returns the algorithm name of this {@code CertPathValidator}. * - * @return the algorithm name of this CertPathValidator + * @return the algorithm name of this {@code CertPathValidator} */ public final String getAlgorithm() { return this.algorithm; @@ -270,20 +270,20 @@ public class CertPathValidator { * Validates the specified certification path using the specified * algorithm parameter set. *

    - * The CertPath specified must be of a type that is + * The {@code CertPath} specified must be of a type that is * supported by the validation algorithm, otherwise an - * InvalidAlgorithmParameterException will be thrown. For - * example, a CertPathValidator that implements the PKIX - * algorithm validates CertPath objects of type X.509. + * {@code InvalidAlgorithmParameterException} will be thrown. For + * example, a {@code CertPathValidator} that implements the PKIX + * algorithm validates {@code CertPath} objects of type X.509. * - * @param certPath the CertPath to be validated + * @param certPath the {@code CertPath} to be validated * @param params the algorithm parameters * @return the result of the validation algorithm - * @exception CertPathValidatorException if the CertPath + * @exception CertPathValidatorException if the {@code CertPath} * does not validate * @exception InvalidAlgorithmParameterException if the specified - * parameters or the type of the specified CertPath are - * inappropriate for this CertPathValidator + * parameters or the type of the specified {@code CertPath} are + * inappropriate for this {@code CertPathValidator} */ public final CertPathValidatorResult validate(CertPath certPath, CertPathParameters params) diff --git a/jdk/src/share/classes/java/security/cert/CertPathValidatorException.java b/jdk/src/share/classes/java/security/cert/CertPathValidatorException.java index 03cae751a0f..7e6b9165fae 100644 --- a/jdk/src/share/classes/java/security/cert/CertPathValidatorException.java +++ b/jdk/src/share/classes/java/security/cert/CertPathValidatorException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -34,11 +34,11 @@ import java.security.GeneralSecurityException; * An exception indicating one of a variety of problems encountered when * validating a certification path. *

    - * A CertPathValidatorException provides support for wrapping + * A {@code CertPathValidatorException} provides support for wrapping * exceptions. The {@link #getCause getCause} method returns the throwable, * if any, that caused this exception to be thrown. *

    - * A CertPathValidatorException may also include the + * A {@code CertPathValidatorException} may also include the * certification path that was being validated when the exception was thrown, * the index of the certificate in the certification path that caused the * exception to be thrown, and the reason that caused the failure. Use the @@ -70,7 +70,7 @@ public class CertPathValidatorException extends GeneralSecurityException { private int index = -1; /** - * @serial the CertPath that was being validated when + * @serial the {@code CertPath} that was being validated when * the exception was thrown */ private CertPath certPath; @@ -81,7 +81,7 @@ public class CertPathValidatorException extends GeneralSecurityException { private Reason reason = BasicReason.UNSPECIFIED; /** - * Creates a CertPathValidatorException with + * Creates a {@code CertPathValidatorException} with * no detail message. */ public CertPathValidatorException() { @@ -89,8 +89,8 @@ public class CertPathValidatorException extends GeneralSecurityException { } /** - * Creates a CertPathValidatorException with the given - * detail message. A detail message is a String that + * Creates a {@code CertPathValidatorException} with the given + * detail message. A detail message is a {@code String} that * describes this particular exception. * * @param msg the detail message @@ -100,16 +100,16 @@ public class CertPathValidatorException extends GeneralSecurityException { } /** - * Creates a CertPathValidatorException that wraps the + * Creates a {@code CertPathValidatorException} that wraps the * specified throwable. This allows any exception to be converted into a - * CertPathValidatorException, while retaining information + * {@code CertPathValidatorException}, while retaining information * about the wrapped exception, which may be useful for debugging. The - * detail message is set to (cause==null ? null : cause.toString() - * ) (which typically contains the class and detail message of + * detail message is set to ({@code cause==null ? null : cause.toString()}) + * (which typically contains the class and detail message of * cause). * * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause getCause()} method). (A null value is + * {@link #getCause getCause()} method). (A {@code null} value is * permitted, and indicates that the cause is nonexistent or unknown.) */ public CertPathValidatorException(Throwable cause) { @@ -117,12 +117,12 @@ public class CertPathValidatorException extends GeneralSecurityException { } /** - * Creates a CertPathValidatorException with the specified + * Creates a {@code CertPathValidatorException} with the specified * detail message and cause. * * @param msg the detail message * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause getCause()} method). (A null value is + * {@link #getCause getCause()} method). (A {@code null} value is * permitted, and indicates that the cause is nonexistent or unknown.) */ public CertPathValidatorException(String msg, Throwable cause) { @@ -130,21 +130,21 @@ public class CertPathValidatorException extends GeneralSecurityException { } /** - * Creates a CertPathValidatorException with the specified + * Creates a {@code CertPathValidatorException} with the specified * detail message, cause, certification path, and index. * - * @param msg the detail message (or null if none) - * @param cause the cause (or null if none) + * @param msg the detail message (or {@code null} if none) + * @param cause the cause (or {@code null} if none) * @param certPath the certification path that was in the process of * being validated when the error was encountered * @param index the index of the certificate in the certification path * that caused the error (or -1 if not applicable). Note that - * the list of certificates in a CertPath is zero based. + * the list of certificates in a {@code CertPath} is zero based. * @throws IndexOutOfBoundsException if the index is out of range * {@code (index < -1 || (certPath != null && index >= * certPath.getCertificates().size()) } - * @throws IllegalArgumentException if certPath is - * null and index is not -1 + * @throws IllegalArgumentException if {@code certPath} is + * {@code null} and {@code index} is not -1 */ public CertPathValidatorException(String msg, Throwable cause, CertPath certPath, int index) { @@ -152,23 +152,23 @@ public class CertPathValidatorException extends GeneralSecurityException { } /** - * Creates a CertPathValidatorException with the specified + * Creates a {@code CertPathValidatorException} with the specified * detail message, cause, certification path, index, and reason. * - * @param msg the detail message (or null if none) - * @param cause the cause (or null if none) + * @param msg the detail message (or {@code null} if none) + * @param cause the cause (or {@code null} if none) * @param certPath the certification path that was in the process of * being validated when the error was encountered * @param index the index of the certificate in the certification path * that caused the error (or -1 if not applicable). Note that - * the list of certificates in a CertPath is zero based. + * the list of certificates in a {@code CertPath} is zero based. * @param reason the reason the validation failed * @throws IndexOutOfBoundsException if the index is out of range * {@code (index < -1 || (certPath != null && index >= * certPath.getCertificates().size()) } - * @throws IllegalArgumentException if certPath is - * null and index is not -1 - * @throws NullPointerException if reason is null + * @throws IllegalArgumentException if {@code certPath} is + * {@code null} and {@code index} is not -1 + * @throws NullPointerException if {@code reason} is {@code null} * * @since 1.7 */ @@ -194,8 +194,8 @@ public class CertPathValidatorException extends GeneralSecurityException { * Returns the certification path that was being validated when * the exception was thrown. * - * @return the CertPath that was being validated when - * the exception was thrown (or null if not specified) + * @return the {@code CertPath} that was being validated when + * the exception was thrown (or {@code null} if not specified) */ public CertPath getCertPath() { return this.certPath; @@ -204,7 +204,7 @@ public class CertPathValidatorException extends GeneralSecurityException { /** * Returns the index of the certificate in the certification path * that caused the exception to be thrown. Note that the list of - * certificates in a CertPath is zero based. If no + * certificates in a {@code CertPath} is zero based. If no * index has been set, -1 is returned. * * @return the index that has been set, or -1 if none has been set @@ -219,7 +219,7 @@ public class CertPathValidatorException extends GeneralSecurityException { * {@link #getIndex}. * * @return the reason that the validation failed, or - * BasicReason.UNSPECIFIED if a reason has not been + * {@code BasicReason.UNSPECIFIED} if a reason has not been * specified * * @since 1.7 diff --git a/jdk/src/share/classes/java/security/cert/CertPathValidatorResult.java b/jdk/src/share/classes/java/security/cert/CertPathValidatorResult.java index 1756db6329f..ae07dc497a9 100644 --- a/jdk/src/share/classes/java/security/cert/CertPathValidatorResult.java +++ b/jdk/src/share/classes/java/security/cert/CertPathValidatorResult.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2001, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -41,10 +41,10 @@ package java.security.cert; public interface CertPathValidatorResult extends Cloneable { /** - * Makes a copy of this CertPathValidatorResult. Changes to the + * Makes a copy of this {@code CertPathValidatorResult}. Changes to the * copy will not affect the original and vice versa. * - * @return a copy of this CertPathValidatorResult + * @return a copy of this {@code CertPathValidatorResult} */ Object clone(); } diff --git a/jdk/src/share/classes/java/security/cert/CertPathValidatorSpi.java b/jdk/src/share/classes/java/security/cert/CertPathValidatorSpi.java index 6d3bd8c9968..50ad9c85c9b 100644 --- a/jdk/src/share/classes/java/security/cert/CertPathValidatorSpi.java +++ b/jdk/src/share/classes/java/security/cert/CertPathValidatorSpi.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -31,23 +31,23 @@ import java.security.InvalidAlgorithmParameterException; * * The Service Provider Interface (SPI) * for the {@link CertPathValidator CertPathValidator} class. All - * CertPathValidator implementations must include a class (the - * SPI class) that extends this class (CertPathValidatorSpi) + * {@code CertPathValidator} implementations must include a class (the + * SPI class) that extends this class ({@code CertPathValidatorSpi}) * and implements all of its methods. In general, instances of this class - * should only be accessed through the CertPathValidator class. + * should only be accessed through the {@code CertPathValidator} class. * For details, see the Java Cryptography Architecture. *

    * Concurrent Access *

    * Instances of this class need not be protected against concurrent * access from multiple threads. Threads that need to access a single - * CertPathValidatorSpi instance concurrently should synchronize + * {@code CertPathValidatorSpi} instance concurrently should synchronize * amongst themselves and provide the necessary locking before calling the - * wrapping CertPathValidator object. + * wrapping {@code CertPathValidator} object. *

    - * However, implementations of CertPathValidatorSpi may still + * However, implementations of {@code CertPathValidatorSpi} may still * encounter concurrency issues, since multiple threads each - * manipulating a different CertPathValidatorSpi instance need not + * manipulating a different {@code CertPathValidatorSpi} instance need not * synchronize. * * @since 1.4 @@ -64,20 +64,20 @@ public abstract class CertPathValidatorSpi { * Validates the specified certification path using the specified * algorithm parameter set. *

    - * The CertPath specified must be of a type that is + * The {@code CertPath} specified must be of a type that is * supported by the validation algorithm, otherwise an - * InvalidAlgorithmParameterException will be thrown. For - * example, a CertPathValidator that implements the PKIX - * algorithm validates CertPath objects of type X.509. + * {@code InvalidAlgorithmParameterException} will be thrown. For + * example, a {@code CertPathValidator} that implements the PKIX + * algorithm validates {@code CertPath} objects of type X.509. * - * @param certPath the CertPath to be validated + * @param certPath the {@code CertPath} to be validated * @param params the algorithm parameters * @return the result of the validation algorithm - * @exception CertPathValidatorException if the CertPath + * @exception CertPathValidatorException if the {@code CertPath} * does not validate * @exception InvalidAlgorithmParameterException if the specified - * parameters or the type of the specified CertPath are - * inappropriate for this CertPathValidator + * parameters or the type of the specified {@code CertPath} are + * inappropriate for this {@code CertPathValidator} */ public abstract CertPathValidatorResult engineValidate(CertPath certPath, CertPathParameters params) diff --git a/jdk/src/share/classes/java/security/cert/CertSelector.java b/jdk/src/share/classes/java/security/cert/CertSelector.java index 5ee1f7156cd..a06cc848019 100644 --- a/jdk/src/share/classes/java/security/cert/CertSelector.java +++ b/jdk/src/share/classes/java/security/cert/CertSelector.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2001, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -27,9 +27,9 @@ package java.security.cert; /** * A selector that defines a set of criteria for selecting - * Certificates. Classes that implement this interface - * are often used to specify which Certificates should - * be retrieved from a CertStore. + * {@code Certificate}s. Classes that implement this interface + * are often used to specify which {@code Certificate}s should + * be retrieved from a {@code CertStore}. *

    * Concurrent Access *

    @@ -49,19 +49,19 @@ package java.security.cert; public interface CertSelector extends Cloneable { /** - * Decides whether a Certificate should be selected. + * Decides whether a {@code Certificate} should be selected. * - * @param cert the Certificate to be checked - * @return true if the Certificate - * should be selected, false otherwise + * @param cert the {@code Certificate} to be checked + * @return {@code true} if the {@code Certificate} + * should be selected, {@code false} otherwise */ boolean match(Certificate cert); /** - * Makes a copy of this CertSelector. Changes to the + * Makes a copy of this {@code CertSelector}. Changes to the * copy will not affect the original and vice versa. * - * @return a copy of this CertSelector + * @return a copy of this {@code CertSelector} */ Object clone(); } diff --git a/jdk/src/share/classes/java/security/cert/CertStore.java b/jdk/src/share/classes/java/security/cert/CertStore.java index 1c6dedbf53c..1a8ed628c13 100644 --- a/jdk/src/share/classes/java/security/cert/CertStore.java +++ b/jdk/src/share/classes/java/security/cert/CertStore.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -38,32 +38,32 @@ import sun.security.jca.*; import sun.security.jca.GetInstance.Instance; /** - * A class for retrieving Certificates and CRLs + * A class for retrieving {@code Certificate}s and {@code CRL}s * from a repository. *

    * This class uses a provider-based architecture. - * To create a CertStore, call one of the static - * getInstance methods, passing in the type of - * CertStore desired, any applicable initialization parameters + * To create a {@code CertStore}, call one of the static + * {@code getInstance} methods, passing in the type of + * {@code CertStore} desired, any applicable initialization parameters * and optionally the name of the provider desired. *

    - * Once the CertStore has been created, it can be used to - * retrieve Certificates and CRLs by calling its + * Once the {@code CertStore} has been created, it can be used to + * retrieve {@code Certificate}s and {@code CRL}s by calling its * {@link #getCertificates(CertSelector selector) getCertificates} and * {@link #getCRLs(CRLSelector selector) getCRLs} methods. *

    * Unlike a {@link java.security.KeyStore KeyStore}, which provides access * to a cache of private keys and trusted certificates, a - * CertStore is designed to provide access to a potentially + * {@code CertStore} is designed to provide access to a potentially * vast repository of untrusted certificates and CRLs. For example, an LDAP - * implementation of CertStore provides access to certificates + * implementation of {@code CertStore} provides access to certificates * and CRLs stored in one or more directories using the LDAP protocol and the * schema as defined in the RFC service attribute. * *

    Every implementation of the Java platform is required to support the - * following standard CertStore type: + * following standard {@code CertStore} type: *

      - *
    • Collection
    • + *
    • {@code Collection}
    • *
    * This type is described in the @@ -75,10 +75,10 @@ import sun.security.jca.GetInstance.Instance; *

    * Concurrent Access *

    - * All public methods of CertStore objects must be thread-safe. + * All public methods of {@code CertStore} objects must be thread-safe. * That is, multiple threads may concurrently invoke these methods on a - * single CertStore object (or more than one) with no - * ill effects. This allows a CertPathBuilder to search for a + * single {@code CertStore} object (or more than one) with no + * ill effects. This allows a {@code CertPathBuilder} to search for a * CRL while simultaneously searching for further certificates, for instance. *

    * The static methods of this class are also guaranteed to be thread-safe. @@ -104,13 +104,13 @@ public class CertStore { private CertStoreParameters params; /** - * Creates a CertStore object of the given type, and + * Creates a {@code CertStore} object of the given type, and * encapsulates the given provider implementation (SPI object) in it. * * @param storeSpi the provider implementation * @param provider the provider * @param type the type - * @param params the initialization parameters (may be null) + * @param params the initialization parameters (may be {@code null}) */ protected CertStore(CertStoreSpi storeSpi, Provider provider, String type, CertStoreParameters params) { @@ -122,28 +122,28 @@ public class CertStore { } /** - * Returns a Collection of Certificates that - * match the specified selector. If no Certificates - * match the selector, an empty Collection will be returned. + * Returns a {@code Collection} of {@code Certificate}s that + * match the specified selector. If no {@code Certificate}s + * match the selector, an empty {@code Collection} will be returned. *

    - * For some CertStore types, the resulting - * Collection may not contain all of the - * Certificates that match the selector. For instance, - * an LDAP CertStore may not search all entries in the + * For some {@code CertStore} types, the resulting + * {@code Collection} may not contain all of the + * {@code Certificate}s that match the selector. For instance, + * an LDAP {@code CertStore} may not search all entries in the * directory. Instead, it may just search entries that are likely to - * contain the Certificates it is looking for. + * contain the {@code Certificate}s it is looking for. *

    - * Some CertStore implementations (especially LDAP - * CertStores) may throw a CertStoreException - * unless a non-null CertSelector is provided that + * Some {@code CertStore} implementations (especially LDAP + * {@code CertStore}s) may throw a {@code CertStoreException} + * unless a non-null {@code CertSelector} is provided that * includes specific criteria that can be used to find the certificates. * Issuer and/or subject names are especially useful criteria. * - * @param selector A CertSelector used to select which - * Certificates should be returned. Specify null - * to return all Certificates (if supported). - * @return A Collection of Certificates that - * match the specified selector (never null) + * @param selector A {@code CertSelector} used to select which + * {@code Certificate}s should be returned. Specify {@code null} + * to return all {@code Certificate}s (if supported). + * @return A {@code Collection} of {@code Certificate}s that + * match the specified selector (never {@code null}) * @throws CertStoreException if an exception occurs */ public final Collection getCertificates @@ -152,28 +152,28 @@ public class CertStore { } /** - * Returns a Collection of CRLs that - * match the specified selector. If no CRLs - * match the selector, an empty Collection will be returned. + * Returns a {@code Collection} of {@code CRL}s that + * match the specified selector. If no {@code CRL}s + * match the selector, an empty {@code Collection} will be returned. *

    - * For some CertStore types, the resulting - * Collection may not contain all of the - * CRLs that match the selector. For instance, - * an LDAP CertStore may not search all entries in the + * For some {@code CertStore} types, the resulting + * {@code Collection} may not contain all of the + * {@code CRL}s that match the selector. For instance, + * an LDAP {@code CertStore} may not search all entries in the * directory. Instead, it may just search entries that are likely to - * contain the CRLs it is looking for. + * contain the {@code CRL}s it is looking for. *

    - * Some CertStore implementations (especially LDAP - * CertStores) may throw a CertStoreException - * unless a non-null CRLSelector is provided that + * Some {@code CertStore} implementations (especially LDAP + * {@code CertStore}s) may throw a {@code CertStoreException} + * unless a non-null {@code CRLSelector} is provided that * includes specific criteria that can be used to find the CRLs. * Issuer names and/or the certificate to be checked are especially useful. * - * @param selector A CRLSelector used to select which - * CRLs should be returned. Specify null - * to return all CRLs (if supported). - * @return A Collection of CRLs that - * match the specified selector (never null) + * @param selector A {@code CRLSelector} used to select which + * {@code CRL}s should be returned. Specify {@code null} + * to return all {@code CRL}s (if supported). + * @return A {@code Collection} of {@code CRL}s that + * match the specified selector (never {@code null}) * @throws CertStoreException if an exception occurs */ public final Collection getCRLs(CRLSelector selector) @@ -182,8 +182,8 @@ public class CertStore { } /** - * Returns a CertStore object that implements the specified - * CertStore type and is initialized with the specified + * Returns a {@code CertStore} object that implements the specified + * {@code CertStore} type and is initialized with the specified * parameters. * *

    This method traverses the list of registered security Providers, @@ -195,29 +195,29 @@ public class CertStore { *

    Note that the list of registered providers may be retrieved via * the {@link Security#getProviders() Security.getProviders()} method. * - *

    The CertStore that is returned is initialized with the - * specified CertStoreParameters. The type of parameters - * needed may vary between different types of CertStores. - * Note that the specified CertStoreParameters object is + *

    The {@code CertStore} that is returned is initialized with the + * specified {@code CertStoreParameters}. The type of parameters + * needed may vary between different types of {@code CertStore}s. + * Note that the specified {@code CertStoreParameters} object is * cloned. * - * @param type the name of the requested CertStore type. + * @param type the name of the requested {@code CertStore} type. * See the CertStore section in the * Java Cryptography Architecture Standard Algorithm Name Documentation * for information about standard types. * - * @param params the initialization parameters (may be null). + * @param params the initialization parameters (may be {@code null}). * - * @return a CertStore object that implements the specified - * CertStore type. + * @return a {@code CertStore} object that implements the specified + * {@code CertStore} type. * * @throws NoSuchAlgorithmException if no Provider supports a * CertStoreSpi implementation for the specified type. * * @throws InvalidAlgorithmParameterException if the specified * initialization parameters are inappropriate for this - * CertStore. + * {@code CertStore}. * * @see java.security.Provider */ @@ -244,8 +244,8 @@ public class CertStore { } /** - * Returns a CertStore object that implements the specified - * CertStore type. + * Returns a {@code CertStore} object that implements the specified + * {@code CertStore} type. * *

    A new CertStore object encapsulating the * CertStoreSpi implementation from the specified provider @@ -255,23 +255,23 @@ public class CertStore { *

    Note that the list of registered providers may be retrieved via * the {@link Security#getProviders() Security.getProviders()} method. * - *

    The CertStore that is returned is initialized with the - * specified CertStoreParameters. The type of parameters - * needed may vary between different types of CertStores. - * Note that the specified CertStoreParameters object is + *

    The {@code CertStore} that is returned is initialized with the + * specified {@code CertStoreParameters}. The type of parameters + * needed may vary between different types of {@code CertStore}s. + * Note that the specified {@code CertStoreParameters} object is * cloned. * - * @param type the requested CertStore type. + * @param type the requested {@code CertStore} type. * See the CertStore section in the * Java Cryptography Architecture Standard Algorithm Name Documentation * for information about standard types. * - * @param params the initialization parameters (may be null). + * @param params the initialization parameters (may be {@code null}). * * @param provider the name of the provider. * - * @return a CertStore object that implements the + * @return a {@code CertStore} object that implements the * specified type. * * @throws NoSuchAlgorithmException if a CertStoreSpi @@ -280,12 +280,12 @@ public class CertStore { * * @throws InvalidAlgorithmParameterException if the specified * initialization parameters are inappropriate for this - * CertStore. + * {@code CertStore}. * * @throws NoSuchProviderException if the specified provider is not * registered in the security provider list. * - * @exception IllegalArgumentException if the provider is + * @exception IllegalArgumentException if the {@code provider} is * null or empty. * * @see java.security.Provider @@ -305,31 +305,31 @@ public class CertStore { } /** - * Returns a CertStore object that implements the specified - * CertStore type. + * Returns a {@code CertStore} object that implements the specified + * {@code CertStore} type. * *

    A new CertStore object encapsulating the * CertStoreSpi implementation from the specified Provider * object is returned. Note that the specified Provider object * does not have to be registered in the provider list. * - *

    The CertStore that is returned is initialized with the - * specified CertStoreParameters. The type of parameters - * needed may vary between different types of CertStores. - * Note that the specified CertStoreParameters object is + *

    The {@code CertStore} that is returned is initialized with the + * specified {@code CertStoreParameters}. The type of parameters + * needed may vary between different types of {@code CertStore}s. + * Note that the specified {@code CertStoreParameters} object is * cloned. * - * @param type the requested CertStore type. + * @param type the requested {@code CertStore} type. * See the CertStore section in the * Java Cryptography Architecture Standard Algorithm Name Documentation * for information about standard types. * - * @param params the initialization parameters (may be null). + * @param params the initialization parameters (may be {@code null}). * * @param provider the provider. * - * @return a CertStore object that implements the + * @return a {@code CertStore} object that implements the * specified type. * * @exception NoSuchAlgorithmException if a CertStoreSpi @@ -338,9 +338,9 @@ public class CertStore { * * @throws InvalidAlgorithmParameterException if the specified * initialization parameters are inappropriate for this - * CertStore + * {@code CertStore} * - * @exception IllegalArgumentException if the provider is + * @exception IllegalArgumentException if the {@code provider} is * null. * * @see java.security.Provider @@ -359,30 +359,30 @@ public class CertStore { } /** - * Returns the parameters used to initialize this CertStore. - * Note that the CertStoreParameters object is cloned before + * Returns the parameters used to initialize this {@code CertStore}. + * Note that the {@code CertStoreParameters} object is cloned before * it is returned. * - * @return the parameters used to initialize this CertStore - * (may be null) + * @return the parameters used to initialize this {@code CertStore} + * (may be {@code null}) */ public final CertStoreParameters getCertStoreParameters() { return (params == null ? null : (CertStoreParameters) params.clone()); } /** - * Returns the type of this CertStore. + * Returns the type of this {@code CertStore}. * - * @return the type of this CertStore + * @return the type of this {@code CertStore} */ public final String getType() { return this.type; } /** - * Returns the provider of this CertStore. + * Returns the provider of this {@code CertStore}. * - * @return the provider of this CertStore + * @return the provider of this {@code CertStore} */ public final Provider getProvider() { return this.provider; diff --git a/jdk/src/share/classes/java/security/cert/CertStoreException.java b/jdk/src/share/classes/java/security/cert/CertStoreException.java index 31baf644e30..77b1c234664 100644 --- a/jdk/src/share/classes/java/security/cert/CertStoreException.java +++ b/jdk/src/share/classes/java/security/cert/CertStoreException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -29,9 +29,9 @@ import java.security.GeneralSecurityException; /** * An exception indicating one of a variety of problems retrieving - * certificates and CRLs from a CertStore. + * certificates and CRLs from a {@code CertStore}. *

    - * A CertStoreException provides support for wrapping + * A {@code CertStoreException} provides support for wrapping * exceptions. The {@link #getCause getCause} method returns the throwable, * if any, that caused this exception to be thrown. *

    @@ -53,7 +53,7 @@ public class CertStoreException extends GeneralSecurityException { private static final long serialVersionUID = 2395296107471573245L; /** - * Creates a CertStoreException with null as + * Creates a {@code CertStoreException} with {@code null} as * its detail message. */ public CertStoreException() { @@ -61,8 +61,8 @@ public class CertStoreException extends GeneralSecurityException { } /** - * Creates a CertStoreException with the given detail - * message. A detail message is a String that describes this + * Creates a {@code CertStoreException} with the given detail + * message. A detail message is a {@code String} that describes this * particular exception. * * @param msg the detail message @@ -72,15 +72,15 @@ public class CertStoreException extends GeneralSecurityException { } /** - * Creates a CertStoreException that wraps the specified + * Creates a {@code CertStoreException} that wraps the specified * throwable. This allows any exception to be converted into a - * CertStoreException, while retaining information about the + * {@code CertStoreException}, while retaining information about the * cause, which may be useful for debugging. The detail message is - * set to (cause==null ? null : cause.toString()) (which + * set to ({@code cause==null ? null : cause.toString()}) (which * typically contains the class and detail message of cause). * * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause getCause()} method). (A null value is + * {@link #getCause getCause()} method). (A {@code null} value is * permitted, and indicates that the cause is nonexistent or unknown.) */ public CertStoreException(Throwable cause) { @@ -88,12 +88,12 @@ public class CertStoreException extends GeneralSecurityException { } /** - * Creates a CertStoreException with the specified detail + * Creates a {@code CertStoreException} with the specified detail * message and cause. * * @param msg the detail message * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause getCause()} method). (A null value is + * {@link #getCause getCause()} method). (A {@code null} value is * permitted, and indicates that the cause is nonexistent or unknown.) */ public CertStoreException(String msg, Throwable cause) { diff --git a/jdk/src/share/classes/java/security/cert/CertStoreParameters.java b/jdk/src/share/classes/java/security/cert/CertStoreParameters.java index d410dc7f332..9938ba25438 100644 --- a/jdk/src/share/classes/java/security/cert/CertStoreParameters.java +++ b/jdk/src/share/classes/java/security/cert/CertStoreParameters.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2001, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -26,20 +26,20 @@ package java.security.cert; /** - * A specification of CertStore parameters. + * A specification of {@code CertStore} parameters. *

    * The purpose of this interface is to group (and provide type safety for) - * all CertStore parameter specifications. All - * CertStore parameter specifications must implement this + * all {@code CertStore} parameter specifications. All + * {@code CertStore} parameter specifications must implement this * interface. *

    - * Typically, a CertStoreParameters object is passed as a parameter + * Typically, a {@code CertStoreParameters} object is passed as a parameter * to one of the {@link CertStore#getInstance CertStore.getInstance} methods. - * The getInstance method returns a CertStore that - * is used for retrieving Certificates and CRLs. The - * CertStore that is returned is initialized with the specified + * The {@code getInstance} method returns a {@code CertStore} that + * is used for retrieving {@code Certificate}s and {@code CRL}s. The + * {@code CertStore} that is returned is initialized with the specified * parameters. The type of parameters needed may vary between different types - * of CertStores. + * of {@code CertStore}s. * * @see CertStore#getInstance * @@ -49,32 +49,32 @@ package java.security.cert; public interface CertStoreParameters extends Cloneable { /** - * Makes a copy of this CertStoreParameters. + * Makes a copy of this {@code CertStoreParameters}. *

    * The precise meaning of "copy" may depend on the class of - * the CertStoreParameters object. A typical implementation + * the {@code CertStoreParameters} object. A typical implementation * performs a "deep copy" of this object, but this is not an absolute * requirement. Some implementations may perform a "shallow copy" of some * or all of the fields of this object. *

    - * Note that the CertStore.getInstance methods make a copy - * of the specified CertStoreParameters. A deep copy - * implementation of clone is safer and more robust, as it - * prevents the caller from corrupting a shared CertStore by + * Note that the {@code CertStore.getInstance} methods make a copy + * of the specified {@code CertStoreParameters}. A deep copy + * implementation of {@code clone} is safer and more robust, as it + * prevents the caller from corrupting a shared {@code CertStore} by * subsequently modifying the contents of its initialization parameters. - * However, a shallow copy implementation of clone is more + * However, a shallow copy implementation of {@code clone} is more * appropriate for applications that need to hold a reference to a - * parameter contained in the CertStoreParameters. For example, + * parameter contained in the {@code CertStoreParameters}. For example, * a shallow copy clone allows an application to release the resources of - * a particular CertStore initialization parameter immediately, + * a particular {@code CertStore} initialization parameter immediately, * rather than waiting for the garbage collection mechanism. This should - * be done with the utmost care, since the CertStore may still + * be done with the utmost care, since the {@code CertStore} may still * be in use by other threads. *

    * Each subclass should state the precise behavior of this method so * that users and developers know what to expect. * - * @return a copy of this CertStoreParameters + * @return a copy of this {@code CertStoreParameters} */ Object clone(); } diff --git a/jdk/src/share/classes/java/security/cert/CertStoreSpi.java b/jdk/src/share/classes/java/security/cert/CertStoreSpi.java index ddcf2bc3f37..fc98e9ebcf0 100644 --- a/jdk/src/share/classes/java/security/cert/CertStoreSpi.java +++ b/jdk/src/share/classes/java/security/cert/CertStoreSpi.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -30,26 +30,26 @@ import java.util.Collection; /** * The Service Provider Interface (SPI) - * for the {@link CertStore CertStore} class. All CertStore + * for the {@link CertStore CertStore} class. All {@code CertStore} * implementations must include a class (the SPI class) that extends - * this class (CertStoreSpi), provides a constructor with - * a single argument of type CertStoreParameters, and implements + * this class ({@code CertStoreSpi}), provides a constructor with + * a single argument of type {@code CertStoreParameters}, and implements * all of its methods. In general, instances of this class should only be - * accessed through the CertStore class. + * accessed through the {@code CertStore} class. * For details, see the Java Cryptography Architecture. *

    * Concurrent Access *

    - * The public methods of all CertStoreSpi objects must be + * The public methods of all {@code CertStoreSpi} objects must be * thread-safe. That is, multiple threads may concurrently invoke these - * methods on a single CertStoreSpi object (or more than one) - * with no ill effects. This allows a CertPathBuilder to search + * methods on a single {@code CertStoreSpi} object (or more than one) + * with no ill effects. This allows a {@code CertPathBuilder} to search * for a CRL while simultaneously searching for further certificates, for * instance. *

    - * Simple CertStoreSpi implementations will probably ensure - * thread safety by adding a synchronized keyword to their - * engineGetCertificates and engineGetCRLs methods. + * Simple {@code CertStoreSpi} implementations will probably ensure + * thread safety by adding a {@code synchronized} keyword to their + * {@code engineGetCertificates} and {@code engineGetCRLs} methods. * More sophisticated ones may allow truly concurrent access. * * @since 1.4 @@ -60,64 +60,64 @@ public abstract class CertStoreSpi { /** * The sole constructor. * - * @param params the initialization parameters (may be null) + * @param params the initialization parameters (may be {@code null}) * @throws InvalidAlgorithmParameterException if the initialization - * parameters are inappropriate for this CertStoreSpi + * parameters are inappropriate for this {@code CertStoreSpi} */ public CertStoreSpi(CertStoreParameters params) throws InvalidAlgorithmParameterException { } /** - * Returns a Collection of Certificates that - * match the specified selector. If no Certificates - * match the selector, an empty Collection will be returned. + * Returns a {@code Collection} of {@code Certificate}s that + * match the specified selector. If no {@code Certificate}s + * match the selector, an empty {@code Collection} will be returned. *

    - * For some CertStore types, the resulting - * Collection may not contain all of the - * Certificates that match the selector. For instance, - * an LDAP CertStore may not search all entries in the + * For some {@code CertStore} types, the resulting + * {@code Collection} may not contain all of the + * {@code Certificate}s that match the selector. For instance, + * an LDAP {@code CertStore} may not search all entries in the * directory. Instead, it may just search entries that are likely to - * contain the Certificates it is looking for. + * contain the {@code Certificate}s it is looking for. *

    - * Some CertStore implementations (especially LDAP - * CertStores) may throw a CertStoreException - * unless a non-null CertSelector is provided that includes + * Some {@code CertStore} implementations (especially LDAP + * {@code CertStore}s) may throw a {@code CertStoreException} + * unless a non-null {@code CertSelector} is provided that includes * specific criteria that can be used to find the certificates. Issuer * and/or subject names are especially useful criteria. * - * @param selector A CertSelector used to select which - * Certificates should be returned. Specify null - * to return all Certificates (if supported). - * @return A Collection of Certificates that - * match the specified selector (never null) + * @param selector A {@code CertSelector} used to select which + * {@code Certificate}s should be returned. Specify {@code null} + * to return all {@code Certificate}s (if supported). + * @return A {@code Collection} of {@code Certificate}s that + * match the specified selector (never {@code null}) * @throws CertStoreException if an exception occurs */ public abstract Collection engineGetCertificates (CertSelector selector) throws CertStoreException; /** - * Returns a Collection of CRLs that - * match the specified selector. If no CRLs - * match the selector, an empty Collection will be returned. + * Returns a {@code Collection} of {@code CRL}s that + * match the specified selector. If no {@code CRL}s + * match the selector, an empty {@code Collection} will be returned. *

    - * For some CertStore types, the resulting - * Collection may not contain all of the - * CRLs that match the selector. For instance, - * an LDAP CertStore may not search all entries in the + * For some {@code CertStore} types, the resulting + * {@code Collection} may not contain all of the + * {@code CRL}s that match the selector. For instance, + * an LDAP {@code CertStore} may not search all entries in the * directory. Instead, it may just search entries that are likely to - * contain the CRLs it is looking for. + * contain the {@code CRL}s it is looking for. *

    - * Some CertStore implementations (especially LDAP - * CertStores) may throw a CertStoreException - * unless a non-null CRLSelector is provided that includes + * Some {@code CertStore} implementations (especially LDAP + * {@code CertStore}s) may throw a {@code CertStoreException} + * unless a non-null {@code CRLSelector} is provided that includes * specific criteria that can be used to find the CRLs. Issuer names * and/or the certificate to be checked are especially useful. * - * @param selector A CRLSelector used to select which - * CRLs should be returned. Specify null - * to return all CRLs (if supported). - * @return A Collection of CRLs that - * match the specified selector (never null) + * @param selector A {@code CRLSelector} used to select which + * {@code CRL}s should be returned. Specify {@code null} + * to return all {@code CRL}s (if supported). + * @return A {@code Collection} of {@code CRL}s that + * match the specified selector (never {@code null}) * @throws CertStoreException if an exception occurs */ public abstract Collection engineGetCRLs diff --git a/jdk/src/share/classes/java/security/cert/Certificate.java b/jdk/src/share/classes/java/security/cert/Certificate.java index 80390ac129c..638a02e6f80 100644 --- a/jdk/src/share/classes/java/security/cert/Certificate.java +++ b/jdk/src/share/classes/java/security/cert/Certificate.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -90,8 +90,8 @@ public abstract class Certificate implements java.io.Serializable { /** * Compares this certificate for equality with the specified - * object. If the other object is an - * instanceof Certificate, then + * object. If the {@code other} object is an + * {@code instanceof} {@code Certificate}, then * its encoded form is retrieved and compared with the * encoded form of this certificate. * @@ -196,8 +196,8 @@ public abstract class Certificate implements java.io.Serializable { * *

    This method was added to version 1.8 of the Java Platform * Standard Edition. In order to maintain backwards compatibility with - * existing service providers, this method cannot be abstract - * and by default throws an UnsupportedOperationException. + * existing service providers, this method cannot be {@code abstract} + * and by default throws an {@code UnsupportedOperationException}. * * @param key the PublicKey used to carry out the verification. * @param sigProvider the signature provider. diff --git a/jdk/src/share/classes/java/security/cert/CertificateEncodingException.java b/jdk/src/share/classes/java/security/cert/CertificateEncodingException.java index dbfc22ca8ce..618ee0a55b9 100644 --- a/jdk/src/share/classes/java/security/cert/CertificateEncodingException.java +++ b/jdk/src/share/classes/java/security/cert/CertificateEncodingException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -56,13 +56,13 @@ public class CertificateEncodingException extends CertificateException { } /** - * Creates a CertificateEncodingException with the specified + * Creates a {@code CertificateEncodingException} with the specified * detail message and cause. * * @param message the detail message (which is saved for later retrieval * by the {@link #getMessage()} method). * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause()} method). (A null value is permitted, + * {@link #getCause()} method). (A {@code null} value is permitted, * and indicates that the cause is nonexistent or unknown.) * @since 1.5 */ @@ -71,14 +71,14 @@ public class CertificateEncodingException extends CertificateException { } /** - * Creates a CertificateEncodingException + * Creates a {@code CertificateEncodingException} * with the specified cause and a detail message of - * (cause==null ? null : cause.toString()) + * {@code (cause==null ? null : cause.toString())} * (which typically contains the class and detail message of - * cause). + * {@code cause}). * * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause()} method). (A null value is permitted, + * {@link #getCause()} method). (A {@code null} value is permitted, * and indicates that the cause is nonexistent or unknown.) * @since 1.5 */ diff --git a/jdk/src/share/classes/java/security/cert/CertificateException.java b/jdk/src/share/classes/java/security/cert/CertificateException.java index 1c91f9f0ebb..f663054000b 100644 --- a/jdk/src/share/classes/java/security/cert/CertificateException.java +++ b/jdk/src/share/classes/java/security/cert/CertificateException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2013, 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 @@ -57,13 +57,13 @@ public class CertificateException extends GeneralSecurityException { } /** - * Creates a CertificateException with the specified + * Creates a {@code CertificateException} with the specified * detail message and cause. * * @param message the detail message (which is saved for later retrieval * by the {@link #getMessage()} method). * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause()} method). (A null value is permitted, + * {@link #getCause()} method). (A {@code null} value is permitted, * and indicates that the cause is nonexistent or unknown.) * @since 1.5 */ @@ -72,13 +72,13 @@ public class CertificateException extends GeneralSecurityException { } /** - * Creates a CertificateException with the specified cause - * and a detail message of (cause==null ? null : cause.toString()) + * Creates a {@code CertificateException} with the specified cause + * and a detail message of {@code (cause==null ? null : cause.toString())} * (which typically contains the class and detail message of - * cause). + * {@code cause}). * * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause()} method). (A null value is permitted, + * {@link #getCause()} method). (A {@code null} value is permitted, * and indicates that the cause is nonexistent or unknown.) * @since 1.5 */ diff --git a/jdk/src/share/classes/java/security/cert/CertificateExpiredException.java b/jdk/src/share/classes/java/security/cert/CertificateExpiredException.java index e5644fa7ff0..9de0c236c13 100644 --- a/jdk/src/share/classes/java/security/cert/CertificateExpiredException.java +++ b/jdk/src/share/classes/java/security/cert/CertificateExpiredException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -27,8 +27,8 @@ package java.security.cert; /** * Certificate Expired Exception. This is thrown whenever the current - * Date or the specified Date is after the - * notAfter date/time specified in the validity period + * {@code Date} or the specified {@code Date} is after the + * {@code notAfter} date/time specified in the validity period * of the certificate. * * @author Hemma Prafullchandra diff --git a/jdk/src/share/classes/java/security/cert/CertificateFactory.java b/jdk/src/share/classes/java/security/cert/CertificateFactory.java index d0762df16be..83ff9fbee92 100644 --- a/jdk/src/share/classes/java/security/cert/CertificateFactory.java +++ b/jdk/src/share/classes/java/security/cert/CertificateFactory.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2013, 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 @@ -41,27 +41,27 @@ import sun.security.jca.GetInstance.Instance; /** * This class defines the functionality of a certificate factory, which is - * used to generate certificate, certification path (CertPath) + * used to generate certificate, certification path ({@code CertPath}) * and certificate revocation list (CRL) objects from their encodings. * *

    For encodings consisting of multiple certificates, use - * generateCertificates when you want to + * {@code generateCertificates} when you want to * parse a collection of possibly unrelated certificates. Otherwise, - * use generateCertPath when you want to generate - * a CertPath (a certificate chain) and subsequently - * validate it with a CertPathValidator. + * use {@code generateCertPath} when you want to generate + * a {@code CertPath} (a certificate chain) and subsequently + * validate it with a {@code CertPathValidator}. * *

    A certificate factory for X.509 must return certificates that are an - * instance of java.security.cert.X509Certificate, and CRLs - * that are an instance of java.security.cert.X509CRL. + * instance of {@code java.security.cert.X509Certificate}, and CRLs + * that are an instance of {@code java.security.cert.X509CRL}. * *

    The following example reads a file with Base64 encoded certificates, * which are each bounded at the beginning by -----BEGIN CERTIFICATE-----, and * bounded at the end by -----END CERTIFICATE-----. We convert the - * FileInputStream (which does not support mark - * and reset) to a BufferedInputStream (which + * {@code FileInputStream} (which does not support {@code mark} + * and {@code reset}) to a {@code BufferedInputStream} (which * supports those methods), so that each call to - * generateCertificate consumes only one certificate, and the + * {@code generateCertificate} consumes only one certificate, and the * read position of the input stream is positioned to the next certificate in * the file:

    * @@ -92,14 +92,14 @@ import sun.security.jca.GetInstance.Instance; * * *

    Every implementation of the Java platform is required to support the - * following standard CertificateFactory type: + * following standard {@code CertificateFactory} type: *

      - *
    • X.509
    • + *
    • {@code X.509}
    • *
    - * and the following standard CertPath encodings: + * and the following standard {@code CertPath} encodings: *
      - *
    • PKCS7
    • - *
    • PkiPath
    • + *
    • {@code PKCS7}
    • + *
    • {@code PkiPath}
    • *
    * The type and encodings are described in the @@ -258,7 +258,7 @@ public class CertificateFactory { * implementation for the specified algorithm is not available * from the specified Provider object. * - * @exception IllegalArgumentException if the provider is + * @exception IllegalArgumentException if the {@code provider} is * null. * * @see java.security.Provider @@ -299,17 +299,17 @@ public class CertificateFactory { /** * Generates a certificate object and initializes it with - * the data read from the input stream inStream. + * the data read from the input stream {@code inStream}. * *

    In order to take advantage of the specialized certificate format * supported by this certificate factory, * the returned certificate object can be typecast to the corresponding * certificate class. For example, if this certificate * factory implements X.509 certificates, the returned certificate object - * can be typecast to the X509Certificate class. + * can be typecast to the {@code X509Certificate} class. * *

    In the case of a certificate factory for X.509 certificates, the - * certificate provided in inStream must be DER-encoded and + * certificate provided in {@code inStream} must be DER-encoded and * may be supplied in binary or printable (Base64) encoding. If the * certificate is provided in Base64 encoding, it must be bounded at * the beginning by -----BEGIN CERTIFICATE-----, and must be bounded at @@ -324,7 +324,7 @@ public class CertificateFactory { * the inherent end-of-certificate marker. If the data in the input stream * does not contain an inherent end-of-certificate marker (other * than EOF) and there is trailing data after the certificate is parsed, a - * CertificateException is thrown. + * {@code CertificateException} is thrown. * * @param inStream an input stream with the certificate data. * @@ -340,19 +340,19 @@ public class CertificateFactory { } /** - * Returns an iteration of the CertPath encodings supported + * Returns an iteration of the {@code CertPath} encodings supported * by this certificate factory, with the default encoding first. See * the CertPath Encodings section in the * Java Cryptography Architecture Standard Algorithm Name Documentation * for information about standard encoding names and their formats. *

    - * Attempts to modify the returned Iterator via its - * remove method result in an - * UnsupportedOperationException. + * Attempts to modify the returned {@code Iterator} via its + * {@code remove} method result in an + * {@code UnsupportedOperationException}. * - * @return an Iterator over the names of the supported - * CertPath encodings (as Strings) + * @return an {@code Iterator} over the names of the supported + * {@code CertPath} encodings (as {@code String}s) * @since 1.4 */ public final Iterator getCertPathEncodings() { @@ -360,15 +360,15 @@ public class CertificateFactory { } /** - * Generates a CertPath object and initializes it with - * the data read from the InputStream inStream. The data + * Generates a {@code CertPath} object and initializes it with + * the data read from the {@code InputStream} inStream. The data * is assumed to be in the default encoding. The name of the default - * encoding is the first element of the Iterator returned by + * encoding is the first element of the {@code Iterator} returned by * the {@link #getCertPathEncodings getCertPathEncodings} method. * - * @param inStream an InputStream containing the data - * @return a CertPath initialized with the data from the - * InputStream + * @param inStream an {@code InputStream} containing the data + * @return a {@code CertPath} initialized with the data from the + * {@code InputStream} * @exception CertificateException if an exception occurs while decoding * @since 1.4 */ @@ -379,18 +379,18 @@ public class CertificateFactory { } /** - * Generates a CertPath object and initializes it with - * the data read from the InputStream inStream. The data + * Generates a {@code CertPath} object and initializes it with + * the data read from the {@code InputStream} inStream. The data * is assumed to be in the specified encoding. See * the CertPath Encodings section in the * Java Cryptography Architecture Standard Algorithm Name Documentation * for information about standard encoding names and their formats. * - * @param inStream an InputStream containing the data + * @param inStream an {@code InputStream} containing the data * @param encoding the encoding used for the data - * @return a CertPath initialized with the data from the - * InputStream + * @return a {@code CertPath} initialized with the data from the + * {@code InputStream} * @exception CertificateException if an exception occurs while decoding or * the encoding requested is not supported * @since 1.4 @@ -402,15 +402,15 @@ public class CertificateFactory { } /** - * Generates a CertPath object and initializes it with - * a List of Certificates. + * Generates a {@code CertPath} object and initializes it with + * a {@code List} of {@code Certificate}s. *

    * The certificates supplied must be of a type supported by the - * CertificateFactory. They will be copied out of the supplied - * List object. + * {@code CertificateFactory}. They will be copied out of the supplied + * {@code List} object. * - * @param certificates a List of Certificates - * @return a CertPath initialized with the supplied list of + * @param certificates a {@code List} of {@code Certificate}s + * @return a {@code CertPath} initialized with the supplied list of * certificates * @exception CertificateException if an exception occurs * @since 1.4 @@ -424,20 +424,20 @@ public class CertificateFactory { /** * Returns a (possibly empty) collection view of the certificates read - * from the given input stream inStream. + * from the given input stream {@code inStream}. * *

    In order to take advantage of the specialized certificate format * supported by this certificate factory, each element in * the returned collection view can be typecast to the corresponding * certificate class. For example, if this certificate * factory implements X.509 certificates, the elements in the returned - * collection can be typecast to the X509Certificate class. + * collection can be typecast to the {@code X509Certificate} class. * *

    In the case of a certificate factory for X.509 certificates, - * inStream may contain a sequence of DER-encoded certificates + * {@code inStream} may contain a sequence of DER-encoded certificates * in the formats described for * {@link #generateCertificate(java.io.InputStream) generateCertificate}. - * In addition, inStream may contain a PKCS#7 certificate + * In addition, {@code inStream} may contain a PKCS#7 certificate * chain. This is a PKCS#7 SignedData object, with the only * significant field being certificates. In particular, the * signature and the contents are ignored. This format allows multiple @@ -464,14 +464,14 @@ public class CertificateFactory { /** * Generates a certificate revocation list (CRL) object and initializes it - * with the data read from the input stream inStream. + * with the data read from the input stream {@code inStream}. * *

    In order to take advantage of the specialized CRL format * supported by this certificate factory, * the returned CRL object can be typecast to the corresponding * CRL class. For example, if this certificate * factory implements X.509 CRLs, the returned CRL object - * can be typecast to the X509CRL class. + * can be typecast to the {@code X509CRL} class. * *

    Note that if the given input stream does not support * {@link java.io.InputStream#mark(int) mark} and @@ -482,7 +482,7 @@ public class CertificateFactory { * end-of-CRL marker. If the data in the * input stream does not contain an inherent end-of-CRL marker (other * than EOF) and there is trailing data after the CRL is parsed, a - * CRLException is thrown. + * {@code CRLException} is thrown. * * @param inStream an input stream with the CRL data. * @@ -499,18 +499,18 @@ public class CertificateFactory { /** * Returns a (possibly empty) collection view of the CRLs read - * from the given input stream inStream. + * from the given input stream {@code inStream}. * *

    In order to take advantage of the specialized CRL format * supported by this certificate factory, each element in * the returned collection view can be typecast to the corresponding * CRL class. For example, if this certificate * factory implements X.509 CRLs, the elements in the returned - * collection can be typecast to the X509CRL class. + * collection can be typecast to the {@code X509CRL} class. * *

    In the case of a certificate factory for X.509 CRLs, - * inStream may contain a sequence of DER-encoded CRLs. - * In addition, inStream may contain a PKCS#7 CRL + * {@code inStream} may contain a sequence of DER-encoded CRLs. + * In addition, {@code inStream} may contain a PKCS#7 CRL * set. This is a PKCS#7 SignedData object, with the only * significant field being crls. In particular, the * signature and the contents are ignored. This format allows multiple diff --git a/jdk/src/share/classes/java/security/cert/CertificateFactorySpi.java b/jdk/src/share/classes/java/security/cert/CertificateFactorySpi.java index 0912ba2a9f9..35aee847bb8 100644 --- a/jdk/src/share/classes/java/security/cert/CertificateFactorySpi.java +++ b/jdk/src/share/classes/java/security/cert/CertificateFactorySpi.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2013, 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 @@ -35,18 +35,18 @@ import java.security.NoSuchProviderException; /** * This class defines the Service Provider Interface (SPI) - * for the CertificateFactory class. + * for the {@code CertificateFactory} class. * All the abstract methods in this class must be implemented by each * cryptographic service provider who wishes to supply the implementation * of a certificate factory for a particular certificate type, e.g., X.509. * *

    Certificate factories are used to generate certificate, certification path - * (CertPath) and certificate revocation list (CRL) objects from + * ({@code CertPath}) and certificate revocation list (CRL) objects from * their encodings. * *

    A certificate factory for X.509 must return certificates that are an - * instance of java.security.cert.X509Certificate, and CRLs - * that are an instance of java.security.cert.X509CRL. + * instance of {@code java.security.cert.X509Certificate}, and CRLs + * that are an instance of {@code java.security.cert.X509CRL}. * * @author Hemma Prafullchandra * @author Jan Luehe @@ -67,17 +67,17 @@ public abstract class CertificateFactorySpi { /** * Generates a certificate object and initializes it with - * the data read from the input stream inStream. + * the data read from the input stream {@code inStream}. * *

    In order to take advantage of the specialized certificate format * supported by this certificate factory, * the returned certificate object can be typecast to the corresponding * certificate class. For example, if this certificate * factory implements X.509 certificates, the returned certificate object - * can be typecast to the X509Certificate class. + * can be typecast to the {@code X509Certificate} class. * *

    In the case of a certificate factory for X.509 certificates, the - * certificate provided in inStream must be DER-encoded and + * certificate provided in {@code inStream} must be DER-encoded and * may be supplied in binary or printable (Base64) encoding. If the * certificate is provided in Base64 encoding, it must be bounded at * the beginning by -----BEGIN CERTIFICATE-----, and must be bounded at @@ -92,7 +92,7 @@ public abstract class CertificateFactorySpi { * end-of-certificate marker. If the data in the * input stream does not contain an inherent end-of-certificate marker (other * than EOF) and there is trailing data after the certificate is parsed, a - * CertificateException is thrown. + * {@code CertificateException} is thrown. * * @param inStream an input stream with the certificate data. * @@ -105,18 +105,18 @@ public abstract class CertificateFactorySpi { throws CertificateException; /** - * Generates a CertPath object and initializes it with - * the data read from the InputStream inStream. The data + * Generates a {@code CertPath} object and initializes it with + * the data read from the {@code InputStream} inStream. The data * is assumed to be in the default encoding. * *

    This method was added to version 1.4 of the Java 2 Platform * Standard Edition. In order to maintain backwards compatibility with - * existing service providers, this method cannot be abstract - * and by default throws an UnsupportedOperationException. + * existing service providers, this method cannot be {@code abstract} + * and by default throws an {@code UnsupportedOperationException}. * - * @param inStream an InputStream containing the data - * @return a CertPath initialized with the data from the - * InputStream + * @param inStream an {@code InputStream} containing the data + * @return a {@code CertPath} initialized with the data from the + * {@code InputStream} * @exception CertificateException if an exception occurs while decoding * @exception UnsupportedOperationException if the method is not supported * @since 1.4 @@ -128,19 +128,19 @@ public abstract class CertificateFactorySpi { } /** - * Generates a CertPath object and initializes it with - * the data read from the InputStream inStream. The data + * Generates a {@code CertPath} object and initializes it with + * the data read from the {@code InputStream} inStream. The data * is assumed to be in the specified encoding. * *

    This method was added to version 1.4 of the Java 2 Platform * Standard Edition. In order to maintain backwards compatibility with - * existing service providers, this method cannot be abstract - * and by default throws an UnsupportedOperationException. + * existing service providers, this method cannot be {@code abstract} + * and by default throws an {@code UnsupportedOperationException}. * - * @param inStream an InputStream containing the data + * @param inStream an {@code InputStream} containing the data * @param encoding the encoding used for the data - * @return a CertPath initialized with the data from the - * InputStream + * @return a {@code CertPath} initialized with the data from the + * {@code InputStream} * @exception CertificateException if an exception occurs while decoding or * the encoding requested is not supported * @exception UnsupportedOperationException if the method is not supported @@ -153,20 +153,20 @@ public abstract class CertificateFactorySpi { } /** - * Generates a CertPath object and initializes it with - * a List of Certificates. + * Generates a {@code CertPath} object and initializes it with + * a {@code List} of {@code Certificate}s. *

    * The certificates supplied must be of a type supported by the - * CertificateFactory. They will be copied out of the supplied - * List object. + * {@code CertificateFactory}. They will be copied out of the supplied + * {@code List} object. * *

    This method was added to version 1.4 of the Java 2 Platform * Standard Edition. In order to maintain backwards compatibility with - * existing service providers, this method cannot be abstract - * and by default throws an UnsupportedOperationException. + * existing service providers, this method cannot be {@code abstract} + * and by default throws an {@code UnsupportedOperationException}. * - * @param certificates a List of Certificates - * @return a CertPath initialized with the supplied list of + * @param certificates a {@code List} of {@code Certificate}s + * @return a {@code CertPath} initialized with the supplied list of * certificates * @exception CertificateException if an exception occurs * @exception UnsupportedOperationException if the method is not supported @@ -180,24 +180,24 @@ public abstract class CertificateFactorySpi { } /** - * Returns an iteration of the CertPath encodings supported + * Returns an iteration of the {@code CertPath} encodings supported * by this certificate factory, with the default encoding first. See * the CertPath Encodings section in the * Java Cryptography Architecture Standard Algorithm Name Documentation * for information about standard encoding names. *

    - * Attempts to modify the returned Iterator via its - * remove method result in an - * UnsupportedOperationException. + * Attempts to modify the returned {@code Iterator} via its + * {@code remove} method result in an + * {@code UnsupportedOperationException}. * *

    This method was added to version 1.4 of the Java 2 Platform * Standard Edition. In order to maintain backwards compatibility with - * existing service providers, this method cannot be abstract - * and by default throws an UnsupportedOperationException. + * existing service providers, this method cannot be {@code abstract} + * and by default throws an {@code UnsupportedOperationException}. * - * @return an Iterator over the names of the supported - * CertPath encodings (as Strings) + * @return an {@code Iterator} over the names of the supported + * {@code CertPath} encodings (as {@code String}s) * @exception UnsupportedOperationException if the method is not supported * @since 1.4 */ @@ -207,21 +207,21 @@ public abstract class CertificateFactorySpi { /** * Returns a (possibly empty) collection view of the certificates read - * from the given input stream inStream. + * from the given input stream {@code inStream}. * *

    In order to take advantage of the specialized certificate format * supported by this certificate factory, each element in * the returned collection view can be typecast to the corresponding * certificate class. For example, if this certificate * factory implements X.509 certificates, the elements in the returned - * collection can be typecast to the X509Certificate class. + * collection can be typecast to the {@code X509Certificate} class. * *

    In the case of a certificate factory for X.509 certificates, - * inStream may contain a single DER-encoded certificate + * {@code inStream} may contain a single DER-encoded certificate * in the formats described for * {@link CertificateFactory#generateCertificate(java.io.InputStream) * generateCertificate}. - * In addition, inStream may contain a PKCS#7 certificate + * In addition, {@code inStream} may contain a PKCS#7 certificate * chain. This is a PKCS#7 SignedData object, with the only * significant field being certificates. In particular, the * signature and the contents are ignored. This format allows multiple @@ -247,14 +247,14 @@ public abstract class CertificateFactorySpi { /** * Generates a certificate revocation list (CRL) object and initializes it - * with the data read from the input stream inStream. + * with the data read from the input stream {@code inStream}. * *

    In order to take advantage of the specialized CRL format * supported by this certificate factory, * the returned CRL object can be typecast to the corresponding * CRL class. For example, if this certificate * factory implements X.509 CRLs, the returned CRL object - * can be typecast to the X509CRL class. + * can be typecast to the {@code X509CRL} class. * *

    Note that if the given input stream does not support * {@link java.io.InputStream#mark(int) mark} and @@ -265,7 +265,7 @@ public abstract class CertificateFactorySpi { * end-of-CRL marker. If the data in the * input stream does not contain an inherent end-of-CRL marker (other * than EOF) and there is trailing data after the CRL is parsed, a - * CRLException is thrown. + * {@code CRLException} is thrown. * * @param inStream an input stream with the CRL data. * @@ -279,18 +279,18 @@ public abstract class CertificateFactorySpi { /** * Returns a (possibly empty) collection view of the CRLs read - * from the given input stream inStream. + * from the given input stream {@code inStream}. * *

    In order to take advantage of the specialized CRL format * supported by this certificate factory, each element in * the returned collection view can be typecast to the corresponding * CRL class. For example, if this certificate * factory implements X.509 CRLs, the elements in the returned - * collection can be typecast to the X509CRL class. + * collection can be typecast to the {@code X509CRL} class. * *

    In the case of a certificate factory for X.509 CRLs, - * inStream may contain a single DER-encoded CRL. - * In addition, inStream may contain a PKCS#7 CRL + * {@code inStream} may contain a single DER-encoded CRL. + * In addition, {@code inStream} may contain a PKCS#7 CRL * set. This is a PKCS#7 SignedData object, with the only * significant field being crls. In particular, the * signature and the contents are ignored. This format allows multiple diff --git a/jdk/src/share/classes/java/security/cert/CertificateNotYetValidException.java b/jdk/src/share/classes/java/security/cert/CertificateNotYetValidException.java index 13da51d06f3..e8722bd339d 100644 --- a/jdk/src/share/classes/java/security/cert/CertificateNotYetValidException.java +++ b/jdk/src/share/classes/java/security/cert/CertificateNotYetValidException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -27,8 +27,8 @@ package java.security.cert; /** * Certificate is not yet valid exception. This is thrown whenever - * the current Date or the specified Date - * is before the notBefore date/time in the Certificate + * the current {@code Date} or the specified {@code Date} + * is before the {@code notBefore} date/time in the Certificate * validity period. * * @author Hemma Prafullchandra diff --git a/jdk/src/share/classes/java/security/cert/CertificateParsingException.java b/jdk/src/share/classes/java/security/cert/CertificateParsingException.java index 3432fb09af6..06a7d603f29 100644 --- a/jdk/src/share/classes/java/security/cert/CertificateParsingException.java +++ b/jdk/src/share/classes/java/security/cert/CertificateParsingException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -57,13 +57,13 @@ public class CertificateParsingException extends CertificateException { } /** - * Creates a CertificateParsingException with the specified + * Creates a {@code CertificateParsingException} with the specified * detail message and cause. * * @param message the detail message (which is saved for later retrieval * by the {@link #getMessage()} method). * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause()} method). (A null value is permitted, + * {@link #getCause()} method). (A {@code null} value is permitted, * and indicates that the cause is nonexistent or unknown.) * @since 1.5 */ @@ -72,14 +72,14 @@ public class CertificateParsingException extends CertificateException { } /** - * Creates a CertificateParsingException with the + * Creates a {@code CertificateParsingException} with the * specified cause and a detail message of - * (cause==null ? null : cause.toString()) + * {@code (cause==null ? null : cause.toString())} * (which typically contains the class and detail message of - * cause). + * {@code cause}). * * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause()} method). (A null value is permitted, + * {@link #getCause()} method). (A {@code null} value is permitted, * and indicates that the cause is nonexistent or unknown.) * @since 1.5 */ diff --git a/jdk/src/share/classes/java/security/cert/CertificateRevokedException.java b/jdk/src/share/classes/java/security/cert/CertificateRevokedException.java index b812689ee6e..c50a224861a 100644 --- a/jdk/src/share/classes/java/security/cert/CertificateRevokedException.java +++ b/jdk/src/share/classes/java/security/cert/CertificateRevokedException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2007, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2007, 2013, 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 @@ -39,7 +39,7 @@ import sun.security.x509.InvalidityDateExtension; /** * An exception that indicates an X.509 certificate is revoked. A - * CertificateRevokedException contains additional information + * {@code CertificateRevokedException} contains additional information * about the revoked certificate, such as the date on which the * certificate was revoked and the reason it was revoked. * @@ -60,7 +60,7 @@ public class CertificateRevokedException extends CertificateException { */ private final CRLReason reason; /** - * @serial the X500Principal that represents the name of the + * @serial the {@code X500Principal} that represents the name of the * authority that signed the certificate's revocation status information */ private final X500Principal authority; @@ -68,7 +68,7 @@ public class CertificateRevokedException extends CertificateException { private transient Map extensions; /** - * Constructs a CertificateRevokedException with + * Constructs a {@code CertificateRevokedException} with * the specified revocation date, reason code, authority name, and map * of extensions. * @@ -78,12 +78,12 @@ public class CertificateRevokedException extends CertificateException { * @param extensions a map of X.509 Extensions. Each key is an OID String * that maps to the corresponding Extension. The map is copied to * prevent subsequent modification. - * @param authority the X500Principal that represents the name + * @param authority the {@code X500Principal} that represents the name * of the authority that signed the certificate's revocation status * information - * @throws NullPointerException if revocationDate, - * reason, authority, or - * extensions is null + * @throws NullPointerException if {@code revocationDate}, + * {@code reason}, {@code authority}, or + * {@code extensions} is {@code null} */ public CertificateRevokedException(Date revocationDate, CRLReason reason, X500Principal authority, Map extensions) { @@ -121,7 +121,7 @@ public class CertificateRevokedException extends CertificateException { * Returns the name of the authority that signed the certificate's * revocation status information. * - * @return the X500Principal that represents the name of the + * @return the {@code X500Principal} that represents the name of the * authority that signed the certificate's revocation status information */ public X500Principal getAuthorityName() { @@ -130,16 +130,16 @@ public class CertificateRevokedException extends CertificateException { /** * Returns the invalidity date, as specifed in the Invalidity Date - * extension of this CertificateRevokedException. The + * extension of this {@code CertificateRevokedException}. The * invalidity date is the date on which it is known or suspected that the * private key was compromised or that the certificate otherwise became - * invalid. This implementation calls getExtensions() and + * invalid. This implementation calls {@code getExtensions()} and * checks the returned map for an entry for the Invalidity Date extension * OID ("2.5.29.24"). If found, it returns the invalidity date in the * extension; otherwise null. A new Date object is returned each time the * method is invoked to protect against subsequent modification. * - * @return the invalidity date, or null if not specified + * @return the invalidity date, or {@code null} if not specified */ public Date getInvalidityDate() { Extension ext = getExtensions().get("2.5.29.24"); @@ -176,7 +176,7 @@ public class CertificateRevokedException extends CertificateException { } /** - * Serialize this CertificateRevokedException instance. + * Serialize this {@code CertificateRevokedException} instance. * * @serialData the size of the extensions map (int), followed by all of * the extensions in the map, in no particular order. For each extension, @@ -208,7 +208,7 @@ public class CertificateRevokedException extends CertificateException { } /** - * Deserialize the CertificateRevokedException instance. + * Deserialize the {@code CertificateRevokedException} instance. */ private void readObject(ObjectInputStream ois) throws IOException, ClassNotFoundException { diff --git a/jdk/src/share/classes/java/security/cert/CollectionCertStoreParameters.java b/jdk/src/share/classes/java/security/cert/CollectionCertStoreParameters.java index 56e25c94778..12bd358cfff 100644 --- a/jdk/src/share/classes/java/security/cert/CollectionCertStoreParameters.java +++ b/jdk/src/share/classes/java/security/cert/CollectionCertStoreParameters.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -30,13 +30,13 @@ import java.util.Collection; import java.util.Collections; /** - * Parameters used as input for the Collection CertStore + * Parameters used as input for the Collection {@code CertStore} * algorithm. *

    * This class is used to provide necessary configuration parameters - * to implementations of the Collection CertStore + * to implementations of the Collection {@code CertStore} * algorithm. The only parameter included in this class is the - * Collection from which the CertStore will + * {@code Collection} from which the {@code CertStore} will * retrieve certificates and CRLs. *

    * Concurrent Access @@ -58,30 +58,30 @@ public class CollectionCertStoreParameters private Collection coll; /** - * Creates an instance of CollectionCertStoreParameters + * Creates an instance of {@code CollectionCertStoreParameters} * which will allow certificates and CRLs to be retrieved from the - * specified Collection. If the specified - * Collection contains an object that is not a - * Certificate or CRL, that object will be - * ignored by the Collection CertStore. + * specified {@code Collection}. If the specified + * {@code Collection} contains an object that is not a + * {@code Certificate} or {@code CRL}, that object will be + * ignored by the Collection {@code CertStore}. *

    - * The Collection is not copied. Instead, a + * The {@code Collection} is not copied. Instead, a * reference is used. This allows the caller to subsequently add or - * remove Certificates or CRLs from the - * Collection, thus changing the set of - * Certificates or CRLs available to the - * Collection CertStore. The Collection CertStore - * will not modify the contents of the Collection. + * remove {@code Certificates} or {@code CRL}s from the + * {@code Collection}, thus changing the set of + * {@code Certificates} or {@code CRL}s available to the + * Collection {@code CertStore}. The Collection {@code CertStore} + * will not modify the contents of the {@code Collection}. *

    - * If the Collection will be modified by one thread while - * another thread is calling a method of a Collection CertStore - * that has been initialized with this Collection, the - * Collection must have fail-fast iterators. + * If the {@code Collection} will be modified by one thread while + * another thread is calling a method of a Collection {@code CertStore} + * that has been initialized with this {@code Collection}, the + * {@code Collection} must have fail-fast iterators. * - * @param collection a Collection of - * Certificates and CRLs - * @exception NullPointerException if collection is - * null + * @param collection a {@code Collection} of + * {@code Certificate}s and {@code CRL}s + * @exception NullPointerException if {@code collection} is + * {@code null} */ public CollectionCertStoreParameters(Collection collection) { if (collection == null) @@ -90,22 +90,22 @@ public class CollectionCertStoreParameters } /** - * Creates an instance of CollectionCertStoreParameters with + * Creates an instance of {@code CollectionCertStoreParameters} with * the default parameter values (an empty and immutable - * Collection). + * {@code Collection}). */ public CollectionCertStoreParameters() { coll = Collections.EMPTY_SET; } /** - * Returns the Collection from which Certificates - * and CRLs are retrieved. This is not a copy of the - * Collection, it is a reference. This allows the caller to - * subsequently add or remove Certificates or - * CRLs from the Collection. + * Returns the {@code Collection} from which {@code Certificate}s + * and {@code CRL}s are retrieved. This is not a copy of the + * {@code Collection}, it is a reference. This allows the caller to + * subsequently add or remove {@code Certificates} or + * {@code CRL}s from the {@code Collection}. * - * @return the Collection (never null) + * @return the {@code Collection} (never null) */ public Collection getCollection() { return coll; @@ -113,7 +113,7 @@ public class CollectionCertStoreParameters /** * Returns a copy of this object. Note that only a reference to the - * Collection is copied, and not the contents. + * {@code Collection} is copied, and not the contents. * * @return the copy */ diff --git a/jdk/src/share/classes/java/security/cert/Extension.java b/jdk/src/share/classes/java/security/cert/Extension.java index cbf89d5cdba..98e827c5919 100644 --- a/jdk/src/share/classes/java/security/cert/Extension.java +++ b/jdk/src/share/classes/java/security/cert/Extension.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2007, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2007, 2013, 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 @@ -84,7 +84,7 @@ public interface Extension { * that are encoded as an OCTET STRING. It does not include the OCTET * STRING tag and length. * - * @return a copy of the extension's value, or null if no + * @return a copy of the extension's value, or {@code null} if no * extension value is present. */ byte[] getValue(); @@ -95,7 +95,7 @@ public interface Extension { * * @param out the output stream * @exception IOException on encoding or output error. - * @exception NullPointerException if out is null. + * @exception NullPointerException if {@code out} is {@code null}. */ void encode(OutputStream out) throws IOException; } diff --git a/jdk/src/share/classes/java/security/cert/LDAPCertStoreParameters.java b/jdk/src/share/classes/java/security/cert/LDAPCertStoreParameters.java index 5d8b4d59927..96fe9cd0939 100644 --- a/jdk/src/share/classes/java/security/cert/LDAPCertStoreParameters.java +++ b/jdk/src/share/classes/java/security/cert/LDAPCertStoreParameters.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -26,10 +26,10 @@ package java.security.cert; /** - * Parameters used as input for the LDAP CertStore algorithm. + * Parameters used as input for the LDAP {@code CertStore} algorithm. *

    * This class is used to provide necessary configuration parameters (server - * name and port number) to implementations of the LDAP CertStore + * name and port number) to implementations of the LDAP {@code CertStore} * algorithm. *

    * Concurrent Access @@ -59,13 +59,13 @@ public class LDAPCertStoreParameters implements CertStoreParameters { private String serverName; /** - * Creates an instance of LDAPCertStoreParameters with the + * Creates an instance of {@code LDAPCertStoreParameters} with the * specified parameter values. * * @param serverName the DNS name of the LDAP server * @param port the port number of the LDAP server - * @exception NullPointerException if serverName is - * null + * @exception NullPointerException if {@code serverName} is + * {@code null} */ public LDAPCertStoreParameters(String serverName, int port) { if (serverName == null) @@ -75,19 +75,19 @@ public class LDAPCertStoreParameters implements CertStoreParameters { } /** - * Creates an instance of LDAPCertStoreParameters with the + * Creates an instance of {@code LDAPCertStoreParameters} with the * specified server name and a default port of 389. * * @param serverName the DNS name of the LDAP server - * @exception NullPointerException if serverName is - * null + * @exception NullPointerException if {@code serverName} is + * {@code null} */ public LDAPCertStoreParameters(String serverName) { this(serverName, LDAP_DEFAULT_PORT); } /** - * Creates an instance of LDAPCertStoreParameters with the + * Creates an instance of {@code LDAPCertStoreParameters} with the * default parameter values (server name "localhost", port 389). */ public LDAPCertStoreParameters() { @@ -97,7 +97,7 @@ public class LDAPCertStoreParameters implements CertStoreParameters { /** * Returns the DNS name of the LDAP server. * - * @return the name (not null) + * @return the name (not {@code null}) */ public String getServerName() { return serverName; @@ -117,7 +117,7 @@ public class LDAPCertStoreParameters implements CertStoreParameters { * the original and vice versa. *

    * Note: this method currently performs a shallow copy of the object - * (simply calls Object.clone()). This may be changed in a + * (simply calls {@code Object.clone()}). This may be changed in a * future revision to perform a deep copy if new parameters are added * that should not be shared. * diff --git a/jdk/src/share/classes/java/security/cert/PKIXBuilderParameters.java b/jdk/src/share/classes/java/security/cert/PKIXBuilderParameters.java index d1b27c6ffba..b33e1f8c1e2 100644 --- a/jdk/src/share/classes/java/security/cert/PKIXBuilderParameters.java +++ b/jdk/src/share/classes/java/security/cert/PKIXBuilderParameters.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -32,35 +32,35 @@ import java.security.InvalidParameterException; import java.util.Set; /** - * Parameters used as input for the PKIX CertPathBuilder + * Parameters used as input for the PKIX {@code CertPathBuilder} * algorithm. *

    - * A PKIX CertPathBuilder uses these parameters to {@link - * CertPathBuilder#build build} a CertPath which has been + * A PKIX {@code CertPathBuilder} uses these parameters to {@link + * CertPathBuilder#build build} a {@code CertPath} which has been * validated according to the PKIX certification path validation algorithm. * - *

    To instantiate a PKIXBuilderParameters object, an + *

    To instantiate a {@code PKIXBuilderParameters} object, an * application must specify one or more most-trusted CAs as defined by * the PKIX certification path validation algorithm. The most-trusted CA * can be specified using one of two constructors. An application * can call {@link #PKIXBuilderParameters(Set, CertSelector) * PKIXBuilderParameters(Set, CertSelector)}, specifying a - * Set of TrustAnchor objects, each of which + * {@code Set} of {@code TrustAnchor} objects, each of which * identifies a most-trusted CA. Alternatively, an application can call * {@link #PKIXBuilderParameters(KeyStore, CertSelector) * PKIXBuilderParameters(KeyStore, CertSelector)}, specifying a - * KeyStore instance containing trusted certificate entries, each + * {@code KeyStore} instance containing trusted certificate entries, each * of which will be considered as a most-trusted CA. * *

    In addition, an application must specify constraints on the target - * certificate that the CertPathBuilder will attempt + * certificate that the {@code CertPathBuilder} will attempt * to build a path to. The constraints are specified as a - * CertSelector object. These constraints should provide the - * CertPathBuilder with enough search criteria to find the target - * certificate. Minimal criteria for an X509Certificate usually + * {@code CertSelector} object. These constraints should provide the + * {@code CertPathBuilder} with enough search criteria to find the target + * certificate. Minimal criteria for an {@code X509Certificate} usually * include the subject name and/or one or more subject alternative names. - * If enough criteria is not specified, the CertPathBuilder - * may throw a CertPathBuilderException. + * If enough criteria is not specified, the {@code CertPathBuilder} + * may throw a {@code CertPathBuilderException}. *

    * Concurrent Access *

    @@ -80,23 +80,23 @@ public class PKIXBuilderParameters extends PKIXParameters { private int maxPathLength = 5; /** - * Creates an instance of PKIXBuilderParameters with - * the specified Set of most-trusted CAs. + * Creates an instance of {@code PKIXBuilderParameters} with + * the specified {@code Set} of most-trusted CAs. * Each element of the set is a {@link TrustAnchor TrustAnchor}. * - *

    Note that the Set is copied to protect against + *

    Note that the {@code Set} is copied to protect against * subsequent modifications. * - * @param trustAnchors a Set of TrustAnchors - * @param targetConstraints a CertSelector specifying the + * @param trustAnchors a {@code Set} of {@code TrustAnchor}s + * @param targetConstraints a {@code CertSelector} specifying the * constraints on the target certificate - * @throws InvalidAlgorithmParameterException if trustAnchors - * is empty (trustAnchors.isEmpty() == true) - * @throws NullPointerException if trustAnchors is - * null + * @throws InvalidAlgorithmParameterException if {@code trustAnchors} + * is empty {@code (trustAnchors.isEmpty() == true)} + * @throws NullPointerException if {@code trustAnchors} is + * {@code null} * @throws ClassCastException if any of the elements of - * trustAnchors are not of type - * java.security.cert.TrustAnchor + * {@code trustAnchors} are not of type + * {@code java.security.cert.TrustAnchor} */ public PKIXBuilderParameters(Set trustAnchors, CertSelector targetConstraints) throws InvalidAlgorithmParameterException @@ -106,22 +106,22 @@ public class PKIXBuilderParameters extends PKIXParameters { } /** - * Creates an instance of PKIXBuilderParameters that + * Creates an instance of {@code PKIXBuilderParameters} that * populates the set of most-trusted CAs from the trusted - * certificate entries contained in the specified KeyStore. - * Only keystore entries that contain trusted X509Certificates + * certificate entries contained in the specified {@code KeyStore}. + * Only keystore entries that contain trusted {@code X509Certificate}s * are considered; all other certificate types are ignored. * - * @param keystore a KeyStore from which the set of + * @param keystore a {@code KeyStore} from which the set of * most-trusted CAs will be populated - * @param targetConstraints a CertSelector specifying the + * @param targetConstraints a {@code CertSelector} specifying the * constraints on the target certificate - * @throws KeyStoreException if keystore has not been + * @throws KeyStoreException if {@code keystore} has not been * initialized - * @throws InvalidAlgorithmParameterException if keystore does + * @throws InvalidAlgorithmParameterException if {@code keystore} does * not contain at least one trusted certificate entry - * @throws NullPointerException if keystore is - * null + * @throws NullPointerException if {@code keystore} is + * {@code null} */ public PKIXBuilderParameters(KeyStore keystore, CertSelector targetConstraints) @@ -139,7 +139,7 @@ public class PKIXBuilderParameters extends PKIXParameters { * in a certification path is not an intermediate certificate, and is not * included in this limit. Usually the last certificate is an end entity * certificate, but it can be a CA certificate. A PKIX - * CertPathBuilder instance must not build + * {@code CertPathBuilder} instance must not build * paths longer than the length specified. * *

    A value of 0 implies that the path can only contain @@ -149,14 +149,14 @@ public class PKIXBuilderParameters extends PKIXParameters { * Setting a value less than -1 will cause an exception to be thrown. * *

    If any of the CA certificates contain the - * BasicConstraintsExtension, the value of the - * pathLenConstraint field of the extension overrides + * {@code BasicConstraintsExtension}, the value of the + * {@code pathLenConstraint} field of the extension overrides * the maximum path length parameter whenever the result is a * certification path of smaller length. * * @param maxPathLength the maximum number of non-self-issued intermediate * certificates that may exist in a certification path - * @throws InvalidParameterException if maxPathLength is set + * @throws InvalidParameterException if {@code maxPathLength} is set * to a value less than -1 * * @see #getMaxPathLength diff --git a/jdk/src/share/classes/java/security/cert/PKIXCertPathBuilderResult.java b/jdk/src/share/classes/java/security/cert/PKIXCertPathBuilderResult.java index d5efbb35ad2..3255a3bbda6 100644 --- a/jdk/src/share/classes/java/security/cert/PKIXCertPathBuilderResult.java +++ b/jdk/src/share/classes/java/security/cert/PKIXCertPathBuilderResult.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2001, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -33,14 +33,14 @@ import java.security.PublicKey; * returned using this algorithm are also validated according to the PKIX * certification path validation algorithm. * - *

    Instances of PKIXCertPathBuilderResult are returned by - * the build method of CertPathBuilder + *

    Instances of {@code PKIXCertPathBuilderResult} are returned by + * the {@code build} method of {@code CertPathBuilder} * objects implementing the PKIX algorithm. * - *

    All PKIXCertPathBuilderResult objects contain the + *

    All {@code PKIXCertPathBuilderResult} objects contain the * certification path constructed by the build algorithm, the * valid policy tree and subject public key resulting from the build - * algorithm, and a TrustAnchor describing the certification + * algorithm, and a {@code TrustAnchor} describing the certification * authority (CA) that served as a trust anchor for the certification path. *

    * Concurrent Access @@ -62,18 +62,18 @@ public class PKIXCertPathBuilderResult extends PKIXCertPathValidatorResult private CertPath certPath; /** - * Creates an instance of PKIXCertPathBuilderResult + * Creates an instance of {@code PKIXCertPathBuilderResult} * containing the specified parameters. * - * @param certPath the validated CertPath - * @param trustAnchor a TrustAnchor describing the CA that + * @param certPath the validated {@code CertPath} + * @param trustAnchor a {@code TrustAnchor} describing the CA that * served as a trust anchor for the certification path - * @param policyTree the immutable valid policy tree, or null + * @param policyTree the immutable valid policy tree, or {@code null} * if there are no valid policies * @param subjectPublicKey the public key of the subject - * @throws NullPointerException if the certPath, - * trustAnchor or subjectPublicKey parameters - * are null + * @throws NullPointerException if the {@code certPath}, + * {@code trustAnchor} or {@code subjectPublicKey} parameters + * are {@code null} */ public PKIXCertPathBuilderResult(CertPath certPath, TrustAnchor trustAnchor, PolicyNode policyTree, @@ -87,13 +87,13 @@ public class PKIXCertPathBuilderResult extends PKIXCertPathValidatorResult /** * Returns the built and validated certification path. The - * CertPath object does not include the trust anchor. + * {@code CertPath} object does not include the trust anchor. * Instead, use the {@link #getTrustAnchor() getTrustAnchor()} method to - * obtain the TrustAnchor that served as the trust anchor + * obtain the {@code TrustAnchor} that served as the trust anchor * for the certification path. * - * @return the built and validated CertPath (never - * null) + * @return the built and validated {@code CertPath} (never + * {@code null}) */ public CertPath getCertPath() { return certPath; @@ -101,10 +101,10 @@ public class PKIXCertPathBuilderResult extends PKIXCertPathValidatorResult /** * Return a printable representation of this - * PKIXCertPathBuilderResult. + * {@code PKIXCertPathBuilderResult}. * - * @return a String describing the contents of this - * PKIXCertPathBuilderResult + * @return a {@code String} describing the contents of this + * {@code PKIXCertPathBuilderResult} */ public String toString() { StringBuffer sb = new StringBuffer(); diff --git a/jdk/src/share/classes/java/security/cert/PKIXCertPathChecker.java b/jdk/src/share/classes/java/security/cert/PKIXCertPathChecker.java index 30b44c37f74..21e01bf5166 100644 --- a/jdk/src/share/classes/java/security/cert/PKIXCertPathChecker.java +++ b/jdk/src/share/classes/java/security/cert/PKIXCertPathChecker.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -30,38 +30,38 @@ import java.util.Set; /** * An abstract class that performs one or more checks on an - * X509Certificate. + * {@code X509Certificate}. * - *

    A concrete implementation of the PKIXCertPathChecker class + *

    A concrete implementation of the {@code PKIXCertPathChecker} class * can be created to extend the PKIX certification path validation algorithm. * For example, an implementation may check for and process a critical private * extension of each certificate in a certification path. * - *

    Instances of PKIXCertPathChecker are passed as parameters + *

    Instances of {@code PKIXCertPathChecker} are passed as parameters * using the {@link PKIXParameters#setCertPathCheckers setCertPathCheckers} * or {@link PKIXParameters#addCertPathChecker addCertPathChecker} methods - * of the PKIXParameters and PKIXBuilderParameters - * class. Each of the PKIXCertPathCheckers {@link #check check} + * of the {@code PKIXParameters} and {@code PKIXBuilderParameters} + * class. Each of the {@code PKIXCertPathChecker}s {@link #check check} * methods will be called, in turn, for each certificate processed by a PKIX - * CertPathValidator or CertPathBuilder + * {@code CertPathValidator} or {@code CertPathBuilder} * implementation. * - *

    A PKIXCertPathChecker may be called multiple times on + *

    A {@code PKIXCertPathChecker} may be called multiple times on * successive certificates in a certification path. Concrete subclasses * are expected to maintain any internal state that may be necessary to * check successive certificates. The {@link #init init} method is used * to initialize the internal state of the checker so that the certificates * of a new certification path may be checked. A stateful implementation * must override the {@link #clone clone} method if necessary in - * order to allow a PKIX CertPathBuilder to efficiently + * order to allow a PKIX {@code CertPathBuilder} to efficiently * backtrack and try other paths. In these situations, the - * CertPathBuilder is able to restore prior path validation - * states by restoring the cloned PKIXCertPathCheckers. + * {@code CertPathBuilder} is able to restore prior path validation + * states by restoring the cloned {@code PKIXCertPathChecker}s. * *

    The order in which the certificates are presented to the - * PKIXCertPathChecker may be either in the forward direction + * {@code PKIXCertPathChecker} may be either in the forward direction * (from target to most-trusted CA) or in the reverse direction (from - * most-trusted CA to target). A PKIXCertPathChecker implementation + * most-trusted CA to target). A {@code PKIXCertPathChecker} implementation * must support reverse checking (the ability to perform its checks when * it is presented with certificates in the reverse direction) and may * support forward checking (the ability to perform its checks when it is @@ -96,19 +96,19 @@ public abstract class PKIXCertPathChecker protected PKIXCertPathChecker() {} /** - * Initializes the internal state of this PKIXCertPathChecker. + * Initializes the internal state of this {@code PKIXCertPathChecker}. *

    - * The forward flag specifies the order that + * The {@code forward} flag specifies the order that * certificates will be passed to the {@link #check check} method - * (forward or reverse). A PKIXCertPathChecker must + * (forward or reverse). A {@code PKIXCertPathChecker} must * support reverse checking and may support forward checking. * * @param forward the order that certificates are presented to - * the check method. If true, certificates + * the {@code check} method. If {@code true}, certificates * are presented from target to most-trusted CA (forward); if - * false, from most-trusted CA to target (reverse). + * {@code false}, from most-trusted CA to target (reverse). * @throws CertPathValidatorException if this - * PKIXCertPathChecker is unable to check certificates in + * {@code PKIXCertPathChecker} is unable to check certificates in * the specified order; it should never be thrown if the forward flag * is false since reverse checking must be supported */ @@ -118,32 +118,32 @@ public abstract class PKIXCertPathChecker /** * Indicates if forward checking is supported. Forward checking refers - * to the ability of the PKIXCertPathChecker to perform - * its checks when certificates are presented to the check + * to the ability of the {@code PKIXCertPathChecker} to perform + * its checks when certificates are presented to the {@code check} * method in the forward direction (from target to most-trusted CA). * - * @return true if forward checking is supported, - * false otherwise + * @return {@code true} if forward checking is supported, + * {@code false} otherwise */ @Override public abstract boolean isForwardCheckingSupported(); /** - * Returns an immutable Set of X.509 certificate extensions - * that this PKIXCertPathChecker supports (i.e. recognizes, is - * able to process), or null if no extensions are supported. + * Returns an immutable {@code Set} of X.509 certificate extensions + * that this {@code PKIXCertPathChecker} supports (i.e. recognizes, is + * able to process), or {@code null} if no extensions are supported. *

    - * Each element of the set is a String representing the + * Each element of the set is a {@code String} representing the * Object Identifier (OID) of the X.509 extension that is supported. * The OID is represented by a set of nonnegative integers separated by * periods. *

    - * All X.509 certificate extensions that a PKIXCertPathChecker + * All X.509 certificate extensions that a {@code PKIXCertPathChecker} * might possibly be able to process should be included in the set. * - * @return an immutable Set of X.509 extension OIDs (in - * String format) supported by this - * PKIXCertPathChecker, or null if no + * @return an immutable {@code Set} of X.509 extension OIDs (in + * {@code String} format) supported by this + * {@code PKIXCertPathChecker}, or {@code null} if no * extensions are supported */ public abstract Set getSupportedExtensions(); @@ -153,10 +153,10 @@ public abstract class PKIXCertPathChecker * state and removes any critical extensions that it processes from the * specified collection of OID strings that represent the unresolved * critical extensions. The certificates are presented in the order - * specified by the init method. + * specified by the {@code init} method. * - * @param cert the Certificate to be checked - * @param unresolvedCritExts a Collection of OID strings + * @param cert the {@code Certificate} to be checked + * @param unresolvedCritExts a {@code Collection} of OID strings * representing the current set of unresolved critical extensions * @exception CertPathValidatorException if the specified certificate does * not pass the check @@ -177,12 +177,12 @@ public abstract class PKIXCertPathChecker } /** - * Returns a clone of this object. Calls the Object.clone() + * Returns a clone of this object. Calls the {@code Object.clone()} * method. * All subclasses which maintain state must support and * override this method, if necessary. * - * @return a copy of this PKIXCertPathChecker + * @return a copy of this {@code PKIXCertPathChecker} */ @Override public Object clone() { diff --git a/jdk/src/share/classes/java/security/cert/PKIXCertPathValidatorResult.java b/jdk/src/share/classes/java/security/cert/PKIXCertPathValidatorResult.java index 39f22726818..b40cd393c7d 100644 --- a/jdk/src/share/classes/java/security/cert/PKIXCertPathValidatorResult.java +++ b/jdk/src/share/classes/java/security/cert/PKIXCertPathValidatorResult.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -31,13 +31,13 @@ import java.security.PublicKey; * This class represents the successful result of the PKIX certification * path validation algorithm. * - *

    Instances of PKIXCertPathValidatorResult are returned by the + *

    Instances of {@code PKIXCertPathValidatorResult} are returned by the * {@link CertPathValidator#validate validate} method of - * CertPathValidator objects implementing the PKIX algorithm. + * {@code CertPathValidator} objects implementing the PKIX algorithm. * - *

    All PKIXCertPathValidatorResult objects contain the + *

    All {@code PKIXCertPathValidatorResult} objects contain the * valid policy tree and subject public key resulting from the - * validation algorithm, as well as a TrustAnchor describing + * validation algorithm, as well as a {@code TrustAnchor} describing * the certification authority (CA) that served as a trust anchor for the * certification path. *

    @@ -62,16 +62,16 @@ public class PKIXCertPathValidatorResult implements CertPathValidatorResult { private PublicKey subjectPublicKey; /** - * Creates an instance of PKIXCertPathValidatorResult + * Creates an instance of {@code PKIXCertPathValidatorResult} * containing the specified parameters. * - * @param trustAnchor a TrustAnchor describing the CA that + * @param trustAnchor a {@code TrustAnchor} describing the CA that * served as a trust anchor for the certification path - * @param policyTree the immutable valid policy tree, or null + * @param policyTree the immutable valid policy tree, or {@code null} * if there are no valid policies * @param subjectPublicKey the public key of the subject - * @throws NullPointerException if the subjectPublicKey or - * trustAnchor parameters are null + * @throws NullPointerException if the {@code subjectPublicKey} or + * {@code trustAnchor} parameters are {@code null} */ public PKIXCertPathValidatorResult(TrustAnchor trustAnchor, PolicyNode policyTree, PublicKey subjectPublicKey) @@ -86,10 +86,10 @@ public class PKIXCertPathValidatorResult implements CertPathValidatorResult { } /** - * Returns the TrustAnchor describing the CA that served + * Returns the {@code TrustAnchor} describing the CA that served * as a trust anchor for the certification path. * - * @return the TrustAnchor (never null) + * @return the {@code TrustAnchor} (never {@code null}) */ public TrustAnchor getTrustAnchor() { return trustAnchor; @@ -98,18 +98,18 @@ public class PKIXCertPathValidatorResult implements CertPathValidatorResult { /** * Returns the root node of the valid policy tree resulting from the * PKIX certification path validation algorithm. The - * PolicyNode object that is returned and any objects that + * {@code PolicyNode} object that is returned and any objects that * it returns through public methods are immutable. * *

    Most applications will not need to examine the valid policy tree. * They can achieve their policy processing goals by setting the - * policy-related parameters in PKIXParameters. However, more + * policy-related parameters in {@code PKIXParameters}. However, more * sophisticated applications, especially those that process policy * qualifiers, may need to traverse the valid policy tree using the * {@link PolicyNode#getParent PolicyNode.getParent} and * {@link PolicyNode#getChildren PolicyNode.getChildren} methods. * - * @return the root node of the valid policy tree, or null + * @return the root node of the valid policy tree, or {@code null} * if there are no valid policies */ public PolicyNode getPolicyTree() { @@ -120,7 +120,7 @@ public class PKIXCertPathValidatorResult implements CertPathValidatorResult { * Returns the public key of the subject (target) of the certification * path, including any inherited public key parameters if applicable. * - * @return the public key of the subject (never null) + * @return the public key of the subject (never {@code null}) */ public PublicKey getPublicKey() { return subjectPublicKey; @@ -142,10 +142,10 @@ public class PKIXCertPathValidatorResult implements CertPathValidatorResult { /** * Return a printable representation of this - * PKIXCertPathValidatorResult. + * {@code PKIXCertPathValidatorResult}. * - * @return a String describing the contents of this - * PKIXCertPathValidatorResult + * @return a {@code String} describing the contents of this + * {@code PKIXCertPathValidatorResult} */ public String toString() { StringBuffer sb = new StringBuffer(); diff --git a/jdk/src/share/classes/java/security/cert/PKIXParameters.java b/jdk/src/share/classes/java/security/cert/PKIXParameters.java index 8b0100511e0..4d8a344532e 100644 --- a/jdk/src/share/classes/java/security/cert/PKIXParameters.java +++ b/jdk/src/share/classes/java/security/cert/PKIXParameters.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -38,34 +38,34 @@ import java.util.List; import java.util.Set; /** - * Parameters used as input for the PKIX CertPathValidator + * Parameters used as input for the PKIX {@code CertPathValidator} * algorithm. *

    - * A PKIX CertPathValidator uses these parameters to - * validate a CertPath according to the PKIX certification path + * A PKIX {@code CertPathValidator} uses these parameters to + * validate a {@code CertPath} according to the PKIX certification path * validation algorithm. * - *

    To instantiate a PKIXParameters object, an + *

    To instantiate a {@code PKIXParameters} object, an * application must specify one or more most-trusted CAs as defined by * the PKIX certification path validation algorithm. The most-trusted CAs * can be specified using one of two constructors. An application * can call {@link #PKIXParameters(Set) PKIXParameters(Set)}, - * specifying a Set of TrustAnchor objects, each + * specifying a {@code Set} of {@code TrustAnchor} objects, each * of which identify a most-trusted CA. Alternatively, an application can call * {@link #PKIXParameters(KeyStore) PKIXParameters(KeyStore)}, specifying a - * KeyStore instance containing trusted certificate entries, each + * {@code KeyStore} instance containing trusted certificate entries, each * of which will be considered as a most-trusted CA. *

    - * Once a PKIXParameters object has been created, other parameters + * Once a {@code PKIXParameters} object has been created, other parameters * can be specified (by calling {@link #setInitialPolicies setInitialPolicies} * or {@link #setDate setDate}, for instance) and then the - * PKIXParameters is passed along with the CertPath + * {@code PKIXParameters} is passed along with the {@code CertPath} * to be validated to {@link CertPathValidator#validate * CertPathValidator.validate}. *

    - * Any parameter that is not set (or is set to null) will + * Any parameter that is not set (or is set to {@code null}) will * be set to the default value for that parameter. The default value for the - * date parameter is null, which indicates + * {@code date} parameter is {@code null}, which indicates * the current time when the path is validated. The default for the * remaining parameters is the least constrained. *

    @@ -99,20 +99,20 @@ public class PKIXParameters implements CertPathParameters { private CertSelector certSelector; /** - * Creates an instance of PKIXParameters with the specified - * Set of most-trusted CAs. Each element of the + * Creates an instance of {@code PKIXParameters} with the specified + * {@code Set} of most-trusted CAs. Each element of the * set is a {@link TrustAnchor TrustAnchor}. *

    - * Note that the Set is copied to protect against + * Note that the {@code Set} is copied to protect against * subsequent modifications. * - * @param trustAnchors a Set of TrustAnchors + * @param trustAnchors a {@code Set} of {@code TrustAnchor}s * @throws InvalidAlgorithmParameterException if the specified - * Set is empty (trustAnchors.isEmpty() == true) - * @throws NullPointerException if the specified Set is - * null - * @throws ClassCastException if any of the elements in the Set - * are not of type java.security.cert.TrustAnchor + * {@code Set} is empty {@code (trustAnchors.isEmpty() == true)} + * @throws NullPointerException if the specified {@code Set} is + * {@code null} + * @throws ClassCastException if any of the elements in the {@code Set} + * are not of type {@code java.security.cert.TrustAnchor} */ public PKIXParameters(Set trustAnchors) throws InvalidAlgorithmParameterException @@ -125,18 +125,18 @@ public class PKIXParameters implements CertPathParameters { } /** - * Creates an instance of PKIXParameters that + * Creates an instance of {@code PKIXParameters} that * populates the set of most-trusted CAs from the trusted - * certificate entries contained in the specified KeyStore. - * Only keystore entries that contain trusted X509Certificates + * certificate entries contained in the specified {@code KeyStore}. + * Only keystore entries that contain trusted {@code X509Certificates} * are considered; all other certificate types are ignored. * - * @param keystore a KeyStore from which the set of + * @param keystore a {@code KeyStore} from which the set of * most-trusted CAs will be populated * @throws KeyStoreException if the keystore has not been initialized * @throws InvalidAlgorithmParameterException if the keystore does * not contain at least one trusted certificate entry - * @throws NullPointerException if the keystore is null + * @throws NullPointerException if the keystore is {@code null} */ public PKIXParameters(KeyStore keystore) throws KeyStoreException, InvalidAlgorithmParameterException @@ -161,11 +161,11 @@ public class PKIXParameters implements CertPathParameters { } /** - * Returns an immutable Set of the most-trusted + * Returns an immutable {@code Set} of the most-trusted * CAs. * - * @return an immutable Set of TrustAnchors - * (never null) + * @return an immutable {@code Set} of {@code TrustAnchor}s + * (never {@code null}) * * @see #setTrustAnchors */ @@ -174,18 +174,18 @@ public class PKIXParameters implements CertPathParameters { } /** - * Sets the Set of most-trusted CAs. + * Sets the {@code Set} of most-trusted CAs. *

    - * Note that the Set is copied to protect against + * Note that the {@code Set} is copied to protect against * subsequent modifications. * - * @param trustAnchors a Set of TrustAnchors + * @param trustAnchors a {@code Set} of {@code TrustAnchor}s * @throws InvalidAlgorithmParameterException if the specified - * Set is empty (trustAnchors.isEmpty() == true) - * @throws NullPointerException if the specified Set is - * null + * {@code Set} is empty {@code (trustAnchors.isEmpty() == true)} + * @throws NullPointerException if the specified {@code Set} is + * {@code null} * @throws ClassCastException if any of the elements in the set - * are not of type java.security.cert.TrustAnchor + * are not of type {@code java.security.cert.TrustAnchor} * * @see #getTrustAnchors */ @@ -211,16 +211,16 @@ public class PKIXParameters implements CertPathParameters { } /** - * Returns an immutable Set of initial + * Returns an immutable {@code Set} of initial * policy identifiers (OID strings), indicating that any one of these * policies would be acceptable to the certificate user for the purposes of * certification path processing. The default return value is an empty - * Set, which is interpreted as meaning that any policy would + * {@code Set}, which is interpreted as meaning that any policy would * be acceptable. * - * @return an immutable Set of initial policy OIDs in - * String format, or an empty Set (implying any - * policy is acceptable). Never returns null. + * @return an immutable {@code Set} of initial policy OIDs in + * {@code String} format, or an empty {@code Set} (implying any + * policy is acceptable). Never returns {@code null}. * * @see #setInitialPolicies */ @@ -229,21 +229,21 @@ public class PKIXParameters implements CertPathParameters { } /** - * Sets the Set of initial policy identifiers + * Sets the {@code Set} of initial policy identifiers * (OID strings), indicating that any one of these * policies would be acceptable to the certificate user for the purposes of * certification path processing. By default, any policy is acceptable * (i.e. all policies), so a user that wants to allow any policy as * acceptable does not need to call this method, or can call it - * with an empty Set (or null). + * with an empty {@code Set} (or {@code null}). *

    - * Note that the Set is copied to protect against + * Note that the {@code Set} is copied to protect against * subsequent modifications. * - * @param initialPolicies a Set of initial policy - * OIDs in String format (or null) + * @param initialPolicies a {@code Set} of initial policy + * OIDs in {@code String} format (or {@code null}) * @throws ClassCastException if any of the elements in the set are - * not of type String + * not of type {@code String} * * @see #getInitialPolicies */ @@ -262,19 +262,19 @@ public class PKIXParameters implements CertPathParameters { } /** - * Sets the list of CertStores to be used in finding - * certificates and CRLs. May be null, in which case - * no CertStores will be used. The first - * CertStores in the list may be preferred to those that + * Sets the list of {@code CertStore}s to be used in finding + * certificates and CRLs. May be {@code null}, in which case + * no {@code CertStore}s will be used. The first + * {@code CertStore}s in the list may be preferred to those that * appear later. *

    - * Note that the List is copied to protect against + * Note that the {@code List} is copied to protect against * subsequent modifications. * - * @param stores a List of CertStores (or - * null) + * @param stores a {@code List} of {@code CertStore}s (or + * {@code null}) * @throws ClassCastException if any of the elements in the list are - * not of type java.security.cert.CertStore + * not of type {@code java.security.cert.CertStore} * * @see #getCertStores */ @@ -293,10 +293,10 @@ public class PKIXParameters implements CertPathParameters { } /** - * Adds a CertStore to the end of the list of - * CertStores used in finding certificates and CRLs. + * Adds a {@code CertStore} to the end of the list of + * {@code CertStore}s used in finding certificates and CRLs. * - * @param store the CertStore to add. If null, + * @param store the {@code CertStore} to add. If {@code null}, * the store is ignored (not added to list). */ public void addCertStore(CertStore store) { @@ -306,11 +306,11 @@ public class PKIXParameters implements CertPathParameters { } /** - * Returns an immutable List of CertStores that + * Returns an immutable {@code List} of {@code CertStore}s that * are used to find certificates and CRLs. * - * @return an immutable List of CertStores - * (may be empty, but never null) + * @return an immutable {@code List} of {@code CertStore}s + * (may be empty, but never {@code null}) * * @see #setCertStores */ @@ -325,7 +325,7 @@ public class PKIXParameters implements CertPathParameters { * will be used. If this flag is false, the default revocation checking * mechanism will be disabled (not used). *

    - * When a PKIXParameters object is created, this flag is set + * When a {@code PKIXParameters} object is created, this flag is set * to true. This setting reflects the most common strategy for checking * revocation, since each service provider must support revocation * checking to be PKIX compliant. Sophisticated applications should set @@ -360,8 +360,8 @@ public class PKIXParameters implements CertPathParameters { * acceptable policy needs to be explicitly identified in every certificate. * By default, the ExplicitPolicyRequired flag is false. * - * @param val true if explicit policy is to be required, - * false otherwise + * @param val {@code true} if explicit policy is to be required, + * {@code false} otherwise */ public void setExplicitPolicyRequired(boolean val) { explicitPolicyRequired = val; @@ -372,8 +372,8 @@ public class PKIXParameters implements CertPathParameters { * acceptable policy needs to be explicitly identified in every certificate. * By default, the ExplicitPolicyRequired flag is false. * - * @return true if explicit policy is required, - * false otherwise + * @return {@code true} if explicit policy is required, + * {@code false} otherwise */ public boolean isExplicitPolicyRequired() { return explicitPolicyRequired; @@ -384,8 +384,8 @@ public class PKIXParameters implements CertPathParameters { * mapping is inhibited. By default, policy mapping is not inhibited (the * flag is false). * - * @param val true if policy mapping is to be inhibited, - * false otherwise + * @param val {@code true} if policy mapping is to be inhibited, + * {@code false} otherwise */ public void setPolicyMappingInhibited(boolean val) { policyMappingInhibited = val; @@ -406,10 +406,10 @@ public class PKIXParameters implements CertPathParameters { * Sets state to determine if the any policy OID should be processed * if it is included in a certificate. By default, the any policy OID * is not inhibited ({@link #isAnyPolicyInhibited isAnyPolicyInhibited()} - * returns false). + * returns {@code false}). * - * @param val true if the any policy OID is to be - * inhibited, false otherwise + * @param val {@code true} if the any policy OID is to be + * inhibited, {@code false} otherwise */ public void setAnyPolicyInhibited(boolean val) { anyPolicyInhibited = val; @@ -419,8 +419,8 @@ public class PKIXParameters implements CertPathParameters { * Checks whether the any policy OID should be processed if it * is included in a certificate. * - * @return true if the any policy OID is inhibited, - * false otherwise + * @return {@code true} if the any policy OID is inhibited, + * {@code false} otherwise */ public boolean isAnyPolicyInhibited() { return anyPolicyInhibited; @@ -432,7 +432,7 @@ public class PKIXParameters implements CertPathParameters { * policies extension that is marked critical are rejected. * If the flag is false, certificates are not rejected on this basis. * - *

    When a PKIXParameters object is created, this flag is + *

    When a {@code PKIXParameters} object is created, this flag is * set to true. This setting reflects the most common (and simplest) * strategy for processing policy qualifiers. Applications that want to use * a more sophisticated policy must set this flag to false. @@ -459,7 +459,7 @@ public class PKIXParameters implements CertPathParameters { * extension that is marked critical are rejected. * If the flag is false, certificates are not rejected on this basis. * - *

    When a PKIXParameters object is created, this flag is + *

    When a {@code PKIXParameters} object is created, this flag is * set to true. This setting reflects the most common (and simplest) * strategy for processing policy qualifiers. Applications that want to use * a more sophisticated policy must set this flag to false. @@ -473,12 +473,12 @@ public class PKIXParameters implements CertPathParameters { /** * Returns the time for which the validity of the certification path - * should be determined. If null, the current time is used. + * should be determined. If {@code null}, the current time is used. *

    - * Note that the Date returned is copied to protect against + * Note that the {@code Date} returned is copied to protect against * subsequent modifications. * - * @return the Date, or null if not set + * @return the {@code Date}, or {@code null} if not set * @see #setDate */ public Date getDate() { @@ -490,12 +490,12 @@ public class PKIXParameters implements CertPathParameters { /** * Sets the time for which the validity of the certification path - * should be determined. If null, the current time is used. + * should be determined. If {@code null}, the current time is used. *

    - * Note that the Date supplied here is copied to protect + * Note that the {@code Date} supplied here is copied to protect * against subsequent modifications. * - * @param date the Date, or null for the + * @param date the {@code Date}, or {@code null} for the * current time * @see #getDate */ @@ -507,39 +507,39 @@ public class PKIXParameters implements CertPathParameters { } /** - * Sets a List of additional certification path checkers. If - * the specified List contains an object that is not a - * PKIXCertPathChecker, it is ignored. + * Sets a {@code List} of additional certification path checkers. If + * the specified {@code List} contains an object that is not a + * {@code PKIXCertPathChecker}, it is ignored. *

    - * Each PKIXCertPathChecker specified implements + * Each {@code PKIXCertPathChecker} specified implements * additional checks on a certificate. Typically, these are checks to * process and verify private extensions contained in certificates. - * Each PKIXCertPathChecker should be instantiated with any + * Each {@code PKIXCertPathChecker} should be instantiated with any * initialization parameters needed to execute the check. *

    * This method allows sophisticated applications to extend a PKIX - * CertPathValidator or CertPathBuilder. - * Each of the specified PKIXCertPathCheckers will be called, - * in turn, by a PKIX CertPathValidator or - * CertPathBuilder for each certificate processed or + * {@code CertPathValidator} or {@code CertPathBuilder}. + * Each of the specified {@code PKIXCertPathChecker}s will be called, + * in turn, by a PKIX {@code CertPathValidator} or + * {@code CertPathBuilder} for each certificate processed or * validated. *

    - * Regardless of whether these additional PKIXCertPathCheckers - * are set, a PKIX CertPathValidator or - * CertPathBuilder must perform all of the required PKIX + * Regardless of whether these additional {@code PKIXCertPathChecker}s + * are set, a PKIX {@code CertPathValidator} or + * {@code CertPathBuilder} must perform all of the required PKIX * checks on each certificate. The one exception to this rule is if the * RevocationEnabled flag is set to false (see the {@link * #setRevocationEnabled setRevocationEnabled} method). *

    - * Note that the List supplied here is copied and each - * PKIXCertPathChecker in the list is cloned to protect + * Note that the {@code List} supplied here is copied and each + * {@code PKIXCertPathChecker} in the list is cloned to protect * against subsequent modifications. * - * @param checkers a List of PKIXCertPathCheckers. - * May be null, in which case no additional checkers will be + * @param checkers a {@code List} of {@code PKIXCertPathChecker}s. + * May be {@code null}, in which case no additional checkers will be * used. * @throws ClassCastException if any of the elements in the list - * are not of type java.security.cert.PKIXCertPathChecker + * are not of type {@code java.security.cert.PKIXCertPathChecker} * @see #getCertPathCheckers */ public void setCertPathCheckers(List checkers) { @@ -556,14 +556,14 @@ public class PKIXParameters implements CertPathParameters { } /** - * Returns the List of certification path checkers. - * The returned List is immutable, and each - * PKIXCertPathChecker in the List is cloned + * Returns the {@code List} of certification path checkers. + * The returned {@code List} is immutable, and each + * {@code PKIXCertPathChecker} in the {@code List} is cloned * to protect against subsequent modifications. * - * @return an immutable List of - * PKIXCertPathCheckers (may be empty, but not - * null) + * @return an immutable {@code List} of + * {@code PKIXCertPathChecker}s (may be empty, but not + * {@code null}) * @see #setCertPathCheckers */ public List getCertPathCheckers() { @@ -575,15 +575,15 @@ public class PKIXParameters implements CertPathParameters { } /** - * Adds a PKIXCertPathChecker to the list of certification + * Adds a {@code PKIXCertPathChecker} to the list of certification * path checkers. See the {@link #setCertPathCheckers setCertPathCheckers} * method for more details. *

    - * Note that the PKIXCertPathChecker is cloned to protect + * Note that the {@code PKIXCertPathChecker} is cloned to protect * against subsequent modifications. * - * @param checker a PKIXCertPathChecker to add to the list of - * checks. If null, the checker is ignored (not added to list). + * @param checker a {@code PKIXCertPathChecker} to add to the list of + * checks. If {@code null}, the checker is ignored (not added to list). */ public void addCertPathChecker(PKIXCertPathChecker checker) { if (checker != null) { @@ -592,10 +592,10 @@ public class PKIXParameters implements CertPathParameters { } /** - * Returns the signature provider's name, or null + * Returns the signature provider's name, or {@code null} * if not set. * - * @return the signature provider's name (or null) + * @return the signature provider's name (or {@code null}) * @see #setSigProvider */ public String getSigProvider() { @@ -605,10 +605,10 @@ public class PKIXParameters implements CertPathParameters { /** * Sets the signature provider's name. The specified provider will be * preferred when creating {@link java.security.Signature Signature} - * objects. If null or not set, the first provider found + * objects. If {@code null} or not set, the first provider found * supporting the algorithm will be used. * - * @param sigProvider the signature provider's name (or null) + * @param sigProvider the signature provider's name (or {@code null}) * @see #getSigProvider */ public void setSigProvider(String sigProvider) { @@ -617,14 +617,14 @@ public class PKIXParameters implements CertPathParameters { /** * Returns the required constraints on the target certificate. - * The constraints are returned as an instance of CertSelector. - * If null, no constraints are defined. + * The constraints are returned as an instance of {@code CertSelector}. + * If {@code null}, no constraints are defined. * - *

    Note that the CertSelector returned is cloned + *

    Note that the {@code CertSelector} returned is cloned * to protect against subsequent modifications. * - * @return a CertSelector specifying the constraints - * on the target certificate (or null) + * @return a {@code CertSelector} specifying the constraints + * on the target certificate (or {@code null}) * @see #setTargetCertConstraints */ public CertSelector getTargetCertConstraints() { @@ -638,14 +638,14 @@ public class PKIXParameters implements CertPathParameters { /** * Sets the required constraints on the target certificate. * The constraints are specified as an instance of - * CertSelector. If null, no constraints are + * {@code CertSelector}. If {@code null}, no constraints are * defined. * - *

    Note that the CertSelector specified is cloned + *

    Note that the {@code CertSelector} specified is cloned * to protect against subsequent modifications. * - * @param selector a CertSelector specifying the constraints - * on the target certificate (or null) + * @param selector a {@code CertSelector} specifying the constraints + * on the target certificate (or {@code null}) * @see #getTargetCertConstraints */ public void setTargetCertConstraints(CertSelector selector) { @@ -656,10 +656,10 @@ public class PKIXParameters implements CertPathParameters { } /** - * Makes a copy of this PKIXParameters object. Changes + * Makes a copy of this {@code PKIXParameters} object. Changes * to the copy will not affect the original and vice versa. * - * @return a copy of this PKIXParameters object + * @return a copy of this {@code PKIXParameters} object */ public Object clone() { try { diff --git a/jdk/src/share/classes/java/security/cert/PKIXReason.java b/jdk/src/share/classes/java/security/cert/PKIXReason.java index 9d81b132104..d58ded97541 100644 --- a/jdk/src/share/classes/java/security/cert/PKIXReason.java +++ b/jdk/src/share/classes/java/security/cert/PKIXReason.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2013, 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 @@ -26,10 +26,10 @@ package java.security.cert; /** - * The PKIXReason enumerates the potential PKIX-specific reasons + * The {@code PKIXReason} enumerates the potential PKIX-specific reasons * that an X.509 certification path may be invalid according to the PKIX * (RFC 3280) standard. These reasons are in addition to those of the - * CertPathValidatorException.BasicReason enumeration. + * {@code CertPathValidatorException.BasicReason} enumeration. * * @since 1.7 */ diff --git a/jdk/src/share/classes/java/security/cert/PolicyNode.java b/jdk/src/share/classes/java/security/cert/PolicyNode.java index 7b16dfe8fbf..1633dcb83da 100644 --- a/jdk/src/share/classes/java/security/cert/PolicyNode.java +++ b/jdk/src/share/classes/java/security/cert/PolicyNode.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -41,7 +41,7 @@ import java.util.Set; * *

    Most applications will not need to examine the valid policy tree. * They can achieve their policy processing goals by setting the - * policy-related parameters in PKIXParameters. However, + * policy-related parameters in {@code PKIXParameters}. However, * the valid policy tree is available for more sophisticated applications, * especially those that process policy qualifiers. * @@ -50,12 +50,12 @@ import java.util.Set; * valid policy tree. The tree can be traversed using the * {@link #getChildren getChildren} and {@link #getParent getParent} methods. * Data about a particular node can be retrieved using other methods of - * PolicyNode. + * {@code PolicyNode}. * *

    Concurrent Access - *

    All PolicyNode objects must be immutable and + *

    All {@code PolicyNode} objects must be immutable and * thread-safe. Multiple threads may concurrently invoke the methods defined - * in this class on a single PolicyNode object (or more than one) + * in this class on a single {@code PolicyNode} object (or more than one) * with no ill effects. This stipulation applies to all public fields and * methods of this class and any added or overridden by subclasses. * @@ -65,10 +65,10 @@ import java.util.Set; public interface PolicyNode { /** - * Returns the parent of this node, or null if this is the + * Returns the parent of this node, or {@code null} if this is the * root node. * - * @return the parent of this node, or null if this is the + * @return the parent of this node, or {@code null} if this is the * root node */ PolicyNode getParent(); @@ -76,8 +76,8 @@ public interface PolicyNode { /** * Returns an iterator over the children of this node. Any attempts to * modify the children of this node through the - * Iterator's remove method must throw an - * UnsupportedOperationException. + * {@code Iterator}'s remove method must throw an + * {@code UnsupportedOperationException}. * * @return an iterator over the children of this node */ @@ -94,7 +94,7 @@ public interface PolicyNode { /** * Returns the valid policy represented by this node. * - * @return the String OID of the valid policy + * @return the {@code String} OID of the valid policy * represented by this node. For the root node, this method always returns * the special anyPolicy OID: "2.5.29.32.0". */ @@ -104,9 +104,9 @@ public interface PolicyNode { * Returns the set of policy qualifiers associated with the * valid policy represented by this node. * - * @return an immutable Set of - * PolicyQualifierInfos. For the root node, this - * is always an empty Set. + * @return an immutable {@code Set} of + * {@code PolicyQualifierInfo}s. For the root node, this + * is always an empty {@code Set}. */ Set getPolicyQualifiers(); @@ -114,9 +114,9 @@ public interface PolicyNode { * Returns the set of expected policies that would satisfy this * node's valid policy in the next certificate to be processed. * - * @return an immutable Set of expected policy - * String OIDs. For the root node, this method - * always returns a Set with one element, the + * @return an immutable {@code Set} of expected policy + * {@code String} OIDs. For the root node, this method + * always returns a {@code Set} with one element, the * special anyPolicy OID: "2.5.29.32.0". */ Set getExpectedPolicies(); @@ -125,8 +125,8 @@ public interface PolicyNode { * Returns the criticality indicator of the certificate policy extension * in the most recently processed certificate. * - * @return true if extension marked critical, - * false otherwise. For the root node, false + * @return {@code true} if extension marked critical, + * {@code false} otherwise. For the root node, {@code false} * is always returned. */ boolean isCritical(); diff --git a/jdk/src/share/classes/java/security/cert/PolicyQualifierInfo.java b/jdk/src/share/classes/java/security/cert/PolicyQualifierInfo.java index 75a8702ac84..bc083eb7a43 100644 --- a/jdk/src/share/classes/java/security/cert/PolicyQualifierInfo.java +++ b/jdk/src/share/classes/java/security/cert/PolicyQualifierInfo.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -50,12 +50,12 @@ import sun.security.util.DerValue; * policy information terms limit the set of policies for certification paths * which include this certificate. *

    - * A Set of PolicyQualifierInfo objects are returned + * A {@code Set} of {@code PolicyQualifierInfo} objects are returned * by the {@link PolicyNode#getPolicyQualifiers PolicyNode.getPolicyQualifiers} * method. This allows applications with specific policy requirements to * process and validate each policy qualifier. Applications that need to * process policy qualifiers should explicitly set the - * policyQualifiersRejected flag to false (by calling the + * {@code policyQualifiersRejected} flag to false (by calling the * {@link PKIXParameters#setPolicyQualifiersRejected * PKIXParameters.setPolicyQualifiersRejected} method) before validating * a certification path. @@ -64,17 +64,17 @@ import sun.security.util.DerValue; * that any policy qualifier in a certificate policies extension that is * marked critical must be processed and validated. Otherwise the * certification path must be rejected. If the - * policyQualifiersRejected flag is set to false, it is up to + * {@code policyQualifiersRejected} flag is set to false, it is up to * the application to validate all policy qualifiers in this manner in order * to be PKIX compliant. * *

    Concurrent Access * - *

    All PolicyQualifierInfo objects must be immutable and + *

    All {@code PolicyQualifierInfo} objects must be immutable and * thread-safe. That is, multiple threads may concurrently invoke the - * methods defined in this class on a single PolicyQualifierInfo + * methods defined in this class on a single {@code PolicyQualifierInfo} * object (or more than one) with no ill effects. Requiring - * PolicyQualifierInfo objects to be immutable and thread-safe + * {@code PolicyQualifierInfo} objects to be immutable and thread-safe * allows them to be passed around to various pieces of code without * worrying about coordinating access. * @@ -90,7 +90,7 @@ public class PolicyQualifierInfo { private String pqiString; /** - * Creates an instance of PolicyQualifierInfo from the + * Creates an instance of {@code PolicyQualifierInfo} from the * encoded bytes. The encoded byte array is copied on construction. * * @param encoded a byte array containing the qualifier in DER encoding @@ -115,12 +115,12 @@ public class PolicyQualifierInfo { } /** - * Returns the policyQualifierId field of this - * PolicyQualifierInfo. The policyQualifierId + * Returns the {@code policyQualifierId} field of this + * {@code PolicyQualifierInfo}. The {@code policyQualifierId} * is an Object Identifier (OID) represented by a set of nonnegative * integers separated by periods. * - * @return the OID (never null) + * @return the OID (never {@code null}) */ public final String getPolicyQualifierId() { return mId; @@ -128,9 +128,9 @@ public class PolicyQualifierInfo { /** * Returns the ASN.1 DER encoded form of this - * PolicyQualifierInfo. + * {@code PolicyQualifierInfo}. * - * @return the ASN.1 DER encoded bytes (never null). + * @return the ASN.1 DER encoded bytes (never {@code null}). * Note that a copy is returned, so the data is cloned each time * this method is called. */ @@ -139,10 +139,10 @@ public class PolicyQualifierInfo { } /** - * Returns the ASN.1 DER encoded form of the qualifier - * field of this PolicyQualifierInfo. + * Returns the ASN.1 DER encoded form of the {@code qualifier} + * field of this {@code PolicyQualifierInfo}. * - * @return the ASN.1 DER encoded bytes of the qualifier + * @return the ASN.1 DER encoded bytes of the {@code qualifier} * field. Note that a copy is returned, so the data is cloned each * time this method is called. */ @@ -152,10 +152,10 @@ public class PolicyQualifierInfo { /** * Return a printable representation of this - * PolicyQualifierInfo. + * {@code PolicyQualifierInfo}. * - * @return a String describing the contents of this - * PolicyQualifierInfo + * @return a {@code String} describing the contents of this + * {@code PolicyQualifierInfo} */ public String toString() { if (pqiString != null) diff --git a/jdk/src/share/classes/java/security/cert/TrustAnchor.java b/jdk/src/share/classes/java/security/cert/TrustAnchor.java index d9c88f405dc..fe267a52f66 100644 --- a/jdk/src/share/classes/java/security/cert/TrustAnchor.java +++ b/jdk/src/share/classes/java/security/cert/TrustAnchor.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2001, 2008, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2001, 2013, 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,16 +40,16 @@ import sun.security.x509.X500Name; * for validating X.509 certification paths. A most-trusted CA includes the * public key of the CA, the CA's name, and any constraints upon the set of * paths which may be validated using this key. These parameters can be - * specified in the form of a trusted X509Certificate or as + * specified in the form of a trusted {@code X509Certificate} or as * individual parameters. *

    * Concurrent Access *

    - *

    All TrustAnchor objects must be immutable and + *

    All {@code TrustAnchor} objects must be immutable and * thread-safe. That is, multiple threads may concurrently invoke the - * methods defined in this class on a single TrustAnchor + * methods defined in this class on a single {@code TrustAnchor} * object (or more than one) with no ill effects. Requiring - * TrustAnchor objects to be immutable and thread-safe + * {@code TrustAnchor} objects to be immutable and thread-safe * allows them to be passed around to various pieces of code without * worrying about coordinating access. This stipulation applies to all * public fields and methods of this class and any added or overridden @@ -71,8 +71,8 @@ public class TrustAnchor { private NameConstraintsExtension nc; /** - * Creates an instance of TrustAnchor with the specified - * X509Certificate and optional name constraints, which + * Creates an instance of {@code TrustAnchor} with the specified + * {@code X509Certificate} and optional name constraints, which * are intended to be used as additional constraints when validating * an X.509 certification path. *

    @@ -82,7 +82,7 @@ public class TrustAnchor { * RFC 3280 * and X.509. The ASN.1 definition of this structure appears below. * - *

    
    +     * 
    {@code
          *  NameConstraints ::= SEQUENCE {
          *       permittedSubtrees       [0]     GeneralSubtrees OPTIONAL,
          *       excludedSubtrees        [1]     GeneralSubtrees OPTIONAL }
    @@ -106,20 +106,20 @@ public class TrustAnchor {
          *       uniformResourceIdentifier       [6]     IA5String,
          *       iPAddress                       [7]     OCTET STRING,
          *       registeredID                    [8]     OBJECT IDENTIFIER}
    -     * 
    + * }
    *

    * Note that the name constraints byte array supplied is cloned to protect * against subsequent modifications. * - * @param trustedCert a trusted X509Certificate + * @param trustedCert a trusted {@code X509Certificate} * @param nameConstraints a byte array containing the ASN.1 DER encoding of * a NameConstraints extension to be used for checking name constraints. * Only the value of the extension is included, not the OID or criticality - * flag. Specify null to omit the parameter. + * flag. Specify {@code null} to omit the parameter. * @throws IllegalArgumentException if the name constraints cannot be * decoded * @throws NullPointerException if the specified - * X509Certificate is null + * {@code X509Certificate} is {@code null} */ public TrustAnchor(X509Certificate trustedCert, byte[] nameConstraints) { @@ -134,7 +134,7 @@ public class TrustAnchor { } /** - * Creates an instance of TrustAnchor where the + * Creates an instance of {@code TrustAnchor} where the * most-trusted CA is specified as an X500Principal and public key. * Name constraints are an optional parameter, and are intended to be used * as additional constraints when validating an X.509 certification path. @@ -155,9 +155,9 @@ public class TrustAnchor { * @param nameConstraints a byte array containing the ASN.1 DER encoding of * a NameConstraints extension to be used for checking name constraints. * Only the value of the extension is included, not the OID or criticality - * flag. Specify null to omit the parameter. - * @throws NullPointerException if the specified caPrincipal or - * pubKey parameter is null + * flag. Specify {@code null} to omit the parameter. + * @throws NullPointerException if the specified {@code caPrincipal} or + * {@code pubKey} parameter is {@code null} * @since 1.5 */ public TrustAnchor(X500Principal caPrincipal, PublicKey pubKey, @@ -173,7 +173,7 @@ public class TrustAnchor { } /** - * Creates an instance of TrustAnchor where the + * Creates an instance of {@code TrustAnchor} where the * most-trusted CA is specified as a distinguished name and public key. * Name constraints are an optional parameter, and are intended to be used * as additional constraints when validating an X.509 certification path. @@ -191,17 +191,17 @@ public class TrustAnchor { * * @param caName the X.500 distinguished name of the most-trusted CA in * RFC 2253 - * String format + * {@code String} format * @param pubKey the public key of the most-trusted CA * @param nameConstraints a byte array containing the ASN.1 DER encoding of * a NameConstraints extension to be used for checking name constraints. * Only the value of the extension is included, not the OID or criticality - * flag. Specify null to omit the parameter. - * @throws IllegalArgumentException if the specified - * caName parameter is empty (caName.length() == 0) + * flag. Specify {@code null} to omit the parameter. + * @throws IllegalArgumentException if the specified + * {@code caName} parameter is empty {@code (caName.length() == 0)} * or incorrectly formatted or the name constraints cannot be decoded - * @throws NullPointerException if the specified caName or - * pubKey parameter is null + * @throws NullPointerException if the specified {@code caName} or + * {@code pubKey} parameter is {@code null} */ public TrustAnchor(String caName, PublicKey pubKey, byte[] nameConstraints) { @@ -225,7 +225,7 @@ public class TrustAnchor { /** * Returns the most-trusted CA certificate. * - * @return a trusted X509Certificate or null + * @return a trusted {@code X509Certificate} or {@code null} * if the trust anchor was not specified as a trusted certificate */ public final X509Certificate getTrustedCert() { @@ -236,7 +236,7 @@ public class TrustAnchor { * Returns the name of the most-trusted CA as an X500Principal. * * @return the X.500 distinguished name of the most-trusted CA, or - * null if the trust anchor was not specified as a trusted + * {@code null} if the trust anchor was not specified as a trusted * public key and name or X500Principal pair * @since 1.5 */ @@ -245,11 +245,11 @@ public class TrustAnchor { } /** - * Returns the name of the most-trusted CA in RFC 2253 String + * Returns the name of the most-trusted CA in RFC 2253 {@code String} * format. * * @return the X.500 distinguished name of the most-trusted CA, or - * null if the trust anchor was not specified as a trusted + * {@code null} if the trust anchor was not specified as a trusted * public key and name or X500Principal pair */ public final String getCAName() { @@ -259,7 +259,7 @@ public class TrustAnchor { /** * Returns the public key of the most-trusted CA. * - * @return the public key of the most-trusted CA, or null + * @return the public key of the most-trusted CA, or {@code null} * if the trust anchor was not specified as a trusted public key and name * or X500Principal pair */ @@ -306,16 +306,16 @@ public class TrustAnchor { * * @return a byte array containing the ASN.1 DER encoding of * a NameConstraints extension used for checking name constraints, - * or null if not set. + * or {@code null} if not set. */ public final byte [] getNameConstraints() { return ncBytes == null ? null : ncBytes.clone(); } /** - * Returns a formatted string describing the TrustAnchor. + * Returns a formatted string describing the {@code TrustAnchor}. * - * @return a formatted string describing the TrustAnchor + * @return a formatted string describing the {@code TrustAnchor} */ public String toString() { StringBuffer sb = new StringBuffer(); diff --git a/jdk/src/share/classes/java/security/cert/X509CRL.java b/jdk/src/share/classes/java/security/cert/X509CRL.java index cd1769f0724..0909ac0a6e6 100644 --- a/jdk/src/share/classes/java/security/cert/X509CRL.java +++ b/jdk/src/share/classes/java/security/cert/X509CRL.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -72,7 +72,7 @@ import sun.security.x509.X509CRLImpl; * RFC 3280: Internet X.509 * Public Key Infrastructure Certificate and CRL Profile. *

    - * The ASN.1 definition of tbsCertList is: + * The ASN.1 definition of {@code tbsCertList} is: *

      * TBSCertList  ::=  SEQUENCE  {
      *     version                 Version OPTIONAL,
    @@ -94,12 +94,12 @@ import sun.security.x509.X509CRLImpl;
      * 

    * CRLs are instantiated using a certificate factory. The following is an * example of how to instantiate an X.509 CRL: - *

    
    + * 
    {@code
      * try (InputStream inStream = new FileInputStream("fileName-of-crl")) {
      *     CertificateFactory cf = CertificateFactory.getInstance("X.509");
      *     X509CRL crl = (X509CRL)cf.generateCRL(inStream);
      * }
    - * 
    + * }
    * * @author Hemma Prafullchandra * @@ -122,8 +122,8 @@ public abstract class X509CRL extends CRL implements X509Extension { /** * Compares this CRL for equality with the given - * object. If the other object is an - * instanceof X509CRL, then + * object. If the {@code other} object is an + * {@code instanceof} {@code X509CRL}, then * its encoded form is retrieved and compared with the * encoded form of this CRL. * @@ -225,7 +225,7 @@ public abstract class X509CRL extends CRL implements X509Extension { * * This method was added to version 1.8 of the Java Platform Standard * Edition. In order to maintain backwards compatibility with existing - * service providers, this method is not abstract + * service providers, this method is not {@code abstract} * and it provides a default implementation. * * @param key the PublicKey used to carry out the verification. @@ -245,7 +245,7 @@ public abstract class X509CRL extends CRL implements X509Extension { } /** - * Gets the version (version number) value from the CRL. + * Gets the {@code version} (version number) value from the CRL. * The ASN.1 definition for this is: *
          * version    Version OPTIONAL,
    @@ -261,12 +261,12 @@ public abstract class X509CRL extends CRL implements X509Extension {
     
         /**
          * Denigrated, replaced by {@linkplain
    -     * #getIssuerX500Principal()}. This method returns the issuer
    +     * #getIssuerX500Principal()}. This method returns the {@code issuer}
          * as an implementation specific Principal object, which should not be
          * relied upon by portable code.
          *
          * 

    - * Gets the issuer (issuer distinguished name) value from + * Gets the {@code issuer} (issuer distinguished name) value from * the CRL. The issuer name identifies the entity that signed (and * issued) the CRL. * @@ -287,14 +287,14 @@ public abstract class X509CRL extends CRL implements X509Extension { * AttributeType ::= OBJECT IDENTIFIER * AttributeValue ::= ANY *

    - * The Name describes a hierarchical name composed of + * The {@code Name} describes a hierarchical name composed of * attributes, * such as country name, and corresponding values, such as US. - * The type of the AttributeValue component is determined by - * the AttributeType; in general it will be a - * directoryString. A directoryString is usually - * one of PrintableString, - * TeletexString or UniversalString. + * The type of the {@code AttributeValue} component is determined by + * the {@code AttributeType}; in general it will be a + * {@code directoryString}. A {@code directoryString} is usually + * one of {@code PrintableString}, + * {@code TeletexString} or {@code UniversalString}. * * @return a Principal whose name is the issuer distinguished name. */ @@ -302,11 +302,11 @@ public abstract class X509CRL extends CRL implements X509Extension { /** * Returns the issuer (issuer distinguished name) value from the - * CRL as an X500Principal. + * CRL as an {@code X500Principal}. *

    * It is recommended that subclasses override this method. * - * @return an X500Principal representing the issuer + * @return an {@code X500Principal} representing the issuer * distinguished name * @since 1.4 */ @@ -318,7 +318,7 @@ public abstract class X509CRL extends CRL implements X509Extension { } /** - * Gets the thisUpdate date from the CRL. + * Gets the {@code thisUpdate} date from the CRL. * The ASN.1 definition for this is: *

          * thisUpdate   ChoiceOfTime
    @@ -327,14 +327,14 @@ public abstract class X509CRL extends CRL implements X509Extension {
          *     generalTime    GeneralizedTime }
          * 
    * - * @return the thisUpdate date from the CRL. + * @return the {@code thisUpdate} date from the CRL. */ public abstract Date getThisUpdate(); /** - * Gets the nextUpdate date from the CRL. + * Gets the {@code nextUpdate} date from the CRL. * - * @return the nextUpdate date from the CRL, or null if + * @return the {@code nextUpdate} date from the CRL, or null if * not present. */ public abstract Date getNextUpdate(); @@ -388,7 +388,7 @@ public abstract class X509CRL extends CRL implements X509Extension { /** * Gets the DER-encoded CRL information, the - * tbsCertList from this CRL. + * {@code tbsCertList} from this CRL. * This can be used to verify the signature independently. * * @return the DER-encoded CRL information. @@ -397,7 +397,7 @@ public abstract class X509CRL extends CRL implements X509Extension { public abstract byte[] getTBSCertList() throws CRLException; /** - * Gets the signature value (the raw signature bits) from + * Gets the {@code signature} value (the raw signature bits) from * the CRL. * The ASN.1 definition for this is: *
    @@ -422,7 +422,7 @@ public abstract class X509CRL extends CRL implements X509Extension {
          *                             -- algorithm object identifier value
          * 
    * - *

    The algorithm name is determined from the algorithm + *

    The algorithm name is determined from the {@code algorithm} * OID string. * * @return the signature algorithm name. diff --git a/jdk/src/share/classes/java/security/cert/X509CRLEntry.java b/jdk/src/share/classes/java/security/cert/X509CRLEntry.java index 517bbd2c03d..f355f62bcb8 100644 --- a/jdk/src/share/classes/java/security/cert/X509CRLEntry.java +++ b/jdk/src/share/classes/java/security/cert/X509CRLEntry.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -68,8 +68,8 @@ public abstract class X509CRLEntry implements X509Extension { /** * Compares this CRL entry for equality with the given - * object. If the other object is an - * instanceof X509CRLEntry, then + * object. If the {@code other} object is an + * {@code instanceof} {@code X509CRLEntry}, then * its encoded form (the inner SEQUENCE) is retrieved and compared * with the encoded form of this CRL entry. * @@ -178,7 +178,7 @@ public abstract class X509CRLEntry implements X509Extension { * in the Reason Code extension of this CRL entry. * * @return the reason the certificate has been revoked, or - * null if this CRL entry does not have + * {@code null} if this CRL entry does not have * a Reason Code extension * @since 1.7 */ diff --git a/jdk/src/share/classes/java/security/cert/X509CRLSelector.java b/jdk/src/share/classes/java/security/cert/X509CRLSelector.java index 4258da39639..0580ee36bf2 100644 --- a/jdk/src/share/classes/java/security/cert/X509CRLSelector.java +++ b/jdk/src/share/classes/java/security/cert/X509CRLSelector.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -37,18 +37,18 @@ import sun.security.x509.CRLNumberExtension; import sun.security.x509.X500Name; /** - * A CRLSelector that selects X509CRLs that + * A {@code CRLSelector} that selects {@code X509CRLs} that * match all specified criteria. This class is particularly useful when - * selecting CRLs from a CertStore to check revocation status + * selecting CRLs from a {@code CertStore} to check revocation status * of a particular certificate. *

    - * When first constructed, an X509CRLSelector has no criteria - * enabled and each of the get methods return a default - * value (null). Therefore, the {@link #match match} method - * would return true for any X509CRL. Typically, + * When first constructed, an {@code X509CRLSelector} has no criteria + * enabled and each of the {@code get} methods return a default + * value ({@code null}). Therefore, the {@link #match match} method + * would return {@code true} for any {@code X509CRL}. Typically, * several criteria are enabled (by calling {@link #setIssuers setIssuers} * or {@link #setDateAndTime setDateAndTime}, for instance) and then the - * X509CRLSelector is passed to + * {@code X509CRLSelector} is passed to * {@link CertStore#getCRLs CertStore.getCRLs} or some similar * method. *

    @@ -86,35 +86,35 @@ public class X509CRLSelector implements CRLSelector { private long skew = 0; /** - * Creates an X509CRLSelector. Initially, no criteria are set - * so any X509CRL will match. + * Creates an {@code X509CRLSelector}. Initially, no criteria are set + * so any {@code X509CRL} will match. */ public X509CRLSelector() {} /** * Sets the issuerNames criterion. The issuer distinguished name in the - * X509CRL must match at least one of the specified - * distinguished names. If null, any issuer distinguished name + * {@code X509CRL} must match at least one of the specified + * distinguished names. If {@code null}, any issuer distinguished name * will do. *

    * This method allows the caller to specify, with a single method call, - * the complete set of issuer names which X509CRLs may contain. + * the complete set of issuer names which {@code X509CRLs} may contain. * The specified value replaces the previous value for the issuerNames * criterion. *

    - * The names parameter (if not null) is a - * Collection of X500Principals. + * The {@code names} parameter (if not {@code null}) is a + * {@code Collection} of {@code X500Principal}s. *

    - * Note that the names parameter can contain duplicate + * Note that the {@code names} parameter can contain duplicate * distinguished names, but they may be removed from the - * Collection of names returned by the + * {@code Collection} of names returned by the * {@link #getIssuers getIssuers} method. *

    - * Note that a copy is performed on the Collection to + * Note that a copy is performed on the {@code Collection} to * protect against subsequent modifications. * - * @param issuers a Collection of X500Principals - * (or null) + * @param issuers a {@code Collection} of X500Principals + * (or {@code null}) * @see #getIssuers * @since 1.5 */ @@ -138,31 +138,31 @@ public class X509CRLSelector implements CRLSelector { * this method. See {@link #addIssuerName(String)} for more information. *

    * Sets the issuerNames criterion. The issuer distinguished name in the - * X509CRL must match at least one of the specified - * distinguished names. If null, any issuer distinguished name + * {@code X509CRL} must match at least one of the specified + * distinguished names. If {@code null}, any issuer distinguished name * will do. *

    * This method allows the caller to specify, with a single method call, - * the complete set of issuer names which X509CRLs may contain. + * the complete set of issuer names which {@code X509CRLs} may contain. * The specified value replaces the previous value for the issuerNames * criterion. *

    - * The names parameter (if not null) is a - * Collection of names. Each name is a String + * The {@code names} parameter (if not {@code null}) is a + * {@code Collection} of names. Each name is a {@code String} * or a byte array representing a distinguished name (in * RFC 2253 or - * ASN.1 DER encoded form, respectively). If null is supplied + * ASN.1 DER encoded form, respectively). If {@code null} is supplied * as the value for this argument, no issuerNames check will be performed. *

    - * Note that the names parameter can contain duplicate + * Note that the {@code names} parameter can contain duplicate * distinguished names, but they may be removed from the - * Collection of names returned by the + * {@code Collection} of names returned by the * {@link #getIssuerNames getIssuerNames} method. *

    * If a name is specified as a byte array, it should contain a single DER * encoded distinguished name, as defined in X.501. The ASN.1 notation for * this structure is as follows. - *

    
    +     * 
    {@code
          * Name ::= CHOICE {
          *   RDNSequence }
          *
    @@ -185,12 +185,12 @@ public class X509CRLSelector implements CRLSelector {
          *       universalString         UniversalString (SIZE (1..MAX)),
          *       utf8String              UTF8String (SIZE (1.. MAX)),
          *       bmpString               BMPString (SIZE (1..MAX)) }
    -     * 
    + * }
    *

    - * Note that a deep copy is performed on the Collection to + * Note that a deep copy is performed on the {@code Collection} to * protect against subsequent modifications. * - * @param names a Collection of names (or null) + * @param names a {@code Collection} of names (or {@code null}) * @throws IOException if a parsing error occurs * @see #getIssuerNames */ @@ -208,11 +208,11 @@ public class X509CRLSelector implements CRLSelector { /** * Adds a name to the issuerNames criterion. The issuer distinguished - * name in the X509CRL must match at least one of the specified + * name in the {@code X509CRL} must match at least one of the specified * distinguished names. *

    * This method allows the caller to add a name to the set of issuer names - * which X509CRLs may contain. The specified name is added to + * which {@code X509CRLs} may contain. The specified name is added to * any previous value for the issuerNames criterion. * If the specified name is a duplicate, it may be ignored. * @@ -232,11 +232,11 @@ public class X509CRLSelector implements CRLSelector { * names. *

    * Adds a name to the issuerNames criterion. The issuer distinguished - * name in the X509CRL must match at least one of the specified + * name in the {@code X509CRL} must match at least one of the specified * distinguished names. *

    * This method allows the caller to add a name to the set of issuer names - * which X509CRLs may contain. The specified name is added to + * which {@code X509CRLs} may contain. The specified name is added to * any previous value for the issuerNames criterion. * If the specified name is a duplicate, it may be ignored. * @@ -249,11 +249,11 @@ public class X509CRLSelector implements CRLSelector { /** * Adds a name to the issuerNames criterion. The issuer distinguished - * name in the X509CRL must match at least one of the specified + * name in the {@code X509CRL} must match at least one of the specified * distinguished names. *

    * This method allows the caller to add a name to the set of issuer names - * which X509CRLs may contain. The specified name is added to + * which {@code X509CRLs} may contain. The specified name is added to * any previous value for the issuerNames criterion. If the specified name * is a duplicate, it may be ignored. * If a name is specified as a byte array, it should contain a single DER @@ -279,7 +279,7 @@ public class X509CRLSelector implements CRLSelector { /** * A private method that adds a name (String or byte array) to the * issuerNames criterion. The issuer distinguished - * name in the X509CRL must match at least one of the specified + * name in the {@code X509CRL} must match at least one of the specified * distinguished names. * * @param name the name in string or byte array form @@ -301,11 +301,11 @@ public class X509CRLSelector implements CRLSelector { * Clone and check an argument of the form passed to * setIssuerNames. Throw an IOException if the argument is malformed. * - * @param names a Collection of names. Each entry is a + * @param names a {@code Collection} of names. Each entry is a * String or a byte array (the name, in string or ASN.1 - * DER encoded form, respectively). null is + * DER encoded form, respectively). {@code null} is * not an acceptable value. - * @return a deep copy of the specified Collection + * @return a deep copy of the specified {@code Collection} * @throws IOException if a parsing error occurs */ private static HashSet cloneAndCheckIssuerNames(Collection names) @@ -334,11 +334,11 @@ public class X509CRLSelector implements CRLSelector { * into a RuntimeException. This method should be used when the object being * cloned has already been checked, so there should never be any exceptions. * - * @param names a Collection of names. Each entry is a + * @param names a {@code Collection} of names. Each entry is a * String or a byte array (the name, in string or ASN.1 - * DER encoded form, respectively). null is + * DER encoded form, respectively). {@code null} is * not an acceptable value. - * @return a deep copy of the specified Collection + * @return a deep copy of the specified {@code Collection} * @throws RuntimeException if a parsing error occurs */ private static HashSet cloneIssuerNames(Collection names) { @@ -354,7 +354,7 @@ public class X509CRLSelector implements CRLSelector { * returning a Collection of issuerX500Principals. * Throw an IOException if the argument is malformed. * - * @param names a Collection of names. Each entry is a + * @param names a {@code Collection} of names. Each entry is a * String or a byte array (the name, in string or ASN.1 * DER encoded form, respectively). Null is * not an acceptable value. @@ -380,24 +380,24 @@ public class X509CRLSelector implements CRLSelector { } /** - * Sets the minCRLNumber criterion. The X509CRL must have a + * Sets the minCRLNumber criterion. The {@code X509CRL} must have a * CRL number extension whose value is greater than or equal to the - * specified value. If null, no minCRLNumber check will be + * specified value. If {@code null}, no minCRLNumber check will be * done. * - * @param minCRL the minimum CRL number accepted (or null) + * @param minCRL the minimum CRL number accepted (or {@code null}) */ public void setMinCRLNumber(BigInteger minCRL) { this.minCRL = minCRL; } /** - * Sets the maxCRLNumber criterion. The X509CRL must have a + * Sets the maxCRLNumber criterion. The {@code X509CRL} must have a * CRL number extension whose value is less than or equal to the - * specified value. If null, no maxCRLNumber check will be + * specified value. If {@code null}, no maxCRLNumber check will be * done. * - * @param maxCRL the maximum CRL number accepted (or null) + * @param maxCRL the maximum CRL number accepted (or {@code null}) */ public void setMaxCRLNumber(BigInteger maxCRL) { this.maxCRL = maxCRL; @@ -406,16 +406,16 @@ public class X509CRLSelector implements CRLSelector { /** * Sets the dateAndTime criterion. The specified date must be * equal to or later than the value of the thisUpdate component - * of the X509CRL and earlier than the value of the - * nextUpdate component. There is no match if the X509CRL + * of the {@code X509CRL} and earlier than the value of the + * nextUpdate component. There is no match if the {@code X509CRL} * does not contain a nextUpdate component. - * If null, no dateAndTime check will be done. + * If {@code null}, no dateAndTime check will be done. *

    - * Note that the Date supplied here is cloned to protect + * Note that the {@code Date} supplied here is cloned to protect * against subsequent modifications. * - * @param dateAndTime the Date to match against - * (or null) + * @param dateAndTime the {@code Date} to match against + * (or {@code null}) * @see #getDateAndTime */ public void setDateAndTime(Date dateAndTime) { @@ -438,13 +438,13 @@ public class X509CRLSelector implements CRLSelector { /** * Sets the certificate being checked. This is not a criterion. Rather, - * it is optional information that may help a CertStore + * it is optional information that may help a {@code CertStore} * find CRLs that would be relevant when checking revocation for the - * specified certificate. If null is specified, then no + * specified certificate. If {@code null} is specified, then no * such optional information is provided. * - * @param cert the X509Certificate being checked - * (or null) + * @param cert the {@code X509Certificate} being checked + * (or {@code null}) * @see #getCertificateChecking */ public void setCertificateChecking(X509Certificate cert) { @@ -453,15 +453,15 @@ public class X509CRLSelector implements CRLSelector { /** * Returns the issuerNames criterion. The issuer distinguished - * name in the X509CRL must match at least one of the specified - * distinguished names. If the value returned is null, any + * name in the {@code X509CRL} must match at least one of the specified + * distinguished names. If the value returned is {@code null}, any * issuer distinguished name will do. *

    - * If the value returned is not null, it is a - * unmodifiable Collection of X500Principals. + * If the value returned is not {@code null}, it is a + * unmodifiable {@code Collection} of {@code X500Principal}s. * - * @return an unmodifiable Collection of names - * (or null) + * @return an unmodifiable {@code Collection} of names + * (or {@code null}) * @see #setIssuers * @since 1.5 */ @@ -474,25 +474,25 @@ public class X509CRLSelector implements CRLSelector { /** * Returns a copy of the issuerNames criterion. The issuer distinguished - * name in the X509CRL must match at least one of the specified - * distinguished names. If the value returned is null, any + * name in the {@code X509CRL} must match at least one of the specified + * distinguished names. If the value returned is {@code null}, any * issuer distinguished name will do. *

    - * If the value returned is not null, it is a - * Collection of names. Each name is a String + * If the value returned is not {@code null}, it is a + * {@code Collection} of names. Each name is a {@code String} * or a byte array representing a distinguished name (in RFC 2253 or * ASN.1 DER encoded form, respectively). Note that the - * Collection returned may contain duplicate names. + * {@code Collection} returned may contain duplicate names. *

    * If a name is specified as a byte array, it should contain a single DER * encoded distinguished name, as defined in X.501. The ASN.1 notation for * this structure is given in the documentation for * {@link #setIssuerNames setIssuerNames(Collection names)}. *

    - * Note that a deep copy is performed on the Collection to + * Note that a deep copy is performed on the {@code Collection} to * protect against subsequent modifications. * - * @return a Collection of names (or null) + * @return a {@code Collection} of names (or {@code null}) * @see #setIssuerNames */ public Collection getIssuerNames() { @@ -503,23 +503,23 @@ public class X509CRLSelector implements CRLSelector { } /** - * Returns the minCRLNumber criterion. The X509CRL must have a + * Returns the minCRLNumber criterion. The {@code X509CRL} must have a * CRL number extension whose value is greater than or equal to the - * specified value. If null, no minCRLNumber check will be done. + * specified value. If {@code null}, no minCRLNumber check will be done. * - * @return the minimum CRL number accepted (or null) + * @return the minimum CRL number accepted (or {@code null}) */ public BigInteger getMinCRL() { return minCRL; } /** - * Returns the maxCRLNumber criterion. The X509CRL must have a + * Returns the maxCRLNumber criterion. The {@code X509CRL} must have a * CRL number extension whose value is less than or equal to the - * specified value. If null, no maxCRLNumber check will be + * specified value. If {@code null}, no maxCRLNumber check will be * done. * - * @return the maximum CRL number accepted (or null) + * @return the maximum CRL number accepted (or {@code null}) */ public BigInteger getMaxCRL() { return maxCRL; @@ -528,15 +528,15 @@ public class X509CRLSelector implements CRLSelector { /** * Returns the dateAndTime criterion. The specified date must be * equal to or later than the value of the thisUpdate component - * of the X509CRL and earlier than the value of the + * of the {@code X509CRL} and earlier than the value of the * nextUpdate component. There is no match if the - * X509CRL does not contain a nextUpdate component. - * If null, no dateAndTime check will be done. + * {@code X509CRL} does not contain a nextUpdate component. + * If {@code null}, no dateAndTime check will be done. *

    - * Note that the Date returned is cloned to protect against + * Note that the {@code Date} returned is cloned to protect against * subsequent modifications. * - * @return the Date to match against (or null) + * @return the {@code Date} to match against (or {@code null}) * @see #setDateAndTime */ public Date getDateAndTime() { @@ -547,12 +547,12 @@ public class X509CRLSelector implements CRLSelector { /** * Returns the certificate being checked. This is not a criterion. Rather, - * it is optional information that may help a CertStore + * it is optional information that may help a {@code CertStore} * find CRLs that would be relevant when checking revocation for the - * specified certificate. If the value returned is null, then + * specified certificate. If the value returned is {@code null}, then * no such optional information is provided. * - * @return the certificate being checked (or null) + * @return the certificate being checked (or {@code null}) * @see #setCertificateChecking */ public X509Certificate getCertificateChecking() { @@ -560,10 +560,10 @@ public class X509CRLSelector implements CRLSelector { } /** - * Returns a printable representation of the X509CRLSelector. + * Returns a printable representation of the {@code X509CRLSelector}. * - * @return a String describing the contents of the - * X509CRLSelector. + * @return a {@code String} describing the contents of the + * {@code X509CRLSelector}. */ public String toString() { StringBuffer sb = new StringBuffer(); @@ -587,11 +587,11 @@ public class X509CRLSelector implements CRLSelector { } /** - * Decides whether a CRL should be selected. + * Decides whether a {@code CRL} should be selected. * - * @param crl the CRL to be checked - * @return true if the CRL should be selected, - * false otherwise + * @param crl the {@code CRL} to be checked + * @return {@code true} if the {@code CRL} should be selected, + * {@code false} otherwise */ public boolean match(CRL crl) { if (!(crl instanceof X509CRL)) { diff --git a/jdk/src/share/classes/java/security/cert/X509CertSelector.java b/jdk/src/share/classes/java/security/cert/X509CertSelector.java index 19ca2cb515d..e44dba125e4 100644 --- a/jdk/src/share/classes/java/security/cert/X509CertSelector.java +++ b/jdk/src/share/classes/java/security/cert/X509CertSelector.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -39,27 +39,27 @@ import sun.security.util.ObjectIdentifier; import sun.security.x509.*; /** - * A CertSelector that selects X509Certificates that + * A {@code CertSelector} that selects {@code X509Certificates} that * match all specified criteria. This class is particularly useful when - * selecting certificates from a CertStore to build a + * selecting certificates from a {@code CertStore} to build a * PKIX-compliant certification path. *

    - * When first constructed, an X509CertSelector has no criteria - * enabled and each of the get methods return a default value - * (null, or -1 for the {@link #getBasicConstraints + * When first constructed, an {@code X509CertSelector} has no criteria + * enabled and each of the {@code get} methods return a default value + * ({@code null}, or {@code -1} for the {@link #getBasicConstraints * getBasicConstraints} method). Therefore, the {@link #match match} - * method would return true for any X509Certificate. + * method would return {@code true} for any {@code X509Certificate}. * Typically, several criteria are enabled (by calling * {@link #setIssuer setIssuer} or * {@link #setKeyUsage setKeyUsage}, for instance) and then the - * X509CertSelector is passed to + * {@code X509CertSelector} is passed to * {@link CertStore#getCertificates CertStore.getCertificates} or some similar * method. *

    * Several criteria can be enabled (by calling {@link #setIssuer setIssuer} * and {@link #setSerialNumber setSerialNumber}, - * for example) such that the match method - * usually uniquely matches a single X509Certificate. We say + * for example) such that the {@code match} method + * usually uniquely matches a single {@code X509Certificate}. We say * usually, since it is possible for two issuing CAs to have the same * distinguished name and each issue a certificate with the same serial * number. Other unique combinations include the issuer, subject, @@ -149,8 +149,8 @@ public class X509CertSelector implements CertSelector { static final int NAME_OID = 8; /** - * Creates an X509CertSelector. Initially, no criteria are set - * so any X509Certificate will match. + * Creates an {@code X509CertSelector}. Initially, no criteria are set + * so any {@code X509Certificate} will match. */ public X509CertSelector() { // empty @@ -158,17 +158,17 @@ public class X509CertSelector implements CertSelector { /** * Sets the certificateEquals criterion. The specified - * X509Certificate must be equal to the - * X509Certificate passed to the match method. - * If null, then this check is not applied. + * {@code X509Certificate} must be equal to the + * {@code X509Certificate} passed to the {@code match} method. + * If {@code null}, then this check is not applied. * *

    This method is particularly useful when it is necessary to * match a single certificate. Although other criteria can be specified * in conjunction with the certificateEquals criterion, it is usually not * practical or necessary. * - * @param cert the X509Certificate to match (or - * null) + * @param cert the {@code X509Certificate} to match (or + * {@code null}) * @see #getCertificate */ public void setCertificate(X509Certificate cert) { @@ -178,11 +178,11 @@ public class X509CertSelector implements CertSelector { /** * Sets the serialNumber criterion. The specified serial number * must match the certificate serial number in the - * X509Certificate. If null, any certificate + * {@code X509Certificate}. If {@code null}, any certificate * serial number will do. * * @param serial the certificate serial number to match - * (or null) + * (or {@code null}) * @see #getSerialNumber */ public void setSerialNumber(BigInteger serial) { @@ -192,11 +192,11 @@ public class X509CertSelector implements CertSelector { /** * Sets the issuer criterion. The specified distinguished name * must match the issuer distinguished name in the - * X509Certificate. If null, any issuer + * {@code X509Certificate}. If {@code null}, any issuer * distinguished name will do. * * @param issuer a distinguished name as X500Principal - * (or null) + * (or {@code null}) * @since 1.5 */ public void setIssuer(X500Principal issuer) { @@ -213,14 +213,14 @@ public class X509CertSelector implements CertSelector { *

    * Sets the issuer criterion. The specified distinguished name * must match the issuer distinguished name in the - * X509Certificate. If null, any issuer + * {@code X509Certificate}. If {@code null}, any issuer * distinguished name will do. *

    - * If issuerDN is not null, it should contain a + * If {@code issuerDN} is not {@code null}, it should contain a * distinguished name, in RFC 2253 format. * * @param issuerDN a distinguished name in RFC 2253 format - * (or null) + * (or {@code null}) * @throws IOException if a parsing error occurs (incorrect form for DN) */ public void setIssuer(String issuerDN) throws IOException { @@ -234,14 +234,14 @@ public class X509CertSelector implements CertSelector { /** * Sets the issuer criterion. The specified distinguished name * must match the issuer distinguished name in the - * X509Certificate. If null is specified, + * {@code X509Certificate}. If {@code null} is specified, * the issuer criterion is disabled and any issuer distinguished name will * do. *

    - * If issuerDN is not null, it should contain a + * If {@code issuerDN} is not {@code null}, it should contain a * single DER encoded distinguished name, as defined in X.501. The ASN.1 * notation for this structure is as follows. - *

    
    +     * 
    {@code
          * Name ::= CHOICE {
          *   RDNSequence }
          *
    @@ -264,13 +264,13 @@ public class X509CertSelector implements CertSelector {
          *       universalString         UniversalString (SIZE (1..MAX)),
          *       utf8String              UTF8String (SIZE (1.. MAX)),
          *       bmpString               BMPString (SIZE (1..MAX)) }
    -     * 
    + * }
    *

    * Note that the byte array specified here is cloned to protect against * subsequent modifications. * * @param issuerDN a byte array containing the distinguished name - * in ASN.1 DER encoded form (or null) + * in ASN.1 DER encoded form (or {@code null}) * @throws IOException if an encoding error occurs (incorrect form for DN) */ public void setIssuer(byte[] issuerDN) throws IOException { @@ -284,11 +284,11 @@ public class X509CertSelector implements CertSelector { /** * Sets the subject criterion. The specified distinguished name * must match the subject distinguished name in the - * X509Certificate. If null, any subject + * {@code X509Certificate}. If {@code null}, any subject * distinguished name will do. * * @param subject a distinguished name as X500Principal - * (or null) + * (or {@code null}) * @since 1.5 */ public void setSubject(X500Principal subject) { @@ -304,14 +304,14 @@ public class X509CertSelector implements CertSelector { *

    * Sets the subject criterion. The specified distinguished name * must match the subject distinguished name in the - * X509Certificate. If null, any subject + * {@code X509Certificate}. If {@code null}, any subject * distinguished name will do. *

    - * If subjectDN is not null, it should contain a + * If {@code subjectDN} is not {@code null}, it should contain a * distinguished name, in RFC 2253 format. * * @param subjectDN a distinguished name in RFC 2253 format - * (or null) + * (or {@code null}) * @throws IOException if a parsing error occurs (incorrect form for DN) */ public void setSubject(String subjectDN) throws IOException { @@ -325,16 +325,16 @@ public class X509CertSelector implements CertSelector { /** * Sets the subject criterion. The specified distinguished name * must match the subject distinguished name in the - * X509Certificate. If null, any subject + * {@code X509Certificate}. If {@code null}, any subject * distinguished name will do. *

    - * If subjectDN is not null, it should contain a + * If {@code subjectDN} is not {@code null}, it should contain a * single DER encoded distinguished name, as defined in X.501. For the ASN.1 * notation for this structure, see * {@link #setIssuer(byte [] issuerDN) setIssuer(byte [] issuerDN)}. * * @param subjectDN a byte array containing the distinguished name in - * ASN.1 DER format (or null) + * ASN.1 DER format (or {@code null}) * @throws IOException if an encoding error occurs (incorrect form for DN) */ public void setSubject(byte[] subjectDN) throws IOException { @@ -347,34 +347,34 @@ public class X509CertSelector implements CertSelector { /** * Sets the subjectKeyIdentifier criterion. The - * X509Certificate must contain a SubjectKeyIdentifier + * {@code X509Certificate} must contain a SubjectKeyIdentifier * extension for which the contents of the extension * matches the specified criterion value. - * If the criterion value is null, no + * If the criterion value is {@code null}, no * subjectKeyIdentifier check will be done. *

    - * If subjectKeyID is not null, it + * If {@code subjectKeyID} is not {@code null}, it * should contain a single DER encoded value corresponding to the contents * of the extension value (not including the object identifier, * criticality setting, and encapsulating OCTET STRING) * for a SubjectKeyIdentifier extension. * The ASN.1 notation for this structure follows. *

    - *

    
    +     * 
    {@code
          * SubjectKeyIdentifier ::= KeyIdentifier
          *
          * KeyIdentifier ::= OCTET STRING
    -     * 
    + * }
    *

    * Since the format of subject key identifiers is not mandated by * any standard, subject key identifiers are not parsed by the - * X509CertSelector. Instead, the values are compared using + * {@code X509CertSelector}. Instead, the values are compared using * a byte-by-byte comparison. *

    * Note that the byte array supplied here is cloned to protect against * subsequent modifications. * - * @param subjectKeyID the subject key identifier (or null) + * @param subjectKeyID the subject key identifier (or {@code null}) * @see #getSubjectKeyIdentifier */ public void setSubjectKeyIdentifier(byte[] subjectKeyID) { @@ -387,46 +387,46 @@ public class X509CertSelector implements CertSelector { /** * Sets the authorityKeyIdentifier criterion. The - * X509Certificate must contain an + * {@code X509Certificate} must contain an * AuthorityKeyIdentifier extension for which the contents of the * extension value matches the specified criterion value. - * If the criterion value is null, no + * If the criterion value is {@code null}, no * authorityKeyIdentifier check will be done. *

    - * If authorityKeyID is not null, it + * If {@code authorityKeyID} is not {@code null}, it * should contain a single DER encoded value corresponding to the contents * of the extension value (not including the object identifier, * criticality setting, and encapsulating OCTET STRING) * for an AuthorityKeyIdentifier extension. * The ASN.1 notation for this structure follows. *

    - *

    
    +     * 
    {@code
          * AuthorityKeyIdentifier ::= SEQUENCE {
          *    keyIdentifier             [0] KeyIdentifier           OPTIONAL,
          *    authorityCertIssuer       [1] GeneralNames            OPTIONAL,
          *    authorityCertSerialNumber [2] CertificateSerialNumber OPTIONAL  }
          *
          * KeyIdentifier ::= OCTET STRING
    -     * 
    + * }
    *

    * Authority key identifiers are not parsed by the - * X509CertSelector. Instead, the values are + * {@code X509CertSelector}. Instead, the values are * compared using a byte-by-byte comparison. *

    - * When the keyIdentifier field of - * AuthorityKeyIdentifier is populated, the value is - * usually taken from the SubjectKeyIdentifier extension + * When the {@code keyIdentifier} field of + * {@code AuthorityKeyIdentifier} is populated, the value is + * usually taken from the {@code SubjectKeyIdentifier} extension * in the issuer's certificate. Note, however, that the result of - * X509Certificate.getExtensionValue(<SubjectKeyIdentifier Object - * Identifier>) on the issuer's certificate may NOT be used - * directly as the input to setAuthorityKeyIdentifier. + * {@code X509Certificate.getExtensionValue()} on the issuer's certificate may NOT be used + * directly as the input to {@code setAuthorityKeyIdentifier}. * This is because the SubjectKeyIdentifier contains * only a KeyIdentifier OCTET STRING, and not a SEQUENCE of * KeyIdentifier, GeneralNames, and CertificateSerialNumber. * In order to use the extension value of the issuer certificate's - * SubjectKeyIdentifier + * {@code SubjectKeyIdentifier} * extension, it will be necessary to extract the value of the embedded - * KeyIdentifier OCTET STRING, then DER encode this OCTET + * {@code KeyIdentifier} OCTET STRING, then DER encode this OCTET * STRING inside a SEQUENCE. * For more details on SubjectKeyIdentifier, see * {@link #setSubjectKeyIdentifier(byte[] subjectKeyID)}. @@ -435,7 +435,7 @@ public class X509CertSelector implements CertSelector { * subsequent modifications. * * @param authorityKeyID the authority key identifier - * (or null) + * (or {@code null}) * @see #getAuthorityKeyIdentifier */ public void setAuthorityKeyIdentifier(byte[] authorityKeyID) { @@ -449,13 +449,13 @@ public class X509CertSelector implements CertSelector { /** * Sets the certificateValid criterion. The specified date must fall * within the certificate validity period for the - * X509Certificate. If null, no certificateValid + * {@code X509Certificate}. If {@code null}, no certificateValid * check will be done. *

    - * Note that the Date supplied here is cloned to protect + * Note that the {@code Date} supplied here is cloned to protect * against subsequent modifications. * - * @param certValid the Date to check (or null) + * @param certValid the {@code Date} to check (or {@code null}) * @see #getCertificateValid */ public void setCertificateValid(Date certValid) { @@ -469,14 +469,14 @@ public class X509CertSelector implements CertSelector { /** * Sets the privateKeyValid criterion. The specified date must fall * within the private key validity period for the - * X509Certificate. If null, no privateKeyValid + * {@code X509Certificate}. If {@code null}, no privateKeyValid * check will be done. *

    - * Note that the Date supplied here is cloned to protect + * Note that the {@code Date} supplied here is cloned to protect * against subsequent modifications. * - * @param privateKeyValid the Date to check (or - * null) + * @param privateKeyValid the {@code Date} to check (or + * {@code null}) * @see #getPrivateKeyValid */ public void setPrivateKeyValid(Date privateKeyValid) { @@ -489,12 +489,12 @@ public class X509CertSelector implements CertSelector { /** * Sets the subjectPublicKeyAlgID criterion. The - * X509Certificate must contain a subject public key - * with the specified algorithm. If null, no + * {@code X509Certificate} must contain a subject public key + * with the specified algorithm. If {@code null}, no * subjectPublicKeyAlgID check will be done. * * @param oid The object identifier (OID) of the algorithm to check - * for (or null). An OID is represented by a + * for (or {@code null}). An OID is represented by a * set of nonnegative integers separated by periods. * @throws IOException if the OID is invalid, such as * the first component being not 0, 1 or 2 or the second component @@ -512,10 +512,10 @@ public class X509CertSelector implements CertSelector { /** * Sets the subjectPublicKey criterion. The - * X509Certificate must contain the specified subject public - * key. If null, no subjectPublicKey check will be done. + * {@code X509Certificate} must contain the specified subject public + * key. If {@code null}, no subjectPublicKey check will be done. * - * @param key the subject public key to check for (or null) + * @param key the subject public key to check for (or {@code null}) * @see #getSubjectPublicKey */ public void setSubjectPublicKey(PublicKey key) { @@ -529,17 +529,17 @@ public class X509CertSelector implements CertSelector { } /** - * Sets the subjectPublicKey criterion. The X509Certificate - * must contain the specified subject public key. If null, + * Sets the subjectPublicKey criterion. The {@code X509Certificate} + * must contain the specified subject public key. If {@code null}, * no subjectPublicKey check will be done. *

    * Because this method allows the public key to be specified as a byte * array, it may be used for unknown key types. *

    - * If key is not null, it should contain a + * If {@code key} is not {@code null}, it should contain a * single DER encoded SubjectPublicKeyInfo structure, as defined in X.509. * The ASN.1 notation for this structure is as follows. - *

    
    +     * 
    {@code
          * SubjectPublicKeyInfo  ::=  SEQUENCE  {
          *   algorithm            AlgorithmIdentifier,
          *   subjectPublicKey     BIT STRING  }
    @@ -550,13 +550,13 @@ public class X509CertSelector implements CertSelector {
          *                              -- contains a value of the type
          *                              -- registered for use with the
          *                              -- algorithm object identifier value
    -     * 
    + * }
    *

    * Note that the byte array supplied here is cloned to protect against * subsequent modifications. * * @param key a byte array containing the subject public key in ASN.1 DER - * form (or null) + * form (or {@code null}) * @throws IOException if an encoding error occurs (incorrect form for * subject public key) * @see #getSubjectPublicKey @@ -572,9 +572,9 @@ public class X509CertSelector implements CertSelector { } /** - * Sets the keyUsage criterion. The X509Certificate - * must allow the specified keyUsage values. If null, no - * keyUsage check will be done. Note that an X509Certificate + * Sets the keyUsage criterion. The {@code X509Certificate} + * must allow the specified keyUsage values. If {@code null}, no + * keyUsage check will be done. Note that an {@code X509Certificate} * that has no keyUsage extension implicitly allows all keyUsage values. *

    * Note that the boolean array supplied here is cloned to protect against @@ -583,7 +583,7 @@ public class X509CertSelector implements CertSelector { * @param keyUsage a boolean array in the same format as the boolean * array returned by * {@link X509Certificate#getKeyUsage() X509Certificate.getKeyUsage()}. - * Or null. + * Or {@code null}. * @see #getKeyUsage */ public void setKeyUsage(boolean[] keyUsage) { @@ -595,18 +595,18 @@ public class X509CertSelector implements CertSelector { } /** - * Sets the extendedKeyUsage criterion. The X509Certificate + * Sets the extendedKeyUsage criterion. The {@code X509Certificate} * must allow the specified key purposes in its extended key usage - * extension. If keyPurposeSet is empty or null, + * extension. If {@code keyPurposeSet} is empty or {@code null}, * no extendedKeyUsage check will be done. Note that an - * X509Certificate that has no extendedKeyUsage extension + * {@code X509Certificate} that has no extendedKeyUsage extension * implicitly allows all key purposes. *

    - * Note that the Set is cloned to protect against + * Note that the {@code Set} is cloned to protect against * subsequent modifications. * - * @param keyPurposeSet a Set of key purpose OIDs in string - * format (or null). Each OID is represented by a set of + * @param keyPurposeSet a {@code Set} of key purpose OIDs in string + * format (or {@code null}). Each OID is represented by a set of * nonnegative integers separated by periods. * @throws IOException if the OID is invalid, such as * the first component being not 0, 1 or 2 or the second component @@ -632,15 +632,15 @@ public class X509CertSelector implements CertSelector { * specified in the {@link #setSubjectAlternativeNames * setSubjectAlternativeNames} or {@link #addSubjectAlternativeName * addSubjectAlternativeName} methods. If enabled, - * the X509Certificate must contain all of the + * the {@code X509Certificate} must contain all of the * specified subject alternative names. If disabled, the - * X509Certificate must contain at least one of the + * {@code X509Certificate} must contain at least one of the * specified subject alternative names. * - *

    The matchAllNames flag is true by default. + *

    The matchAllNames flag is {@code true} by default. * - * @param matchAllNames if true, the flag is enabled; - * if false, the flag is disabled. + * @param matchAllNames if {@code true}, the flag is enabled; + * if {@code false}, the flag is disabled. * @see #getMatchAllSubjectAltNames */ public void setMatchAllSubjectAltNames(boolean matchAllNames) { @@ -649,7 +649,7 @@ public class X509CertSelector implements CertSelector { /** * Sets the subjectAlternativeNames criterion. The - * X509Certificate must contain all or at least one of the + * {@code X509Certificate} must contain all or at least one of the * specified subjectAlternativeNames, depending on the value of * the matchAllNames flag (see {@link #setMatchAllSubjectAltNames * setMatchAllSubjectAltNames}). @@ -659,19 +659,19 @@ public class X509CertSelector implements CertSelector { * subjectAlternativeNames criterion. The specified value replaces * the previous value for the subjectAlternativeNames criterion. *

    - * The names parameter (if not null) is a - * Collection with one + * The {@code names} parameter (if not {@code null}) is a + * {@code Collection} with one * entry for each name to be included in the subject alternative name - * criterion. Each entry is a List whose first entry is an - * Integer (the name type, 0-8) and whose second - * entry is a String or a byte array (the name, in + * criterion. Each entry is a {@code List} whose first entry is an + * {@code Integer} (the name type, 0-8) and whose second + * entry is a {@code String} or a byte array (the name, in * string or ASN.1 DER encoded form, respectively). - * There can be multiple names of the same type. If null + * There can be multiple names of the same type. If {@code null} * is supplied as the value for this argument, no * subjectAlternativeNames check will be performed. *

    - * Each subject alternative name in the Collection - * may be specified either as a String or as an ASN.1 encoded + * Each subject alternative name in the {@code Collection} + * may be specified either as a {@code String} or as an ASN.1 encoded * byte array. For more details about the formats used, see * {@link #addSubjectAlternativeName(int type, String name) * addSubjectAlternativeName(int type, String name)} and @@ -682,15 +682,15 @@ public class X509CertSelector implements CertSelector { * array form instead of the String form. See the note in * {@link #addSubjectAlternativeName(int, String)} for more information. *

    - * Note that the names parameter can contain duplicate + * Note that the {@code names} parameter can contain duplicate * names (same name and name type), but they may be removed from the - * Collection of names returned by the + * {@code Collection} of names returned by the * {@link #getSubjectAlternativeNames getSubjectAlternativeNames} method. *

    - * Note that a deep copy is performed on the Collection to + * Note that a deep copy is performed on the {@code Collection} to * protect against subsequent modifications. * - * @param names a Collection of names (or null) + * @param names a {@code Collection} of names (or {@code null}) * @throws IOException if a parsing error occurs * @see #getSubjectAlternativeNames */ @@ -714,7 +714,7 @@ public class X509CertSelector implements CertSelector { /** * Adds a name to the subjectAlternativeNames criterion. The - * X509Certificate must contain all or at least one + * {@code X509Certificate} must contain all or at least one * of the specified subjectAlternativeNames, depending on the value of * the matchAllNames flag (see {@link #setMatchAllSubjectAltNames * setMatchAllSubjectAltNames}). @@ -747,7 +747,7 @@ public class X509CertSelector implements CertSelector { * * @param type the name type (0-8, as specified in * RFC 3280, section 4.2.1.7) - * @param name the name in string form (not null) + * @param name the name in string form (not {@code null}) * @throws IOException if a parsing error occurs */ public void addSubjectAlternativeName(int type, String name) @@ -757,7 +757,7 @@ public class X509CertSelector implements CertSelector { /** * Adds a name to the subjectAlternativeNames criterion. The - * X509Certificate must contain all or at least one + * {@code X509Certificate} must contain all or at least one * of the specified subjectAlternativeNames, depending on the value of * the matchAllNames flag (see {@link #setMatchAllSubjectAltNames * setMatchAllSubjectAltNames}). @@ -774,7 +774,7 @@ public class X509CertSelector implements CertSelector { * the encoded value of the name, and should not include the tag associated * with the name in the GeneralName structure. The ASN.1 definition of this * structure appears below. - *

    
    +     * 
    {@code
          *  GeneralName ::= CHOICE {
          *       otherName                       [0]     OtherName,
          *       rfc822Name                      [1]     IA5String,
    @@ -785,7 +785,7 @@ public class X509CertSelector implements CertSelector {
          *       uniformResourceIdentifier       [6]     IA5String,
          *       iPAddress                       [7]     OCTET STRING,
          *       registeredID                    [8]     OBJECT IDENTIFIER}
    -     * 
    + * }
    *

    * Note that the byte array supplied here is cloned to protect against * subsequent modifications. @@ -802,7 +802,7 @@ public class X509CertSelector implements CertSelector { /** * A private method that adds a name (String or byte array) to the - * subjectAlternativeNames criterion. The X509Certificate + * subjectAlternativeNames criterion. The {@code X509Certificate} * must contain the specified subjectAlternativeName. * * @param type the name type (0-8, as specified in @@ -829,19 +829,19 @@ public class X509CertSelector implements CertSelector { /** * Parse an argument of the form passed to setSubjectAlternativeNames, - * returning a Collection of - * GeneralNameInterfaces. + * returning a {@code Collection} of + * {@code GeneralNameInterface}s. * Throw an IllegalArgumentException or a ClassCastException * if the argument is malformed. * * @param names a Collection with one entry per name. - * Each entry is a List whose first entry + * Each entry is a {@code List} whose first entry * is an Integer (the name type, 0-8) and whose second * entry is a String or a byte array (the name, in * string or ASN.1 DER encoded form, respectively). * There can be multiple names of the same type. Null is * not an acceptable value. - * @return a Set of GeneralNameInterfaces + * @return a Set of {@code GeneralNameInterface}s * @throws IOException if a parsing error occurs */ private static Set parseNames(Collection> names) throws IOException { @@ -865,8 +865,8 @@ public class X509CertSelector implements CertSelector { /** * Compare for equality two objects of the form passed to * setSubjectAlternativeNames (or X509CRLSelector.setIssuerNames). - * Throw an IllegalArgumentException or a - * ClassCastException if one of the objects is malformed. + * Throw an {@code IllegalArgumentException} or a + * {@code ClassCastException} if one of the objects is malformed. * * @param object1 a Collection containing the first object to compare * @param object2 a Collection containing the second object to compare @@ -880,7 +880,7 @@ public class X509CertSelector implements CertSelector { } /** - * Make a GeneralNameInterface out of a name type (0-8) and an + * Make a {@code GeneralNameInterface} out of a name type (0-8) and an * Object that may be a byte array holding the ASN.1 DER encoded * name or a String form of the name. Except for X.509 * Distinguished Names, the String form of the name must not be the @@ -989,7 +989,7 @@ public class X509CertSelector implements CertSelector { /** - * Sets the name constraints criterion. The X509Certificate + * Sets the name constraints criterion. The {@code X509Certificate} * must have subject and subject alternative names that * meet the specified name constraints. *

    @@ -998,7 +998,7 @@ public class X509CertSelector implements CertSelector { * would appear in the NameConstraints structure defined in RFC 3280 * and X.509. The ASN.1 definition of this structure appears below. * - *

    
    +     * 
    {@code
          *  NameConstraints ::= SEQUENCE {
          *       permittedSubtrees       [0]     GeneralSubtrees OPTIONAL,
          *       excludedSubtrees        [1]     GeneralSubtrees OPTIONAL }
    @@ -1022,7 +1022,7 @@ public class X509CertSelector implements CertSelector {
          *       uniformResourceIdentifier       [6]     IA5String,
          *       iPAddress                       [7]     OCTET STRING,
          *       registeredID                    [8]     OBJECT IDENTIFIER}
    -     * 
    + * }
    *

    * Note that the byte array supplied here is cloned to protect against * subsequent modifications. @@ -1031,7 +1031,7 @@ public class X509CertSelector implements CertSelector { * a NameConstraints extension to be used for checking * name constraints. Only the value of the extension is * included, not the OID or criticality flag. Can be - * null, + * {@code null}, * in which case no name constraints check will be performed. * @throws IOException if a parsing error occurs * @see #getNameConstraints @@ -1048,7 +1048,7 @@ public class X509CertSelector implements CertSelector { /** * Sets the basic constraints constraint. If the value is greater than or - * equal to zero, X509Certificates must include a + * equal to zero, {@code X509Certificates} must include a * basicConstraints extension with * a pathLen of at least this value. If the value is -2, only end-entity * certificates are accepted. If the value is -1, no check is done. @@ -1070,18 +1070,18 @@ public class X509CertSelector implements CertSelector { } /** - * Sets the policy constraint. The X509Certificate must + * Sets the policy constraint. The {@code X509Certificate} must * include at least one of the specified policies in its certificate - * policies extension. If certPolicySet is empty, then the - * X509Certificate must include at least some specified policy - * in its certificate policies extension. If certPolicySet is - * null, no policy check will be performed. + * policies extension. If {@code certPolicySet} is empty, then the + * {@code X509Certificate} must include at least some specified policy + * in its certificate policies extension. If {@code certPolicySet} is + * {@code null}, no policy check will be performed. *

    - * Note that the Set is cloned to protect against + * Note that the {@code Set} is cloned to protect against * subsequent modifications. * - * @param certPolicySet a Set of certificate policy OIDs in - * string format (or null). Each OID is + * @param certPolicySet a {@code Set} of certificate policy OIDs in + * string format (or {@code null}). Each OID is * represented by a set of nonnegative integers * separated by periods. * @throws IOException if a parsing error occurs on the OID such as @@ -1115,12 +1115,12 @@ public class X509CertSelector implements CertSelector { } /** - * Sets the pathToNames criterion. The X509Certificate must + * Sets the pathToNames criterion. The {@code X509Certificate} must * not include name constraints that would prohibit building a * path to the specified names. *

    * This method allows the caller to specify, with a single method call, - * the complete set of names which the X509Certificates's + * the complete set of names which the {@code X509Certificates}'s * name constraints must permit. The specified value replaces * the previous value for the pathToNames criterion. *

    @@ -1129,19 +1129,19 @@ public class X509CertSelector implements CertSelector { * built, any candidate certificate must not include name constraints that * would prohibit building a path to any of the names in the partial path. *

    - * The names parameter (if not null) is a - * Collection with one + * The {@code names} parameter (if not {@code null}) is a + * {@code Collection} with one * entry for each name to be included in the pathToNames - * criterion. Each entry is a List whose first entry is an - * Integer (the name type, 0-8) and whose second - * entry is a String or a byte array (the name, in + * criterion. Each entry is a {@code List} whose first entry is an + * {@code Integer} (the name type, 0-8) and whose second + * entry is a {@code String} or a byte array (the name, in * string or ASN.1 DER encoded form, respectively). - * There can be multiple names of the same type. If null + * There can be multiple names of the same type. If {@code null} * is supplied as the value for this argument, no * pathToNames check will be performed. *

    - * Each name in the Collection - * may be specified either as a String or as an ASN.1 encoded + * Each name in the {@code Collection} + * may be specified either as a {@code String} or as an ASN.1 encoded * byte array. For more details about the formats used, see * {@link #addPathToName(int type, String name) * addPathToName(int type, String name)} and @@ -1152,16 +1152,16 @@ public class X509CertSelector implements CertSelector { * array form instead of the String form. See the note in * {@link #addPathToName(int, String)} for more information. *

    - * Note that the names parameter can contain duplicate + * Note that the {@code names} parameter can contain duplicate * names (same name and name type), but they may be removed from the - * Collection of names returned by the + * {@code Collection} of names returned by the * {@link #getPathToNames getPathToNames} method. *

    - * Note that a deep copy is performed on the Collection to + * Note that a deep copy is performed on the {@code Collection} to * protect against subsequent modifications. * - * @param names a Collection with one entry per name - * (or null) + * @param names a {@code Collection} with one entry per name + * (or {@code null}) * @throws IOException if a parsing error occurs * @see #getPathToNames */ @@ -1186,12 +1186,12 @@ public class X509CertSelector implements CertSelector { } /** - * Adds a name to the pathToNames criterion. The X509Certificate + * Adds a name to the pathToNames criterion. The {@code X509Certificate} * must not include name constraints that would prohibit building a * path to the specified name. *

    * This method allows the caller to add a name to the set of names which - * the X509Certificates's name constraints must permit. + * the {@code X509Certificates}'s name constraints must permit. * The specified name is added to any previous value for the * pathToNames criterion. If the name is a duplicate, it may be ignored. *

    @@ -1223,12 +1223,12 @@ public class X509CertSelector implements CertSelector { } /** - * Adds a name to the pathToNames criterion. The X509Certificate + * Adds a name to the pathToNames criterion. The {@code X509Certificate} * must not include name constraints that would prohibit building a * path to the specified name. *

    * This method allows the caller to add a name to the set of names which - * the X509Certificates's name constraints must permit. + * the {@code X509Certificates}'s name constraints must permit. * The specified name is added to any previous value for the * pathToNames criterion. If the name is a duplicate, it may be ignored. *

    @@ -1254,7 +1254,7 @@ public class X509CertSelector implements CertSelector { /** * A private method that adds a name (String or byte array) to the - * pathToNames criterion. The X509Certificate must contain + * pathToNames criterion. The {@code X509Certificate} must contain * the specified pathToName. * * @param type the name type (0-8, as specified in @@ -1279,11 +1279,11 @@ public class X509CertSelector implements CertSelector { /** * Returns the certificateEquals criterion. The specified - * X509Certificate must be equal to the - * X509Certificate passed to the match method. - * If null, this check is not applied. + * {@code X509Certificate} must be equal to the + * {@code X509Certificate} passed to the {@code match} method. + * If {@code null}, this check is not applied. * - * @return the X509Certificate to match (or null) + * @return the {@code X509Certificate} to match (or {@code null}) * @see #setCertificate */ public X509Certificate getCertificate() { @@ -1293,11 +1293,11 @@ public class X509CertSelector implements CertSelector { /** * Returns the serialNumber criterion. The specified serial number * must match the certificate serial number in the - * X509Certificate. If null, any certificate + * {@code X509Certificate}. If {@code null}, any certificate * serial number will do. * * @return the certificate serial number to match - * (or null) + * (or {@code null}) * @see #setSerialNumber */ public BigInteger getSerialNumber() { @@ -1305,13 +1305,13 @@ public class X509CertSelector implements CertSelector { } /** - * Returns the issuer criterion as an X500Principal. This + * Returns the issuer criterion as an {@code X500Principal}. This * distinguished name must match the issuer distinguished name in the - * X509Certificate. If null, the issuer criterion + * {@code X509Certificate}. If {@code null}, the issuer criterion * is disabled and any issuer distinguished name will do. * * @return the required issuer distinguished name as X500Principal - * (or null) + * (or {@code null}) * @since 1.5 */ public X500Principal getIssuer() { @@ -1325,16 +1325,16 @@ public class X509CertSelector implements CertSelector { * encoding information in the RFC 2253 String form of some distinguished * names. *

    - * Returns the issuer criterion as a String. This + * Returns the issuer criterion as a {@code String}. This * distinguished name must match the issuer distinguished name in the - * X509Certificate. If null, the issuer criterion + * {@code X509Certificate}. If {@code null}, the issuer criterion * is disabled and any issuer distinguished name will do. *

    - * If the value returned is not null, it is a + * If the value returned is not {@code null}, it is a * distinguished name, in RFC 2253 format. * * @return the required issuer distinguished name in RFC 2253 format - * (or null) + * (or {@code null}) */ public String getIssuerAsString() { return (issuer == null ? null : issuer.getName()); @@ -1343,10 +1343,10 @@ public class X509CertSelector implements CertSelector { /** * Returns the issuer criterion as a byte array. This distinguished name * must match the issuer distinguished name in the - * X509Certificate. If null, the issuer criterion + * {@code X509Certificate}. If {@code null}, the issuer criterion * is disabled and any issuer distinguished name will do. *

    - * If the value returned is not null, it is a byte + * If the value returned is not {@code null}, it is a byte * array containing a single DER encoded distinguished name, as defined in * X.501. The ASN.1 notation for this structure is supplied in the * documentation for @@ -1356,7 +1356,7 @@ public class X509CertSelector implements CertSelector { * subsequent modifications. * * @return a byte array containing the required issuer distinguished name - * in ASN.1 DER format (or null) + * in ASN.1 DER format (or {@code null}) * @throws IOException if an encoding error occurs */ public byte[] getIssuerAsBytes() throws IOException { @@ -1364,13 +1364,13 @@ public class X509CertSelector implements CertSelector { } /** - * Returns the subject criterion as an X500Principal. This + * Returns the subject criterion as an {@code X500Principal}. This * distinguished name must match the subject distinguished name in the - * X509Certificate. If null, the subject criterion + * {@code X509Certificate}. If {@code null}, the subject criterion * is disabled and any subject distinguished name will do. * * @return the required subject distinguished name as X500Principal - * (or null) + * (or {@code null}) * @since 1.5 */ public X500Principal getSubject() { @@ -1384,16 +1384,16 @@ public class X509CertSelector implements CertSelector { * encoding information in the RFC 2253 String form of some distinguished * names. *

    - * Returns the subject criterion as a String. This + * Returns the subject criterion as a {@code String}. This * distinguished name must match the subject distinguished name in the - * X509Certificate. If null, the subject criterion + * {@code X509Certificate}. If {@code null}, the subject criterion * is disabled and any subject distinguished name will do. *

    - * If the value returned is not null, it is a + * If the value returned is not {@code null}, it is a * distinguished name, in RFC 2253 format. * * @return the required subject distinguished name in RFC 2253 format - * (or null) + * (or {@code null}) */ public String getSubjectAsString() { return (subject == null ? null : subject.getName()); @@ -1402,10 +1402,10 @@ public class X509CertSelector implements CertSelector { /** * Returns the subject criterion as a byte array. This distinguished name * must match the subject distinguished name in the - * X509Certificate. If null, the subject criterion + * {@code X509Certificate}. If {@code null}, the subject criterion * is disabled and any subject distinguished name will do. *

    - * If the value returned is not null, it is a byte + * If the value returned is not {@code null}, it is a byte * array containing a single DER encoded distinguished name, as defined in * X.501. The ASN.1 notation for this structure is supplied in the * documentation for @@ -1415,7 +1415,7 @@ public class X509CertSelector implements CertSelector { * subsequent modifications. * * @return a byte array containing the required subject distinguished name - * in ASN.1 DER format (or null) + * in ASN.1 DER format (or {@code null}) * @throws IOException if an encoding error occurs */ public byte[] getSubjectAsBytes() throws IOException { @@ -1424,14 +1424,14 @@ public class X509CertSelector implements CertSelector { /** * Returns the subjectKeyIdentifier criterion. The - * X509Certificate must contain a SubjectKeyIdentifier - * extension with the specified value. If null, no + * {@code X509Certificate} must contain a SubjectKeyIdentifier + * extension with the specified value. If {@code null}, no * subjectKeyIdentifier check will be done. *

    * Note that the byte array returned is cloned to protect against * subsequent modifications. * - * @return the key identifier (or null) + * @return the key identifier (or {@code null}) * @see #setSubjectKeyIdentifier */ public byte[] getSubjectKeyIdentifier() { @@ -1443,14 +1443,14 @@ public class X509CertSelector implements CertSelector { /** * Returns the authorityKeyIdentifier criterion. The - * X509Certificate must contain a AuthorityKeyIdentifier - * extension with the specified value. If null, no + * {@code X509Certificate} must contain a AuthorityKeyIdentifier + * extension with the specified value. If {@code null}, no * authorityKeyIdentifier check will be done. *

    * Note that the byte array returned is cloned to protect against * subsequent modifications. * - * @return the key identifier (or null) + * @return the key identifier (or {@code null}) * @see #setAuthorityKeyIdentifier */ public byte[] getAuthorityKeyIdentifier() { @@ -1463,13 +1463,13 @@ public class X509CertSelector implements CertSelector { /** * Returns the certificateValid criterion. The specified date must fall * within the certificate validity period for the - * X509Certificate. If null, no certificateValid + * {@code X509Certificate}. If {@code null}, no certificateValid * check will be done. *

    - * Note that the Date returned is cloned to protect against + * Note that the {@code Date} returned is cloned to protect against * subsequent modifications. * - * @return the Date to check (or null) + * @return the {@code Date} to check (or {@code null}) * @see #setCertificateValid */ public Date getCertificateValid() { @@ -1482,13 +1482,13 @@ public class X509CertSelector implements CertSelector { /** * Returns the privateKeyValid criterion. The specified date must fall * within the private key validity period for the - * X509Certificate. If null, no privateKeyValid + * {@code X509Certificate}. If {@code null}, no privateKeyValid * check will be done. *

    - * Note that the Date returned is cloned to protect against + * Note that the {@code Date} returned is cloned to protect against * subsequent modifications. * - * @return the Date to check (or null) + * @return the {@code Date} to check (or {@code null}) * @see #setPrivateKeyValid */ public Date getPrivateKeyValid() { @@ -1500,12 +1500,12 @@ public class X509CertSelector implements CertSelector { /** * Returns the subjectPublicKeyAlgID criterion. The - * X509Certificate must contain a subject public key - * with the specified algorithm. If null, no + * {@code X509Certificate} must contain a subject public key + * with the specified algorithm. If {@code null}, no * subjectPublicKeyAlgID check will be done. * * @return the object identifier (OID) of the signature algorithm to check - * for (or null). An OID is represented by a set of + * for (or {@code null}). An OID is represented by a set of * nonnegative integers separated by periods. * @see #setSubjectPublicKeyAlgID */ @@ -1518,10 +1518,10 @@ public class X509CertSelector implements CertSelector { /** * Returns the subjectPublicKey criterion. The - * X509Certificate must contain the specified subject - * public key. If null, no subjectPublicKey check will be done. + * {@code X509Certificate} must contain the specified subject + * public key. If {@code null}, no subjectPublicKey check will be done. * - * @return the subject public key to check for (or null) + * @return the subject public key to check for (or {@code null}) * @see #setSubjectPublicKey */ public PublicKey getSubjectPublicKey() { @@ -1529,7 +1529,7 @@ public class X509CertSelector implements CertSelector { } /** - * Returns the keyUsage criterion. The X509Certificate + * Returns the keyUsage criterion. The {@code X509Certificate} * must allow the specified keyUsage values. If null, no keyUsage * check will be done. *

    @@ -1539,7 +1539,7 @@ public class X509CertSelector implements CertSelector { * @return a boolean array in the same format as the boolean * array returned by * {@link X509Certificate#getKeyUsage() X509Certificate.getKeyUsage()}. - * Or null. + * Or {@code null}. * @see #setKeyUsage */ public boolean[] getKeyUsage() { @@ -1550,15 +1550,15 @@ public class X509CertSelector implements CertSelector { } /** - * Returns the extendedKeyUsage criterion. The X509Certificate + * Returns the extendedKeyUsage criterion. The {@code X509Certificate} * must allow the specified key purposes in its extended key usage - * extension. If the keyPurposeSet returned is empty or - * null, no extendedKeyUsage check will be done. Note that an - * X509Certificate that has no extendedKeyUsage extension + * extension. If the {@code keyPurposeSet} returned is empty or + * {@code null}, no extendedKeyUsage check will be done. Note that an + * {@code X509Certificate} that has no extendedKeyUsage extension * implicitly allows all key purposes. * - * @return an immutable Set of key purpose OIDs in string - * format (or null) + * @return an immutable {@code Set} of key purpose OIDs in string + * format (or {@code null}) * @see #setExtendedKeyUsage */ public Set getExtendedKeyUsage() { @@ -1566,19 +1566,19 @@ public class X509CertSelector implements CertSelector { } /** - * Indicates if the X509Certificate must contain all + * Indicates if the {@code X509Certificate} must contain all * or at least one of the subjectAlternativeNames * specified in the {@link #setSubjectAlternativeNames * setSubjectAlternativeNames} or {@link #addSubjectAlternativeName - * addSubjectAlternativeName} methods. If true, - * the X509Certificate must contain all of the - * specified subject alternative names. If false, the - * X509Certificate must contain at least one of the + * addSubjectAlternativeName} methods. If {@code true}, + * the {@code X509Certificate} must contain all of the + * specified subject alternative names. If {@code false}, the + * {@code X509Certificate} must contain at least one of the * specified subject alternative names. * - * @return true if the flag is enabled; - * false if the flag is disabled. The flag is - * true by default. + * @return {@code true} if the flag is enabled; + * {@code false} if the flag is disabled. The flag is + * {@code true} by default. * @see #setMatchAllSubjectAltNames */ public boolean getMatchAllSubjectAltNames() { @@ -1587,35 +1587,35 @@ public class X509CertSelector implements CertSelector { /** * Returns a copy of the subjectAlternativeNames criterion. - * The X509Certificate must contain all or at least one + * The {@code X509Certificate} must contain all or at least one * of the specified subjectAlternativeNames, depending on the value * of the matchAllNames flag (see {@link #getMatchAllSubjectAltNames * getMatchAllSubjectAltNames}). If the value returned is - * null, no subjectAlternativeNames check will be performed. + * {@code null}, no subjectAlternativeNames check will be performed. *

    - * If the value returned is not null, it is a - * Collection with + * If the value returned is not {@code null}, it is a + * {@code Collection} with * one entry for each name to be included in the subject alternative name - * criterion. Each entry is a List whose first entry is an - * Integer (the name type, 0-8) and whose second - * entry is a String or a byte array (the name, in + * criterion. Each entry is a {@code List} whose first entry is an + * {@code Integer} (the name type, 0-8) and whose second + * entry is a {@code String} or a byte array (the name, in * string or ASN.1 DER encoded form, respectively). * There can be multiple names of the same type. Note that the - * Collection returned may contain duplicate names (same name + * {@code Collection} returned may contain duplicate names (same name * and name type). *

    - * Each subject alternative name in the Collection - * may be specified either as a String or as an ASN.1 encoded + * Each subject alternative name in the {@code Collection} + * may be specified either as a {@code String} or as an ASN.1 encoded * byte array. For more details about the formats used, see * {@link #addSubjectAlternativeName(int type, String name) * addSubjectAlternativeName(int type, String name)} and * {@link #addSubjectAlternativeName(int type, byte [] name) * addSubjectAlternativeName(int type, byte [] name)}. *

    - * Note that a deep copy is performed on the Collection to + * Note that a deep copy is performed on the {@code Collection} to * protect against subsequent modifications. * - * @return a Collection of names (or null) + * @return a {@code Collection} of names (or {@code null}) * @see #setSubjectAlternativeNames */ public Collection> getSubjectAlternativeNames() { @@ -1628,21 +1628,21 @@ public class X509CertSelector implements CertSelector { /** * Clone an object of the form passed to * setSubjectAlternativeNames and setPathToNames. - * Throw a RuntimeException if the argument is malformed. + * Throw a {@code RuntimeException} if the argument is malformed. *

    * This method wraps cloneAndCheckNames, changing any - * IOException into a RuntimeException. This + * {@code IOException} into a {@code RuntimeException}. This * method should be used when the object being * cloned has already been checked, so there should never be any exceptions. * - * @param names a Collection with one entry per name. - * Each entry is a List whose first entry + * @param names a {@code Collection} with one entry per name. + * Each entry is a {@code List} whose first entry * is an Integer (the name type, 0-8) and whose second * entry is a String or a byte array (the name, in * string or ASN.1 DER encoded form, respectively). * There can be multiple names of the same type. Null * is not an acceptable value. - * @return a deep copy of the specified Collection + * @return a deep copy of the specified {@code Collection} * @throws RuntimeException if a parsing error occurs */ private static Set> cloneNames(Collection> names) { @@ -1657,16 +1657,16 @@ public class X509CertSelector implements CertSelector { /** * Clone and check an argument of the form passed to * setSubjectAlternativeNames and setPathToNames. - * Throw an IOException if the argument is malformed. + * Throw an {@code IOException} if the argument is malformed. * - * @param names a Collection with one entry per name. - * Each entry is a List whose first entry + * @param names a {@code Collection} with one entry per name. + * Each entry is a {@code List} whose first entry * is an Integer (the name type, 0-8) and whose second * entry is a String or a byte array (the name, in * string or ASN.1 DER encoded form, respectively). * There can be multiple names of the same type. - * null is not an acceptable value. - * @return a deep copy of the specified Collection + * {@code null} is not an acceptable value. + * @return a deep copy of the specified {@code Collection} * @throws IOException if a parsing error occurs */ private static Set> cloneAndCheckNames(Collection> names) throws IOException { @@ -1709,7 +1709,7 @@ public class X509CertSelector implements CertSelector { } /** - * Returns the name constraints criterion. The X509Certificate + * Returns the name constraints criterion. The {@code X509Certificate} * must have subject and subject alternative names that * meet the specified name constraints. *

    @@ -1725,7 +1725,7 @@ public class X509CertSelector implements CertSelector { * * @return a byte array containing the ASN.1 DER encoding of * a NameConstraints extension used for checking name constraints. - * null if no name constraints check will be performed. + * {@code null} if no name constraints check will be performed. * @see #setNameConstraints */ public byte[] getNameConstraints() { @@ -1738,7 +1738,7 @@ public class X509CertSelector implements CertSelector { /** * Returns the basic constraints constraint. If the value is greater than - * or equal to zero, the X509Certificates must include a + * or equal to zero, the {@code X509Certificates} must include a * basicConstraints extension with a pathLen of at least this value. * If the value is -2, only end-entity certificates are accepted. If * the value is -1, no basicConstraints check is done. @@ -1751,15 +1751,15 @@ public class X509CertSelector implements CertSelector { } /** - * Returns the policy criterion. The X509Certificate must + * Returns the policy criterion. The {@code X509Certificate} must * include at least one of the specified policies in its certificate policies - * extension. If the Set returned is empty, then the - * X509Certificate must include at least some specified policy - * in its certificate policies extension. If the Set returned is - * null, no policy check will be performed. + * extension. If the {@code Set} returned is empty, then the + * {@code X509Certificate} must include at least some specified policy + * in its certificate policies extension. If the {@code Set} returned is + * {@code null}, no policy check will be performed. * - * @return an immutable Set of certificate policy OIDs in - * string format (or null) + * @return an immutable {@code Set} of certificate policy OIDs in + * string format (or {@code null}) * @see #setPolicy */ public Set getPolicy() { @@ -1768,33 +1768,33 @@ public class X509CertSelector implements CertSelector { /** * Returns a copy of the pathToNames criterion. The - * X509Certificate must not include name constraints that would + * {@code X509Certificate} must not include name constraints that would * prohibit building a path to the specified names. If the value - * returned is null, no pathToNames check will be performed. + * returned is {@code null}, no pathToNames check will be performed. *

    - * If the value returned is not null, it is a - * Collection with one + * If the value returned is not {@code null}, it is a + * {@code Collection} with one * entry for each name to be included in the pathToNames - * criterion. Each entry is a List whose first entry is an - * Integer (the name type, 0-8) and whose second - * entry is a String or a byte array (the name, in + * criterion. Each entry is a {@code List} whose first entry is an + * {@code Integer} (the name type, 0-8) and whose second + * entry is a {@code String} or a byte array (the name, in * string or ASN.1 DER encoded form, respectively). * There can be multiple names of the same type. Note that the - * Collection returned may contain duplicate names (same + * {@code Collection} returned may contain duplicate names (same * name and name type). *

    - * Each name in the Collection - * may be specified either as a String or as an ASN.1 encoded + * Each name in the {@code Collection} + * may be specified either as a {@code String} or as an ASN.1 encoded * byte array. For more details about the formats used, see * {@link #addPathToName(int type, String name) * addPathToName(int type, String name)} and * {@link #addPathToName(int type, byte [] name) * addPathToName(int type, byte [] name)}. *

    - * Note that a deep copy is performed on the Collection to + * Note that a deep copy is performed on the {@code Collection} to * protect against subsequent modifications. * - * @return a Collection of names (or null) + * @return a {@code Collection} of names (or {@code null}) * @see #setPathToNames */ public Collection> getPathToNames() { @@ -1805,10 +1805,10 @@ public class X509CertSelector implements CertSelector { } /** - * Return a printable representation of the CertSelector. + * Return a printable representation of the {@code CertSelector}. * - * @return a String describing the contents of the - * CertSelector + * @return a {@code String} describing the contents of the + * {@code CertSelector} */ public String toString() { StringBuffer sb = new StringBuffer(); @@ -1927,22 +1927,22 @@ public class X509CertSelector implements CertSelector { /** * Returns an Extension object given any X509Certificate and extension oid. - * Throw an IOException if the extension byte value is + * Throw an {@code IOException} if the extension byte value is * malformed. * - * @param cert a X509Certificate - * @param extId an integer which specifies the extension index. + * @param cert a {@code X509Certificate} + * @param extId an {@code integer} which specifies the extension index. * Currently, the supported extensions are as follows: * index 0 - PrivateKeyUsageExtension * index 1 - SubjectAlternativeNameExtension * index 2 - NameConstraintsExtension * index 3 - CertificatePoliciesExtension * index 4 - ExtendedKeyUsageExtension - * @return an Extension object whose real type is as specified + * @return an {@code Extension} object whose real type is as specified * by the extension oid. - * @throws IOException if cannot construct the Extension + * @throws IOException if cannot construct the {@code Extension} * object with the extension encoding retrieved from the passed in - * X509Certificate. + * {@code X509Certificate}. */ private static Extension getExtensionObject(X509Certificate cert, int extId) throws IOException { @@ -1990,11 +1990,11 @@ public class X509CertSelector implements CertSelector { } /** - * Decides whether a Certificate should be selected. + * Decides whether a {@code Certificate} should be selected. * - * @param cert the Certificate to be checked - * @return true if the Certificate should be - * selected, false otherwise + * @param cert the {@code Certificate} to be checked + * @return {@code true} if the {@code Certificate} should be + * selected, {@code false} otherwise */ public boolean match(Certificate cert) { if (!(cert instanceof X509Certificate)) { diff --git a/jdk/src/share/classes/java/security/cert/X509Certificate.java b/jdk/src/share/classes/java/security/cert/X509Certificate.java index f257d028f7b..9094dfcc95d 100644 --- a/jdk/src/share/classes/java/security/cert/X509Certificate.java +++ b/jdk/src/share/classes/java/security/cert/X509Certificate.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -66,7 +66,7 @@ import sun.security.x509.X509CertImpl; * RFC 3280: Internet X.509 * Public Key Infrastructure Certificate and CRL Profile. *

    - * The ASN.1 definition of tbsCertificate is: + * The ASN.1 definition of {@code tbsCertificate} is: *

      * TBSCertificate  ::=  SEQUENCE  {
      *     version         [0]  EXPLICIT Version DEFAULT v1,
    @@ -151,9 +151,9 @@ implements X509Extension {
          *        is valid at that date/time.
          *
          * @exception CertificateExpiredException if the certificate has expired
    -     * with respect to the date supplied.
    +     * with respect to the {@code date} supplied.
          * @exception CertificateNotYetValidException if the certificate is not
    -     * yet valid with respect to the date supplied.
    +     * yet valid with respect to the {@code date} supplied.
          *
          * @see #checkValidity()
          */
    @@ -161,7 +161,7 @@ implements X509Extension {
             throws CertificateExpiredException, CertificateNotYetValidException;
     
         /**
    -     * Gets the version (version number) value from the
    +     * Gets the {@code version} (version number) value from the
          * certificate.
          * The ASN.1 definition for this is:
          * 
    @@ -173,7 +173,7 @@ implements X509Extension {
         public abstract int getVersion();
     
         /**
    -     * Gets the serialNumber value from the certificate.
    +     * Gets the {@code serialNumber} value from the certificate.
          * The serial number is an integer assigned by the certification
          * authority to each certificate. It must be unique for each
          * certificate issued by a given CA (i.e., the issuer name and
    @@ -191,12 +191,12 @@ implements X509Extension {
     
         /**
          * Denigrated, replaced by {@linkplain
    -     * #getIssuerX500Principal()}. This method returns the issuer
    +     * #getIssuerX500Principal()}. This method returns the {@code issuer}
          * as an implementation specific Principal object, which should not be
          * relied upon by portable code.
          *
          * 

    - * Gets the issuer (issuer distinguished name) value from + * Gets the {@code issuer} (issuer distinguished name) value from * the certificate. The issuer name identifies the entity that signed (and * issued) the certificate. * @@ -217,14 +217,14 @@ implements X509Extension { * AttributeType ::= OBJECT IDENTIFIER * AttributeValue ::= ANY *

    - * The Name describes a hierarchical name composed of + * The {@code Name} describes a hierarchical name composed of * attributes, * such as country name, and corresponding values, such as US. - * The type of the AttributeValue component is determined by - * the AttributeType; in general it will be a - * directoryString. A directoryString is usually - * one of PrintableString, - * TeletexString or UniversalString. + * The type of the {@code AttributeValue} component is determined by + * the {@code AttributeType}; in general it will be a + * {@code directoryString}. A {@code directoryString} is usually + * one of {@code PrintableString}, + * {@code TeletexString} or {@code UniversalString}. * * @return a Principal whose name is the issuer distinguished name. */ @@ -232,11 +232,11 @@ implements X509Extension { /** * Returns the issuer (issuer distinguished name) value from the - * certificate as an X500Principal. + * certificate as an {@code X500Principal}. *

    * It is recommended that subclasses override this method. * - * @return an X500Principal representing the issuer + * @return an {@code X500Principal} representing the issuer * distinguished name * @since 1.4 */ @@ -249,22 +249,22 @@ implements X509Extension { /** * Denigrated, replaced by {@linkplain - * #getSubjectX500Principal()}. This method returns the subject + * #getSubjectX500Principal()}. This method returns the {@code subject} * as an implementation specific Principal object, which should not be * relied upon by portable code. * *

    - * Gets the subject (subject distinguished name) value - * from the certificate. If the subject value is empty, - * then the getName() method of the returned - * Principal object returns an empty string (""). + * Gets the {@code subject} (subject distinguished name) value + * from the certificate. If the {@code subject} value is empty, + * then the {@code getName()} method of the returned + * {@code Principal} object returns an empty string (""). * *

    The ASN.1 definition for this is: *

          * subject    Name
          * 
    * - *

    See {@link #getIssuerDN() getIssuerDN} for Name + *

    See {@link #getIssuerDN() getIssuerDN} for {@code Name} * and other relevant definitions. * * @return a Principal whose name is the subject name. @@ -273,13 +273,13 @@ implements X509Extension { /** * Returns the subject (subject distinguished name) value from the - * certificate as an X500Principal. If the subject value - * is empty, then the getName() method of the returned - * X500Principal object returns an empty string (""). + * certificate as an {@code X500Principal}. If the subject value + * is empty, then the {@code getName()} method of the returned + * {@code X500Principal} object returns an empty string (""). *

    * It is recommended that subclasses override this method. * - * @return an X500Principal representing the subject + * @return an {@code X500Principal} representing the subject * distinguished name * @since 1.4 */ @@ -291,7 +291,7 @@ implements X509Extension { } /** - * Gets the notBefore date from the validity period of + * Gets the {@code notBefore} date from the validity period of * the certificate. * The relevant ASN.1 definitions are: *

    @@ -311,7 +311,7 @@ implements X509Extension {
         public abstract Date getNotBefore();
     
         /**
    -     * Gets the notAfter date from the validity period of
    +     * Gets the {@code notAfter} date from the validity period of
          * the certificate. See {@link #getNotBefore() getNotBefore}
          * for relevant ASN.1 definitions.
          *
    @@ -322,7 +322,7 @@ implements X509Extension {
     
         /**
          * Gets the DER-encoded certificate information, the
    -     * tbsCertificate from this certificate.
    +     * {@code tbsCertificate} from this certificate.
          * This can be used to verify the signature independently.
          *
          * @return the DER-encoded certificate information.
    @@ -332,7 +332,7 @@ implements X509Extension {
             throws CertificateEncodingException;
     
         /**
    -     * Gets the signature value (the raw signature bits) from
    +     * Gets the {@code signature} value (the raw signature bits) from
          * the certificate.
          * The ASN.1 definition for this is:
          * 
    @@ -357,7 +357,7 @@ implements X509Extension {
          *                             -- algorithm object identifier value
          * 
    * - *

    The algorithm name is determined from the algorithm + *

    The algorithm name is determined from the {@code algorithm} * OID string. * * @return the signature algorithm name. @@ -400,7 +400,7 @@ implements X509Extension { public abstract byte[] getSigAlgParams(); /** - * Gets the issuerUniqueID value from the certificate. + * Gets the {@code issuerUniqueID} value from the certificate. * The issuer unique identifier is present in the certificate * to handle the possibility of reuse of issuer names over time. * RFC 3280 recommends that names not be reused and that @@ -420,7 +420,7 @@ implements X509Extension { public abstract boolean[] getIssuerUniqueID(); /** - * Gets the subjectUniqueID value from the certificate. + * Gets the {@code subjectUniqueID} value from the certificate. * *

    The ASN.1 definition for this is: *

    @@ -435,7 +435,7 @@ implements X509Extension {
     
         /**
          * Gets a boolean array representing bits of
    -     * the KeyUsage extension, (OID = 2.5.29.15).
    +     * the {@code KeyUsage} extension, (OID = 2.5.29.15).
          * The key usage extension defines the purpose (e.g., encipherment,
          * signature, certificate signing) of the key contained in the
          * certificate.
    @@ -467,7 +467,7 @@ implements X509Extension {
     
         /**
          * Gets an unmodifiable list of Strings representing the OBJECT
    -     * IDENTIFIERs of the ExtKeyUsageSyntax field of the
    +     * IDENTIFIERs of the {@code ExtKeyUsageSyntax} field of the
          * extended key usage extension, (OID = 2.5.29.37).  It indicates
          * one or more purposes for which the certified public key may be
          * used, in addition to or in place of the basic purposes
    @@ -486,7 +486,7 @@ implements X509Extension {
          * 

    * This method was added to version 1.4 of the Java 2 Platform Standard * Edition. In order to maintain backwards compatibility with existing - * service providers, this method is not abstract + * service providers, this method is not {@code abstract} * and it provides a default implementation. Subclasses * should override this method with a correct implementation. * @@ -503,13 +503,13 @@ implements X509Extension { /** * Gets the certificate constraints path length from the - * critical BasicConstraints extension, (OID = 2.5.29.19). + * critical {@code BasicConstraints} extension, (OID = 2.5.29.19). *

    * The basic constraints extension identifies whether the subject * of the certificate is a Certificate Authority (CA) and * how deep a certification path may exist through that CA. The - * pathLenConstraint field (see below) is meaningful - * only if cA is set to TRUE. In this case, it gives the + * {@code pathLenConstraint} field (see below) is meaningful + * only if {@code cA} is set to TRUE. In this case, it gives the * maximum number of CA certificates that may follow this certificate in a * certification path. A value of zero indicates that only an end-entity * certificate may follow in the path. @@ -521,21 +521,21 @@ implements X509Extension { * pathLenConstraint INTEGER (0..MAX) OPTIONAL } *

    * - * @return the value of pathLenConstraint if the + * @return the value of {@code pathLenConstraint} if the * BasicConstraints extension is present in the certificate and the * subject of the certificate is a CA, otherwise -1. * If the subject of the certificate is a CA and - * pathLenConstraint does not appear, - * Integer.MAX_VALUE is returned to indicate that there is no + * {@code pathLenConstraint} does not appear, + * {@code Integer.MAX_VALUE} is returned to indicate that there is no * limit to the allowed length of the certification path. */ public abstract int getBasicConstraints(); /** * Gets an immutable collection of subject alternative names from the - * SubjectAltName extension, (OID = 2.5.29.17). + * {@code SubjectAltName} extension, (OID = 2.5.29.17). *

    - * The ASN.1 definition of the SubjectAltName extension is: + * The ASN.1 definition of the {@code SubjectAltName} extension is: *

          * SubjectAltName ::= GeneralNames
          *
    @@ -553,23 +553,23 @@ implements X509Extension {
          *      registeredID                    [8]     OBJECT IDENTIFIER}
          * 
    *

    - * If this certificate does not contain a SubjectAltName - * extension, null is returned. Otherwise, a - * Collection is returned with an entry representing each - * GeneralName included in the extension. Each entry is a - * List whose first entry is an Integer - * (the name type, 0-8) and whose second entry is a String + * If this certificate does not contain a {@code SubjectAltName} + * extension, {@code null} is returned. Otherwise, a + * {@code Collection} is returned with an entry representing each + * {@code GeneralName} included in the extension. Each entry is a + * {@code List} whose first entry is an {@code Integer} + * (the name type, 0-8) and whose second entry is a {@code String} * or a byte array (the name, in string or ASN.1 DER encoded form, * respectively). *

    * RFC 822, DNS, and URI - * names are returned as Strings, + * names are returned as {@code String}s, * using the well-established string formats for those types (subject to * the restrictions included in RFC 3280). IPv4 address names are * returned using dotted quad notation. IPv6 address names are returned * in the form "a1:a2:...:a8", where a1-a8 are hexadecimal values * representing the eight 16-bit pieces of the address. OID names are - * returned as Strings represented as a series of nonnegative + * returned as {@code String}s represented as a series of nonnegative * integers separated by periods. And directory names (distinguished names) * are returned in * RFC 2253 string format. No standard string format is @@ -577,19 +577,19 @@ implements X509Extension { * other type of names. They are returned as byte arrays * containing the ASN.1 DER encoded form of the name. *

    - * Note that the Collection returned may contain more + * Note that the {@code Collection} returned may contain more * than one name of the same type. Also, note that the returned - * Collection is immutable and any entries containing byte + * {@code Collection} is immutable and any entries containing byte * arrays are cloned to protect against subsequent modifications. *

    * This method was added to version 1.4 of the Java 2 Platform Standard * Edition. In order to maintain backwards compatibility with existing - * service providers, this method is not abstract + * service providers, this method is not {@code abstract} * and it provides a default implementation. Subclasses * should override this method with a correct implementation. * - * @return an immutable Collection of subject alternative - * names (or null) + * @return an immutable {@code Collection} of subject alternative + * names (or {@code null}) * @throws CertificateParsingException if the extension cannot be decoded * @since 1.4 */ @@ -600,38 +600,38 @@ implements X509Extension { /** * Gets an immutable collection of issuer alternative names from the - * IssuerAltName extension, (OID = 2.5.29.18). + * {@code IssuerAltName} extension, (OID = 2.5.29.18). *

    - * The ASN.1 definition of the IssuerAltName extension is: + * The ASN.1 definition of the {@code IssuerAltName} extension is: *

          * IssuerAltName ::= GeneralNames
          * 
    - * The ASN.1 definition of GeneralNames is defined + * The ASN.1 definition of {@code GeneralNames} is defined * in {@link #getSubjectAlternativeNames getSubjectAlternativeNames}. *

    - * If this certificate does not contain an IssuerAltName - * extension, null is returned. Otherwise, a - * Collection is returned with an entry representing each - * GeneralName included in the extension. Each entry is a - * List whose first entry is an Integer - * (the name type, 0-8) and whose second entry is a String + * If this certificate does not contain an {@code IssuerAltName} + * extension, {@code null} is returned. Otherwise, a + * {@code Collection} is returned with an entry representing each + * {@code GeneralName} included in the extension. Each entry is a + * {@code List} whose first entry is an {@code Integer} + * (the name type, 0-8) and whose second entry is a {@code String} * or a byte array (the name, in string or ASN.1 DER encoded form, * respectively). For more details about the formats used for each - * name type, see the getSubjectAlternativeNames method. + * name type, see the {@code getSubjectAlternativeNames} method. *

    - * Note that the Collection returned may contain more + * Note that the {@code Collection} returned may contain more * than one name of the same type. Also, note that the returned - * Collection is immutable and any entries containing byte + * {@code Collection} is immutable and any entries containing byte * arrays are cloned to protect against subsequent modifications. *

    * This method was added to version 1.4 of the Java 2 Platform Standard * Edition. In order to maintain backwards compatibility with existing - * service providers, this method is not abstract + * service providers, this method is not {@code abstract} * and it provides a default implementation. Subclasses * should override this method with a correct implementation. * - * @return an immutable Collection of issuer alternative - * names (or null) + * @return an immutable {@code Collection} of issuer alternative + * names (or {@code null}) * @throws CertificateParsingException if the extension cannot be decoded * @since 1.4 */ @@ -649,7 +649,7 @@ implements X509Extension { * * This method was added to version 1.8 of the Java Platform Standard * Edition. In order to maintain backwards compatibility with existing - * service providers, this method is not abstract + * service providers, this method is not {@code abstract} * and it provides a default implementation. * * @param key the PublicKey used to carry out the verification. diff --git a/jdk/src/share/classes/java/security/cert/X509Extension.java b/jdk/src/share/classes/java/security/cert/X509Extension.java index ee63e662347..03469606eed 100644 --- a/jdk/src/share/classes/java/security/cert/X509Extension.java +++ b/jdk/src/share/classes/java/security/cert/X509Extension.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -59,9 +59,9 @@ import java.util.Set; * -- the extnId object identifier value * } *

    - * Since not all extensions are known, the getExtensionValue + * Since not all extensions are known, the {@code getExtensionValue} * method returns the DER-encoded OCTET STRING of the - * extension value (i.e., the extnValue). This can then + * extension value (i.e., the {@code extnValue}). This can then * be handled by a Class that understands the extension. * * @author Hemma Prafullchandra @@ -72,8 +72,8 @@ public interface X509Extension { /** * Check if there is a critical extension that is not supported. * - * @return true if a critical extension is found that is - * not supported, otherwise false. + * @return {@code true} if a critical extension is found that is + * not supported, otherwise {@code false}. */ public boolean hasUnsupportedCriticalExtension(); @@ -113,28 +113,28 @@ public interface X509Extension { * * Here is sample code to get a Set of non-critical extensions from an * X509CRL revoked certificate entry and print the OIDs: - *
    
    +     * 
    {@code
          * CertificateFactory cf = null;
          * X509CRL crl = null;
          * try (InputStream inStrm = new FileInputStream("DER-encoded-CRL")) {
          *     cf = CertificateFactory.getInstance("X.509");
          *     crl = (X509CRL)cf.generateCRL(inStrm);
    -     * }

    + * } * - * byte[] certData = <DER-encoded certificate data> + * byte[] certData = * ByteArrayInputStream bais = new ByteArrayInputStream(certData); * X509Certificate cert = (X509Certificate)cf.generateCertificate(bais); * X509CRLEntry badCert = - * crl.getRevokedCertificate(cert.getSerialNumber());

    + * crl.getRevokedCertificate(cert.getSerialNumber()); * * if (badCert != null) { - * Set nonCritSet = badCert.getNonCriticalExtensionOIDs();

    + * Set nonCritSet = badCert.getNonCriticalExtensionOIDs(); * if (nonCritSet != null) * for (String oid : nonCritSet) { * System.out.println(oid); * } * } - *

    + * }
    * * @return a Set (or an empty Set if none are marked non-critical) of * the extension OID strings for extensions that are marked non-critical. @@ -145,9 +145,9 @@ public interface X509Extension { /** * Gets the DER-encoded OCTET string for the extension value - * (extnValue) identified by the passed-in oid + * (extnValue) identified by the passed-in {@code oid} * String. - * The oid string is + * The {@code oid} string is * represented by a set of nonnegative whole numbers separated * by periods. * From d30f173a22d49a586ee59722ac8470efe69558e2 Mon Sep 17 00:00:00 2001 From: Jason Uh Date: Tue, 25 Jun 2013 14:41:46 -0700 Subject: [PATCH 025/127] 8017326: Cleanup of the javadoc tag in java.security.spec Convert javadoc and tags to {@code ...} Reviewed-by: darcy --- .../security/spec/DSAGenParameterSpec.java | 20 +++--- .../java/security/spec/DSAParameterSpec.java | 14 ++-- .../java/security/spec/DSAPrivateKeySpec.java | 18 ++--- .../java/security/spec/DSAPublicKeySpec.java | 18 ++--- .../java/security/spec/ECFieldF2m.java | 70 +++++++++---------- .../classes/java/security/spec/ECFieldFp.java | 12 ++-- .../security/spec/ECGenParameterSpec.java | 6 +- .../java/security/spec/ECParameterSpec.java | 12 ++-- .../classes/java/security/spec/ECPoint.java | 14 ++-- .../java/security/spec/ECPrivateKeySpec.java | 6 +- .../java/security/spec/ECPublicKeySpec.java | 8 +-- .../java/security/spec/EllipticCurve.java | 44 ++++++------ .../java/security/spec/EncodedKeySpec.java | 8 +-- .../spec/InvalidKeySpecException.java | 14 ++-- .../classes/java/security/spec/KeySpec.java | 4 +- .../java/security/spec/MGF1ParameterSpec.java | 4 +- .../security/spec/PKCS8EncodedKeySpec.java | 10 +-- .../java/security/spec/PSSParameterSpec.java | 18 ++--- .../security/spec/RSAKeyGenParameterSpec.java | 4 +- .../spec/RSAMultiPrimePrivateCrtKeySpec.java | 18 ++--- .../java/security/spec/RSAOtherPrimeInfo.java | 8 +-- .../security/spec/RSAPrivateCrtKeySpec.java | 4 +- .../security/spec/X509EncodedKeySpec.java | 10 +-- 23 files changed, 172 insertions(+), 172 deletions(-) diff --git a/jdk/src/share/classes/java/security/spec/DSAGenParameterSpec.java b/jdk/src/share/classes/java/security/spec/DSAGenParameterSpec.java index a354c4807ac..932a9f05ccd 100644 --- a/jdk/src/share/classes/java/security/spec/DSAGenParameterSpec.java +++ b/jdk/src/share/classes/java/security/spec/DSAGenParameterSpec.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2013, 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 @@ -41,13 +41,13 @@ public final class DSAGenParameterSpec implements AlgorithmParameterSpec { /** * Creates a domain parameter specification for DSA parameter - * generation using primePLen and subprimeQLen. - * The value of subprimeQLen is also used as the default + * generation using {@code primePLen} and {@code subprimeQLen}. + * The value of {@code subprimeQLen} is also used as the default * length of the domain parameter seed in bits. * @param primePLen the desired length of the prime P in bits. * @param subprimeQLen the desired length of the sub-prime Q in bits. - * @exception IllegalArgumentException if primePLen - * or subprimeQLen is illegal per the specification of + * @exception IllegalArgumentException if {@code primePLen} + * or {@code subprimeQLen} is illegal per the specification of * FIPS 186-3. */ public DSAGenParameterSpec(int primePLen, int subprimeQLen) { @@ -56,14 +56,14 @@ public final class DSAGenParameterSpec implements AlgorithmParameterSpec { /** * Creates a domain parameter specification for DSA parameter - * generation using primePLen, subprimeQLen, - * and seedLen. + * generation using {@code primePLen}, {@code subprimeQLen}, + * and {@code seedLen}. * @param primePLen the desired length of the prime P in bits. * @param subprimeQLen the desired length of the sub-prime Q in bits. * @param seedLen the desired length of the domain parameter seed in bits, - * shall be equal to or greater than subprimeQLen. - * @exception IllegalArgumentException if primePLenLen, - * subprimeQLen, or seedLen is illegal per the + * shall be equal to or greater than {@code subprimeQLen}. + * @exception IllegalArgumentException if {@code primePLenLen}, + * {@code subprimeQLen}, or {@code seedLen} is illegal per the * specification of FIPS 186-3. */ public DSAGenParameterSpec(int primePLen, int subprimeQLen, int seedLen) { diff --git a/jdk/src/share/classes/java/security/spec/DSAParameterSpec.java b/jdk/src/share/classes/java/security/spec/DSAParameterSpec.java index 2c9c546669d..eed6bdcae8b 100644 --- a/jdk/src/share/classes/java/security/spec/DSAParameterSpec.java +++ b/jdk/src/share/classes/java/security/spec/DSAParameterSpec.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 1999, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -61,27 +61,27 @@ java.security.interfaces.DSAParams { } /** - * Returns the prime p. + * Returns the prime {@code p}. * - * @return the prime p. + * @return the prime {@code p}. */ public BigInteger getP() { return this.p; } /** - * Returns the sub-prime q. + * Returns the sub-prime {@code q}. * - * @return the sub-prime q. + * @return the sub-prime {@code q}. */ public BigInteger getQ() { return this.q; } /** - * Returns the base g. + * Returns the base {@code g}. * - * @return the base g. + * @return the base {@code g}. */ public BigInteger getG() { return this.g; diff --git a/jdk/src/share/classes/java/security/spec/DSAPrivateKeySpec.java b/jdk/src/share/classes/java/security/spec/DSAPrivateKeySpec.java index 44d6859fd6c..a004de75db3 100644 --- a/jdk/src/share/classes/java/security/spec/DSAPrivateKeySpec.java +++ b/jdk/src/share/classes/java/security/spec/DSAPrivateKeySpec.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 1999, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -69,36 +69,36 @@ public class DSAPrivateKeySpec implements KeySpec { } /** - * Returns the private key x. + * Returns the private key {@code x}. * - * @return the private key x. + * @return the private key {@code x}. */ public BigInteger getX() { return this.x; } /** - * Returns the prime p. + * Returns the prime {@code p}. * - * @return the prime p. + * @return the prime {@code p}. */ public BigInteger getP() { return this.p; } /** - * Returns the sub-prime q. + * Returns the sub-prime {@code q}. * - * @return the sub-prime q. + * @return the sub-prime {@code q}. */ public BigInteger getQ() { return this.q; } /** - * Returns the base g. + * Returns the base {@code g}. * - * @return the base g. + * @return the base {@code g}. */ public BigInteger getG() { return this.g; diff --git a/jdk/src/share/classes/java/security/spec/DSAPublicKeySpec.java b/jdk/src/share/classes/java/security/spec/DSAPublicKeySpec.java index 2dfc7384298..a56e6f9c08e 100644 --- a/jdk/src/share/classes/java/security/spec/DSAPublicKeySpec.java +++ b/jdk/src/share/classes/java/security/spec/DSAPublicKeySpec.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 1999, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -69,36 +69,36 @@ public class DSAPublicKeySpec implements KeySpec { } /** - * Returns the public key y. + * Returns the public key {@code y}. * - * @return the public key y. + * @return the public key {@code y}. */ public BigInteger getY() { return this.y; } /** - * Returns the prime p. + * Returns the prime {@code p}. * - * @return the prime p. + * @return the prime {@code p}. */ public BigInteger getP() { return this.p; } /** - * Returns the sub-prime q. + * Returns the sub-prime {@code q}. * - * @return the sub-prime q. + * @return the sub-prime {@code q}. */ public BigInteger getQ() { return this.q; } /** - * Returns the base g. + * Returns the base {@code g}. * - * @return the base g. + * @return the base {@code g}. */ public BigInteger getG() { return this.g; diff --git a/jdk/src/share/classes/java/security/spec/ECFieldF2m.java b/jdk/src/share/classes/java/security/spec/ECFieldF2m.java index f271ccbd350..58843ab67da 100644 --- a/jdk/src/share/classes/java/security/spec/ECFieldF2m.java +++ b/jdk/src/share/classes/java/security/spec/ECFieldF2m.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -45,9 +45,9 @@ public class ECFieldF2m implements ECField { /** * Creates an elliptic curve characteristic 2 finite - * field which has 2^m elements with normal basis. - * @param m with 2^m being the number of elements. - * @exception IllegalArgumentException if m + * field which has 2^{@code m} elements with normal basis. + * @param m with 2^{@code m} being the number of elements. + * @exception IllegalArgumentException if {@code m} * is not positive. */ public ECFieldF2m(int m) { @@ -61,24 +61,24 @@ public class ECFieldF2m implements ECField { /** * Creates an elliptic curve characteristic 2 finite - * field which has 2^m elements with + * field which has 2^{@code m} elements with * polynomial basis. * The reduction polynomial for this field is based - * on rp whose i-th bit correspondes to + * on {@code rp} whose i-th bit correspondes to * the i-th coefficient of the reduction polynomial.

    * Note: A valid reduction polynomial is either a - * trinomial (X^m + X^k + 1 - * with m > k >= 1) or a - * pentanomial (X^m + X^k3 - * + X^k2 + X^k1 + 1 with - * m > k3 > k2 - * > k1 >= 1). - * @param m with 2^m being the number of elements. + * trinomial (X^{@code m} + X^{@code k} + 1 + * with {@code m} > {@code k} >= 1) or a + * pentanomial (X^{@code m} + X^{@code k3} + * + X^{@code k2} + X^{@code k1} + 1 with + * {@code m} > {@code k3} > {@code k2} + * > {@code k1} >= 1). + * @param m with 2^{@code m} being the number of elements. * @param rp the BigInteger whose i-th bit corresponds to * the i-th coefficient of the reduction polynomial. - * @exception NullPointerException if rp is null. - * @exception IllegalArgumentException if m - * is not positive, or rp does not represent + * @exception NullPointerException if {@code rp} is null. + * @exception IllegalArgumentException if {@code m} + * is not positive, or {@code rp} does not represent * a valid reduction polynomial. */ public ECFieldF2m(int m, BigInteger rp) { @@ -106,28 +106,28 @@ public class ECFieldF2m implements ECField { /** * Creates an elliptic curve characteristic 2 finite - * field which has 2^m elements with + * field which has 2^{@code m} elements with * polynomial basis. The reduction polynomial for this - * field is based on ks whose content + * field is based on {@code ks} whose content * contains the order of the middle term(s) of the * reduction polynomial. * Note: A valid reduction polynomial is either a - * trinomial (X^m + X^k + 1 - * with m > k >= 1) or a - * pentanomial (X^m + X^k3 - * + X^k2 + X^k1 + 1 with - * m > k3 > k2 - * > k1 >= 1), so ks should + * trinomial (X^{@code m} + X^{@code k} + 1 + * with {@code m} > {@code k} >= 1) or a + * pentanomial (X^{@code m} + X^{@code k3} + * + X^{@code k2} + X^{@code k1} + 1 with + * {@code m} > {@code k3} > {@code k2} + * > {@code k1} >= 1), so {@code ks} should * have length 1 or 3. - * @param m with 2^m being the number of elements. + * @param m with 2^{@code m} being the number of elements. * @param ks the order of the middle term(s) of the * reduction polynomial. Contents of this array are copied * to protect against subsequent modification. - * @exception NullPointerException if ks is null. - * @exception IllegalArgumentException ifm - * is not positive, or the length of ks - * is neither 1 nor 3, or values in ks - * are not between m-1 and 1 (inclusive) + * @exception NullPointerException if {@code ks} is null. + * @exception IllegalArgumentException if{@code m} + * is not positive, or the length of {@code ks} + * is neither 1 nor 3, or values in {@code ks} + * are not between {@code m}-1 and 1 (inclusive) * and in descending order. */ public ECFieldF2m(int m, int[] ks) { @@ -160,7 +160,7 @@ public class ECFieldF2m implements ECField { } /** - * Returns the field size in bits which is m + * Returns the field size in bits which is {@code m} * for this characteristic 2 finite field. * @return the field size in bits. */ @@ -169,9 +169,9 @@ public class ECFieldF2m implements ECField { } /** - * Returns the value m of this characteristic + * Returns the value {@code m} of this characteristic * 2 finite field. - * @return m with 2^m being the + * @return {@code m} with 2^{@code m} being the * number of elements. */ public int getM() { @@ -211,8 +211,8 @@ public class ECFieldF2m implements ECField { * Compares this finite field for equality with the * specified object. * @param obj the object to be compared. - * @return true if obj is an instance - * of ECFieldF2m and both m and the reduction + * @return true if {@code obj} is an instance + * of ECFieldF2m and both {@code m} and the reduction * polynomial match, false otherwise. */ public boolean equals(Object obj) { diff --git a/jdk/src/share/classes/java/security/spec/ECFieldFp.java b/jdk/src/share/classes/java/security/spec/ECFieldFp.java index 183549981db..c578962d3c2 100644 --- a/jdk/src/share/classes/java/security/spec/ECFieldFp.java +++ b/jdk/src/share/classes/java/security/spec/ECFieldFp.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -43,10 +43,10 @@ public class ECFieldFp implements ECField { /** * Creates an elliptic curve prime finite field - * with the specified prime p. + * with the specified prime {@code p}. * @param p the prime. - * @exception NullPointerException if p is null. - * @exception IllegalArgumentException if p + * @exception NullPointerException if {@code p} is null. + * @exception IllegalArgumentException if {@code p} * is not positive. */ public ECFieldFp(BigInteger p) { @@ -66,7 +66,7 @@ public class ECFieldFp implements ECField { }; /** - * Returns the prime p of this prime finite field. + * Returns the prime {@code p} of this prime finite field. * @return the prime. */ public BigInteger getP() { @@ -77,7 +77,7 @@ public class ECFieldFp implements ECField { * Compares this prime finite field for equality with the * specified object. * @param obj the object to be compared. - * @return true if obj is an instance + * @return true if {@code obj} is an instance * of ECFieldFp and the prime value match, false otherwise. */ public boolean equals(Object obj) { diff --git a/jdk/src/share/classes/java/security/spec/ECGenParameterSpec.java b/jdk/src/share/classes/java/security/spec/ECGenParameterSpec.java index da1694541b5..4f3f63b873a 100644 --- a/jdk/src/share/classes/java/security/spec/ECGenParameterSpec.java +++ b/jdk/src/share/classes/java/security/spec/ECGenParameterSpec.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -41,13 +41,13 @@ public class ECGenParameterSpec implements AlgorithmParameterSpec { /** * Creates a parameter specification for EC parameter * generation using a standard (or predefined) name - * stdName in order to generate the corresponding + * {@code stdName} in order to generate the corresponding * (precomputed) elliptic curve domain parameters. For the * list of supported names, please consult the documentation * of provider whose implementation will be used. * @param stdName the standard name of the to-be-generated EC * domain parameters. - * @exception NullPointerException if stdName + * @exception NullPointerException if {@code stdName} * is null. */ public ECGenParameterSpec(String stdName) { diff --git a/jdk/src/share/classes/java/security/spec/ECParameterSpec.java b/jdk/src/share/classes/java/security/spec/ECParameterSpec.java index 8837516e3bf..3f7cae3b82b 100644 --- a/jdk/src/share/classes/java/security/spec/ECParameterSpec.java +++ b/jdk/src/share/classes/java/security/spec/ECParameterSpec.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -49,12 +49,12 @@ public class ECParameterSpec implements AlgorithmParameterSpec { * @param curve the elliptic curve which this parameter * defines. * @param g the generator which is also known as the base point. - * @param n the order of the generator g. + * @param n the order of the generator {@code g}. * @param h the cofactor. - * @exception NullPointerException if curve, - * g, or n is null. - * @exception IllegalArgumentException if n - * or h is not positive. + * @exception NullPointerException if {@code curve}, + * {@code g}, or {@code n} is null. + * @exception IllegalArgumentException if {@code n} + * or {@code h} is not positive. */ public ECParameterSpec(EllipticCurve curve, ECPoint g, BigInteger n, int h) { diff --git a/jdk/src/share/classes/java/security/spec/ECPoint.java b/jdk/src/share/classes/java/security/spec/ECPoint.java index 0c2ce57d96c..1b051c71a13 100644 --- a/jdk/src/share/classes/java/security/spec/ECPoint.java +++ b/jdk/src/share/classes/java/security/spec/ECPoint.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -54,11 +54,11 @@ public class ECPoint { /** * Creates an ECPoint from the specified affine x-coordinate - * x and affine y-coordinate y. + * {@code x} and affine y-coordinate {@code y}. * @param x the affine x-coordinate. * @param y the affine y-coordinate. - * @exception NullPointerException if x or - * y is null. + * @exception NullPointerException if {@code x} or + * {@code y} is null. */ public ECPoint(BigInteger x, BigInteger y) { if ((x==null) || (y==null)) { @@ -69,7 +69,7 @@ public class ECPoint { } /** - * Returns the affine x-coordinate x. + * Returns the affine x-coordinate {@code x}. * Note: POINT_INFINITY has a null affine x-coordinate. * @return the affine x-coordinate. */ @@ -78,7 +78,7 @@ public class ECPoint { } /** - * Returns the affine y-coordinate y. + * Returns the affine y-coordinate {@code y}. * Note: POINT_INFINITY has a null affine y-coordinate. * @return the affine y-coordinate. */ @@ -90,7 +90,7 @@ public class ECPoint { * Compares this elliptic curve point for equality with * the specified object. * @param obj the object to be compared. - * @return true if obj is an instance of + * @return true if {@code obj} is an instance of * ECPoint and the affine coordinates match, false otherwise. */ public boolean equals(Object obj) { diff --git a/jdk/src/share/classes/java/security/spec/ECPrivateKeySpec.java b/jdk/src/share/classes/java/security/spec/ECPrivateKeySpec.java index c8e2c408a86..7f03cfd49e6 100644 --- a/jdk/src/share/classes/java/security/spec/ECPrivateKeySpec.java +++ b/jdk/src/share/classes/java/security/spec/ECPrivateKeySpec.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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,8 +48,8 @@ public class ECPrivateKeySpec implements KeySpec { * @param s the private value. * @param params the associated elliptic curve domain * parameters. - * @exception NullPointerException if s - * or params is null. + * @exception NullPointerException if {@code s} + * or {@code params} is null. */ public ECPrivateKeySpec(BigInteger s, ECParameterSpec params) { if (s == null) { diff --git a/jdk/src/share/classes/java/security/spec/ECPublicKeySpec.java b/jdk/src/share/classes/java/security/spec/ECPublicKeySpec.java index 2d8b510ecbd..e0cfb777c50 100644 --- a/jdk/src/share/classes/java/security/spec/ECPublicKeySpec.java +++ b/jdk/src/share/classes/java/security/spec/ECPublicKeySpec.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -47,9 +47,9 @@ public class ECPublicKeySpec implements KeySpec { * @param w the public point. * @param params the associated elliptic curve domain * parameters. - * @exception NullPointerException if w - * or params is null. - * @exception IllegalArgumentException if w + * @exception NullPointerException if {@code w} + * or {@code params} is null. + * @exception IllegalArgumentException if {@code w} * is point at infinity, i.e. ECPoint.POINT_INFINITY */ public ECPublicKeySpec(ECPoint w, ECParameterSpec params) { diff --git a/jdk/src/share/classes/java/security/spec/EllipticCurve.java b/jdk/src/share/classes/java/security/spec/EllipticCurve.java index d9eef25caf8..8ec97b05ed3 100644 --- a/jdk/src/share/classes/java/security/spec/EllipticCurve.java +++ b/jdk/src/share/classes/java/security/spec/EllipticCurve.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -68,15 +68,15 @@ public class EllipticCurve { /** * Creates an elliptic curve with the specified elliptic field - * field and the coefficients a and - * b. + * {@code field} and the coefficients {@code a} and + * {@code b}. * @param field the finite field that this elliptic curve is over. * @param a the first coefficient of this elliptic curve. * @param b the second coefficient of this elliptic curve. - * @exception NullPointerException if field, - * a, or b is null. - * @exception IllegalArgumentException if a - * or b is not null and not in field. + * @exception NullPointerException if {@code field}, + * {@code a}, or {@code b} is null. + * @exception IllegalArgumentException if {@code a} + * or {@code b} is not null and not in {@code field}. */ public EllipticCurve(ECField field, BigInteger a, BigInteger b) { @@ -85,18 +85,18 @@ public class EllipticCurve { /** * Creates an elliptic curve with the specified elliptic field - * field, the coefficients a and - * b, and the seed used for curve generation. + * {@code field}, the coefficients {@code a} and + * {@code b}, and the {@code seed} used for curve generation. * @param field the finite field that this elliptic curve is over. * @param a the first coefficient of this elliptic curve. * @param b the second coefficient of this elliptic curve. * @param seed the bytes used during curve generation for later * validation. Contents of this array are copied to protect against * subsequent modification. - * @exception NullPointerException if field, - * a, or b is null. - * @exception IllegalArgumentException if a - * or b is not null and not in field. + * @exception NullPointerException if {@code field}, + * {@code a}, or {@code b} is null. + * @exception IllegalArgumentException if {@code a} + * or {@code b} is not null and not in {@code field}. */ public EllipticCurve(ECField field, BigInteger a, BigInteger b, byte[] seed) { @@ -122,9 +122,9 @@ public class EllipticCurve { } /** - * Returns the finite field field that this + * Returns the finite field {@code field} that this * elliptic curve is over. - * @return the field field that this curve + * @return the field {@code field} that this curve * is over. */ public ECField getField() { @@ -132,27 +132,27 @@ public class EllipticCurve { } /** - * Returns the first coefficient a of the + * Returns the first coefficient {@code a} of the * elliptic curve. - * @return the first coefficient a. + * @return the first coefficient {@code a}. */ public BigInteger getA() { return a; } /** - * Returns the second coefficient b of the + * Returns the second coefficient {@code b} of the * elliptic curve. - * @return the second coefficient b. + * @return the second coefficient {@code b}. */ public BigInteger getB() { return b; } /** - * Returns the seeding bytes seed used + * Returns the seeding bytes {@code seed} used * during curve generation. May be null if not specified. - * @return the seeding bytes seed. A new + * @return the seeding bytes {@code seed}. A new * array is returned each time this method is called. */ public byte[] getSeed() { @@ -164,7 +164,7 @@ public class EllipticCurve { * Compares this elliptic curve for equality with the * specified object. * @param obj the object to be compared. - * @return true if obj is an instance of + * @return true if {@code obj} is an instance of * EllipticCurve and the field, A, and B match, false otherwise. */ public boolean equals(Object obj) { diff --git a/jdk/src/share/classes/java/security/spec/EncodedKeySpec.java b/jdk/src/share/classes/java/security/spec/EncodedKeySpec.java index b58781921d2..cc3b81e6ab3 100644 --- a/jdk/src/share/classes/java/security/spec/EncodedKeySpec.java +++ b/jdk/src/share/classes/java/security/spec/EncodedKeySpec.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2005, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -49,7 +49,7 @@ public abstract class EncodedKeySpec implements KeySpec { * * @param encodedKey the encoded key. The contents of the * array are copied to protect against subsequent modification. - * @exception NullPointerException if encodedKey + * @exception NullPointerException if {@code encodedKey} * is null. */ public EncodedKeySpec(byte[] encodedKey) { @@ -74,9 +74,9 @@ public abstract class EncodedKeySpec implements KeySpec { * (see {@link java.security.Key Key}) can be transformed * (see {@link java.security.KeyFactory KeyFactory}) * into this key specification (or a subclass of it), - * getFormat called + * {@code getFormat} called * on the opaque key returns the same value as the - * getFormat method + * {@code getFormat} method * of this key specification. * * @return a string representation of the encoding format. diff --git a/jdk/src/share/classes/java/security/spec/InvalidKeySpecException.java b/jdk/src/share/classes/java/security/spec/InvalidKeySpecException.java index 670913d1366..4655c4abe0c 100644 --- a/jdk/src/share/classes/java/security/spec/InvalidKeySpecException.java +++ b/jdk/src/share/classes/java/security/spec/InvalidKeySpecException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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,13 +63,13 @@ public class InvalidKeySpecException extends GeneralSecurityException { } /** - * Creates a InvalidKeySpecException with the specified + * Creates a {@code InvalidKeySpecException} with the specified * detail message and cause. * * @param message the detail message (which is saved for later retrieval * by the {@link #getMessage()} method). * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause()} method). (A null value is permitted, + * {@link #getCause()} method). (A {@code null} value is permitted, * and indicates that the cause is nonexistent or unknown.) * @since 1.5 */ @@ -78,13 +78,13 @@ public class InvalidKeySpecException extends GeneralSecurityException { } /** - * Creates a InvalidKeySpecException with the specified cause - * and a detail message of (cause==null ? null : cause.toString()) + * Creates a {@code InvalidKeySpecException} with the specified cause + * and a detail message of {@code (cause==null ? null : cause.toString())} * (which typically contains the class and detail message of - * cause). + * {@code cause}). * * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause()} method). (A null value is permitted, + * {@link #getCause()} method). (A {@code null} value is permitted, * and indicates that the cause is nonexistent or unknown.) * @since 1.5 */ diff --git a/jdk/src/share/classes/java/security/spec/KeySpec.java b/jdk/src/share/classes/java/security/spec/KeySpec.java index 26c9777ef07..34fec5d3125 100644 --- a/jdk/src/share/classes/java/security/spec/KeySpec.java +++ b/jdk/src/share/classes/java/security/spec/KeySpec.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 1999, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -36,7 +36,7 @@ package java.security.spec; *

    A key may be specified in an algorithm-specific way, or in an * algorithm-independent encoding format (such as ASN.1). * For example, a DSA private key may be specified by its components - * x, p, q, and g + * {@code x}, {@code p}, {@code q}, and {@code g} * (see {@link DSAPrivateKeySpec}), or it may be * specified using its DER encoding * (see {@link PKCS8EncodedKeySpec}). diff --git a/jdk/src/share/classes/java/security/spec/MGF1ParameterSpec.java b/jdk/src/share/classes/java/security/spec/MGF1ParameterSpec.java index c1f1de37130..1be267f0ced 100644 --- a/jdk/src/share/classes/java/security/spec/MGF1ParameterSpec.java +++ b/jdk/src/share/classes/java/security/spec/MGF1ParameterSpec.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -92,7 +92,7 @@ public class MGF1ParameterSpec implements AlgorithmParameterSpec { * * @param mdName the algorithm name for the message digest * used in this mask generation function MGF1. - * @exception NullPointerException if mdName is null. + * @exception NullPointerException if {@code mdName} is null. */ public MGF1ParameterSpec(String mdName) { if (mdName == null) { diff --git a/jdk/src/share/classes/java/security/spec/PKCS8EncodedKeySpec.java b/jdk/src/share/classes/java/security/spec/PKCS8EncodedKeySpec.java index b6dabad364b..060f266fcb1 100644 --- a/jdk/src/share/classes/java/security/spec/PKCS8EncodedKeySpec.java +++ b/jdk/src/share/classes/java/security/spec/PKCS8EncodedKeySpec.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2005, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -27,8 +27,8 @@ package java.security.spec; /** * This class represents the ASN.1 encoding of a private key, - * encoded according to the ASN.1 type PrivateKeyInfo. - * The PrivateKeyInfo syntax is defined in the PKCS#8 standard + * encoded according to the ASN.1 type {@code PrivateKeyInfo}. + * The {@code PrivateKeyInfo} syntax is defined in the PKCS#8 standard * as follows: * *

    @@ -67,7 +67,7 @@ public class PKCS8EncodedKeySpec extends EncodedKeySpec {
          * @param encodedKey the key, which is assumed to be
          * encoded according to the PKCS #8 standard. The contents of
          * the array are copied to protect against subsequent modification.
    -     * @exception NullPointerException if encodedKey
    +     * @exception NullPointerException if {@code encodedKey}
          * is null.
          */
         public PKCS8EncodedKeySpec(byte[] encodedKey) {
    @@ -88,7 +88,7 @@ public class PKCS8EncodedKeySpec extends EncodedKeySpec {
          * Returns the name of the encoding format associated with this
          * key specification.
          *
    -     * @return the string "PKCS#8".
    +     * @return the string {@code "PKCS#8"}.
          */
         public final String getFormat() {
             return "PKCS#8";
    diff --git a/jdk/src/share/classes/java/security/spec/PSSParameterSpec.java b/jdk/src/share/classes/java/security/spec/PSSParameterSpec.java
    index 37a2eeb2625..a9b82d8e42b 100644
    --- a/jdk/src/share/classes/java/security/spec/PSSParameterSpec.java
    +++ b/jdk/src/share/classes/java/security/spec/PSSParameterSpec.java
    @@ -1,5 +1,5 @@
     /*
    - * Copyright (c) 2001, 2012, Oracle and/or its affiliates. All rights reserved.
    + * Copyright (c) 2001, 2013, 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
    @@ -91,14 +91,14 @@ public class PSSParameterSpec implements AlgorithmParameterSpec {
         public static final PSSParameterSpec DEFAULT = new PSSParameterSpec();
     
         /**
    -     * Constructs a new PSSParameterSpec as defined in
    +     * Constructs a new {@code PSSParameterSpec} as defined in
          * the PKCS #1 standard using the default values.
          */
         private PSSParameterSpec() {
         }
     
         /**
    -     * Creates a new PSSParameterSpec as defined in
    +     * Creates a new {@code PSSParameterSpec} as defined in
          * the PKCS #1 standard using the specified message digest,
          * mask generation function, parameters for mask generation
          * function, salt length, and trailer field values.
    @@ -111,10 +111,10 @@ public class PSSParameterSpec implements AlgorithmParameterSpec {
          * getMGFParameters().
          * @param saltLen the length of salt.
          * @param trailerField the value of the trailer field.
    -     * @exception NullPointerException if mdName,
    -     * or mgfName is null.
    -     * @exception IllegalArgumentException if saltLen
    -     * or trailerField is less than 0.
    +     * @exception NullPointerException if {@code mdName},
    +     * or {@code mgfName} is null.
    +     * @exception IllegalArgumentException if {@code saltLen}
    +     * or {@code trailerField} is less than 0.
          * @since 1.5
          */
         public PSSParameterSpec(String mdName, String mgfName,
    @@ -143,13 +143,13 @@ public class PSSParameterSpec implements AlgorithmParameterSpec {
         }
     
         /**
    -     * Creates a new PSSParameterSpec
    +     * Creates a new {@code PSSParameterSpec}
          * using the specified salt length and other default values as
          * defined in PKCS#1.
          *
          * @param saltLen the length of salt in bits to be used in PKCS#1
          * PSS encoding.
    -     * @exception IllegalArgumentException if saltLen is
    +     * @exception IllegalArgumentException if {@code saltLen} is
          * less than 0.
          */
         public PSSParameterSpec(int saltLen) {
    diff --git a/jdk/src/share/classes/java/security/spec/RSAKeyGenParameterSpec.java b/jdk/src/share/classes/java/security/spec/RSAKeyGenParameterSpec.java
    index e9a10fa58a8..a73c6cd46b7 100644
    --- a/jdk/src/share/classes/java/security/spec/RSAKeyGenParameterSpec.java
    +++ b/jdk/src/share/classes/java/security/spec/RSAKeyGenParameterSpec.java
    @@ -1,5 +1,5 @@
     /*
    - * Copyright (c) 1999, Oracle and/or its affiliates. All rights reserved.
    + * Copyright (c) 1999, 2013, 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
    @@ -55,7 +55,7 @@ public class RSAKeyGenParameterSpec implements AlgorithmParameterSpec {
         public static final BigInteger F4 = BigInteger.valueOf(65537);
     
         /**
    -     * Constructs a new RSAParameterSpec object from the
    +     * Constructs a new {@code RSAParameterSpec} object from the
          * given keysize and public-exponent value.
          *
          * @param keysize the modulus size (specified in number of bits)
    diff --git a/jdk/src/share/classes/java/security/spec/RSAMultiPrimePrivateCrtKeySpec.java b/jdk/src/share/classes/java/security/spec/RSAMultiPrimePrivateCrtKeySpec.java
    index 97346d6e22a..a198e43a2e1 100644
    --- a/jdk/src/share/classes/java/security/spec/RSAMultiPrimePrivateCrtKeySpec.java
    +++ b/jdk/src/share/classes/java/security/spec/RSAMultiPrimePrivateCrtKeySpec.java
    @@ -1,5 +1,5 @@
     /*
    - * Copyright (c) 2001, 2003, Oracle and/or its affiliates. All rights reserved.
    + * Copyright (c) 2001, 2013, 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
    @@ -57,12 +57,12 @@ public class RSAMultiPrimePrivateCrtKeySpec extends RSAPrivateKeySpec {
         private final RSAOtherPrimeInfo otherPrimeInfo[];
     
        /**
    -    * Creates a new RSAMultiPrimePrivateCrtKeySpec
    +    * Creates a new {@code RSAMultiPrimePrivateCrtKeySpec}
         * given the modulus, publicExponent, privateExponent,
         * primeP, primeQ, primeExponentP, primeExponentQ,
         * crtCoefficient, and otherPrimeInfo as defined in PKCS#1 v2.1.
         *
    -    * 

    Note that the contents of otherPrimeInfo + *

    Note that the contents of {@code otherPrimeInfo} * are copied to protect against subsequent modification when * constructing this object. * @@ -78,13 +78,13 @@ public class RSAMultiPrimePrivateCrtKeySpec extends RSAPrivateKeySpec { * @param otherPrimeInfo triplets of the rest of primes, null can be * specified if there are only two prime factors (p and q). * @exception NullPointerException if any of the parameters, i.e. - * modulus, - * publicExponent, privateExponent, - * primeP, primeQ, - * primeExponentP, primeExponentQ, - * crtCoefficient, is null. + * {@code modulus}, + * {@code publicExponent}, {@code privateExponent}, + * {@code primeP}, {@code primeQ}, + * {@code primeExponentP}, {@code primeExponentQ}, + * {@code crtCoefficient}, is null. * @exception IllegalArgumentException if an empty, i.e. 0-length, - * otherPrimeInfo is specified. + * {@code otherPrimeInfo} is specified. */ public RSAMultiPrimePrivateCrtKeySpec(BigInteger modulus, BigInteger publicExponent, diff --git a/jdk/src/share/classes/java/security/spec/RSAOtherPrimeInfo.java b/jdk/src/share/classes/java/security/spec/RSAOtherPrimeInfo.java index e0889152dcd..10d8471765d 100644 --- a/jdk/src/share/classes/java/security/spec/RSAOtherPrimeInfo.java +++ b/jdk/src/share/classes/java/security/spec/RSAOtherPrimeInfo.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2001, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2001, 2013, 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 @@ -58,7 +58,7 @@ public class RSAOtherPrimeInfo { /** - * Creates a new RSAOtherPrimeInfo + * Creates a new {@code RSAOtherPrimeInfo} * given the prime, primeExponent, and * crtCoefficient as defined in PKCS#1. * @@ -67,8 +67,8 @@ public class RSAOtherPrimeInfo { * @param crtCoefficient the Chinese Remainder Theorem * coefficient. * @exception NullPointerException if any of the parameters, i.e. - * prime, primeExponent, - * crtCoefficient, is null. + * {@code prime}, {@code primeExponent}, + * {@code crtCoefficient}, is null. * */ public RSAOtherPrimeInfo(BigInteger prime, diff --git a/jdk/src/share/classes/java/security/spec/RSAPrivateCrtKeySpec.java b/jdk/src/share/classes/java/security/spec/RSAPrivateCrtKeySpec.java index c8d8faa5e53..d0ba70be443 100644 --- a/jdk/src/share/classes/java/security/spec/RSAPrivateCrtKeySpec.java +++ b/jdk/src/share/classes/java/security/spec/RSAPrivateCrtKeySpec.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2013, 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 @@ -55,7 +55,7 @@ public class RSAPrivateCrtKeySpec extends RSAPrivateKeySpec { /** - * Creates a new RSAPrivateCrtKeySpec + * Creates a new {@code RSAPrivateCrtKeySpec} * given the modulus, publicExponent, privateExponent, * primeP, primeQ, primeExponentP, primeExponentQ, and * crtCoefficient as defined in PKCS#1. diff --git a/jdk/src/share/classes/java/security/spec/X509EncodedKeySpec.java b/jdk/src/share/classes/java/security/spec/X509EncodedKeySpec.java index 7dd3d7bf244..b9984de87e3 100644 --- a/jdk/src/share/classes/java/security/spec/X509EncodedKeySpec.java +++ b/jdk/src/share/classes/java/security/spec/X509EncodedKeySpec.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2005, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -27,8 +27,8 @@ package java.security.spec; /** * This class represents the ASN.1 encoding of a public key, - * encoded according to the ASN.1 type SubjectPublicKeyInfo. - * The SubjectPublicKeyInfo syntax is defined in the X.509 + * encoded according to the ASN.1 type {@code SubjectPublicKeyInfo}. + * The {@code SubjectPublicKeyInfo} syntax is defined in the X.509 * standard as follows: * *

    @@ -57,7 +57,7 @@ public class X509EncodedKeySpec extends EncodedKeySpec {
          * @param encodedKey the key, which is assumed to be
          * encoded according to the X.509 standard. The contents of the
          * array are copied to protect against subsequent modification.
    -     * @exception NullPointerException if encodedKey
    +     * @exception NullPointerException if {@code encodedKey}
          * is null.
          */
         public X509EncodedKeySpec(byte[] encodedKey) {
    @@ -78,7 +78,7 @@ public class X509EncodedKeySpec extends EncodedKeySpec {
          * Returns the name of the encoding format associated with this
          * key specification.
          *
    -     * @return the string "X.509".
    +     * @return the string {@code "X.509"}.
          */
         public final String getFormat() {
             return "X.509";
    
    From 345f3a94c5fece020c5def814d53f15127deff16 Mon Sep 17 00:00:00 2001
    From: Yong Jeffrey Huang 
    Date: Tue, 25 Jun 2013 21:03:08 -0700
    Subject: [PATCH 026/127] 8013836: getFirstDayOfWeek reports wrong day for
     pt-BR locale
    
    Reviewed-by: naoto
    ---
     .../pt/CalendarData_pt_BR.properties          | 40 +++++++++++++++++++
     jdk/test/sun/text/resources/LocaleData        |  4 +-
     .../sun/text/resources/LocaleDataTest.java    |  2 +-
     3 files changed, 43 insertions(+), 3 deletions(-)
     create mode 100644 jdk/src/share/classes/sun/util/resources/pt/CalendarData_pt_BR.properties
    
    diff --git a/jdk/src/share/classes/sun/util/resources/pt/CalendarData_pt_BR.properties b/jdk/src/share/classes/sun/util/resources/pt/CalendarData_pt_BR.properties
    new file mode 100644
    index 00000000000..ea543b258e8
    --- /dev/null
    +++ b/jdk/src/share/classes/sun/util/resources/pt/CalendarData_pt_BR.properties
    @@ -0,0 +1,40 @@
    +#
    +# Copyright (c) 2013, 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.  Oracle designates this
    +# particular file as subject to the "Classpath" exception as provided
    +# by Oracle in the LICENSE file that accompanied this code.
    +#
    +# 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.
    +#
    +
    +# (C) Copyright Taligent, Inc. 1996, 1997 - All Rights Reserved
    +# (C) Copyright IBM Corp. 1996 - 1999 - All Rights Reserved
    +#
    +# The original version of this source code and documentation
    +# is copyrighted and owned by Taligent, Inc., a wholly-owned
    +# subsidiary of IBM. These materials are provided under terms
    +# of a License Agreement between Taligent and Sun. This technology
    +# is protected by multiple US and International patents.
    +#
    +# This notice and attribution to Taligent may not be removed.
    +# Taligent is a registered trademark of Taligent, Inc.
    +
    +
    +firstDayOfWeek=1
    +minimalDaysInFirstWeek=1
    diff --git a/jdk/test/sun/text/resources/LocaleData b/jdk/test/sun/text/resources/LocaleData
    index 91d4c46b854..4bcb9739295 100644
    --- a/jdk/test/sun/text/resources/LocaleData
    +++ b/jdk/test/sun/text/resources/LocaleData
    @@ -11,7 +11,7 @@ LocaleNames//es=Spanish
     # bug #4052679
     LocaleNames/fr/fr=fran\u00e7ais
     
    -# bug #4055602, 4290801
    +# bug #4055602, 4290801, 8013836
     CurrencyNames/pt_BR/BRL=R$
     FormatData/pt_BR/NumberPatterns/0=#,##0.###;-#,##0.###
     # FormatData/pt_BR/NumberPatterns/1=R$ #,##0.##;-R$ #,##0.## # Changed; see bug 4122840
    @@ -34,7 +34,7 @@ FormatData/pt_BR/DayAbbreviations/2=Ter
     FormatData/pt_BR/DayNames/0=Domingo
     FormatData/pt_BR/DayNames/1=Segunda-feira
     FormatData/pt_BR/DayNames/2=Ter\u00e7a-feira
    -CalendarData/pt_BR/firstDayOfWeek=2
    +CalendarData/pt_BR/firstDayOfWeek=1
     CalendarData/pt_BR/minimalDaysInFirstWeek=1
     FormatData/pt_BR/MonthNames/0=Janeiro
     FormatData/pt_BR/MonthNames/1=Fevereiro
    diff --git a/jdk/test/sun/text/resources/LocaleDataTest.java b/jdk/test/sun/text/resources/LocaleDataTest.java
    index 73cd7e805ad..961fcf52be1 100644
    --- a/jdk/test/sun/text/resources/LocaleDataTest.java
    +++ b/jdk/test/sun/text/resources/LocaleDataTest.java
    @@ -35,7 +35,7 @@
      *      6645405 6650730 6910489 6573250 6870908 6585666 6716626 6914413 6916787
      *      6919624 6998391 7019267 7020960 7025837 7020583 7036905 7066203 7101495
      *      7003124 7085757 7028073 7171028 7189611 8000983 7195759 8004489 8006509
    - *      7114053 7074882 7040556
    + *      7114053 7074882 7040556 8013836
      * @summary Verify locale data
      *
      */
    
    From d22a89a1aeac40e2dbb613ca45fe2d2fc122ba76 Mon Sep 17 00:00:00 2001
    From: Xue-Lei Andrew Fan 
    Date: Wed, 26 Jun 2013 06:32:40 -0700
    Subject: [PATCH 027/127] 8017049: rename property
     jdk.tls.rejectClientInitializedRenego
    
    Reviewed-by: vinnie, wetmore, mullan
    ---
     jdk/src/share/classes/sun/security/ssl/Handshaker.java    | 8 ++++----
     .../internal/ssl/SSLSocketImpl/NoImpactServerRenego.java  | 2 +-
     .../internal/ssl/SSLSocketImpl/RejectClientRenego.java    | 3 ++-
     3 files changed, 7 insertions(+), 6 deletions(-)
    
    diff --git a/jdk/src/share/classes/sun/security/ssl/Handshaker.java b/jdk/src/share/classes/sun/security/ssl/Handshaker.java
    index 8314c379d33..17b1f92ac74 100644
    --- a/jdk/src/share/classes/sun/security/ssl/Handshaker.java
    +++ b/jdk/src/share/classes/sun/security/ssl/Handshaker.java
    @@ -187,14 +187,14 @@ abstract class Handshaker {
                         "sun.security.ssl.allowLegacyHelloMessages", true);
     
         // To prevent the TLS renegotiation issues, by setting system property
    -    // "jdk.tls.rejectClientInitializedRenego" to true, applications in server
    -    // side can disable all client initiated SSL renegotiations regardless
    -    // of the support of TLS protocols.
    +    // "jdk.tls.rejectClientInitiatedRenegotiation" to true, applications in
    +    // server side can disable all client initiated SSL renegotiations
    +    // regardless of the support of TLS protocols.
         //
         // By default, allow client initiated renegotiations.
         static final boolean rejectClientInitiatedRenego =
                 Debug.getBooleanProperty(
    -                "jdk.tls.rejectClientInitializedRenego", false);
    +                "jdk.tls.rejectClientInitiatedRenegotiation", false);
     
         // need to dispose the object when it is invalidated
         boolean invalidated;
    diff --git a/jdk/test/sun/security/ssl/com/sun/net/ssl/internal/ssl/SSLSocketImpl/NoImpactServerRenego.java b/jdk/test/sun/security/ssl/com/sun/net/ssl/internal/ssl/SSLSocketImpl/NoImpactServerRenego.java
    index 5ef0c76dca1..ab23ce4239c 100644
    --- a/jdk/test/sun/security/ssl/com/sun/net/ssl/internal/ssl/SSLSocketImpl/NoImpactServerRenego.java
    +++ b/jdk/test/sun/security/ssl/com/sun/net/ssl/internal/ssl/SSLSocketImpl/NoImpactServerRenego.java
    @@ -29,7 +29,7 @@
      * @bug 7188658
      * @summary Add possibility to disable client initiated renegotiation
      * @run main/othervm
    - *      -Djdk.tls.rejectClientInitializedRenego=true NoImpactServerRenego
    + *      -Djdk.tls.rejectClientInitiatedRenegotiation=true NoImpactServerRenego
      */
     
     import java.io.*;
    diff --git a/jdk/test/sun/security/ssl/com/sun/net/ssl/internal/ssl/SSLSocketImpl/RejectClientRenego.java b/jdk/test/sun/security/ssl/com/sun/net/ssl/internal/ssl/SSLSocketImpl/RejectClientRenego.java
    index 29f80d9e15b..01a7febca29 100644
    --- a/jdk/test/sun/security/ssl/com/sun/net/ssl/internal/ssl/SSLSocketImpl/RejectClientRenego.java
    +++ b/jdk/test/sun/security/ssl/com/sun/net/ssl/internal/ssl/SSLSocketImpl/RejectClientRenego.java
    @@ -216,7 +216,8 @@ public class RejectClientRenego implements
             System.setProperty("javax.net.ssl.trustStorePassword", passwd);
     
             // reject client initialized SSL renegotiation.
    -        System.setProperty("jdk.tls.rejectClientInitializedRenego", "true");
    +        System.setProperty(
    +            "jdk.tls.rejectClientInitiatedRenegotiation", "true");
     
             if (debug)
                 System.setProperty("javax.net.debug", "all");
    
    From b3e5539d0607ec08dac27e85720acec9ff024944 Mon Sep 17 00:00:00 2001
    From: Chris Hegarty 
    Date: Wed, 26 Jun 2013 15:30:39 +0100
    Subject: [PATCH 028/127] 8012647: Add Arrays.parallelPrefix (prefix sum, scan,
     cumulative sum)
    
    Co-authored-by: Doug Lea 
    Co-authored-by: Tristan Yan 
    Reviewed-by: chegar, alanb, psandoz
    ---
     .../classes/java/util/ArrayPrefixHelpers.java | 697 ++++++++++++++++++
     jdk/src/share/classes/java/util/Arrays.java   | 177 +++++
     jdk/test/java/util/Arrays/ParallelPrefix.java | 165 +++++
     3 files changed, 1039 insertions(+)
     create mode 100644 jdk/src/share/classes/java/util/ArrayPrefixHelpers.java
     create mode 100644 jdk/test/java/util/Arrays/ParallelPrefix.java
    
    diff --git a/jdk/src/share/classes/java/util/ArrayPrefixHelpers.java b/jdk/src/share/classes/java/util/ArrayPrefixHelpers.java
    new file mode 100644
    index 00000000000..ef59ec7d478
    --- /dev/null
    +++ b/jdk/src/share/classes/java/util/ArrayPrefixHelpers.java
    @@ -0,0 +1,697 @@
    +/*
    + * Copyright (c) 2012, 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.  Oracle designates this
    + * particular file as subject to the "Classpath" exception as provided
    + * by Oracle in the LICENSE file that accompanied this code.
    + *
    + * 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.
    + */
    +package java.util;
    +
    +/*
    + * Written by Doug Lea with assistance from members of JCP JSR-166
    + * Expert Group and released to the public domain, as explained at
    + * http://creativecommons.org/publicdomain/zero/1.0/
    + */
    +
    +import java.util.concurrent.ForkJoinPool;
    +import java.util.concurrent.CountedCompleter;
    +import java.util.function.BinaryOperator;
    +import java.util.function.IntBinaryOperator;
    +import java.util.function.LongBinaryOperator;
    +import java.util.function.DoubleBinaryOperator;
    +
    +/**
    + * ForkJoin tasks to perform Arrays.parallelPrefix operations.
    + *
    + * @author Doug Lea
    + * @since 1.8
    + */
    +class ArrayPrefixHelpers {
    +    private ArrayPrefixHelpers() {}; // non-instantiable
    +
    +    /*
    +     * Parallel prefix (aka cumulate, scan) task classes
    +     * are based loosely on Guy Blelloch's original
    +     * algorithm (http://www.cs.cmu.edu/~scandal/alg/scan.html):
    +     *  Keep dividing by two to threshold segment size, and then:
    +     *   Pass 1: Create tree of partial sums for each segment
    +     *   Pass 2: For each segment, cumulate with offset of left sibling
    +     *
    +     * This version improves performance within FJ framework mainly by
    +     * allowing the second pass of ready left-hand sides to proceed
    +     * even if some right-hand side first passes are still executing.
    +     * It also combines first and second pass for leftmost segment,
    +     * and skips the first pass for rightmost segment (whose result is
    +     * not needed for second pass).  It similarly manages to avoid
    +     * requiring that users supply an identity basis for accumulations
    +     * by tracking those segments/subtasks for which the first
    +     * existing element is used as base.
    +     *
    +     * Managing this relies on ORing some bits in the pendingCount for
    +     * phases/states: CUMULATE, SUMMED, and FINISHED. CUMULATE is the
    +     * main phase bit. When false, segments compute only their sum.
    +     * When true, they cumulate array elements. CUMULATE is set at
    +     * root at beginning of second pass and then propagated down. But
    +     * it may also be set earlier for subtrees with lo==0 (the left
    +     * spine of tree). SUMMED is a one bit join count. For leafs, it
    +     * is set when summed. For internal nodes, it becomes true when
    +     * one child is summed.  When the second child finishes summing,
    +     * we then moves up tree to trigger the cumulate phase. FINISHED
    +     * is also a one bit join count. For leafs, it is set when
    +     * cumulated. For internal nodes, it becomes true when one child
    +     * is cumulated.  When the second child finishes cumulating, it
    +     * then moves up tree, completing at the root.
    +     *
    +     * To better exploit locality and reduce overhead, the compute
    +     * method loops starting with the current task, moving if possible
    +     * to one of its subtasks rather than forking.
    +     *
    +     * As usual for this sort of utility, there are 4 versions, that
    +     * are simple copy/paste/adapt variants of each other.  (The
    +     * double and int versions differ from long version soley by
    +     * replacing "long" (with case-matching)).
    +     */
    +
    +    // see above
    +    static final int CUMULATE = 1;
    +    static final int SUMMED   = 2;
    +    static final int FINISHED = 4;
    +
    +    /** The smallest subtask array partition size to use as threshold */
    +    static final int MIN_PARTITION = 16;
    +
    +    static final class CumulateTask extends CountedCompleter {
    +        final T[] array;
    +        final BinaryOperator function;
    +        CumulateTask left, right;
    +        T in, out;
    +        final int lo, hi, origin, fence, threshold;
    +
    +        /** Root task constructor */
    +        public CumulateTask(CumulateTask parent,
    +                            BinaryOperator function,
    +                            T[] array, int lo, int hi) {
    +            super(parent);
    +            this.function = function; this.array = array;
    +            this.lo = this.origin = lo; this.hi = this.fence = hi;
    +            int p;
    +            this.threshold =
    +                    (p = (hi - lo) / (ForkJoinPool.getCommonPoolParallelism() << 3))
    +                    <= MIN_PARTITION ? MIN_PARTITION : p;
    +        }
    +
    +        /** Subtask constructor */
    +        CumulateTask(CumulateTask parent, BinaryOperator function,
    +                     T[] array, int origin, int fence, int threshold,
    +                     int lo, int hi) {
    +            super(parent);
    +            this.function = function; this.array = array;
    +            this.origin = origin; this.fence = fence;
    +            this.threshold = threshold;
    +            this.lo = lo; this.hi = hi;
    +        }
    +
    +        public final void compute() {
    +            final BinaryOperator fn;
    +            final T[] a;
    +            if ((fn = this.function) == null || (a = this.array) == null)
    +                throw new NullPointerException();    // hoist checks
    +            int th = threshold, org = origin, fnc = fence, l, h;
    +            CumulateTask t = this;
    +            outer: while ((l = t.lo) >= 0 && (h = t.hi) <= a.length) {
    +                if (h - l > th) {
    +                    CumulateTask lt = t.left, rt = t.right, f;
    +                    if (lt == null) {                // first pass
    +                        int mid = (l + h) >>> 1;
    +                        f = rt = t.right =
    +                                new CumulateTask(t, fn, a, org, fnc, th, mid, h);
    +                        t = lt = t.left  =
    +                                new CumulateTask(t, fn, a, org, fnc, th, l, mid);
    +                    }
    +                    else {                           // possibly refork
    +                        T pin = t.in;
    +                        lt.in = pin;
    +                        f = t = null;
    +                        if (rt != null) {
    +                            T lout = lt.out;
    +                            rt.in = (l == org ? lout :
    +                                     fn.apply(pin, lout));
    +                            for (int c;;) {
    +                                if (((c = rt.getPendingCount()) & CUMULATE) != 0)
    +                                    break;
    +                                if (rt.compareAndSetPendingCount(c, c|CUMULATE)){
    +                                    t = rt;
    +                                    break;
    +                                }
    +                            }
    +                        }
    +                        for (int c;;) {
    +                            if (((c = lt.getPendingCount()) & CUMULATE) != 0)
    +                                break;
    +                            if (lt.compareAndSetPendingCount(c, c|CUMULATE)) {
    +                                if (t != null)
    +                                    f = t;
    +                                t = lt;
    +                                break;
    +                            }
    +                        }
    +                        if (t == null)
    +                            break;
    +                    }
    +                    if (f != null)
    +                        f.fork();
    +                }
    +                else {
    +                    int state; // Transition to sum, cumulate, or both
    +                    for (int b;;) {
    +                        if (((b = t.getPendingCount()) & FINISHED) != 0)
    +                            break outer;                      // already done
    +                        state = ((b & CUMULATE) != 0? FINISHED :
    +                                 (l > org) ? SUMMED : (SUMMED|FINISHED));
    +                        if (t.compareAndSetPendingCount(b, b|state))
    +                            break;
    +                    }
    +
    +                    T sum;
    +                    if (state != SUMMED) {
    +                        int first;
    +                        if (l == org) {                       // leftmost; no in
    +                            sum = a[org];
    +                            first = org + 1;
    +                        }
    +                        else {
    +                            sum = t.in;
    +                            first = l;
    +                        }
    +                        for (int i = first; i < h; ++i)       // cumulate
    +                            a[i] = sum = fn.apply(sum, a[i]);
    +                    }
    +                    else if (h < fnc) {                       // skip rightmost
    +                        sum = a[l];
    +                        for (int i = l + 1; i < h; ++i)       // sum only
    +                            sum = fn.apply(sum, a[i]);
    +                    }
    +                    else
    +                        sum = t.in;
    +                    t.out = sum;
    +                    for (CumulateTask par;;) {             // propagate
    +                        if ((par = (CumulateTask)t.getCompleter()) == null) {
    +                            if ((state & FINISHED) != 0)      // enable join
    +                                t.quietlyComplete();
    +                            break outer;
    +                        }
    +                        int b = par.getPendingCount();
    +                        if ((b & state & FINISHED) != 0)
    +                            t = par;                          // both done
    +                        else if ((b & state & SUMMED) != 0) { // both summed
    +                            int nextState; CumulateTask lt, rt;
    +                            if ((lt = par.left) != null &&
    +                                (rt = par.right) != null) {
    +                                T lout = lt.out;
    +                                par.out = (rt.hi == fnc ? lout :
    +                                           fn.apply(lout, rt.out));
    +                            }
    +                            int refork = (((b & CUMULATE) == 0 &&
    +                                           par.lo == org) ? CUMULATE : 0);
    +                            if ((nextState = b|state|refork) == b ||
    +                                par.compareAndSetPendingCount(b, nextState)) {
    +                                state = SUMMED;               // drop finished
    +                                t = par;
    +                                if (refork != 0)
    +                                    par.fork();
    +                            }
    +                        }
    +                        else if (par.compareAndSetPendingCount(b, b|state))
    +                            break outer;                      // sib not ready
    +                    }
    +                }
    +            }
    +        }
    +    }
    +
    +    static final class LongCumulateTask extends CountedCompleter {
    +        final long[] array;
    +        final LongBinaryOperator function;
    +        LongCumulateTask left, right;
    +        long in, out;
    +        final int lo, hi, origin, fence, threshold;
    +
    +        /** Root task constructor */
    +        public LongCumulateTask(LongCumulateTask parent,
    +                                LongBinaryOperator function,
    +                                long[] array, int lo, int hi) {
    +            super(parent);
    +            this.function = function; this.array = array;
    +            this.lo = this.origin = lo; this.hi = this.fence = hi;
    +            int p;
    +            this.threshold =
    +                    (p = (hi - lo) / (ForkJoinPool.getCommonPoolParallelism() << 3))
    +                    <= MIN_PARTITION ? MIN_PARTITION : p;
    +        }
    +
    +        /** Subtask constructor */
    +        LongCumulateTask(LongCumulateTask parent, LongBinaryOperator function,
    +                         long[] array, int origin, int fence, int threshold,
    +                         int lo, int hi) {
    +            super(parent);
    +            this.function = function; this.array = array;
    +            this.origin = origin; this.fence = fence;
    +            this.threshold = threshold;
    +            this.lo = lo; this.hi = hi;
    +        }
    +
    +        public final void compute() {
    +            final LongBinaryOperator fn;
    +            final long[] a;
    +            if ((fn = this.function) == null || (a = this.array) == null)
    +                throw new NullPointerException();    // hoist checks
    +            int th = threshold, org = origin, fnc = fence, l, h;
    +            LongCumulateTask t = this;
    +            outer: while ((l = t.lo) >= 0 && (h = t.hi) <= a.length) {
    +                if (h - l > th) {
    +                    LongCumulateTask lt = t.left, rt = t.right, f;
    +                    if (lt == null) {                // first pass
    +                        int mid = (l + h) >>> 1;
    +                        f = rt = t.right =
    +                                new LongCumulateTask(t, fn, a, org, fnc, th, mid, h);
    +                        t = lt = t.left  =
    +                                new LongCumulateTask(t, fn, a, org, fnc, th, l, mid);
    +                    }
    +                    else {                           // possibly refork
    +                        long pin = t.in;
    +                        lt.in = pin;
    +                        f = t = null;
    +                        if (rt != null) {
    +                            long lout = lt.out;
    +                            rt.in = (l == org ? lout :
    +                                     fn.applyAsLong(pin, lout));
    +                            for (int c;;) {
    +                                if (((c = rt.getPendingCount()) & CUMULATE) != 0)
    +                                    break;
    +                                if (rt.compareAndSetPendingCount(c, c|CUMULATE)){
    +                                    t = rt;
    +                                    break;
    +                                }
    +                            }
    +                        }
    +                        for (int c;;) {
    +                            if (((c = lt.getPendingCount()) & CUMULATE) != 0)
    +                                break;
    +                            if (lt.compareAndSetPendingCount(c, c|CUMULATE)) {
    +                                if (t != null)
    +                                    f = t;
    +                                t = lt;
    +                                break;
    +                            }
    +                        }
    +                        if (t == null)
    +                            break;
    +                    }
    +                    if (f != null)
    +                        f.fork();
    +                }
    +                else {
    +                    int state; // Transition to sum, cumulate, or both
    +                    for (int b;;) {
    +                        if (((b = t.getPendingCount()) & FINISHED) != 0)
    +                            break outer;                      // already done
    +                        state = ((b & CUMULATE) != 0? FINISHED :
    +                                 (l > org) ? SUMMED : (SUMMED|FINISHED));
    +                        if (t.compareAndSetPendingCount(b, b|state))
    +                            break;
    +                    }
    +
    +                    long sum;
    +                    if (state != SUMMED) {
    +                        int first;
    +                        if (l == org) {                       // leftmost; no in
    +                            sum = a[org];
    +                            first = org + 1;
    +                        }
    +                        else {
    +                            sum = t.in;
    +                            first = l;
    +                        }
    +                        for (int i = first; i < h; ++i)       // cumulate
    +                            a[i] = sum = fn.applyAsLong(sum, a[i]);
    +                    }
    +                    else if (h < fnc) {                       // skip rightmost
    +                        sum = a[l];
    +                        for (int i = l + 1; i < h; ++i)       // sum only
    +                            sum = fn.applyAsLong(sum, a[i]);
    +                    }
    +                    else
    +                        sum = t.in;
    +                    t.out = sum;
    +                    for (LongCumulateTask par;;) {            // propagate
    +                        if ((par = (LongCumulateTask)t.getCompleter()) == null) {
    +                            if ((state & FINISHED) != 0)      // enable join
    +                                t.quietlyComplete();
    +                            break outer;
    +                        }
    +                        int b = par.getPendingCount();
    +                        if ((b & state & FINISHED) != 0)
    +                            t = par;                          // both done
    +                        else if ((b & state & SUMMED) != 0) { // both summed
    +                            int nextState; LongCumulateTask lt, rt;
    +                            if ((lt = par.left) != null &&
    +                                (rt = par.right) != null) {
    +                                long lout = lt.out;
    +                                par.out = (rt.hi == fnc ? lout :
    +                                           fn.applyAsLong(lout, rt.out));
    +                            }
    +                            int refork = (((b & CUMULATE) == 0 &&
    +                                           par.lo == org) ? CUMULATE : 0);
    +                            if ((nextState = b|state|refork) == b ||
    +                                par.compareAndSetPendingCount(b, nextState)) {
    +                                state = SUMMED;               // drop finished
    +                                t = par;
    +                                if (refork != 0)
    +                                    par.fork();
    +                            }
    +                        }
    +                        else if (par.compareAndSetPendingCount(b, b|state))
    +                            break outer;                      // sib not ready
    +                    }
    +                }
    +            }
    +        }
    +    }
    +
    +    static final class DoubleCumulateTask extends CountedCompleter {
    +        final double[] array;
    +        final DoubleBinaryOperator function;
    +        DoubleCumulateTask left, right;
    +        double in, out;
    +        final int lo, hi, origin, fence, threshold;
    +
    +        /** Root task constructor */
    +        public DoubleCumulateTask(DoubleCumulateTask parent,
    +                                  DoubleBinaryOperator function,
    +                                  double[] array, int lo, int hi) {
    +            super(parent);
    +            this.function = function; this.array = array;
    +            this.lo = this.origin = lo; this.hi = this.fence = hi;
    +            int p;
    +            this.threshold =
    +                    (p = (hi - lo) / (ForkJoinPool.getCommonPoolParallelism() << 3))
    +                    <= MIN_PARTITION ? MIN_PARTITION : p;
    +        }
    +
    +        /** Subtask constructor */
    +        DoubleCumulateTask(DoubleCumulateTask parent, DoubleBinaryOperator function,
    +                           double[] array, int origin, int fence, int threshold,
    +                           int lo, int hi) {
    +            super(parent);
    +            this.function = function; this.array = array;
    +            this.origin = origin; this.fence = fence;
    +            this.threshold = threshold;
    +            this.lo = lo; this.hi = hi;
    +        }
    +
    +        public final void compute() {
    +            final DoubleBinaryOperator fn;
    +            final double[] a;
    +            if ((fn = this.function) == null || (a = this.array) == null)
    +                throw new NullPointerException();    // hoist checks
    +            int th = threshold, org = origin, fnc = fence, l, h;
    +            DoubleCumulateTask t = this;
    +            outer: while ((l = t.lo) >= 0 && (h = t.hi) <= a.length) {
    +                if (h - l > th) {
    +                    DoubleCumulateTask lt = t.left, rt = t.right, f;
    +                    if (lt == null) {                // first pass
    +                        int mid = (l + h) >>> 1;
    +                        f = rt = t.right =
    +                                new DoubleCumulateTask(t, fn, a, org, fnc, th, mid, h);
    +                        t = lt = t.left  =
    +                                new DoubleCumulateTask(t, fn, a, org, fnc, th, l, mid);
    +                    }
    +                    else {                           // possibly refork
    +                        double pin = t.in;
    +                        lt.in = pin;
    +                        f = t = null;
    +                        if (rt != null) {
    +                            double lout = lt.out;
    +                            rt.in = (l == org ? lout :
    +                                     fn.applyAsDouble(pin, lout));
    +                            for (int c;;) {
    +                                if (((c = rt.getPendingCount()) & CUMULATE) != 0)
    +                                    break;
    +                                if (rt.compareAndSetPendingCount(c, c|CUMULATE)){
    +                                    t = rt;
    +                                    break;
    +                                }
    +                            }
    +                        }
    +                        for (int c;;) {
    +                            if (((c = lt.getPendingCount()) & CUMULATE) != 0)
    +                                break;
    +                            if (lt.compareAndSetPendingCount(c, c|CUMULATE)) {
    +                                if (t != null)
    +                                    f = t;
    +                                t = lt;
    +                                break;
    +                            }
    +                        }
    +                        if (t == null)
    +                            break;
    +                    }
    +                    if (f != null)
    +                        f.fork();
    +                }
    +                else {
    +                    int state; // Transition to sum, cumulate, or both
    +                    for (int b;;) {
    +                        if (((b = t.getPendingCount()) & FINISHED) != 0)
    +                            break outer;                      // already done
    +                        state = ((b & CUMULATE) != 0? FINISHED :
    +                                 (l > org) ? SUMMED : (SUMMED|FINISHED));
    +                        if (t.compareAndSetPendingCount(b, b|state))
    +                            break;
    +                    }
    +
    +                    double sum;
    +                    if (state != SUMMED) {
    +                        int first;
    +                        if (l == org) {                       // leftmost; no in
    +                            sum = a[org];
    +                            first = org + 1;
    +                        }
    +                        else {
    +                            sum = t.in;
    +                            first = l;
    +                        }
    +                        for (int i = first; i < h; ++i)       // cumulate
    +                            a[i] = sum = fn.applyAsDouble(sum, a[i]);
    +                    }
    +                    else if (h < fnc) {                       // skip rightmost
    +                        sum = a[l];
    +                        for (int i = l + 1; i < h; ++i)       // sum only
    +                            sum = fn.applyAsDouble(sum, a[i]);
    +                    }
    +                    else
    +                        sum = t.in;
    +                    t.out = sum;
    +                    for (DoubleCumulateTask par;;) {            // propagate
    +                        if ((par = (DoubleCumulateTask)t.getCompleter()) == null) {
    +                            if ((state & FINISHED) != 0)      // enable join
    +                                t.quietlyComplete();
    +                            break outer;
    +                        }
    +                        int b = par.getPendingCount();
    +                        if ((b & state & FINISHED) != 0)
    +                            t = par;                          // both done
    +                        else if ((b & state & SUMMED) != 0) { // both summed
    +                            int nextState; DoubleCumulateTask lt, rt;
    +                            if ((lt = par.left) != null &&
    +                                (rt = par.right) != null) {
    +                                double lout = lt.out;
    +                                par.out = (rt.hi == fnc ? lout :
    +                                           fn.applyAsDouble(lout, rt.out));
    +                            }
    +                            int refork = (((b & CUMULATE) == 0 &&
    +                                           par.lo == org) ? CUMULATE : 0);
    +                            if ((nextState = b|state|refork) == b ||
    +                                par.compareAndSetPendingCount(b, nextState)) {
    +                                state = SUMMED;               // drop finished
    +                                t = par;
    +                                if (refork != 0)
    +                                    par.fork();
    +                            }
    +                        }
    +                        else if (par.compareAndSetPendingCount(b, b|state))
    +                            break outer;                      // sib not ready
    +                    }
    +                }
    +            }
    +        }
    +    }
    +
    +    static final class IntCumulateTask extends CountedCompleter {
    +        final int[] array;
    +        final IntBinaryOperator function;
    +        IntCumulateTask left, right;
    +        int in, out;
    +        final int lo, hi, origin, fence, threshold;
    +
    +        /** Root task constructor */
    +        public IntCumulateTask(IntCumulateTask parent,
    +                               IntBinaryOperator function,
    +                               int[] array, int lo, int hi) {
    +            super(parent);
    +            this.function = function; this.array = array;
    +            this.lo = this.origin = lo; this.hi = this.fence = hi;
    +            int p;
    +            this.threshold =
    +                    (p = (hi - lo) / (ForkJoinPool.getCommonPoolParallelism() << 3))
    +                    <= MIN_PARTITION ? MIN_PARTITION : p;
    +        }
    +
    +        /** Subtask constructor */
    +        IntCumulateTask(IntCumulateTask parent, IntBinaryOperator function,
    +                        int[] array, int origin, int fence, int threshold,
    +                        int lo, int hi) {
    +            super(parent);
    +            this.function = function; this.array = array;
    +            this.origin = origin; this.fence = fence;
    +            this.threshold = threshold;
    +            this.lo = lo; this.hi = hi;
    +        }
    +
    +        public final void compute() {
    +            final IntBinaryOperator fn;
    +            final int[] a;
    +            if ((fn = this.function) == null || (a = this.array) == null)
    +                throw new NullPointerException();    // hoist checks
    +            int th = threshold, org = origin, fnc = fence, l, h;
    +            IntCumulateTask t = this;
    +            outer: while ((l = t.lo) >= 0 && (h = t.hi) <= a.length) {
    +                if (h - l > th) {
    +                    IntCumulateTask lt = t.left, rt = t.right, f;
    +                    if (lt == null) {                // first pass
    +                        int mid = (l + h) >>> 1;
    +                        f = rt = t.right =
    +                                new IntCumulateTask(t, fn, a, org, fnc, th, mid, h);
    +                        t = lt = t.left  =
    +                                new IntCumulateTask(t, fn, a, org, fnc, th, l, mid);
    +                    }
    +                    else {                           // possibly refork
    +                        int pin = t.in;
    +                        lt.in = pin;
    +                        f = t = null;
    +                        if (rt != null) {
    +                            int lout = lt.out;
    +                            rt.in = (l == org ? lout :
    +                                     fn.applyAsInt(pin, lout));
    +                            for (int c;;) {
    +                                if (((c = rt.getPendingCount()) & CUMULATE) != 0)
    +                                    break;
    +                                if (rt.compareAndSetPendingCount(c, c|CUMULATE)){
    +                                    t = rt;
    +                                    break;
    +                                }
    +                            }
    +                        }
    +                        for (int c;;) {
    +                            if (((c = lt.getPendingCount()) & CUMULATE) != 0)
    +                                break;
    +                            if (lt.compareAndSetPendingCount(c, c|CUMULATE)) {
    +                                if (t != null)
    +                                    f = t;
    +                                t = lt;
    +                                break;
    +                            }
    +                        }
    +                        if (t == null)
    +                            break;
    +                    }
    +                    if (f != null)
    +                        f.fork();
    +                }
    +                else {
    +                    int state; // Transition to sum, cumulate, or both
    +                    for (int b;;) {
    +                        if (((b = t.getPendingCount()) & FINISHED) != 0)
    +                            break outer;                      // already done
    +                        state = ((b & CUMULATE) != 0? FINISHED :
    +                                 (l > org) ? SUMMED : (SUMMED|FINISHED));
    +                        if (t.compareAndSetPendingCount(b, b|state))
    +                            break;
    +                    }
    +
    +                    int sum;
    +                    if (state != SUMMED) {
    +                        int first;
    +                        if (l == org) {                       // leftmost; no in
    +                            sum = a[org];
    +                            first = org + 1;
    +                        }
    +                        else {
    +                            sum = t.in;
    +                            first = l;
    +                        }
    +                        for (int i = first; i < h; ++i)       // cumulate
    +                            a[i] = sum = fn.applyAsInt(sum, a[i]);
    +                    }
    +                    else if (h < fnc) {                       // skip rightmost
    +                        sum = a[l];
    +                        for (int i = l + 1; i < h; ++i)       // sum only
    +                            sum = fn.applyAsInt(sum, a[i]);
    +                    }
    +                    else
    +                        sum = t.in;
    +                    t.out = sum;
    +                    for (IntCumulateTask par;;) {            // propagate
    +                        if ((par = (IntCumulateTask)t.getCompleter()) == null) {
    +                            if ((state & FINISHED) != 0)      // enable join
    +                                t.quietlyComplete();
    +                            break outer;
    +                        }
    +                        int b = par.getPendingCount();
    +                        if ((b & state & FINISHED) != 0)
    +                            t = par;                          // both done
    +                        else if ((b & state & SUMMED) != 0) { // both summed
    +                            int nextState; IntCumulateTask lt, rt;
    +                            if ((lt = par.left) != null &&
    +                                (rt = par.right) != null) {
    +                                int lout = lt.out;
    +                                par.out = (rt.hi == fnc ? lout :
    +                                           fn.applyAsInt(lout, rt.out));
    +                            }
    +                            int refork = (((b & CUMULATE) == 0 &&
    +                                           par.lo == org) ? CUMULATE : 0);
    +                            if ((nextState = b|state|refork) == b ||
    +                                par.compareAndSetPendingCount(b, nextState)) {
    +                                state = SUMMED;               // drop finished
    +                                t = par;
    +                                if (refork != 0)
    +                                    par.fork();
    +                            }
    +                        }
    +                        else if (par.compareAndSetPendingCount(b, b|state))
    +                            break outer;                      // sib not ready
    +                    }
    +                }
    +            }
    +        }
    +    }
    +
    +
    +}
    \ No newline at end of file
    diff --git a/jdk/src/share/classes/java/util/Arrays.java b/jdk/src/share/classes/java/util/Arrays.java
    index 4035666d2ab..196a31e5767 100644
    --- a/jdk/src/share/classes/java/util/Arrays.java
    +++ b/jdk/src/share/classes/java/util/Arrays.java
    @@ -1559,6 +1559,183 @@ public class Arrays {
             }
         }
     
    +    // Parallel prefix
    +
    +    /**
    +     * Cumulates, in parallel, each element of the given array in place,
    +     * using the supplied function. For example if the array initially
    +     * holds {@code [2, 1, 0, 3]} and the operation performs addition,
    +     * then upon return the array holds {@code [2, 3, 3, 6]}.
    +     * Parallel prefix computation is usually more efficient than
    +     * sequential loops for large arrays.
    +     *
    +     * @param array the array, which is modified in-place by this method
    +     * @param op a side-effect-free, associative function to perform the
    +     * cumulation
    +     * @throws NullPointerException if the specified array or function is null
    +     * @since 1.8
    +     */
    +    public static  void parallelPrefix(T[] array, BinaryOperator op) {
    +        if (array.length > 0)
    +            new ArrayPrefixHelpers.CumulateTask<>
    +                    (null, op, array, 0, array.length).invoke();
    +    }
    +
    +    /**
    +     * Performs {@link #parallelPrefix(Object[], BinaryOperator)}
    +     * for the given subrange of the array.
    +     *
    +     * @param array the array
    +     * @param fromIndex the index of the first element, inclusive
    +     * @param toIndex the index of the last element, exclusive
    +     * @param op a side-effect-free, associative function to perform the
    +     * cumulation
    +     * @throws IllegalArgumentException if {@code fromIndex > toIndex}
    +     * @throws ArrayIndexOutOfBoundsException
    +     *     if {@code fromIndex < 0} or {@code toIndex > array.length}
    +     * @throws NullPointerException if the specified array or function is null
    +     * @since 1.8
    +     */
    +    public static  void parallelPrefix(T[] array, int fromIndex,
    +                                          int toIndex, BinaryOperator op) {
    +        rangeCheck(array.length, fromIndex, toIndex);
    +        if (fromIndex < toIndex)
    +            new ArrayPrefixHelpers.CumulateTask<>
    +                    (null, op, array, fromIndex, toIndex).invoke();
    +    }
    +
    +    /**
    +     * Cumulates, in parallel, each element of the given array in place,
    +     * using the supplied function. For example if the array initially
    +     * holds {@code [2, 1, 0, 3]} and the operation performs addition,
    +     * then upon return the array holds {@code [2, 3, 3, 6]}.
    +     * Parallel prefix computation is usually more efficient than
    +     * sequential loops for large arrays.
    +     *
    +     * @param array the array, which is modified in-place by this method
    +     * @param op a side-effect-free, associative function to perform the
    +     * cumulation
    +     * @throws NullPointerException if the specified array or function is null
    +     * @since 1.8
    +     */
    +    public static void parallelPrefix(long[] array, LongBinaryOperator op) {
    +        if (array.length > 0)
    +            new ArrayPrefixHelpers.LongCumulateTask
    +                    (null, op, array, 0, array.length).invoke();
    +    }
    +
    +    /**
    +     * Performs {@link #parallelPrefix(long[], LongBinaryOperator)}
    +     * for the given subrange of the array.
    +     *
    +     * @param array the array
    +     * @param fromIndex the index of the first element, inclusive
    +     * @param toIndex the index of the last element, exclusive
    +     * @param op a side-effect-free, associative function to perform the
    +     * cumulation
    +     * @throws IllegalArgumentException if {@code fromIndex > toIndex}
    +     * @throws ArrayIndexOutOfBoundsException
    +     *     if {@code fromIndex < 0} or {@code toIndex > array.length}
    +     * @throws NullPointerException if the specified array or function is null
    +     * @since 1.8
    +     */
    +    public static void parallelPrefix(long[] array, int fromIndex,
    +                                      int toIndex, LongBinaryOperator op) {
    +        rangeCheck(array.length, fromIndex, toIndex);
    +        if (fromIndex < toIndex)
    +            new ArrayPrefixHelpers.LongCumulateTask
    +                    (null, op, array, fromIndex, toIndex).invoke();
    +    }
    +
    +    /**
    +     * Cumulates, in parallel, each element of the given array in place,
    +     * using the supplied function. For example if the array initially
    +     * holds {@code [2.0, 1.0, 0.0, 3.0]} and the operation performs addition,
    +     * then upon return the array holds {@code [2.0, 3.0, 3.0, 6.0]}.
    +     * Parallel prefix computation is usually more efficient than
    +     * sequential loops for large arrays.
    +     *
    +     * 

    Because floating-point operations may not be strictly associative, + * the returned result may not be identical to the value that would be + * obtained if the operation was performed sequentially. + * + * @param array the array, which is modified in-place by this method + * @param op a side-effect-free function to perform the cumulation + * @throws NullPointerException if the specified array or function is null + * @since 1.8 + */ + public static void parallelPrefix(double[] array, DoubleBinaryOperator op) { + if (array.length > 0) + new ArrayPrefixHelpers.DoubleCumulateTask + (null, op, array, 0, array.length).invoke(); + } + + /** + * Performs {@link #parallelPrefix(double[], DoubleBinaryOperator)} + * for the given subrange of the array. + * + * @param array the array + * @param fromIndex the index of the first element, inclusive + * @param toIndex the index of the last element, exclusive + * @param op a side-effect-free, associative function to perform the + * cumulation + * @throws IllegalArgumentException if {@code fromIndex > toIndex} + * @throws ArrayIndexOutOfBoundsException + * if {@code fromIndex < 0} or {@code toIndex > array.length} + * @throws NullPointerException if the specified array or function is null + * @since 1.8 + */ + public static void parallelPrefix(double[] array, int fromIndex, + int toIndex, DoubleBinaryOperator op) { + rangeCheck(array.length, fromIndex, toIndex); + if (fromIndex < toIndex) + new ArrayPrefixHelpers.DoubleCumulateTask + (null, op, array, fromIndex, toIndex).invoke(); + } + + /** + * Cumulates, in parallel, each element of the given array in place, + * using the supplied function. For example if the array initially + * holds {@code [2, 1, 0, 3]} and the operation performs addition, + * then upon return the array holds {@code [2, 3, 3, 6]}. + * Parallel prefix computation is usually more efficient than + * sequential loops for large arrays. + * + * @param array the array, which is modified in-place by this method + * @param op a side-effect-free, associative function to perform the + * cumulation + * @throws NullPointerException if the specified array or function is null + * @since 1.8 + */ + public static void parallelPrefix(int[] array, IntBinaryOperator op) { + if (array.length > 0) + new ArrayPrefixHelpers.IntCumulateTask + (null, op, array, 0, array.length).invoke(); + } + + /** + * Performs {@link #parallelPrefix(int[], IntBinaryOperator)} + * for the given subrange of the array. + * + * @param array the array + * @param fromIndex the index of the first element, inclusive + * @param toIndex the index of the last element, exclusive + * @param op a side-effect-free, associative function to perform the + * cumulation + * @throws IllegalArgumentException if {@code fromIndex > toIndex} + * @throws ArrayIndexOutOfBoundsException + * if {@code fromIndex < 0} or {@code toIndex > array.length} + * @throws NullPointerException if the specified array or function is null + * @since 1.8 + */ + public static void parallelPrefix(int[] array, int fromIndex, + int toIndex, IntBinaryOperator op) { + rangeCheck(array.length, fromIndex, toIndex); + if (fromIndex < toIndex) + new ArrayPrefixHelpers.IntCumulateTask + (null, op, array, fromIndex, toIndex).invoke(); + } + // Searching /** diff --git a/jdk/test/java/util/Arrays/ParallelPrefix.java b/jdk/test/java/util/Arrays/ParallelPrefix.java new file mode 100644 index 00000000000..072de79c42c --- /dev/null +++ b/jdk/test/java/util/Arrays/ParallelPrefix.java @@ -0,0 +1,165 @@ +/* + * Copyright (c) 2013, 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 Arrays.ParallelPrefix(). + * @author Tristan Yan + * @run testng ParallelPrefix + */ + +import java.util.Arrays; +import java.util.function.BinaryOperator; +import java.util.function.DoubleBinaryOperator; +import java.util.function.Function; +import java.util.function.IntBinaryOperator; +import java.util.function.LongBinaryOperator; +import java.util.stream.IntStream; +import java.util.stream.LongStream; +import static org.testng.Assert.*; +import org.testng.annotations.DataProvider; +import org.testng.annotations.Test; + +public class ParallelPrefix { + //Array size less than MIN_PARTITION + private final static int SMALL_ARRAY_SIZE = 1 << 3; + + //Array size equals MIN_PARTITION + private final static int THRESHOLD_ARRAY_SIZE = 1 << 4; + + //Array size greater than MIN_PARTITION + private final static int MEDIUM_ARRAY_SIZE = 1 << 8; + + //Array size much greater than MIN_PARTITION + private final static int LARGE_ARRAY_SIZE = 1 << 12; + + private final static int[] ARRAY_SIZE_COLLECTION = new int[]{ + SMALL_ARRAY_SIZE, THRESHOLD_ARRAY_SIZE,MEDIUM_ARRAY_SIZE, LARGE_ARRAY_SIZE}; + + @DataProvider + public static Object[][] intSet(){ + return genericData(size -> IntStream.range(0, size).toArray(), new IntBinaryOperator[]{Integer::sum, Integer::min}); + } + + @DataProvider + public static Object[][] longSet(){ + return genericData(size -> LongStream.range(0, size).toArray(), new LongBinaryOperator[]{Long::sum, Long::min}); + } + + @DataProvider + public static Object[][] doubleSet(){ + return genericData(size -> IntStream.range(0, size).mapToDouble(i -> (double)i).toArray(), + new DoubleBinaryOperator[]{Double::sum, Double::min}); + } + + @DataProvider + public static Object[][] stringSet(){ + Function stringsFunc = size -> + IntStream.range(0, size).mapToObj(Integer::toString).toArray(String[]::new); + BinaryOperator cancatBop = String::concat; + return genericData(stringsFunc, new BinaryOperator[]{cancatBop}); + } + + private static Object[][] genericData(Function generateFunc, OPS[] ops) { + //test arrays which size is equals n-1, n, n+1, test random data + Object[][] data = new Object[ARRAY_SIZE_COLLECTION.length * 3 * ops.length][4]; + for(int n = 0; n < ARRAY_SIZE_COLLECTION.length; n++ ) { + for(int testValue = -1 ; testValue <= 1; testValue++) { + int array_size = ARRAY_SIZE_COLLECTION[n] + testValue; + for(int opsN = 0; opsN < ops.length; opsN++) { + int index = n * 3 * ops.length + (testValue + 1) * ops.length + opsN; + data[index][0] = generateFunc.apply(array_size); + data[index][1] = array_size / 3; + data[index][2] = 2 * array_size / 3; + data[index][3] = ops[opsN]; + } + } + } + return data; + } + + @Test(dataProvider="intSet") + public void testParallelPrefixForInt(int[] data, int fromIndex, int toIndex, IntBinaryOperator op) { + int[] sequentialResult = data.clone(); + for (int index = fromIndex + 1; index < toIndex; index++) { + sequentialResult[index ] = op.applyAsInt(sequentialResult[index - 1], sequentialResult[index]); + } + + int[] parallelResult = data.clone(); + Arrays.parallelPrefix(parallelResult, fromIndex, toIndex, op); + assertEquals(parallelResult, sequentialResult); + + int[] parallelRangeResult = Arrays.copyOfRange(data, fromIndex, toIndex); + Arrays.parallelPrefix(parallelRangeResult, op); + assertEquals(parallelRangeResult, Arrays.copyOfRange(sequentialResult, fromIndex, toIndex)); + } + + @Test(dataProvider="longSet") + public void testParallelPrefixForLong(long[] data, int fromIndex, int toIndex, LongBinaryOperator op) { + long[] sequentialResult = data.clone(); + for (int index = fromIndex + 1; index < toIndex; index++) { + sequentialResult[index ] = op.applyAsLong(sequentialResult[index - 1], sequentialResult[index]); + } + + long[] parallelResult = data.clone(); + Arrays.parallelPrefix(parallelResult, fromIndex, toIndex, op); + assertEquals(parallelResult, sequentialResult); + + long[] parallelRangeResult = Arrays.copyOfRange(data, fromIndex, toIndex); + Arrays.parallelPrefix(parallelRangeResult, op); + assertEquals(parallelRangeResult, Arrays.copyOfRange(sequentialResult, fromIndex, toIndex)); + } + + @Test(dataProvider="doubleSet") + public void testParallelPrefixForDouble(double[] data, int fromIndex, int toIndex, DoubleBinaryOperator op) { + double[] sequentialResult = data.clone(); + for (int index = fromIndex + 1; index < toIndex; index++) { + sequentialResult[index ] = op.applyAsDouble(sequentialResult[index - 1], sequentialResult[index]); + } + + double[] parallelResult = data.clone(); + Arrays.parallelPrefix(parallelResult, fromIndex, toIndex, op); + assertEquals(parallelResult, sequentialResult); + + double[] parallelRangeResult = Arrays.copyOfRange(data, fromIndex, toIndex); + Arrays.parallelPrefix(parallelRangeResult, op); + assertEquals(parallelRangeResult, Arrays.copyOfRange(sequentialResult, fromIndex, toIndex)); + } + + @Test(dataProvider="stringSet") + public void testParallelPrefixForStringr(String[] data , int fromIndex, int toIndex, BinaryOperator op) { + String[] sequentialResult = data.clone(); + for (int index = fromIndex + 1; index < toIndex; index++) { + sequentialResult[index ] = op.apply(sequentialResult[index - 1], sequentialResult[index]); + } + + String[] parallelResult = data.clone(); + Arrays.parallelPrefix(parallelResult, fromIndex, toIndex, op); + assertEquals(parallelResult, sequentialResult); + + String[] parallelRangeResult = Arrays.copyOfRange(data, fromIndex, toIndex); + Arrays.parallelPrefix(parallelRangeResult, op); + assertEquals(parallelRangeResult, Arrays.copyOfRange(sequentialResult, fromIndex, toIndex)); + } +} + From 9151d673653866ebd1b48ceb2c87f30019dad569 Mon Sep 17 00:00:00 2001 From: Robert Field Date: Wed, 26 Jun 2013 07:50:04 -0700 Subject: [PATCH 029/127] 8016761: Lambda metafactory - incorrect type conversion of constructor method handle Reviewed-by: jrose --- .../invoke/InnerClassLambdaMetafactory.java | 4 +- .../LambdaConstructorMethodHandleUnbox.java | 41 +++++++++++++++++++ 2 files changed, 44 insertions(+), 1 deletion(-) create mode 100644 jdk/test/java/lang/invoke/lambda/LambdaConstructorMethodHandleUnbox.java diff --git a/jdk/src/share/classes/java/lang/invoke/InnerClassLambdaMetafactory.java b/jdk/src/share/classes/java/lang/invoke/InnerClassLambdaMetafactory.java index 16703fc0917..0b6f4016b1d 100644 --- a/jdk/src/share/classes/java/lang/invoke/InnerClassLambdaMetafactory.java +++ b/jdk/src/share/classes/java/lang/invoke/InnerClassLambdaMetafactory.java @@ -112,7 +112,9 @@ import java.security.PrivilegedAction; implMethodDesc = implMethodType.toMethodDescriptorString(); Type implMethodAsmType = Type.getMethodType(implMethodDesc); implMethodArgumentTypes = implMethodAsmType.getArgumentTypes(); - implMethodReturnType = implMethodAsmType.getReturnType(); + implMethodReturnType = (implKind == MethodHandleInfo.REF_newInvokeSpecial) + ? Type.getObjectType(implMethodClassName) + : implMethodAsmType.getReturnType(); constructorType = invokedType.changeReturnType(Void.TYPE); constructorDesc = constructorType.toMethodDescriptorString(); lambdaClassName = targetClass.getName().replace('.', '/') + "$$Lambda$" + counter.incrementAndGet(); diff --git a/jdk/test/java/lang/invoke/lambda/LambdaConstructorMethodHandleUnbox.java b/jdk/test/java/lang/invoke/lambda/LambdaConstructorMethodHandleUnbox.java new file mode 100644 index 00000000000..5d77da88828 --- /dev/null +++ b/jdk/test/java/lang/invoke/lambda/LambdaConstructorMethodHandleUnbox.java @@ -0,0 +1,41 @@ +/* + * Copyright (c) 2013, 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 + * @bug 8016761 + * @summary Lambda metafactory: incorrect type conversion of constructor method handle + */ + +public class LambdaConstructorMethodHandleUnbox { + interface IntFunction { + int m(X x); + } + + public static void main(String[] args) { + IntFunction s = Integer::new; + if (s.m("2000") + s.m("13") != 2013) { + throw new RuntimeException("Lambda conversion failure"); + } + } +} From 6dfb68534015a9d8068502050f7e7137a2aa1475 Mon Sep 17 00:00:00 2001 From: Naoto Sato Date: Wed, 26 Jun 2013 11:21:01 -0700 Subject: [PATCH 030/127] 8017322: java/util/Currency/PropertiesTest.sh should run exclusively Reviewed-by: alanb --- jdk/test/TEST.ROOT | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/jdk/test/TEST.ROOT b/jdk/test/TEST.ROOT index 1645f6b26da..6bf72964f66 100644 --- a/jdk/test/TEST.ROOT +++ b/jdk/test/TEST.ROOT @@ -1,6 +1,5 @@ # This file identifies the root of the test-suite hierarchy. # It also contains test-suite configuration information. -# DO NOT EDIT without first contacting jdk-regtest@sun.com. # The list of keywords supported in the entire test suite keys=2d dnd i18n @@ -9,4 +8,4 @@ keys=2d dnd i18n othervm.dirs=java/awt java/beans java/rmi javax/accessibility javax/imageio javax/sound javax/print javax/management com/sun/awt sun/awt sun/java2d sun/pisces sun/rmi # Tests that cannot run concurrently -exclusiveAccess.dirs=java/rmi/Naming java/util/prefs sun/management/jmxremote sun/tools/jstatd sun/security/mscapi +exclusiveAccess.dirs=java/rmi/Naming java/util/Currency java/util/prefs sun/management/jmxremote sun/tools/jstatd sun/security/mscapi From 4d367e8fbbbd047a78df22a5613d373c90eab2ba Mon Sep 17 00:00:00 2001 From: Joe Darcy Date: Wed, 26 Jun 2013 13:24:13 -0700 Subject: [PATCH 031/127] 7018139: Fix HTML accessibility and doclint issues in java.math Reviewed-by: lancea, bpb --- jdk/src/share/classes/java/math/BigDecimal.java | 3 +++ jdk/src/share/classes/java/math/RoundingMode.java | 10 +++++++++- 2 files changed, 12 insertions(+), 1 deletion(-) diff --git a/jdk/src/share/classes/java/math/BigDecimal.java b/jdk/src/share/classes/java/math/BigDecimal.java index d2a44922378..944f8a79fbe 100644 --- a/jdk/src/share/classes/java/math/BigDecimal.java +++ b/jdk/src/share/classes/java/math/BigDecimal.java @@ -2572,6 +2572,9 @@ public class BigDecimal extends Number implements Comparable { * ({@code this} * 10n). The scale of * the result is {@code (this.scale() - n)}. * + * @param n the exponent power of ten to scale by + * @return a BigDecimal whose numerical value is equal to + * ({@code this} * 10n) * @throws ArithmeticException if the scale would be * outside the range of a 32-bit integer. * diff --git a/jdk/src/share/classes/java/math/RoundingMode.java b/jdk/src/share/classes/java/math/RoundingMode.java index 69994a4c316..41493a200e2 100644 --- a/jdk/src/share/classes/java/math/RoundingMode.java +++ b/jdk/src/share/classes/java/math/RoundingMode.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -101,6 +101,7 @@ public enum RoundingMode { * *

    Example: * + * * * @@ -124,6 +125,7 @@ public enum RoundingMode { * *

    Example: *

    Rounding mode UP Examples
    Input NumberInput rounded to one digit
    with {@code UP} rounding *
    5.5 6
    + * * * @@ -148,6 +150,7 @@ public enum RoundingMode { * *

    Example: *

    Rounding mode DOWN Examples
    Input NumberInput rounded to one digit
    with {@code DOWN} rounding *
    5.5 5
    + * * * @@ -172,6 +175,7 @@ public enum RoundingMode { * *

    Example: *

    Rounding mode CEILING Examples
    Input NumberInput rounded to one digit
    with {@code CEILING} rounding *
    5.5 6
    + * * * @@ -198,6 +202,7 @@ public enum RoundingMode { * *

    Example: *

    Rounding mode FLOOR Examples
    Input NumberInput rounded to one digit
    with {@code FLOOR} rounding *
    5.5 5
    + * * * @@ -223,6 +228,7 @@ public enum RoundingMode { * *

    Example: *

    Rounding mode HALF_UP Examples
    Input NumberInput rounded to one digit
    with {@code HALF_UP} rounding *
    5.5 6
    + * * * @@ -255,6 +261,7 @@ public enum RoundingMode { * *

    Example: *

    Rounding mode HALF_DOWN Examples
    Input NumberInput rounded to one digit
    with {@code HALF_DOWN} rounding *
    5.5 5
    + * * * @@ -278,6 +285,7 @@ public enum RoundingMode { * {@code ArithmeticException} is thrown. *

    Example: *

    Rounding mode HALF_EVEN Examples
    Input NumberInput rounded to one digit
    with {@code HALF_EVEN} rounding *
    5.5 6
    + * * * From 5837f1387b40704f8edeac86b70a9666c765a84a Mon Sep 17 00:00:00 2001 From: Joe Darcy Date: Wed, 26 Jun 2013 19:09:18 -0700 Subject: [PATCH 032/127] 8019223: Fix doclint warnings in java.rmi.server Reviewed-by: smarks --- jdk/src/share/classes/java/rmi/server/RMIClassLoader.java | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/jdk/src/share/classes/java/rmi/server/RMIClassLoader.java b/jdk/src/share/classes/java/rmi/server/RMIClassLoader.java index f064d617fcd..f9f23ddd019 100644 --- a/jdk/src/share/classes/java/rmi/server/RMIClassLoader.java +++ b/jdk/src/share/classes/java/rmi/server/RMIClassLoader.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2004, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2013, 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 @@ -424,7 +424,7 @@ public class RMIClassLoader { * *
      * - *

    • If the class loader is the system class loader (see + *
    • If the class loader is the system class loader (see * {@link ClassLoader#getSystemClassLoader}), a parent of the * system class loader such as the loader used for installed * extensions, or the bootstrap class loader (which may be @@ -433,7 +433,7 @@ public class RMIClassLoader { * earlier cached value) is returned, or * null is returned if that property is not set. * - *

    • Otherwise, if the class loader is an instance of + *
    • Otherwise, if the class loader is an instance of * URLClassLoader, then the returned string is a * space-separated list of the external forms of the URLs returned * by invoking the getURLs methods of the loader. If @@ -452,7 +452,7 @@ public class RMIClassLoader { * property (or possibly an earlier cached value) is returned, or * null is returned if that property is not set. * - *

    • Finally, if the class loader is not an instance of + *
    • Finally, if the class loader is not an instance of * URLClassLoader, then the value of the * java.rmi.server.codebase property (or possibly an * earlier cached value) is returned, or From c9e713d562be1fb4b8b8bb2a077b62aa65b421be Mon Sep 17 00:00:00 2001 From: Joe Darcy Date: Wed, 26 Jun 2013 22:12:09 -0700 Subject: [PATCH 033/127] 8019228: Fix doclint issues in java.util.zip Reviewed-by: sherman, mchung --- jdk/src/share/classes/java/util/zip/Deflater.java | 6 +++--- jdk/src/share/classes/java/util/zip/Inflater.java | 6 +++--- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/jdk/src/share/classes/java/util/zip/Deflater.java b/jdk/src/share/classes/java/util/zip/Deflater.java index 227c06d1c14..085287996be 100644 --- a/jdk/src/share/classes/java/util/zip/Deflater.java +++ b/jdk/src/share/classes/java/util/zip/Deflater.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2013, 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 @@ -461,7 +461,7 @@ class Deflater { } /** - * Returns the total number of uncompressed bytes input so far.

      + * Returns the total number of uncompressed bytes input so far. * * @return the total (non-negative) number of uncompressed bytes input so far * @since 1.5 @@ -487,7 +487,7 @@ class Deflater { } /** - * Returns the total number of compressed bytes output so far.

      + * Returns the total number of compressed bytes output so far. * * @return the total (non-negative) number of compressed bytes output so far * @since 1.5 diff --git a/jdk/src/share/classes/java/util/zip/Inflater.java b/jdk/src/share/classes/java/util/zip/Inflater.java index 25f9d2dcd34..c1eefe122d8 100644 --- a/jdk/src/share/classes/java/util/zip/Inflater.java +++ b/jdk/src/share/classes/java/util/zip/Inflater.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2013, 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 @@ -305,7 +305,7 @@ class Inflater { } /** - * Returns the total number of compressed bytes input so far.

      + * Returns the total number of compressed bytes input so far. * * @return the total (non-negative) number of compressed bytes input so far * @since 1.5 @@ -331,7 +331,7 @@ class Inflater { } /** - * Returns the total number of uncompressed bytes output so far.

      + * Returns the total number of uncompressed bytes output so far. * * @return the total (non-negative) number of uncompressed bytes output so far * @since 1.5 From f20ec2a5b563822343e6f4188f82f951bad6b856 Mon Sep 17 00:00:00 2001 From: Bradford Wetmore Date: Thu, 27 Jun 2013 10:19:59 +0100 Subject: [PATCH 034/127] 8019227: JDK-8010325 broke the old build Reviewed-by: alanb, chegar --- jdk/make/java/java/FILES_java.gmk | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/jdk/make/java/java/FILES_java.gmk b/jdk/make/java/java/FILES_java.gmk index 1bdbdf03b31..b62d15d5ba5 100644 --- a/jdk/make/java/java/FILES_java.gmk +++ b/jdk/make/java/java/FILES_java.gmk @@ -1,5 +1,5 @@ # -# Copyright (c) 1996, 2012, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 1996, 2013, 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 @@ -529,7 +529,6 @@ JAVA_JAVA_java = \ sun/misc/JavaNioAccess.java \ sun/misc/Perf.java \ sun/misc/PerfCounter.java \ - sun/misc/Hashing.java \ sun/net/www/protocol/jar/Handler.java \ sun/net/www/protocol/jar/JarURLConnection.java \ sun/net/www/protocol/file/Handler.java \ From 50e05b177d7a24923e2aa05bd6b331d8e91f607d Mon Sep 17 00:00:00 2001 From: Joe Darcy Date: Thu, 27 Jun 2013 11:06:46 -0700 Subject: [PATCH 035/127] 8019304: Fix doclint issues in java.util.prefs Reviewed-by: lancea --- .../share/classes/java/util/prefs/AbstractPreferences.java | 6 +++++- .../share/classes/java/util/prefs/PreferencesFactory.java | 5 ++++- 2 files changed, 9 insertions(+), 2 deletions(-) diff --git a/jdk/src/share/classes/java/util/prefs/AbstractPreferences.java b/jdk/src/share/classes/java/util/prefs/AbstractPreferences.java index b7723d831ac..31c35d7fa46 100644 --- a/jdk/src/share/classes/java/util/prefs/AbstractPreferences.java +++ b/jdk/src/share/classes/java/util/prefs/AbstractPreferences.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -1121,6 +1121,8 @@ public abstract class AbstractPreferences extends Preferences { * removed. (The implementor needn't check for any of these things.) * *

      This method is invoked with the lock on this node held. + * @param key the key + * @param value the value */ protected abstract void putSpi(String key, String value); @@ -1139,6 +1141,7 @@ public abstract class AbstractPreferences extends Preferences { * *

      This method is invoked with the lock on this node held. * + * @param key the key * @return the value associated with the specified key at this preference * node, or null if there is no association for this * key, or the association cannot be determined at this time. @@ -1152,6 +1155,7 @@ public abstract class AbstractPreferences extends Preferences { * (The implementor needn't check for either of these things.) * *

      This method is invoked with the lock on this node held. + * @param key the key */ protected abstract void removeSpi(String key); diff --git a/jdk/src/share/classes/java/util/prefs/PreferencesFactory.java b/jdk/src/share/classes/java/util/prefs/PreferencesFactory.java index 8bf37bc3c5c..d7341e6569d 100644 --- a/jdk/src/share/classes/java/util/prefs/PreferencesFactory.java +++ b/jdk/src/share/classes/java/util/prefs/PreferencesFactory.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2005, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -45,6 +45,7 @@ public interface PreferencesFactory { /** * Returns the system root preference node. (Multiple calls on this * method will return the same object reference.) + * @return the system root preference node */ Preferences systemRoot(); @@ -52,6 +53,8 @@ public interface PreferencesFactory { * Returns the user root preference node corresponding to the calling * user. In a server, the returned value will typically depend on * some implicit client-context. + * @return the user root preference node corresponding to the calling + * user */ Preferences userRoot(); } From f693157806b83313c87865b51192d1c9825c8c38 Mon Sep 17 00:00:00 2001 From: Lance Andersen Date: Thu, 27 Jun 2013 15:07:56 -0400 Subject: [PATCH 036/127] 8017471: Fix JDBC -Xdoclint public errors Reviewed-by: darcy --- jdk/src/share/classes/java/sql/Blob.java | 4 +- .../classes/java/sql/CallableStatement.java | 2 + jdk/src/share/classes/java/sql/Clob.java | 4 +- .../classes/java/sql/DatabaseMetaData.java | 4 +- jdk/src/share/classes/java/sql/Driver.java | 5 +- .../share/classes/java/sql/DriverAction.java | 2 +- jdk/src/share/classes/java/sql/NClob.java | 4 +- jdk/src/share/classes/java/sql/ResultSet.java | 6 +- jdk/src/share/classes/java/sql/SQLInput.java | 1 + .../share/classes/java/sql/SQLPermission.java | 1 - jdk/src/share/classes/java/sql/SQLXML.java | 4 +- jdk/src/share/classes/java/sql/Wrapper.java | 3 +- .../classes/javax/sql/CommonDataSource.java | 5 +- .../javax/sql/ConnectionPoolDataSource.java | 4 +- .../share/classes/javax/sql/DataSource.java | 2 +- jdk/src/share/classes/javax/sql/RowSet.java | 4 +- .../share/classes/javax/sql/XADataSource.java | 4 +- .../classes/javax/sql/rowset/BaseRowSet.java | 8 +- .../javax/sql/rowset/CachedRowSet.java | 11 +- .../javax/sql/rowset/FilteredRowSet.java | 8 +- .../classes/javax/sql/rowset/JdbcRowSet.java | 12 +- .../classes/javax/sql/rowset/Joinable.java | 4 +- .../classes/javax/sql/rowset/Predicate.java | 4 +- .../javax/sql/rowset/RowSetProvider.java | 6 +- .../javax/sql/rowset/RowSetWarning.java | 4 +- .../classes/javax/sql/rowset/WebRowSet.java | 570 +++++++++--------- .../classes/javax/sql/rowset/package.html | 4 +- .../javax/sql/rowset/serial/SerialArray.java | 4 +- .../javax/sql/rowset/serial/SerialBlob.java | 4 +- .../javax/sql/rowset/serial/SerialClob.java | 4 +- .../sql/rowset/serial/SerialDatalink.java | 5 +- .../sql/rowset/serial/SerialJavaObject.java | 2 +- .../javax/sql/rowset/serial/SerialRef.java | 4 +- .../javax/sql/rowset/serial/SerialStruct.java | 4 +- .../javax/sql/rowset/spi/SyncFactory.java | 14 +- .../javax/sql/rowset/spi/SyncResolver.java | 15 +- 36 files changed, 386 insertions(+), 360 deletions(-) diff --git a/jdk/src/share/classes/java/sql/Blob.java b/jdk/src/share/classes/java/sql/Blob.java index 46b7c2f2013..90bb251c07b 100644 --- a/jdk/src/share/classes/java/sql/Blob.java +++ b/jdk/src/share/classes/java/sql/Blob.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2006, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2013, 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 @@ -29,7 +29,7 @@ import java.io.InputStream; /** * The representation (mapping) in - * the JavaTM programming + * the Java™ programming * language of an SQL * BLOB value. An SQL BLOB is a built-in type * that stores a Binary Large Object as a column value in a row of diff --git a/jdk/src/share/classes/java/sql/CallableStatement.java b/jdk/src/share/classes/java/sql/CallableStatement.java index a39af405220..dc98859bf8b 100644 --- a/jdk/src/share/classes/java/sql/CallableStatement.java +++ b/jdk/src/share/classes/java/sql/CallableStatement.java @@ -2445,6 +2445,7 @@ public interface CallableStatement extends PreparedStatement { * @param parameterIndex the first parameter is 1, the second is 2, and so on * @param type Class representing the Java data type to convert the * designated parameter to. + * @param the type of the class modeled by this Class object * @return an instance of {@code type} holding the OUT parameter value * @throws SQLException if conversion is not supported, type is null or * another error occurs. The getCause() method of the @@ -2473,6 +2474,7 @@ public interface CallableStatement extends PreparedStatement { * @param parameterName the name of the parameter * @param type Class representing the Java data type to convert * the designated parameter to. + * @param the type of the class modeled by this Class object * @return an instance of {@code type} holding the OUT parameter * value * @throws SQLException if conversion is not supported, type is null or diff --git a/jdk/src/share/classes/java/sql/Clob.java b/jdk/src/share/classes/java/sql/Clob.java index 868c862a013..8ffc38af754 100644 --- a/jdk/src/share/classes/java/sql/Clob.java +++ b/jdk/src/share/classes/java/sql/Clob.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2006, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2013, 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 @@ -28,7 +28,7 @@ package java.sql; import java.io.Reader; /** - * The mapping in the JavaTM programming language + * The mapping in the Java™ programming language * for the SQL CLOB type. * An SQL CLOB is a built-in type * that stores a Character Large Object as a column value in a row of diff --git a/jdk/src/share/classes/java/sql/DatabaseMetaData.java b/jdk/src/share/classes/java/sql/DatabaseMetaData.java index 035365512b7..63c6f131c4f 100644 --- a/jdk/src/share/classes/java/sql/DatabaseMetaData.java +++ b/jdk/src/share/classes/java/sql/DatabaseMetaData.java @@ -31,7 +31,7 @@ package java.sql; *

      * This interface is implemented by driver vendors to let users know the capabilities * of a Database Management System (DBMS) in combination with - * the driver based on JDBCTM technology + * the driver based on JDBC™ technology * ("JDBC driver") that is used with it. Different relational DBMSs often support * different features, implement features in different ways, and use different * data types. In addition, a driver may implement a feature on top of what the @@ -3074,7 +3074,7 @@ public interface DatabaseMetaData extends Wrapper { * * @param holdability one of the following constants: * ResultSet.HOLD_CURSORS_OVER_COMMIT or - * ResultSet.CLOSE_CURSORS_AT_COMMIT + * ResultSet.CLOSE_CURSORS_AT_COMMIT * @return true if so; false otherwise * @exception SQLException if a database access error occurs * @see Connection diff --git a/jdk/src/share/classes/java/sql/Driver.java b/jdk/src/share/classes/java/sql/Driver.java index 27ad3e0407d..3bb3e0c4576 100644 --- a/jdk/src/share/classes/java/sql/Driver.java +++ b/jdk/src/share/classes/java/sql/Driver.java @@ -144,7 +144,7 @@ public interface Driver { /** * Reports whether this driver is a genuine JDBC - * CompliantTM driver. + * Compliant™ driver. * A driver may only report true here if it passes the JDBC * compliance tests; otherwise it is required to return false. *

      @@ -173,7 +173,8 @@ public interface Driver { * In the worst case, this may be the root Logger. * * @return the parent Logger for this driver - * @throws SQLFeatureNotSupportedException if the driver does not use java.util.logging. + * @throws SQLFeatureNotSupportedException if the driver does not use + * {@code java.util.logging}. * @since 1.7 */ public Logger getParentLogger() throws SQLFeatureNotSupportedException; diff --git a/jdk/src/share/classes/java/sql/DriverAction.java b/jdk/src/share/classes/java/sql/DriverAction.java index 167168c9b85..59d98259620 100644 --- a/jdk/src/share/classes/java/sql/DriverAction.java +++ b/jdk/src/share/classes/java/sql/DriverAction.java @@ -33,7 +33,7 @@ package java.sql; * directly by applications. A JDBC Driver may choose * to create its {@code DriverAction} implementation in a private class * to avoid it being called directly. - * + *

      * The JDBC driver's static initialization block must call * {@linkplain DriverManager#registerDriver(java.sql.Driver, java.sql.DriverAction) } in order * to inform {@code DriverManager} which {@code DriverAction} implementation to diff --git a/jdk/src/share/classes/java/sql/NClob.java b/jdk/src/share/classes/java/sql/NClob.java index a70ed6190a6..f3d535c0afd 100644 --- a/jdk/src/share/classes/java/sql/NClob.java +++ b/jdk/src/share/classes/java/sql/NClob.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2006, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2013, 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 @@ -28,7 +28,7 @@ package java.sql; import java.sql.Clob; /** - * The mapping in the JavaTM programming language + * The mapping in the Java™ programming language * for the SQL NCLOB type. * An SQL NCLOB is a built-in type * that stores a Character Large Object using the National Character Set diff --git a/jdk/src/share/classes/java/sql/ResultSet.java b/jdk/src/share/classes/java/sql/ResultSet.java index 7029c935906..9c912416308 100644 --- a/jdk/src/share/classes/java/sql/ResultSet.java +++ b/jdk/src/share/classes/java/sql/ResultSet.java @@ -90,7 +90,7 @@ import java.io.InputStream; * the intended columns, which can be assured with the SQL AS clause. *

      * A set of updater methods were added to this interface - * in the JDBC 2.0 API (JavaTM 2 SDK, + * in the JDBC 2.0 API (Java™ 2 SDK, * Standard Edition, version 1.2). The comments regarding parameters * to the getter methods also apply to parameters to the * updater methods. @@ -4101,7 +4101,7 @@ public interface ResultSet extends Wrapper, AutoCloseable { * Appendix B, Table B-3 and conversion of appropriate user defined SQL * types to a Java type which implements {@code SQLData}, or {@code Struct}. * Additional conversions may be supported and are vendor defined. - * + * @param the type of the class modeled by this Class object * @param columnIndex the first column is 1, the second is 2, ... * @param type Class representing the Java data type to convert the designated * column to. @@ -4135,6 +4135,7 @@ public interface ResultSet extends Wrapper, AutoCloseable { * of the column * @param type Class representing the Java data type to convert the designated * column to. + * @param the type of the class modeled by this Class object * @return an instance of {@code type} holding the column value * @throws SQLException if conversion is not supported, type is null or * another error occurs. The getCause() method of the @@ -4208,6 +4209,7 @@ public interface ResultSet extends Wrapper, AutoCloseable { * @param columnLabel the label for the column specified with the SQL AS * clause. If the SQL AS clause was not specified, then the label is * the name of the column + * @param x the new column value * @param targetSqlType the SQL type to be sent to the database * @param scaleOrLength for an object of {@code java.math.BigDecimal} , * this is the number of digits after the decimal point. For diff --git a/jdk/src/share/classes/java/sql/SQLInput.java b/jdk/src/share/classes/java/sql/SQLInput.java index 8d2540dc499..ae65e67ac6f 100644 --- a/jdk/src/share/classes/java/sql/SQLInput.java +++ b/jdk/src/share/classes/java/sql/SQLInput.java @@ -444,6 +444,7 @@ public interface SQLInput { *

      * The default implementation will throw {@code SQLFeatureNotSupportedException} * + * @param the type of the class modeled by this Class object * @param type Class representing the Java data type to convert the attribute to. * @return the attribute at the head of the stream as an {@code Object} in the * Java programming language;{@code null} if the attribute is SQL {@code NULL} diff --git a/jdk/src/share/classes/java/sql/SQLPermission.java b/jdk/src/share/classes/java/sql/SQLPermission.java index 3aa5a42860b..d264706ab7d 100644 --- a/jdk/src/share/classes/java/sql/SQLPermission.java +++ b/jdk/src/share/classes/java/sql/SQLPermission.java @@ -103,7 +103,6 @@ import java.security.*; *

    * - * *
    Rounding mode UNNECESSARY Examples
    Input NumberInput rounded to one digit
    with {@code UNNECESSARY} rounding *
    5.5 throw {@code ArithmeticException}Permits an application to remove a JDBC driver from the list of * registered Drivers and release its resources.
    *

    * @since 1.3 diff --git a/jdk/src/share/classes/java/sql/SQLXML.java b/jdk/src/share/classes/java/sql/SQLXML.java index 88e3baada72..2acc5d1d350 100644 --- a/jdk/src/share/classes/java/sql/SQLXML.java +++ b/jdk/src/share/classes/java/sql/SQLXML.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2006, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2013, 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 @@ -360,6 +360,7 @@ public interface SQLXML * xmlReader.parse(saxSource.getInputSource()); *

    * + * @param the type of the class modeled by this Class object * @param sourceClass The class of the source, or null. * If the class is null, a vendor specifc Source implementation will be returned. * The following classes are supported at a minimum: @@ -401,6 +402,7 @@ public interface SQLXML * contentHandler.endDocument(); *
    * + * @param the type of the class modeled by this Class object * @param resultClass The class of the result, or null. * If resultClass is null, a vendor specific Result implementation will be returned. * The following classes are supported at a minimum: diff --git a/jdk/src/share/classes/java/sql/Wrapper.java b/jdk/src/share/classes/java/sql/Wrapper.java index 2eaa003f240..ee77431c0cd 100644 --- a/jdk/src/share/classes/java/sql/Wrapper.java +++ b/jdk/src/share/classes/java/sql/Wrapper.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2006, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2013, 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 @@ -53,6 +53,7 @@ public interface Wrapper { * or a proxy for that result. If the receiver is not a * wrapper and does not implement the interface, then an SQLException is thrown. * + * @param the type of the class modeled by this Class object * @param iface A Class defining an interface that the result must implement. * @return an object that implements the interface. May be a proxy for the actual implementing object. * @throws java.sql.SQLException If no object found that implements the interface diff --git a/jdk/src/share/classes/javax/sql/CommonDataSource.java b/jdk/src/share/classes/javax/sql/CommonDataSource.java index 25b40686d87..51f5ea03eb7 100644 --- a/jdk/src/share/classes/javax/sql/CommonDataSource.java +++ b/jdk/src/share/classes/javax/sql/CommonDataSource.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2013, 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 @@ -122,7 +122,8 @@ public interface CommonDataSource { * In the worst case, this may be the root Logger. * * @return the parent Logger for this data source - * @throws SQLFeatureNotSupportedException if the data source does not use java.util.logging. + * @throws SQLFeatureNotSupportedException if the data source does not use + * {@code java.util.logging} * @since 1.7 */ public Logger getParentLogger() throws SQLFeatureNotSupportedException; diff --git a/jdk/src/share/classes/javax/sql/ConnectionPoolDataSource.java b/jdk/src/share/classes/javax/sql/ConnectionPoolDataSource.java index 8bb34ed273b..6388735adc6 100644 --- a/jdk/src/share/classes/javax/sql/ConnectionPoolDataSource.java +++ b/jdk/src/share/classes/javax/sql/ConnectionPoolDataSource.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -32,7 +32,7 @@ import java.sql.SQLException; * A factory for PooledConnection * objects. An object that implements this interface will typically be * registered with a naming service that is based on the - * JavaTM Naming and Directory Interface + * Java™ Naming and Directory Interface * (JNDI). * * @since 1.4 diff --git a/jdk/src/share/classes/javax/sql/DataSource.java b/jdk/src/share/classes/javax/sql/DataSource.java index 8235d2a2779..71fa074e204 100644 --- a/jdk/src/share/classes/javax/sql/DataSource.java +++ b/jdk/src/share/classes/javax/sql/DataSource.java @@ -36,7 +36,7 @@ import java.sql.Wrapper; * is the preferred means of getting a connection. An object that implements * the {@code DataSource} interface will typically be * registered with a naming service based on the - * JavaTM Naming and Directory (JNDI) API. + * Java™ Naming and Directory (JNDI) API. *

    * The {@code DataSource} interface is implemented by a driver vendor. * There are three types of implementations: diff --git a/jdk/src/share/classes/javax/sql/RowSet.java b/jdk/src/share/classes/javax/sql/RowSet.java index fd33529667e..38cd35a3c3c 100644 --- a/jdk/src/share/classes/javax/sql/RowSet.java +++ b/jdk/src/share/classes/javax/sql/RowSet.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2006, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -32,7 +32,7 @@ import java.util.*; /** * The interface that adds support to the JDBC API for the - * JavaBeansTM component model. + * JavaBeans™ component model. * A rowset, which can be used as a JavaBeans component in * a visual Bean development environment, can be created and * configured at design time and executed at run time. diff --git a/jdk/src/share/classes/javax/sql/XADataSource.java b/jdk/src/share/classes/javax/sql/XADataSource.java index 325f015f733..b768601c7f3 100644 --- a/jdk/src/share/classes/javax/sql/XADataSource.java +++ b/jdk/src/share/classes/javax/sql/XADataSource.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2006, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -31,7 +31,7 @@ import java.sql.*; * A factory for {@code XAConnection} objects that is used internally. * An object that implements the {@code XADataSource} interface is * typically registered with a naming service that uses the - * Java Naming and Directory InterfaceTM + * Java Naming and Directory Interface™ * (JNDI). *

    * An implementation of {@code XADataSource} must include a public no-arg diff --git a/jdk/src/share/classes/javax/sql/rowset/BaseRowSet.java b/jdk/src/share/classes/javax/sql/rowset/BaseRowSet.java index a3b13fa0f5c..1ca60adbfa4 100644 --- a/jdk/src/share/classes/javax/sql/rowset/BaseRowSet.java +++ b/jdk/src/share/classes/javax/sql/rowset/BaseRowSet.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -37,7 +37,7 @@ import javax.sql.rowset.serial.*; /** * An abstract class providing a RowSet object with its basic functionality. * The basic functions include having properties and sending event notifications, - * which all JavaBeansTM components must implement. + * which all JavaBeans™ components must implement. *

    *

    1.0 Overview

    * The BaseRowSet class provides the core functionality @@ -93,7 +93,7 @@ import javax.sql.rowset.serial.*; * NOTE: In order to use a DataSource object for making a * connection, the DataSource object must have been registered * with a naming service that uses the Java Naming and Directory - * InterfaceTM (JNDI) API. This registration + * Interface™ (JNDI) API. This registration * is usually done by a person acting in the capacity of a system administrator. *

    *

    3.0 Setting the Command and Its Parameters

    @@ -106,7 +106,7 @@ import javax.sql.rowset.serial.*; * to null if required. *

    * The following code fragment illustrates how the - * CachedRowSetTM + * CachedRowSet™ * object crs might have its command property set. Note that if a * tool is used to set properties, this is the code that the tool would use. *

    {@code
    diff --git a/jdk/src/share/classes/javax/sql/rowset/CachedRowSet.java b/jdk/src/share/classes/javax/sql/rowset/CachedRowSet.java
    index 1a8517520a2..26862715edf 100644
    --- a/jdk/src/share/classes/javax/sql/rowset/CachedRowSet.java
    +++ b/jdk/src/share/classes/javax/sql/rowset/CachedRowSet.java
    @@ -1,5 +1,5 @@
     /*
    - * Copyright (c) 2003, 2010, Oracle and/or its affiliates. All rights reserved.
    + * Copyright (c) 2003, 2013, 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
    @@ -46,7 +46,7 @@ import javax.sql.rowset.spi.*;
      * A CachedRowSet object is a container for rows of data
      * that caches its rows in memory, which makes it possible to operate without always being
      * connected to its data source. Further, it is a
    - * JavaBeansTM component and is scrollable,
    + * JavaBeans™ component and is scrollable,
      * updatable, and serializable. A CachedRowSet object typically
      * contains rows from a result set, but it can also contain rows from any file
      * with a tabular format, such as a spread sheet.  The reference implementation
    @@ -410,7 +410,7 @@ import javax.sql.rowset.spi.*;
      * NOTE:  In order to use a DataSource object for making a
      * connection, the DataSource object must have been registered
      * with a naming service that uses the Java Naming and Directory
    - * InterfaceTM (JNDI) API.  This registration
    + * Interface™ (JNDI) API.  This registration
      * is usually done by a person acting in the capacity of a system
      * administrator.
      * 

    @@ -734,7 +734,6 @@ public interface CachedRowSet extends RowSet, Joinable { * source. Otherwise, the application must explicity call the * commit() or rollback() methods as appropriate. * - * @throws SQLException if the cursor is on the insert row * @throws SyncProviderException if the underlying * synchronization provider's writer fails to write the updates * back to the data source @@ -805,7 +804,6 @@ public interface CachedRowSet extends RowSet, Joinable { * commit or rollback methods as appropriate. * * @param con a standard JDBC Connection object - * @throws SQLException if the cursor is on the insert row * @throws SyncProviderException if the underlying * synchronization provider's writer fails to write the updates * back to the data source @@ -1371,7 +1369,7 @@ public interface CachedRowSet extends RowSet, Joinable { * Applications can form a WebRowSet object from the CachedRowSet * object returned by this method in order * to export the RowSet schema definition to XML for future use. - * + * @return An empty copy of this {@code CachedRowSet} object * @throws SQLException if an error occurs in cloning the structure of this * CachedRowSet object * @see #createShared @@ -1543,6 +1541,7 @@ public interface CachedRowSet extends RowSet, Joinable { * @param numRows when populating, the number of rows interval on which the * CachedRowSet populated should fire; the default value * is zero; cannot be less than fetchSize or zero + * @throws SQLException {@code numRows < 0 or numRows < getFetchSize() } */ public void rowSetPopulated(RowSetEvent event, int numRows) throws SQLException; diff --git a/jdk/src/share/classes/javax/sql/rowset/FilteredRowSet.java b/jdk/src/share/classes/javax/sql/rowset/FilteredRowSet.java index 15bfa42a840..754bc49159d 100644 --- a/jdk/src/share/classes/javax/sql/rowset/FilteredRowSet.java +++ b/jdk/src/share/classes/javax/sql/rowset/FilteredRowSet.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2004, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -51,7 +51,7 @@ import java.math.*; *

    * A JDBC FilteredRowSet standard implementation implements the * RowSet interfaces and extends the - * CachedRowSetTM class. The + * CachedRowSet™ class. The * CachedRowSet class provides a set of protected cursor manipulation * methods, which a FilteredRowSet implementation can override * to supply filtering support. @@ -69,8 +69,8 @@ import java.math.*; * class JavaDoc), a FilteredRowSet could then be used as described * below. *

    - * *

    + * {@code
      *     FilteredRowSet frs = new FilteredRowSetImpl();
      *     frs.populate(rs);
      *
    @@ -78,8 +78,8 @@ import java.math.*;
      *     frs.setFilter(name);
      *
      *     frs.next() // only names from "Alpha" to "Bravo" will be returned
    + * }
      * 
    - * * In the example above, we initialize a Range object which * implements the Predicate interface. This object expresses * the following constraints: All rows outputted or modified from this diff --git a/jdk/src/share/classes/javax/sql/rowset/JdbcRowSet.java b/jdk/src/share/classes/javax/sql/rowset/JdbcRowSet.java index 448f4cd8ce4..bcb05d104dc 100644 --- a/jdk/src/share/classes/javax/sql/rowset/JdbcRowSet.java +++ b/jdk/src/share/classes/javax/sql/rowset/JdbcRowSet.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2006, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -38,7 +38,7 @@ import java.io.*; * *

    1.0 Overview

    * A wrapper around a ResultSet object that makes it possible - * to use the result set as a JavaBeansTM + * to use the result set as a JavaBeans™ * component. Thus, a JdbcRowSet object can be one of the Beans that * a tool makes available for composing an application. Because * a JdbcRowSet is a connected rowset, that is, it continually @@ -113,7 +113,7 @@ import java.io.*; *

    * The implementation of the RowSet method execute in the * JdbcRowSet reference implementation differs from that in the - * CachedRowSetTM + * CachedRowSet™ * reference implementation to account for the different * requirements of connected and disconnected RowSet objects. *

    @@ -238,6 +238,7 @@ public interface JdbcRowSet extends RowSet, Joinable { * call to either the method commit or the method rollback. By default, * new connections are in auto-commit mode. * + * @return {@code true} if auto-commit is enabled; {@code false} otherwise * @throws SQLException if a database access error occurs * @see java.sql.Connection#getAutoCommit() */ @@ -251,7 +252,8 @@ public interface JdbcRowSet extends RowSet, Joinable { * to allow an application to set the JdbcRowSet transaction behavior. *

    * Sets the current auto-commit mode for this Connection object. - * + * @param autoCommit {@code true} to enable auto-commit; {@code false} to + * disable auto-commit * @throws SQLException if a database access error occurs * @see java.sql.Connection#setAutoCommit(boolean) */ @@ -277,7 +279,7 @@ public interface JdbcRowSet extends RowSet, Joinable { * Undoes all changes made in the current transaction to the last set savepoint * and releases any database locks currently held by this Connection * object. This method should be used only when auto-commit mode has been disabled. - * + * @param s The {@code Savepoint} to rollback to * @throws SQLException if a database access error occurs or this Connection * object within this JdbcRowSet is in auto-commit mode. * @see #rollback diff --git a/jdk/src/share/classes/javax/sql/rowset/Joinable.java b/jdk/src/share/classes/javax/sql/rowset/Joinable.java index 7a789474b76..c15f44de54c 100644 --- a/jdk/src/share/classes/javax/sql/rowset/Joinable.java +++ b/jdk/src/share/classes/javax/sql/rowset/Joinable.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2004, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -137,7 +137,7 @@ public interface Joinable { * object. A JoinRowSet object can now add this RowSet * object based on the match column. *

    - * Sub-interfaces such as the CachedRowSetTM + * Sub-interfaces such as the CachedRowSet™ * interface define the method CachedRowSet.setKeyColumns, which allows * primary key semantics to be enforced on specific columns. * Implementations of the setMatchColumn(int columnIdx) method diff --git a/jdk/src/share/classes/javax/sql/rowset/Predicate.java b/jdk/src/share/classes/javax/sql/rowset/Predicate.java index eb747602eb0..63d76fdca6b 100644 --- a/jdk/src/share/classes/javax/sql/rowset/Predicate.java +++ b/jdk/src/share/classes/javax/sql/rowset/Predicate.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2004, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -111,7 +111,7 @@ public interface Predicate { * cursor moving from row to the next. In addition, if this internal method * moves the cursor onto a row that has been deleted, the internal method will * continue to ove the cursor until a valid row is found. - * + * @param rs The {@code RowSet} to be evaluated * @return true if there are more rows in the filter; * false otherwise */ diff --git a/jdk/src/share/classes/javax/sql/rowset/RowSetProvider.java b/jdk/src/share/classes/javax/sql/rowset/RowSetProvider.java index 1dd2d8315e7..654bb88ea24 100644 --- a/jdk/src/share/classes/javax/sql/rowset/RowSetProvider.java +++ b/jdk/src/share/classes/javax/sql/rowset/RowSetProvider.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2010, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2010, 2013, 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 @@ -71,7 +71,9 @@ public class RowSetProvider { debug = val != null && !"false".equals(val); } - + /** + * RowSetProvider constructor + */ protected RowSetProvider () { } diff --git a/jdk/src/share/classes/javax/sql/rowset/RowSetWarning.java b/jdk/src/share/classes/javax/sql/rowset/RowSetWarning.java index 57b9e438399..c110834c2cf 100644 --- a/jdk/src/share/classes/javax/sql/rowset/RowSetWarning.java +++ b/jdk/src/share/classes/javax/sql/rowset/RowSetWarning.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2004, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -35,7 +35,7 @@ import java.sql.SQLException; * This class complements the SQLWarning class. *

    * Rowset warnings may be retrieved from JdbcRowSet, - * CachedRowSetTM, + * CachedRowSet™, * WebRowSet, FilteredRowSet, or JoinRowSet * implementations. To retrieve the first warning reported on any * RowSet diff --git a/jdk/src/share/classes/javax/sql/rowset/WebRowSet.java b/jdk/src/share/classes/javax/sql/rowset/WebRowSet.java index abef62f1271..3f0ba94b739 100644 --- a/jdk/src/share/classes/javax/sql/rowset/WebRowSet.java +++ b/jdk/src/share/classes/javax/sql/rowset/WebRowSet.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2010, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -33,306 +33,310 @@ import java.math.*; import org.xml.sax.*; /** - * The standard interface that all implementations of a WebRowSet + * The standard interface that all implementations of a {@code WebRowSet} * must implement. *

    *

    1.0 Overview

    - * The WebRowSetImpl provides the standard + * The {@code WebRowSetImpl} provides the standard * reference implementation, which may be extended if required. *

    * The standard WebRowSet XML Schema definition is available at the following * URI: *

    * It describes the standard XML document format required when describing a - * RowSet object in XML and must be used be all standard implementations - * of the WebRowSet interface to ensure interoperability. In addition, - * the WebRowSet schema uses specific SQL/XML Schema annotations, + * {@code RowSet} object in XML and must be used be all standard implementations + * of the {@code WebRowSet} interface to ensure interoperability. In addition, + * the {@code WebRowSet} schema uses specific SQL/XML Schema annotations, * thus ensuring greater cross * platform inter-operability. This is an effort currently under way at the ISO * organization. The SQL/XML definition is available at the following URI: * - * The schema definition describes the internal data of a RowSet object + * The schema definition describes the internal data of a {@code RowSet} object * in three distinct areas: *
      - *
    • properties
    • - * These properties describe the standard synchronization provider properties in - * addition to the more general RowSet properties. - *

      - *

    • metadata
    • - * This describes the metadata associated with the tabular structure governed by a - * WebRowSet object. The metadata described is closely aligned with the - * metadata accessible in the underlying java.sql.ResultSet interface. - *

      - *

    • data
    • - * This describes the original data (the state of data since the last population - * or last synchronization of the WebRowSet object) and the current + *
    • properties - These properties describe the standard synchronization + * provider properties in addition to the more general {@code RowSet} properties. + *
    • + *
    • metadata - This describes the metadata associated with the tabular structure governed by a + * {@code WebRowSet} object. The metadata described is closely aligned with the + * metadata accessible in the underlying {@code java.sql.ResultSet} interface. + *
    • + *
    • data - This describes the original data (the state of data since the + * last population + * or last synchronization of the {@code WebRowSet} object) and the current * data. By keeping track of the delta between the original data and the current data, - * a WebRowSet maintains - * the ability to synchronize changes in its data back to the originating data source. + * a {@code WebRowSet} maintains the ability to synchronize changes + * in its data back to the originating data source. + *
    • *
    *

    *

    2.0 WebRowSet States

    - * The following sections demonstrates how a WebRowSet implementation + * The following sections demonstrates how a {@code WebRowSet} implementation * should use the XML Schema to describe update, insert, and delete operations - * and to describe the state of a WebRowSet object in XML. + * and to describe the state of a {@code WebRowSet} object in XML. *

    - *

    2.1 State 1 - Outputting a WebRowSet Object to XML

    - * In this example, a WebRowSet object is created and populated with a simple 2 column, - * 5 row table from a data source. Having the 5 rows in a WebRowSet object + *

    2.1 State 1 - Outputting a {@code WebRowSet} Object to XML

    + * In this example, a {@code WebRowSet} object is created and populated with a simple 2 column, + * 5 row table from a data source. Having the 5 rows in a {@code WebRowSet} object * makes it possible to describe them in XML. The * metadata describing the various standard JavaBeans properties as defined * in the RowSet interface plus the standard properties defined in - * the CachedRowSetTM interface + * the {@code CachedRowSet}™ interface * provide key details that describe WebRowSet * properties. Outputting the WebRowSet object to XML using the standard - * writeXml methods describes the internal properties as follows: + * {@code writeXml} methods describes the internal properties as follows: *
    - * <properties>
    - *       <command>select co1, col2 from test_table</command>
    - *      <concurrency>1</concurrency>
    - *      <datasource/>
    - *      <escape-processing>true</escape-processing>
    - *      <fetch-direction>0</fetch-direction>
    - *      <fetch-size>0</fetch-size>
    - *      <isolation-level>1</isolation-level>
    - *      <key-columns/>
    - *      <map/>
    - *      <max-field-size>0</max-field-size>
    - *      <max-rows>0</max-rows>
    - *      <query-timeout>0</query-timeout>
    - *      <read-only>false</read-only>
    - *      <rowset-type>TRANSACTION_READ_UNCOMMITED</rowset-type>
    - *      <show-deleted>false</show-deleted>
    - *      <table-name/>
    - *      <url>jdbc:thin:oracle</url>
    - *      <sync-provider>
    - *              <sync-provider-name>.com.rowset.provider.RIOptimisticProvider</sync-provider-name>
    - *              <sync-provider-vendor>Oracle Corporation</sync-provider-vendor>
    - *              <sync-provider-version>1.0</sync-provider-name>
    - *              <sync-provider-grade>LOW</sync-provider-grade>
    - *              <data-source-lock>NONE</data-source-lock>
    - *      </sync-provider>
    - * </properties>
    - * 
    + * {@code + * + * select co1, col2 from test_table + * 1 + * + * true + * 0 + * 0 + * 1 + * + * + * 0 + * 0 + * 0 + * false + * TRANSACTION_READ_UNCOMMITED + * false + * + * jdbc:thin:oracle + * + * .com.rowset.provider.RIOptimisticProvider + * Oracle Corporation + * 1.0 + * LOW + * NONE + * + * + * }
    * The meta-data describing the make up of the WebRowSet is described * in XML as detailed below. Note both columns are described between the - * column-definition tags. + * {@code column-definition} tags. *
    - * <metadata>
    - *      <column-count>2</column-count>
    - *      <column-definition>
    - *              <column-index>1</column-index>
    - *              <auto-increment>false</auto-increment>
    - *              <case-sensitive>true</case-sensitive>
    - *              <currency>false</currency>
    - *              <nullable>1</nullable>
    - *              <signed>false</signed>
    - *              <searchable>true</searchable>
    - *              <column-display-size>10</column-display-size>
    - *              <column-label>COL1</column-label>
    - *              <column-name>COL1</column-name>
    - *              <schema-name/>
    - *              <column-precision>10</column-precision>
    - *              <column-scale>0</column-scale>
    - *              <table-name/>
    - *              <catalog-name/>
    - *              <column-type>1</column-type>
    - *              <column-type-name>CHAR</column-type-name>
    - *      </column-definition>
    - *      <column-definition>
    - *              <column-index>2</column-index>
    - *              <auto-increment>false</auto-increment>
    - *              <case-sensitive>false</case-sensitive>
    - *              <currency>false</currency>
    - *              <nullable>1</nullable>
    - *              <signed>true</signed>
    - *              <searchable>true</searchable>
    - *              <column-display-size>39</column-display-size>
    - *              <column-label>COL2</column-label>
    - *              <column-name>COL2</column-name>
    - *              <schema-name/>
    - *              <column-precision>38</column-precision>
    - *              <column-scale>0</column-scale>
    - *              <table-name/>
    - *              <catalog-name/>
    - *              <column-type>3</column-type>
    - *              <column-type-name>NUMBER</column-type-name>
    - *      </column-definition>
    - * </metadata>
    - * 
    + * {@code + * + * 2 + * + * 1 + * false + * true + * false + * 1 + * false + * true + * 10 + * COL1 + * COL1 + * + * 10 + * 0 + * + * + * 1 + * CHAR + * + * + * 2 + * false + * false + * false + * 1 + * true + * true + * 39 + * COL2 + * COL2 + * + * 38 + * 0 + * + * + * 3 + * NUMBER + * + * + * }
    * Having detailed how the properties and metadata are described, the following details - * how the contents of a WebRowSet object is described in XML. Note, that - * this describes a WebRowSet object that has not undergone any + * how the contents of a {@code WebRowSet} object is described in XML. Note, that + * this describes a {@code WebRowSet} object that has not undergone any * modifications since its instantiation. - * A currentRow tag is mapped to each row of the table structure that the - * WebRowSet object provides. A columnValue tag may contain - * either the stringData or binaryData tag, according to + * A {@code currentRow} tag is mapped to each row of the table structure that the + * {@code WebRowSet} object provides. A {@code columnValue} tag may contain + * either the {@code stringData} or {@code binaryData} tag, according to * the SQL type that - * the XML value is mapping back to. The binaryData tag contains data in the - * Base64 encoding and is typically used for BLOB and CLOB type data. + * the XML value is mapping back to. The {@code binaryData} tag contains data in the + * Base64 encoding and is typically used for {@code BLOB} and {@code CLOB} type data. *
    - * <data>
    - *      <currentRow>
    - *              <columnValue>
    + * {@code
    + * 
    + *      
    + *              
      *                      firstrow
    - *              </columnValue>
    - *              <columnValue>
    + *              
    + *              
      *                      1
    - *              </columnValue>
    - *      </currentRow>
    - *      <currentRow>
    - *              <columnValue>
    + *              
    + *      
    + *      
    + *              
      *                      secondrow
    - *              </columnValue>
    - *              <columnValue>
    + *              
    + *              
      *                      2
    - *              </columnValue>
    - *      </currentRow>
    - *      <currentRow>
    - *              <columnValue>
    + *              
    + *      
    + *      
    + *              
      *                      thirdrow
    - *              </columnValue>
    - *              <columnValue>
    + *              
    + *              
      *                      3
    - *              </columnValue>
    - *      </currentRow>
    - *      <currentRow>
    - *              <columnValue>
    + *              
    + *      
    + *      
    + *              
      *                      fourthrow
    - *              </columnValue>
    - *              <columnValue>
    + *              
    + *              
      *                      4
    - *              </columnValue>
    - *      </currentRow>
    - * </data>
    - * 
    + * + * + * + * } *

    2.2 State 2 - Deleting a Row

    - * Deleting a row in a WebRowSet object involves simply moving to the row - * to be deleted and then calling the method deleteRow, as in any other - * RowSet object. The following - * two lines of code, in which wrs is a WebRowSet object, delete + * Deleting a row in a {@code WebRowSet} object involves simply moving to the row + * to be deleted and then calling the method {@code deleteRow}, as in any other + * {@code RowSet} object. The following + * two lines of code, in which wrs is a {@code WebRowSet} object, delete * the third row. *
      *     wrs.absolute(3);
      *     wrs.deleteRow();
      * 
    - * The XML description shows the third row is marked as a deleteRow, - * which eliminates the third row in the WebRowSet object. + * The XML description shows the third row is marked as a {@code deleteRow}, + * which eliminates the third row in the {@code WebRowSet} object. *
    - * <data>
    - *      <currentRow>
    - *              <columnValue>
    + * {@code
    + * 
    + *      
    + *              
      *                      firstrow
    - *              </columnValue>
    - *              <columnValue>
    + *              
    + *              
      *                      1
    - *              </columnValue>
    - *      </currentRow>
    - *      <currentRow>
    - *              <columnValue>
    + *              
    + *      
    + *      
    + *              
      *                      secondrow
    - *              </columnValue>
    - *              <columnValue>
    + *              
    + *              
      *                      2
    - *              </columnValue>
    - *      </currentRow>
    - *      <deleteRow>
    - *              <columnValue>
    + *              
    + *      
    + *      
    + *              
      *                      thirdrow
    - *              </columnValue>
    - *              <columnValue>
    + *              
    + *              
      *                      3
    - *              </columnValue>
    - *      </deleteRow>
    - *      <currentRow>
    - *              <columnValue>
    + *              
    + *      
    + *      
    + *              
      *                      fourthrow
    - *              </columnValue>
    - *              <columnValue>
    + *              
    + *              
      *                      4
    - *              </columnValue>
    - *      </currentRow>
    - * </data>
    - * 
    + * + * + * + *} *

    2.3 State 3 - Inserting a Row

    - * A WebRowSet object can insert a new row by moving to the insert row, + * A {@code WebRowSet} object can insert a new row by moving to the insert row, * calling the appropriate updater methods for each column in the row, and then - * calling the method insertRow. + * calling the method {@code insertRow}. *
    + * {@code
      * wrs.moveToInsertRow();
      * wrs.updateString(1, "fifththrow");
      * wrs.updateString(2, "5");
      * wrs.insertRow();
    - * 
    + * } * The following code fragment changes the second column value in the row just inserted. * Note that this code applies when new rows are inserted right after the current row, - * which is why the method next moves the cursor to the correct row. - * Calling the method acceptChanges writes the change to the data source. + * which is why the method {@code next} moves the cursor to the correct row. + * Calling the method {@code acceptChanges} writes the change to the data source. * *
    - * wrs.moveToCurrentRow();
    + * {@code wrs.moveToCurrentRow();
      * wrs.next();
      * wrs.updateString(2, "V");
      * wrs.acceptChanges();
    - * :
    - * 
    + * } * Describing this in XML demonstrates where the Java code inserts a new row and then * performs an update on the newly inserted row on an individual field. *
    - * <data>
    - *      <currentRow>
    - *              <columnValue>
    + * {@code
    + * 
    + *      
    + *              
      *                      firstrow
    - *              </columnValue>
    - *              <columnValue>
    + *              
    + *              
      *                      1
    - *              </columnValue>
    - *      </currentRow>
    - *      <currentRow>
    - *              <columnValue>
    + *              
    + *      
    + *      
    + *              
      *                      secondrow
    - *              </columnValue>
    - *              <columnValue>
    + *              
    + *              
      *                      2
    - *              </columnValue>
    - *      </currentRow>
    - *      <currentRow>
    - *              <columnValue>
    + *              
    + *      
    + *      
    + *              
      *                      newthirdrow
    - *              </columnValue>
    - *              <columnValue>
    + *              
    + *              
      *                      III
    - *              </columnValue>
    - *      </currentRow>
    - *      <insertRow>
    - *              <columnValue>
    + *              
    + *      
    + *      
    + *              
      *                      fifthrow
    - *              </columnValue>
    - *              <columnValue>
    + *              
    + *              
      *                      5
    - *              </columnValue>
    - *              <updateValue>
    + *              
    + *              
      *                      V
    - *              </updateValue>
    - *      </insertRow>
    - *      <currentRow>
    - *              <columnValue>
    + *              
    + *      
    + *      
    + *              
      *                      fourthrow
    - *              </columnValue>
    - *              <columnValue>
    + *              
    + *              
      *                      4
    - *              </columnValue>
    - *      </currentRow>
    - * </date>
    - * 
    + * + * + * + *} *

    2.4 State 4 - Modifying a Row

    * Modifying a row produces specific XML that records both the new value and the * value that was replaced. The value that was replaced becomes the original value, @@ -340,63 +344,65 @@ import org.xml.sax.*; * code moves the cursor to a specific row, performs some modifications, and updates * the row when complete. *
    + *{@code
      * wrs.absolute(5);
      * wrs.updateString(1, "new4thRow");
      * wrs.updateString(2, "IV");
      * wrs.updateRow();
    - * 
    - * In XML, this is described by the modifyRow tag. Both the original and new + * } + * In XML, this is described by the {@code modifyRow} tag. Both the original and new * values are contained within the tag for original row tracking purposes. *
    - * <data>
    - *      <currentRow>
    - *              <columnValue>
    + * {@code
    + * 
    + *      
    + *              
      *                      firstrow
    - *              </columnValue>
    - *              <columnValue>
    + *              
    + *              
      *                      1
    - *              </columnValue>
    - *      </currentRow>
    - *      <currentRow>
    - *              <columnValue>
    + *              
    + *      
    + *      
    + *              
      *                      secondrow
    - *              </columnValue>
    - *              <columnValue>
    + *              
    + *              
      *                      2
    - *              </columnValue>
    - *      </currentRow>
    - *      <currentRow>
    - *              <columnValue>
    + *              
    + *      
    + *      
    + *              
      *                      newthirdrow
    - *              </columnValue>
    - *              <columnValue>
    + *              
    + *              
      *                      III
    - *              </columnValue>
    - *      </currentRow>
    - *      <currentRow>
    - *              <columnValue>
    + *              
    + *      
    + *      
    + *              
      *                      fifthrow
    - *              </columnValue>
    - *              <columnValue>
    + *              
    + *              
      *                      5
    - *              </columnValue>
    - *      </currentRow>
    - *      <modifyRow>
    - *              <columnValue>
    + *              
    + *      
    + *      
    + *              
      *                      fourthrow
    - *              </columnValue>
    - *              <updateValue>
    + *              
    + *              
      *                      new4thRow
    - *              </updateValue>
    - *              <columnValue>
    + *              
    + *              
      *                      4
    - *              </columnValue>
    - *              <updateValue>
    + *              
    + *              
      *                      IV
    - *              </updateValue>
    - *      </modifyRow>
    - * </data>
    - * 
    + * + * + * + * } * * @see javax.sql.rowset.JdbcRowSet * @see javax.sql.rowset.CachedRowSet @@ -407,78 +413,78 @@ import org.xml.sax.*; public interface WebRowSet extends CachedRowSet { /** - * Reads a WebRowSet object in its XML format from the given - * Reader object. + * Reads a {@code WebRowSet} object in its XML format from the given + * {@code Reader} object. * - * @param reader the java.io.Reader stream from which this - * WebRowSet object will be populated + * @param reader the {@code java.io.Reader} stream from which this + * {@code WebRowSet} object will be populated * @throws SQLException if a database access error occurs */ public void readXml(java.io.Reader reader) throws SQLException; /** - * Reads a stream based XML input to populate this WebRowSet + * Reads a stream based XML input to populate this {@code WebRowSet} * object. * - * @param iStream the java.io.InputStream from which this - * WebRowSet object will be populated + * @param iStream the {@code java.io.InputStream} from which this + * {@code WebRowSet} object will be populated * @throws SQLException if a data source access error occurs * @throws IOException if an IO exception occurs */ public void readXml(java.io.InputStream iStream) throws SQLException, IOException; /** - * Populates this WebRowSet object with - * the contents of the given ResultSet object and writes its + * Populates this {@code WebRowSet} object with + * the contents of the given {@code ResultSet} object and writes its * data, properties, and metadata - * to the given Writer object in XML format. + * to the given {@code Writer} object in XML format. *

    - * NOTE: The WebRowSet cursor may be moved to write out the + * NOTE: The {@code WebRowSet} cursor may be moved to write out the * contents to the XML data source. If implemented in this way, the cursor must - * be returned to its position just prior to the writeXml() call. + * be returned to its position just prior to the {@code writeXml()} call. * - * @param rs the ResultSet object with which to populate this - * WebRowSet object - * @param writer the java.io.Writer object to write to. + * @param rs the {@code ResultSet} object with which to populate this + * {@code WebRowSet} object + * @param writer the {@code java.io.Writer} object to write to. * @throws SQLException if an error occurs writing out the rowset * contents in XML format */ public void writeXml(ResultSet rs, java.io.Writer writer) throws SQLException; /** - * Populates this WebRowSet object with - * the contents of the given ResultSet object and writes its + * Populates this {@code WebRowSet} object with + * the contents of the given {@code ResultSet} object and writes its * data, properties, and metadata - * to the given OutputStream object in XML format. + * to the given {@code OutputStream} object in XML format. *

    - * NOTE: The WebRowSet cursor may be moved to write out the + * NOTE: The {@code WebRowSet} cursor may be moved to write out the * contents to the XML data source. If implemented in this way, the cursor must - * be returned to its position just prior to the writeXml() call. + * be returned to its position just prior to the {@code writeXml()} call. * - * @param rs the ResultSet object with which to populate this - * WebRowSet object - * @param oStream the java.io.OutputStream to write to + * @param rs the {@code ResultSet} object with which to populate this + * {@code WebRowSet} object + * @param oStream the {@code java.io.OutputStream} to write to * @throws SQLException if a data source access error occurs * @throws IOException if a IO exception occurs */ public void writeXml(ResultSet rs, java.io.OutputStream oStream) throws SQLException, IOException; /** - * Writes the data, properties, and metadata for this WebRowSet object - * to the given Writer object in XML format. + * Writes the data, properties, and metadata for this {@code WebRowSet} object + * to the given {@code Writer} object in XML format. * - * @param writer the java.io.Writer stream to write to + * @param writer the {@code java.io.Writer} stream to write to * @throws SQLException if an error occurs writing out the rowset * contents to XML */ public void writeXml(java.io.Writer writer) throws SQLException; /** - * Writes the data, properties, and metadata for this WebRowSet object - * to the given OutputStream object in XML format. + * Writes the data, properties, and metadata for this {@code WebRowSet} object + * to the given {@code OutputStream} object in XML format. * - * @param oStream the java.io.OutputStream stream to write to + * @param oStream the {@code java.io.OutputStream} stream to write to * @throws SQLException if a data source access error occurs * @throws IOException if a IO exception occurs */ @@ -486,14 +492,14 @@ public interface WebRowSet extends CachedRowSet { /** * The public identifier for the XML Schema definition that defines the XML - * tags and their valid values for a WebRowSet implementation. + * tags and their valid values for a {@code WebRowSet} implementation. */ public static String PUBLIC_XML_SCHEMA = "--//Oracle Corporation//XSD Schema//EN"; /** * The URL for the XML Schema definition file that defines the XML tags and - * their valid values for a WebRowSet implementation. + * their valid values for a {@code WebRowSet} implementation. */ public static String SCHEMA_SYSTEM_ID = "http://java.sun.com/xml/ns/jdbc/webrowset.xsd"; } diff --git a/jdk/src/share/classes/javax/sql/rowset/package.html b/jdk/src/share/classes/javax/sql/rowset/package.html index 61073131eec..e8b494ee744 100644 --- a/jdk/src/share/classes/javax/sql/rowset/package.html +++ b/jdk/src/share/classes/javax/sql/rowset/package.html @@ -67,7 +67,7 @@ interfaces.

    • JdbcRowSet - A wrapper around a ResultSet object that makes it possible to use the result set as a -JavaBeansTM component. Thus, +JavaBeans™ component. Thus, a JdbcRowSet object can be a Bean that any tool makes available for assembling an application as part of a component based architecture . A JdbcRowSet object is a connected RowSet @@ -79,7 +79,7 @@ data structure as defined in the JDBC 3.0 specification.

    • CachedRowSet - - A CachedRowSet object is a JavaBeansTM + - A CachedRowSet object is a JavaBeans™ component that is scrollable, updatable, serializable, and generally disconnected from the source of its data. A CachedRowSet object typically contains rows from a result set, but it can also contain rows from any diff --git a/jdk/src/share/classes/javax/sql/rowset/serial/SerialArray.java b/jdk/src/share/classes/javax/sql/rowset/serial/SerialArray.java index 3d3926cb83c..1e0e440bcef 100644 --- a/jdk/src/share/classes/javax/sql/rowset/serial/SerialArray.java +++ b/jdk/src/share/classes/javax/sql/rowset/serial/SerialArray.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -50,7 +50,7 @@ import java.util.Arrays; * if necessary. At this time, logical pointers to the data in the data source, * such as locators, are not currently supported. * - *

      Thread safety

      + *

      Thread safety

      * * A SerialArray is not safe for use by multiple concurrent threads. If a * SerialArray is to be used by more than one thread then access to the diff --git a/jdk/src/share/classes/javax/sql/rowset/serial/SerialBlob.java b/jdk/src/share/classes/javax/sql/rowset/serial/SerialBlob.java index e7bdbcf87e0..4c5a6b867a9 100644 --- a/jdk/src/share/classes/javax/sql/rowset/serial/SerialBlob.java +++ b/jdk/src/share/classes/javax/sql/rowset/serial/SerialBlob.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -51,7 +51,7 @@ import java.util.Arrays; * Blob object within a SerialBlob object * and to update or truncate a Blob object. * - *

      Thread safety

      + *

      Thread safety

      * *

      A SerialBlob is not safe for use by multiple concurrent threads. If a * SerialBlob is to be used by more than one thread then access to the SerialBlob diff --git a/jdk/src/share/classes/javax/sql/rowset/serial/SerialClob.java b/jdk/src/share/classes/javax/sql/rowset/serial/SerialClob.java index 5ea5fee14bc..a2177b2c153 100644 --- a/jdk/src/share/classes/javax/sql/rowset/serial/SerialClob.java +++ b/jdk/src/share/classes/javax/sql/rowset/serial/SerialClob.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -44,7 +44,7 @@ import java.util.Arrays; * from a SerialClob object or to locate the start of * a pattern of characters. * - *

      Thread safety

      + *

      Thread safety

      * *

      A SerialClob is not safe for use by multiple concurrent threads. If a * SerialClob is to be used by more than one thread then access to the SerialClob diff --git a/jdk/src/share/classes/javax/sql/rowset/serial/SerialDatalink.java b/jdk/src/share/classes/javax/sql/rowset/serial/SerialDatalink.java index 4cfcfb1155a..ad053bcdec9 100644 --- a/jdk/src/share/classes/javax/sql/rowset/serial/SerialDatalink.java +++ b/jdk/src/share/classes/javax/sql/rowset/serial/SerialDatalink.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -43,7 +43,7 @@ import java.net.URL; * java.net.URL url = rowset.getURL(1); * * - *

      Thread safety

      + *

      Thread safety

      * * A SerialDatalink is not safe for use by multiple concurrent threads. If a * SerialDatalink is to be used by more than one thread then access to the @@ -77,6 +77,7 @@ public class SerialDatalink implements Serializable, Cloneable { * Constructs a new SerialDatalink object from the given * java.net.URL object. *

      + * @param url the {@code URL} to create the {@code SerialDataLink} from * @throws SerialException if url parameter is a null */ public SerialDatalink(URL url) throws SerialException { diff --git a/jdk/src/share/classes/javax/sql/rowset/serial/SerialJavaObject.java b/jdk/src/share/classes/javax/sql/rowset/serial/SerialJavaObject.java index 985ef400591..4a9ce17b4c8 100644 --- a/jdk/src/share/classes/javax/sql/rowset/serial/SerialJavaObject.java +++ b/jdk/src/share/classes/javax/sql/rowset/serial/SerialJavaObject.java @@ -47,7 +47,7 @@ import sun.reflect.misc.ReflectUtil; * Static or transient fields cannot be serialized; an attempt to serialize * them will result in a SerialException object being thrown. * - *

      Thread safety

      + *

      Thread safety

      * * A SerialJavaObject is not safe for use by multiple concurrent threads. If a * SerialJavaObject is to be used by more than one thread then access to the diff --git a/jdk/src/share/classes/javax/sql/rowset/serial/SerialRef.java b/jdk/src/share/classes/javax/sql/rowset/serial/SerialRef.java index 84009fac6cb..834fafe32b6 100644 --- a/jdk/src/share/classes/javax/sql/rowset/serial/SerialRef.java +++ b/jdk/src/share/classes/javax/sql/rowset/serial/SerialRef.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -37,7 +37,7 @@ import java.util.*; * creating a SerialRef instance from a Ref * object and provides methods for getting and setting the Ref object. * - *

      Thread safety

      + *

      Thread safety

      * * A SerialRef is not safe for use by multiple concurrent threads. If a * SerialRef is to be used by more than one thread then access to the SerialRef diff --git a/jdk/src/share/classes/javax/sql/rowset/serial/SerialStruct.java b/jdk/src/share/classes/javax/sql/rowset/serial/SerialStruct.java index 2fe11996eb7..6eef84f3ef9 100644 --- a/jdk/src/share/classes/javax/sql/rowset/serial/SerialStruct.java +++ b/jdk/src/share/classes/javax/sql/rowset/serial/SerialStruct.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -51,7 +51,7 @@ import javax.sql.rowset.*; * the SQL type name of the SQL structured type in the database, and methods * for retrieving its attribute values. * - *

      Thread safety

      + *

      Thread safety

      * * A SerialStruct is not safe for use by multiple concurrent threads. If a * SerialStruct is to be used by more than one thread then access to the diff --git a/jdk/src/share/classes/javax/sql/rowset/spi/SyncFactory.java b/jdk/src/share/classes/javax/sql/rowset/spi/SyncFactory.java index e9b10bdcbfb..6797dc0d397 100644 --- a/jdk/src/share/classes/javax/sql/rowset/spi/SyncFactory.java +++ b/jdk/src/share/classes/javax/sql/rowset/spi/SyncFactory.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -260,13 +260,14 @@ public class SyncFactory { *

      * Synchronization providers bound to a JNDI context can be * registered by binding a SyncProvider instance to a JNDI namespace. - *

        + * *
        +     * {@code
              * SyncProvider p = new MySyncProvider();
              * InitialContext ic = new InitialContext();
              * ic.bind ("jdbc/rowset/MySyncProvider", p);
        -     * 
        - *
      + * } + * * Furthermore, an initial JNDI context should be set with the * SyncFactory using the setJNDIContext method. * The SyncFactory leverages this context to search for @@ -564,6 +565,8 @@ public class SyncFactory { * * @return Enumeration A enumeration of available synchronization * providers that are registered with this Factory + * @throws SyncFactoryException If an error occurs obtaining the registered + * providers */ public static Enumeration getRegisteredProviders() throws SyncFactoryException { @@ -648,7 +651,8 @@ public class SyncFactory { /** * Returns the logging object for applications to retrieve * synchronization events posted by SyncProvider implementations. - * + * @return The {@code Logger} that has been specified for use by + * {@code SyncProvider} implementations * @throws SyncFactoryException if no logging object has been set. */ public static Logger getLogger() throws SyncFactoryException { diff --git a/jdk/src/share/classes/javax/sql/rowset/spi/SyncResolver.java b/jdk/src/share/classes/javax/sql/rowset/spi/SyncResolver.java index c1180cf9251..71f463fef2f 100644 --- a/jdk/src/share/classes/javax/sql/rowset/spi/SyncResolver.java +++ b/jdk/src/share/classes/javax/sql/rowset/spi/SyncResolver.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2004, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -81,10 +81,13 @@ import java.sql.SQLException; * SyncProviderException method getSyncResolver to get * the SyncResolver object resolver. *
      + * {@code
        *     } catch (SyncProviderException spe) {
        *         SyncResolver resolver = spe.getSyncResolver();
        *     ...
        *     }
      + *
      + * }
        * 
      *

      * With resolver in hand, an application can use it to get the information @@ -97,7 +100,7 @@ import java.sql.SQLException; * The following kinds of information can be obtained from a SyncResolver * object: *

      - *

    • What operation was being attempted when a conflict occurred
      + *

      What operation was being attempted when a conflict occurred

      * The SyncProvider interface defines four constants * describing states that may occur. Three * constants describe the type of operation (update, delete, or insert) that a @@ -106,10 +109,10 @@ import java.sql.SQLException; * These constants are the possible return values when a SyncResolver object * calls the method getStatus. *
      - *     int operation = resolver.getStatus();
      + *     {@code int operation = resolver.getStatus(); }
        * 
      *

      - *

    • The value in the data source that caused a conflict
      + *

      The value in the data source that caused a conflict

      * A conflict exists when a value that a RowSet object has changed * and is attempting to write to the data source * has also been changed in the data source since the last synchronization. An @@ -122,7 +125,6 @@ import java.sql.SQLException; * * Note that the column in resolver can be designated by the column number, * as is done in the preceding line of code, or by the column name. - *
    *

    * With the information retrieved from the methods getStatus and * getConflictValue, the application may make a determination as to @@ -193,7 +195,8 @@ import java.sql.SQLException; * code fragment, the value in crs is the one set as the resolved value, which means * that it will be used to overwrite the conflict value in the data source. * - *

    {@code
    + * 
    + * {@code
      *     try {
      *
      *         crs.acceptChanges(con);
    
    From a8bb269e470ece77ebca9b5678e5668141f75992 Mon Sep 17 00:00:00 2001
    From: Joe Darcy 
    Date: Thu, 27 Jun 2013 12:24:26 -0700
    Subject: [PATCH 037/127] 8019315: Fix doclint issues in java.util.logging
    
    Reviewed-by: lancea
    ---
     jdk/src/share/classes/java/util/logging/Handler.java    | 3 ++-
     jdk/src/share/classes/java/util/logging/LogManager.java | 3 ++-
     jdk/src/share/classes/java/util/logging/LogRecord.java  | 5 ++++-
     3 files changed, 8 insertions(+), 3 deletions(-)
    
    diff --git a/jdk/src/share/classes/java/util/logging/Handler.java b/jdk/src/share/classes/java/util/logging/Handler.java
    index c44dafbb7ba..a8c3eb4b036 100644
    --- a/jdk/src/share/classes/java/util/logging/Handler.java
    +++ b/jdk/src/share/classes/java/util/logging/Handler.java
    @@ -1,5 +1,5 @@
     /*
    - * Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved.
    + * Copyright (c) 2000, 2013, 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
    @@ -209,6 +209,7 @@ public abstract class Handler {
         /**
          * Retrieves the ErrorManager for this Handler.
          *
    +     * @return the ErrorManager for this Handler
          * @exception  SecurityException  if a security manager exists and if
          *             the caller does not have LoggingPermission("control").
          */
    diff --git a/jdk/src/share/classes/java/util/logging/LogManager.java b/jdk/src/share/classes/java/util/logging/LogManager.java
    index deed5574d2a..6ecfe69a981 100644
    --- a/jdk/src/share/classes/java/util/logging/LogManager.java
    +++ b/jdk/src/share/classes/java/util/logging/LogManager.java
    @@ -257,7 +257,8 @@ public class LogManager {
         }
     
         /**
    -     * Return the global LogManager object.
    +     * Returns the global LogManager object.
    +     * @return the global LogManager object
          */
         public static LogManager getLogManager() {
             if (manager != null) {
    diff --git a/jdk/src/share/classes/java/util/logging/LogRecord.java b/jdk/src/share/classes/java/util/logging/LogRecord.java
    index 93540d9a009..50444f1cd8a 100644
    --- a/jdk/src/share/classes/java/util/logging/LogRecord.java
    +++ b/jdk/src/share/classes/java/util/logging/LogRecord.java
    @@ -1,5 +1,5 @@
     /*
    - * Copyright (c) 2000, 2010, Oracle and/or its affiliates. All rights reserved.
    + * Copyright (c) 2000, 2013, 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
    @@ -211,6 +211,7 @@ public class LogRecord implements java.io.Serializable {
          * the message string before formatting it.  The result may
          * be null if the message is not localizable, or if no suitable
          * ResourceBundle is available.
    +     * @return the localization resource bundle
          */
         public ResourceBundle getResourceBundle() {
             return resourceBundle;
    @@ -231,6 +232,7 @@ public class LogRecord implements java.io.Serializable {
          * This is the name for the ResourceBundle that should be
          * used to localize the message string before formatting it.
          * The result may be null if the message is not localizable.
    +     * @return the localization resource bundle name
          */
         public String getResourceBundleName() {
             return resourceBundleName;
    @@ -281,6 +283,7 @@ public class LogRecord implements java.io.Serializable {
          * 

    * Sequence numbers are normally assigned in the LogRecord constructor, * so it should not normally be necessary to use this method. + * @param seq the sequence number */ public void setSequenceNumber(long seq) { sequenceNumber = seq; From c421a2d9b7482ddaf886152a60887ccb88095305 Mon Sep 17 00:00:00 2001 From: Stuart Marks Date: Thu, 27 Jun 2013 13:35:01 -0700 Subject: [PATCH 038/127] 8019224: add exception chaining to RMI CGIHandler Reviewed-by: darcy --- .../sun/rmi/transport/proxy/CGIHandler.java | 31 +++++++++++++------ 1 file changed, 21 insertions(+), 10 deletions(-) diff --git a/jdk/src/share/classes/sun/rmi/transport/proxy/CGIHandler.java b/jdk/src/share/classes/sun/rmi/transport/proxy/CGIHandler.java index a60b23864af..657683cd6f8 100644 --- a/jdk/src/share/classes/sun/rmi/transport/proxy/CGIHandler.java +++ b/jdk/src/share/classes/sun/rmi/transport/proxy/CGIHandler.java @@ -38,6 +38,10 @@ class CGIClientException extends Exception { public CGIClientException(String s) { super(s); } + + public CGIClientException(String s, Throwable cause) { + super(s, cause); + } } /** @@ -50,6 +54,10 @@ class CGIServerException extends Exception { public CGIServerException(String s) { super(s); } + + public CGIServerException(String s, Throwable cause) { + super(s, cause); + } } /** @@ -148,13 +156,16 @@ public final class CGIHandler { try { handler.execute(param); } catch (CGIClientException e) { + e.printStackTrace(); returnClientError(e.getMessage()); } catch (CGIServerException e) { + e.printStackTrace(); returnServerError(e.getMessage()); } else returnClientError("invalid command."); } catch (Exception e) { + e.printStackTrace(); returnServerError("internal error: " + e.getMessage()); } System.exit(0); @@ -225,7 +236,7 @@ final class CGIForwardCommand implements CGICommandHandler { try { port = Integer.parseInt(param); } catch (NumberFormatException e) { - throw new CGIClientException("invalid port number."); + throw new CGIClientException("invalid port number.", e); } if (port <= 0 || port > 0xFFFF) throw new CGIClientException("invalid port: " + port); @@ -238,7 +249,7 @@ final class CGIForwardCommand implements CGICommandHandler { try { socket = new Socket(InetAddress.getLocalHost(), port); } catch (IOException e) { - throw new CGIServerException("could not connect to local port"); + throw new CGIServerException("could not connect to local port", e); } /* @@ -249,9 +260,9 @@ final class CGIForwardCommand implements CGICommandHandler { try { clientIn.readFully(buffer); } catch (EOFException e) { - throw new CGIClientException("unexpected EOF reading request body"); + throw new CGIClientException("unexpected EOF reading request body", e); } catch (IOException e) { - throw new CGIClientException("error reading request body"); + throw new CGIClientException("error reading request body", e); } /* @@ -266,7 +277,7 @@ final class CGIForwardCommand implements CGICommandHandler { socketOut.write(buffer); socketOut.flush(); } catch (IOException e) { - throw new CGIServerException("error writing to server"); + throw new CGIServerException("error writing to server", e); } /* @@ -276,7 +287,7 @@ final class CGIForwardCommand implements CGICommandHandler { try { socketIn = new DataInputStream(socket.getInputStream()); } catch (IOException e) { - throw new CGIServerException("error reading from server"); + throw new CGIServerException("error reading from server", e); } String key = "Content-length:".toLowerCase(); boolean contentLengthFound = false; @@ -286,7 +297,7 @@ final class CGIForwardCommand implements CGICommandHandler { try { line = getLine(socketIn); } catch (IOException e) { - throw new CGIServerException("error reading from server"); + throw new CGIServerException("error reading from server", e); } if (line == null) throw new CGIServerException( @@ -313,9 +324,9 @@ final class CGIForwardCommand implements CGICommandHandler { socketIn.readFully(buffer); } catch (EOFException e) { throw new CGIServerException( - "unexpected EOF reading server response"); + "unexpected EOF reading server response", e); } catch (IOException e) { - throw new CGIServerException("error reading from server"); + throw new CGIServerException("error reading from server", e); } /* @@ -327,7 +338,7 @@ final class CGIForwardCommand implements CGICommandHandler { try { System.out.write(buffer); } catch (IOException e) { - throw new CGIServerException("error writing response"); + throw new CGIServerException("error writing response", e); } System.out.flush(); } From ff500d62010352b7d306aa3e3c9d48290bbb4cea Mon Sep 17 00:00:00 2001 From: Joe Darcy Date: Thu, 27 Jun 2013 14:11:25 -0700 Subject: [PATCH 039/127] 8019320: Fix doclint issues in javax.script Reviewed-by: lancea --- jdk/src/share/classes/javax/script/Invocable.java | 5 ++++- jdk/src/share/classes/javax/script/ScriptContext.java | 3 ++- jdk/src/share/classes/javax/script/ScriptEngineFactory.java | 3 ++- jdk/src/share/classes/javax/script/SimpleScriptContext.java | 6 ++++-- 4 files changed, 12 insertions(+), 5 deletions(-) diff --git a/jdk/src/share/classes/javax/script/Invocable.java b/jdk/src/share/classes/javax/script/Invocable.java index e0b1bc78048..81d363c01e9 100644 --- a/jdk/src/share/classes/javax/script/Invocable.java +++ b/jdk/src/share/classes/javax/script/Invocable.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2006, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2013, 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,6 +63,7 @@ public interface Invocable { /** * Used to call top-level procedures and functions defined in scripts. * + * @param name of the procedure or function to call * @param args Arguments to pass to the procedure or function * @return The value returned by the procedure or function * @@ -79,6 +80,7 @@ public interface Invocable { * the interpreter. The methods of the interface * may be implemented using the invokeFunction method. * + * @param the type of the interface to return * @param clasz The Class object of the interface to return. * * @return An instance of requested interface - null if the requested interface is unavailable, @@ -95,6 +97,7 @@ public interface Invocable { * a scripting object compiled in the interpreter. The methods of the * interface may be implemented using the invokeMethod method. * + * @param the type of the interface to return * @param thiz The scripting object whose member functions are used to implement the methods of the interface. * @param clasz The Class object of the interface to return. * diff --git a/jdk/src/share/classes/javax/script/ScriptContext.java b/jdk/src/share/classes/javax/script/ScriptContext.java index 78247bb7436..8d1076b6d9f 100644 --- a/jdk/src/share/classes/javax/script/ScriptContext.java +++ b/jdk/src/share/classes/javax/script/ScriptContext.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2013, 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 @@ -78,6 +78,7 @@ public interface ScriptContext { * @return The associated Bindings. Returns null if it has not * been set. * + * @param scope The scope * @throws IllegalArgumentException If no Bindings is defined for the * specified scope value in ScriptContext of this type. */ diff --git a/jdk/src/share/classes/javax/script/ScriptEngineFactory.java b/jdk/src/share/classes/javax/script/ScriptEngineFactory.java index ca22d163590..298b4ad7b41 100644 --- a/jdk/src/share/classes/javax/script/ScriptEngineFactory.java +++ b/jdk/src/share/classes/javax/script/ScriptEngineFactory.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2013, 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 @@ -80,6 +80,7 @@ public interface ScriptEngineFactory { * identify the ScriptEngine by the ScriptEngineManager. * For instance, an implementation based on the Mozilla Rhino Javascript engine might * return list containing {"javascript", "rhino"}. + * @return an immutable list of short names */ public List getNames(); diff --git a/jdk/src/share/classes/javax/script/SimpleScriptContext.java b/jdk/src/share/classes/javax/script/SimpleScriptContext.java index 98f8c81d5e3..a5bf12f9a22 100644 --- a/jdk/src/share/classes/javax/script/SimpleScriptContext.java +++ b/jdk/src/share/classes/javax/script/SimpleScriptContext.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2006, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2013, 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 @@ -82,7 +82,9 @@ public class SimpleScriptContext implements ScriptContext { */ protected Bindings globalScope; - + /** + * Create a {@code SimpleScriptContext}. + */ public SimpleScriptContext() { engineScope = new SimpleBindings(); globalScope = null; From eb278c1a275bdf7245fb567bae4cd03f32333bae Mon Sep 17 00:00:00 2001 From: Naoto Sato Date: Thu, 27 Jun 2013 14:40:21 -0700 Subject: [PATCH 040/127] 6609431: (rb) ResourceBundle.getString() returns incorrect value Reviewed-by: okutsu, sherman --- .../share/classes/java/util/Properties.java | 8 ++- jdk/test/java/util/Properties/Bug6609431.java | 53 +++++++++++++++++++ .../util/Properties/Bug6609431.properties | 24 +++++++++ 3 files changed, 84 insertions(+), 1 deletion(-) create mode 100644 jdk/test/java/util/Properties/Bug6609431.java create mode 100644 jdk/test/java/util/Properties/Bug6609431.properties diff --git a/jdk/src/share/classes/java/util/Properties.java b/jdk/src/share/classes/java/util/Properties.java index 3e899d00113..ed0bf857d66 100644 --- a/jdk/src/share/classes/java/util/Properties.java +++ b/jdk/src/share/classes/java/util/Properties.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1995, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1995, 2013, 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 @@ -443,6 +443,9 @@ class Properties extends Hashtable { if (len == 0 || isCommentLine) { return -1; } + if (precedingBackslash) { + len--; + } return len; } } @@ -510,6 +513,9 @@ class Properties extends Hashtable { :inStream.read(inByteBuf); inOff = 0; if (inLimit <= 0) { + if (precedingBackslash) { + len--; + } return len; } } diff --git a/jdk/test/java/util/Properties/Bug6609431.java b/jdk/test/java/util/Properties/Bug6609431.java new file mode 100644 index 00000000000..a1232f1fd43 --- /dev/null +++ b/jdk/test/java/util/Properties/Bug6609431.java @@ -0,0 +1,53 @@ +/* + * Copyright (c) 2013, 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 + * @bug 6609431 + * @summary Test whether loading of a property value in a file ending with + * a backslash works fine. + */ + +import java.io.File; +import java.io.FileReader; +import java.io.IOException; +import java.util.Properties; + +public class Bug6609431 { + private static final String expected = "backslash"; + + public static void main(String[] args) throws IOException { + try (FileReader fr = + new FileReader(new File(System.getProperty("test.src", "."), + "Bug6609431.properties"))) { + Properties p = new Properties(); + p.load(fr); + p.getProperty("a"); + String val = p.getProperty("b"); + if (!val.equals(expected)) { + throw new RuntimeException("Value returned from the property" + + " list was incorrect. Returned: '" + val + + "', expected: '" + expected + "'"); + } + } + } +} diff --git a/jdk/test/java/util/Properties/Bug6609431.properties b/jdk/test/java/util/Properties/Bug6609431.properties new file mode 100644 index 00000000000..59f35f43823 --- /dev/null +++ b/jdk/test/java/util/Properties/Bug6609431.properties @@ -0,0 +1,24 @@ +# +# Copyright (c) 2013, 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. +# +a=backslashbackslash +b=backslash\ From 0e32f67d9590ff6d625ffc20a84214039b700efe Mon Sep 17 00:00:00 2001 From: Joe Darcy Date: Thu, 27 Jun 2013 19:02:02 -0700 Subject: [PATCH 041/127] 8019357: Fix doclint warnings in java.lang.invoke Reviewed-by: jrose --- .../invoke/LambdaConversionException.java | 26 ++++++- .../java/lang/invoke/LambdaMetafactory.java | 8 +- .../java/lang/invoke/MethodHandle.java | 39 +++++++--- .../java/lang/invoke/MethodHandleProxies.java | 3 +- .../java/lang/invoke/MethodHandles.java | 77 +++++++++++-------- .../classes/java/lang/invoke/MethodType.java | 18 ++++- .../java/lang/invoke/MutableCallSite.java | 2 +- .../java/lang/invoke/SerializedLambda.java | 77 +++++++++++++++---- .../java/lang/invoke/package-info.java | 8 +- 9 files changed, 186 insertions(+), 72 deletions(-) diff --git a/jdk/src/share/classes/java/lang/invoke/LambdaConversionException.java b/jdk/src/share/classes/java/lang/invoke/LambdaConversionException.java index 11ffb580ea9..5cc3c626e36 100644 --- a/jdk/src/share/classes/java/lang/invoke/LambdaConversionException.java +++ b/jdk/src/share/classes/java/lang/invoke/LambdaConversionException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2013, 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 @@ -29,21 +29,45 @@ package java.lang.invoke; * LambdaConversionException */ public class LambdaConversionException extends Exception { + /** + * Constructs a {@code LambdaConversionException}. + */ public LambdaConversionException() { } + /** + * Constructs a {@code LambdaConversionException} with a message. + * @param message the detail message + */ public LambdaConversionException(String message) { super(message); } + /** + * Constructs a {@code LambdaConversionException} with a message and cause. + * @param message the detail message + * @param cause the cause + */ public LambdaConversionException(String message, Throwable cause) { super(message, cause); } + /** + * Constructs a {@code LambdaConversionException} with a cause. + * @param cause the cause + */ public LambdaConversionException(Throwable cause) { super(cause); } + /** + * Constructs a {@code LambdaConversionException} with a message, + * cause, and other settings. + * @param message the detail message + * @param cause the cause + * @param enableSuppression whether or not suppressed exceptions are enabled + * @param writableStackTrace whether or not the stack trace is writable + */ public LambdaConversionException(String message, Throwable cause, boolean enableSuppression, boolean writableStackTrace) { super(message, cause, enableSuppression, writableStackTrace); } diff --git a/jdk/src/share/classes/java/lang/invoke/LambdaMetafactory.java b/jdk/src/share/classes/java/lang/invoke/LambdaMetafactory.java index d179d438e8a..e03dda002d1 100644 --- a/jdk/src/share/classes/java/lang/invoke/LambdaMetafactory.java +++ b/jdk/src/share/classes/java/lang/invoke/LambdaMetafactory.java @@ -111,7 +111,7 @@ package java.lang.invoke; * done on return type, while a strict version is applied to arguments. * *

    A type Q is considered adaptable to S as follows: - * + *
    * * * @@ -155,7 +155,7 @@ public class LambdaMetafactory { private static final Class[] EMPTY_CLASS_ARRAY = new Class[0]; -/** + /** * Standard meta-factory for conversion of lambda expressions or method references to functional interfaces. * * @param caller Stacked automatically by VM; represents a lookup context with the accessibility privileges @@ -174,7 +174,7 @@ public class LambdaMetafactory { * @param instantiatedMethodType The signature of the primary functional interface method after type variables * are substituted with their instantiation from the capture site * @return a CallSite, which, when invoked, will return an instance of the functional interface - * @throws ReflectiveOperationException + * @throws ReflectiveOperationException if the caller is not able to reconstruct one of the method handles * @throws LambdaConversionException If any of the meta-factory protocol invariants are violated */ public static CallSite metaFactory(MethodHandles.Lookup caller, @@ -226,7 +226,7 @@ public class LambdaMetafactory { * the first argument in the invocation signature will correspond to the receiver. * @param args argument to pass, flags, marker interface count, and marker interfaces as described above * @return a CallSite, which, when invoked, will return an instance of the functional interface - * @throws ReflectiveOperationException + * @throws ReflectiveOperationException if the caller is not able to reconstruct one of the method handles * @throws LambdaConversionException If any of the meta-factory protocol invariants are violated */ public static CallSite altMetaFactory(MethodHandles.Lookup caller, diff --git a/jdk/src/share/classes/java/lang/invoke/MethodHandle.java b/jdk/src/share/classes/java/lang/invoke/MethodHandle.java index 06084056fb4..df784d35e5b 100644 --- a/jdk/src/share/classes/java/lang/invoke/MethodHandle.java +++ b/jdk/src/share/classes/java/lang/invoke/MethodHandle.java @@ -44,7 +44,7 @@ import java.util.logging.Logger; * {@linkplain java.lang.invoke.MethodHandles#dropArguments deletion}, * and {@linkplain java.lang.invoke.MethodHandles#filterArguments substitution}. * - *

    Method handle contents

    + *

    Method handle contents

    * Method handles are dynamically and strongly typed according to their parameter and return types. * They are not distinguished by the name or the defining class of their underlying methods. * A method handle must be invoked using a symbolic type descriptor which matches @@ -81,7 +81,7 @@ import java.util.logging.Logger; * from its specific class, as the method handle class hierarchy (if any) * may change from time to time or across implementations from different vendors. * - *

    Method handle compilation

    + *

    Method handle compilation

    * A Java method call expression naming {@code invokeExact} or {@code invoke} * can invoke a method handle from Java source code. * From the viewpoint of source code, these methods can take any arguments @@ -111,7 +111,7 @@ import java.util.logging.Logger; * The ambiguity with the type {@code Void} is harmless, since there are no references of type * {@code Void} except the null reference. * - *

    Method handle invocation

    + *

    Method handle invocation

    * The first time a {@code invokevirtual} instruction is executed * it is linked, by symbolically resolving the names in the instruction * and verifying that the method call is statically legal. @@ -154,7 +154,7 @@ import java.util.logging.Logger; * (Note: The adjusted method handle {@code M2} is not directly observable, * and implementations are therefore not required to materialize it.) * - *

    Invocation checking

    + *

    Invocation checking

    * In typical programs, method handle type matching will usually succeed. * But if a match fails, the JVM will throw a {@link WrongMethodTypeException}, * either directly (in the case of {@code invokeExact}) or indirectly as if @@ -195,7 +195,7 @@ import java.util.logging.Logger; * They should not be passed to untrusted code unless their use from * the untrusted code would be harmless. * - *

    Method handle creation

    + *

    Method handle creation

    * Java code can create a method handle that directly accesses * any method, constructor, or field that is accessible to that code. * This is done via a reflective, capability-based API called @@ -249,7 +249,7 @@ import java.util.logging.Logger; * receiver type. Such a method handle simulates the effect of * an {@code invokespecial} instruction to the same method. * - *

    Usage examples

    + *

    Usage examples

    * Here are some examples of usage: *

    {@code
     Object x, y; String s; int i;
    @@ -295,7 +295,7 @@ mh.invokeExact(System.out, "Hello, world.");
      * be a method which calls {@link java.util.Objects#equals(Object,Object) Objects.equals }
      * on its arguments, and asserts that the result is true.
      *
    - * 

    Exceptions

    + *

    Exceptions

    * The methods {@code invokeExact} and {@code invoke} are declared * to throw {@link java.lang.Throwable Throwable}, * which is to say that there is no static restriction on what a method handle @@ -308,7 +308,7 @@ mh.invokeExact(System.out, "Hello, world."); * throwables locally, rethrowing only those which are legal in the context, * and wrapping ones which are illegal. * - *

    Signature polymorphism

    + *

    Signature polymorphism

    * The unusual compilation and linkage behavior of * {@code invokeExact} and plain {@code invoke} * is referenced by the term signature polymorphism. @@ -333,7 +333,7 @@ mh.invokeExact(System.out, "Hello, world."); * Tools which determine symbolic linkage are required to accept such * untransformed descriptors, without reporting linkage errors. * - *

    Interoperation between method handles and the Core Reflection API

    + *

    Interoperation between method handles and the Core Reflection API

    * Using factory methods in the {@link java.lang.invoke.MethodHandles.Lookup Lookup} API, * any class member represented by a Core Reflection API object * can be converted to a behaviorally equivalent method handle. @@ -375,7 +375,7 @@ mh.invokeExact(System.out, "Hello, world."); * to call {@code invokeExact} or plain {@code invoke}, * for any specified type descriptor . * - *

    Interoperation between method handles and Java generics

    + *

    Interoperation between method handles and Java generics

    * A method handle can be obtained on a method, constructor, or field * which is declared with Java generic types. * As with the Core Reflection API, the type of the method handle @@ -457,6 +457,8 @@ public abstract class MethodHandle { * {@link java.lang.reflect.Method#invoke java.lang.reflect.Method.invoke}, via JNI, * or indirectly via {@link java.lang.invoke.MethodHandles.Lookup#unreflect Lookup.unreflect}, * it will throw an {@code UnsupportedOperationException}. + * @param args the signature-polymorphic parameter list, statically represented using varargs + * @return the signature-polymorphic result, statically represented using {@code Object} * @throws WrongMethodTypeException if the target's type is not identical with the caller's symbolic type descriptor * @throws Throwable anything thrown by the underlying method propagates unchanged through the method handle call */ @@ -491,6 +493,8 @@ public abstract class MethodHandle { * {@link java.lang.reflect.Method#invoke java.lang.reflect.Method.invoke}, via JNI, * or indirectly via {@link java.lang.invoke.MethodHandles.Lookup#unreflect Lookup.unreflect}, * it will throw an {@code UnsupportedOperationException}. + * @param args the signature-polymorphic parameter list, statically represented using varargs + * @return the signature-polymorphic result, statically represented using {@code Object} * @throws WrongMethodTypeException if the target's type cannot be adjusted to the caller's symbolic type descriptor * @throws ClassCastException if the target's type can be adjusted to the caller, but a reference cast fails * @throws Throwable anything thrown by the underlying method propagates unchanged through the method handle call @@ -511,15 +515,26 @@ public abstract class MethodHandle { * operations on outgoing argument values.) * The caller can assume that the incoming result value is part of the range * of the callee's return type. + * @param args the signature-polymorphic parameter list, statically represented using varargs + * @return the signature-polymorphic result, statically represented using {@code Object} */ /*non-public*/ final native @PolymorphicSignature Object invokeBasic(Object... args) throws Throwable; + /** + * Private method for trusted invocation of a MemberName of kind {@code REF_invokeVirtual}. + * The caller signature is restricted to basic types as with {@code invokeBasic}. + * The trailing (not leading) argument must be a MemberName. + * @param args the signature-polymorphic parameter list, statically represented using varargs + * @return the signature-polymorphic result, statically represented using {@code Object} + */ /*non-public*/ static native @PolymorphicSignature Object linkToVirtual(Object... args) throws Throwable; /** * Private method for trusted invocation of a MemberName of kind {@code REF_invokeStatic}. * The caller signature is restricted to basic types as with {@code invokeBasic}. * The trailing (not leading) argument must be a MemberName. + * @param args the signature-polymorphic parameter list, statically represented using varargs + * @return the signature-polymorphic result, statically represented using {@code Object} */ /*non-public*/ static native @PolymorphicSignature Object linkToStatic(Object... args) throws Throwable; @@ -527,6 +542,8 @@ public abstract class MethodHandle { * Private method for trusted invocation of a MemberName of kind {@code REF_invokeSpecial}. * The caller signature is restricted to basic types as with {@code invokeBasic}. * The trailing (not leading) argument must be a MemberName. + * @param args the signature-polymorphic parameter list, statically represented using varargs + * @return the signature-polymorphic result, statically represented using {@code Object} */ /*non-public*/ static native @PolymorphicSignature Object linkToSpecial(Object... args) throws Throwable; @@ -534,6 +551,8 @@ public abstract class MethodHandle { * Private method for trusted invocation of a MemberName of kind {@code REF_invokeInterface}. * The caller signature is restricted to basic types as with {@code invokeBasic}. * The trailing (not leading) argument must be a MemberName. + * @param args the signature-polymorphic parameter list, statically represented using varargs + * @return the signature-polymorphic result, statically represented using {@code Object} */ /*non-public*/ static native @PolymorphicSignature Object linkToInterface(Object... args) throws Throwable; diff --git a/jdk/src/share/classes/java/lang/invoke/MethodHandleProxies.java b/jdk/src/share/classes/java/lang/invoke/MethodHandleProxies.java index 641f2eeea51..246160cabaf 100644 --- a/jdk/src/share/classes/java/lang/invoke/MethodHandleProxies.java +++ b/jdk/src/share/classes/java/lang/invoke/MethodHandleProxies.java @@ -108,8 +108,9 @@ public class MethodHandleProxies { * Future versions of this API may also equip wrapper instances * with one or more additional public "marker" interfaces. * + * @param the desired type of the wrapper, a single-method interface + * @param intfc a class object representing {@code T} * @param target the method handle to invoke from the wrapper - * @param intfc the desired type of the wrapper, a single-method interface * @return a correctly-typed wrapper for the given target * @throws NullPointerException if either argument is null * @throws IllegalArgumentException if the {@code intfc} is not a diff --git a/jdk/src/share/classes/java/lang/invoke/MethodHandles.java b/jdk/src/share/classes/java/lang/invoke/MethodHandles.java index d37c8e947d8..3bf24bc8503 100644 --- a/jdk/src/share/classes/java/lang/invoke/MethodHandles.java +++ b/jdk/src/share/classes/java/lang/invoke/MethodHandles.java @@ -70,6 +70,7 @@ public class MethodHandles { * including direct method handles to private fields and methods. * This lookup object is a capability which may be delegated to trusted agents. * Do not store it in place where untrusted code can access it. + * @return a lookup object for the caller of this method */ @CallerSensitive public static Lookup lookup() { @@ -88,6 +89,7 @@ public class MethodHandles { * {@linkplain Lookup#in publicLookup().in(C.class)}. * Since all classes have equal access to public names, * such a change would confer no new access rights. + * @return a lookup object which is trusted minimally */ public static Lookup publicLookup() { return Lookup.PUBLIC_LOOKUP; @@ -111,72 +113,74 @@ public class MethodHandles { * on the {@code Lookup} object to create method handles for access-checked members. * This includes all methods, constructors, and fields which are allowed to the lookup class, * even private ones. - *

    + * + *

    Lookup Factory Methods

    * The factory methods on a {@code Lookup} object correspond to all major * use cases for methods, constructors, and fields. * Here is a summary of the correspondence between these factory methods and * the behavior the resulting method handles: - * *
    QSLink-time checksCapture-time checks
    PrimitivePrimitive
    * * - * - * + * + * * * - * - * + * + * * * - * - * + * + * * * - * - * + * + * * * - * - * + * + * * * - * - * + * + * * * - * - * + * + * * * - * - * + * + * * * - * - * + * + * * * - * - * + * + * * * - * - * + * + * * * - * - * + * + * * * - * - * + * + * * *
    lookup expressionmemberbehavior
    {@linkplain java.lang.invoke.MethodHandles.Lookup#findGetter lookup.findGetter(C.class,"f",FT.class)}FT f;(T) this.f;{@link java.lang.invoke.MethodHandles.Lookup#findGetter lookup.findGetter(C.class,"f",FT.class)}{@code FT f;}{@code (T) this.f;}
    {@linkplain java.lang.invoke.MethodHandles.Lookup#findStaticGetter lookup.findStaticGetter(C.class,"f",FT.class)}static
    FT f;
    (T) C.f;{@link java.lang.invoke.MethodHandles.Lookup#findStaticGetter lookup.findStaticGetter(C.class,"f",FT.class)}{@code static}
    {@code FT f;}
    {@code (T) C.f;}
    {@linkplain java.lang.invoke.MethodHandles.Lookup#findSetter lookup.findSetter(C.class,"f",FT.class)}FT f;this.f = x;{@link java.lang.invoke.MethodHandles.Lookup#findSetter lookup.findSetter(C.class,"f",FT.class)}{@code FT f;}{@code this.f = x;}
    {@linkplain java.lang.invoke.MethodHandles.Lookup#findStaticSetter lookup.findStaticSetter(C.class,"f",FT.class)}static
    FT f;
    C.f = arg;{@link java.lang.invoke.MethodHandles.Lookup#findStaticSetter lookup.findStaticSetter(C.class,"f",FT.class)}{@code static}
    {@code FT f;}
    {@code C.f = arg;}
    {@linkplain java.lang.invoke.MethodHandles.Lookup#findVirtual lookup.findVirtual(C.class,"m",MT)}T m(A*);(T) this.m(arg*);{@link java.lang.invoke.MethodHandles.Lookup#findVirtual lookup.findVirtual(C.class,"m",MT)}{@code T m(A*);}{@code (T) this.m(arg*);}
    {@linkplain java.lang.invoke.MethodHandles.Lookup#findStatic lookup.findStatic(C.class,"m",MT)}static
    T m(A*);
    (T) C.m(arg*);{@link java.lang.invoke.MethodHandles.Lookup#findStatic lookup.findStatic(C.class,"m",MT)}{@code static}
    {@code T m(A*);}
    {@code (T) C.m(arg*);}
    {@linkplain java.lang.invoke.MethodHandles.Lookup#findSpecial lookup.findSpecial(C.class,"m",MT,this.class)}T m(A*);(T) super.m(arg*);{@link java.lang.invoke.MethodHandles.Lookup#findSpecial lookup.findSpecial(C.class,"m",MT,this.class)}{@code T m(A*);}{@code (T) super.m(arg*);}
    {@linkplain java.lang.invoke.MethodHandles.Lookup#findConstructor lookup.findConstructor(C.class,MT)}C(A*);(T) new C(arg*);{@link java.lang.invoke.MethodHandles.Lookup#findConstructor lookup.findConstructor(C.class,MT)}{@code C(A*);}{@code new C(arg*);}
    {@linkplain java.lang.invoke.MethodHandles.Lookup#unreflectGetter lookup.unreflectGetter(aField)}(static)?
    FT f;
    (FT) aField.get(thisOrNull);{@link java.lang.invoke.MethodHandles.Lookup#unreflectGetter lookup.unreflectGetter(aField)}({@code static})?
    {@code FT f;}
    {@code (FT) aField.get(thisOrNull);}
    {@linkplain java.lang.invoke.MethodHandles.Lookup#unreflectSetter lookup.unreflectSetter(aField)}(static)?
    FT f;
    aField.set(thisOrNull, arg);{@link java.lang.invoke.MethodHandles.Lookup#unreflectSetter lookup.unreflectSetter(aField)}({@code static})?
    {@code FT f;}
    {@code aField.set(thisOrNull, arg);}
    {@linkplain java.lang.invoke.MethodHandles.Lookup#unreflect lookup.unreflect(aMethod)}(static)?
    T m(A*);
    (T) aMethod.invoke(thisOrNull, arg*);{@link java.lang.invoke.MethodHandles.Lookup#unreflect lookup.unreflect(aMethod)}({@code static})?
    {@code T m(A*);}
    {@code (T) aMethod.invoke(thisOrNull, arg*);}
    {@linkplain java.lang.invoke.MethodHandles.Lookup#unreflectConstructor lookup.unreflectConstructor(aConstructor)}C(A*);(C) aConstructor.newInstance(arg*);{@link java.lang.invoke.MethodHandles.Lookup#unreflectConstructor lookup.unreflectConstructor(aConstructor)}{@code C(A*);}{@code (C) aConstructor.newInstance(arg*);}
    {@linkplain java.lang.invoke.MethodHandles.Lookup#unreflect lookup.unreflect(aMethod)}(static)?
    T m(A*);
    (T) aMethod.invoke(thisOrNull, arg*);{@link java.lang.invoke.MethodHandles.Lookup#unreflect lookup.unreflect(aMethod)}({@code static})?
    {@code T m(A*);}
    {@code (T) aMethod.invoke(thisOrNull, arg*);}
    - * + * * Here, the type {@code C} is the class or interface being searched for a member, * documented as a parameter named {@code refc} in the lookup methods. - * The method or constructor type {@code MT} is composed from the return type {@code T} + * The method type {@code MT} is composed from the return type {@code T} * and the sequence of argument types {@code A*}. + * The constructor also has a sequence of argument types {@code A*} and + * is deemed to return the newly-created object of type {@code C}. * Both {@code MT} and the field type {@code FT} are documented as a parameter named {@code type}. * The formal parameter {@code this} stands for the self-reference of type {@code C}; * if it is present, it is always the leading argument to the method handle invocation. @@ -210,7 +214,7 @@ public class MethodHandles { * security manager checks. * * - *

    Access checking

    + *

    Access checking

    * Access checks are applied in the factory methods of {@code Lookup}, * when a method handle is created. * This is a key difference from the Core Reflection API, since @@ -297,7 +301,7 @@ public class MethodHandles { * with static methods of {@link MethodHandles}, * independently of any {@code Lookup} object. * - *

    Security manager interactions

    + *

    Security manager interactions

    * * If a security manager is present, member lookups are subject to * additional checks. @@ -388,6 +392,7 @@ public class MethodHandles { * but the permissions may be additionally limited by the bitmask * {@link #lookupModes lookupModes}, which controls whether non-public members * can be accessed. + * @return the lookup class, on behalf of which this lookup object finds members */ public Class lookupClass() { return lookupClass; @@ -414,6 +419,7 @@ public class MethodHandles { * The purpose of this is to restrict access via the new lookup object, * so that it can access only names which can be reached by the original * lookup object, and also by the new lookup class. + * @return the lookup modes, which limit the kinds of access performed by this lookup object */ public int lookupModes() { return allowedModes & ALL_MODES; @@ -1352,6 +1358,7 @@ return mh1; * The type of the method handle will have a void return type. * Its last argument will be the array's element type. * The first and second arguments will be the array type and int. + * @param arrayClass the class of an array * @return a method handle which can store values into the array type * @throws NullPointerException if the argument is null * @throws IllegalArgumentException if arrayClass is not an array type @@ -1580,12 +1587,12 @@ import static java.lang.invoke.MethodType.*; ... MethodType intfn1 = methodType(int.class, int.class); MethodType intfn2 = methodType(int.class, int.class, int.class); -MethodHandle sub = ... {int x, int y => x-y} ...; +MethodHandle sub = ... (int x, int y) -> (x-y) ...; assert(sub.type().equals(intfn2)); MethodHandle sub1 = permuteArguments(sub, intfn2, 0, 1); MethodHandle rsub = permuteArguments(sub, intfn2, 1, 0); assert((int)rsub.invokeExact(1, 100) == 99); -MethodHandle add = ... {int x, int y => x+y} ...; +MethodHandle add = ... (int x, int y) -> (x+y) ...; assert(add.type().equals(intfn2)); MethodHandle twice = permuteArguments(add, intfn1, 0, 0); assert(twice.type().equals(intfn1)); @@ -2261,6 +2268,8 @@ assertEquals("boojum", (String) catTrace.invokeExact("boo", "jum")); * The method type will nominally specify a return of {@code returnType}. * The return type may be anything convenient: It doesn't matter to the * method handle's behavior, since it will never return normally. + * @param returnType the return type of the desired method handle + * @param exType the parameter type of the desired method handle * @return method handle which can throw the given exceptions * @throws NullPointerException if either argument is null */ diff --git a/jdk/src/share/classes/java/lang/invoke/MethodType.java b/jdk/src/share/classes/java/lang/invoke/MethodType.java index 7c9f2450840..f55479f1345 100644 --- a/jdk/src/share/classes/java/lang/invoke/MethodType.java +++ b/jdk/src/share/classes/java/lang/invoke/MethodType.java @@ -194,6 +194,8 @@ class MethodType implements java.io.Serializable { /** * Finds or creates a method type with the given components. * Convenience method for {@link #methodType(java.lang.Class, java.lang.Class[]) methodType}. + * @param rtype the return type + * @param ptypes the parameter types * @return a method type with the given components * @throws NullPointerException if {@code rtype} or {@code ptypes} or any element of {@code ptypes} is null * @throws IllegalArgumentException if any element of {@code ptypes} is {@code void.class} @@ -214,6 +216,9 @@ class MethodType implements java.io.Serializable { * Finds or creates a method type with the given components. * Convenience method for {@link #methodType(java.lang.Class, java.lang.Class[]) methodType}. * The leading parameter type is prepended to the remaining array. + * @param rtype the return type + * @param ptype0 the first parameter type + * @param ptypes the remaining parameter types * @return a method type with the given components * @throws NullPointerException if {@code rtype} or {@code ptype0} or {@code ptypes} or any element of {@code ptypes} is null * @throws IllegalArgumentException if {@code ptype0} or {@code ptypes} or any element of {@code ptypes} is {@code void.class} @@ -230,6 +235,7 @@ class MethodType implements java.io.Serializable { * Finds or creates a method type with the given components. * Convenience method for {@link #methodType(java.lang.Class, java.lang.Class[]) methodType}. * The resulting method has no parameter types. + * @param rtype the return type * @return a method type with the given return value * @throws NullPointerException if {@code rtype} is null */ @@ -242,6 +248,8 @@ class MethodType implements java.io.Serializable { * Finds or creates a method type with the given components. * Convenience method for {@link #methodType(java.lang.Class, java.lang.Class[]) methodType}. * The resulting method has the single given parameter type. + * @param rtype the return type + * @param ptype0 the parameter type * @return a method type with the given return value and parameter type * @throws NullPointerException if {@code rtype} or {@code ptype0} is null * @throws IllegalArgumentException if {@code ptype0} is {@code void.class} @@ -256,6 +264,9 @@ class MethodType implements java.io.Serializable { * Convenience method for {@link #methodType(java.lang.Class, java.lang.Class[]) methodType}. * The resulting method has the same parameter types as {@code ptypes}, * and the specified return type. + * @param rtype the return type + * @param ptypes the method type which supplies the parameter types + * @return a method type with the given components * @throws NullPointerException if {@code rtype} or {@code ptypes} is null */ public static @@ -938,7 +949,8 @@ s.writeObject(this.parameterArray()); * provided to the factory method {@link #methodType(Class,Class[]) methodType}. * For example, null values, or {@code void} parameter types, * will lead to exceptions during deserialization. - * @param the stream to write the object to + * @param s the stream to write the object to + * @throws java.io.IOException if there is a problem writing the object */ private void writeObject(java.io.ObjectOutputStream s) throws java.io.IOException { s.defaultWriteObject(); // requires serialPersistentFields to be an empty array @@ -953,7 +965,9 @@ s.writeObject(this.parameterArray()); * It provides the parameters to the factory method called by * {@link #readResolve readResolve}. * After that call it is discarded. - * @param the stream to read the object from + * @param s the stream to read the object from + * @throws java.io.IOException if there is a problem reading the object + * @throws ClassNotFoundException if one of the component classes cannot be resolved * @see #MethodType() * @see #readResolve * @see #writeObject diff --git a/jdk/src/share/classes/java/lang/invoke/MutableCallSite.java b/jdk/src/share/classes/java/lang/invoke/MutableCallSite.java index d48f99afefb..37bd4641484 100644 --- a/jdk/src/share/classes/java/lang/invoke/MutableCallSite.java +++ b/jdk/src/share/classes/java/lang/invoke/MutableCallSite.java @@ -195,7 +195,7 @@ public class MutableCallSite extends CallSite { * processed before the method returns abnormally. * Which elements these are (if any) is implementation-dependent. * - *

    Java Memory Model details

    + *

    Java Memory Model details

    * In terms of the Java Memory Model, this operation performs a synchronization * action which is comparable in effect to the writing of a volatile variable * by the current thread, and an eventual volatile read by every other thread diff --git a/jdk/src/share/classes/java/lang/invoke/SerializedLambda.java b/jdk/src/share/classes/java/lang/invoke/SerializedLambda.java index 3679e3f726d..558fa5ab6ee 100644 --- a/jdk/src/share/classes/java/lang/invoke/SerializedLambda.java +++ b/jdk/src/share/classes/java/lang/invoke/SerializedLambda.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2013, 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 @@ -97,66 +97,113 @@ public final class SerializedLambda implements Serializable { this.capturedArgs = Objects.requireNonNull(capturedArgs).clone(); } - /** Get the name of the class that captured this lambda */ + /** + * Get the name of the class that captured this lambda. + * @return the name of the class that captured this lambda + */ public String getCapturingClass() { return capturingClass.getName().replace('.', '/'); } - /** Get the name of the functional interface class to which this lambda has been converted */ + /** + * Get the name of the functional interface class to which this + * lambda has been converted + * @return the name of the functional interface this lambda has + * been converted to + */ public String getFunctionalInterfaceClass() { return functionalInterfaceClass; } - /** Get the name of the primary method for the functional interface to which this lambda has been converted */ + /** + * Get the name of the primary method for the functional interface + * to which this lambda has been converted. + * @return the name of the primary methods of the functional interface + */ public String getFunctionalInterfaceMethodName() { return functionalInterfaceMethodName; } - /** Get the signature of the primary method for the functional interface to which this lambda has been converted */ + /** + * Get the signature of the primary method for the functional + * interface to which this lambda has been converted. + * @return the signature of the primary method of the functional + * interface + */ public String getFunctionalInterfaceMethodSignature() { return functionalInterfaceMethodSignature; } - /** Get the method handle kind (see {@link MethodHandleInfo}) of the primary method for the functional interface - * to which this lambda has been converted */ + /** + * Get the method handle kind (see {@link MethodHandleInfo}) of + * the primary method for the functional interface to which this + * lambda has been converted + * @return the method handle kind of the primary method of + * functional interface + */ public int getFunctionalInterfaceMethodKind() { return functionalInterfaceMethodKind; } - /** Get the name of the class containing the implementation method */ + /** + * Get the name of the class containing the implementation + * method. + * @return the name of the class containing the implementation + * method + */ public String getImplClass() { return implClass; } - /** Get the name of the implementation method */ + /** + * Get the name of the implementation method. + * @return the name of the implementation method + */ public String getImplMethodName() { return implMethodName; } - /** Get the signature of the implementation method */ + /** + * Get the signature of the implementation method. + * @return the signature of the implementation method + */ public String getImplMethodSignature() { return implMethodSignature; } - /** Get the method handle kind (see {@link MethodHandleInfo}) of the implementation method */ + /** + * Get the method handle kind (see {@link MethodHandleInfo}) of + * the implementation method. + * @return the method handle kind of the implementation method + */ public int getImplMethodKind() { return implMethodKind; } /** - * Get the signature of the primary functional interface method after type variables are substituted with - * their instantiation from the capture site + * Get the signature of the primary functional interface method + * after type variables are substituted with their instantiation + * from the capture site. + * @return the signature of the primary functional interface method + * after type variable processing */ public final String getInstantiatedMethodType() { return instantiatedMethodType; } - /** Get the count of dynamic arguments to the lambda capture site */ + /** + * Get the count of dynamic arguments to the lambda capture site. + * @return the count of dynamic arguments to the lambda capture site + */ public int getCapturedArgCount() { return capturedArgs.length; } - /** Get a dynamic argument to the lambda capture site */ + /** + * Get a dynamic argument to the lambda capture site. + * @param i the argument to capture + * @return a dynamic argument to the lambda capture site + */ public Object getCapturedArg(int i) { return capturedArgs[i]; } diff --git a/jdk/src/share/classes/java/lang/invoke/package-info.java b/jdk/src/share/classes/java/lang/invoke/package-info.java index 880bf54021f..51fc21c3f77 100644 --- a/jdk/src/share/classes/java/lang/invoke/package-info.java +++ b/jdk/src/share/classes/java/lang/invoke/package-info.java @@ -43,13 +43,13 @@ * * * - *

    Summary of relevant Java Virtual Machine changes

    + *

    Summary of relevant Java Virtual Machine changes

    * The following low-level information summarizes relevant parts of the * Java Virtual Machine specification. For full details, please see the * current version of that specification. * * Each occurrence of an {@code invokedynamic} instruction is called a dynamic call site. - *

    {@code invokedynamic} instructions

    + *

    {@code invokedynamic} instructions

    * A dynamic call site is originally in an unlinked state. In this state, there is * no target method for the call site to invoke. *

    @@ -97,7 +97,7 @@ * If this happens, the same error will the thrown for all subsequent * attempts to execute the dynamic call site. * - *

    timing of linkage

    + *

    timing of linkage

    * A dynamic call site is linked just before its first execution. * The bootstrap method call implementing the linkage occurs within * a thread that is attempting a first execution. @@ -131,7 +131,7 @@ * just before its first invocation. * There is no way to undo the effect of a completed bootstrap method call. * - *

    types of bootstrap methods

    + *

    types of bootstrap methods

    * As long as each bootstrap method can be correctly invoked * by {@code MethodHandle.invoke}, its detailed type is arbitrary. * For example, the first argument could be {@code Object} From 154d88d2bdf1317aa90517aa8e943e9004c5480b Mon Sep 17 00:00:00 2001 From: Xue-Lei Andrew Fan Date: Thu, 27 Jun 2013 19:22:51 -0700 Subject: [PATCH 042/127] 8019359: To comment why not use no_renegotiation to reject client initiated renegotiation Reviewed-by: wetmore --- .../classes/sun/security/ssl/ServerHandshaker.java | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/jdk/src/share/classes/sun/security/ssl/ServerHandshaker.java b/jdk/src/share/classes/sun/security/ssl/ServerHandshaker.java index 69c78324775..e317e1f18c5 100644 --- a/jdk/src/share/classes/sun/security/ssl/ServerHandshaker.java +++ b/jdk/src/share/classes/sun/security/ssl/ServerHandshaker.java @@ -281,7 +281,15 @@ final class ServerHandshaker extends Handshaker { // Reject client initiated renegotiation? // - // Should not have any impact on server initiated renegotiation. + // If server side should reject client-initiated renegotiation, + // send an alert_handshake_failure fatal alert, not a no_renegotiation + // warning alert (no_renegotiation must be a warning: RFC 2246). + // no_renegotiation might seem more natural at first, but warnings + // are not appropriate because the sending party does not know how + // the receiving party will behave. This state must be treated as + // a fatal server condition. + // + // This will not have any impact on server initiated renegotiation. if (rejectClientInitiatedRenego && !isInitialHandshake && state != HandshakeMessage.ht_hello_request) { fatalSE(Alerts.alert_handshake_failure, From 411df5ec9097d527936374353433bfb039ad90d4 Mon Sep 17 00:00:00 2001 From: Henry Jen Date: Tue, 11 Jun 2013 13:41:38 -0700 Subject: [PATCH 043/127] 8009736: Comparator API cleanup Reviewed-by: psandoz, briangoetz, mduigou, plevart --- .../share/classes/java/util/Collections.java | 10 + .../share/classes/java/util/Comparator.java | 343 ++++++++++++++++-- .../share/classes/java/util/Comparators.java | 261 ++----------- jdk/src/share/classes/java/util/Map.java | 69 ++++ jdk/src/share/classes/java/util/TreeMap.java | 4 +- .../java/util/function/BinaryOperator.java | 30 ++ .../classes/java/util/stream/Collectors.java | 21 +- .../java/util/stream/ReferencePipeline.java | 5 +- .../classes/java/util/stream/SortedOps.java | 3 +- jdk/test/java/nio/file/Files/StreamTest.java | 16 +- .../java/util/Collection/ListDefaults.java | 19 +- .../BasicTest.java | 289 +++++++-------- jdk/test/java/util/Comparator/TypeTest.java | 96 +++++ jdk/test/java/util/Map/EntryComparators.java | 139 +++++++ .../function/BinaryOperator/BasicTest.java | 104 ++++++ .../java/util/stream/SequentialOpTest.java | 7 +- .../tests/java/util/stream/SliceOpTest.java | 2 +- .../tests/java/util/stream/SortedOpTest.java | 20 +- .../misc/JavaLangAccess/NewUnsafeString.java | 8 +- 19 files changed, 967 insertions(+), 479 deletions(-) rename jdk/test/java/util/{Comparators => Comparator}/BasicTest.java (55%) create mode 100644 jdk/test/java/util/Comparator/TypeTest.java create mode 100644 jdk/test/java/util/Map/EntryComparators.java create mode 100644 jdk/test/java/util/function/BinaryOperator/BasicTest.java diff --git a/jdk/src/share/classes/java/util/Collections.java b/jdk/src/share/classes/java/util/Collections.java index da258793ba6..ad4540db14a 100644 --- a/jdk/src/share/classes/java/util/Collections.java +++ b/jdk/src/share/classes/java/util/Collections.java @@ -4304,6 +4304,11 @@ public class Collections { } private Object readResolve() { return Collections.reverseOrder(); } + + @Override + public Comparator> reversed() { + return Comparator.naturalOrder(); + } } /** @@ -4367,6 +4372,11 @@ public class Collections { public int hashCode() { return cmp.hashCode() ^ Integer.MIN_VALUE; } + + @Override + public Comparator reversed() { + return cmp; + } } /** diff --git a/jdk/src/share/classes/java/util/Comparator.java b/jdk/src/share/classes/java/util/Comparator.java index 017c2e78e2c..cd65ca4ea06 100644 --- a/jdk/src/share/classes/java/util/Comparator.java +++ b/jdk/src/share/classes/java/util/Comparator.java @@ -25,10 +25,12 @@ package java.util; +import java.io.Serializable; import java.util.function.Function; import java.util.function.ToIntFunction; import java.util.function.ToLongFunction; import java.util.function.ToDoubleFunction; +import java.util.Comparators; /** * A comparison function, which imposes a total ordering on some @@ -175,88 +177,357 @@ public interface Comparator { * Returns a comparator that imposes the reverse ordering of this * comparator. * - * @return A comparator that imposes the reverse ordering of this + * @return a comparator that imposes the reverse ordering of this * comparator. * @since 1.8 */ - default Comparator reverseOrder() { + default Comparator reversed() { return Collections.reverseOrder(this); } /** - * Constructs a lexicographic order comparator with another comparator. - * For example, a {@code Comparator byLastName} can be composed - * with another {@code Comparator byFirstName}, then {@code - * byLastName.thenComparing(byFirstName)} creates a {@code - * Comparator} which sorts by last name, and for equal last names - * sorts by first name. + * Returns a lexicographic-order comparator with another comparator. + * If this {@code Comparator} considers two elements equal, i.e. + * {@code compare(a, b) == 0}, {@code other} is used to determine the order. * - * @param other the other comparator used when equals on this. + *

    The returned comparator is serializable if the specified comparator + * is also serializable. + * + * @apiNote + * For example, to sort a collection of {@code String} based on the length + * and then case-insensitive natural ordering, the comparator can be + * composed using following code, + * + *

    {@code
    +     *     Comparator cmp = Comparator.comparing(String::length)
    +     *             .thenComparing(String.CASE_INSENSITIVE_ORDER);
    +     * }
    + * + * @param other the other comparator to be used when this comparator + * compares two objects that are equal. + * @return a lexicographic-order comparator composed of this and then the + * other comparator * @throws NullPointerException if the argument is null. * @since 1.8 */ default Comparator thenComparing(Comparator other) { - return Comparators.compose(this, other); + Objects.requireNonNull(other); + return (Comparator & Serializable) (c1, c2) -> { + int res = compare(c1, c2); + return (res != 0) ? res : other.compare(c1, c2); + }; } /** - * Constructs a lexicographic order comparator with a function that - * extracts a {@code Comparable} key. This default implementation calls - * {@code thenComparing(this, Comparators.comparing(keyExtractor))}. + * Returns a lexicographic-order comparator with a function that + * extracts a key to be compared with the given {@code Comparator}. * - * @param the {@link Comparable} type for comparison - * @param keyExtractor the function used to extract the {@link Comparable} sort key + * @implSpec This default implementation behaves as if {@code + * thenComparing(comparing(keyExtractor, cmp))}. + * + * @param the type of the sort key + * @param keyExtractor the function used to extract the sort key + * @param keyComparator the {@code Comparator} used to compare the sort key + * @return a lexicographic-order comparator composed of this comparator + * and then comparing on the key extracted by the keyExtractor function * @throws NullPointerException if the argument is null. - * @see Comparators#comparing(Function) + * @see #comparing(Function, Comparator) * @see #thenComparing(Comparator) * @since 1.8 */ - default > Comparator thenComparing(Function keyExtractor) { - return thenComparing(Comparators.comparing(keyExtractor)); + default > Comparator thenComparing( + Function keyExtractor, + Comparator keyComparator) + { + return thenComparing(comparing(keyExtractor, keyComparator)); } /** - * Constructs a lexicographic order comparator with a function that - * extracts a {@code int} value. This default implementation calls {@code - * thenComparing(this, Comparators.comparing(keyExtractor))}. + * Returns a lexicographic-order comparator with a function that + * extracts a {@code Comparable} sort key. * - * @param keyExtractor the function used to extract the integer value + * @implSpec This default implementation behaves as if {@code + * thenComparing(comparing(keyExtractor))}. + * + * @param the type of the {@link Comparable} sort key + * @param keyExtractor the function used to extract the {@link + * Comparable} sort key + * @return a lexicographic-order comparator composed of this and then the + * {@link Comparable} sort key. * @throws NullPointerException if the argument is null. - * @see Comparators#comparing(ToIntFunction) + * @see #comparing(Function) + * @see #thenComparing(Comparator) + * @since 1.8 + */ + default > Comparator thenComparing( + Function keyExtractor) + { + return thenComparing(comparing(keyExtractor)); + } + + /** + * Returns a lexicographic-order comparator with a function that + * extracts a {@code int} sort key. + * + * @implSpec This default implementation behaves as if {@code + * thenComparing(comparing(keyExtractor))}. + * + * @param keyExtractor the function used to extract the integer sort key + * @return a lexicographic-order comparator composed of this and then the + * {@code int} sort key + * @throws NullPointerException if the argument is null. + * @see #comparing(ToIntFunction) * @see #thenComparing(Comparator) * @since 1.8 */ default Comparator thenComparing(ToIntFunction keyExtractor) { - return thenComparing(Comparators.comparing(keyExtractor)); + return thenComparing(comparing(keyExtractor)); } /** - * Constructs a lexicographic order comparator with a function that - * extracts a {@code long} value. This default implementation calls - * {@code thenComparing(this, Comparators.comparing(keyExtractor))}. + * Returns a lexicographic-order comparator with a function that + * extracts a {@code long} sort key. * - * @param keyExtractor the function used to extract the long value + * @implSpec This default implementation behaves as if {@code + * thenComparing(comparing(keyExtractor))}. + * + * @param keyExtractor the function used to extract the long sort key + * @return a lexicographic-order comparator composed of this and then the + * {@code long} sort key * @throws NullPointerException if the argument is null. - * @see Comparators#comparing(ToLongFunction) + * @see #comparing(ToLongFunction) * @see #thenComparing(Comparator) * @since 1.8 */ default Comparator thenComparing(ToLongFunction keyExtractor) { - return thenComparing(Comparators.comparing(keyExtractor)); + return thenComparing(comparing(keyExtractor)); } /** - * Constructs a lexicographic order comparator with a function that - * extracts a {@code double} value. This default implementation calls - * {@code thenComparing(this, Comparators.comparing(keyExtractor))}. + * Returns a lexicographic-order comparator with a function that + * extracts a {@code double} sort key. * - * @param keyExtractor the function used to extract the double value + * @implSpec This default implementation behaves as if {@code + * thenComparing(comparing(keyExtractor))}. + * + * @param keyExtractor the function used to extract the double sort key + * @return a lexicographic-order comparator composed of this and then the + * {@code double} sort key * @throws NullPointerException if the argument is null. - * @see Comparators#comparing(ToDoubleFunction) + * @see #comparing(ToDoubleFunction) * @see #thenComparing(Comparator) * @since 1.8 */ default Comparator thenComparing(ToDoubleFunction keyExtractor) { - return thenComparing(Comparators.comparing(keyExtractor)); + return thenComparing(comparing(keyExtractor)); + } + + /** + * Returns a comparator that imposes the reverse of the natural + * ordering. + * + *

    The returned comparator is serializable and throws {@link + * NullPointerException} when comparing {@code null}. + * + * @param the {@link Comparable} type of element to be compared + * @return a comparator that imposes the reverse of the natural + * ordering on {@code Comparable} objects. + * @see Comparable + * @since 1.8 + */ + public static > Comparator reverseOrder() { + return Collections.reverseOrder(); + } + + /** + * Returns a comparator that compares {@link Comparable} objects in natural + * order. + * + *

    The returned comparator is serializable and throws {@link + * NullPointerException} when comparing {@code null}. + * + * @param the {@link Comparable} type of element to be compared + * @return a comparator that imposes the natural ordering on {@code + * Comparable} objects. + * @see Comparable + * @since 1.8 + */ + public static > Comparator naturalOrder() { + return (Comparator) Comparators.NaturalOrderComparator.INSTANCE; + } + + /** + * Returns a null-friendly comparator that considers {@code null} to be + * less than non-null. When both are {@code null}, they are considered + * equal. If both are non-null, the specified {@code Comparator} is used + * to determine the order. If the specified comparator is {@code null}, + * then the returned comparator considers all non-null values to be equal. + * + *

    The returned comparator is serializable if the specified comparator + * is serializable. + * + * @param the type of the elements to be compared + * @param comparator a {@code Comparator} for comparing non-null values + * @return a comparator that considers {@code null} to be less than + * non-null, and compares non-null objects with the supplied + * {@code Comparator}. + * @since 1.8 + */ + public static Comparator nullsFirst(Comparator comparator) { + return new Comparators.NullComparator(true, comparator); + } + + /** + * Returns a null-friendly comparator that considers {@code null} to be + * greater than non-null. When both are {@code null}, they are considered + * equal. If both are non-null, the specified {@code Comparator} is used + * to determine the order. If the specified comparator is {@code null}, + * then the returned comparator considers all non-null values to be equal. + * + *

    The returned comparator is serializable if the specified comparator + * is serializable. + * + * @param the type of the elements to be compared + * @param comparator a {@code Comparator} for comparing non-null values + * @return a comparator that considers {@code null} to be greater than + * non-null, and compares non-null objects with the supplied + * {@code Comparator}. + * @since 1.8 + */ + public static Comparator nullsLast(Comparator comparator) { + return new Comparators.NullComparator(false, comparator); + } + + /** + * Accepts a function that extracts a sort key from a type {@code T}, and + * returns a {@code Comparator} that compares by that sort key using + * the specified {@link Comparator}. + * + *

    The returned comparator is serializable if the specified function + * and comparator are both serializable. + * + * @apiNote + * For example, to obtain a {@code Comparator} that compares {@code + * Person} objects by their last name ignoring case differences, + * + *

    {@code
    +     *     Comparator cmp = Comparator.comparing(
    +     *             Person::getLastName,
    +     *             String.CASE_INSENSITIVE_ORDER);
    +     * }
    + * + * @param the type of element to be compared + * @param the type of the sort key + * @param keyExtractor the function used to extract the sort key + * @param keyComparator the {@code Comparator} used to compare the sort key + * @return a comparator that compares by an extracted key using the + * specified {@code Comparator} + * @throws NullPointerException if either argument is null + * @since 1.8 + */ + public static Comparator comparing( + Function keyExtractor, + Comparator keyComparator) + { + Objects.requireNonNull(keyExtractor); + Objects.requireNonNull(keyComparator); + return (Comparator & Serializable) + (c1, c2) -> keyComparator.compare(keyExtractor.apply(c1), + keyExtractor.apply(c2)); + } + + /** + * Accepts a function that extracts a {@link java.lang.Comparable + * Comparable} sort key from a type {@code T}, and returns a {@code + * Comparator} that compares by that sort key. + * + *

    The returned comparator is serializable if the specified function + * is also serializable. + * + * @apiNote + * For example, to obtain a {@code Comparator} that compares {@code + * Person} objects by their last name, + * + *

    {@code
    +     *     Comparator byLastName = Comparator.comparing(Person::getLastName);
    +     * }
    + * + * @param the type of element to be compared + * @param the type of the {@code Comparable} sort key + * @param keyExtractor the function used to extract the {@link + * Comparable} sort key + * @return a comparator that compares by an extracted key + * @throws NullPointerException if the argument is null + * @since 1.8 + */ + public static > Comparator comparing( + Function keyExtractor) + { + Objects.requireNonNull(keyExtractor); + return (Comparator & Serializable) + (c1, c2) -> keyExtractor.apply(c1).compareTo(keyExtractor.apply(c2)); + } + + /** + * Accepts a function that extracts an {@code int} sort key from a type + * {@code T}, and returns a {@code Comparator} that compares by that + * sort key. + * + *

    The returned comparator is serializable if the specified function + * is also serializable. + * + * @param the type of element to be compared + * @param keyExtractor the function used to extract the integer sort key + * @return a comparator that compares by an extracted key + * @see #comparing(Function) + * @throws NullPointerException if the argument is null + * @since 1.8 + */ + public static Comparator comparing(ToIntFunction keyExtractor) { + Objects.requireNonNull(keyExtractor); + return (Comparator & Serializable) + (c1, c2) -> Integer.compare(keyExtractor.applyAsInt(c1), keyExtractor.applyAsInt(c2)); + } + + /** + * Accepts a function that extracts a {@code long} sort key from a type + * {@code T}, and returns a {@code Comparator} that compares by that + * sort key. + * + *

    The returned comparator is serializable if the specified function is + * also serializable. + * + * @param the type of element to be compared + * @param keyExtractor the function used to extract the long sort key + * @return a comparator that compares by an extracted key + * @see #comparing(Function) + * @throws NullPointerException if the argument is null + * @since 1.8 + */ + public static Comparator comparing(ToLongFunction keyExtractor) { + Objects.requireNonNull(keyExtractor); + return (Comparator & Serializable) + (c1, c2) -> Long.compare(keyExtractor.applyAsLong(c1), keyExtractor.applyAsLong(c2)); + } + + /** + * Accepts a function that extracts a {@code double} sort key from a type + * {@code T}, and returns a {@code Comparator} that compares by that + * sort key. + * + *

    The returned comparator is serializable if the specified function + * is also serializable. + * + * @param the type of element to be compared + * @param keyExtractor the function used to extract the double sort key + * @return a comparator that compares by an extracted key + * @see #comparing(Function) + * @throws NullPointerException if the argument is null + * @since 1.8 + */ + public static Comparator comparing(ToDoubleFunction keyExtractor) { + Objects.requireNonNull(keyExtractor); + return (Comparator & Serializable) + (c1, c2) -> Double.compare(keyExtractor.applyAsDouble(c1), keyExtractor.applyAsDouble(c2)); } } diff --git a/jdk/src/share/classes/java/util/Comparators.java b/jdk/src/share/classes/java/util/Comparators.java index 97b7412f5c9..a9038321085 100644 --- a/jdk/src/share/classes/java/util/Comparators.java +++ b/jdk/src/share/classes/java/util/Comparators.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2013, 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 @@ -32,16 +32,9 @@ import java.util.function.ToIntFunction; import java.util.function.ToLongFunction; /** - * This class consists of {@code static} utility methods for comparators. Mostly - * factory method that returns a {@link Comparator}. - * - *

    Unless otherwise noted, passing a {@code null} argument to a method in - * this class will cause a {@link NullPointerException} to be thrown. - * - * @see Comparator - * @since 1.8 + * Package private supporting class for {@link Comparator}. */ -public class Comparators { +class Comparators { private Comparators() { throw new AssertionError("no instances"); } @@ -51,231 +44,55 @@ public class Comparators { * * @see Comparable */ - private enum NaturalOrderComparator implements Comparator> { + enum NaturalOrderComparator implements Comparator> { INSTANCE; @Override public int compare(Comparable c1, Comparable c2) { return c1.compareTo(c2); } + + @Override + public Comparator> reversed() { + return Comparator.reverseOrder(); + } } /** - * Returns a comparator that imposes the reverse of the natural - * ordering. - * - *

    The returned comparator is serializable. - * - * @param {@link Comparable} type - * - * @return A comparator that imposes the reverse of the natural - * ordering on a collection of objects that implement - * the {@link Comparable} interface. - * @see Comparable + * Null-friendly comparators */ - public static > Comparator reverseOrder() { - return Collections.reverseOrder(); - } + final static class NullComparator implements Comparator, Serializable { + private static final long serialVersionUID = -7569533591570686392L; + private final boolean nullFirst; + // if null, non-null Ts are considered equal + private final Comparator real; - /** - * Returns a comparator that imposes the reverse ordering of the specified - * {@link Comparator}. - * - *

    The returned comparator is serializable (assuming the specified - * comparator is also serializable). - * - * @param the element type to be compared - * @param cmp a comparator whose ordering is to be reversed by the returned - * comparator - * @return A comparator that imposes the reverse ordering of the - * specified comparator. - */ - public static Comparator reverseOrder(Comparator cmp) { - Objects.requireNonNull(cmp); - return Collections.reverseOrder(cmp); - } + @SuppressWarnings("unchecked") + NullComparator(boolean nullFirst, Comparator real) { + this.nullFirst = nullFirst; + this.real = (Comparator) real; + } - /** - * Gets a comparator compares {@link Comparable} type in natural order. - * - * @param {@link Comparable} type - */ - public static > Comparator naturalOrder() { - return (Comparator) NaturalOrderComparator.INSTANCE; - } + @Override + public int compare(T a, T b) { + if (a == null) { + return (b == null) ? 0 : (nullFirst ? -1 : 1); + } else if (b == null) { + return nullFirst ? 1: -1; + } else { + return (real == null) ? 0 : real.compare(a, b); + } + } - /** - * Gets a comparator compares {@link Map.Entry} in natural order on key. - * - * @param {@link Comparable} key type - * @param value type - */ - public static , V> Comparator> naturalOrderKeys() { - return (Comparator> & Serializable) - (c1, c2) -> c1.getKey().compareTo(c2.getKey()); - } + @Override + public Comparator thenComparing(Comparator other) { + Objects.requireNonNull(other); + return new NullComparator(nullFirst, real == null ? other : real.thenComparing(other)); + } - /** - * Gets a comparator compares {@link Map.Entry} in natural order on value. - * - * @param key type - * @param {@link Comparable} value type - */ - public static > Comparator> naturalOrderValues() { - return (Comparator> & Serializable) - (c1, c2) -> c1.getValue().compareTo(c2.getValue()); - } - - /** - * Gets a comparator compares {@link Map.Entry} by key using the given - * {@link Comparator}. - * - *

    The returned comparator is serializable assuming the specified - * comparators are also serializable. - * - * @param key type - * @param value type - * @param cmp the key {@link Comparator} - */ - public static Comparator> byKey(Comparator cmp) { - Objects.requireNonNull(cmp); - return (Comparator> & Serializable) - (c1, c2) -> cmp.compare(c1.getKey(), c2.getKey()); - } - - /** - * Gets a comparator compares {@link Map.Entry} by value using the given - * {@link Comparator}. - * - * @param key type - * @param value type - * @param cmp the value {@link Comparator} - */ - public static Comparator> byValue(Comparator cmp) { - Objects.requireNonNull(cmp); - return (Comparator> & Serializable) - (c1, c2) -> cmp.compare(c1.getValue(), c2.getValue()); - } - - /** - * Accepts a function that extracts a {@link java.lang.Comparable - * Comparable} sort key from a type {@code T}, and returns a {@code - * Comparator} that compares by that sort key. For example, if a class - * {@code Person} has a {@code String}-valued getter {@code getLastName}, - * then {@code comparing(Person::getLastName)} would return a {@code - * Comparator} that compares {@code Person} objects by their last - * name. - * - * @param the original element type - * @param the {@link Comparable} type for comparison - * @param keyExtractor the function used to extract the {@link Comparable} sort key - */ - public static > Comparator comparing(Function keyExtractor) { - Objects.requireNonNull(keyExtractor); - return (Comparator & Serializable) - (c1, c2) -> keyExtractor.apply(c1).compareTo(keyExtractor.apply(c2)); - } - - /** - * Accepts a function that extracts an {@code int} value from a type {@code - * T}, and returns a {@code Comparator} that compares by that value. - * - *

    The returned comparator is serializable assuming the specified - * function is also serializable. - * - * @see #comparing(Function) - * @param the original element type - * @param keyExtractor the function used to extract the integer value - */ - public static Comparator comparing(ToIntFunction keyExtractor) { - Objects.requireNonNull(keyExtractor); - return (Comparator & Serializable) - (c1, c2) -> Integer.compare(keyExtractor.applyAsInt(c1), keyExtractor.applyAsInt(c2)); - } - - /** - * Accepts a function that extracts a {@code long} value from a type {@code - * T}, and returns a {@code Comparator} that compares by that value. - * - *

    The returned comparator is serializable assuming the specified - * function is also serializable. - * - * @see #comparing(Function) - * @param the original element type - * @param keyExtractor the function used to extract the long value - */ - public static Comparator comparing(ToLongFunction keyExtractor) { - Objects.requireNonNull(keyExtractor); - return (Comparator & Serializable) - (c1, c2) -> Long.compare(keyExtractor.applyAsLong(c1), keyExtractor.applyAsLong(c2)); - } - - /** - * Accepts a function that extracts a {@code double} value from a type - * {@code T}, and returns a {@code Comparator} that compares by that - * value. - * - *

    The returned comparator is serializable assuming the specified - * function is also serializable. - * - * @see #comparing(Function) - * @param the original element type - * @param keyExtractor the function used to extract the double value - */ - public static Comparator comparing(ToDoubleFunction keyExtractor) { - Objects.requireNonNull(keyExtractor); - return (Comparator & Serializable) - (c1, c2) -> Double.compare(keyExtractor.applyAsDouble(c1), keyExtractor.applyAsDouble(c2)); - } - - /** - * Constructs a lexicographic order from two {@link Comparator}s. For - * example, if you have comparators {@code byLastName} and {@code - * byFirstName}, each of type {@code Comparator}, then {@code - * compose(byLastName, byFirstName)} creates a {@code Comparator} - * which sorts by last name, and for equal last names sorts by first name. - * - *

    The returned comparator is serializable assuming the specified - * comparators are also serializable. - * - * @param the element type to be compared - * @param first the first comparator - * @param second the secondary comparator used when equals on the first - */ - public static Comparator compose(Comparator first, Comparator second) { - Objects.requireNonNull(first); - Objects.requireNonNull(second); - return (Comparator & Serializable) (c1, c2) -> { - int res = first.compare(c1, c2); - return (res != 0) ? res : second.compare(c1, c2); - }; - } - - /** - * Constructs a {@link BinaryOperator} which returns the lesser of two elements - * according to the specified {@code Comparator} - * - * @param comparator A {@code Comparator} for comparing the two values - * @param the type of the elements to be compared - * @return a {@code BinaryOperator} which returns the lesser of its operands, - * according to the supplied {@code Comparator} - */ - public static BinaryOperator lesserOf(Comparator comparator) { - Objects.requireNonNull(comparator); - return (a, b) -> comparator.compare(a, b) <= 0 ? a : b; - } - - /** - * Constructs a {@link BinaryOperator} which returns the greater of two elements - * according to the specified {@code Comparator} - * - * @param comparator A {@code Comparator} for comparing the two values - * @param the type of the elements to be compared - * @return a {@code BinaryOperator} which returns the greater of its operands, - * according to the supplied {@code Comparator} - */ - public static BinaryOperator greaterOf(Comparator comparator) { - Objects.requireNonNull(comparator); - return (a, b) -> comparator.compare(a, b) >= 0 ? a : b; + @Override + public Comparator reversed() { + return new NullComparator(!nullFirst, real == null ? null : real.reversed()); + } } } diff --git a/jdk/src/share/classes/java/util/Map.java b/jdk/src/share/classes/java/util/Map.java index bfb72d7f10b..8ad16ee8323 100644 --- a/jdk/src/share/classes/java/util/Map.java +++ b/jdk/src/share/classes/java/util/Map.java @@ -28,6 +28,7 @@ package java.util; import java.util.function.BiConsumer; import java.util.function.BiFunction; import java.util.function.Function; +import java.io.Serializable; /** * An object that maps keys to values. A map cannot contain duplicate keys; @@ -446,6 +447,74 @@ public interface Map { * @see #equals(Object) */ int hashCode(); + + /** + * Returns a comparator that compares {@link Map.Entry} in natural order on key. + * + *

    The returned comparator is serializable and throws {@link + * NullPointerException} when comparing an entry with a null key. + * + * @param the {@link Comparable} type of then map keys + * @param the type of the map values + * @return a comparator that compares {@link Map.Entry} in natural order on key. + * @see Comparable + */ + public static , V> Comparator> comparingByKey() { + return (Comparator> & Serializable) + (c1, c2) -> c1.getKey().compareTo(c2.getKey()); + } + + /** + * Returns a comparator that compares {@link Map.Entry} in natural order on value. + * + *

    The returned comparator is serializable and throws {@link + * NullPointerException} when comparing an entry with null values. + * + * @param the type of the map keys + * @param the {@link Comparable} type of the map values + * @return a comparator that compares {@link Map.Entry} in natural order on value. + * @see Comparable + */ + public static > Comparator> comparingByValue() { + return (Comparator> & Serializable) + (c1, c2) -> c1.getValue().compareTo(c2.getValue()); + } + + /** + * Returns a comparator that compares {@link Map.Entry} by key using the given + * {@link Comparator}. + * + *

    The returned comparator is serializable if the specified comparator + * is also serializable. + * + * @param the type of the map keys + * @param the type of the map values + * @param cmp the key {@link Comparator} + * @return a comparator that compares {@link Map.Entry} by the key. + */ + public static Comparator> comparingByKey(Comparator cmp) { + Objects.requireNonNull(cmp); + return (Comparator> & Serializable) + (c1, c2) -> cmp.compare(c1.getKey(), c2.getKey()); + } + + /** + * Returns a comparator that compares {@link Map.Entry} by value using the given + * {@link Comparator}. + * + *

    The returned comparator is serializable if the specified comparator + * is also serializable. + * + * @param the type of the map keys + * @param the type of the map values + * @param cmp the value {@link Comparator} + * @return a comparator that compares {@link Map.Entry} by the value. + */ + public static Comparator> comparingByValue(Comparator cmp) { + Objects.requireNonNull(cmp); + return (Comparator> & Serializable) + (c1, c2) -> cmp.compare(c1.getValue(), c2.getValue()); + } } // Comparison and hashing diff --git a/jdk/src/share/classes/java/util/TreeMap.java b/jdk/src/share/classes/java/util/TreeMap.java index f34832c85a4..44d7449e07a 100644 --- a/jdk/src/share/classes/java/util/TreeMap.java +++ b/jdk/src/share/classes/java/util/TreeMap.java @@ -2938,13 +2938,13 @@ public class TreeMap public int characteristics() { return (side == 0 ? Spliterator.SIZED : 0) | - Spliterator.DISTINCT | Spliterator.SORTED | Spliterator.ORDERED; + Spliterator.DISTINCT | Spliterator.SORTED | Spliterator.ORDERED; } @Override public Comparator> getComparator() { return tree.comparator != null ? - Comparators.byKey(tree.comparator) : null; + Map.Entry.comparingByKey(tree.comparator) : null; } } } diff --git a/jdk/src/share/classes/java/util/function/BinaryOperator.java b/jdk/src/share/classes/java/util/function/BinaryOperator.java index e81bce8c553..85b3db797b1 100644 --- a/jdk/src/share/classes/java/util/function/BinaryOperator.java +++ b/jdk/src/share/classes/java/util/function/BinaryOperator.java @@ -24,6 +24,9 @@ */ package java.util.function; +import java.util.Objects; +import java.util.Comparator; + /** * An operation upon two operands yielding a result. This is a specialization of * {@code BiFunction} where the operands and the result are all of the same type. @@ -35,4 +38,31 @@ package java.util.function; */ @FunctionalInterface public interface BinaryOperator extends BiFunction { + /** + * Returns a {@link BinaryOperator} which returns the lesser of two elements + * according to the specified {@code Comparator} + * + * @param comparator a {@code Comparator} for comparing the two values + * @return a {@code BinaryOperator} which returns the lesser of its operands, + * according to the supplied {@code Comparator} + * @throws NullPointerException if the argument is null + */ + public static BinaryOperator minBy(Comparator comparator) { + Objects.requireNonNull(comparator); + return (a, b) -> comparator.compare(a, b) <= 0 ? a : b; + } + + /** + * Returns a {@link BinaryOperator} which returns the greater of two elements + * according to the specified {@code Comparator} + * + * @param comparator a {@code Comparator} for comparing the two values + * @return a {@code BinaryOperator} which returns the greater of its operands, + * according to the supplied {@code Comparator} + * @throws NullPointerException if the argument is null + */ + public static BinaryOperator maxBy(Comparator comparator) { + Objects.requireNonNull(comparator); + return (a, b) -> comparator.compare(a, b) >= 0 ? a : b; + } } diff --git a/jdk/src/share/classes/java/util/stream/Collectors.java b/jdk/src/share/classes/java/util/stream/Collectors.java index 0d14c888e9e..8f5e8ff42e4 100644 --- a/jdk/src/share/classes/java/util/stream/Collectors.java +++ b/jdk/src/share/classes/java/util/stream/Collectors.java @@ -30,7 +30,6 @@ import java.util.ArrayList; import java.util.Collection; import java.util.Collections; import java.util.Comparator; -import java.util.Comparators; import java.util.DoubleSummaryStatistics; import java.util.EnumSet; import java.util.HashMap; @@ -78,7 +77,7 @@ import java.util.function.ToLongFunction; * * // Find highest-paid employee * Employee highestPaid = employees.stream() - * .collect(Collectors.maxBy(Comparators.comparing(Employee::getSalary))); + * .collect(Collectors.maxBy(Comparator.comparing(Employee::getSalary))); * * // Group employees by department * Map> byDept @@ -89,7 +88,7 @@ import java.util.function.ToLongFunction; * Map highestPaidByDept * = employees.stream() * .collect(Collectors.groupingBy(Employee::getDepartment, - * Collectors.maxBy(Comparators.comparing(Employee::getSalary)))); + * Collectors.maxBy(Comparator.comparing(Employee::getSalary)))); * * // Partition students into passing and failing * Map> passingFailing = @@ -404,7 +403,7 @@ public final class Collectors { * @implSpec * This produces a result equivalent to: *

    {@code
    -     *     reducing(Comparators.lesserOf(comparator))
    +     *     reducing(BinaryOperator.minBy(comparator))
          * }
    * * @param the type of the input elements @@ -413,7 +412,7 @@ public final class Collectors { */ public static Collector minBy(Comparator comparator) { - return reducing(Comparators.lesserOf(comparator)); + return reducing(BinaryOperator.minBy(comparator)); } /** @@ -423,7 +422,7 @@ public final class Collectors { * @implSpec * This produces a result equivalent to: *
    {@code
    -     *     reducing(Comparators.greaterOf(comparator))
    +     *     reducing(BinaryOperator.maxBy(comparator))
          * }
    * * @param the type of the input elements @@ -432,7 +431,7 @@ public final class Collectors { */ public static Collector maxBy(Comparator comparator) { - return reducing(Comparators.greaterOf(comparator)); + return reducing(BinaryOperator.maxBy(comparator)); } /** @@ -491,8 +490,8 @@ public final class Collectors { *

    For example, given a stream of {@code Person}, to calculate tallest * person in each city: *

    {@code
    -     *     Comparator byHeight = Comparators.comparing(Person::getHeight);
    -     *     BinaryOperator tallerOf = Comparators.greaterOf(byHeight);
    +     *     Comparator byHeight = Comparator.comparing(Person::getHeight);
    +     *     BinaryOperator tallerOf = BinaryOperator.greaterOf(byHeight);
          *     Map tallestByCity
          *         = people.stream().collect(groupingBy(Person::getCity, reducing(tallerOf)));
          * }
    @@ -531,8 +530,8 @@ public final class Collectors { *

    For example, given a stream of {@code Person}, to calculate the longest * last name of residents in each city: *

    {@code
    -     *     Comparator byLength = Comparators.comparing(String::length);
    -     *     BinaryOperator longerOf = Comparators.greaterOf(byLength);
    +     *     Comparator byLength = Comparator.comparing(String::length);
    +     *     BinaryOperator longerOf = BinaryOperator.greaterOf(byLength);
          *     Map longestLastNameByCity
          *         = people.stream().collect(groupingBy(Person::getCity,
          *                                              reducing(Person::getLastName, longerOf)));
    diff --git a/jdk/src/share/classes/java/util/stream/ReferencePipeline.java b/jdk/src/share/classes/java/util/stream/ReferencePipeline.java
    index 6e3beca1f11..8a86c2d6c3b 100644
    --- a/jdk/src/share/classes/java/util/stream/ReferencePipeline.java
    +++ b/jdk/src/share/classes/java/util/stream/ReferencePipeline.java
    @@ -25,7 +25,6 @@
     package java.util.stream;
     
     import java.util.Comparator;
    -import java.util.Comparators;
     import java.util.Iterator;
     import java.util.Objects;
     import java.util.Optional;
    @@ -512,12 +511,12 @@ abstract class ReferencePipeline
     
         @Override
         public final Optional max(Comparator comparator) {
    -        return reduce(Comparators.greaterOf(comparator));
    +        return reduce(BinaryOperator.maxBy(comparator));
         }
     
         @Override
         public final Optional min(Comparator comparator) {
    -        return reduce(Comparators.lesserOf(comparator));
    +        return reduce(BinaryOperator.minBy(comparator));
     
         }
     
    diff --git a/jdk/src/share/classes/java/util/stream/SortedOps.java b/jdk/src/share/classes/java/util/stream/SortedOps.java
    index 7b2a6934b4e..de02ba8e32f 100644
    --- a/jdk/src/share/classes/java/util/stream/SortedOps.java
    +++ b/jdk/src/share/classes/java/util/stream/SortedOps.java
    @@ -27,7 +27,6 @@ package java.util.stream;
     import java.util.ArrayList;
     import java.util.Arrays;
     import java.util.Comparator;
    -import java.util.Comparators;
     import java.util.Objects;
     import java.util.Spliterator;
     import java.util.concurrent.ForkJoinTask;
    @@ -114,7 +113,7 @@ final class SortedOps {
                       StreamOpFlag.IS_ORDERED | StreamOpFlag.IS_SORTED);
                 this.isNaturalSort = true;
                 // Will throw CCE when we try to sort if T is not Comparable
    -            this.comparator = (Comparator) Comparators.naturalOrder();
    +            this.comparator = (Comparator) Comparator.naturalOrder();
             }
     
             /**
    diff --git a/jdk/test/java/nio/file/Files/StreamTest.java b/jdk/test/java/nio/file/Files/StreamTest.java
    index 0033dd31f38..b5ff2977257 100644
    --- a/jdk/test/java/nio/file/Files/StreamTest.java
    +++ b/jdk/test/java/nio/file/Files/StreamTest.java
    @@ -43,7 +43,7 @@ import java.nio.file.Path;
     import java.nio.file.Paths;
     import java.nio.file.attribute.BasicFileAttributes;
     import java.util.Arrays;
    -import java.util.Comparators;
    +import java.util.Comparator;
     import java.util.Iterator;
     import java.util.List;
     import java.util.Objects;
    @@ -139,7 +139,7 @@ public class StreamTest {
     
         public void testBasic() {
             try (CloseableStream s = Files.list(testFolder)) {
    -            Object[] actual = s.sorted(Comparators.naturalOrder()).toArray();
    +            Object[] actual = s.sorted(Comparator.naturalOrder()).toArray();
                 assertEquals(actual, level1);
             } catch (IOException ioe) {
                 fail("Unexpected IOException");
    @@ -155,7 +155,7 @@ public class StreamTest {
     
         public void testWalk() {
             try (CloseableStream s = Files.walk(testFolder)) {
    -            Object[] actual = s.sorted(Comparators.naturalOrder()).toArray();
    +            Object[] actual = s.sorted(Comparator.naturalOrder()).toArray();
                 assertEquals(actual, all);
             } catch (IOException ioe) {
                 fail("Unexpected IOException");
    @@ -165,7 +165,7 @@ public class StreamTest {
         public void testWalkOneLevel() {
             try (CloseableStream s = Files.walk(testFolder, 1)) {
                 Object[] actual = s.filter(path -> ! path.equals(testFolder))
    -                               .sorted(Comparators.naturalOrder())
    +                               .sorted(Comparator.naturalOrder())
                                    .toArray();
                 assertEquals(actual, level1);
             } catch (IOException ioe) {
    @@ -177,7 +177,7 @@ public class StreamTest {
             // If link is not supported, the directory structure won't have link.
             // We still want to test the behavior with FOLLOW_LINKS option.
             try (CloseableStream s = Files.walk(testFolder, FileVisitOption.FOLLOW_LINKS)) {
    -            Object[] actual = s.sorted(Comparators.naturalOrder()).toArray();
    +            Object[] actual = s.sorted(Comparator.naturalOrder()).toArray();
                 assertEquals(actual, all_folowLinks);
             } catch (IOException ioe) {
                 fail("Unexpected IOException");
    @@ -637,13 +637,13 @@ public class StreamTest {
         public void testClosedStream() throws IOException {
             try (CloseableStream s = Files.list(testFolder)) {
                 s.close();
    -            Object[] actual = s.sorted(Comparators.naturalOrder()).toArray();
    +            Object[] actual = s.sorted(Comparator.naturalOrder()).toArray();
                 assertTrue(actual.length <= level1.length);
             }
     
             try (CloseableStream s = Files.walk(testFolder)) {
                 s.close();
    -            Object[] actual = s.sorted(Comparators.naturalOrder()).toArray();
    +            Object[] actual = s.sorted(Comparator.naturalOrder()).toArray();
                 fail("Operate on closed stream should throw IllegalStateException");
             } catch (IllegalStateException ex) {
                 // expected
    @@ -652,7 +652,7 @@ public class StreamTest {
             try (CloseableStream s = Files.find(testFolder, Integer.MAX_VALUE,
                         (p, attr) -> true)) {
                 s.close();
    -            Object[] actual = s.sorted(Comparators.naturalOrder()).toArray();
    +            Object[] actual = s.sorted(Comparator.naturalOrder()).toArray();
                 fail("Operate on closed stream should throw IllegalStateException");
             } catch (IllegalStateException ex) {
                 // expected
    diff --git a/jdk/test/java/util/Collection/ListDefaults.java b/jdk/test/java/util/Collection/ListDefaults.java
    index 6011fbf7804..e0f8e6f6992 100644
    --- a/jdk/test/java/util/Collection/ListDefaults.java
    +++ b/jdk/test/java/util/Collection/ListDefaults.java
    @@ -25,7 +25,6 @@ import java.util.ArrayList;
     import java.util.Arrays;
     import java.util.Collections;
     import java.util.Comparator;
    -import java.util.Comparators;
     import java.util.List;
     import java.util.LinkedList;
     import java.util.Stack;
    @@ -337,23 +336,23 @@ public class ListDefaults {
     
                 CollectionSupplier.shuffle(list);
                 list.sort(null);
    -            CollectionAsserts.assertSorted(list, Comparators.naturalOrder());
    +            CollectionAsserts.assertSorted(list, Comparator.naturalOrder());
                 if (test.name.startsWith("reverse")) {
                     Collections.reverse(list);
                 }
                 CollectionAsserts.assertContents(list, original);
     
                 CollectionSupplier.shuffle(list);
    -            list.sort(Comparators.naturalOrder());
    -            CollectionAsserts.assertSorted(list, Comparators.naturalOrder());
    +            list.sort(Comparator.naturalOrder());
    +            CollectionAsserts.assertSorted(list, Comparator.naturalOrder());
                 if (test.name.startsWith("reverse")) {
                     Collections.reverse(list);
                 }
                 CollectionAsserts.assertContents(list, original);
     
                 CollectionSupplier.shuffle(list);
    -            list.sort(Comparators.reverseOrder());
    -            CollectionAsserts.assertSorted(list, Comparators.reverseOrder());
    +            list.sort(Comparator.reverseOrder());
    +            CollectionAsserts.assertSorted(list, Comparator.reverseOrder());
                 if (!test.name.startsWith("reverse")) {
                     Collections.reverse(list);
                 }
    @@ -390,8 +389,8 @@ public class ListDefaults {
                     final List copy = new ArrayList<>(list);
                     final List subList = list.subList(SUBLIST_FROM, SUBLIST_TO);
                     CollectionSupplier.shuffle(subList);
    -                subList.sort(Comparators.naturalOrder());
    -                CollectionAsserts.assertSorted(subList, Comparators.naturalOrder());
    +                subList.sort(Comparator.naturalOrder());
    +                CollectionAsserts.assertSorted(subList, Comparator.naturalOrder());
                     // verify that elements [0, from) remain unmodified
                     for (int i = 0; i < SUBLIST_FROM; i++) {
                         assertTrue(list.get(i) == copy.get(i),
    @@ -412,8 +411,8 @@ public class ListDefaults {
                     public void call(final List list) {
                         final List copy = new ArrayList<>(list);
                         CollectionSupplier.shuffle(list);
    -                    list.sort(Comparators.naturalOrder());
    -                    CollectionAsserts.assertSorted(list, Comparators.naturalOrder());
    +                    list.sort(Comparator.naturalOrder());
    +                    CollectionAsserts.assertSorted(list, Comparator.naturalOrder());
                     }
                 });
             }
    diff --git a/jdk/test/java/util/Comparators/BasicTest.java b/jdk/test/java/util/Comparator/BasicTest.java
    similarity index 55%
    rename from jdk/test/java/util/Comparators/BasicTest.java
    rename to jdk/test/java/util/Comparator/BasicTest.java
    index 0913eb84b58..5bbb700e0b3 100644
    --- a/jdk/test/java/util/Comparators/BasicTest.java
    +++ b/jdk/test/java/util/Comparator/BasicTest.java
    @@ -1,5 +1,5 @@
     /*
    - * Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved.
    + * Copyright (c) 2013, 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
    @@ -21,19 +21,16 @@
      * questions.
      */
     
    -/*
    +/**
      * @test
    - * @bug 8001667 8010279
    + * @summary Comparator default method tests
      * @run testng BasicTest
      */
     
    +import java.util.TreeMap;
     import java.util.Comparator;
    -import java.util.Comparators;
    -import java.util.AbstractMap;
    -import java.util.Map;
     import org.testng.annotations.Test;
     
    -import java.util.function.BinaryOperator;
     import java.util.function.Function;
     import java.util.function.ToIntFunction;
     import java.util.function.ToLongFunction;
    @@ -41,12 +38,8 @@ import java.util.function.ToDoubleFunction;
     
     import static org.testng.Assert.assertEquals;
     import static org.testng.Assert.assertTrue;
    -import static org.testng.Assert.assertSame;
     import static org.testng.Assert.fail;
     
    -/**
    - * Unit tests for helper methods in Comparators
    - */
     @Test(groups = "unit")
     public class BasicTest {
         private static class Thing {
    @@ -97,7 +90,7 @@ public class BasicTest {
             Thing[] things = new Thing[intValues.length];
             for (int i=0; i comp = Comparators.comparing(new ToIntFunction() {
    +        Comparator comp = Comparator.comparing(new ToIntFunction() {
                 @Override
                 public int applyAsInt(Thing thing) {
                     return thing.getIntField();
    @@ -111,7 +104,7 @@ public class BasicTest {
             Thing[] things = new Thing[longValues.length];
             for (int i=0; i comp = Comparators.comparing(new ToLongFunction() {
    +        Comparator comp = Comparator.comparing(new ToLongFunction() {
                 @Override
                 public long applyAsLong(Thing thing) {
                     return thing.getLongField();
    @@ -125,7 +118,7 @@ public class BasicTest {
             Thing[] things = new Thing[doubleValues.length];
             for (int i=0; i comp = Comparators.comparing(new ToDoubleFunction() {
    +        Comparator comp = Comparator.comparing(new ToDoubleFunction() {
                 @Override
                 public double applyAsDouble(Thing thing) {
                     return thing.getDoubleField();
    @@ -139,7 +132,7 @@ public class BasicTest {
             Thing[] things = new Thing[doubleValues.length];
             for (int i=0; i comp = Comparators.comparing(new Function() {
    +        Comparator comp = Comparator.comparing(new Function() {
                 @Override
                 public String apply(Thing thing) {
                     return thing.getStringField();
    @@ -150,16 +143,16 @@ public class BasicTest {
         }
     
         public void testNaturalOrderComparator() {
    -        Comparator comp = Comparators.naturalOrder();
    +        Comparator comp = Comparator.naturalOrder();
     
             assertComparisons(stringValues, comp, comparisons);
         }
     
         public void testReverseComparator() {
    -        Comparator cmpr = Comparators.reverseOrder();
    -        Comparator cmp = cmpr.reverseOrder();
    +        Comparator cmpr = Comparator.reverseOrder();
    +        Comparator cmp = cmpr.reversed();
     
    -        assertEquals(cmp.reverseOrder(), cmpr);
    +        assertEquals(cmp.reversed(), cmpr);
             assertEquals(0, cmp.compare("a", "a"));
             assertEquals(0, cmpr.compare("a", "a"));
             assertTrue(cmp.compare("a", "b") < 0);
    @@ -170,9 +163,9 @@ public class BasicTest {
     
         public void testReverseComparator2() {
             Comparator cmp = (s1, s2) -> s1.length() - s2.length();
    -        Comparator cmpr = cmp.reverseOrder();
    +        Comparator cmpr = cmp.reversed();
     
    -        assertEquals(cmpr.reverseOrder(), cmp);
    +        assertEquals(cmpr.reversed(), cmp);
             assertEquals(0, cmp.compare("abc", "def"));
             assertEquals(0, cmpr.compare("abc", "def"));
             assertTrue(cmp.compare("abcd", "def") > 0);
    @@ -181,71 +174,11 @@ public class BasicTest {
             assertTrue(cmpr.compare("abc", "defg") > 0);
         }
     
    -    @Test(expectedExceptions=NullPointerException.class)
    -    public void testReverseComparatorNPE() {
    -        Comparator cmp = Comparators.reverseOrder(null);
    -    }
    -
    -    public void testComposeComparator() {
    -        // Longer string in front
    -        Comparator first = (s1, s2) -> s2.length() - s1.length();
    -        Comparator second = Comparators.naturalOrder();
    -        Comparator composed = Comparators.compose(first, second);
    -
    -        assertTrue(composed.compare("abcdefg", "abcdef") < 0);
    -        assertTrue(composed.compare("abcdef", "abcdefg") > 0);
    -        assertTrue(composed.compare("abcdef", "abcdef") == 0);
    -        assertTrue(composed.compare("abcdef", "ghijkl") < 0);
    -        assertTrue(composed.compare("ghijkl", "abcdefg") > 0);
    -    }
    -
    -    private  void assertPairComparison(K k1, V v1, K k2, V v2,
    -                                        Comparator> ck,
    -                                        Comparator> cv) {
    -        final Map.Entry p11 = new AbstractMap.SimpleImmutableEntry<>(k1, v1);
    -        final Map.Entry p12 = new AbstractMap.SimpleImmutableEntry<>(k1, v2);
    -        final Map.Entry p21 = new AbstractMap.SimpleImmutableEntry<>(k2, v1);
    -        final Map.Entry p22 = new AbstractMap.SimpleImmutableEntry<>(k2, v2);
    -
    -        assertTrue(ck.compare(p11, p11) == 0);
    -        assertTrue(ck.compare(p12, p11) == 0);
    -        assertTrue(ck.compare(p11, p12) == 0);
    -        assertTrue(ck.compare(p12, p22) < 0);
    -        assertTrue(ck.compare(p12, p21) < 0);
    -        assertTrue(ck.compare(p21, p11) > 0);
    -        assertTrue(ck.compare(p21, p12) > 0);
    -
    -        assertTrue(cv.compare(p11, p11) == 0);
    -        assertTrue(cv.compare(p12, p11) > 0);
    -        assertTrue(cv.compare(p11, p12) < 0);
    -        assertTrue(cv.compare(p12, p22) == 0);
    -        assertTrue(cv.compare(p12, p21) > 0);
    -        assertTrue(cv.compare(p21, p11) == 0);
    -        assertTrue(cv.compare(p21, p12) < 0);
    -
    -        Comparator> cmp = Comparators.compose(ck, cv);
    -        assertTrue(cmp.compare(p11, p11) == 0);
    -        assertTrue(cmp.compare(p12, p11) > 0);
    -        assertTrue(cmp.compare(p11, p12) < 0);
    -        assertTrue(cmp.compare(p12, p22) < 0);
    -        assertTrue(cmp.compare(p12, p21) < 0);
    -        assertTrue(cmp.compare(p21, p11) > 0);
    -        assertTrue(cmp.compare(p21, p12) > 0);
    -
    -        cmp = Comparators.compose(cv, ck);
    -        assertTrue(cmp.compare(p11, p11) == 0);
    -        assertTrue(cmp.compare(p12, p11) > 0);
    -        assertTrue(cmp.compare(p11, p12) < 0);
    -        assertTrue(cmp.compare(p12, p22) < 0);
    -        assertTrue(cmp.compare(p12, p21) > 0);
    -        assertTrue(cmp.compare(p21, p11) > 0);
    -        assertTrue(cmp.compare(p21, p12) < 0);
    -    }
    -
    -    public void testKVComparatorable() {
    -        assertPairComparison(1, "ABC", 2, "XYZ",
    -                         Comparators.naturalOrderKeys(),
    -                         Comparators.naturalOrderValues());
    +    private  void assertComparison(Comparator cmp, T less, T greater) {
    +        assertTrue(cmp.compare(less, greater) < 0, "less");
    +        assertTrue(cmp.compare(less, less) == 0, "equal");
    +        assertTrue(cmp.compare(greater, greater) == 0, "equal");
    +        assertTrue(cmp.compare(greater, less) > 0, "greater");
         }
     
         private static class People {
    @@ -273,33 +206,15 @@ public class BasicTest {
             new People("Jonah", "Doe", 10),
             new People("John", "Cook", 54),
             new People("Mary", "Cook", 50),
    +        new People("Mary", null, 25),
    +        new People("John", null, 27)
         };
     
    -    public void testKVComparators() {
    -        // Comparator cmp = Comparators.naturalOrder(); // Should fail to compiler as People is not comparable
    -        // We can use simple comparator, but those have been tested above.
    -        // Thus choose to do compose for some level of interation.
    -        Comparator cmp1 = Comparators.comparing((Function) People::getFirstName);
    -        Comparator cmp2 = Comparators.comparing((Function) People::getLastName);
    -        Comparator cmp = Comparators.compose(cmp1, cmp2);
    -
    -        assertPairComparison(people[0], people[0], people[1], people[1],
    -                         Comparators.byKey(cmp),
    -                         Comparators.byValue(cmp));
    -
    -    }
    -
    -    private  void assertComparison(Comparator cmp, T less, T greater) {
    -        assertTrue(cmp.compare(less, greater) < 0, "less");
    -        assertTrue(cmp.compare(less, less) == 0, "equal");
    -        assertTrue(cmp.compare(greater, less) > 0, "greater");
    -    }
    -
         public void testComparatorDefaultMethods() {
    -        Comparator cmp = Comparators.comparing((Function) People::getFirstName);
    -        Comparator cmp2 = Comparators.comparing((Function) People::getLastName);
    +        Comparator cmp = Comparator.comparing((Function) People::getFirstName);
    +        Comparator cmp2 = Comparator.comparing((Function) People::getLastName);
             // reverseOrder
    -        assertComparison(cmp.reverseOrder(), people[1], people[0]);
    +        assertComparison(cmp.reversed(), people[1], people[0]);
             // thenComparing(Comparator)
             assertComparison(cmp.thenComparing(cmp2), people[0], people[1]);
             assertComparison(cmp.thenComparing(cmp2), people[4], people[0]);
    @@ -317,96 +232,138 @@ public class BasicTest {
             assertComparison(cmp.thenComparing(People::getAgeAsDouble), people[1], people[5]);
         }
     
    -    public void testGreaterOf() {
    -        // lesser
    -        assertSame(Comparators.greaterOf(Comparators.comparing(
    -                                    (Function) People::getFirstName))
    -                              .apply(people[0], people[1]),
    -                   people[1]);
    -        // euqal
    -        assertSame(Comparators.greaterOf(Comparators.comparing(
    -                                    (Function) People::getLastName))
    -                              .apply(people[0], people[1]),
    -                   people[0]);
    -        // greater
    -        assertSame(Comparators.greaterOf(Comparators.comparing(
    -                                    (ToIntFunction) People::getAge))
    -                              .apply(people[0], people[1]),
    -                   people[0]);
    +
    +    public void testNullsFirst() {
    +        Comparator strcmp = Comparator.nullsFirst(Comparator.naturalOrder());
    +        Comparator cmp = Comparator.comparing(People::getLastName, strcmp)
    +                                           .thenComparing(People::getFirstName, strcmp);
    +        // Mary.null vs Mary.Cook - solve by last name
    +        assertComparison(cmp, people[6], people[5]);
    +        // John.null vs Mary.null - solve by first name
    +        assertComparison(cmp, people[7], people[6]);
    +
    +        // More than one thenComparing
    +        strcmp = Comparator.nullsFirst(Comparator.comparing((ToIntFunction) String::length)
    +                                                 .thenComparing(String.CASE_INSENSITIVE_ORDER));
    +        assertComparison(strcmp, null, "abc");
    +        assertComparison(strcmp, "ab", "abc");
    +        assertComparison(strcmp, "abc", "def");
    +        assertEquals(0, strcmp.compare("abc", "ABC"));
    +
    +        // Ensure reverse still handle null properly
    +        Comparator strcmp2 = strcmp.reversed().thenComparing(Comparator.naturalOrder());
    +        assertComparison(strcmp2, "abc", null);
    +        assertComparison(strcmp2, "abc", "ab");
    +        assertComparison(strcmp2, "def", "abc");
    +        assertComparison(strcmp2, "ABC", "abc");
    +
    +        // Considering non-null values to be equal
    +        Comparator blind = Comparator.nullsFirst(null);
    +        assertComparison(blind, null, "abc");
    +        assertEquals(0, blind.compare("abc", "def"));
    +        // reverse still consider non-null values to be equal
    +        strcmp = blind.reversed();
    +        assertComparison(strcmp, "abc", null);
    +        assertEquals(0, strcmp.compare("abc", "def"));
    +        // chain with another comparator to compare non-nulls
    +        strcmp = blind.thenComparing(Comparator.naturalOrder());
    +        assertComparison(strcmp, null, "abc");
    +        assertComparison(strcmp, "abc", "def");
         }
     
    -    public void testLesserOf() {
    -        // lesser
    -        assertSame(Comparators.lesserOf(Comparators.comparing(
    -                                    (Function) People::getFirstName))
    -                              .apply(people[0], people[1]),
    -                   people[0]);
    -        // euqal
    -        assertSame(Comparators.lesserOf(Comparators.comparing(
    -                                    (Function) People::getLastName))
    -                              .apply(people[0], people[1]),
    -                   people[0]);
    -        // greater
    -        assertSame(Comparators.lesserOf(Comparators.comparing(
    -                                    (ToIntFunction) People::getAge))
    -                              .apply(people[0], people[1]),
    -                   people[1]);
    +    public void testNullsLast() {
    +        Comparator strcmp = Comparator.nullsLast(Comparator.naturalOrder());
    +        Comparator cmp = Comparator.comparing(People::getLastName, strcmp)
    +                                           .thenComparing(People::getFirstName, strcmp);
    +        // Mary.null vs Mary.Cook - solve by last name
    +        assertComparison(cmp, people[5], people[6]);
    +        // John.null vs Mary.null - solve by first name
    +        assertComparison(cmp, people[7], people[6]);
    +
    +        // More than one thenComparing
    +        strcmp = Comparator.nullsLast(Comparator.comparing((ToIntFunction) String::length)
    +                                                .thenComparing(String.CASE_INSENSITIVE_ORDER));
    +        assertComparison(strcmp, "abc", null);
    +        assertComparison(strcmp, "ab", "abc");
    +        assertComparison(strcmp, "abc", "def");
    +
    +        // Ensure reverse still handle null properly
    +        Comparator strcmp2 = strcmp.reversed().thenComparing(Comparator.naturalOrder());
    +        assertComparison(strcmp2, null, "abc");
    +        assertComparison(strcmp2, "abc", "ab");
    +        assertComparison(strcmp2, "def", "abc");
    +        assertComparison(strcmp2, "ABC", "abc");
    +
    +        // Considering non-null values to be equal
    +        Comparator blind = Comparator.nullsLast(null);
    +        assertComparison(blind, "abc", null);
    +        assertEquals(0, blind.compare("abc", "def"));
    +        // reverse still consider non-null values to be equal
    +        strcmp = blind.reversed();
    +        assertComparison(strcmp, null, "abc");
    +        assertEquals(0, strcmp.compare("abc", "def"));
    +        // chain with another comparator to compare non-nulls
    +        strcmp = blind.thenComparing(Comparator.naturalOrder());
    +        assertComparison(strcmp, "abc", null);
    +        assertComparison(strcmp, "abc", "def");
    +    }
    +
    +    public void testComposeComparator() {
    +        // Longer string in front
    +        Comparator first = (s1, s2) -> s2.length() - s1.length();
    +        Comparator second = Comparator.naturalOrder();
    +        Comparator composed = first.thenComparing(second);
    +
    +        assertTrue(composed.compare("abcdefg", "abcdef") < 0);
    +        assertTrue(composed.compare("abcdef", "abcdefg") > 0);
    +        assertTrue(composed.compare("abcdef", "abcdef") == 0);
    +        assertTrue(composed.compare("abcdef", "ghijkl") < 0);
    +        assertTrue(composed.compare("ghijkl", "abcdefg") > 0);
         }
     
         public void testNulls() {
             try {
    -            Comparators.naturalOrder().compare("abc", (String) null);
    +            Comparator.naturalOrder().compare("abc", (String) null);
                 fail("expected NPE with naturalOrder");
             } catch (NullPointerException npe) {}
             try {
    -            Comparators.naturalOrder().compare((String) null, "abc");
    +            Comparator.naturalOrder().compare((String) null, "abc");
                 fail("expected NPE with naturalOrder");
             } catch (NullPointerException npe) {}
     
             try {
    -            Comparators.reverseOrder().compare("abc", (String) null);
    +            Comparator.reverseOrder().compare("abc", (String) null);
                 fail("expected NPE with naturalOrder");
             } catch (NullPointerException npe) {}
             try {
    -            Comparators.reverseOrder().compare((String) null, "abc");
    +            Comparator.reverseOrder().compare((String) null, "abc");
                 fail("expected NPE with naturalOrder");
             } catch (NullPointerException npe) {}
     
             try {
    -            Comparator> cmp = Comparators.byKey(null);
    -            fail("byKey(null) should throw NPE");
    +            Comparator cmp = Comparator.comparing((Function) null, Comparator.naturalOrder());
    +            fail("comparing(null, cmp) should throw NPE");
    +        } catch (NullPointerException npe) {}
    +        try {
    +            Comparator cmp = Comparator.comparing((Function) People::getFirstName, null);
    +            fail("comparing(f, null) should throw NPE");
             } catch (NullPointerException npe) {}
     
             try {
    -            Comparator> cmp = Comparators.byValue(null);
    -            fail("byValue(null) should throw NPE");
    -        } catch (NullPointerException npe) {}
    -
    -        try {
    -            Comparator cmp = Comparators.comparing((Function) null);
    +            Comparator cmp = Comparator.comparing((Function) null);
                 fail("comparing(null) should throw NPE");
             } catch (NullPointerException npe) {}
             try {
    -            Comparator cmp = Comparators.comparing((ToIntFunction) null);
    +            Comparator cmp = Comparator.comparing((ToIntFunction) null);
                 fail("comparing(null) should throw NPE");
             } catch (NullPointerException npe) {}
             try {
    -            Comparator cmp = Comparators.comparing((ToLongFunction) null);
    +            Comparator cmp = Comparator.comparing((ToLongFunction) null);
                 fail("comparing(null) should throw NPE");
             } catch (NullPointerException npe) {}
             try {
    -            Comparator cmp = Comparators.comparing((ToDoubleFunction) null);
    +            Comparator cmp = Comparator.comparing((ToDoubleFunction) null);
                 fail("comparing(null) should throw NPE");
             } catch (NullPointerException npe) {}
    -
    -        try {
    -            BinaryOperator op = Comparators.lesserOf(null);
    -            fail("lesserOf(null) should throw NPE");
    -        } catch (NullPointerException npe) {}
    -
    -        try {
    -            BinaryOperator op = Comparators.greaterOf(null);
    -            fail("lesserOf(null) should throw NPE");
    -        } catch (NullPointerException npe) {}
         }
     }
    diff --git a/jdk/test/java/util/Comparator/TypeTest.java b/jdk/test/java/util/Comparator/TypeTest.java
    new file mode 100644
    index 00000000000..b1c8a41cf3a
    --- /dev/null
    +++ b/jdk/test/java/util/Comparator/TypeTest.java
    @@ -0,0 +1,96 @@
    +/*
    + * Copyright (c) 2013, 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 Comparator API narrowing type test
    + * @run testng TypeTest
    + */
    +
    +import java.util.function.Function;
    +import java.util.Map;
    +import java.util.TreeMap;
    +import java.util.Comparator;
    +import org.testng.annotations.Test;
    +
    +@Test(groups = "unit")
    +public class TypeTest {
    +    static class Person {
    +        String name;
    +        static Comparator C = (p1, p2) -> p1.name.compareTo(p2.name);
    +
    +        Person(String name) {
    +            this.name = name;
    +        }
    +
    +        String getName() { return name; }
    +    }
    +
    +    static class Employee extends Person {
    +        int id;
    +        static Comparator C = (e1, e2) -> e1.id - e2.id;
    +
    +        Employee(int id, String name) {
    +            super(name);
    +            this.id = id;
    +        }
    +    }
    +
    +    static class Manager extends Employee {
    +        long reports;
    +        static Comparator C = (e1, e2) -> (int) (e1.reports - e2.reports);
    +
    +        Manager(String name, int id, long reports) {
    +            super(id, name);
    +            this.reports = reports;
    +        }
    +    }
    +
    +    static  void assertOrder(T o1, T o2, Comparator cmp) {
    +        if (cmp.compare(o1, o2) > 0) {
    +            System.out.println("Fail!!");
    +        }
    +        if (cmp.compare(o1, o2) == 0) {
    +            System.out.println("Equal!!");
    +        }
    +    }
    +
    +    public static void main(String[] args) {
    +        Manager m1 = new Manager("Manager", 2, 2000);
    +        Manager m2 = new Manager("Manager", 4, 1300);
    +
    +        // Comparator tmp = Person.C;
    +
    +        // Comparator cmp = Employee.C.thenComparing(Person.C);
    +        Comparator cmp = Employee.C.thenComparing(Person.C);
    +        assertOrder(m1, m2, Employee.C.thenComparing(Person.C));
    +        assertOrder(m1, m2, cmp);
    +        assertOrder(m1, new Employee(1, "Z"), Person.C);
    +        assertOrder(new Employee(1, "Z"), m2, Employee.C);
    +
    +        assertOrder(m1, m2, Comparator.comparing(Employee::getName, String.CASE_INSENSITIVE_ORDER));
    +
    +        Map map = new TreeMap<>();
    +        map.entrySet().stream().sorted(Map.Entry.comparingByKey(String.CASE_INSENSITIVE_ORDER));
    +    }
    +}
    diff --git a/jdk/test/java/util/Map/EntryComparators.java b/jdk/test/java/util/Map/EntryComparators.java
    new file mode 100644
    index 00000000000..ce607a36901
    --- /dev/null
    +++ b/jdk/test/java/util/Map/EntryComparators.java
    @@ -0,0 +1,139 @@
    +/*
    + * Copyright (c) 2012, 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
    + * @bug 8009736 8010279
    + * @run testng EntryComparators
    + */
    +import java.util.function.Function;
    +import java.util.Comparator;
    +import java.util.AbstractMap;
    +import java.util.Map;
    +import org.testng.annotations.Test;
    +
    +import static org.testng.Assert.assertTrue;
    +import static org.testng.Assert.fail;
    +
    +/**
    + * Unit tests for Map.Entry.comparing
    + */
    +@Test(groups = "unit")
    +public class EntryComparators {
    +
    +    private  void assertPairComparison(K k1, V v1, K k2, V v2,
    +                                        Comparator> ck,
    +                                        Comparator> cv) {
    +        final Map.Entry p11 = new AbstractMap.SimpleImmutableEntry<>(k1, v1);
    +        final Map.Entry p12 = new AbstractMap.SimpleImmutableEntry<>(k1, v2);
    +        final Map.Entry p21 = new AbstractMap.SimpleImmutableEntry<>(k2, v1);
    +        final Map.Entry p22 = new AbstractMap.SimpleImmutableEntry<>(k2, v2);
    +
    +        assertTrue(ck.compare(p11, p11) == 0);
    +        assertTrue(ck.compare(p12, p11) == 0);
    +        assertTrue(ck.compare(p11, p12) == 0);
    +        assertTrue(ck.compare(p12, p22) < 0);
    +        assertTrue(ck.compare(p12, p21) < 0);
    +        assertTrue(ck.compare(p21, p11) > 0);
    +        assertTrue(ck.compare(p21, p12) > 0);
    +
    +        assertTrue(cv.compare(p11, p11) == 0);
    +        assertTrue(cv.compare(p12, p11) > 0);
    +        assertTrue(cv.compare(p11, p12) < 0);
    +        assertTrue(cv.compare(p12, p22) == 0);
    +        assertTrue(cv.compare(p12, p21) > 0);
    +        assertTrue(cv.compare(p21, p11) == 0);
    +        assertTrue(cv.compare(p21, p12) < 0);
    +
    +        Comparator> cmp = ck.thenComparing(cv);
    +        assertTrue(cmp.compare(p11, p11) == 0);
    +        assertTrue(cmp.compare(p12, p11) > 0);
    +        assertTrue(cmp.compare(p11, p12) < 0);
    +        assertTrue(cmp.compare(p12, p22) < 0);
    +        assertTrue(cmp.compare(p12, p21) < 0);
    +        assertTrue(cmp.compare(p21, p11) > 0);
    +        assertTrue(cmp.compare(p21, p12) > 0);
    +
    +        cmp = cv.thenComparing(ck);
    +        assertTrue(cmp.compare(p11, p11) == 0);
    +        assertTrue(cmp.compare(p12, p11) > 0);
    +        assertTrue(cmp.compare(p11, p12) < 0);
    +        assertTrue(cmp.compare(p12, p22) < 0);
    +        assertTrue(cmp.compare(p12, p21) > 0);
    +        assertTrue(cmp.compare(p21, p11) > 0);
    +        assertTrue(cmp.compare(p21, p12) < 0);
    +    }
    +
    +    public void testKVComparables() {
    +        assertPairComparison(1, "ABC", 2, "XYZ",
    +                         Map.Entry.comparingByKey(),
    +                         Map.Entry.comparingByValue());
    +    }
    +
    +    private static class People {
    +        final String firstName;
    +        final String lastName;
    +        final int age;
    +
    +        People(String first, String last, int age) {
    +            firstName = first;
    +            lastName = last;
    +            this.age = age;
    +        }
    +
    +        String getFirstName() { return firstName; }
    +        String getLastName() { return lastName; }
    +        int getAge() { return age; }
    +    }
    +
    +    private final People people[] = {
    +        new People("John", "Doe", 34),
    +        new People("Mary", "Doe", 30),
    +    };
    +
    +    public void testKVComparators() {
    +        // Comparator cmp = Comparator.naturalOrder(); // Should fail to compiler as People is not comparable
    +        // We can use simple comparator, but those have been tested above.
    +        // Thus choose to do compose for some level of interation.
    +        Comparator cmp1 = Comparator.comparing((Function) People::getFirstName);
    +        Comparator cmp2 = Comparator.comparing((Function) People::getLastName);
    +        Comparator cmp = cmp1.thenComparing(cmp2);
    +
    +        assertPairComparison(people[0], people[0], people[1], people[1],
    +                         Map.Entry.comparingByKey(cmp),
    +                         Map.Entry.comparingByValue(cmp));
    +
    +    }
    +
    +    public void testNulls() {
    +        try {
    +            Comparator> cmp = Map.Entry.comparingByKey(null);
    +            fail("comparingByKey(null) should throw NPE");
    +        } catch (NullPointerException npe) {}
    +
    +        try {
    +            Comparator> cmp = Map.Entry.comparingByValue(null);
    +            fail("comparingByValue(null) should throw NPE");
    +        } catch (NullPointerException npe) {}
    +    }
    +}
    diff --git a/jdk/test/java/util/function/BinaryOperator/BasicTest.java b/jdk/test/java/util/function/BinaryOperator/BasicTest.java
    new file mode 100644
    index 00000000000..1519fb88177
    --- /dev/null
    +++ b/jdk/test/java/util/function/BinaryOperator/BasicTest.java
    @@ -0,0 +1,104 @@
    +/*
    + * Copyright (c) 2012, 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
    + * @bug 8009736 8010279
    + * @run testng BasicTest
    + */
    +
    +import java.util.Comparator;
    +import java.util.function.BinaryOperator;
    +import java.util.function.Function;
    +import java.util.function.ToIntFunction;
    +import org.testng.annotations.Test;
    +
    +
    +import static java.util.function.BinaryOperator.minBy;
    +import static java.util.function.BinaryOperator.maxBy;
    +import static org.testng.Assert.assertSame;
    +import static org.testng.Assert.fail;
    +
    +/**
    + * Unit tests for helper methods in Comparators
    + */
    +@Test(groups = "unit")
    +public class BasicTest {
    +
    +    private static class People {
    +        final String firstName;
    +        final String lastName;
    +        final int age;
    +
    +        People(String first, String last, int age) {
    +            firstName = first;
    +            lastName = last;
    +            this.age = age;
    +        }
    +
    +        String getFirstName() { return firstName; }
    +        String getLastName() { return lastName; }
    +        int getAge() { return age; }
    +    }
    +
    +    private final People people[] = {
    +        new People("John", "Doe", 34),
    +        new People("Mary", "Doe", 30),
    +    };
    +
    +    public void testMaxBy() {
    +        Comparator cmp = Comparator.comparing((Function) People::getFirstName);
    +        // lesser
    +        assertSame(maxBy(cmp).apply(people[0], people[1]), people[1]);
    +        // euqal
    +        cmp = Comparator.comparing((Function) People::getLastName);
    +        assertSame(maxBy(cmp).apply(people[0], people[1]), people[0]);
    +        // greater
    +        cmp = Comparator.comparing((ToIntFunction) People::getAge);
    +        assertSame(maxBy(cmp).apply(people[0], people[1]), people[0]);
    +    }
    +
    +    public void testLesserOf() {
    +        Comparator cmp = Comparator.comparing((Function) People::getFirstName);
    +        // lesser
    +        assertSame(minBy(cmp).apply(people[0], people[1]), people[0]);
    +        // euqal
    +        cmp = Comparator.comparing((Function) People::getLastName);
    +        assertSame(minBy(cmp).apply(people[0], people[1]), people[0]);
    +        // greater
    +        cmp = Comparator.comparing((ToIntFunction) People::getAge);
    +        assertSame(minBy(cmp).apply(people[0], people[1]), people[1]);
    +    }
    +
    +    public void testNulls() {
    +        try {
    +            BinaryOperator op = minBy(null);
    +            fail("minBy(null) should throw NPE");
    +        } catch (NullPointerException npe) {}
    +
    +        try {
    +            BinaryOperator op = maxBy(null);
    +            fail("maxBy(null) should throw NPE");
    +        } catch (NullPointerException npe) {}
    +    }
    +}
    diff --git a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/SequentialOpTest.java b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/SequentialOpTest.java
    index 793b31daed4..efa5c62e640 100644
    --- a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/SequentialOpTest.java
    +++ b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/SequentialOpTest.java
    @@ -22,7 +22,6 @@
      */
     package org.openjdk.tests.java.util.stream;
     
    -import java.util.Comparators;
     import java.util.stream.LambdaTestHelpers;
     import java.util.stream.OpTestCase;
     import java.util.stream.StreamTestDataProvider;
    @@ -109,9 +108,9 @@ public class SequentialOpTest extends OpTestCase {
                     = new UnaryOperator[] {
                     (UnaryOperator>) s -> s,
                     (UnaryOperator>) s -> s.map(id),
    -                (UnaryOperator>) s -> s.sorted(Comparators.naturalOrder()),
    -                (UnaryOperator>) s -> s.map(id).sorted(Comparators.naturalOrder()).map(id),
    -                (UnaryOperator>) s -> s.filter(LambdaTestHelpers.pEven).sorted(Comparators.naturalOrder()).map(id),
    +                (UnaryOperator>) s -> s.sorted(Comparator.naturalOrder()),
    +                (UnaryOperator>) s -> s.map(id).sorted(Comparator.naturalOrder()).map(id),
    +                (UnaryOperator>) s -> s.filter(LambdaTestHelpers.pEven).sorted(Comparator.naturalOrder()).map(id),
             };
     
             for (int c1Index = 0; c1Index < changers.length; c1Index++) {
    diff --git a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/SliceOpTest.java b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/SliceOpTest.java
    index ff940035980..29086fa351d 100644
    --- a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/SliceOpTest.java
    +++ b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/SliceOpTest.java
    @@ -270,7 +270,7 @@ public class SliceOpTest extends OpTestCase {
         public void testLimitSort() {
             List l = countTo(100);
             Collections.reverse(l);
    -        exerciseOps(l, s -> s.limit(10).sorted(Comparators.naturalOrder()));
    +        exerciseOps(l, s -> s.limit(10).sorted(Comparator.naturalOrder()));
         }
     
         @Test(groups = { "serialization-hostile" })
    diff --git a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/SortedOpTest.java b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/SortedOpTest.java
    index 93ac4eae386..956dea39ec3 100644
    --- a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/SortedOpTest.java
    +++ b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/SortedOpTest.java
    @@ -40,10 +40,10 @@ public class SortedOpTest extends OpTestCase {
         public void testSorted() {
             assertCountSum(countTo(0).stream().sorted(), 0, 0);
             assertCountSum(countTo(10).stream().sorted(), 10, 55);
    -        assertCountSum(countTo(10).stream().sorted(cInteger.reverseOrder()), 10, 55);
    +        assertCountSum(countTo(10).stream().sorted(cInteger.reversed()), 10, 55);
     
             List to10 = countTo(10);
    -        assertSorted(to10.stream().sorted(cInteger.reverseOrder()).iterator(), cInteger.reverseOrder());
    +        assertSorted(to10.stream().sorted(cInteger.reversed()).iterator(), cInteger.reversed());
     
             Collections.reverse(to10);
             assertSorted(to10.stream().sorted().iterator());
    @@ -51,7 +51,7 @@ public class SortedOpTest extends OpTestCase {
             Spliterator s = to10.stream().sorted().spliterator();
             assertTrue(s.hasCharacteristics(Spliterator.SORTED));
     
    -        s = to10.stream().sorted(cInteger.reverseOrder()).spliterator();
    +        s = to10.stream().sorted(cInteger.reversed()).spliterator();
             assertFalse(s.hasCharacteristics(Spliterator.SORTED));
         }
     
    @@ -87,8 +87,8 @@ public class SortedOpTest extends OpTestCase {
             assertSorted(result.iterator());
             assertContentsUnordered(data, result);
     
    -        result = exerciseOps(data, s -> s.sorted(cInteger.reverseOrder()));
    -        assertSorted(result.iterator(), cInteger.reverseOrder());
    +        result = exerciseOps(data, s -> s.sorted(cInteger.reversed()));
    +        assertSorted(result.iterator(), cInteger.reversed());
             assertContentsUnordered(data, result);
         }
     
    @@ -104,23 +104,23 @@ public class SortedOpTest extends OpTestCase {
             assertContentsUnordered(data, result);
     
             result = withData(data)
    -                .stream(s -> s.sorted(cInteger.reverseOrder()).sorted(cInteger.reverseOrder()),
    +                .stream(s -> s.sorted(cInteger.reversed()).sorted(cInteger.reversed()),
                             new CollectorOps.TestParallelSizedOp())
                     .exercise();
     
    -        assertSorted(result, cInteger.reverseOrder());
    +        assertSorted(result, cInteger.reversed());
             assertContentsUnordered(data, result);
     
             result = withData(data)
    -                .stream(s -> s.sorted().sorted(cInteger.reverseOrder()),
    +                .stream(s -> s.sorted().sorted(cInteger.reversed()),
                             new CollectorOps.TestParallelSizedOp())
                     .exercise();
     
    -        assertSorted(result, cInteger.reverseOrder());
    +        assertSorted(result, cInteger.reversed());
             assertContentsUnordered(data, result);
     
             result = withData(data)
    -                .stream(s -> s.sorted(cInteger.reverseOrder()).sorted(),
    +                .stream(s -> s.sorted(cInteger.reversed()).sorted(),
                             new CollectorOps.TestParallelSizedOp())
                     .exercise();
     
    diff --git a/jdk/test/sun/misc/JavaLangAccess/NewUnsafeString.java b/jdk/test/sun/misc/JavaLangAccess/NewUnsafeString.java
    index 930d57bee80..ab608d7dcf5 100644
    --- a/jdk/test/sun/misc/JavaLangAccess/NewUnsafeString.java
    +++ b/jdk/test/sun/misc/JavaLangAccess/NewUnsafeString.java
    @@ -22,7 +22,7 @@
      */
     
     import java.util.Objects;
    -import java.util.Comparators;
    +import java.util.Comparator;
     import sun.misc.JavaLangAccess;
     import sun.misc.SharedSecrets;
     
    @@ -48,7 +48,7 @@ public class NewUnsafeString {
             if (!benchmark.equals(constructorCopy)) {
                 throw new Error("Copy not equal");
             }
    -        if (0 != Objects.compare(benchmark, constructorCopy, Comparators.naturalOrder())) {
    +        if (0 != Objects.compare(benchmark, constructorCopy, Comparator.naturalOrder())) {
                 throw new Error("Copy not equal");
             }
     
    @@ -58,7 +58,7 @@ public class NewUnsafeString {
             if (!benchmark.equals(jlaCopy)) {
                 throw new Error("Copy not equal");
             }
    -        if (0 != Objects.compare(benchmark, jlaCopy, Comparators.naturalOrder())) {
    +        if (0 != Objects.compare(benchmark, jlaCopy, Comparator.naturalOrder())) {
                 throw new Error("Copy not equal");
             }
     
    @@ -68,7 +68,7 @@ public class NewUnsafeString {
             if (!constructorCopy.equals(jlaCopy)) {
                 throw new Error("Copy not equal");
             }
    -        if (0 != Objects.compare(constructorCopy, jlaCopy, Comparators.naturalOrder())) {
    +        if (0 != Objects.compare(constructorCopy, jlaCopy, Comparator.naturalOrder())) {
                 throw new Error("Copy not equal");
             }
     
    
    From 4f7010b973432dbf1c09eb5ddbcb05cf484bd3cf Mon Sep 17 00:00:00 2001
    From: Zhengyu Gu 
    Date: Tue, 25 Jun 2013 17:22:04 -0400
    Subject: [PATCH 044/127] 8017478: Kitchensink crashed with SIGSEGV in
     BaselineReporter::diff_callsites
    
    Fixed possible NULL pointer that caused SIGSEGV
    
    Reviewed-by: coleenp, acorn, ctornqvi
    ---
     hotspot/src/share/vm/services/memReporter.cpp | 46 +++++++++++++------
     1 file changed, 33 insertions(+), 13 deletions(-)
    
    diff --git a/hotspot/src/share/vm/services/memReporter.cpp b/hotspot/src/share/vm/services/memReporter.cpp
    index 573d9e03c14..9d0f45ada36 100644
    --- a/hotspot/src/share/vm/services/memReporter.cpp
    +++ b/hotspot/src/share/vm/services/memReporter.cpp
    @@ -188,8 +188,8 @@ void BaselineReporter::diff_callsites(const MemBaseline& cur, const MemBaseline&
                       (MallocCallsitePointer*)prev_malloc_itr.current();
     
       while (cur_malloc_callsite != NULL || prev_malloc_callsite != NULL) {
    -    if (prev_malloc_callsite == NULL ||
    -        cur_malloc_callsite->addr() < prev_malloc_callsite->addr()) {
    +    if (prev_malloc_callsite == NULL) {
    +      assert(cur_malloc_callsite != NULL, "sanity check");
           // this is a new callsite
           _outputer.diff_malloc_callsite(cur_malloc_callsite->addr(),
             amount_in_current_scale(cur_malloc_callsite->amount()),
    @@ -197,22 +197,42 @@ void BaselineReporter::diff_callsites(const MemBaseline& cur, const MemBaseline&
             diff_in_current_scale(cur_malloc_callsite->amount(), 0),
             diff(cur_malloc_callsite->count(), 0));
           cur_malloc_callsite = (MallocCallsitePointer*)cur_malloc_itr.next();
    -    } else if (cur_malloc_callsite == NULL ||
    -               cur_malloc_callsite->addr() > prev_malloc_callsite->addr()) {
    +    } else if (cur_malloc_callsite == NULL) {
    +      assert(prev_malloc_callsite != NULL, "Sanity check");
           // this callsite is already gone
           _outputer.diff_malloc_callsite(prev_malloc_callsite->addr(),
    -        amount_in_current_scale(0), 0,
    +        0, 0,
             diff_in_current_scale(0, prev_malloc_callsite->amount()),
             diff(0, prev_malloc_callsite->count()));
           prev_malloc_callsite = (MallocCallsitePointer*)prev_malloc_itr.next();
    -    } else {  // the same callsite
    -      _outputer.diff_malloc_callsite(cur_malloc_callsite->addr(),
    -        amount_in_current_scale(cur_malloc_callsite->amount()),
    -        cur_malloc_callsite->count(),
    -        diff_in_current_scale(cur_malloc_callsite->amount(), prev_malloc_callsite->amount()),
    -        diff(cur_malloc_callsite->count(), prev_malloc_callsite->count()));
    -      cur_malloc_callsite = (MallocCallsitePointer*)cur_malloc_itr.next();
    -      prev_malloc_callsite = (MallocCallsitePointer*)prev_malloc_itr.next();
    +    } else {
    +      assert(cur_malloc_callsite  != NULL,  "Sanity check");
    +      assert(prev_malloc_callsite != NULL,  "Sanity check");
    +      if (cur_malloc_callsite->addr() < prev_malloc_callsite->addr()) {
    +        // this is a new callsite
    +        _outputer.diff_malloc_callsite(cur_malloc_callsite->addr(),
    +          amount_in_current_scale(cur_malloc_callsite->amount()),
    +          cur_malloc_callsite->count(),
    +          diff_in_current_scale(cur_malloc_callsite->amount(), 0),
    +          diff(cur_malloc_callsite->count(), 0));
    +          cur_malloc_callsite = (MallocCallsitePointer*)cur_malloc_itr.next();
    +      } else if (cur_malloc_callsite->addr() > prev_malloc_callsite->addr()) {
    +        // this callsite is already gone
    +        _outputer.diff_malloc_callsite(prev_malloc_callsite->addr(),
    +          0, 0,
    +          diff_in_current_scale(0, prev_malloc_callsite->amount()),
    +          diff(0, prev_malloc_callsite->count()));
    +        prev_malloc_callsite = (MallocCallsitePointer*)prev_malloc_itr.next();
    +      } else {
    +        // the same callsite
    +        _outputer.diff_malloc_callsite(cur_malloc_callsite->addr(),
    +          amount_in_current_scale(cur_malloc_callsite->amount()),
    +          cur_malloc_callsite->count(),
    +          diff_in_current_scale(cur_malloc_callsite->amount(), prev_malloc_callsite->amount()),
    +          diff(cur_malloc_callsite->count(), prev_malloc_callsite->count()));
    +        cur_malloc_callsite = (MallocCallsitePointer*)cur_malloc_itr.next();
    +        prev_malloc_callsite = (MallocCallsitePointer*)prev_malloc_itr.next();
    +      }
         }
       }
     
    
    From 08377de5aba4c0410a3c66a292080db1fd957a1c Mon Sep 17 00:00:00 2001
    From: Kevin Walls 
    Date: Wed, 26 Jun 2013 00:01:20 +0100
    Subject: [PATCH 045/127] 8010278: SA: provide mechanism for using an
     alternative SA debugger back-end
    
    Reviewed-by: sla, dsamersoff
    ---
     .../share/classes/sun/jvm/hotspot/CLHSDB.java |  26 +++--
     .../sun/jvm/hotspot/CommandProcessor.java     |   9 +-
     .../share/classes/sun/jvm/hotspot/HSDB.java   |  48 +++++++--
     .../classes/sun/jvm/hotspot/HotSpotAgent.java | 102 ++++++++++++++----
     .../hotspot/debugger/linux/LinuxAddress.java  |   4 +-
     .../debugger/linux/LinuxOopHandle.java        |   4 +-
     .../classes/sun/jvm/hotspot/runtime/VM.java   |  11 +-
     .../jvm/hotspot/tools/ClassLoaderStats.java   |   8 ++
     .../sun/jvm/hotspot/tools/FinalizerInfo.java  |  10 ++
     .../sun/jvm/hotspot/tools/FlagDumper.java     |   9 ++
     .../sun/jvm/hotspot/tools/HeapDumper.java     |   6 ++
     .../sun/jvm/hotspot/tools/HeapSummary.java    |   9 ++
     .../classes/sun/jvm/hotspot/tools/JInfo.java  |   9 ++
     .../classes/sun/jvm/hotspot/tools/JMap.java   |   5 +
     .../classes/sun/jvm/hotspot/tools/JSnap.java  |  10 ++
     .../classes/sun/jvm/hotspot/tools/JStack.java |   6 ++
     .../jvm/hotspot/tools/ObjectHistogram.java    |   8 ++
     .../classes/sun/jvm/hotspot/tools/PMap.java   |   9 ++
     .../classes/sun/jvm/hotspot/tools/PStack.java |   4 +
     .../sun/jvm/hotspot/tools/StackTrace.java     |  10 ++
     .../sun/jvm/hotspot/tools/SysPropsDumper.java |   9 ++
     .../classes/sun/jvm/hotspot/tools/Tool.java   |  31 +++++-
     .../jvm/hotspot/tools/jcore/ClassDump.java    |  48 +++++----
     .../sun/jvm/hotspot/tools/soql/JSDB.java      |  10 ++
     .../sun/jvm/hotspot/tools/soql/SOQL.java      |   8 ++
     25 files changed, 340 insertions(+), 73 deletions(-)
    
    diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/CLHSDB.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/CLHSDB.java
    index 5071235fa3e..9e8d016dcc2 100644
    --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/CLHSDB.java
    +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/CLHSDB.java
    @@ -31,13 +31,19 @@ import java.io.*;
     import java.util.*;
     
     public class CLHSDB {
    +
    +    public CLHSDB(JVMDebugger d) {
    +        jvmDebugger = d;
    +    }
    +
         public static void main(String[] args) {
             new CLHSDB(args).run();
         }
     
    -    private void run() {
    -        // At this point, if pidText != null we are supposed to attach to it.
    -        // Else, if execPath != null, it is the path of a jdk/bin/java
    +    public void run() {
    +        // If jvmDebugger is already set, we have been given a JVMDebugger.
    +        // Otherwise, if pidText != null we are supposed to attach to it.
    +        // Finally, if execPath != null, it is the path of a jdk/bin/java
             // and coreFilename is the pathname of a core file we are
             // supposed to attach to.
     
    @@ -49,7 +55,9 @@ public class CLHSDB {
                     }
                 });
     
    -        if (pidText != null) {
    +        if (jvmDebugger != null) {
    +            attachDebugger(jvmDebugger);
    +        } else if (pidText != null) {
                 attachDebugger(pidText);
             } else if (execPath != null) {
                 attachDebugger(execPath, coreFilename);
    @@ -96,6 +104,7 @@ public class CLHSDB {
         // Internals only below this point
         //
         private HotSpotAgent agent;
    +    private JVMDebugger jvmDebugger;
         private boolean      attached;
         // These had to be made data members because they are referenced in inner classes.
         private String pidText;
    @@ -120,7 +129,7 @@ public class CLHSDB {
             case (1):
                 if (args[0].equals("help") || args[0].equals("-help")) {
                     doUsage();
    -                System.exit(0);
    +                return;
                 }
                 // If all numbers, it is a PID to attach to
                 // Else, it is a pathname to a .../bin/java for a core file.
    @@ -142,10 +151,15 @@ public class CLHSDB {
             default:
                 System.out.println("HSDB Error: Too many options specified");
                 doUsage();
    -            System.exit(1);
    +            return;
             }
         }
     
    +    private void attachDebugger(JVMDebugger d) {
    +        agent.attach(d);
    +        attached = true;
    +     }
    +
         /** NOTE we are in a different thread here than either the main
             thread or the Swing/AWT event handler thread, so we must be very
             careful when creating or removing widgets */
    diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/CommandProcessor.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/CommandProcessor.java
    index 2233844267c..1840caf9313 100644
    --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/CommandProcessor.java
    +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/CommandProcessor.java
    @@ -101,6 +101,9 @@ import sun.jvm.hotspot.utilities.soql.JSJavaFactoryImpl;
     import sun.jvm.hotspot.utilities.soql.JSJavaScriptEngine;
     
     public class CommandProcessor {
    +
    +    volatile boolean quit;
    +
         public abstract static class DebuggerInterface {
             public abstract HotSpotAgent getAgent();
             public abstract boolean isAttached();
    @@ -1135,7 +1138,7 @@ public class CommandProcessor {
                         usage();
                     } else {
                         debugger.detach();
    -                    System.exit(0);
    +                    quit = true;
                     }
                 }
             },
    @@ -1714,7 +1717,7 @@ public class CommandProcessor {
                             }
                             protected void quit() {
                                 debugger.detach();
    -                            System.exit(0);
    +                            quit = true;
                             }
                             protected BufferedReader getInputReader() {
                                 return in;
    @@ -1781,7 +1784,7 @@ public class CommandProcessor {
     
         public void run(boolean prompt) {
             // Process interactive commands.
    -        while (true) {
    +        while (!quit) {
                 if (prompt) printPrompt();
                 String ln = null;
                 try {
    diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/HSDB.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/HSDB.java
    index 5143408c687..d50cbaa5140 100644
    --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/HSDB.java
    +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/HSDB.java
    @@ -59,8 +59,11 @@ public class HSDB implements ObjectHistogramPanel.Listener, SAListener {
       // Internals only below this point
       //
       private HotSpotAgent agent;
    +  private JVMDebugger jvmDebugger;
       private JDesktopPane desktop;
       private boolean      attached;
    +  private boolean      argError;
    +  private JFrame frame;
       /** List  */
       private java.util.List attachMenuItems;
       /** List  */
    @@ -85,6 +88,11 @@ public class HSDB implements ObjectHistogramPanel.Listener, SAListener {
         System.out.println("           path-to-corefile:        Debug this corefile.  The default is 'core'");
         System.out.println("        If no arguments are specified, you can select what to do from the GUI.\n");
         HotSpotAgent.showUsage();
    +    argError = true;
    +  }
    +
    +  public HSDB(JVMDebugger d) {
    +    jvmDebugger = d;
       }
     
       private HSDB(String[] args) {
    @@ -95,7 +103,6 @@ public class HSDB implements ObjectHistogramPanel.Listener, SAListener {
         case (1):
           if (args[0].equals("help") || args[0].equals("-help")) {
             doUsage();
    -        System.exit(0);
           }
           // If all numbers, it is a PID to attach to
           // Else, it is a pathname to a .../bin/java for a core file.
    @@ -117,24 +124,29 @@ public class HSDB implements ObjectHistogramPanel.Listener, SAListener {
         default:
           System.out.println("HSDB Error: Too many options specified");
           doUsage();
    -      System.exit(1);
         }
       }
     
    -  private void run() {
    -    // At this point, if pidText != null we are supposed to attach to it.
    -    // Else, if execPath != null, it is the path of a jdk/bin/java
    -    // and coreFilename is the pathname of a core file we are
    -    // supposed to attach to.
    +  // close this tool without calling System.exit
    +  protected void closeUI() {
    +      workerThread.shutdown();
    +      frame.dispose();
    +  }
    +
    +  public void run() {
    +    // Don't start the UI if there were bad arguments.
    +    if (argError) {
    +        return;
    +    }
     
         agent = new HotSpotAgent();
         workerThread = new WorkerThread();
         attachMenuItems = new java.util.ArrayList();
         detachMenuItems = new java.util.ArrayList();
     
    -    JFrame frame = new JFrame("HSDB - HotSpot Debugger");
    +    frame = new JFrame("HSDB - HotSpot Debugger");
         frame.setSize(800, 600);
    -    frame.setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
    +    frame.setDefaultCloseOperation(WindowConstants.DISPOSE_ON_CLOSE);
     
         JMenuBar menuBar = new JMenuBar();
     
    @@ -197,7 +209,7 @@ public class HSDB implements ObjectHistogramPanel.Listener, SAListener {
         item = createMenuItem("Exit",
                                 new ActionListener() {
                                     public void actionPerformed(ActionEvent e) {
    -                                  System.exit(0);
    +                                  closeUI();
                                     }
                                   });
         item.setAccelerator(KeyStroke.getKeyStroke(KeyEvent.VK_X, ActionEvent.ALT_MASK));
    @@ -406,7 +418,15 @@ public class HSDB implements ObjectHistogramPanel.Listener, SAListener {
             }
           });
     
    -    if (pidText != null) {
    +    // If jvmDebugger is already set, we have been given a JVMDebugger.
    +    // Otherwise, if pidText != null we are supposed to attach to it.
    +    // Finally, if execPath != null, it is the path of a jdk/bin/java
    +    // and coreFilename is the pathname of a core file we are
    +    // supposed to attach to.
    +
    +    if (jvmDebugger != null) {
    +      attach(jvmDebugger);
    +    } else if (pidText != null) {
           attach(pidText);
         } else if (execPath != null) {
           attach(execPath, coreFilename);
    @@ -1113,6 +1133,12 @@ public class HSDB implements ObjectHistogramPanel.Listener, SAListener {
           });
       }
     
    +  // Attach to existing JVMDebugger, which should be already attached to a core/process.
    +  private void attach(JVMDebugger d) {
    +    attached = true;
    +    showThreadsDialog();
    +  }
    +
       /** NOTE we are in a different thread here than either the main
           thread or the Swing/AWT event handler thread, so we must be very
           careful when creating or removing widgets */
    diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/HotSpotAgent.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/HotSpotAgent.java
    index bdf9bd369e6..c963350591d 100644
    --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/HotSpotAgent.java
    +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/HotSpotAgent.java
    @@ -25,6 +25,8 @@
     package sun.jvm.hotspot;
     
     import java.rmi.RemoteException;
    +import java.lang.reflect.Constructor;
    +import java.lang.reflect.InvocationTargetException;
     
     import sun.jvm.hotspot.debugger.Debugger;
     import sun.jvm.hotspot.debugger.DebuggerException;
    @@ -63,7 +65,6 @@ public class HotSpotAgent {
     
         private String os;
         private String cpu;
    -    private String fileSep;
     
         // The system can work in several ways:
         //  - Attaching to local process
    @@ -155,6 +156,14 @@ public class HotSpotAgent {
             go();
         }
     
    +    /** This uses a JVMDebugger that is already attached to the core or process */
    +    public synchronized void attach(JVMDebugger d)
    +    throws DebuggerException {
    +        debugger = d;
    +        isServer = false;
    +        go();
    +    }
    +
         /** This attaches to a "debug server" on a remote machine; this
           remote server has already attached to a process or opened a
           core file and is waiting for RMI calls on the Debugger object to
    @@ -303,28 +312,37 @@ public class HotSpotAgent {
                 // server, but not client attaching to server)
                 //
     
    -            try {
    -                os  = PlatformInfo.getOS();
    -                cpu = PlatformInfo.getCPU();
    -            }
    -            catch (UnsupportedPlatformException e) {
    -                throw new DebuggerException(e);
    -            }
    -            fileSep = System.getProperty("file.separator");
    +            // Handle existing or alternate JVMDebugger:
    +            // these will set os, cpu independently of our PlatformInfo implementation.
    +            String alternateDebugger = System.getProperty("sa.altDebugger");
    +            if (debugger != null) {
    +                setupDebuggerExisting();
    +
    +            } else if (alternateDebugger != null) {
    +                setupDebuggerAlternate(alternateDebugger);
     
    -            if (os.equals("solaris")) {
    -                setupDebuggerSolaris();
    -            } else if (os.equals("win32")) {
    -                setupDebuggerWin32();
    -            } else if (os.equals("linux")) {
    -                setupDebuggerLinux();
    -            } else if (os.equals("bsd")) {
    -                setupDebuggerBsd();
    -            } else if (os.equals("darwin")) {
    -                setupDebuggerDarwin();
                 } else {
    -                // Add support for more operating systems here
    -                throw new DebuggerException("Operating system " + os + " not yet supported");
    +                // Otherwise, os, cpu are those of our current platform:
    +                try {
    +                    os  = PlatformInfo.getOS();
    +                    cpu = PlatformInfo.getCPU();
    +                } catch (UnsupportedPlatformException e) {
    +                   throw new DebuggerException(e);
    +                }
    +                if (os.equals("solaris")) {
    +                    setupDebuggerSolaris();
    +                } else if (os.equals("win32")) {
    +                    setupDebuggerWin32();
    +                } else if (os.equals("linux")) {
    +                    setupDebuggerLinux();
    +                } else if (os.equals("bsd")) {
    +                    setupDebuggerBsd();
    +                } else if (os.equals("darwin")) {
    +                    setupDebuggerDarwin();
    +                } else {
    +                    // Add support for more operating systems here
    +                    throw new DebuggerException("Operating system " + os + " not yet supported");
    +                }
                 }
     
                 if (isServer) {
    @@ -423,6 +441,41 @@ public class HotSpotAgent {
         // OS-specific debugger setup/connect routines
         //
     
    +    // Use the existing JVMDebugger, as passed to our constructor.
    +    // Retrieve os and cpu from that debugger, not the current platform.
    +    private void setupDebuggerExisting() {
    +
    +        os = debugger.getOS();
    +        cpu = debugger.getCPU();
    +        setupJVMLibNames(os);
    +        machDesc = debugger.getMachineDescription();
    +    }
    +
    +    // Given a classname, load an alternate implementation of JVMDebugger.
    +    private void setupDebuggerAlternate(String alternateName) {
    +
    +        try {
    +            Class c = Class.forName(alternateName);
    +            Constructor cons = c.getConstructor();
    +            debugger = (JVMDebugger) cons.newInstance();
    +            attachDebugger();
    +            setupDebuggerExisting();
    +
    +        } catch (ClassNotFoundException cnfe) {
    +            throw new DebuggerException("Cannot find alternate SA Debugger: '" + alternateName + "'");
    +        } catch (NoSuchMethodException nsme) {
    +            throw new DebuggerException("Alternate SA Debugger: '" + alternateName + "' has missing constructor.");
    +        } catch (InstantiationException ie) {
    +            throw new DebuggerException("Alternate SA Debugger: '" + alternateName + "' fails to initialise: ", ie);
    +        } catch (IllegalAccessException iae) {
    +            throw new DebuggerException("Alternate SA Debugger: '" + alternateName + "' fails to initialise: ", iae);
    +        } catch (InvocationTargetException iae) {
    +            throw new DebuggerException("Alternate SA Debugger: '" + alternateName + "' fails to initialise: ", iae);
    +        }
    +
    +        System.err.println("Loaded alternate HotSpot SA Debugger: " + alternateName);
    +    }
    +
         //
         // Solaris
         //
    @@ -466,6 +519,11 @@ public class HotSpotAgent {
             debugger = new RemoteDebuggerClient(remote);
             machDesc = ((RemoteDebuggerClient) debugger).getMachineDescription();
             os = debugger.getOS();
    +        setupJVMLibNames(os);
    +        cpu = debugger.getCPU();
    +    }
    +
    +    private void setupJVMLibNames(String os) {
             if (os.equals("solaris")) {
                 setupJVMLibNamesSolaris();
             } else if (os.equals("win32")) {
    @@ -479,8 +537,6 @@ public class HotSpotAgent {
             } else {
                 throw new RuntimeException("Unknown OS type");
             }
    -
    -        cpu = debugger.getCPU();
         }
     
         private void setupJVMLibNamesSolaris() {
    diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/linux/LinuxAddress.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/linux/LinuxAddress.java
    index 9e85e133b3a..cff29ce8edc 100644
    --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/linux/LinuxAddress.java
    +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/linux/LinuxAddress.java
    @@ -26,11 +26,11 @@ package sun.jvm.hotspot.debugger.linux;
     
     import sun.jvm.hotspot.debugger.*;
     
    -class LinuxAddress implements Address {
    +public class LinuxAddress implements Address {
         protected LinuxDebugger debugger;
         protected long addr;
     
    -    LinuxAddress(LinuxDebugger debugger, long addr) {
    +    public LinuxAddress(LinuxDebugger debugger, long addr) {
             this.debugger = debugger;
             this.addr = addr;
         }
    diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/linux/LinuxOopHandle.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/linux/LinuxOopHandle.java
    index 310acb88ac7..99291aada29 100644
    --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/linux/LinuxOopHandle.java
    +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/debugger/linux/LinuxOopHandle.java
    @@ -26,8 +26,8 @@ package sun.jvm.hotspot.debugger.linux;
     
     import sun.jvm.hotspot.debugger.*;
     
    -class LinuxOopHandle extends LinuxAddress implements OopHandle {
    -  LinuxOopHandle(LinuxDebugger debugger, long addr) {
    +public class LinuxOopHandle extends LinuxAddress implements OopHandle {
    +  public LinuxOopHandle(LinuxDebugger debugger, long addr) {
         super(debugger, addr);
       }
     
    diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/runtime/VM.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/runtime/VM.java
    index 0a9d9436878..f84da894ac2 100644
    --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/runtime/VM.java
    +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/runtime/VM.java
    @@ -246,7 +246,7 @@ public class VM {
          }
       }
     
    -  private static final boolean disableDerivedPrinterTableCheck;
    +  private static final boolean disableDerivedPointerTableCheck;
       private static final Properties saProps;
     
       static {
    @@ -256,12 +256,12 @@ public class VM {
            url = VM.class.getClassLoader().getResource("sa.properties");
            saProps.load(new BufferedInputStream(url.openStream()));
          } catch (Exception e) {
    -       throw new RuntimeException("Unable to load properties  " +
    +       System.err.println("Unable to load properties  " +
                                       (url == null ? "null" : url.toString()) +
                                       ": " + e.getMessage());
          }
     
    -     disableDerivedPrinterTableCheck = System.getProperty("sun.jvm.hotspot.runtime.VM.disableDerivedPointerTableCheck") != null;
    +     disableDerivedPointerTableCheck = System.getProperty("sun.jvm.hotspot.runtime.VM.disableDerivedPointerTableCheck") != null;
       }
     
       private VM(TypeDataBase db, JVMDebugger debugger, boolean isBigEndian) {
    @@ -371,7 +371,8 @@ public class VM {
       /** This is used by the debugging system */
       public static void initialize(TypeDataBase db, JVMDebugger debugger) {
         if (soleInstance != null) {
    -      throw new RuntimeException("Attempt to initialize VM twice");
    +      // Using multiple SA Tool classes in the same process creates a call here.
    +      return;
         }
         soleInstance = new VM(db, debugger, debugger.getMachineDescription().isBigEndian());
     
    @@ -683,7 +684,7 @@ public class VM {
     
       /** Returns true if C2 derived pointer table should be used, false otherwise */
       public boolean useDerivedPointerTable() {
    -    return !disableDerivedPrinterTableCheck;
    +    return !disableDerivedPointerTableCheck;
       }
     
       /** Returns the code cache; should not be used if is core build */
    diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/ClassLoaderStats.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/ClassLoaderStats.java
    index 77f0f800445..eeda376b1d6 100644
    --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/ClassLoaderStats.java
    +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/ClassLoaderStats.java
    @@ -41,6 +41,14 @@ import sun.jvm.hotspot.utilities.*;
     public class ClassLoaderStats extends Tool {
        boolean verbose = true;
     
    +   public ClassLoaderStats() {
    +      super();
    +   }
    +
    +   public ClassLoaderStats(JVMDebugger d) {
    +      super(d);
    +   }
    +
        public static void main(String[] args) {
           ClassLoaderStats cls = new ClassLoaderStats();
           cls.start(args);
    diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/FinalizerInfo.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/FinalizerInfo.java
    index 79e6784a63e..ed707b9ee8a 100644
    --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/FinalizerInfo.java
    +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/FinalizerInfo.java
    @@ -24,6 +24,7 @@
     
     package sun.jvm.hotspot.tools;
     
    +import sun.jvm.hotspot.debugger.JVMDebugger;
     import sun.jvm.hotspot.tools.*;
     
     import sun.jvm.hotspot.oops.*;
    @@ -42,6 +43,15 @@ import java.util.Comparator;
      * summary of these objects in the form of a histogram.
      */
     public class FinalizerInfo extends Tool {
    +
    +    public FinalizerInfo() {
    +        super();
    +    }
    +
    +    public FinalizerInfo(JVMDebugger d) {
    +        super(d);
    +    }
    +
         public static void main(String[] args) {
             FinalizerInfo finfo = new FinalizerInfo();
             finfo.start(args);
    diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/FlagDumper.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/FlagDumper.java
    index effeabb582a..c8db6d6b044 100644
    --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/FlagDumper.java
    +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/FlagDumper.java
    @@ -25,10 +25,19 @@
     package sun.jvm.hotspot.tools;
     
     import java.io.PrintStream;
    +import sun.jvm.hotspot.debugger.JVMDebugger;
     import sun.jvm.hotspot.runtime.*;
     
     public class FlagDumper extends Tool {
     
    +    public FlagDumper() {
    +        super();
    +    }
    +
    +    public FlagDumper(JVMDebugger d) {
    +        super(d);
    +    }
    +
        public void run() {
           VM.Flag[] flags = VM.getVM().getCommandLineFlags();
           PrintStream out = System.out;
    diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/HeapDumper.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/HeapDumper.java
    index 5a7c06618b9..c5af0ed005d 100644
    --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/HeapDumper.java
    +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/HeapDumper.java
    @@ -25,6 +25,7 @@
     package sun.jvm.hotspot.tools;
     
     import sun.jvm.hotspot.utilities.HeapHprofBinWriter;
    +import sun.jvm.hotspot.debugger.JVMDebugger;
     import java.io.IOException;
     
     /*
    @@ -42,6 +43,11 @@ public class HeapDumper extends Tool {
             this.dumpFile = dumpFile;
         }
     
    +    public HeapDumper(String dumpFile, JVMDebugger d) {
    +        super(d);
    +        this.dumpFile = dumpFile;
    +    }
    +
         protected void printFlagsUsage() {
             System.out.println("    \tto dump heap to " +
                 DEFAULT_DUMP_FILE);
    diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/HeapSummary.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/HeapSummary.java
    index 87621655269..a0123dd4c99 100644
    --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/HeapSummary.java
    +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/HeapSummary.java
    @@ -29,12 +29,21 @@ import sun.jvm.hotspot.gc_interface.*;
     import sun.jvm.hotspot.gc_implementation.g1.*;
     import sun.jvm.hotspot.gc_implementation.parallelScavenge.*;
     import sun.jvm.hotspot.gc_implementation.shared.*;
    +import sun.jvm.hotspot.debugger.JVMDebugger;
     import sun.jvm.hotspot.memory.*;
     import sun.jvm.hotspot.oops.*;
     import sun.jvm.hotspot.runtime.*;
     
     public class HeapSummary extends Tool {
     
    +   public HeapSummary() {
    +      super();
    +   }
    +
    +   public HeapSummary(JVMDebugger d) {
    +      super(d);
    +   }
    +
        public static void main(String[] args) {
           HeapSummary hs = new HeapSummary();
           hs.start(args);
    diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/JInfo.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/JInfo.java
    index a9f6c0e9c90..f2452420744 100644
    --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/JInfo.java
    +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/JInfo.java
    @@ -25,12 +25,21 @@
     package sun.jvm.hotspot.tools;
     
     import sun.jvm.hotspot.runtime.*;
    +import sun.jvm.hotspot.debugger.JVMDebugger;
     
     public class JInfo extends Tool {
    +    public JInfo() {
    +        super();
    +    }
    +
         public JInfo(int m) {
             mode = m;
         }
     
    +    public JInfo(JVMDebugger d) {
    +        super(d);
    +    }
    +
         protected boolean needsJavaPrefix() {
             return false;
         }
    diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/JMap.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/JMap.java
    index d9ea364edaa..f6f3c0741c0 100644
    --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/JMap.java
    +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/JMap.java
    @@ -25,6 +25,7 @@
     package sun.jvm.hotspot.tools;
     
     import java.io.*;
    +import sun.jvm.hotspot.debugger.JVMDebugger;
     import sun.jvm.hotspot.utilities.*;
     
     public class JMap extends Tool {
    @@ -36,6 +37,10 @@ public class JMap extends Tool {
             this(MODE_PMAP);
         }
     
    +    public JMap(JVMDebugger d) {
    +        super(d);
    +    }
    +
         protected boolean needsJavaPrefix() {
             return false;
         }
    diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/JSnap.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/JSnap.java
    index 95f46445f8a..9301f1059fd 100644
    --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/JSnap.java
    +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/JSnap.java
    @@ -25,9 +25,19 @@
     package sun.jvm.hotspot.tools;
     
     import java.io.*;
    +import sun.jvm.hotspot.debugger.JVMDebugger;
     import sun.jvm.hotspot.runtime.*;
     
     public class JSnap extends Tool {
    +
    +    public JSnap() {
    +        super();
    +    }
    +
    +    public JSnap(JVMDebugger d) {
    +        super(d);
    +    }
    +
         public void run() {
             final PrintStream out = System.out;
             if (PerfMemory.initialized()) {
    diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/JStack.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/JStack.java
    index 9e0688cf393..7cbe8f4d945 100644
    --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/JStack.java
    +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/JStack.java
    @@ -24,6 +24,8 @@
     
     package sun.jvm.hotspot.tools;
     
    +import sun.jvm.hotspot.debugger.JVMDebugger;
    +
     public class JStack extends Tool {
         public JStack(boolean mixedMode, boolean concurrentLocks) {
             this.mixedMode = mixedMode;
    @@ -34,6 +36,10 @@ public class JStack extends Tool {
             this(true, true);
         }
     
    +    public JStack(JVMDebugger d) {
    +        super(d);
    +    }
    +
         protected boolean needsJavaPrefix() {
             return false;
         }
    diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/ObjectHistogram.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/ObjectHistogram.java
    index f03469e13f1..168202eec2c 100644
    --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/ObjectHistogram.java
    +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/ObjectHistogram.java
    @@ -33,6 +33,14 @@ import java.io.PrintStream;
         an object histogram from a remote or crashed VM. */
     public class ObjectHistogram extends Tool {
     
    +    public ObjectHistogram() {
    +       super();
    +    }
    +
    +    public ObjectHistogram(JVMDebugger d) {
    +       super(d);
    +    }
    +
        public void run() {
           run(System.out, System.err);
        }
    diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/PMap.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/PMap.java
    index 70bd55513b9..2a234130991 100644
    --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/PMap.java
    +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/PMap.java
    @@ -31,6 +31,15 @@ import sun.jvm.hotspot.debugger.cdbg.*;
     import sun.jvm.hotspot.runtime.*;
     
     public class PMap extends Tool {
    +
    +   public PMap() {
    +       super();
    +   }
    +
    +   public PMap(JVMDebugger d) {
    +       super(d);
    +   }
    +
        public void run() {
           run(System.out);
        }
    diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/PStack.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/PStack.java
    index 0b3720ff594..7f10612b317 100644
    --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/PStack.java
    +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/PStack.java
    @@ -45,6 +45,10 @@ public class PStack extends Tool {
           this(true, true);
        }
     
    +   public PStack(JVMDebugger d) {
    +      super(d);
    +   }
    +
        public void run() {
           run(System.out);
        }
    diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/StackTrace.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/StackTrace.java
    index 83270bfdeff..eb0cc88d116 100644
    --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/StackTrace.java
    +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/StackTrace.java
    @@ -45,6 +45,16 @@ public class StackTrace extends Tool {
             run(System.out);
         }
     
    +    public StackTrace(JVMDebugger d) {
    +        super(d);
    +    }
    +
    +    public StackTrace(JVMDebugger d, boolean v, boolean concurrentLocks) {
    +        super(d);
    +        this.verbose = v;
    +        this.concurrentLocks = concurrentLocks;
    +    }
    +
         public void run(java.io.PrintStream tty) {
             // Ready to go with the database...
             try {
    diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/SysPropsDumper.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/SysPropsDumper.java
    index bb4f703c64b..d601fef4401 100644
    --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/SysPropsDumper.java
    +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/SysPropsDumper.java
    @@ -27,10 +27,19 @@ package sun.jvm.hotspot.tools;
     import java.io.PrintStream;
     import java.util.*;
     
    +import sun.jvm.hotspot.debugger.JVMDebugger;
     import sun.jvm.hotspot.runtime.*;
     
     public class SysPropsDumper extends Tool {
     
    +   public SysPropsDumper() {
    +      super();
    +   }
    +
    +   public SysPropsDumper(JVMDebugger d) {
    +      super(d);
    +   }
    +
        public void run() {
           Properties sysProps = VM.getVM().getSystemProperties();
           PrintStream out = System.out;
    diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/Tool.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/Tool.java
    index 4279c425bd8..3021801c9dd 100644
    --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/Tool.java
    +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/Tool.java
    @@ -35,6 +35,7 @@ import sun.jvm.hotspot.debugger.*;
     
     public abstract class Tool implements Runnable {
        private HotSpotAgent agent;
    +   private JVMDebugger jvmDebugger;
        private int debugeeType;
     
        // debugeeType is one of constants below
    @@ -42,6 +43,13 @@ public abstract class Tool implements Runnable {
        protected static final int DEBUGEE_CORE   = 1;
        protected static final int DEBUGEE_REMOTE = 2;
     
    +   public Tool() {
    +   }
    +
    +   public Tool(JVMDebugger d) {
    +      jvmDebugger = d;
    +   }
    +
        public String getName() {
           return getClass().getName();
        }
    @@ -90,7 +98,6 @@ public abstract class Tool implements Runnable {
     
        protected void usage() {
           printUsage();
    -      System.exit(1);
        }
     
        /*
    @@ -106,13 +113,13 @@ public abstract class Tool implements Runnable {
        protected void stop() {
           if (agent != null) {
              agent.detach();
    -         System.exit(0);
           }
        }
     
        protected void start(String[] args) {
           if ((args.length < 1) || (args.length > 2)) {
              usage();
    +         return;
           }
     
           // Attempt to handle -h or -help or some invalid flag
    @@ -185,13 +192,31 @@ public abstract class Tool implements Runnable {
             }
             if (e.getMessage() != null) {
               err.print(e.getMessage());
    +          e.printStackTrace();
             }
             err.println();
    -        System.exit(1);
    +        return;
           }
     
           err.println("Debugger attached successfully.");
    +      startInternal();
    +   }
     
    +   // When using an existing JVMDebugger.
    +   public void start() {
    +
    +      if (jvmDebugger == null) {
    +         throw new RuntimeException("Tool.start() called with no JVMDebugger set.");
    +      }
    +      agent = new HotSpotAgent();
    +      agent.attach(jvmDebugger);
    +      startInternal();
    +   }
    +
    +   // Remains of the start mechanism, common to both start methods.
    +   private void startInternal() {
    +
    +      PrintStream err = System.err;
           VM vm = VM.getVM();
           if (vm.isCore()) {
             err.println("Core build detected.");
    diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/jcore/ClassDump.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/jcore/ClassDump.java
    index 34ccc102acb..96817b26226 100644
    --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/jcore/ClassDump.java
    +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/jcore/ClassDump.java
    @@ -25,6 +25,7 @@
     package sun.jvm.hotspot.tools.jcore;
     
     import java.io.*;
    +import java.lang.reflect.Constructor;
     import java.util.jar.JarOutputStream;
     import java.util.jar.JarEntry;
     import java.util.jar.Manifest;
    @@ -38,6 +39,16 @@ public class ClassDump extends Tool {
         private ClassFilter classFilter;
         private String      outputDirectory;
         private JarOutputStream jarStream;
    +    private String      pkgList;
    +
    +    public ClassDump() {
    +        super();
    +    }
    +
    +    public ClassDump(JVMDebugger d, String pkgList) {
    +        super(d);
    +        this.pkgList = pkgList;
    +    }
     
         public void setClassFilter(ClassFilter cf) {
             classFilter = cf;
    @@ -63,6 +74,25 @@ public class ClassDump extends Tool {
         public void run() {
             // Ready to go with the database...
             try {
    +            // The name of the filter always comes from a System property.
    +            // If we have a pkgList, pass it, otherwise let the filter read
    +            // its own System property for the list of classes.
    +            String filterClassName = System.getProperty("sun.jvm.hotspot.tools.jcore.filter",
    +                                                        "sun.jvm.hotspot.tools.jcore.PackageNameFilter");
    +            try {
    +                Class filterClass = Class.forName(filterClassName);
    +                if (pkgList == null) {
    +                    classFilter = (ClassFilter) filterClass.newInstance();
    +                } else {
    +                    Constructor con = filterClass.getConstructor(String.class);
    +                    classFilter = (ClassFilter) con.newInstance(pkgList);
    +                }
    +            } catch(Exception exp) {
    +                System.err.println("Warning: Can not create class filter!");
    +            }
    +
    +            String outputDirectory = System.getProperty("sun.jvm.hotspot.tools.jcore.outputDir", ".");
    +            setOutputDirectory(outputDirectory);
     
                 // walk through the system dictionary
                 SystemDictionary dict = VM.getVM().getSystemDictionary();
    @@ -139,26 +169,8 @@ public class ClassDump extends Tool {
         }
     
         public static void main(String[] args) {
    -        // load class filters
    -        ClassFilter classFilter = null;
    -        String filterClassName = System.getProperty("sun.jvm.hotspot.tools.jcore.filter");
    -        if (filterClassName != null) {
    -            try {
    -                Class filterClass = Class.forName(filterClassName);
    -                classFilter = (ClassFilter) filterClass.newInstance();
    -            } catch(Exception exp) {
    -                System.err.println("Warning: Can not create class filter!");
    -            }
    -        }
    -
    -        String outputDirectory = System.getProperty("sun.jvm.hotspot.tools.jcore.outputDir");
    -        if (outputDirectory == null)
    -            outputDirectory = ".";
    -
     
             ClassDump cd = new ClassDump();
    -        cd.setClassFilter(classFilter);
    -        cd.setOutputDirectory(outputDirectory);
             cd.start(args);
             cd.stop();
         }
    diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/soql/JSDB.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/soql/JSDB.java
    index e46de0194d7..09874af178e 100644
    --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/soql/JSDB.java
    +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/soql/JSDB.java
    @@ -24,12 +24,22 @@
     
     package sun.jvm.hotspot.tools.soql;
     
    +import sun.jvm.hotspot.debugger.JVMDebugger;
     import sun.jvm.hotspot.tools.*;
     import sun.jvm.hotspot.utilities.*;
     import sun.jvm.hotspot.utilities.soql.*;
     
     /** This is command line JavaScript debugger console */
     public class JSDB extends Tool {
    +
    +    public JSDB() {
    +        super();
    +    }
    +
    +    public JSDB(JVMDebugger d) {
    +        super(d);
    +    }
    +
         public static void main(String[] args) {
             JSDB jsdb = new JSDB();
             jsdb.start(args);
    diff --git a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/soql/SOQL.java b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/soql/SOQL.java
    index 3a4c2470b1b..b3054b90bd0 100644
    --- a/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/soql/SOQL.java
    +++ b/hotspot/agent/src/share/classes/sun/jvm/hotspot/tools/soql/SOQL.java
    @@ -44,6 +44,14 @@ public class SOQL extends Tool {
           soql.stop();
        }
     
    +   public SOQL() {
    +      super();
    +   }
    +
    +   public SOQL(JVMDebugger d) {
    +      super(d);
    +   }
    +
        protected SOQLEngine soqlEngine;
        protected BufferedReader in = new BufferedReader(new InputStreamReader(System.in));
        protected PrintStream out       = System.out;
    
    From 8d048d554de09f44a53315991a6229a4595ee239 Mon Sep 17 00:00:00 2001
    From: Ioi Lam 
    Date: Thu, 27 Jun 2013 10:03:21 -0700
    Subject: [PATCH 046/127] 8016075: Win32 crash with CDS enabled and small heap
     size
    
    Fixed MetaspaceShared::is_in_shared_space
    
    Reviewed-by: coleenp, hseigel
    ---
     hotspot/src/share/vm/memory/filemap.cpp       | 10 ++++++
     hotspot/src/share/vm/memory/filemap.hpp       |  1 +
     .../src/share/vm/memory/metaspaceShared.cpp   | 33 +++++--------------
     3 files changed, 20 insertions(+), 24 deletions(-)
    
    diff --git a/hotspot/src/share/vm/memory/filemap.cpp b/hotspot/src/share/vm/memory/filemap.cpp
    index dbc0c87edce..5dfaf6f9701 100644
    --- a/hotspot/src/share/vm/memory/filemap.cpp
    +++ b/hotspot/src/share/vm/memory/filemap.cpp
    @@ -549,3 +549,13 @@ bool FileMapInfo::is_in_shared_space(const void* p) {
     
       return false;
     }
    +
    +void FileMapInfo::print_shared_spaces() {
    +  gclog_or_tty->print_cr("Shared Spaces:");
    +  for (int i = 0; i < MetaspaceShared::n_regions; i++) {
    +    struct FileMapInfo::FileMapHeader::space_info* si = &_header._space[i];
    +    gclog_or_tty->print("  %s " INTPTR_FORMAT "-" INTPTR_FORMAT,
    +                        shared_region_name[i],
    +                        si->_base, si->_base + si->_used);
    +  }
    +}
    diff --git a/hotspot/src/share/vm/memory/filemap.hpp b/hotspot/src/share/vm/memory/filemap.hpp
    index a11914b9c01..ee4ccec5bfe 100644
    --- a/hotspot/src/share/vm/memory/filemap.hpp
    +++ b/hotspot/src/share/vm/memory/filemap.hpp
    @@ -149,6 +149,7 @@ public:
     
       // Return true if given address is in the mapped shared space.
       bool is_in_shared_space(const void* p) NOT_CDS_RETURN_(false);
    +  void print_shared_spaces() NOT_CDS_RETURN;
     };
     
     #endif // SHARE_VM_MEMORY_FILEMAP_HPP
    diff --git a/hotspot/src/share/vm/memory/metaspaceShared.cpp b/hotspot/src/share/vm/memory/metaspaceShared.cpp
    index d2c91827485..c7d61f7b732 100644
    --- a/hotspot/src/share/vm/memory/metaspaceShared.cpp
    +++ b/hotspot/src/share/vm/memory/metaspaceShared.cpp
    @@ -826,35 +826,15 @@ public:
       bool reading() const { return true; }
     };
     
    -
    -// Save bounds of shared spaces mapped in.
    -static char* _ro_base = NULL;
    -static char* _rw_base = NULL;
    -static char* _md_base = NULL;
    -static char* _mc_base = NULL;
    -
     // Return true if given address is in the mapped shared space.
     bool MetaspaceShared::is_in_shared_space(const void* p) {
    -  if (_ro_base == NULL || _rw_base == NULL) {
    -    return false;
    -  } else {
    -    return ((p >= _ro_base && p < (_ro_base + SharedReadOnlySize)) ||
    -            (p >= _rw_base && p < (_rw_base + SharedReadWriteSize)));
    -  }
    +  return UseSharedSpaces && FileMapInfo::current_info()->is_in_shared_space(p);
     }
     
     void MetaspaceShared::print_shared_spaces() {
    -  gclog_or_tty->print_cr("Shared Spaces:");
    -  gclog_or_tty->print("  read-only " INTPTR_FORMAT "-" INTPTR_FORMAT,
    -    _ro_base, _ro_base + SharedReadOnlySize);
    -  gclog_or_tty->print("  read-write " INTPTR_FORMAT "-" INTPTR_FORMAT,
    -    _rw_base, _rw_base + SharedReadWriteSize);
    -  gclog_or_tty->cr();
    -  gclog_or_tty->print("  misc-data " INTPTR_FORMAT "-" INTPTR_FORMAT,
    -    _md_base, _md_base + SharedMiscDataSize);
    -  gclog_or_tty->print("  misc-code " INTPTR_FORMAT "-" INTPTR_FORMAT,
    -    _mc_base, _mc_base + SharedMiscCodeSize);
    -  gclog_or_tty->cr();
    +  if (UseSharedSpaces) {
    +    FileMapInfo::current_info()->print_shared_spaces();
    +  }
     }
     
     
    @@ -874,6 +854,11 @@ bool MetaspaceShared::map_shared_spaces(FileMapInfo* mapinfo) {
     
       assert(!DumpSharedSpaces, "Should not be called with DumpSharedSpaces");
     
    +  char* _ro_base = NULL;
    +  char* _rw_base = NULL;
    +  char* _md_base = NULL;
    +  char* _mc_base = NULL;
    +
       // Map each shared region
       if ((_ro_base = mapinfo->map_region(ro)) != NULL &&
           (_rw_base = mapinfo->map_region(rw)) != NULL &&
    
    From 17ebe26fa04dc940965a15d4a54f79eda46e41da Mon Sep 17 00:00:00 2001
    From: Lois Foltan 
    Date: Sun, 30 Jun 2013 09:59:08 -0400
    Subject: [PATCH 047/127] 7007040: Check of capacity paramenters in
     JNI_PushLocalFrame is wrong
    
    Changed AND to OR
    
    Reviewed-by: coleenp, hseigel
    ---
     hotspot/src/share/vm/prims/jni.cpp | 2 +-
     1 file changed, 1 insertion(+), 1 deletion(-)
    
    diff --git a/hotspot/src/share/vm/prims/jni.cpp b/hotspot/src/share/vm/prims/jni.cpp
    index 85f3e2e0e41..f37ea34c46d 100644
    --- a/hotspot/src/share/vm/prims/jni.cpp
    +++ b/hotspot/src/share/vm/prims/jni.cpp
    @@ -879,7 +879,7 @@ JNI_ENTRY(jint, jni_PushLocalFrame(JNIEnv *env, jint capacity))
                                        env, capacity);
     #endif /* USDT2 */
       //%note jni_11
    -  if (capacity < 0 && capacity > MAX_REASONABLE_LOCAL_CAPACITY) {
    +  if (capacity < 0 || capacity > MAX_REASONABLE_LOCAL_CAPACITY) {
     #ifndef USDT2
         DTRACE_PROBE1(hotspot_jni, PushLocalFrame__return, JNI_ERR);
     #else /* USDT2 */
    
    From 8ce6e0db3dd5ce8b8f00e86c91bb472341cdbc2b Mon Sep 17 00:00:00 2001
    From: Volker Simonis 
    Date: Mon, 1 Jul 2013 09:13:19 +0000
    Subject: [PATCH 048/127] 7060111: race condition in VMError::report_and_die()
    
    Reviewed-by: zgu, coleenp
    ---
     hotspot/src/share/vm/utilities/vmError.cpp | 18 +++++++++---------
     hotspot/src/share/vm/utilities/vmError.hpp |  5 ++++-
     2 files changed, 13 insertions(+), 10 deletions(-)
    
    diff --git a/hotspot/src/share/vm/utilities/vmError.cpp b/hotspot/src/share/vm/utilities/vmError.cpp
    index f7b940b52e7..64f753bc75c 100644
    --- a/hotspot/src/share/vm/utilities/vmError.cpp
    +++ b/hotspot/src/share/vm/utilities/vmError.cpp
    @@ -1,5 +1,5 @@
     /*
    - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved.
    + * Copyright (c) 2003, 2013, 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
    @@ -799,6 +799,14 @@ void VMError::report(outputStream* st) {
     VMError* volatile VMError::first_error = NULL;
     volatile jlong VMError::first_error_tid = -1;
     
    +// An error could happen before tty is initialized or after it has been
    +// destroyed. Here we use a very simple unbuffered fdStream for printing.
    +// Only out.print_raw() and out.print_raw_cr() should be used, as other
    +// printing methods need to allocate large buffer on stack. To format a
    +// string, use jio_snprintf() with a static buffer or use staticBufferStream.
    +fdStream VMError::out(defaultStream::output_fd());
    +fdStream VMError::log; // error log used by VMError::report_and_die()
    +
     /** Expand a pattern into a buffer starting at pos and open a file using constructed path */
     static int expand_and_open(const char* pattern, char* buf, size_t buflen, size_t pos) {
       int fd = -1;
    @@ -853,13 +861,6 @@ void VMError::report_and_die() {
       // Don't allocate large buffer on stack
       static char buffer[O_BUFLEN];
     
    -  // An error could happen before tty is initialized or after it has been
    -  // destroyed. Here we use a very simple unbuffered fdStream for printing.
    -  // Only out.print_raw() and out.print_raw_cr() should be used, as other
    -  // printing methods need to allocate large buffer on stack. To format a
    -  // string, use jio_snprintf() with a static buffer or use staticBufferStream.
    -  static fdStream out(defaultStream::output_fd());
    -
       // How many errors occurred in error handler when reporting first_error.
       static int recursive_error_count;
     
    @@ -868,7 +869,6 @@ void VMError::report_and_die() {
       static bool out_done = false;         // done printing to standard out
       static bool log_done = false;         // done saving error log
       static bool transmit_report_done = false; // done error reporting
    -  static fdStream log;                  // error log
     
       // disble NMT to avoid further exception
       MemTracker::shutdown(MemTracker::NMT_error_reporting);
    diff --git a/hotspot/src/share/vm/utilities/vmError.hpp b/hotspot/src/share/vm/utilities/vmError.hpp
    index f298c1edbf5..1b1608bdc90 100644
    --- a/hotspot/src/share/vm/utilities/vmError.hpp
    +++ b/hotspot/src/share/vm/utilities/vmError.hpp
    @@ -1,5 +1,5 @@
     /*
    - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved.
    + * Copyright (c) 2003, 2013, 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
    @@ -96,6 +96,9 @@ class VMError : public StackObj {
         return (id != OOM_MALLOC_ERROR) && (id != OOM_MMAP_ERROR);
       }
     
    +  static fdStream out;
    +  static fdStream log; // error log used by VMError::report_and_die()
    +
     public:
     
       // Constructor for crashes
    
    From 2977c8fca37be2ecedb504684daa93b3a6a7b89c Mon Sep 17 00:00:00 2001
    From: =?UTF-8?q?Rickard=20B=C3=A4ckman?= 
    Date: Wed, 12 Jun 2013 09:49:42 +0200
    Subject: [PATCH 049/127] 8016444: Duplicate zombie check in safe_for_sender
    
    Reviewed-by: dholmes, sla
    ---
     hotspot/src/cpu/sparc/vm/frame_sparc.cpp                | 5 -----
     hotspot/src/share/vm/memory/referenceProcessorStats.hpp | 2 +-
     2 files changed, 1 insertion(+), 6 deletions(-)
    
    diff --git a/hotspot/src/cpu/sparc/vm/frame_sparc.cpp b/hotspot/src/cpu/sparc/vm/frame_sparc.cpp
    index 55f344f55a1..ac9746679b3 100644
    --- a/hotspot/src/cpu/sparc/vm/frame_sparc.cpp
    +++ b/hotspot/src/cpu/sparc/vm/frame_sparc.cpp
    @@ -257,11 +257,6 @@ bool frame::safe_for_sender(JavaThread *thread) {
           return false;
         }
     
    -    // Could be a zombie method
    -    if (sender_blob->is_zombie() || sender_blob->is_unloaded()) {
    -      return false;
    -    }
    -
         // It should be safe to construct the sender though it might not be valid
     
         frame sender(_SENDER_SP, younger_sp, adjusted_stack);
    diff --git a/hotspot/src/share/vm/memory/referenceProcessorStats.hpp b/hotspot/src/share/vm/memory/referenceProcessorStats.hpp
    index 73208331bac..7497c09b92f 100644
    --- a/hotspot/src/share/vm/memory/referenceProcessorStats.hpp
    +++ b/hotspot/src/share/vm/memory/referenceProcessorStats.hpp
    @@ -1,5 +1,5 @@
     /*
    - * Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved.
    + * Copyright (c) 2012, 2013, 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
    
    From 93241c0ecb0fc17b8999790d92f57b70c617ac6a Mon Sep 17 00:00:00 2001
    From: Athijegannathan Sundararajan 
    Date: Tue, 18 Jun 2013 18:43:05 +0530
    Subject: [PATCH 050/127] 8012698: [nashorn] tests fail to run with agentvm or
     samevm
    
    Reviewed-by: hannesw, jlaskey
    ---
     .../test/src/jdk/nashorn/api/javaaccess/BooleanAccessTest.java  | 2 +-
     .../test/src/jdk/nashorn/api/javaaccess/MethodAccessTest.java   | 2 +-
     .../test/src/jdk/nashorn/api/javaaccess/NumberAccessTest.java   | 2 +-
     .../test/src/jdk/nashorn/api/javaaccess/NumberBoxingTest.java   | 2 +-
     .../test/src/jdk/nashorn/api/javaaccess/ObjectAccessTest.java   | 2 +-
     .../test/src/jdk/nashorn/api/javaaccess/StringAccessTest.java   | 2 +-
     6 files changed, 6 insertions(+), 6 deletions(-)
    
    diff --git a/nashorn/test/src/jdk/nashorn/api/javaaccess/BooleanAccessTest.java b/nashorn/test/src/jdk/nashorn/api/javaaccess/BooleanAccessTest.java
    index 2cfdbf00046..b6e5bbcddc9 100644
    --- a/nashorn/test/src/jdk/nashorn/api/javaaccess/BooleanAccessTest.java
    +++ b/nashorn/test/src/jdk/nashorn/api/javaaccess/BooleanAccessTest.java
    @@ -39,7 +39,7 @@ import org.testng.annotations.Test;
     /**
      * @test
      * @build jdk.nashorn.api.javaaccess.SharedObject jdk.nashorn.api.javaaccess.Person jdk.nashorn.api.javaaccess.BooleanAccessTest
    - * @run testng jdk.nashorn.api.javaaccess.BooleanAccessTest
    + * @run testng/othervm jdk.nashorn.api.javaaccess.BooleanAccessTest
      */
     public class BooleanAccessTest {
     
    diff --git a/nashorn/test/src/jdk/nashorn/api/javaaccess/MethodAccessTest.java b/nashorn/test/src/jdk/nashorn/api/javaaccess/MethodAccessTest.java
    index 69ca20c6c16..6de10a54783 100644
    --- a/nashorn/test/src/jdk/nashorn/api/javaaccess/MethodAccessTest.java
    +++ b/nashorn/test/src/jdk/nashorn/api/javaaccess/MethodAccessTest.java
    @@ -42,7 +42,7 @@ import org.testng.annotations.Test;
     /**
      * @test
      * @build jdk.nashorn.api.javaaccess.SharedObject jdk.nashorn.api.javaaccess.Person jdk.nashorn.api.javaaccess.MethodAccessTest
    - * @run testng jdk.nashorn.api.javaaccess.MethodAccessTest
    + * @run testng/othervm jdk.nashorn.api.javaaccess.MethodAccessTest
      */
     public class MethodAccessTest {
     
    diff --git a/nashorn/test/src/jdk/nashorn/api/javaaccess/NumberAccessTest.java b/nashorn/test/src/jdk/nashorn/api/javaaccess/NumberAccessTest.java
    index 21994960176..0b7cb027b61 100644
    --- a/nashorn/test/src/jdk/nashorn/api/javaaccess/NumberAccessTest.java
    +++ b/nashorn/test/src/jdk/nashorn/api/javaaccess/NumberAccessTest.java
    @@ -39,7 +39,7 @@ import org.testng.annotations.Test;
     /**
      * @test
      * @build jdk.nashorn.api.javaaccess.SharedObject jdk.nashorn.api.javaaccess.Person jdk.nashorn.api.javaaccess.NumberAccessTest
    - * @run testng jdk.nashorn.api.javaaccess.NumberAccessTest
    + * @run testng/othervm jdk.nashorn.api.javaaccess.NumberAccessTest
      */
     public class NumberAccessTest {
     
    diff --git a/nashorn/test/src/jdk/nashorn/api/javaaccess/NumberBoxingTest.java b/nashorn/test/src/jdk/nashorn/api/javaaccess/NumberBoxingTest.java
    index ae719e7fb62..0302259e95b 100644
    --- a/nashorn/test/src/jdk/nashorn/api/javaaccess/NumberBoxingTest.java
    +++ b/nashorn/test/src/jdk/nashorn/api/javaaccess/NumberBoxingTest.java
    @@ -38,7 +38,7 @@ import org.testng.annotations.Test;
     /**
      * @test
      * @build jdk.nashorn.api.javaaccess.SharedObject jdk.nashorn.api.javaaccess.Person jdk.nashorn.api.javaaccess.NumberBoxingTest
    - * @run testng jdk.nashorn.api.javaaccess.NumberBoxingTest
    + * @run testng/othervm jdk.nashorn.api.javaaccess.NumberBoxingTest
      */
     public class NumberBoxingTest {
     
    diff --git a/nashorn/test/src/jdk/nashorn/api/javaaccess/ObjectAccessTest.java b/nashorn/test/src/jdk/nashorn/api/javaaccess/ObjectAccessTest.java
    index 7172051416c..2a51e7a9ce1 100644
    --- a/nashorn/test/src/jdk/nashorn/api/javaaccess/ObjectAccessTest.java
    +++ b/nashorn/test/src/jdk/nashorn/api/javaaccess/ObjectAccessTest.java
    @@ -38,7 +38,7 @@ import org.testng.annotations.Test;
     /**
      * @test
      * @build jdk.nashorn.api.javaaccess.SharedObject jdk.nashorn.api.javaaccess.Person jdk.nashorn.api.javaaccess.ObjectAccessTest
    - * @run testng jdk.nashorn.api.javaaccess.ObjectAccessTest
    + * @run testng/othervm jdk.nashorn.api.javaaccess.ObjectAccessTest
      */
     public class ObjectAccessTest {
     
    diff --git a/nashorn/test/src/jdk/nashorn/api/javaaccess/StringAccessTest.java b/nashorn/test/src/jdk/nashorn/api/javaaccess/StringAccessTest.java
    index 6a7713bd6a4..dd4b5020787 100644
    --- a/nashorn/test/src/jdk/nashorn/api/javaaccess/StringAccessTest.java
    +++ b/nashorn/test/src/jdk/nashorn/api/javaaccess/StringAccessTest.java
    @@ -38,7 +38,7 @@ import org.testng.annotations.Test;
     /**
      * @test
      * @build jdk.nashorn.api.javaaccess.SharedObject jdk.nashorn.api.javaaccess.Person jdk.nashorn.api.javaaccess.StringAccessTest
    - * @run testng jdk.nashorn.api.javaaccess.StringAccessTest
    + * @run testng/othervm jdk.nashorn.api.javaaccess.StringAccessTest
      */
     public class StringAccessTest {
     
    
    From d643a2fcd763aa3b4c7a0fc107d0b6a441b938ca Mon Sep 17 00:00:00 2001
    From: James Laskey 
    Date: Wed, 19 Jun 2013 09:10:49 -0300
    Subject: [PATCH 051/127] 8010697: DeletedArrayFilter seems to leak memory
    
    Reviewed-by: hannesw, sundar
    ---
     .../nashorn/internal/objects/NativeArray.java |  8 ++-
     .../internal/runtime/arrays/ArrayData.java    | 23 ++++++++
     .../internal/runtime/arrays/ArrayFilter.java  | 12 ++++
     .../runtime/arrays/DeletedArrayFilter.java    |  2 +
     .../arrays/DeletedRangeArrayFilter.java       |  3 +
     .../runtime/arrays/ObjectArrayData.java       | 16 ++++-
     .../runtime/arrays/SparseArrayData.java       | 12 ++++
     nashorn/test/script/basic/JDK-8010697.js      | 59 +++++++++++++++++++
     .../test/script/basic/JDK-8010697.js.EXPECTED |  1 +
     9 files changed, 133 insertions(+), 3 deletions(-)
     create mode 100644 nashorn/test/script/basic/JDK-8010697.js
     create mode 100644 nashorn/test/script/basic/JDK-8010697.js.EXPECTED
    
    diff --git a/nashorn/src/jdk/nashorn/internal/objects/NativeArray.java b/nashorn/src/jdk/nashorn/internal/objects/NativeArray.java
    index a480c590062..6eb3603784c 100644
    --- a/nashorn/src/jdk/nashorn/internal/objects/NativeArray.java
    +++ b/nashorn/src/jdk/nashorn/internal/objects/NativeArray.java
    @@ -856,8 +856,12 @@ public final class NativeArray extends ScriptObject {
                     }
     
                     // delete missing elements - which are at the end of sorted array
    -                sobj.setArray(array.delete(sorted.length, len - 1));
    -            }
    +                if (sorted.length != len) {
    +                    array = array.delete(sorted.length, len - 1);
    +                }
    +
    +                sobj.setArray(array);
    +           }
     
                 return sobj;
             } catch (final ClassCastException | NullPointerException e) {
    diff --git a/nashorn/src/jdk/nashorn/internal/runtime/arrays/ArrayData.java b/nashorn/src/jdk/nashorn/internal/runtime/arrays/ArrayData.java
    index fca724a8bf3..d11059b275d 100644
    --- a/nashorn/src/jdk/nashorn/internal/runtime/arrays/ArrayData.java
    +++ b/nashorn/src/jdk/nashorn/internal/runtime/arrays/ArrayData.java
    @@ -294,6 +294,29 @@ public abstract class ArrayData {
          */
         public abstract ArrayData set(int index, double value, boolean strict);
     
    +    /**
    +     * Set an empty value at a given index. Should only affect Object array.
    +     *
    +     * @param index the index
    +     * @return new array data (or same)
    +     */
    +    public ArrayData setEmpty(final int index) {
    +        // Do nothing.
    +        return this;
    +    }
    +
    +    /**
    +     * Set an empty value for a given range. Should only affect Object array.
    +     *
    +     * @param lo range low end
    +     * @param hi range high end
    +     * @return new array data (or same)
    +     */
    +    public ArrayData setEmpty(final long lo, final long hi) {
    +        // Do nothing.
    +        return this;
    +    }
    +
         /**
          * Get an int value from a given index
          *
    diff --git a/nashorn/src/jdk/nashorn/internal/runtime/arrays/ArrayFilter.java b/nashorn/src/jdk/nashorn/internal/runtime/arrays/ArrayFilter.java
    index c347ed70e8b..7a20f788fda 100644
    --- a/nashorn/src/jdk/nashorn/internal/runtime/arrays/ArrayFilter.java
    +++ b/nashorn/src/jdk/nashorn/internal/runtime/arrays/ArrayFilter.java
    @@ -128,6 +128,18 @@ abstract class ArrayFilter extends ArrayData {
             return this;
         }
     
    +    @Override
    +    public ArrayData setEmpty(final int index) {
    +        underlying.setEmpty(index);
    +        return this;
    +    }
    +
    +    @Override
    +    public ArrayData setEmpty(final long lo, final long hi) {
    +        underlying.setEmpty(lo, hi);
    +        return this;
    +    }
    +
         @Override
         public int getInt(final int index) {
             return underlying.getInt(index);
    diff --git a/nashorn/src/jdk/nashorn/internal/runtime/arrays/DeletedArrayFilter.java b/nashorn/src/jdk/nashorn/internal/runtime/arrays/DeletedArrayFilter.java
    index 57bea4cf1e6..b5f1f16d024 100644
    --- a/nashorn/src/jdk/nashorn/internal/runtime/arrays/DeletedArrayFilter.java
    +++ b/nashorn/src/jdk/nashorn/internal/runtime/arrays/DeletedArrayFilter.java
    @@ -142,6 +142,7 @@ final class DeletedArrayFilter extends ArrayFilter {
             final long longIndex = ArrayIndex.toLongIndex(index);
             assert longIndex >= 0 && longIndex < length();
             deleted.set(longIndex);
    +        underlying.setEmpty(index);
             return this;
         }
     
    @@ -149,6 +150,7 @@ final class DeletedArrayFilter extends ArrayFilter {
         public ArrayData delete(final long fromIndex, final long toIndex) {
             assert fromIndex >= 0 && fromIndex <= toIndex && toIndex < length();
             deleted.setRange(fromIndex, toIndex + 1);
    +        underlying.setEmpty(fromIndex, toIndex);
             return this;
         }
     
    diff --git a/nashorn/src/jdk/nashorn/internal/runtime/arrays/DeletedRangeArrayFilter.java b/nashorn/src/jdk/nashorn/internal/runtime/arrays/DeletedRangeArrayFilter.java
    index 588252ac4f2..29c443bae10 100644
    --- a/nashorn/src/jdk/nashorn/internal/runtime/arrays/DeletedRangeArrayFilter.java
    +++ b/nashorn/src/jdk/nashorn/internal/runtime/arrays/DeletedRangeArrayFilter.java
    @@ -202,6 +202,8 @@ final class DeletedRangeArrayFilter extends ArrayFilter {
         @Override
         public ArrayData delete(final int index) {
             final long longIndex = ArrayIndex.toLongIndex(index);
    +        underlying.setEmpty(index);
    +
             if (longIndex + 1 == lo) {
                 lo = longIndex;
             } else if (longIndex - 1 == hi) {
    @@ -220,6 +222,7 @@ final class DeletedRangeArrayFilter extends ArrayFilter {
             }
             lo = Math.min(fromIndex, lo);
             hi = Math.max(toIndex, hi);
    +        underlying.setEmpty(lo, hi);
             return this;
         }
     
    diff --git a/nashorn/src/jdk/nashorn/internal/runtime/arrays/ObjectArrayData.java b/nashorn/src/jdk/nashorn/internal/runtime/arrays/ObjectArrayData.java
    index cb1e2fa03ba..4b1f58a430a 100644
    --- a/nashorn/src/jdk/nashorn/internal/runtime/arrays/ObjectArrayData.java
    +++ b/nashorn/src/jdk/nashorn/internal/runtime/arrays/ObjectArrayData.java
    @@ -138,6 +138,18 @@ final class ObjectArrayData extends ArrayData {
             return this;
         }
     
    +    @Override
    +    public ArrayData setEmpty(final int index) {
    +        array[index] = ScriptRuntime.EMPTY;
    +        return this;
    +    }
    +
    +    @Override
    +    public ArrayData setEmpty(final long lo, final long hi) {
    +        Arrays.fill(array, (int)Math.max(lo, 0L), (int)Math.min(hi, (long)Integer.MAX_VALUE), ScriptRuntime.EMPTY);
    +        return this;
    +    }
    +
         @Override
         public int getInt(final int index) {
             return JSType.toInt32(array[index]);
    @@ -165,11 +177,13 @@ final class ObjectArrayData extends ArrayData {
     
         @Override
         public ArrayData delete(final int index) {
    +        setEmpty(index);
             return new DeletedRangeArrayFilter(this, index, index);
         }
     
         @Override
         public ArrayData delete(final long fromIndex, final long toIndex) {
    +        setEmpty(fromIndex, toIndex);
             return new DeletedRangeArrayFilter(this, fromIndex, toIndex);
         }
     
    @@ -181,7 +195,7 @@ final class ObjectArrayData extends ArrayData {
     
             final int newLength = (int) (length() - 1);
             final Object elem = array[newLength];
    -        array[newLength] = 0;
    +        setEmpty(newLength);
             setLength(newLength);
             return elem;
         }
    diff --git a/nashorn/src/jdk/nashorn/internal/runtime/arrays/SparseArrayData.java b/nashorn/src/jdk/nashorn/internal/runtime/arrays/SparseArrayData.java
    index fd52f22db83..0ccbb23c535 100644
    --- a/nashorn/src/jdk/nashorn/internal/runtime/arrays/SparseArrayData.java
    +++ b/nashorn/src/jdk/nashorn/internal/runtime/arrays/SparseArrayData.java
    @@ -203,6 +203,18 @@ class SparseArrayData extends ArrayData {
             return this;
         }
     
    +    @Override
    +    public ArrayData setEmpty(final int index) {
    +        underlying.setEmpty(index);
    +        return this;
    +    }
    +
    +    @Override
    +    public ArrayData setEmpty(final long lo, final long hi) {
    +        underlying.setEmpty(lo, hi);
    +        return this;
    +    }
    +
         @Override
         public int getInt(final int index) {
             if (index >= 0 && index < maxDenseLength) {
    diff --git a/nashorn/test/script/basic/JDK-8010697.js b/nashorn/test/script/basic/JDK-8010697.js
    new file mode 100644
    index 00000000000..c1b8e572937
    --- /dev/null
    +++ b/nashorn/test/script/basic/JDK-8010697.js
    @@ -0,0 +1,59 @@
    +/*
    + * Copyright (c) 2010, 2013, 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.
    + */
    +
    +/**
    + * JDK-8010697: DeletedArrayFilter seems to leak memory
    + *
    + * @test
    + * @run
    + */
    +
    +var N = 1000;
    +
    +var array = new Array(N);
    +var WeakReferenceArray = Java.type("java.lang.ref.WeakReference[]");
    +var refArray = new WeakReferenceArray(N);
    +
    +for (var i = 0; i < N; i ++) {
    +    var object = new java.lang.Object();
    +    array[i] = object;
    +    refArray[i] = new java.lang.ref.WeakReference(object);
    +}
    +
    +object = null;
    +
    +for (var i = 0; i < N; i ++) {
    +    delete array[i];
    +}
    +
    +java.lang.System.gc();
    +java.lang.System.gc();
    +
    +for (var i = 0; i < N; i ++) {
    +    if (refArray[i].get() != null) {
    +        print("Reference found at " + i);
    +        exit(0);
    +    }
    +}
    +
    +print("All references gone");
    diff --git a/nashorn/test/script/basic/JDK-8010697.js.EXPECTED b/nashorn/test/script/basic/JDK-8010697.js.EXPECTED
    new file mode 100644
    index 00000000000..fe74109082d
    --- /dev/null
    +++ b/nashorn/test/script/basic/JDK-8010697.js.EXPECTED
    @@ -0,0 +1 @@
    +All references gone
    
    From 1d927dd28e688ae698294beebd1b6ebc380e1595 Mon Sep 17 00:00:00 2001
    From: Athijegannathan Sundararajan 
    Date: Wed, 19 Jun 2013 21:07:59 +0530
    Subject: [PATCH 052/127] 8015347: Parsing issue with decodeURIComponent
    
    Reviewed-by: jlaskey, hannesw
    ---
     .../nashorn/internal/runtime/URIUtils.java    | 68 +++++++++++--------
     nashorn/test/script/basic/JDK-8015347.js      | 39 +++++++++++
     2 files changed, 80 insertions(+), 27 deletions(-)
     create mode 100644 nashorn/test/script/basic/JDK-8015347.js
    
    diff --git a/nashorn/src/jdk/nashorn/internal/runtime/URIUtils.java b/nashorn/src/jdk/nashorn/internal/runtime/URIUtils.java
    index 448d72c364f..2321353fbaa 100644
    --- a/nashorn/src/jdk/nashorn/internal/runtime/URIUtils.java
    +++ b/nashorn/src/jdk/nashorn/internal/runtime/URIUtils.java
    @@ -27,8 +27,6 @@ package jdk.nashorn.internal.runtime;
     
     import static jdk.nashorn.internal.runtime.ECMAErrors.uriError;
     
    -import java.io.UnsupportedEncodingException;
    -
     /**
      * URI handling global functions. ECMA 15.1.3 URI Handling Function Properties
      *
    @@ -127,6 +125,7 @@ public final class URIUtils {
     
                 k += 2;
                 char C;
    +            // Most significant bit is zero
                 if ((B & 0x80) == 0) {
                     C = (char) B;
                     if (!component && URI_RESERVED.indexOf(C) >= 0) {
    @@ -137,49 +136,68 @@ public final class URIUtils {
                         sb.append(C);
                     }
                 } else {
    -                int n;
    -                for (n = 1; n < 6; n++) {
    -                    if (((B << n) & 0x80) == 0) {
    -                        break;
    -                    }
    -                }
    +                // n is utf8 length, V is codepoint and minV is lower bound
    +                int n, V, minV;
     
    -                if (n == 1 || n > 4) {
    +                if ((B & 0xC0) == 0x80) {
    +                    // 10xxxxxx - illegal first byte
    +                    return error(string, k);
    +                } else if ((B & 0x20) == 0) {
    +                    // 110xxxxx 10xxxxxx
    +                    n = 2;
    +                    V = B & 0x1F;
    +                    minV = 0x80;
    +                } else if ((B & 0x10) == 0) {
    +                    // 1110xxxx 10xxxxxx 10xxxxxx
    +                    n = 3;
    +                    V = B & 0x0F;
    +                    minV = 0x800;
    +                } else if ((B & 0x08) == 0) {
    +                    // 11110xxx 10xxxxxx 10xxxxxx 10xxxxxx
    +                    n = 4;
    +                    V = B & 0x07;
    +                    minV = 0x10000;
    +                } else if ((B & 0x04) == 0) {
    +                    // 111110xx 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx
    +                    n = 5;
    +                    V =  B & 0x03;
    +                    minV = 0x200000;
    +                } else if ((B & 0x02) == 0) {
    +                    // 1111110x 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx
    +                    n = 6;
    +                    V = B & 0x01;
    +                    minV = 0x4000000;
    +                } else {
                         return error(string, k);
                     }
     
    -                if ((k + (3 * (n - 1))) >= len) {
    +                // check bound for sufficient chars
    +                if (k + (3*(n-1)) >= len) {
                         return error(string, k);
                     }
     
    -                final byte[] bbuf = new byte[n];
    -                bbuf[0] = (byte) B;
    -
                     for (int j = 1; j < n; j++) {
                         k++;
                         if (string.charAt(k) != '%') {
                             return error(string, k);
                         }
     
    -                    if (k + 2 == len) {
    -                        return error(string, k);
    -                    }
    -
                         B = toHexByte(string.charAt(k + 1), string.charAt(k + 2));
                         if (B < 0 || (B & 0xC0) != 0x80) {
                             return error(string, k + 1);
                         }
     
    +                    V = (V << 6) | (B & 0x3F);
                         k += 2;
    -                    bbuf[j] = (byte) B;
                     }
     
    -                int V;
    -                try {
    -                    V = ucs4Char(bbuf);
    -                } catch (final Exception e) {
    -                    throw uriError(e, "bad.uri", string, Integer.toString(k));
    +                // Check for overlongs and invalid codepoints.
    +                // The high and low surrogate halves used by UTF-16
    +                // (U+D800 through U+DFFF) are not legal Unicode values.
    +                if ((V < minV) || (V >= 0xD800 && V <= 0xDFFF)) {
    +                    V = Integer.MAX_VALUE;
                     }
    +
                     if (V < 0x10000) {
                         C = (char) V;
                         if (!component && URI_RESERVED.indexOf(C) >= 0) {
    @@ -224,10 +242,6 @@ public final class URIUtils {
             return -1;
         }
     
    -    private static int ucs4Char(final byte[] utf8) throws UnsupportedEncodingException {
    -        return new String(utf8, "UTF-8").codePointAt(0);
    -    }
    -
         private static String toHexEscape(final int u0) {
             int u = u0;
             int len;
    diff --git a/nashorn/test/script/basic/JDK-8015347.js b/nashorn/test/script/basic/JDK-8015347.js
    new file mode 100644
    index 00000000000..d5a8ba318c0
    --- /dev/null
    +++ b/nashorn/test/script/basic/JDK-8015347.js
    @@ -0,0 +1,39 @@
    +/*
    + * Copyright (c) 2010, 2013, 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.
    + */
    +
    +/**
    + * JDK-8015347: Parsing issue with decodeURIComponent
    + *
    + * @test
    + * @run
    + */
    +
    +try {
    +    decodeURIComponent("%C0%80");
    +    fail("Should have thrown URIError");
    +} catch (e) {
    +    if (! (e instanceof URIError)) {
    +        fail("Expected URIError, but got " + e);
    +    }
    +}
    +
    
    From 9e051832007aef670c22961aed2d8610ad892eb3 Mon Sep 17 00:00:00 2001
    From: Athijegannathan Sundararajan 
    Date: Thu, 20 Jun 2013 13:45:38 +0530
    Subject: [PATCH 053/127] 8017046: Cannot assign undefined to a function
     argument if the function uses arguments object
    
    Reviewed-by: hannesw
    ---
     .../internal/objects/NativeArguments.java     |  2 +-
     nashorn/test/script/basic/JDK-8017046.js      | 46 +++++++++++++++++++
     2 files changed, 47 insertions(+), 1 deletion(-)
     create mode 100644 nashorn/test/script/basic/JDK-8017046.js
    
    diff --git a/nashorn/src/jdk/nashorn/internal/objects/NativeArguments.java b/nashorn/src/jdk/nashorn/internal/objects/NativeArguments.java
    index d92d7fb3ee7..dc95315d860 100644
    --- a/nashorn/src/jdk/nashorn/internal/objects/NativeArguments.java
    +++ b/nashorn/src/jdk/nashorn/internal/objects/NativeArguments.java
    @@ -125,7 +125,7 @@ public final class NativeArguments extends ScriptObject {
         @Override
         public void setArgument(final int key, final Object value) {
             if (namedArgs.has(key)) {
    -            namedArgs.set(key, value, false);
    +            namedArgs = namedArgs.set(key, value, false);
             }
         }
     
    diff --git a/nashorn/test/script/basic/JDK-8017046.js b/nashorn/test/script/basic/JDK-8017046.js
    new file mode 100644
    index 00000000000..7097e9f5c79
    --- /dev/null
    +++ b/nashorn/test/script/basic/JDK-8017046.js
    @@ -0,0 +1,46 @@
    +/*
    + * Copyright (c) 2010, 2013, 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.
    + */
    +
    +/**
    + * JDK-8017046: Cannot assign undefined to a function argument if the function uses arguments object
    + *
    + * @test
    + * @run
    + */
    +
    +function assert(value, msg) {
    +    if (! value) {
    +        fail(msg);
    +    }
    +}
    +
    +function func(a) {
    +    assert(a === arguments[0], "a !== arguments[0]");
    +    assert(a === "hello", "a !== 'hello'");
    +    a = undefined;
    +    assert(a === arguments[0], "a !== arguments[0]");
    +    assert(a === undefined, "a !== undefined");
    +    assert(typeof(a) === 'undefined', "typeof(a) is not 'undefined'");
    +}
    +
    +func("hello");
    
    From 4fb1e1757ab890fd6053a1aee9c82b429b4432e9 Mon Sep 17 00:00:00 2001
    From: Leonid Romanov 
    Date: Thu, 20 Jun 2013 18:50:55 +0400
    Subject: [PATCH 054/127] 8014264: The applet pathguy_TimeDead throws
     java.lang.NullPointerException in java console once click drop-down check box
    
    Reviewed-by: art, anthony, serb
    ---
     .../classes/sun/awt/X11/XBaseMenuWindow.java  | 16 ++++++----
     .../classes/sun/awt/X11/XChoicePeer.java      | 32 +++++++++++--------
     .../classes/sun/awt/X11/XListPeer.java        | 13 ++++----
     3 files changed, 34 insertions(+), 27 deletions(-)
    
    diff --git a/jdk/src/solaris/classes/sun/awt/X11/XBaseMenuWindow.java b/jdk/src/solaris/classes/sun/awt/X11/XBaseMenuWindow.java
    index f0b1aef36cd..ade334c269b 100644
    --- a/jdk/src/solaris/classes/sun/awt/X11/XBaseMenuWindow.java
    +++ b/jdk/src/solaris/classes/sun/awt/X11/XBaseMenuWindow.java
    @@ -1,5 +1,5 @@
     /*
    - * Copyright (c) 2005, 2008, Oracle and/or its affiliates. All rights reserved.
    + * Copyright (c) 2005, 2013, 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
    @@ -904,11 +904,12 @@ abstract public class XBaseMenuWindow extends XWindow {
          */
         public void dispose() {
             setDisposed(true);
    -        EventQueue.invokeLater(new Runnable() {
    +        InvocationEvent ev = new InvocationEvent(target, new Runnable() {
                 public void run() {
                     doDispose();
                 }
             });
    +        super.postEvent(ev);
         }
     
         /**
    @@ -933,11 +934,12 @@ abstract public class XBaseMenuWindow extends XWindow {
          * so events can not be processed using standart means
          */
         void postEvent(final AWTEvent event) {
    -        EventQueue.invokeLater(new Runnable() {
    -                public void run() {
    -                    handleEvent(event);
    -                }
    -            });
    +        InvocationEvent ev = new InvocationEvent(event.getSource(), new Runnable() {
    +            public void run() {
    +                handleEvent(event);
    +            }
    +        });
    +        super.postEvent(ev);
         }
     
         /**
    diff --git a/jdk/src/solaris/classes/sun/awt/X11/XChoicePeer.java b/jdk/src/solaris/classes/sun/awt/X11/XChoicePeer.java
    index a9fc4969875..d06bdb90fd0 100644
    --- a/jdk/src/solaris/classes/sun/awt/X11/XChoicePeer.java
    +++ b/jdk/src/solaris/classes/sun/awt/X11/XChoicePeer.java
    @@ -1,5 +1,5 @@
     /*
    - * Copyright (c) 2003, 2007, Oracle and/or its affiliates. All rights reserved.
    + * Copyright (c) 2003, 2013, 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
    @@ -1033,15 +1033,17 @@ public class XChoicePeer extends XComponentPeer implements ChoicePeer, ToplevelS
                 //fix 6252982: PIT: Keyboard FocusTraversal not working when choice's drop-down is visible, on XToolkit
                 if (e instanceof KeyEvent){
                     // notify XWindow that this event had been already handled and no need to post it again
    -                EventQueue.invokeLater(new Runnable() {
    -                        public void run() {
    -                            if(target.isFocusable() &&
    -                               getParentTopLevel().isFocusableWindow() )
    -                            {
    -                                handleJavaKeyEvent((KeyEvent)e);
    -                            }
    +                InvocationEvent ev = new InvocationEvent(target, new Runnable() {
    +                    public void run() {
    +                        if(target.isFocusable() &&
    +                                getParentTopLevel().isFocusableWindow() )
    +                        {
    +                            handleJavaKeyEvent((KeyEvent)e);
                             }
    -                    });
    +                    }
    +                });
    +                postEvent(ev);
    +
                     return true;
                 } else {
                     if (e instanceof MouseEvent){
    @@ -1083,11 +1085,13 @@ public class XChoicePeer extends XComponentPeer implements ChoicePeer, ToplevelS
         //convenient method
         //do not generate this kind of Events
         public boolean handleMouseEventByChoice(final MouseEvent me){
    -        EventQueue.invokeLater(new Runnable() {
    -                public void run() {
    -                    handleJavaMouseEvent(me);
    -                }
    -            });
    +        InvocationEvent ev = new InvocationEvent(target, new Runnable() {
    +            public void run() {
    +                handleJavaMouseEvent(me);
    +            }
    +        });
    +        postEvent(ev);
    +
             return true;
         }
     
    diff --git a/jdk/src/solaris/classes/sun/awt/X11/XListPeer.java b/jdk/src/solaris/classes/sun/awt/X11/XListPeer.java
    index eeeed3975cd..7d2ac0fe14a 100644
    --- a/jdk/src/solaris/classes/sun/awt/X11/XListPeer.java
    +++ b/jdk/src/solaris/classes/sun/awt/X11/XListPeer.java
    @@ -1,5 +1,5 @@
     /*
    - * Copyright (c) 2003, 2008, Oracle and/or its affiliates. All rights reserved.
    + * Copyright (c) 2003, 2013, 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
    @@ -1669,11 +1669,12 @@ class XListPeer extends XComponentPeer implements ListPeer, XScrollbarClient {
          * Do handleJavaMouseEvent on EDT
          */
         void handleJavaMouseEventOnEDT(final MouseEvent me){
    -        EventQueue.invokeLater(new Runnable() {
    -                public void run() {
    -                    handleJavaMouseEvent(me);
    -                }
    -            });
    +        InvocationEvent ev = new InvocationEvent(target, new Runnable() {
    +            public void run() {
    +                handleJavaMouseEvent(me);
    +            }
    +        });
    +        postEvent(ev);
         }
     
         /*
    
    From 6f8f3be8c3aac40741cbfdbe2df044856ec51132 Mon Sep 17 00:00:00 2001
    From: Athijegannathan Sundararajan 
    Date: Fri, 21 Jun 2013 16:55:18 +0530
    Subject: [PATCH 055/127] 8017260: adjust lookup code in objects.* classes
    
    Reviewed-by: hannesw, jlaskey
    ---
     nashorn/src/jdk/nashorn/internal/objects/Global.java     | 9 +++++++--
     .../jdk/nashorn/internal/objects/NativeArguments.java    | 9 +++++++--
     .../src/jdk/nashorn/internal/objects/NativeError.java    | 7 ++++++-
     .../nashorn/internal/objects/NativeStrictArguments.java  | 7 ++++++-
     .../jdk/nashorn/internal/objects/PrototypeObject.java    | 7 ++++++-
     5 files changed, 32 insertions(+), 7 deletions(-)
    
    diff --git a/nashorn/src/jdk/nashorn/internal/objects/Global.java b/nashorn/src/jdk/nashorn/internal/objects/Global.java
    index 59a9dd34a20..8de71c887c1 100644
    --- a/nashorn/src/jdk/nashorn/internal/objects/Global.java
    +++ b/nashorn/src/jdk/nashorn/internal/objects/Global.java
    @@ -25,9 +25,9 @@
     
     package jdk.nashorn.internal.objects;
     
    +import static jdk.nashorn.internal.lookup.Lookup.MH;
     import static jdk.nashorn.internal.runtime.ECMAErrors.typeError;
     import static jdk.nashorn.internal.runtime.ScriptRuntime.UNDEFINED;
    -import static jdk.nashorn.internal.lookup.Lookup.MH;
     
     import java.io.IOException;
     import java.io.PrintWriter;
    @@ -43,6 +43,7 @@ import java.util.List;
     import java.util.Map;
     import jdk.internal.dynalink.linker.GuardedInvocation;
     import jdk.internal.dynalink.linker.LinkRequest;
    +import jdk.nashorn.internal.lookup.MethodHandleFactory;
     import jdk.nashorn.internal.objects.annotations.Attribute;
     import jdk.nashorn.internal.objects.annotations.Property;
     import jdk.nashorn.internal.objects.annotations.ScriptClass;
    @@ -1780,7 +1781,11 @@ public final class Global extends ScriptObject implements GlobalObject, Scope {
     
     
         private static MethodHandle findOwnMH(final String name, final Class rtype, final Class... types) {
    -        return MH.findStatic(MethodHandles.publicLookup(), Global.class, name, MH.type(rtype, types));
    +        try {
    +            return MethodHandles.lookup().findStatic(Global.class, name, MH.type(rtype, types));
    +        } catch (final NoSuchMethodException | IllegalAccessException e) {
    +            throw new MethodHandleFactory.LookupException(e);
    +        }
         }
     
         RegExpResult getLastRegExpResult() {
    diff --git a/nashorn/src/jdk/nashorn/internal/objects/NativeArguments.java b/nashorn/src/jdk/nashorn/internal/objects/NativeArguments.java
    index dc95315d860..4898c48b8ed 100644
    --- a/nashorn/src/jdk/nashorn/internal/objects/NativeArguments.java
    +++ b/nashorn/src/jdk/nashorn/internal/objects/NativeArguments.java
    @@ -25,9 +25,9 @@
     
     package jdk.nashorn.internal.objects;
     
    +import static jdk.nashorn.internal.lookup.Lookup.MH;
     import static jdk.nashorn.internal.runtime.ECMAErrors.typeError;
     import static jdk.nashorn.internal.runtime.ScriptRuntime.UNDEFINED;
    -import static jdk.nashorn.internal.lookup.Lookup.MH;
     
     import java.lang.invoke.MethodHandle;
     import java.lang.invoke.MethodHandles;
    @@ -42,6 +42,7 @@ import jdk.nashorn.internal.runtime.ScriptRuntime;
     import jdk.nashorn.internal.runtime.arrays.ArrayData;
     import jdk.nashorn.internal.runtime.arrays.ArrayIndex;
     import jdk.nashorn.internal.lookup.Lookup;
    +import jdk.nashorn.internal.lookup.MethodHandleFactory;
     
     /**
      * ECMA 10.6 Arguments Object.
    @@ -624,7 +625,11 @@ public final class NativeArguments extends ScriptObject {
         }
     
         private static MethodHandle findOwnMH(final String name, final Class rtype, final Class... types) {
    -        return MH.findStatic(MethodHandles.publicLookup(), NativeArguments.class, name, MH.type(rtype, types));
    +        try {
    +            return MethodHandles.lookup().findStatic(NativeArguments.class, name, MH.type(rtype, types));
    +        } catch (final NoSuchMethodException | IllegalAccessException e) {
    +            throw new MethodHandleFactory.LookupException(e);
    +        }
         }
     
     }
    diff --git a/nashorn/src/jdk/nashorn/internal/objects/NativeError.java b/nashorn/src/jdk/nashorn/internal/objects/NativeError.java
    index b10a1c40990..c31217be301 100644
    --- a/nashorn/src/jdk/nashorn/internal/objects/NativeError.java
    +++ b/nashorn/src/jdk/nashorn/internal/objects/NativeError.java
    @@ -33,6 +33,7 @@ import java.lang.invoke.MethodHandles;
     import java.util.ArrayList;
     import java.util.List;
     import jdk.nashorn.internal.codegen.CompilerConstants;
    +import jdk.nashorn.internal.lookup.MethodHandleFactory;
     import jdk.nashorn.internal.objects.annotations.Attribute;
     import jdk.nashorn.internal.objects.annotations.Constructor;
     import jdk.nashorn.internal.objects.annotations.Function;
    @@ -328,6 +329,10 @@ public final class NativeError extends ScriptObject {
         }
     
         private static MethodHandle findOwnMH(final String name, final Class rtype, final Class... types) {
    -        return MH.findStatic(MethodHandles.publicLookup(), NativeError.class, name, MH.type(rtype, types));
    +        try {
    +            return MethodHandles.lookup().findStatic(NativeError.class, name, MH.type(rtype, types));
    +        } catch (final NoSuchMethodException | IllegalAccessException e) {
    +            throw new MethodHandleFactory.LookupException(e);
    +        }
         }
     }
    diff --git a/nashorn/src/jdk/nashorn/internal/objects/NativeStrictArguments.java b/nashorn/src/jdk/nashorn/internal/objects/NativeStrictArguments.java
    index a643c190c5c..2a5756f7e81 100644
    --- a/nashorn/src/jdk/nashorn/internal/objects/NativeStrictArguments.java
    +++ b/nashorn/src/jdk/nashorn/internal/objects/NativeStrictArguments.java
    @@ -37,6 +37,7 @@ import jdk.nashorn.internal.runtime.ScriptFunction;
     import jdk.nashorn.internal.runtime.ScriptObject;
     import jdk.nashorn.internal.runtime.arrays.ArrayData;
     import jdk.nashorn.internal.lookup.Lookup;
    +import jdk.nashorn.internal.lookup.MethodHandleFactory;
     
     /**
      * ECMA 10.6 Arguments Object.
    @@ -142,6 +143,10 @@ public final class NativeStrictArguments extends ScriptObject {
         }
     
         private static MethodHandle findOwnMH(final String name, final Class rtype, final Class... types) {
    -        return MH.findStatic(MethodHandles.publicLookup(), NativeStrictArguments.class, name, MH.type(rtype, types));
    +        try {
    +            return MethodHandles.lookup().findStatic(NativeStrictArguments.class, name, MH.type(rtype, types));
    +        } catch (final NoSuchMethodException | IllegalAccessException e) {
    +            throw new MethodHandleFactory.LookupException(e);
    +        }
         }
     }
    diff --git a/nashorn/src/jdk/nashorn/internal/objects/PrototypeObject.java b/nashorn/src/jdk/nashorn/internal/objects/PrototypeObject.java
    index edcc3274064..d476a866dc9 100644
    --- a/nashorn/src/jdk/nashorn/internal/objects/PrototypeObject.java
    +++ b/nashorn/src/jdk/nashorn/internal/objects/PrototypeObject.java
    @@ -35,6 +35,7 @@ import jdk.nashorn.internal.runtime.PropertyMap;
     import jdk.nashorn.internal.runtime.ScriptFunction;
     import jdk.nashorn.internal.runtime.ScriptObject;
     import jdk.nashorn.internal.lookup.Lookup;
    +import jdk.nashorn.internal.lookup.MethodHandleFactory;
     
     /**
      * Instances of this class serve as "prototype" object for script functions.
    @@ -106,6 +107,10 @@ public class PrototypeObject extends ScriptObject {
         }
     
         private static MethodHandle findOwnMH(final String name, final Class rtype, final Class... types) {
    -        return MH.findStatic(MethodHandles.publicLookup(), PrototypeObject.class, name, MH.type(rtype, types));
    +        try {
    +            return MethodHandles.lookup().findStatic(PrototypeObject.class, name, MH.type(rtype, types));
    +        } catch (final NoSuchMethodException | IllegalAccessException e) {
    +            throw new MethodHandleFactory.LookupException(e);
    +        }
         }
     }
    
    From 10e6614da08638889774747c2c00a3539997c24f Mon Sep 17 00:00:00 2001
    From: Sergey Malenkov 
    Date: Fri, 21 Jun 2013 17:13:43 +0400
    Subject: [PATCH 056/127] 8016545: java.beans.XMLEncoder.writeObject output is
     wrong
    
    Reviewed-by: alexsch
    ---
     .../share/classes/java/beans/XMLEncoder.java  |   2 +-
     .../java/beans/XMLEncoder/Test8016545.java    | 106 ++++++++++++++++++
     2 files changed, 107 insertions(+), 1 deletion(-)
     create mode 100644 jdk/test/java/beans/XMLEncoder/Test8016545.java
    
    diff --git a/jdk/src/share/classes/java/beans/XMLEncoder.java b/jdk/src/share/classes/java/beans/XMLEncoder.java
    index 2ac3cdc30b2..b7cc21de312 100644
    --- a/jdk/src/share/classes/java/beans/XMLEncoder.java
    +++ b/jdk/src/share/classes/java/beans/XMLEncoder.java
    @@ -377,7 +377,7 @@ public class XMLEncoder extends Encoder implements AutoCloseable {
                 Object arg = args[i];
                 mark(arg, true);
             }
    -        mark(stm.getTarget(), false);
    +        mark(stm.getTarget(), stm instanceof Expression);
         }
     
     
    diff --git a/jdk/test/java/beans/XMLEncoder/Test8016545.java b/jdk/test/java/beans/XMLEncoder/Test8016545.java
    new file mode 100644
    index 00000000000..466d8eb01fa
    --- /dev/null
    +++ b/jdk/test/java/beans/XMLEncoder/Test8016545.java
    @@ -0,0 +1,106 @@
    +/*
    + * Copyright (c) 2013, 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
    + * @bug 8016545
    + * @summary Tests beans with predefined fields
    + * @author Sergey Malenkov
    + */
    +
    +public class Test8016545 extends AbstractTest {
    +    public static void main(String[] args) {
    +        new Test8016545().test(true);
    +    }
    +
    +    @Override
    +    protected Object getObject() {
    +        Bean bean = new Bean();
    +        bean.setUndefined(Boolean.FALSE);
    +        Info info = new Info();
    +        info.setEnabled(Boolean.TRUE);
    +        info.setID(1);
    +        bean.setInfo(info);
    +        return bean;
    +    }
    +
    +    @Override
    +    protected Object getAnotherObject() {
    +        Bean bean = new Bean();
    +        bean.setUndefined(Boolean.TRUE);
    +        bean.getInfo().setEnabled(Boolean.FALSE);
    +        bean.getInfo().setID(2);
    +        return bean;
    +    }
    +
    +    public static class Bean {
    +        private Info info = new Info(); // predefined
    +        private Boolean defined = Boolean.TRUE;
    +        private Boolean undefined;
    +
    +        public Info getInfo() {
    +            return this.info;
    +        }
    +
    +        public void setInfo(Info info) {
    +            this.info = info;
    +        }
    +
    +        public Boolean getDefined() {
    +            return this.defined;
    +        }
    +
    +        public void setDefined(Boolean defined) {
    +            this.defined = defined;
    +        }
    +
    +        public Boolean getUndefined() {
    +            return this.undefined;
    +        }
    +
    +        public void setUndefined(Boolean undefined) {
    +            this.undefined = undefined;
    +        }
    +    }
    +
    +    public static class Info {
    +        private Integer id;
    +        private Boolean enabled;
    +
    +        public Integer getID() {
    +            return this.id;
    +        }
    +
    +        public void setID(Integer id) {
    +            this.id = id;
    +        }
    +
    +        public Boolean getEnabled() {
    +            return this.enabled;
    +        }
    +
    +        public void setEnabled(Boolean enabled) {
    +            this.enabled = enabled;
    +        }
    +    }
    +}
    
    From 8b4ab0bb1e2b432408265d2908c7d93b44fd6b26 Mon Sep 17 00:00:00 2001
    From: Anton Litvinov 
    Date: Fri, 21 Jun 2013 21:30:12 +0400
    Subject: [PATCH 057/127] =?UTF-8?q?8007642:=20Media=20Names=20on=20Java=20?=
     =?UTF-8?q?Print=20Do=20Not=20Match=20the=20Printer=E2=80=99s=20and=20Conf?=
     =?UTF-8?q?use=20Users?=
    MIME-Version: 1.0
    Content-Type: text/plain; charset=UTF-8
    Content-Transfer-Encoding: 8bit
    
    Reviewed-by: prr, jgodinez
    ---
     .../classes/sun/print/Win32PrintService.java  | 145 +++++++++++-------
     1 file changed, 89 insertions(+), 56 deletions(-)
    
    diff --git a/jdk/src/windows/classes/sun/print/Win32PrintService.java b/jdk/src/windows/classes/sun/print/Win32PrintService.java
    index bef2213e664..19d76850bfe 100644
    --- a/jdk/src/windows/classes/sun/print/Win32PrintService.java
    +++ b/jdk/src/windows/classes/sun/print/Win32PrintService.java
    @@ -1,5 +1,5 @@
     /*
    - * Copyright (c) 2000, 2011, Oracle and/or its affiliates. All rights reserved.
    + * Copyright (c) 2000, 2013, 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
    @@ -28,11 +28,8 @@ package sun.print;
     import java.io.File;
     import java.net.URI;
     import java.net.URISyntaxException;
    -import java.net.URL;
    -
    -import java.util.Vector;
    +import java.util.ArrayList;
     import java.util.HashMap;
    -
     import javax.print.DocFlavor;
     import javax.print.DocPrintJob;
     import javax.print.PrintService;
    @@ -69,22 +66,14 @@ import javax.print.attribute.standard.Severity;
     import javax.print.attribute.standard.Sides;
     import javax.print.attribute.standard.ColorSupported;
     import javax.print.attribute.standard.PrintQuality;
    -import javax.print.attribute.ResolutionSyntax;
     import javax.print.attribute.standard.PrinterResolution;
     import javax.print.attribute.standard.SheetCollate;
     import javax.print.event.PrintServiceAttributeListener;
    -import java.util.ArrayList;
    -
    -import sun.print.SunPrinterJobService;
     
     public class Win32PrintService implements PrintService, AttributeUpdater,
                                               SunPrinterJobService {
     
    -    public static MediaSize[] predefMedia;
    -
    -    static {
    -        Class c = Win32MediaSize.class;
    -    }
    +    public static MediaSize[] predefMedia = Win32MediaSize.getPredefMedia();
     
         private static final DocFlavor[] supportedFlavors = {
             DocFlavor.BYTE_ARRAY.GIF,
    @@ -310,7 +299,9 @@ public class Win32PrintService implements PrintService, AttributeUpdater,
     
         public MediaSizeName findWin32Media(int dmIndex) {
             if (dmIndex >= 1 && dmIndex <= dmPaperToPrintService.length) {
    -           switch(dmIndex) {
    +            return dmPaperToPrintService[dmIndex - 1];
    +        }
    +        switch(dmIndex) {
                 /* matching media sizes with indices beyond
                    dmPaperToPrintService's length */
                 case DMPAPER_A2:
    @@ -320,11 +311,8 @@ public class Win32PrintService implements PrintService, AttributeUpdater,
                 case DMPAPER_B6_JIS:
                     return MediaSizeName.JIS_B6;
                 default:
    -                return dmPaperToPrintService[dmIndex - 1];
    -            }
    +                return null;
             }
    -
    -        return null;
         }
     
         private boolean addToUniqueList(ArrayList msnList, MediaSizeName mediaName) {
    @@ -350,6 +338,7 @@ public class Win32PrintService implements PrintService, AttributeUpdater,
             }
     
             ArrayList msnList = new ArrayList();
    +        ArrayList trailingWmsList = new ArrayList();
             ArrayList printableList = new ArrayList();
             MediaSizeName mediaName;
             boolean added;
    @@ -368,7 +357,8 @@ public class Win32PrintService implements PrintService, AttributeUpdater,
                 idList.add(Integer.valueOf(media[i]));
             }
     
    -        mediaSizes = getMediaSizes(idList, media);
    +        ArrayList dmPaperNameList = new ArrayList();
    +        mediaSizes = getMediaSizes(idList, media, dmPaperNameList);
             for (int i = 0; i < idList.size(); i++) {
     
                 // match Win ID with our predefined ID using table
    @@ -387,6 +377,7 @@ public class Win32PrintService implements PrintService, AttributeUpdater,
                        mediaName = null;
                     }
                 }
    +            boolean dmPaperIDMatched = (mediaName != null);
     
                 // No match found, then we get the MediaSizeName out of the MediaSize
                 // This requires 1-1 correspondence, lengths must be checked.
    @@ -395,9 +386,32 @@ public class Win32PrintService implements PrintService, AttributeUpdater,
                 }
     
                 // Add mediaName to the msnList
    +            added = false;
                 if (mediaName != null) {
                     added = addToUniqueList(msnList, mediaName);
                 }
    +            if ((!dmPaperIDMatched || !added) && (idList.size() == dmPaperNameList.size())) {
    +                /* The following block allows to add such media names to the list, whose sizes
    +                 * matched with media sizes predefined in JDK, while whose paper IDs did not,
    +                 * or whose sizes and paper IDs both did not match with any predefined in JDK.
    +                 */
    +                Win32MediaSize wms = Win32MediaSize.findMediaName(dmPaperNameList.get(i));
    +                if ((wms == null) && (idList.size() == mediaSizes.length)) {
    +                    wms = new Win32MediaSize(dmPaperNameList.get(i), (Integer)idList.get(i));
    +                    mediaSizes[i] = new MediaSize(mediaSizes[i].getX(MediaSize.MM),
    +                        mediaSizes[i].getY(MediaSize.MM), MediaSize.MM, wms);
    +                }
    +                if ((wms != null) && (wms != mediaName)) {
    +                    if (!added) {
    +                        added = addToUniqueList(msnList, mediaName = wms);
    +                    } else {
    +                        trailingWmsList.add(wms);
    +                    }
    +                }
    +            }
    +        }
    +        for (Win32MediaSize wms : trailingWmsList) {
    +            added = addToUniqueList(msnList, wms);
             }
     
             // init mediaSizeNames
    @@ -588,7 +602,11 @@ public class Win32PrintService implements PrintService, AttributeUpdater,
         }
     
     
    -    private MediaSize[] getMediaSizes(ArrayList idList, int[] media) {
    +    private MediaSize[] getMediaSizes(ArrayList idList, int[] media, ArrayList dmPaperNameList) {
    +        if (dmPaperNameList == null) {
    +            dmPaperNameList = new ArrayList();
    +        }
    +
             String prnPort = getPort();
             int[] mediaSz = getAllMediaSizes(printer, prnPort);
             String[] winMediaNames = getAllMediaNames(printer, prnPort);
    @@ -607,40 +625,43 @@ public class Win32PrintService implements PrintService, AttributeUpdater,
                 wid = mediaSz[i*2]/10f;
                 ht = mediaSz[i*2+1]/10f;
     
    -          // Make sure to validate wid & ht.
    -          // HP LJ 4050 (german) causes IAE in Sonderformat paper, wid & ht
    -          // returned is not constant.
    -          if ((wid <= 0) || (ht <= 0)) {
    -            //Remove corresponding ID from list
    -            if (nMedia == media.length) {
    -                Integer remObj = Integer.valueOf(media[i]);
    -              idList.remove(idList.indexOf(remObj));
    +            // Make sure to validate wid & ht.
    +            // HP LJ 4050 (german) causes IAE in Sonderformat paper, wid & ht
    +            // returned is not constant.
    +            if ((wid <= 0) || (ht <= 0)) {
    +                //Remove corresponding ID from list
    +                if (nMedia == media.length) {
    +                    Integer remObj = Integer.valueOf(media[i]);
    +                    idList.remove(idList.indexOf(remObj));
    +                }
    +                continue;
                 }
    -            continue;
    -          }
    -          // Find matching media using dimensions.
    -          // This call matches only with our own predefined sizes.
    -          msn = findMatchingMediaSizeNameMM(wid, ht);
    -          if (msn != null) {
    -            ms = MediaSize.getMediaSizeForName(msn);
    -          }
    -
    -          if (ms != null) {
    -            msList.add(ms);
    -          } else {
    -              Win32MediaSize wms =
    -                new Win32MediaSize(winMediaNames[i], media[i]);
    -            try {
    -              ms = new MediaSize(wid, ht, MediaSize.MM, wms);
    -              msList.add(ms);
    -            } catch(IllegalArgumentException e) {
    -              if (nMedia == media.length) {
    -                  Integer remObj = Integer.valueOf(media[i]);
    -                idList.remove(idList.indexOf(remObj));
    -              }
    +            // Find matching media using dimensions.
    +            // This call matches only with our own predefined sizes.
    +            msn = findMatchingMediaSizeNameMM(wid, ht);
    +            if (msn != null) {
    +                ms = MediaSize.getMediaSizeForName(msn);
                 }
    -          }
     
    +            if (ms != null) {
    +                msList.add(ms);
    +                dmPaperNameList.add(winMediaNames[i]);
    +            } else {
    +                Win32MediaSize wms = Win32MediaSize.findMediaName(winMediaNames[i]);
    +                if (wms == null) {
    +                    wms = new Win32MediaSize(winMediaNames[i], media[i]);
    +                }
    +                try {
    +                    ms = new MediaSize(wid, ht, MediaSize.MM, wms);
    +                    msList.add(ms);
    +                    dmPaperNameList.add(winMediaNames[i]);
    +                } catch(IllegalArgumentException e) {
    +                    if (nMedia == media.length) {
    +                        Integer remObj = Integer.valueOf(media[i]);
    +                        idList.remove(idList.indexOf(remObj));
    +                    }
    +                }
    +            }
             }
     
             MediaSize[] arr2 = new MediaSize[msList.size()];
    @@ -1614,6 +1635,7 @@ public class Win32PrintService implements PrintService, AttributeUpdater,
     class Win32MediaSize extends MediaSizeName {
         private static ArrayList winStringTable = new ArrayList();
         private static ArrayList winEnumTable = new ArrayList();
    +    private static MediaSize[] predefMedia;
     
         private int dmPaperID; // driver ID for this paper.
     
    @@ -1627,6 +1649,18 @@ class Win32MediaSize extends MediaSizeName {
           return (winStringTable.size()-1);
         }
     
    +    public static synchronized Win32MediaSize findMediaName(String name) {
    +        int nameIndex = winStringTable.indexOf(name);
    +        if (nameIndex != -1) {
    +            return (Win32MediaSize)winEnumTable.get(nameIndex);
    +        }
    +        return null;
    +    }
    +
    +    public static MediaSize[] getPredefMedia() {
    +        return predefMedia;
    +    }
    +
         public Win32MediaSize(String name, int dmPaper) {
             super(nextValue(name));
             dmPaperID = dmPaper;
    @@ -1638,18 +1672,17 @@ class Win32MediaSize extends MediaSizeName {
         }
     
         static {
    -         /* initialize Win32PrintService.predefMedia */
    +         /* initialize predefMedia */
             {
                 Win32MediaSize winMedia = new Win32MediaSize(-1);
     
                 // cannot call getSuperEnumTable directly because of static context
                 MediaSizeName[] enumMedia = winMedia.getSuperEnumTable();
                 if (enumMedia != null) {
    -                Win32PrintService.predefMedia = new MediaSize[enumMedia.length];
    +                predefMedia = new MediaSize[enumMedia.length];
     
                     for (int i=0; i
    Date: Fri, 21 Jun 2013 14:34:00 -0300
    Subject: [PATCH 058/127] 8010732: BigDecimal, BigInteger and Long handling in
     nashorn
    
    Reviewed-by: sundar
    ---
     nashorn/test/script/basic/JDK-8010732.js      | 48 +++++++++++++++++++
     .../test/script/basic/JDK-8010732.js.EXPECTED | 12 +++++
     2 files changed, 60 insertions(+)
     create mode 100644 nashorn/test/script/basic/JDK-8010732.js
     create mode 100644 nashorn/test/script/basic/JDK-8010732.js.EXPECTED
    
    diff --git a/nashorn/test/script/basic/JDK-8010732.js b/nashorn/test/script/basic/JDK-8010732.js
    new file mode 100644
    index 00000000000..166acb9e774
    --- /dev/null
    +++ b/nashorn/test/script/basic/JDK-8010732.js
    @@ -0,0 +1,48 @@
    +/*
    + * Copyright (c) 2010, 2013, 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.
    + */
    +
    +/**
    + * JDK-8010732: BigDecimal, BigInteger and Long handling in nashorn
    + *
    + * @test
    + * @run
    + */
    +
    +var x = new java.math.BigDecimal(1111.5);
    +var y = new java.math.BigDecimal(2222.5);
    +
    +print(x);
    +print(y);
    +
    +print(x + y);
    +print(x - y);
    +print(x * y);
    +print(x / y);
    +print(Math.sin(x));
    +
    +print(x.toString());
    +print(y.toString());
    +print(x.class);
    +print(y.class);
    +print(x.doubleValue() + y.doubleValue());
    +
    diff --git a/nashorn/test/script/basic/JDK-8010732.js.EXPECTED b/nashorn/test/script/basic/JDK-8010732.js.EXPECTED
    new file mode 100644
    index 00000000000..2e0b42fd073
    --- /dev/null
    +++ b/nashorn/test/script/basic/JDK-8010732.js.EXPECTED
    @@ -0,0 +1,12 @@
    +111.5
    +2222.5
    +3334
    +-1111
    +2470308.75
    +0.5001124859392576
    +-0.5841231854504038
    +1111.5
    +2222.5
    +class java.math.BigDecimal
    +class java.math.BigDecimal
    +3334
    
    From 2aad633d9b7602b7230b307d88032feec78031fd Mon Sep 17 00:00:00 2001
    From: James Laskey 
    Date: Sat, 22 Jun 2013 10:12:19 -0300
    Subject: [PATCH 059/127] 8017448: JDK-8010732.js.EXPECTED truncated
    
    Reviewed-by: sundar
    ---
     nashorn/test/script/basic/JDK-8010732.js.EXPECTED | 2 +-
     1 file changed, 1 insertion(+), 1 deletion(-)
    
    diff --git a/nashorn/test/script/basic/JDK-8010732.js.EXPECTED b/nashorn/test/script/basic/JDK-8010732.js.EXPECTED
    index 2e0b42fd073..5df1cb1d956 100644
    --- a/nashorn/test/script/basic/JDK-8010732.js.EXPECTED
    +++ b/nashorn/test/script/basic/JDK-8010732.js.EXPECTED
    @@ -1,4 +1,4 @@
    -111.5
    +1111.5
     2222.5
     3334
     -1111
    
    From 02e0b5c3f17ba897c3ed1b9bdad546447ff94f00 Mon Sep 17 00:00:00 2001
    From: Athijegannathan Sundararajan 
    Date: Mon, 24 Jun 2013 19:06:01 +0530
    Subject: [PATCH 060/127] 8015959: Can't call foreign constructor
    
    Reviewed-by: jlaskey, hannesw
    ---
     .../jdk/nashorn/api/scripting/JSObject.java   | 16 ++++-
     .../api/scripting/ScriptObjectMirror.java     | 34 ++++++++-
     .../internal/runtime/ScriptFunction.java      | 10 +++
     .../internal/runtime/ScriptFunctionData.java  | 70 +++++++++++++++++++
     .../internal/runtime/ScriptRuntime.java       | 41 +++++++++++
     .../runtime/linker/JSObjectLinker.java        | 68 ++++--------------
     nashorn/test/script/basic/JDK-8015959.js      | 54 ++++++++++++++
     .../test/script/basic/JDK-8015959.js.EXPECTED | 14 ++++
     8 files changed, 245 insertions(+), 62 deletions(-)
     create mode 100644 nashorn/test/script/basic/JDK-8015959.js
     create mode 100644 nashorn/test/script/basic/JDK-8015959.js.EXPECTED
    
    diff --git a/nashorn/src/jdk/nashorn/api/scripting/JSObject.java b/nashorn/src/jdk/nashorn/api/scripting/JSObject.java
    index 583e8f7a199..4f3a8e88f93 100644
    --- a/nashorn/src/jdk/nashorn/api/scripting/JSObject.java
    +++ b/nashorn/src/jdk/nashorn/api/scripting/JSObject.java
    @@ -30,13 +30,23 @@ package jdk.nashorn.api.scripting;
      */
     public abstract class JSObject {
         /**
    -     * Call a JavaScript method
    +     * Call a JavaScript function
          *
    -     * @param methodName name of method
    +     * @param functionName name of function
          * @param args arguments to method
          * @return result of call
          */
    -    public abstract Object call(String methodName, Object args[]);
    +    public abstract Object call(String functionName, Object... args);
    +
    +    /**
    +     * Call a JavaScript method as a constructor. This is equivalent to
    +     * calling new obj.Method(arg1, arg2...) in JavaScript.
    +     *
    +     * @param functionName name of function
    +     * @param args arguments to method
    +     * @return result of constructor call
    +     */
    +    public abstract Object newObject(String functionName, Object... args);
     
         /**
          * Evaluate a JavaScript expression
    diff --git a/nashorn/src/jdk/nashorn/api/scripting/ScriptObjectMirror.java b/nashorn/src/jdk/nashorn/api/scripting/ScriptObjectMirror.java
    index 79e908db5d2..c7dbab5a184 100644
    --- a/nashorn/src/jdk/nashorn/api/scripting/ScriptObjectMirror.java
    +++ b/nashorn/src/jdk/nashorn/api/scripting/ScriptObjectMirror.java
    @@ -102,7 +102,7 @@ public final class ScriptObjectMirror extends JSObject implements Bindings {
     
         // JSObject methods
         @Override
    -    public Object call(final String methodName, final Object args[]) {
    +    public Object call(final String functionName, final Object... args) {
             final ScriptObject oldGlobal = NashornScriptEngine.getNashornGlobal();
             final boolean globalChanged = (oldGlobal != global);
     
    @@ -111,9 +111,9 @@ public final class ScriptObjectMirror extends JSObject implements Bindings {
                     NashornScriptEngine.setNashornGlobal(global);
                 }
     
    -            final Object val = sobj.get(methodName);
    +            final Object val = functionName == null? sobj : sobj.get(functionName);
                 if (! (val instanceof ScriptFunction)) {
    -                throw new RuntimeException("No such method: " + methodName);
    +                throw new RuntimeException("No such function " + ((functionName != null)? functionName : ""));
                 }
     
                 final Object[] modArgs = globalChanged? wrapArray(args, oldGlobal) : args;
    @@ -129,6 +129,34 @@ public final class ScriptObjectMirror extends JSObject implements Bindings {
             }
         }
     
    +    @Override
    +    public Object newObject(final String functionName, final Object... args) {
    +        final ScriptObject oldGlobal = NashornScriptEngine.getNashornGlobal();
    +        final boolean globalChanged = (oldGlobal != global);
    +
    +        try {
    +            if (globalChanged) {
    +                NashornScriptEngine.setNashornGlobal(global);
    +            }
    +
    +            final Object val = functionName == null? sobj : sobj.get(functionName);
    +            if (! (val instanceof ScriptFunction)) {
    +                throw new RuntimeException("not a constructor " + ((functionName != null)? functionName : ""));
    +            }
    +
    +            final Object[] modArgs = globalChanged? wrapArray(args, oldGlobal) : args;
    +            return wrap(ScriptRuntime.checkAndConstruct((ScriptFunction)val, unwrapArray(modArgs, global)), global);
    +        } catch (final RuntimeException | Error e) {
    +            throw e;
    +        } catch (final Throwable t) {
    +            throw new RuntimeException(t);
    +        } finally {
    +            if (globalChanged) {
    +                NashornScriptEngine.setNashornGlobal(oldGlobal);
    +            }
    +        }
    +    }
    +
         @Override
         public Object eval(final String s) {
             return inGlobal(new Callable() {
    diff --git a/nashorn/src/jdk/nashorn/internal/runtime/ScriptFunction.java b/nashorn/src/jdk/nashorn/internal/runtime/ScriptFunction.java
    index 26e6270a4f2..5dca0e26978 100644
    --- a/nashorn/src/jdk/nashorn/internal/runtime/ScriptFunction.java
    +++ b/nashorn/src/jdk/nashorn/internal/runtime/ScriptFunction.java
    @@ -202,6 +202,16 @@ public abstract class ScriptFunction extends ScriptObject {
             return data.invoke(this, self, arguments);
         }
     
    +    /**
    +     * Execute this script function as a constructor.
    +     * @param arguments  Call arguments.
    +     * @return Newly constructed result.
    +     * @throws Throwable if there is an exception/error with the invocation or thrown from it
    +     */
    +    Object construct(final Object... arguments) throws Throwable {
    +        return data.construct(this, arguments);
    +    }
    +
         /**
          * Allocate function. Called from generated {@link ScriptObject} code
          * for allocation as a factory method
    diff --git a/nashorn/src/jdk/nashorn/internal/runtime/ScriptFunctionData.java b/nashorn/src/jdk/nashorn/internal/runtime/ScriptFunctionData.java
    index f98817c8ee6..673c0152ecf 100644
    --- a/nashorn/src/jdk/nashorn/internal/runtime/ScriptFunctionData.java
    +++ b/nashorn/src/jdk/nashorn/internal/runtime/ScriptFunctionData.java
    @@ -216,6 +216,12 @@ public abstract class ScriptFunctionData {
             return composeGenericMethod(code.mostGeneric().getInvoker());
         }
     
    +    final MethodHandle getGenericConstructor() {
    +        ensureCodeGenerated();
    +        ensureConstructor(code.mostGeneric());
    +        return composeGenericMethod(code.mostGeneric().getConstructor());
    +    }
    +
         private CompiledFunction getBest(final MethodType callSiteType) {
             ensureCodeGenerated();
             return code.best(callSiteType);
    @@ -535,10 +541,74 @@ public abstract class ScriptFunctionData {
             }
         }
     
    +    Object construct(final ScriptFunction fn, final Object... arguments) throws Throwable {
    +        final MethodHandle mh = getGenericConstructor();
    +
    +        final Object[]     args       = arguments == null ? ScriptRuntime.EMPTY_ARRAY : arguments;
    +
    +        if (isVarArg(mh)) {
    +            if (needsCallee(mh)) {
    +                return mh.invokeExact(fn, args);
    +            }
    +            return mh.invokeExact(args);
    +        }
    +
    +        final int paramCount = mh.type().parameterCount();
    +        if (needsCallee(mh)) {
    +            switch (paramCount) {
    +            case 1:
    +                return mh.invokeExact(fn);
    +            case 2:
    +                return mh.invokeExact(fn, getArg(args, 0));
    +            case 3:
    +                return mh.invokeExact(fn, getArg(args, 0), getArg(args, 1));
    +            case 4:
    +                return mh.invokeExact(fn, getArg(args, 0), getArg(args, 1), getArg(args, 2));
    +            default:
    +                return mh.invokeWithArguments(withArguments(fn, paramCount, args));
    +            }
    +        }
    +
    +        switch (paramCount) {
    +        case 0:
    +            return mh.invokeExact();
    +        case 1:
    +            return mh.invokeExact(getArg(args, 0));
    +        case 2:
    +            return mh.invokeExact(getArg(args, 0), getArg(args, 1));
    +        case 3:
    +            return mh.invokeExact(getArg(args, 0), getArg(args, 1), getArg(args, 2));
    +        default:
    +            return mh.invokeWithArguments(withArguments(null, paramCount, args));
    +        }
    +    }
    +
         private static Object getArg(final Object[] args, final int i) {
             return i < args.length ? args[i] : UNDEFINED;
         }
     
    +    private static Object[] withArguments(final ScriptFunction fn, final int argCount, final Object[] args) {
    +        final Object[] finalArgs = new Object[argCount];
    +
    +        int nextArg = 0;
    +        if (fn != null) {
    +            //needs callee
    +            finalArgs[nextArg++] = fn;
    +        }
    +
    +        // Don't add more args that there is argCount in the handle (including self and callee).
    +        for (int i = 0; i < args.length && nextArg < argCount;) {
    +            finalArgs[nextArg++] = args[i++];
    +        }
    +
    +        // If we have fewer args than argCount, pad with undefined.
    +        while (nextArg < argCount) {
    +            finalArgs[nextArg++] = UNDEFINED;
    +        }
    +
    +        return finalArgs;
    +    }
    +
         private static Object[] withArguments(final ScriptFunction fn, final Object self, final int argCount, final Object[] args) {
             final Object[] finalArgs = new Object[argCount];
     
    diff --git a/nashorn/src/jdk/nashorn/internal/runtime/ScriptRuntime.java b/nashorn/src/jdk/nashorn/internal/runtime/ScriptRuntime.java
    index f1febc0ca17..854b3229894 100644
    --- a/nashorn/src/jdk/nashorn/internal/runtime/ScriptRuntime.java
    +++ b/nashorn/src/jdk/nashorn/internal/runtime/ScriptRuntime.java
    @@ -360,6 +360,47 @@ public final class ScriptRuntime {
             }
         }
     
    +    /**
    +     * Check that the target function is associated with current Context.
    +     * And also make sure that 'self', if ScriptObject, is from current context.
    +     *
    +     * Call a function as a constructor given args.
    +     *
    +     * @param target ScriptFunction object.
    +     * @param args   Call arguments.
    +     * @return Constructor call result.
    +     */
    +    public static Object checkAndConstruct(final ScriptFunction target, final Object... args) {
    +        final ScriptObject global = Context.getGlobalTrusted();
    +        if (! (global instanceof GlobalObject)) {
    +            throw new IllegalStateException("No current global set");
    +        }
    +
    +        if (target.getContext() != global.getContext()) {
    +            throw new IllegalArgumentException("'target' function is not from current Context");
    +        }
    +
    +        // all in order - call real 'construct'
    +        return construct(target, args);
    +    }
    +
    +    /*
    +     * Call a script function as a constructor with given args.
    +     *
    +     * @param target ScriptFunction object.
    +     * @param args   Call arguments.
    +     * @return Constructor call result.
    +     */
    +    public static Object construct(final ScriptFunction target, final Object... args) {
    +        try {
    +            return target.construct(args);
    +        } catch (final RuntimeException | Error e) {
    +            throw e;
    +        } catch (final Throwable t) {
    +            throw new RuntimeException(t);
    +        }
    +    }
    +
         /**
          * Generic implementation of ECMA 9.12 - SameValue algorithm
          *
    diff --git a/nashorn/src/jdk/nashorn/internal/runtime/linker/JSObjectLinker.java b/nashorn/src/jdk/nashorn/internal/runtime/linker/JSObjectLinker.java
    index edd75e4dafd..1b7eb66b4e9 100644
    --- a/nashorn/src/jdk/nashorn/internal/runtime/linker/JSObjectLinker.java
    +++ b/nashorn/src/jdk/nashorn/internal/runtime/linker/JSObjectLinker.java
    @@ -45,44 +45,14 @@ import jdk.nashorn.api.scripting.JSObject;
      * as ScriptObjects from other Nashorn contexts.
      */
     final class JSObjectLinker implements TypeBasedGuardingDynamicLinker {
    -   /**
    -     * Instances of this class are used to represent a method member of a JSObject
    -     */
    -    private static final class JSObjectMethod {
    -        // The name of the JSObject method property
    -        private final String name;
    -
    -        JSObjectMethod(final String name) {
    -            this.name = name;
    -        }
    -
    -        String getName() {
    -            return name;
    -        }
    -
    -        static GuardedInvocation lookup(final CallSiteDescriptor desc) {
    -            final String operator = CallSiteDescriptorFactory.tokenizeOperators(desc).get(0);
    -            switch (operator) {
    -                case "call": {
    -                    // collect everything except the first two - JSObjectMethod instance and the actual 'self'
    -                    final int paramCount = desc.getMethodType().parameterCount();
    -                    final MethodHandle caller = MH.asCollector(JSOBJECTMETHOD_CALL, Object[].class, paramCount - 2);
    -                    return new GuardedInvocation(caller, null, IS_JSOBJECTMETHOD_GUARD);
    -                }
    -                default:
    -                    return null;
    -            }
    -        }
    -    }
    -
         @Override
         public boolean canLinkType(final Class type) {
             return canLinkTypeStatic(type);
         }
     
         static boolean canLinkTypeStatic(final Class type) {
    -        // can link JSObject and JSObjectMethod
    -        return JSObject.class.isAssignableFrom(type) || JSObjectMethod.class.isAssignableFrom(type);
    +        // can link JSObject
    +        return JSObject.class.isAssignableFrom(type);
         }
     
         @Override
    @@ -99,8 +69,6 @@ final class JSObjectLinker implements TypeBasedGuardingDynamicLinker {
             final GuardedInvocation inv;
             if (self instanceof JSObject) {
                 inv = lookup(desc);
    -        } else if (self instanceof JSObjectMethod) {
    -            inv = JSObjectMethod.lookup(desc);
             } else {
                 throw new AssertionError(); // Should never reach here.
             }
    @@ -115,7 +83,7 @@ final class JSObjectLinker implements TypeBasedGuardingDynamicLinker {
                 case "getProp":
                 case "getElem":
                 case "getMethod":
    -                return c > 2 ? findGetMethod(desc, operator) : findGetIndexMethod();
    +                return c > 2 ? findGetMethod(desc) : findGetIndexMethod();
                 case "setProp":
                 case "setElem":
                     return c > 2 ? findSetMethod(desc) : findSetIndexMethod();
    @@ -123,15 +91,14 @@ final class JSObjectLinker implements TypeBasedGuardingDynamicLinker {
                 case "callMethod":
                     return findCallMethod(desc, operator);
                 case "new":
    +                return findNewMethod(desc);
                 default:
                     return null;
             }
         }
     
    -    private static GuardedInvocation findGetMethod(final CallSiteDescriptor desc, final String operator) {
    -        // if "getMethod" then return JSObjectMethod object - which just holds the name of the method
    -        // subsequently, link on dyn:call for JSObjectMethod will actually call that method
    -        final MethodHandle getter = MH.insertArguments("getMethod".equals(operator)? JSOBJECT_GETMETHOD : JSOBJECT_GET, 1, desc.getNameToken(2));
    +    private static GuardedInvocation findGetMethod(final CallSiteDescriptor desc) {
    +        final MethodHandle getter = MH.insertArguments(JSOBJECT_GET, 1, desc.getNameToken(2));
             return new GuardedInvocation(getter, null, IS_JSOBJECT_GUARD);
         }
     
    @@ -156,9 +123,9 @@ final class JSObjectLinker implements TypeBasedGuardingDynamicLinker {
             return new GuardedInvocation(func, null, IS_JSOBJECT_GUARD);
         }
     
    -    @SuppressWarnings("unused")
    -    private static boolean isJSObjectMethod(final Object self) {
    -        return self instanceof JSObjectMethod;
    +    private static GuardedInvocation findNewMethod(final CallSiteDescriptor desc) {
    +        MethodHandle func = MH.asCollector(JSOBJECT_NEW, Object[].class, desc.getMethodType().parameterCount() - 1);
    +        return new GuardedInvocation(func, null, IS_JSOBJECT_GUARD);
         }
     
         @SuppressWarnings("unused")
    @@ -166,12 +133,6 @@ final class JSObjectLinker implements TypeBasedGuardingDynamicLinker {
             return self instanceof JSObject;
         }
     
    -
    -    @SuppressWarnings("unused")
    -    private static Object getMethod(final Object jsobj, final Object key) {
    -        return new JSObjectMethod(Objects.toString(key));
    -    }
    -
         @SuppressWarnings("unused")
         private static Object get(final Object jsobj, final Object key) {
             if (key instanceof String) {
    @@ -200,11 +161,8 @@ final class JSObjectLinker implements TypeBasedGuardingDynamicLinker {
         }
     
         @SuppressWarnings("unused")
    -    private static Object jsObjectMethodCall(final Object jsObjMethod, final Object jsobj, final Object... args) {
    -        // we have JSObjectMethod, JSObject and args. Get method name from JSObjectMethod instance
    -        final String methodName = ((JSObjectMethod)jsObjMethod).getName();
    -        // call the method on JSObject
    -        return ((JSObject)jsobj).call(methodName, args);
    +    private static Object newObject(final Object jsobj, final Object... args) {
    +        return ((JSObject)jsobj).newObject(null, args);
         }
     
         private static int getIndex(final Number n) {
    @@ -214,13 +172,11 @@ final class JSObjectLinker implements TypeBasedGuardingDynamicLinker {
     
         private static final MethodHandleFunctionality MH = MethodHandleFactory.getFunctionality();
     
    -    private static final MethodHandle IS_JSOBJECTMETHOD_GUARD = findOwnMH("isJSObjectMethod", boolean.class, Object.class);
         private static final MethodHandle IS_JSOBJECT_GUARD = findOwnMH("isJSObject", boolean.class, Object.class);
    -    private static final MethodHandle JSOBJECT_GETMETHOD = findOwnMH("getMethod", Object.class, Object.class, Object.class);
         private static final MethodHandle JSOBJECT_GET = findOwnMH("get", Object.class, Object.class, Object.class);
         private static final MethodHandle JSOBJECT_PUT = findOwnMH("put", Void.TYPE, Object.class, Object.class, Object.class);
         private static final MethodHandle JSOBJECT_CALL = findOwnMH("call", Object.class, Object.class, Object.class, Object[].class);
    -    private static final MethodHandle JSOBJECTMETHOD_CALL = findOwnMH("jsObjectMethodCall", Object.class, Object.class, Object.class, Object[].class);
    +    private static final MethodHandle JSOBJECT_NEW = findOwnMH("newObject", Object.class, Object.class, Object[].class);
     
         private static MethodHandle findOwnMH(final String name, final Class rtype, final Class... types) {
             final Class   own = JSObjectLinker.class;
    diff --git a/nashorn/test/script/basic/JDK-8015959.js b/nashorn/test/script/basic/JDK-8015959.js
    new file mode 100644
    index 00000000000..c5322e3e149
    --- /dev/null
    +++ b/nashorn/test/script/basic/JDK-8015959.js
    @@ -0,0 +1,54 @@
    +/*
    + * Copyright (c) 2010, 2013, 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.
    + */
    +
    +/**
    + * JDK-8015959: Can't call foreign constructor
    + *
    + * @test
    + * @run
    + */
    +
    +function check(global) {
    +    var obj = new global.Point(344, 12);
    +    print("obj.x " + obj.x);
    +    print("obj.y " + obj.y);
    +    print("obj instanceof global.Point? " + (obj instanceof global.Point))
    +
    +    var P = global.Point;
    +    var p = new P(343, 54);
    +    print("p.x " + p.x);
    +    print("p.y " + p.y);
    +    print("p instanceof P? " + (p instanceof P))
    +}
    +
    +print("check with loadWithNewGlobal");
    +check(loadWithNewGlobal({
    +   name: "myscript",
    +   script: "function Point(x, y) { this.x = x; this.y = y }; this"
    +}));
    +
    +print("check with script engine");
    +var m = new javax.script.ScriptEngineManager();
    +var e = m.getEngineByName('nashorn');
    +check(e.eval("function Point(x, y) { this.x = x; this.y = y }; this"));
    +
    diff --git a/nashorn/test/script/basic/JDK-8015959.js.EXPECTED b/nashorn/test/script/basic/JDK-8015959.js.EXPECTED
    new file mode 100644
    index 00000000000..e5a00a9540d
    --- /dev/null
    +++ b/nashorn/test/script/basic/JDK-8015959.js.EXPECTED
    @@ -0,0 +1,14 @@
    +check with loadWithNewGlobal
    +obj.x 344
    +obj.y 12
    +obj instanceof global.Point? true
    +p.x 343
    +p.y 54
    +p instanceof P? true
    +check with script engine
    +obj.x 344
    +obj.y 12
    +obj instanceof global.Point? true
    +p.x 343
    +p.y 54
    +p instanceof P? true
    
    From 249d0ae5b46154f66c51322f343a8426e2a892bd Mon Sep 17 00:00:00 2001
    From: Athijegannathan Sundararajan 
    Date: Tue, 25 Jun 2013 17:31:19 +0530
    Subject: [PATCH 061/127] 8015969: Needs to enforce and document that global
     "context" and "engine" can't be modified when running via jsr223
    
    Reviewed-by: hannesw, jlaskey
    ---
     .../docs/JavaScriptingProgrammersGuide.html   | 10 +++
     .../api/scripting/NashornScriptEngine.java    | 15 +++-
     .../internal/runtime/AccessorProperty.java    |  4 +-
     .../nashorn/internal/runtime/Property.java    |  4 +-
     .../runtime/UserAccessorProperty.java         |  4 +-
     nashorn/test/script/basic/JDK-8015969.js      | 75 +++++++++++++++++++
     6 files changed, 102 insertions(+), 10 deletions(-)
     create mode 100644 nashorn/test/script/basic/JDK-8015969.js
    
    diff --git a/nashorn/docs/JavaScriptingProgrammersGuide.html b/nashorn/docs/JavaScriptingProgrammersGuide.html
    index a9803f7fd81..18ae823d82e 100644
    --- a/nashorn/docs/JavaScriptingProgrammersGuide.html
    +++ b/nashorn/docs/JavaScriptingProgrammersGuide.html
    @@ -227,6 +227,16 @@ access the variable - for example, it can call public methods on
     it. Note that the syntax to access Java objects, methods and fields
     is dependent on the scripting language. JavaScript supports the
     most "natural" Java-like syntax.

    +

    +Nashorn script engine pre-defines two global variables named "context" +and "engine". The "context" variable is of type javax.script.ScriptContext +and refers to the current ScriptContext instance passed to script engine's +eval method. The "engine" variable is of type javax.script.ScriptEngine and +refers to the current nashorn script engine instance evaluating the script. +Both of these variables are non-writable, non-enumerable and non-configurable +- which implies script code can not write overwrite the value, for..loop iteration +on global object will not iterate these variables and these variables can not be +deleted by script.

    
     // ScriptVars.java
     
    diff --git a/nashorn/src/jdk/nashorn/api/scripting/NashornScriptEngine.java b/nashorn/src/jdk/nashorn/api/scripting/NashornScriptEngine.java
    index b05a4aee435..d38e63c88b8 100644
    --- a/nashorn/src/jdk/nashorn/api/scripting/NashornScriptEngine.java
    +++ b/nashorn/src/jdk/nashorn/api/scripting/NashornScriptEngine.java
    @@ -71,6 +71,9 @@ public final class NashornScriptEngine extends AbstractScriptEngine implements C
         private final ScriptEngineFactory factory;
         private final Context             nashornContext;
         private final ScriptObject        global;
    +    // initialized bit late to be made 'final'. Property object for "context"
    +    // property of global object
    +    private Property                  contextProperty;
     
         // default options passed to Nashorn Options object
         private static final String[] DEFAULT_OPTIONS = new String[] { "-scripting", "-doe" };
    @@ -281,13 +284,16 @@ public final class NashornScriptEngine extends AbstractScriptEngine implements C
     
             nashornContext.initGlobal(newGlobal);
     
    +        final int NON_ENUMERABLE_CONSTANT = Property.NOT_ENUMERABLE | Property.NOT_CONFIGURABLE | Property.NOT_WRITABLE;
             // current ScriptContext exposed as "context"
    -        newGlobal.addOwnProperty("context", Property.NOT_ENUMERABLE, UNDEFINED);
    +        // "context" is non-writable from script - but script engine still
    +        // needs to set it and so save the context Property object
    +        contextProperty = newGlobal.addOwnProperty("context", NON_ENUMERABLE_CONSTANT, UNDEFINED);
             // current ScriptEngine instance exposed as "engine". We added @SuppressWarnings("LeakingThisInConstructor") as
             // NetBeans identifies this assignment as such a leak - this is a false positive as we're setting this property
             // in the Global of a Context we just created - both the Context and the Global were just created and can not be
             // seen from another thread outside of this constructor.
    -        newGlobal.addOwnProperty("engine", Property.NOT_ENUMERABLE, this);
    +        newGlobal.addOwnProperty("engine", NON_ENUMERABLE_CONSTANT, this);
             // global script arguments with undefined value
             newGlobal.addOwnProperty("arguments", Property.NOT_ENUMERABLE, UNDEFINED);
             // file name default is null
    @@ -322,9 +328,10 @@ public final class NashornScriptEngine extends AbstractScriptEngine implements C
     
         // scripts should see "context" and "engine" as variables
         private void setContextVariables(final ScriptContext ctxt) {
    -        ctxt.setAttribute("context", ctxt, ScriptContext.ENGINE_SCOPE);
             final ScriptObject ctxtGlobal = getNashornGlobalFrom(ctxt);
    -        ctxtGlobal.set("context", ctxt, false);
    +        // set "context" global variable via contextProperty - because this
    +        // property is non-writable
    +        contextProperty.setObjectValue(ctxtGlobal, ctxtGlobal, ctxt, false);
             Object args = ScriptObjectMirror.unwrap(ctxt.getAttribute("arguments"), ctxtGlobal);
             if (args == null || args == UNDEFINED) {
                 args = ScriptRuntime.EMPTY_ARRAY;
    diff --git a/nashorn/src/jdk/nashorn/internal/runtime/AccessorProperty.java b/nashorn/src/jdk/nashorn/internal/runtime/AccessorProperty.java
    index 13e9e1ce3bd..bfdfa71995d 100644
    --- a/nashorn/src/jdk/nashorn/internal/runtime/AccessorProperty.java
    +++ b/nashorn/src/jdk/nashorn/internal/runtime/AccessorProperty.java
    @@ -288,7 +288,7 @@ public class AccessorProperty extends Property {
         }
     
         @Override
    -    protected void setObjectValue(final ScriptObject self, final ScriptObject owner, final Object value, final boolean strict)  {
    +    public void setObjectValue(final ScriptObject self, final ScriptObject owner, final Object value, final boolean strict)  {
             if (isSpill()) {
                 self.spill[getSlot()] = value;
             } else {
    @@ -303,7 +303,7 @@ public class AccessorProperty extends Property {
         }
     
         @Override
    -    protected Object getObjectValue(final ScriptObject self, final ScriptObject owner) {
    +    public Object getObjectValue(final ScriptObject self, final ScriptObject owner) {
             if (isSpill()) {
                 return self.spill[getSlot()];
             }
    diff --git a/nashorn/src/jdk/nashorn/internal/runtime/Property.java b/nashorn/src/jdk/nashorn/internal/runtime/Property.java
    index a5e46016a00..d516a78377b 100644
    --- a/nashorn/src/jdk/nashorn/internal/runtime/Property.java
    +++ b/nashorn/src/jdk/nashorn/internal/runtime/Property.java
    @@ -363,7 +363,7 @@ public abstract class Property {
          * @param value the new property value
          * @param strict is this a strict setter?
          */
    -    protected abstract void setObjectValue(ScriptObject self, ScriptObject owner, Object value, boolean strict);
    +    public abstract void setObjectValue(ScriptObject self, ScriptObject owner, Object value, boolean strict);
     
         /**
          * Set the Object value of this property from {@code owner}. This allows to bypass creation of the
    @@ -373,7 +373,7 @@ public abstract class Property {
          * @param owner the owner object
          * @return  the property value
          */
    -    protected abstract Object getObjectValue(ScriptObject self, ScriptObject owner);
    +    public abstract Object getObjectValue(ScriptObject self, ScriptObject owner);
     
         /**
          * Abstract method for retrieving the setter for the property. We do not know
    diff --git a/nashorn/src/jdk/nashorn/internal/runtime/UserAccessorProperty.java b/nashorn/src/jdk/nashorn/internal/runtime/UserAccessorProperty.java
    index 5159e6537b0..4371d7e8296 100644
    --- a/nashorn/src/jdk/nashorn/internal/runtime/UserAccessorProperty.java
    +++ b/nashorn/src/jdk/nashorn/internal/runtime/UserAccessorProperty.java
    @@ -158,12 +158,12 @@ public final class UserAccessorProperty extends Property {
         }
     
         @Override
    -    protected Object getObjectValue(final ScriptObject self, final ScriptObject owner) {
    +    public Object getObjectValue(final ScriptObject self, final ScriptObject owner) {
             return userAccessorGetter(owner, getGetterSlot(), self);
         }
     
         @Override
    -    protected void setObjectValue(final ScriptObject self, final ScriptObject owner, final Object value, final boolean strict) {
    +    public void setObjectValue(final ScriptObject self, final ScriptObject owner, final Object value, final boolean strict) {
             userAccessorSetter(owner, getSetterSlot(), strict ? getKey() : null, self, value);
         }
     
    diff --git a/nashorn/test/script/basic/JDK-8015969.js b/nashorn/test/script/basic/JDK-8015969.js
    new file mode 100644
    index 00000000000..a9813773dfa
    --- /dev/null
    +++ b/nashorn/test/script/basic/JDK-8015969.js
    @@ -0,0 +1,75 @@
    +/*
    + * Copyright (c) 2010, 2013, 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.
    + */
    +
    +/**
    + * JDK-8015969: Needs to enforce and document that global "context" and "engine" can't be modified when running via jsr223
    + *
    + * @test
    + * @option -scripting
    + * @run
    + */
    +
    +var m = new javax.script.ScriptEngineManager();
    +var e = m.getEngineByName("nashorn");
    +
    +e.eval(<
    Date: Wed, 26 Jun 2013 13:49:16 +0400
    Subject: [PATCH 062/127] 8016254: several sun/java2d/OpenGL tests failed with
     SIGFPE
    
    Reviewed-by: prr, bae
    ---
     jdk/src/share/native/sun/java2d/opengl/OGLContext.c | 7 +++++++
     1 file changed, 7 insertions(+)
    
    diff --git a/jdk/src/share/native/sun/java2d/opengl/OGLContext.c b/jdk/src/share/native/sun/java2d/opengl/OGLContext.c
    index b9c60046070..d1484f73e37 100644
    --- a/jdk/src/share/native/sun/java2d/opengl/OGLContext.c
    +++ b/jdk/src/share/native/sun/java2d/opengl/OGLContext.c
    @@ -662,6 +662,13 @@ OGLContext_IsFBObjectExtensionAvailable(JNIEnv *env,
             return JNI_FALSE;
         }
     
    +    // next see if the depth texture extension is available
    +    if (!OGLContext_IsExtensionAvailable(extString,
    +                                         "GL_ARB_depth_texture"))
    +    {
    +        return JNI_FALSE;
    +    }
    +
         // next see if the fbobject system property has been enabled
         isFBObjectEnabled =
             JNU_GetStaticFieldByName(env, NULL,
    
    From f4695eca85bd51546d6470da76b0146a4481644e Mon Sep 17 00:00:00 2001
    From: Athijegannathan Sundararajan 
    Date: Wed, 26 Jun 2013 16:36:13 +0530
    Subject: [PATCH 063/127] 8017950: error.stack should be a string rather than
     an array
    
    Reviewed-by: hannesw, jlaskey
    ---
     .../nashorn/internal/objects/NativeError.java | 80 ++++++++++++++-----
     .../internal/runtime/ECMAException.java       |  2 +-
     nashorn/test/script/basic/JDK-8012164.js      |  5 +-
     .../test/script/basic/JDK-8012164.js.EXPECTED |  2 +-
     nashorn/test/script/basic/JDK-8017950.js      | 47 +++++++++++
     .../test/script/basic/JDK-8017950.js.EXPECTED |  4 +
     nashorn/test/script/basic/NASHORN-109.js      |  5 +-
     nashorn/test/script/basic/NASHORN-296.js      |  4 +-
     nashorn/test/script/basic/errorstack.js       |  8 +-
     9 files changed, 126 insertions(+), 31 deletions(-)
     create mode 100644 nashorn/test/script/basic/JDK-8017950.js
     create mode 100644 nashorn/test/script/basic/JDK-8017950.js.EXPECTED
    
    diff --git a/nashorn/src/jdk/nashorn/internal/objects/NativeError.java b/nashorn/src/jdk/nashorn/internal/objects/NativeError.java
    index c31217be301..fa23597af90 100644
    --- a/nashorn/src/jdk/nashorn/internal/objects/NativeError.java
    +++ b/nashorn/src/jdk/nashorn/internal/objects/NativeError.java
    @@ -143,6 +143,30 @@ public final class NativeError extends ScriptObject {
             return ECMAException.printStackTrace((ScriptObject)self);
         }
     
    +    /**
    +     * Nashorn extension: Error.prototype.getStackTrace()
    +     * "stack" property is an array typed value containing {@link StackTraceElement}
    +     * objects of JavaScript stack frames.
    +     *
    +     * @param self  self reference
    +     *
    +     * @return      stack trace as a script array.
    +     */
    +    @Function(attributes = Attribute.NOT_ENUMERABLE)
    +    public static Object getStackTrace(final Object self) {
    +        Global.checkObject(self);
    +        final ScriptObject sobj = (ScriptObject)self;
    +        final Object exception = ECMAException.getException(sobj);
    +        Object[] res;
    +        if (exception instanceof Throwable) {
    +            res = getScriptFrames((Throwable)exception);
    +        } else {
    +            res = ScriptRuntime.EMPTY_ARRAY;
    +        }
    +
    +        return new NativeArray(res);
    +    }
    +
         /**
          * Nashorn extension: Error.prototype.lineNumber
          *
    @@ -229,8 +253,8 @@ public final class NativeError extends ScriptObject {
     
         /**
          * Nashorn extension: Error.prototype.stack
    -     * "stack" property is an array typed value containing {@link StackTraceElement}
    -     * objects of JavaScript stack frames.
    +     * "stack" property is a string typed value containing JavaScript stack frames.
    +     * Each frame information is separated bv "\n" character.
          *
          * @param self  self reference
          *
    @@ -244,27 +268,28 @@ public final class NativeError extends ScriptObject {
             }
     
             final Object exception = ECMAException.getException(sobj);
    -        Object[] res;
    +        final StringBuilder buf = new StringBuilder();
             if (exception instanceof Throwable) {
    -            final StackTraceElement[] frames = ((Throwable)exception).getStackTrace();
    -            final List filtered = new ArrayList<>();
    -            for (final StackTraceElement st : frames) {
    -                if (ECMAErrors.isScriptFrame(st)) {
    -                    final String className = "<" + st.getFileName() + ">";
    -                    String methodName = st.getMethodName();
    -                    if (methodName.equals(CompilerConstants.RUN_SCRIPT.symbolName())) {
    -                        methodName = "";
    -                    }
    -                    filtered.add(new StackTraceElement(className, methodName,
    -                            st.getFileName(), st.getLineNumber()));
    -                }
    +            final Object[] frames = getScriptFrames((Throwable)exception);
    +            for (final Object fr : frames) {
    +                final StackTraceElement st = (StackTraceElement)fr;
    +                buf.append(st.getMethodName());
    +                buf.append(" @ ");
    +                buf.append(st.getFileName());
    +                buf.append(':');
    +                buf.append(st.getLineNumber());
    +                buf.append('\n');
                 }
    -            res = filtered.toArray();
    +            final int len = buf.length();
    +            // remove trailing '\n'
    +            if (len > 0) {
    +                assert buf.charAt(len - 1) == '\n';
    +                buf.deleteCharAt(len - 1);
    +            }
    +            return buf.toString();
             } else {
    -            res = ScriptRuntime.EMPTY_ARRAY;
    +            return "";
             }
    -
    -        return new NativeArray(res);
         }
     
         /**
    @@ -335,4 +360,21 @@ public final class NativeError extends ScriptObject {
                 throw new MethodHandleFactory.LookupException(e);
             }
         }
    +
    +    private static Object[] getScriptFrames(final Throwable exception) {
    +        final StackTraceElement[] frames = ((Throwable)exception).getStackTrace();
    +        final List filtered = new ArrayList<>();
    +        for (final StackTraceElement st : frames) {
    +            if (ECMAErrors.isScriptFrame(st)) {
    +                final String className = "<" + st.getFileName() + ">";
    +                String methodName = st.getMethodName();
    +                if (methodName.equals(CompilerConstants.RUN_SCRIPT.symbolName())) {
    +                    methodName = "";
    +                }
    +                filtered.add(new StackTraceElement(className, methodName,
    +                        st.getFileName(), st.getLineNumber()));
    +            }
    +        }
    +        return filtered.toArray();
    +    }
     }
    diff --git a/nashorn/src/jdk/nashorn/internal/runtime/ECMAException.java b/nashorn/src/jdk/nashorn/internal/runtime/ECMAException.java
    index a32e721cc46..bb4e49a0c1b 100644
    --- a/nashorn/src/jdk/nashorn/internal/runtime/ECMAException.java
    +++ b/nashorn/src/jdk/nashorn/internal/runtime/ECMAException.java
    @@ -51,7 +51,7 @@ public final class ECMAException extends NashornException {
         /** Field handle to the{@link ECMAException#thrown} field, so that it can be accessed from generated code */
         public static final FieldAccess THROWN = virtualField(ECMAException.class, "thrown", Object.class);
     
    -    private static final String EXCEPTION_PROPERTY = "nashornException";
    +    public static final String EXCEPTION_PROPERTY = "nashornException";
     
         /** Object thrown. */
         public final Object thrown;
    diff --git a/nashorn/test/script/basic/JDK-8012164.js b/nashorn/test/script/basic/JDK-8012164.js
    index 6416cfadfdb..62bb09c4b23 100644
    --- a/nashorn/test/script/basic/JDK-8012164.js
    +++ b/nashorn/test/script/basic/JDK-8012164.js
    @@ -37,8 +37,9 @@ function error() {
       try {
           throw new Error('foo');
       } catch (e) {
    -      for (i in e.stack) {
    -          printFrame(e.stack[i]);
    +      var frames = e.getStackTrace();
    +      for (i in frames) {
    +          printFrame(frames[i]);
           }
       }
     }
    diff --git a/nashorn/test/script/basic/JDK-8012164.js.EXPECTED b/nashorn/test/script/basic/JDK-8012164.js.EXPECTED
    index e70edea3c8e..9912edcd509 100644
    --- a/nashorn/test/script/basic/JDK-8012164.js.EXPECTED
    +++ b/nashorn/test/script/basic/JDK-8012164.js.EXPECTED
    @@ -1,3 +1,3 @@
     .error(test/script/basic/JDK-8012164.js:38)
     .func(test/script/basic/JDK-8012164.js:33)
    -.(test/script/basic/JDK-8012164.js:46)
    +.(test/script/basic/JDK-8012164.js:47)
    diff --git a/nashorn/test/script/basic/JDK-8017950.js b/nashorn/test/script/basic/JDK-8017950.js
    new file mode 100644
    index 00000000000..c84eacc57f0
    --- /dev/null
    +++ b/nashorn/test/script/basic/JDK-8017950.js
    @@ -0,0 +1,47 @@
    +/*
    + * Copyright (c) 2010, 2013, 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.
    + */
    +
    +/**
    + * JDK-8017950: error.stack should be a string rather than an array
    + *
    + * @test
    + * @run
    + */
    +
    +function func() {
    +    try {
    +        throw new Error();
    +    } catch (e){
    +        print(e.stack.replace(/\\/g, '/'))
    +    }
    +}
    +
    +function f() { 
    +    func()
    +}
    +
    +function g() {
    +    f()
    +}
    +
    +g()
    diff --git a/nashorn/test/script/basic/JDK-8017950.js.EXPECTED b/nashorn/test/script/basic/JDK-8017950.js.EXPECTED
    new file mode 100644
    index 00000000000..e86d02ef604
    --- /dev/null
    +++ b/nashorn/test/script/basic/JDK-8017950.js.EXPECTED
    @@ -0,0 +1,4 @@
    +func @ test/script/basic/JDK-8017950.js:33
    +f @ test/script/basic/JDK-8017950.js:40
    +g @ test/script/basic/JDK-8017950.js:44
    + @ test/script/basic/JDK-8017950.js:47
    diff --git a/nashorn/test/script/basic/NASHORN-109.js b/nashorn/test/script/basic/NASHORN-109.js
    index b05e0f12e50..4667feb21de 100644
    --- a/nashorn/test/script/basic/NASHORN-109.js
    +++ b/nashorn/test/script/basic/NASHORN-109.js
    @@ -33,8 +33,9 @@ try {
             throw new Error("error");
         }
     } catch (e) {
    -    for (i in e.stack) { 
    -        print(e.stack[i].methodName + ' ' + e.stack[i].lineNumber);
    +    var frames = e.getStackTrace();
    +    for (i in frames) {
    +        print(frames[i].methodName + ' ' + frames[i].lineNumber);
         }
     }
     
    diff --git a/nashorn/test/script/basic/NASHORN-296.js b/nashorn/test/script/basic/NASHORN-296.js
    index cbb752fbcaa..26338e60f56 100644
    --- a/nashorn/test/script/basic/NASHORN-296.js
    +++ b/nashorn/test/script/basic/NASHORN-296.js
    @@ -33,7 +33,7 @@ function test(name) {
             load({ script: 'throw new Error()', name: name });
         } catch(e) {
             // normalize windows path separator to URL style
    -        var actual = e.stack[0].fileName;
    +        var actual = e.getStackTrace()[0].fileName;
             if (actual !== name) {
                 fail("expected file name to be " + name +
                      ", actually got file name " + actual);
    @@ -48,6 +48,6 @@ test("com/oracle/node/sample.js");
     try {
         throw new Error();
     } catch (e) {
    -    test(e.stack[0].fileName.substring(6));
    +    test(e.getStackTrace()[0].fileName.substring(6));
     }
     
    diff --git a/nashorn/test/script/basic/errorstack.js b/nashorn/test/script/basic/errorstack.js
    index 7db53142c10..8fcd25a2e1b 100644
    --- a/nashorn/test/script/basic/errorstack.js
    +++ b/nashorn/test/script/basic/errorstack.js
    @@ -22,7 +22,7 @@
      */
     
     /**
    - * "stack" property of Error objects. (nashorn extension).
    + * "getStackTrace()" method of Error objects. (nashorn extension).
      *
      * @test
      * @run
    @@ -43,9 +43,9 @@ function func3() {
     try {
         func1();
     } catch (e) {
    -    // "stack" is java.lang.StackTraceElement object
    -    for (i in e.stack) {
    -        print(e.stack[i].methodName + " : " + e.stack[i].lineNumber);
    +    var frames = e.getStackTrace();
    +    for (i in frames) {
    +        print(frames[i].methodName + " : " + frames[i].lineNumber);
         }
     }
     
    
    From e628bb4979f37972407aa441f93cbf4ed3e44f4d Mon Sep 17 00:00:00 2001
    From: James Laskey 
    Date: Wed, 26 Jun 2013 08:36:53 -0300
    Subject: [PATCH 064/127] 8008458: Strict functions dont share property map
    
    Reviewed-by: sundar, hannesw
    ---
     .../objects/NativeStrictArguments.java        |  6 +-
     .../internal/objects/ScriptFunctionImpl.java  | 23 +++--
     .../internal/runtime/FindProperty.java        |  6 +-
     .../nashorn/internal/runtime/Property.java    |  6 +-
     .../nashorn/internal/runtime/PropertyMap.java | 17 +++-
     .../internal/runtime/ScriptObject.java        | 91 ++++++-------------
     .../internal/runtime/SetMethodCreator.java    |  5 +-
     .../runtime/UserAccessorProperty.java         | 28 ++----
     8 files changed, 85 insertions(+), 97 deletions(-)
    
    diff --git a/nashorn/src/jdk/nashorn/internal/objects/NativeStrictArguments.java b/nashorn/src/jdk/nashorn/internal/objects/NativeStrictArguments.java
    index 2a5756f7e81..7f75b4eed20 100644
    --- a/nashorn/src/jdk/nashorn/internal/objects/NativeStrictArguments.java
    +++ b/nashorn/src/jdk/nashorn/internal/objects/NativeStrictArguments.java
    @@ -57,8 +57,10 @@ public final class NativeStrictArguments extends ScriptObject {
             PropertyMap map = PropertyMap.newMap(NativeStrictArguments.class);
             map = Lookup.newProperty(map, "length", Property.NOT_ENUMERABLE, G$LENGTH, S$LENGTH);
             // In strict mode, the caller and callee properties should throw TypeError
    -        map = ScriptFunctionImpl.newThrowerProperty(map, "caller");
    -        map = ScriptFunctionImpl.newThrowerProperty(map, "callee");
    +        // Need to add properties directly to map since slots are assigned speculatively by newUserAccessors.
    +        final int flags = Property.NOT_ENUMERABLE | Property.NOT_CONFIGURABLE;
    +        map = map.addProperty(map.newUserAccessors("caller", flags));
    +        map = map.addProperty(map.newUserAccessors("callee", flags));
             nasgenmap$ = map;
         }
     
    diff --git a/nashorn/src/jdk/nashorn/internal/objects/ScriptFunctionImpl.java b/nashorn/src/jdk/nashorn/internal/objects/ScriptFunctionImpl.java
    index 23a13f25931..9289320e1cf 100644
    --- a/nashorn/src/jdk/nashorn/internal/objects/ScriptFunctionImpl.java
    +++ b/nashorn/src/jdk/nashorn/internal/objects/ScriptFunctionImpl.java
    @@ -155,8 +155,12 @@ public class ScriptFunctionImpl extends ScriptFunction {
                     Lookup.TYPE_ERROR_THROWER_GETTER, Lookup.TYPE_ERROR_THROWER_SETTER);
         }
     
    -    private static PropertyMap createStrictModeMap(final PropertyMap functionMap) {
    -        return newThrowerProperty(newThrowerProperty(functionMap, "arguments"), "caller");
    +    private static PropertyMap createStrictModeMap(PropertyMap map) {
    +        final int flags = Property.NOT_ENUMERABLE | Property.NOT_CONFIGURABLE;
    +        // Need to add properties directly to map since slots are assigned speculatively by newUserAccessors.
    +        map = map.addProperty(map.newUserAccessors("arguments", flags));
    +        map = map.addProperty(map.newUserAccessors("caller", flags));
    +        return map;
         }
     
         // Choose the map based on strict mode!
    @@ -260,12 +264,15 @@ public class ScriptFunctionImpl extends ScriptFunction {
             this.setProto(Global.instance().getFunctionPrototype());
             this.prototype = LAZY_PROTOTYPE;
     
    -        if (isStrict()) {
    -            final ScriptFunction func = getTypeErrorThrower();
    -            // We have to fill user accessor functions late as these are stored
    -            // in this object rather than in the PropertyMap of this object.
    -            setUserAccessors("arguments", func, func);
    -            setUserAccessors("caller", func, func);
    +        // We have to fill user accessor functions late as these are stored
    +        // in this object rather than in the PropertyMap of this object.
    +
    +        if (findProperty("arguments", true) != null) {
    +            setUserAccessors("arguments", getTypeErrorThrower(), getTypeErrorThrower());
    +        }
    +
    +        if (findProperty("caller", true) != null) {
    +            setUserAccessors("caller", getTypeErrorThrower(), getTypeErrorThrower());
             }
         }
     }
    diff --git a/nashorn/src/jdk/nashorn/internal/runtime/FindProperty.java b/nashorn/src/jdk/nashorn/internal/runtime/FindProperty.java
    index 16165fe9caa..c14accb7c4e 100644
    --- a/nashorn/src/jdk/nashorn/internal/runtime/FindProperty.java
    +++ b/nashorn/src/jdk/nashorn/internal/runtime/FindProperty.java
    @@ -89,7 +89,7 @@ public final class FindProperty {
             MethodHandle setter = property.getSetter(type, getOwner().getMap());
             if (property instanceof UserAccessorProperty) {
                 final UserAccessorProperty uc = (UserAccessorProperty) property;
    -            setter = MH.insertArguments(setter, 0, (isInherited() ? getOwner() : null),
    +            setter = MH.insertArguments(setter, 0, isInherited() ? getOwner() : null,
                         uc.getSetterSlot(), strict? property.getKey() : null);
             }
     
    @@ -109,7 +109,7 @@ public final class FindProperty {
          * @return appropriate receiver
          */
         public ScriptObject getGetterReceiver() {
    -        return property != null && property.hasGetterFunction() ? self : prototype;
    +        return property != null && property.hasGetterFunction(prototype) ? self : prototype;
         }
     
        /**
    @@ -117,7 +117,7 @@ public final class FindProperty {
          * @return appropriate receiver
          */
         public ScriptObject getSetterReceiver() {
    -        return property != null && property.hasSetterFunction() ? self : prototype;
    +        return property != null && property.hasSetterFunction(prototype) ? self : prototype;
         }
     
         /**
    diff --git a/nashorn/src/jdk/nashorn/internal/runtime/Property.java b/nashorn/src/jdk/nashorn/internal/runtime/Property.java
    index d516a78377b..e2cc6cdec21 100644
    --- a/nashorn/src/jdk/nashorn/internal/runtime/Property.java
    +++ b/nashorn/src/jdk/nashorn/internal/runtime/Property.java
    @@ -180,17 +180,19 @@ public abstract class Property {
     
         /**
          * Check whether this property has a user defined getter function. See {@link UserAccessorProperty}
    +     * @param obj object containing getter
          * @return true if getter function exists, false is default
          */
    -    public boolean hasGetterFunction() {
    +    public boolean hasGetterFunction(final ScriptObject obj) {
             return false;
         }
     
         /**
          * Check whether this property has a user defined setter function. See {@link UserAccessorProperty}
    +     * @param obj object containing setter
          * @return true if getter function exists, false is default
          */
    -    public boolean hasSetterFunction() {
    +    public boolean hasSetterFunction(final ScriptObject obj) {
             return false;
         }
     
    diff --git a/nashorn/src/jdk/nashorn/internal/runtime/PropertyMap.java b/nashorn/src/jdk/nashorn/internal/runtime/PropertyMap.java
    index b7248166696..3c552daa118 100644
    --- a/nashorn/src/jdk/nashorn/internal/runtime/PropertyMap.java
    +++ b/nashorn/src/jdk/nashorn/internal/runtime/PropertyMap.java
    @@ -302,7 +302,7 @@ public final class PropertyMap implements Iterable, PropertyListener {
          *
          * @return New {@link PropertyMap} with {@link Property} added.
          */
    -    PropertyMap addProperty(final Property property) {
    +    public PropertyMap addProperty(final Property property) {
             PropertyMap newMap = checkHistory(property);
     
             if (newMap == null) {
    @@ -383,6 +383,21 @@ public final class PropertyMap implements Iterable, PropertyListener {
             return newMap;
         }
     
    +    /*
    +     * Make a new UserAccessorProperty property. getter and setter functions are stored in
    +     * this ScriptObject and slot values are used in property object. Note that slots
    +     * are assigned speculatively and should be added to map before adding other
    +     * properties.
    +     */
    +    public UserAccessorProperty newUserAccessors(final String key, final int propertyFlags) {
    +        int oldSpillLength = spillLength;
    +
    +        final int getterSlot = oldSpillLength++;
    +        final int setterSlot = oldSpillLength++;
    +
    +        return new UserAccessorProperty(key, propertyFlags, getterSlot, setterSlot);
    +    }
    +
         /**
          * Find a property in the map.
          *
    diff --git a/nashorn/src/jdk/nashorn/internal/runtime/ScriptObject.java b/nashorn/src/jdk/nashorn/internal/runtime/ScriptObject.java
    index 0a2337f4d3c..3b11ab9d67f 100644
    --- a/nashorn/src/jdk/nashorn/internal/runtime/ScriptObject.java
    +++ b/nashorn/src/jdk/nashorn/internal/runtime/ScriptObject.java
    @@ -777,30 +777,18 @@ public abstract class ScriptObject extends PropertyListenerManager implements Pr
         public final Property modifyOwnProperty(final Property oldProperty, final int propertyFlags, final ScriptFunction getter, final ScriptFunction setter) {
             Property newProperty;
             if (oldProperty instanceof UserAccessorProperty) {
    -            // re-use the slots of the old user accessor property.
                 final UserAccessorProperty uc = (UserAccessorProperty) oldProperty;
    -
    -            int getterSlot = uc.getGetterSlot();
    -            // clear the old getter and set the new getter
    +            final int getterSlot = uc.getGetterSlot();
    +            final int setterSlot = uc.getSetterSlot();
                 setSpill(getterSlot, getter);
    -            // if getter function is null, flag the slot to be negative (less by 1)
    -            if (getter == null) {
    -                getterSlot = -getterSlot - 1;
    -            }
    -
    -            int setterSlot = uc.getSetterSlot();
    -            // clear the old setter and set the new setter
                 setSpill(setterSlot, setter);
    -            // if setter function is null, flag the slot to be negative (less by 1)
    -            if (setter == null) {
    -                setterSlot = -setterSlot - 1;
    +
    +            // if just flipping getter and setter with new functions, no need to change property or map
    +            if (uc.flags == propertyFlags) {
    +                return oldProperty;
                 }
     
                 newProperty = new UserAccessorProperty(oldProperty.getKey(), propertyFlags, getterSlot, setterSlot);
    -            // if just flipping getter and setter with new functions, no need to change property or map
    -            if (oldProperty.equals(newProperty)) {
    -                return oldProperty;
    -            }
             } else {
                 // erase old property value and create new user accessor property
                 erasePropertyValue(oldProperty);
    @@ -862,12 +850,12 @@ public abstract class ScriptObject extends PropertyListenerManager implements Pr
          */
         public final void setUserAccessors(final String key, final ScriptFunction getter, final ScriptFunction setter) {
             final Property oldProperty = getMap().findProperty(key);
    -        if (oldProperty != null) {
    -            final UserAccessorProperty newProperty = newUserAccessors(oldProperty.getKey(), oldProperty.getFlags(), getter, setter);
    -            modifyOwnProperty(oldProperty, newProperty);
    +        if (oldProperty instanceof UserAccessorProperty) {
    +            final UserAccessorProperty ua = (UserAccessorProperty)oldProperty;
    +            setSpill(ua.getGetterSlot(), getter);
    +            setSpill(ua.getSetterSlot(), setter);
             } else {
    -            final UserAccessorProperty newProperty = newUserAccessors(key, 0, getter, setter);
    -            addOwnProperty(newProperty);
    +            addOwnProperty(newUserAccessors(key, oldProperty != null ? oldProperty.getFlags() : 0, getter, setter));
             }
         }
     
    @@ -1712,7 +1700,7 @@ public abstract class ScriptObject extends PropertyListenerManager implements Pr
     
                 final ScriptObject prototype = find.getOwner();
     
    -            if (!property.hasGetterFunction()) {
    +            if (!property.hasGetterFunction(prototype)) {
                     methodHandle = bindTo(methodHandle, prototype);
                 }
                 return new GuardedInvocation(methodHandle, getMap().getProtoGetSwitchPoint(proto, name), guard);
    @@ -3144,49 +3132,30 @@ public abstract class ScriptObject extends PropertyListenerManager implements Pr
          * Make a new UserAccessorProperty property. getter and setter functions are stored in
          * this ScriptObject and slot values are used in property object.
          */
    -    private UserAccessorProperty newUserAccessors(final String key, final int propertyFlags, final ScriptFunction getter, final ScriptFunction setter) {
    -        int oldSpillLength = getMap().getSpillLength();
    +    protected final UserAccessorProperty newUserAccessors(final String key, final int propertyFlags, final ScriptFunction getter, final ScriptFunction setter) {
    +        final UserAccessorProperty property = getMap().newUserAccessors(key, propertyFlags);
    +        setSpill(property.getGetterSlot(), getter);
    +        setSpill(property.getSetterSlot(), setter);
     
    -        int getterSlot = oldSpillLength++;
    -        setSpill(getterSlot, getter);
    -        // if getter function is null, flag the slot to be negative (less by 1)
    -        if (getter == null) {
    -            getterSlot = -getterSlot - 1;
    -        }
    -
    -        int setterSlot = oldSpillLength++;
    -
    -        setSpill(setterSlot, setter);
    -        // if setter function is null, flag the slot to be negative (less by 1)
    -        if (setter == null) {
    -            setterSlot = -setterSlot - 1;
    -        }
    -
    -        return new UserAccessorProperty(key, propertyFlags, getterSlot, setterSlot);
    +        return property;
         }
     
    -    private void setSpill(final int slot, final Object value) {
    -        if (slot >= 0) {
    -            final int index = slot;
    -            if (spill == null) {
    -                // create new spill.
    -                spill = new Object[Math.max(index + 1, SPILL_RATE)];
    -            } else if (index >= spill.length) {
    -                // grow spill as needed
    -                final Object[] newSpill = new Object[index + 1];
    -                System.arraycopy(spill, 0, newSpill, 0, spill.length);
    -                spill = newSpill;
    -            }
    -
    -            spill[index] = value;
    +    protected final void setSpill(final int slot, final Object value) {
    +        if (spill == null) {
    +            // create new spill.
    +            spill = new Object[Math.max(slot + 1, SPILL_RATE)];
    +        } else if (slot >= spill.length) {
    +            // grow spill as needed
    +            final Object[] newSpill = new Object[slot + 1];
    +            System.arraycopy(spill, 0, newSpill, 0, spill.length);
    +            spill = newSpill;
             }
    +
    +        spill[slot] = value;
         }
     
    -    // user accessors are either stored in spill array slots
    -    // get the accessor value using slot number. Note that slot is spill array index.
    -    Object getSpill(final int slot) {
    -        final int index = slot;
    -        return (index < 0 || (index >= spill.length)) ? null : spill[index];
    +    protected Object getSpill(final int slot) {
    +        return spill != null && slot < spill.length ? spill[slot] : null;
         }
     
         private static MethodHandle findOwnMH(final String name, final Class rtype, final Class... types) {
    diff --git a/nashorn/src/jdk/nashorn/internal/runtime/SetMethodCreator.java b/nashorn/src/jdk/nashorn/internal/runtime/SetMethodCreator.java
    index a6dfce0f5fd..777254d831c 100644
    --- a/nashorn/src/jdk/nashorn/internal/runtime/SetMethodCreator.java
    +++ b/nashorn/src/jdk/nashorn/internal/runtime/SetMethodCreator.java
    @@ -151,9 +151,10 @@ final class SetMethodCreator {
             assert methodHandle != null;
             assert property     != null;
     
    +        final ScriptObject prototype = find.getOwner();
             final MethodHandle boundHandle;
    -        if (!property.hasSetterFunction() && find.isInherited()) {
    -            boundHandle = ScriptObject.bindTo(methodHandle, find.getOwner());
    +        if (!property.hasSetterFunction(prototype) && find.isInherited()) {
    +            boundHandle = ScriptObject.bindTo(methodHandle, prototype);
             } else {
                 boundHandle = methodHandle;
             }
    diff --git a/nashorn/src/jdk/nashorn/internal/runtime/UserAccessorProperty.java b/nashorn/src/jdk/nashorn/internal/runtime/UserAccessorProperty.java
    index 4371d7e8296..1dc64311545 100644
    --- a/nashorn/src/jdk/nashorn/internal/runtime/UserAccessorProperty.java
    +++ b/nashorn/src/jdk/nashorn/internal/runtime/UserAccessorProperty.java
    @@ -96,19 +96,19 @@ public final class UserAccessorProperty extends Property {
         }
     
         /**
    -     * Return getter slot for this UserAccessorProperty. Slots start with first embed field.
    +     * Return getter spill slot for this UserAccessorProperty.
          * @return getter slot
          */
         public int getGetterSlot() {
    -        return getterSlot < 0 ? -getterSlot - 1 : getterSlot;
    +        return getterSlot;
         }
     
         /**
    -     * Return setter slot for this UserAccessorProperty. Slots start with first embed field.
    +     * Return setter spill slot for this UserAccessorProperty.
          * @return setter slot
          */
         public int getSetterSlot() {
    -        return setterSlot < 0 ? -setterSlot - 1 : setterSlot;
    +        return setterSlot;
         }
     
         @Override
    @@ -124,7 +124,7 @@ public final class UserAccessorProperty extends Property {
     
             final UserAccessorProperty uc = (UserAccessorProperty) other;
             return getterSlot == uc.getterSlot && setterSlot == uc.setterSlot;
    -     }
    +    }
     
         @Override
         public int hashCode() {
    @@ -136,25 +136,17 @@ public final class UserAccessorProperty extends Property {
          */
         @Override
         public int getSpillCount() {
    -        // calculate how many spill array slots used by this propery.
    -        int count = 0;
    -        if (getGetterSlot() >= 0) {
    -            count++;
    -        }
    -        if (getSetterSlot() >= 0) {
    -            count++;
    -        }
    -        return count;
    +        return 2;
         }
     
         @Override
    -    public boolean hasGetterFunction() {
    -        return getterSlot > -1;
    +    public boolean hasGetterFunction(final ScriptObject obj) {
    +        return obj.getSpill(getterSlot) != null;
         }
     
         @Override
    -    public boolean hasSetterFunction() {
    -        return setterSlot > -1;
    +    public boolean hasSetterFunction(final ScriptObject obj) {
    +        return obj.getSpill(setterSlot) != null;
         }
     
         @Override
    
    From 70383eb20a782422fba17f6283cd19bd2ae69263 Mon Sep 17 00:00:00 2001
    From: =?UTF-8?q?Hannes=20Walln=C3=B6fer?= 
    Date: Wed, 26 Jun 2013 15:40:52 +0200
    Subject: [PATCH 065/127] 8019157: Avoid calling ScriptObject.setProto() if
     possible
    
    Reviewed-by: jlaskey, sundar
    ---
     .../internal/tools/nasgen/ClassGenerator.java | 12 +++----
     .../tools/nasgen/ScriptClassInstrumentor.java | 14 +++++---
     .../internal/codegen/ClassEmitter.java        |  3 +-
     .../internal/codegen/CodeGenerator.java       |  2 +-
     .../nashorn/internal/codegen/Compiler.java    |  4 +--
     .../codegen/ObjectClassGenerator.java         |  4 +--
     .../objects/AccessorPropertyDescriptor.java   |  6 +++-
     .../internal/objects/ArrayBufferView.java     |  4 +++
     .../objects/DataPropertyDescriptor.java       |  6 +++-
     .../objects/GenericPropertyDescriptor.java    |  6 +++-
     .../jdk/nashorn/internal/objects/Global.java  | 33 +++++++++++++------
     .../internal/objects/NativeArguments.java     | 14 ++++----
     .../nashorn/internal/objects/NativeArray.java |  7 ++--
     .../internal/objects/NativeArrayBuffer.java   |  6 +++-
     .../internal/objects/NativeBoolean.java       |  6 +++-
     .../nashorn/internal/objects/NativeDate.java  |  6 +++-
     .../nashorn/internal/objects/NativeDebug.java |  8 +++--
     .../nashorn/internal/objects/NativeError.java |  6 +++-
     .../internal/objects/NativeEvalError.java     |  8 +++--
     .../internal/objects/NativeFloat32Array.java  |  4 +++
     .../internal/objects/NativeFloat64Array.java  |  4 +++
     .../internal/objects/NativeFunction.java      |  5 +++
     .../internal/objects/NativeInt16Array.java    |  5 +++
     .../internal/objects/NativeInt32Array.java    |  4 +++
     .../internal/objects/NativeInt8Array.java     |  4 +++
     .../internal/objects/NativeJSAdapter.java     |  6 +++-
     .../nashorn/internal/objects/NativeJSON.java  |  5 ++-
     .../nashorn/internal/objects/NativeJava.java  |  4 +++
     .../internal/objects/NativeJavaImporter.java  |  6 +++-
     .../nashorn/internal/objects/NativeMath.java  |  6 +++-
     .../internal/objects/NativeNumber.java        |  6 +++-
     .../internal/objects/NativeObject.java        |  4 +++
     .../internal/objects/NativeRangeError.java    |  6 +++-
     .../objects/NativeReferenceError.java         |  6 +++-
     .../internal/objects/NativeRegExp.java        |  4 +++
     .../objects/NativeRegExpExecResult.java       |  6 +++-
     .../objects/NativeStrictArguments.java        | 10 +++---
     .../internal/objects/NativeString.java        |  6 +++-
     .../internal/objects/NativeSyntaxError.java   |  6 +++-
     .../internal/objects/NativeTypeError.java     |  6 +++-
     .../internal/objects/NativeURIError.java      |  6 +++-
     .../internal/objects/NativeUint16Array.java   |  4 +++
     .../internal/objects/NativeUint32Array.java   |  4 +++
     .../internal/objects/NativeUint8Array.java    |  4 +++
     .../objects/NativeUint8ClampedArray.java      |  4 +++
     .../internal/objects/PrototypeObject.java     | 10 +++---
     .../internal/objects/ScriptFunctionImpl.java  | 12 +++----
     .../jdk/nashorn/internal/runtime/Context.java |  8 +----
     .../internal/runtime/FunctionScope.java       |  6 ++--
     .../nashorn/internal/runtime/PropertyMap.java |  4 ++-
     .../internal/runtime/ScriptObject.java        | 25 +++++++++++---
     .../src/jdk/nashorn/internal/scripts/JO.java  | 14 +++++++-
     52 files changed, 275 insertions(+), 94 deletions(-)
    
    diff --git a/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/ClassGenerator.java b/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/ClassGenerator.java
    index 808f2658046..bc6bb4b2db2 100644
    --- a/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/ClassGenerator.java
    +++ b/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/ClassGenerator.java
    @@ -166,11 +166,11 @@ public class ClassGenerator {
             mi.putStatic(className, MAP_FIELD_NAME, MAP_DESC);
             mi.loadClass(className);
             mi.invokeStatic(MAP_TYPE, MAP_NEWMAP, MAP_NEWMAP_DESC);
    -        mi.storeLocal(0);
    +        // stack: PropertyMap
         }
     
         static void emitStaticInitSuffix(final MethodGenerator mi, final String className) {
    -        mi.loadLocal(0);
    +        // stack: PropertyMap
             mi.putStatic(className, MAP_FIELD_NAME, MAP_DESC);
             mi.returnVoid();
             mi.computeMaxs();
    @@ -278,7 +278,7 @@ public class ClassGenerator {
     
         static void linkerAddGetterSetter(final MethodGenerator mi, final String className, final MemberInfo memInfo) {
             final String propertyName = memInfo.getName();
    -        mi.loadLocal(0);
    +        // stack: PropertyMap
             mi.loadLiteral(propertyName);
             // setup flags
             mi.push(memInfo.getAttributes());
    @@ -293,12 +293,12 @@ public class ClassGenerator {
                 mi.visitLdcInsn(new Handle(H_INVOKEVIRTUAL, className, javaName, setterDesc(memInfo)));
             }
             mi.invokeStatic(LOOKUP_TYPE, LOOKUP_NEWPROPERTY, LOOKUP_NEWPROPERTY_DESC);
    -        mi.storeLocal(0);
    +        // stack: PropertyMap
         }
     
         static void linkerAddGetterSetter(final MethodGenerator mi, final String className, final MemberInfo getter, final MemberInfo setter) {
             final String propertyName = getter.getName();
    -        mi.loadLocal(0);
    +        // stack: PropertyMap
             mi.loadLiteral(propertyName);
             // setup flags
             mi.push(getter.getAttributes());
    @@ -313,7 +313,7 @@ public class ClassGenerator {
                         setter.getJavaName(), setter.getJavaDesc()));
             }
             mi.invokeStatic(LOOKUP_TYPE, LOOKUP_NEWPROPERTY, LOOKUP_NEWPROPERTY_DESC);
    -        mi.storeLocal(0);
    +        // stack: PropertyMap
         }
     
         static ScriptClassInfo getScriptClassInfo(final String fileName) throws IOException {
    diff --git a/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/ScriptClassInstrumentor.java b/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/ScriptClassInstrumentor.java
    index d140585f499..ffeb90bea3e 100644
    --- a/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/ScriptClassInstrumentor.java
    +++ b/nashorn/buildtools/nasgen/src/jdk/nashorn/internal/tools/nasgen/ScriptClassInstrumentor.java
    @@ -159,10 +159,14 @@ public class ScriptClassInstrumentor extends ClassVisitor {
                 public void visitMethodInsn(final int opcode, final String owner, final String name, final String desc) {
                     if (isConstructor && opcode == INVOKESPECIAL &&
                             INIT.equals(name) && SCRIPTOBJECT_TYPE.equals(owner)) {
    -                    super.visitFieldInsn(GETSTATIC, scriptClassInfo.getJavaName(),
    -                            MAP_FIELD_NAME, MAP_DESC);
    -                    super.visitMethodInsn(INVOKESPECIAL, SCRIPTOBJECT_TYPE, INIT,
    -                            SCRIPTOBJECT_INIT_DESC);
    +
    +                    // replace call to empty super-constructor with one passing PropertyMap argument
    +                    if (DEFAULT_INIT_DESC.equals(desc)) {
    +                        super.visitFieldInsn(GETSTATIC, scriptClassInfo.getJavaName(), MAP_FIELD_NAME, MAP_DESC);
    +                        super.visitMethodInsn(INVOKESPECIAL, SCRIPTOBJECT_TYPE, INIT, SCRIPTOBJECT_INIT_DESC);
    +                    } else {
    +                        super.visitMethodInsn(opcode, owner, name, desc);
    +                    }
     
                         if (memberCount > 0) {
                             // initialize @Property fields if needed
    @@ -223,7 +227,7 @@ public class ScriptClassInstrumentor extends ClassVisitor {
                     ClassGenerator.addSetter(cv, className, memInfo);
                 }
             }
    -        ClassGenerator.addMapField(this);
    +        // omit addMapField() since instance classes already define a static PropertyMap field
         }
     
         void emitGettersSetters() {
    diff --git a/nashorn/src/jdk/nashorn/internal/codegen/ClassEmitter.java b/nashorn/src/jdk/nashorn/internal/codegen/ClassEmitter.java
    index 2d379183fd5..09c6a0651cb 100644
    --- a/nashorn/src/jdk/nashorn/internal/codegen/ClassEmitter.java
    +++ b/nashorn/src/jdk/nashorn/internal/codegen/ClassEmitter.java
    @@ -165,7 +165,8 @@ public class ClassEmitter implements Emitter {
         /**
          * Constructor from the compiler
          *
    -     * @param compiler      Compiler
    +     * @param env           Script environment
    +     * @param sourceName    Source name
          * @param unitClassName Compile unit class name.
          * @param strictMode    Should we generate this method in strict mode
          */
    diff --git a/nashorn/src/jdk/nashorn/internal/codegen/CodeGenerator.java b/nashorn/src/jdk/nashorn/internal/codegen/CodeGenerator.java
    index e66e288801d..0f96b6d7983 100644
    --- a/nashorn/src/jdk/nashorn/internal/codegen/CodeGenerator.java
    +++ b/nashorn/src/jdk/nashorn/internal/codegen/CodeGenerator.java
    @@ -244,7 +244,7 @@ final class CodeGenerator extends NodeOperatorVisitor currentGlobal =
    -        new ThreadLocal() {
    -            @Override
    -            protected ScriptObject initialValue() {
    -                 return null;
    -            }
    -        };
    +    private static final ThreadLocal currentGlobal = new ThreadLocal<>();
     
         /**
          * Get the current global scope
    diff --git a/nashorn/src/jdk/nashorn/internal/runtime/FunctionScope.java b/nashorn/src/jdk/nashorn/internal/runtime/FunctionScope.java
    index 713aa69d3ce..59a9d5ede03 100644
    --- a/nashorn/src/jdk/nashorn/internal/runtime/FunctionScope.java
    +++ b/nashorn/src/jdk/nashorn/internal/runtime/FunctionScope.java
    @@ -54,9 +54,8 @@ public class FunctionScope extends ScriptObject implements Scope {
          * @param arguments   arguments
          */
         public FunctionScope(final PropertyMap map, final ScriptObject callerScope, final Object arguments) {
    -        super(map);
    +        super(callerScope, map);
             this.arguments = arguments;
    -        setProto(callerScope);
             setIsScope();
         }
     
    @@ -67,9 +66,8 @@ public class FunctionScope extends ScriptObject implements Scope {
          * @param callerScope caller scope
          */
         public FunctionScope(final PropertyMap map, final ScriptObject callerScope) {
    -        super(map);
    +        super(callerScope, map);
             this.arguments = null;
    -        setProto(callerScope);
             setIsScope();
         }
     
    diff --git a/nashorn/src/jdk/nashorn/internal/runtime/PropertyMap.java b/nashorn/src/jdk/nashorn/internal/runtime/PropertyMap.java
    index 3c552daa118..e03a3ef836e 100644
    --- a/nashorn/src/jdk/nashorn/internal/runtime/PropertyMap.java
    +++ b/nashorn/src/jdk/nashorn/internal/runtime/PropertyMap.java
    @@ -25,6 +25,8 @@
     
     package jdk.nashorn.internal.runtime;
     
    +import jdk.nashorn.internal.scripts.JO;
    +
     import static jdk.nashorn.internal.runtime.PropertyHashMap.EMPTY_HASHMAP;
     
     import java.lang.invoke.MethodHandle;
    @@ -166,7 +168,7 @@ public final class PropertyMap implements Iterable, PropertyListener {
          */
         public static PropertyMap newMap(final Class structure, final Collection properties, final int fieldCount, final int fieldMaximum) {
             // Reduce the number of empty maps in the context.
    -        if (structure == jdk.nashorn.internal.scripts.JO.class) {
    +        if (structure == JO.class) {
                 return EMPTY_MAP;
             }
     
    diff --git a/nashorn/src/jdk/nashorn/internal/runtime/ScriptObject.java b/nashorn/src/jdk/nashorn/internal/runtime/ScriptObject.java
    index 3b11ab9d67f..6b51ad525e2 100644
    --- a/nashorn/src/jdk/nashorn/internal/runtime/ScriptObject.java
    +++ b/nashorn/src/jdk/nashorn/internal/runtime/ScriptObject.java
    @@ -170,13 +170,30 @@ public abstract class ScriptObject extends PropertyListenerManager implements Pr
             }
     
             this.arrayData = ArrayData.EMPTY_ARRAY;
    +        this.setMap(map == null ? PropertyMap.newMap(getClass()) : map);
    +    }
     
    -        if (map == null) {
    -            this.setMap(PropertyMap.newMap(getClass()));
    -            return;
    +    /**
    +     * Constructor that directly sets the prototype to {@code proto} and property map to
    +     * {@code map} without invalidating the map as calling {@link #setProto(ScriptObject)}
    +     * would do. This should only be used for objects that are always constructed with the
    +     * same combination of prototype and property map.
    +     *
    +     * @param proto the prototype object
    +     * @param map intial {@link PropertyMap}
    +     */
    +    protected ScriptObject(final ScriptObject proto, final PropertyMap map) {
    +        if (Context.DEBUG) {
    +            ScriptObject.count++;
             }
     
    -        this.setMap(map);
    +        this.arrayData = ArrayData.EMPTY_ARRAY;
    +        this.setMap(map == null ? PropertyMap.newMap(getClass()) : map);
    +        this.proto = proto;
    +
    +        if (proto != null) {
    +            proto.setIsPrototype();
    +        }
         }
     
         /**
    diff --git a/nashorn/src/jdk/nashorn/internal/scripts/JO.java b/nashorn/src/jdk/nashorn/internal/scripts/JO.java
    index d698a2637ce..b31df1ae6f1 100644
    --- a/nashorn/src/jdk/nashorn/internal/scripts/JO.java
    +++ b/nashorn/src/jdk/nashorn/internal/scripts/JO.java
    @@ -32,11 +32,14 @@ import jdk.nashorn.internal.runtime.ScriptObject;
      * Empty object class.
      */
     public class JO extends ScriptObject {
    +
    +    private static final PropertyMap map$ = PropertyMap.newMap(JO.class);
    +
         /**
          * Constructor
          */
         public JO() {
    -        super(PropertyMap.newMap(JO.class));
    +        super(map$);
         }
     
         /**
    @@ -48,6 +51,15 @@ public class JO extends ScriptObject {
             super(map);
         }
     
    +    /**
    +     * Constructor given an initial prototype using the default property map
    +     *
    +     * @param proto the prototype object
    +     */
    +    public JO(final ScriptObject proto) {
    +        super(proto, map$);
    +    }
    +
         /**
          * Used by FunctionObjectCreator. A method handle of this method is passed to the ScriptFunction constructor.
          *
    
    From ee8b3bd823959bd9dd909c9fa367a37ddbf39371 Mon Sep 17 00:00:00 2001
    From: Athijegannathan Sundararajan 
    Date: Wed, 26 Jun 2013 19:42:17 +0530
    Subject: [PATCH 066/127] 8014781: support Error.captureStackTrace
    
    Reviewed-by: jlaskey, hannesw
    ---
     .../api/scripting/NashornException.java       | 51 ++++++++++++++++++
     .../nashorn/internal/objects/NativeError.java | 53 ++++++-------------
     nashorn/test/script/basic/JDK-8014781.js      | 40 ++++++++++++++
     .../test/script/basic/JDK-8014781.js.EXPECTED |  3 ++
     4 files changed, 111 insertions(+), 36 deletions(-)
     create mode 100644 nashorn/test/script/basic/JDK-8014781.js
     create mode 100644 nashorn/test/script/basic/JDK-8014781.js.EXPECTED
    
    diff --git a/nashorn/src/jdk/nashorn/api/scripting/NashornException.java b/nashorn/src/jdk/nashorn/api/scripting/NashornException.java
    index d1d47b1dc08..0b479856630 100644
    --- a/nashorn/src/jdk/nashorn/api/scripting/NashornException.java
    +++ b/nashorn/src/jdk/nashorn/api/scripting/NashornException.java
    @@ -25,6 +25,9 @@
     
     package jdk.nashorn.api.scripting;
     
    +import java.util.ArrayList;
    +import java.util.List;
    +import jdk.nashorn.internal.codegen.CompilerConstants;
     import jdk.nashorn.internal.runtime.ECMAErrors;
     
     /**
    @@ -136,4 +139,52 @@ public abstract class NashornException extends RuntimeException {
             return column;
         }
     
    +    /**
    +     * Returns array javascript stack frames from the given exception object.
    +     *
    +     * @param exception exception from which stack frames are retrieved and filtered
    +     * @return array of javascript stack frames
    +     */
    +    public static StackTraceElement[] getScriptFrames(final Throwable exception) {
    +        final StackTraceElement[] frames = ((Throwable)exception).getStackTrace();
    +        final List filtered = new ArrayList<>();
    +        for (final StackTraceElement st : frames) {
    +            if (ECMAErrors.isScriptFrame(st)) {
    +                final String className = "<" + st.getFileName() + ">";
    +                String methodName = st.getMethodName();
    +                if (methodName.equals(CompilerConstants.RUN_SCRIPT.symbolName())) {
    +                    methodName = "";
    +                }
    +                filtered.add(new StackTraceElement(className, methodName,
    +                        st.getFileName(), st.getLineNumber()));
    +            }
    +        }
    +        return filtered.toArray(new StackTraceElement[filtered.size()]);
    +    }
    +
    +    /**
    +     * Return a formatted script stack trace string with frames information separated by '\n'
    +     *
    +     * @param exception exception for which script stack string is returned
    +     * @return formatted stack trace string
    +     */
    +    public static String getScriptStackString(final Throwable exception) {
    +        final StringBuilder buf = new StringBuilder();
    +        final StackTraceElement[] frames = getScriptFrames((Throwable)exception);
    +        for (final StackTraceElement st : frames) {
    +            buf.append(st.getMethodName());
    +            buf.append(" @ ");
    +            buf.append(st.getFileName());
    +            buf.append(':');
    +            buf.append(st.getLineNumber());
    +            buf.append('\n');
    +        }
    +        final int len = buf.length();
    +        // remove trailing '\n'
    +        if (len > 0) {
    +            assert buf.charAt(len - 1) == '\n';
    +            buf.deleteCharAt(len - 1);
    +        }
    +        return buf.toString();
    +    }
     }
    diff --git a/nashorn/src/jdk/nashorn/internal/objects/NativeError.java b/nashorn/src/jdk/nashorn/internal/objects/NativeError.java
    index 1a638cf82bf..12029ad091b 100644
    --- a/nashorn/src/jdk/nashorn/internal/objects/NativeError.java
    +++ b/nashorn/src/jdk/nashorn/internal/objects/NativeError.java
    @@ -32,6 +32,7 @@ import java.lang.invoke.MethodHandle;
     import java.lang.invoke.MethodHandles;
     import java.util.ArrayList;
     import java.util.List;
    +import jdk.nashorn.api.scripting.NashornException;
     import jdk.nashorn.internal.codegen.CompilerConstants;
     import jdk.nashorn.internal.lookup.MethodHandleFactory;
     import jdk.nashorn.internal.objects.annotations.Attribute;
    @@ -118,6 +119,20 @@ public final class NativeError extends ScriptObject {
             return new NativeError(msg);
         }
     
    +    /**
    +     * Nashorn extension: Error.captureStackTrace. Capture stack trace at the point of call into the Error object provided.
    +     *
    +     * @param self self reference
    +     */
    +    @Function(attributes = Attribute.NOT_ENUMERABLE, where = Where.CONSTRUCTOR)
    +    public static Object captureStackTrace(final Object self, final Object errorObj) {
    +        Global.checkObject(errorObj);
    +        final ScriptObject sobj = (ScriptObject)errorObj;
    +        final ECMAException exp = new ECMAException(sobj, null);
    +        sobj.set("stack", NashornException.getScriptStackString(exp), false);
    +        return UNDEFINED;
    +    }
    +
         /**
          * Nashorn extension: Error.dumpStack
          * dumps the stack of the current thread.
    @@ -163,7 +178,7 @@ public final class NativeError extends ScriptObject {
             final Object exception = ECMAException.getException(sobj);
             Object[] res;
             if (exception instanceof Throwable) {
    -            res = getScriptFrames((Throwable)exception);
    +            res = NashornException.getScriptFrames((Throwable)exception);
             } else {
                 res = ScriptRuntime.EMPTY_ARRAY;
             }
    @@ -272,25 +287,8 @@ public final class NativeError extends ScriptObject {
             }
     
             final Object exception = ECMAException.getException(sobj);
    -        final StringBuilder buf = new StringBuilder();
             if (exception instanceof Throwable) {
    -            final Object[] frames = getScriptFrames((Throwable)exception);
    -            for (final Object fr : frames) {
    -                final StackTraceElement st = (StackTraceElement)fr;
    -                buf.append(st.getMethodName());
    -                buf.append(" @ ");
    -                buf.append(st.getFileName());
    -                buf.append(':');
    -                buf.append(st.getLineNumber());
    -                buf.append('\n');
    -            }
    -            final int len = buf.length();
    -            // remove trailing '\n'
    -            if (len > 0) {
    -                assert buf.charAt(len - 1) == '\n';
    -                buf.deleteCharAt(len - 1);
    -            }
    -            return buf.toString();
    +            return NashornException.getScriptStackString((Throwable)exception);
             } else {
                 return "";
             }
    @@ -364,21 +362,4 @@ public final class NativeError extends ScriptObject {
                 throw new MethodHandleFactory.LookupException(e);
             }
         }
    -
    -    private static Object[] getScriptFrames(final Throwable exception) {
    -        final StackTraceElement[] frames = ((Throwable)exception).getStackTrace();
    -        final List filtered = new ArrayList<>();
    -        for (final StackTraceElement st : frames) {
    -            if (ECMAErrors.isScriptFrame(st)) {
    -                final String className = "<" + st.getFileName() + ">";
    -                String methodName = st.getMethodName();
    -                if (methodName.equals(CompilerConstants.RUN_SCRIPT.symbolName())) {
    -                    methodName = "";
    -                }
    -                filtered.add(new StackTraceElement(className, methodName,
    -                        st.getFileName(), st.getLineNumber()));
    -            }
    -        }
    -        return filtered.toArray();
    -    }
     }
    diff --git a/nashorn/test/script/basic/JDK-8014781.js b/nashorn/test/script/basic/JDK-8014781.js
    new file mode 100644
    index 00000000000..3c6d7d88a46
    --- /dev/null
    +++ b/nashorn/test/script/basic/JDK-8014781.js
    @@ -0,0 +1,40 @@
    +/*
    + * Copyright (c) 2010, 2013, 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.
    + */
    +
    +/**
    + * JDK-8014781: support Error.captureStackTrace
    + *
    + * @test
    + * @run
    + */
    +
    +function MyError() {
    +    Error.captureStackTrace(this);
    +}
    +
    +function func() {
    +    return new MyError();
    +}
    +
    +var e = func();
    +print(e.stack.replace(/\\/g, '/'));
    diff --git a/nashorn/test/script/basic/JDK-8014781.js.EXPECTED b/nashorn/test/script/basic/JDK-8014781.js.EXPECTED
    new file mode 100644
    index 00000000000..073d3b78bc8
    --- /dev/null
    +++ b/nashorn/test/script/basic/JDK-8014781.js.EXPECTED
    @@ -0,0 +1,3 @@
    +MyError @ test/script/basic/JDK-8014781.js:32
    +func @ test/script/basic/JDK-8014781.js:36
    + @ test/script/basic/JDK-8014781.js:39
    
    From bb7b31d9ff5fa4b7c4e92fdc78c4fcdfa516ff6a Mon Sep 17 00:00:00 2001
    From: Erik Gahlin 
    Date: Wed, 26 Jun 2013 17:02:04 +0200
    Subject: [PATCH 067/127] 8016331: Minor issues in event tracing metadata
    
    Reviewed-by: stefank, brutisso, mgronlun
    ---
     hotspot/src/share/vm/trace/trace.xml | 12 ++++++------
     1 file changed, 6 insertions(+), 6 deletions(-)
    
    diff --git a/hotspot/src/share/vm/trace/trace.xml b/hotspot/src/share/vm/trace/trace.xml
    index c530bbc3c16..6b1d9a8850f 100644
    --- a/hotspot/src/share/vm/trace/trace.xml
    +++ b/hotspot/src/share/vm/trace/trace.xml
    @@ -158,7 +158,7 @@ Declares a structure type that can be used in other events.
           
         
     
    -    
    +    
           
           
     
    @@ -203,7 +203,7 @@ Declares a structure type that can be used in other events.
           
         
     
    -    
    +    
           
           
           
    @@ -211,7 +211,7 @@ Declares a structure type that can be used in other events.
           
           
           
    -      
    +      
           
         
     
    @@ -240,14 +240,14 @@ Declares a structure type that can be used in other events.
         
           
    -      
    +      
           
         
     
         
           
    -      
    +      
         
     
         
           
           
    -      
    +      
           
         
     
    
    From 1e7b1f36e402c5ab85b662471a819a03540e826c Mon Sep 17 00:00:00 2001
    From: James Laskey 
    Date: Wed, 26 Jun 2013 12:38:35 -0300
    Subject: [PATCH 068/127] 8019175: Simplify ScriptObject.modifyOwnProperty
    
    Reviewed-by: hannesw
    ---
     .../jdk/nashorn/internal/objects/ScriptFunctionImpl.java    | 6 ------
     nashorn/src/jdk/nashorn/internal/runtime/ScriptObject.java  | 4 +---
     2 files changed, 1 insertion(+), 9 deletions(-)
    
    diff --git a/nashorn/src/jdk/nashorn/internal/objects/ScriptFunctionImpl.java b/nashorn/src/jdk/nashorn/internal/objects/ScriptFunctionImpl.java
    index 32ce0a035d8..6834ef4b701 100644
    --- a/nashorn/src/jdk/nashorn/internal/objects/ScriptFunctionImpl.java
    +++ b/nashorn/src/jdk/nashorn/internal/objects/ScriptFunctionImpl.java
    @@ -149,12 +149,6 @@ public class ScriptFunctionImpl extends ScriptFunction {
             return typeErrorThrower;
         }
     
    -    // add a new property that throws TypeError on get as well as set
    -    static synchronized PropertyMap newThrowerProperty(final PropertyMap map, final String name) {
    -        return map.newProperty(name, Property.NOT_ENUMERABLE | Property.NOT_CONFIGURABLE, -1,
    -                Lookup.TYPE_ERROR_THROWER_GETTER, Lookup.TYPE_ERROR_THROWER_SETTER);
    -    }
    -
         private static PropertyMap createStrictModeMap(PropertyMap map) {
             final int flags = Property.NOT_ENUMERABLE | Property.NOT_CONFIGURABLE;
             // Need to add properties directly to map since slots are assigned speculatively by newUserAccessors.
    diff --git a/nashorn/src/jdk/nashorn/internal/runtime/ScriptObject.java b/nashorn/src/jdk/nashorn/internal/runtime/ScriptObject.java
    index 6b51ad525e2..1a081a1b2d5 100644
    --- a/nashorn/src/jdk/nashorn/internal/runtime/ScriptObject.java
    +++ b/nashorn/src/jdk/nashorn/internal/runtime/ScriptObject.java
    @@ -868,9 +868,7 @@ public abstract class ScriptObject extends PropertyListenerManager implements Pr
         public final void setUserAccessors(final String key, final ScriptFunction getter, final ScriptFunction setter) {
             final Property oldProperty = getMap().findProperty(key);
             if (oldProperty instanceof UserAccessorProperty) {
    -            final UserAccessorProperty ua = (UserAccessorProperty)oldProperty;
    -            setSpill(ua.getGetterSlot(), getter);
    -            setSpill(ua.getSetterSlot(), setter);
    +            modifyOwnProperty(oldProperty, oldProperty.getFlags(), getter, setter);
             } else {
                 addOwnProperty(newUserAccessors(key, oldProperty != null ? oldProperty.getFlags() : 0, getter, setter));
             }
    
    From 7b09b9e85a8fe5442e715eca3a0a2c25fc8b03a9 Mon Sep 17 00:00:00 2001
    From: Staffan Larsen 
    Date: Wed, 26 Jun 2013 19:15:34 +0200
    Subject: [PATCH 069/127] 8019155: Update makefiles with correct jfr packages
    
    Reviewed-by: mgronlun, erikj
    ---
     jdk/make/common/Release.gmk  |  6 ++++--
     jdk/makefiles/CreateJars.gmk | 22 ++++++++++++----------
     2 files changed, 16 insertions(+), 12 deletions(-)
    
    diff --git a/jdk/make/common/Release.gmk b/jdk/make/common/Release.gmk
    index ce2dda53d1d..b584781eb50 100644
    --- a/jdk/make/common/Release.gmk
    +++ b/jdk/make/common/Release.gmk
    @@ -252,7 +252,7 @@ images:: sanity-images post-sanity-images  \
     	 $(INITIAL_IMAGE_JRE) $(INITIAL_IMAGE_JDK) \
     	 trim-image-jre trim-image-jdk \
              identify-image-jre identify-image-jdk \
    -	 process-image-jre process-image-jdk sec-files sec-files-win jgss-files 
    +	 process-image-jre process-image-jdk sec-files sec-files-win jgss-files
     endif
     
     # Don't use these
    @@ -400,7 +400,8 @@ TOOLS = \
     # classes that go into jfr.jar
     JFR_CLASSES_DIRS= \
     	com/oracle/jrockit/jfr \
    -	oracle/jrockit/jfr
    +	oracle/jrockit/jfr \
    +	jdk/jfr
     
     # classes that go into jsse.jar
     JSSE_CLASSES_DIRS = \
    @@ -612,6 +613,7 @@ ifndef JAVASE_EMBEDDED
     	$(ECHO) "oracle/jrockit/jfr/parser/" >> $@
     	$(ECHO) "oracle/jrockit/jfr/settings/" >> $@
     	$(ECHO) "oracle/jrockit/jfr/tools/" >> $@
    +	$(ECHO) "jdk/jfr/" >> $@
     endif
     endif
     
    diff --git a/jdk/makefiles/CreateJars.gmk b/jdk/makefiles/CreateJars.gmk
    index 64c96b2c97e..54531f19ef5 100644
    --- a/jdk/makefiles/CreateJars.gmk
    +++ b/jdk/makefiles/CreateJars.gmk
    @@ -132,7 +132,7 @@ $(eval $(call SetupArchive,BUILD_LOCALEDATA_JAR,,\
     ##########################################################################################
     
     # Full JRE exclude list for rt.jar and resources.jar
    -# This value should exclude types destined for jars other than rt.jar and resources.jar. 
    +# This value should exclude types destined for jars other than rt.jar and resources.jar.
     # When building a Profile this value augments the profile specific exclusions
     RT_JAR_EXCLUDES += \
     	com/oracle/security \
    @@ -246,7 +246,8 @@ RT_JAR_EXCLUDES += \
     	sun/util/resources/cldr \
     	$(LOCALEDATA_INCLUDES) \
     	com/oracle/jrockit/jfr \
    -	oracle/jrockit/jfr
    +	oracle/jrockit/jfr \
    +	jdk/jfr
     
     ifeq ($(OPENJDK_TARGET_OS), macosx)
             RT_JAR_EXCLUDES += com/sun/nio/sctp \
    @@ -337,7 +338,7 @@ $(PROFILE_VERSION_CLASS_TARGETS) : $(PROFILE_VERSION_JAVA_TARGETS)
     
     
     # Support for removing the addPropertyChangeListener and removePropertyChangeListener
    -# methods from classes that only go into the profile builds. 
    +# methods from classes that only go into the profile builds.
     BEANLESS_CLASSES = $(IMAGES_OUTPUTDIR)/beanless
     
     # When there are $ characters in filenames we have some very subtle interactions between
    @@ -352,7 +353,7 @@ CLASSES_TO_DEBEAN = \
         java/util/jar/Pack200\$$Packer.class \
         java/util/jar/Pack200\$$Unpacker.class \
         com/sun/java/util/jar/pack/PackerImpl.class \
    -    com/sun/java/util/jar/pack/UnpackerImpl.class 
    +    com/sun/java/util/jar/pack/UnpackerImpl.class
     
     ifneq ($(PROFILE),)
         BEANLESS_CLASSES_TARGETS := $(addprefix $(BEANLESS_CLASSES)/, $(CLASSES_TO_DEBEAN))
    @@ -428,7 +429,8 @@ ifeq ($(ENABLE_JFR), true)
     		SRCS:=$(JDK_OUTPUTDIR)/classes,\
     		SUFFIXES:=.class .jfc .xsd,\
     		INCLUDES:=com/oracle/jrockit/jfr \
    -			  oracle/jrockit/jfr,\
    +			  oracle/jrockit/jfr \
    +			  jdk/jfr,\
     		JAR:=$(IMAGES_OUTPUTDIR)/lib/jfr.jar,\
     		SKIP_METAINF:=true,\
     		MANIFEST:=$(MAINMANIFEST), \
    @@ -468,14 +470,14 @@ $(JCE_MANIFEST): $(MAINMANIFEST)
     	$(MV) $@.tmp $@
     
     ##########################################################################################
    -# For security and crypto jars, always build the jar, but for closed, install the prebuilt 
    -# signed version instead of the newly built jar. Unsigned jars are treated as intermediate 
    -# targets and explicitly added to the JARS list. For open, signing is not needed. See 
    +# For security and crypto jars, always build the jar, but for closed, install the prebuilt
    +# signed version instead of the newly built jar. Unsigned jars are treated as intermediate
    +# targets and explicitly added to the JARS list. For open, signing is not needed. See
     # SignJars.gmk for more information.
     #
     # The source for the crypto jars is not available for all licensees. The BUILD_CRYPTO
     # variable is set to no if these jars can't be built to skip that step of the build.
    -# Note that for OPENJDK, the build will fail if BUILD_CRYPTO=no since then there is no 
    +# Note that for OPENJDK, the build will fail if BUILD_CRYPTO=no since then there is no
     # other way to get the jars than to build them.
     
     SUNPKCS11_JAR_DST := $(IMAGES_OUTPUTDIR)/lib/ext/sunpkcs11.jar
    @@ -738,7 +740,7 @@ $(UCRYPTO_JAR_DST) : $(UCRYPTO_JAR_SRC)
     	@$(ECHO) $(LOG_INFO) "\n>>>Installing prebuilt OracleUcrypto provider..."
     	$(install-file)
     
    -JARS += $(UCRYPTO_JAR_UNSIGNED) 
    +JARS += $(UCRYPTO_JAR_UNSIGNED)
     
     endif
     endif
    
    From a089899deb71504933be671ef618c4bd457abe73 Mon Sep 17 00:00:00 2001
    From: Athijegannathan Sundararajan 
    Date: Thu, 27 Jun 2013 13:24:50 +0530
    Subject: [PATCH 070/127] 8019226: line number not generated for first
     statement if it is on the same function declaration line
    
    Reviewed-by: jlaskey, hannesw
    ---
     .../internal/codegen/CodeGenerator.java       |  4 +-
     nashorn/test/script/basic/JDK-8019226.js      | 39 +++++++++++++++++++
     .../test/script/basic/JDK-8019226.js.EXPECTED |  3 ++
     3 files changed, 45 insertions(+), 1 deletion(-)
     create mode 100644 nashorn/test/script/basic/JDK-8019226.js
     create mode 100644 nashorn/test/script/basic/JDK-8019226.js.EXPECTED
    
    diff --git a/nashorn/src/jdk/nashorn/internal/codegen/CodeGenerator.java b/nashorn/src/jdk/nashorn/internal/codegen/CodeGenerator.java
    index 0f96b6d7983..c4b0af9938b 100644
    --- a/nashorn/src/jdk/nashorn/internal/codegen/CodeGenerator.java
    +++ b/nashorn/src/jdk/nashorn/internal/codegen/CodeGenerator.java
    @@ -1016,6 +1016,8 @@ final class CodeGenerator extends NodeOperatorVisitor @ test/script/basic/JDK-8019226.js:36
    
    From d3dfbb3cf2d10ed83529d6764cafdfe1bbbc7f20 Mon Sep 17 00:00:00 2001
    From: Bengt Rutisson 
    Date: Thu, 27 Jun 2013 09:59:59 +0200
    Subject: [PATCH 071/127] 8017483: G1 tests fail with native OOME on Solaris
     x86 after HeapBaseMinAddress has been increased
    
    Set HeapBaseMinAddress as default rather than ergo
    
    Reviewed-by: stefank, jmasa, kvn
    ---
     hotspot/src/share/vm/runtime/arguments.cpp | 4 +++-
     1 file changed, 3 insertions(+), 1 deletion(-)
    
    diff --git a/hotspot/src/share/vm/runtime/arguments.cpp b/hotspot/src/share/vm/runtime/arguments.cpp
    index 625feda03f9..3fc9761f787 100644
    --- a/hotspot/src/share/vm/runtime/arguments.cpp
    +++ b/hotspot/src/share/vm/runtime/arguments.cpp
    @@ -1571,7 +1571,9 @@ void Arguments::set_heap_base_min_address() {
         // By default HeapBaseMinAddress is 2G on all platforms except Solaris x86.
         // G1 currently needs a lot of C-heap, so on Solaris we have to give G1
         // some extra space for the C-heap compared to other collectors.
    -    FLAG_SET_ERGO(uintx, HeapBaseMinAddress, 1*G);
    +    // Use FLAG_SET_DEFAULT here rather than FLAG_SET_ERGO to make sure that
    +    // code that checks for default values work correctly.
    +    FLAG_SET_DEFAULT(HeapBaseMinAddress, 1*G);
       }
     }
     
    
    From 13f301694b9663923bbe3a06e4dbfbf0b4a91a98 Mon Sep 17 00:00:00 2001
    From: Petr Pchelko 
    Date: Thu, 27 Jun 2013 13:56:16 +0400
    Subject: [PATCH 072/127] 8019236: [macosx] Add javadoc to the
     handleWindowFocusEvent in CEmbeddedFrame
    
    Reviewed-by: serb, ant
    ---
     .../classes/sun/lwawt/macosx/CEmbeddedFrame.java    | 13 +++++++++++++
     1 file changed, 13 insertions(+)
    
    diff --git a/jdk/src/macosx/classes/sun/lwawt/macosx/CEmbeddedFrame.java b/jdk/src/macosx/classes/sun/lwawt/macosx/CEmbeddedFrame.java
    index 9e0377cdc25..ff3fb757783 100644
    --- a/jdk/src/macosx/classes/sun/lwawt/macosx/CEmbeddedFrame.java
    +++ b/jdk/src/macosx/classes/sun/lwawt/macosx/CEmbeddedFrame.java
    @@ -119,6 +119,19 @@ public class CEmbeddedFrame extends EmbeddedFrame {
             }
         }
     
    +    /**
    +     * When the parent window is activated this method is called for all EmbeddedFrames in it.
    +     *
    +     * For the CEmbeddedFrame which had focus before the deactivation this method triggers
    +     * focus events in the following order:
    +     *  1. WINDOW_ACTIVATED for this EmbeddedFrame
    +     *  2. WINDOW_GAINED_FOCUS for this EmbeddedFrame
    +     *  3. FOCUS_GAINED for the most recent focus owner in this EmbeddedFrame
    +     *
    +     * The caller must not requestFocus on the EmbeddedFrame together with calling this method.
    +     *
    +     * @param parentWindowActive true if the window is activated, false otherwise
    +     */
         public void handleWindowFocusEvent(boolean parentWindowActive) {
             this.parentWindowActive = parentWindowActive;
             // ignore focus "lost" native request as it may mistakenly
    
    From 27da77ce6bb543aa17bf23f97ae2e9b06271b492 Mon Sep 17 00:00:00 2001
    From: Paul Sandoz 
    Date: Fri, 28 Jun 2013 10:29:21 +0200
    Subject: [PATCH 073/127] 8012987: Optimizations for Stream.limit/substream
    
    Co-authored-by: Brian Goetz 
    Reviewed-by: mduigou
    ---
     .../java/util/stream/AbstractPipeline.java    |  25 +
     .../java/util/stream/AbstractTask.java        |   1 +
     .../java/util/stream/DoubleStream.java        |  11 +-
     .../classes/java/util/stream/ForEachOps.java  |   2 +-
     .../classes/java/util/stream/IntStream.java   |  11 +-
     .../classes/java/util/stream/LongStream.java  |  11 +-
     .../java/util/stream/PipelineHelper.java      |  17 +-
     .../classes/java/util/stream/SliceOps.java    | 593 +++++++----
     .../classes/java/util/stream/Stream.java      |  11 +-
     .../java/util/stream/StreamSpliterators.java  | 959 ++++++++++++++++--
     .../bootlib/java/util/stream/OpTestCase.java  |   4 +-
     .../util/stream/SpliteratorTestHelper.java    | 126 ++-
     .../util/stream/SliceSpliteratorTest.java     | 201 ++++
     .../java/util/stream/StreamFlagsTest.java     |   4 +-
     .../stream/InfiniteStreamWithLimitOpTest.java | 439 +++++++-
     15 files changed, 2001 insertions(+), 414 deletions(-)
     create mode 100644 jdk/test/java/util/stream/boottest/java/util/stream/SliceSpliteratorTest.java
    
    diff --git a/jdk/src/share/classes/java/util/stream/AbstractPipeline.java b/jdk/src/share/classes/java/util/stream/AbstractPipeline.java
    index 37575b0c72c..efda9407152 100644
    --- a/jdk/src/share/classes/java/util/stream/AbstractPipeline.java
    +++ b/jdk/src/share/classes/java/util/stream/AbstractPipeline.java
    @@ -375,6 +375,12 @@ abstract class AbstractPipeline>
                         // NOTE: there are no size-injecting ops
                         if (StreamOpFlag.SHORT_CIRCUIT.isKnown(thisOpFlags)) {
                             backPropagationHead = p;
    +                        // Clear the short circuit flag for next pipeline stage
    +                        // This stage encapsulates short-circuiting, the next
    +                        // stage may not have any short-circuit operations, and
    +                        // if so spliterator.forEachRemaining should be be used
    +                        // for traversal
    +                        thisOpFlags = thisOpFlags & ~StreamOpFlag.IS_SHORT_CIRCUIT;
                         }
     
                         depth = 0;
    @@ -447,6 +453,15 @@ abstract class AbstractPipeline>
     
         // PipelineHelper
     
    +    @Override
    +    final StreamShape getSourceShape() {
    +        AbstractPipeline p = AbstractPipeline.this;
    +        while (p.depth > 0) {
    +            p = p.previousStage;
    +        }
    +        return p.getOutputShape();
    +    }
    +
         @Override
         final  long exactOutputSizeIfKnown(Spliterator spliterator) {
             return StreamOpFlag.SIZED.isKnown(getStreamAndOpFlags()) ? spliterator.getExactSizeIfKnown() : -1;
    @@ -502,6 +517,16 @@ abstract class AbstractPipeline>
             return (Sink) sink;
         }
     
    +    @Override
    +    final  Spliterator wrapSpliterator(Spliterator sourceSpliterator) {
    +        if (depth == 0) {
    +            return (Spliterator) sourceSpliterator;
    +        }
    +        else {
    +            return wrap(this, () -> sourceSpliterator, isParallel());
    +        }
    +    }
    +
         @Override
         @SuppressWarnings("unchecked")
         final  Node evaluate(Spliterator spliterator,
    diff --git a/jdk/src/share/classes/java/util/stream/AbstractTask.java b/jdk/src/share/classes/java/util/stream/AbstractTask.java
    index 1b7ad212286..75fc3a11f60 100644
    --- a/jdk/src/share/classes/java/util/stream/AbstractTask.java
    +++ b/jdk/src/share/classes/java/util/stream/AbstractTask.java
    @@ -316,6 +316,7 @@ abstract class AbstractTask {
          */
         public static DoubleStream generate(DoubleSupplier s) {
             Objects.requireNonNull(s);
    -        return StreamSupport.doubleStream(Spliterators.spliteratorUnknownSize(
    -                new PrimitiveIterator.OfDouble() {
    -                    @Override
    -                    public boolean hasNext() { return true; }
    -
    -                    @Override
    -                    public double nextDouble() { return s.getAsDouble(); }
    -                },
    -                Spliterator.ORDERED | Spliterator.IMMUTABLE | Spliterator.NONNULL));
    +        return StreamSupport.doubleStream(
    +                new StreamSpliterators.InfiniteSupplyingSpliterator.OfDouble(Long.MAX_VALUE, s));
         }
     }
    diff --git a/jdk/src/share/classes/java/util/stream/ForEachOps.java b/jdk/src/share/classes/java/util/stream/ForEachOps.java
    index 944dec6211f..6f20677cd66 100644
    --- a/jdk/src/share/classes/java/util/stream/ForEachOps.java
    +++ b/jdk/src/share/classes/java/util/stream/ForEachOps.java
    @@ -342,7 +342,7 @@ final class ForEachOps {
                 doCompute(this);
             }
     
    -        private static void doCompute(ForEachOrderedTask task) {
    +        private static  void doCompute(ForEachOrderedTask task) {
                 while (true) {
                     Spliterator split;
                     if (!AbstractTask.suggestSplit(task.spliterator, task.targetSize)
    diff --git a/jdk/src/share/classes/java/util/stream/IntStream.java b/jdk/src/share/classes/java/util/stream/IntStream.java
    index 3545c9b83ab..3eb4409c4e5 100644
    --- a/jdk/src/share/classes/java/util/stream/IntStream.java
    +++ b/jdk/src/share/classes/java/util/stream/IntStream.java
    @@ -745,15 +745,8 @@ public interface IntStream extends BaseStream {
          */
         public static IntStream generate(IntSupplier s) {
             Objects.requireNonNull(s);
    -        return StreamSupport.intStream(Spliterators.spliteratorUnknownSize(
    -                new PrimitiveIterator.OfInt() {
    -                    @Override
    -                    public boolean hasNext() { return true; }
    -
    -                    @Override
    -                    public int nextInt() { return s.getAsInt(); }
    -                },
    -                Spliterator.ORDERED | Spliterator.IMMUTABLE | Spliterator.NONNULL));
    +        return StreamSupport.intStream(
    +                new StreamSpliterators.InfiniteSupplyingSpliterator.OfInt(Long.MAX_VALUE, s));
         }
     
         /**
    diff --git a/jdk/src/share/classes/java/util/stream/LongStream.java b/jdk/src/share/classes/java/util/stream/LongStream.java
    index 1a1b2414338..3bc0f76a494 100644
    --- a/jdk/src/share/classes/java/util/stream/LongStream.java
    +++ b/jdk/src/share/classes/java/util/stream/LongStream.java
    @@ -736,15 +736,8 @@ public interface LongStream extends BaseStream {
          */
         public static LongStream generate(LongSupplier s) {
             Objects.requireNonNull(s);
    -        return StreamSupport.longStream(Spliterators.spliteratorUnknownSize(
    -                new PrimitiveIterator.OfLong() {
    -                    @Override
    -                    public boolean hasNext() { return true; }
    -
    -                    @Override
    -                    public long nextLong() { return s.getAsLong(); }
    -                },
    -                Spliterator.ORDERED | Spliterator.IMMUTABLE | Spliterator.NONNULL));
    +        return StreamSupport.longStream(
    +                new StreamSpliterators.InfiniteSupplyingSpliterator.OfLong(Long.MAX_VALUE, s));
         }
     
         /**
    diff --git a/jdk/src/share/classes/java/util/stream/PipelineHelper.java b/jdk/src/share/classes/java/util/stream/PipelineHelper.java
    index 853a1ffac48..6824e3b3179 100644
    --- a/jdk/src/share/classes/java/util/stream/PipelineHelper.java
    +++ b/jdk/src/share/classes/java/util/stream/PipelineHelper.java
    @@ -44,7 +44,7 @@ import java.util.function.IntFunction;
      * and {@link AbstractPipeline#opEvaluateParallel(PipelineHelper, java.util.Spliterator,
      * java.util.function.IntFunction)}, methods, which can use the
      * {@code PipelineHelper} to access information about the pipeline such as
    - * input shape, output shape, stream flags, and size, and use the helper methods
    + * head shape, stream flags, and size, and use the helper methods
      * such as {@link #wrapAndCopyInto(Sink, Spliterator)},
      * {@link #copyInto(Sink, Spliterator)}, and {@link #wrapSink(Sink)} to execute
      * pipeline operations.
    @@ -54,6 +54,13 @@ import java.util.function.IntFunction;
      */
     abstract class PipelineHelper {
     
    +    /**
    +     * Gets the stream shape for the source of the pipeline segment.
    +     *
    +     * @return the stream shape for the source of the pipeline segment.
    +     */
    +    abstract StreamShape getSourceShape();
    +
         /**
          * Gets the combined stream and operation flags for the output of the described
          * pipeline.  This will incorporate stream flags from the stream source, all
    @@ -145,6 +152,14 @@ abstract class PipelineHelper {
          */
         abstract Sink wrapSink(Sink sink);
     
    +    /**
    +     *
    +     * @param spliterator
    +     * @param 
    +     * @return
    +     */
    +    abstract Spliterator wrapSpliterator(Spliterator spliterator);
    +
         /**
          * Constructs a @{link Node.Builder} compatible with the output shape of
          * this {@code PipelineHelper}.
    diff --git a/jdk/src/share/classes/java/util/stream/SliceOps.java b/jdk/src/share/classes/java/util/stream/SliceOps.java
    index 31c6bd82446..78fd3d7f0d5 100644
    --- a/jdk/src/share/classes/java/util/stream/SliceOps.java
    +++ b/jdk/src/share/classes/java/util/stream/SliceOps.java
    @@ -24,14 +24,9 @@
      */
     package java.util.stream;
     
    -import java.util.ArrayList;
    -import java.util.List;
     import java.util.Spliterator;
     import java.util.concurrent.CountedCompleter;
    -import java.util.function.DoubleConsumer;
    -import java.util.function.IntConsumer;
     import java.util.function.IntFunction;
    -import java.util.function.LongConsumer;
     
     /**
      * Factory for instances of a short-circuiting stateful intermediate operations
    @@ -44,6 +39,63 @@ final class SliceOps {
         // No instances
         private SliceOps() { }
     
    +    /**
    +     * Calculates the sliced size given the current size, number of elements
    +     * skip, and the number of elements to limit.
    +     *
    +     * @param size the current size
    +     * @param skip the number of elements to skip, assumed to be >= 0
    +     * @param limit the number of elements to limit, assumed to be >= 0, with
    +     *        a value of {@code Long.MAX_VALUE} if there is no limit
    +     * @return the sliced size
    +     */
    +    private static long calcSize(long size, long skip, long limit) {
    +        return size >= 0 ? Math.max(-1, Math.min(size - skip, limit)) : -1;
    +    }
    +
    +    /**
    +     * Calculates the slice fence, which is one past the index of the slice
    +     * range
    +     * @param skip the number of elements to skip, assumed to be >= 0
    +     * @param limit the number of elements to limit, assumed to be >= 0, with
    +     *        a value of {@code Long.MAX_VALUE} if there is no limit
    +     * @return the slice fence.
    +     */
    +    private static long calcSliceFence(long skip, long limit) {
    +        long sliceFence = limit >= 0 ? skip + limit : Long.MAX_VALUE;
    +        // Check for overflow
    +        return (sliceFence >= 0) ? sliceFence : Long.MAX_VALUE;
    +    }
    +
    +    /**
    +     * Creates a slice spliterator given a stream shape governing the
    +     * spliterator type.  Requires that the underlying Spliterator
    +     * be SUBSIZED.
    +     */
    +    @SuppressWarnings("unchecked")
    +    private static  Spliterator sliceSpliterator(StreamShape shape,
    +                                                             Spliterator s,
    +                                                             long skip, long limit) {
    +        assert s.hasCharacteristics(Spliterator.SUBSIZED);
    +        long sliceFence = calcSliceFence(skip, limit);
    +        switch (shape) {
    +            case REFERENCE:
    +                return new StreamSpliterators
    +                        .SliceSpliterator.OfRef<>(s, skip, sliceFence);
    +            case INT_VALUE:
    +                return (Spliterator) new StreamSpliterators
    +                        .SliceSpliterator.OfInt((Spliterator.OfInt) s, skip, sliceFence);
    +            case LONG_VALUE:
    +                return (Spliterator) new StreamSpliterators
    +                        .SliceSpliterator.OfLong((Spliterator.OfLong) s, skip, sliceFence);
    +            case DOUBLE_VALUE:
    +                return (Spliterator) new StreamSpliterators
    +                        .SliceSpliterator.OfDouble((Spliterator.OfDouble) s, skip, sliceFence);
    +            default:
    +                throw new IllegalStateException("Unknown shape " + shape);
    +        }
    +    }
    +
         /**
          * Appends a "slice" operation to the provided stream.  The slice operation
          * may be may be skip-only, limit-only, or skip-and-limit.
    @@ -61,11 +113,71 @@ final class SliceOps {
     
             return new ReferencePipeline.StatefulOp(upstream, StreamShape.REFERENCE,
                                                          flags(limit)) {
    +            Spliterator unorderedSkipLimitSpliterator(Spliterator s,
    +                                                         long skip, long limit, long sizeIfKnown) {
    +                if (skip <= sizeIfKnown) {
    +                    // Use just the limit if the number of elements
    +                    // to skip is <= the known pipeline size
    +                    limit = limit >= 0 ? Math.min(limit, sizeIfKnown - skip) : sizeIfKnown - skip;
    +                    skip = 0;
    +                }
    +                return new StreamSpliterators.UnorderedSliceSpliterator.OfRef<>(s, skip, limit);
    +            }
    +
    +            @Override
    +             Spliterator opEvaluateParallelLazy(PipelineHelper helper, Spliterator spliterator) {
    +                long size = helper.exactOutputSizeIfKnown(spliterator);
    +                if (size > 0 && spliterator.hasCharacteristics(Spliterator.SUBSIZED)) {
    +                    return new StreamSpliterators.SliceSpliterator.OfRef<>(
    +                            helper.wrapSpliterator(spliterator),
    +                            skip,
    +                            calcSliceFence(skip, limit));
    +                } else if (!StreamOpFlag.ORDERED.isKnown(helper.getStreamAndOpFlags())) {
    +                    return unorderedSkipLimitSpliterator(
    +                            helper.wrapSpliterator(spliterator),
    +                            skip, limit, size);
    +                }
    +                else {
    +                    // @@@ OOMEs will occur for LongStream.longs().filter(i -> true).limit(n)
    +                    //     regardless of the value of n
    +                    //     Need to adjust the target size of splitting for the
    +                    //     SliceTask from say (size / k) to say min(size / k, 1 << 14)
    +                    //     This will limit the size of the buffers created at the leaf nodes
    +                    //     cancellation will be more aggressive cancelling later tasks
    +                    //     if the target slice size has been reached from a given task,
    +                    //     cancellation should also clear local results if any
    +                    return new SliceTask<>(this, helper, spliterator, i -> (T[]) new Object[i], skip, limit).
    +                            invoke().spliterator();
    +                }
    +            }
    +
                 @Override
                  Node opEvaluateParallel(PipelineHelper helper,
                                                   Spliterator spliterator,
                                                   IntFunction generator) {
    -                return new SliceTask<>(this, helper, spliterator, generator, skip, limit).invoke();
    +                long size = helper.exactOutputSizeIfKnown(spliterator);
    +                if (size > 0 && spliterator.hasCharacteristics(Spliterator.SUBSIZED)) {
    +                    // Because the pipeline is SIZED the slice spliterator
    +                    // can be created from the source, this requires matching
    +                    // to shape of the source, and is potentially more efficient
    +                    // than creating the slice spliterator from the pipeline
    +                    // wrapping spliterator
    +                    Spliterator s = sliceSpliterator(helper.getSourceShape(), spliterator, skip, limit);
    +                    return Nodes.collect(helper, s, true, generator);
    +                } else if (!StreamOpFlag.ORDERED.isKnown(helper.getStreamAndOpFlags())) {
    +                    Spliterator s =  unorderedSkipLimitSpliterator(
    +                            helper.wrapSpliterator(spliterator),
    +                            skip, limit, size);
    +                    // Collect using this pipeline, which is empty and therefore
    +                    // can be used with the pipeline wrapping spliterator
    +                    // Note that we cannot create a slice spliterator from
    +                    // the source spliterator if the pipeline is not SIZED
    +                    return Nodes.collect(this, s, true, generator);
    +                }
    +                else {
    +                    return new SliceTask<>(this, helper, spliterator, generator, skip, limit).
    +                            invoke();
    +                }
                 }
     
                 @Override
    @@ -74,6 +186,11 @@ final class SliceOps {
                         long n = skip;
                         long m = limit >= 0 ? limit : Long.MAX_VALUE;
     
    +                    @Override
    +                    public void begin(long size) {
    +                        downstream.begin(calcSize(size, skip, m));
    +                    }
    +
                         @Override
                         public void accept(T t) {
                             if (n == 0) {
    @@ -112,11 +229,64 @@ final class SliceOps {
     
             return new IntPipeline.StatefulOp(upstream, StreamShape.INT_VALUE,
                                                        flags(limit)) {
    +            Spliterator.OfInt unorderedSkipLimitSpliterator(
    +                    Spliterator.OfInt s, long skip, long limit, long sizeIfKnown) {
    +                if (skip <= sizeIfKnown) {
    +                    // Use just the limit if the number of elements
    +                    // to skip is <= the known pipeline size
    +                    limit = limit >= 0 ? Math.min(limit, sizeIfKnown - skip) : sizeIfKnown - skip;
    +                    skip = 0;
    +                }
    +                return new StreamSpliterators.UnorderedSliceSpliterator.OfInt(s, skip, limit);
    +            }
    +
    +            @Override
    +             Spliterator opEvaluateParallelLazy(PipelineHelper helper,
    +                                                               Spliterator spliterator) {
    +                long size = helper.exactOutputSizeIfKnown(spliterator);
    +                if (size > 0 && spliterator.hasCharacteristics(Spliterator.SUBSIZED)) {
    +                    return new StreamSpliterators.SliceSpliterator.OfInt(
    +                            (Spliterator.OfInt) helper.wrapSpliterator(spliterator),
    +                            skip,
    +                            calcSliceFence(skip, limit));
    +                } else if (!StreamOpFlag.ORDERED.isKnown(helper.getStreamAndOpFlags())) {
    +                    return unorderedSkipLimitSpliterator(
    +                            (Spliterator.OfInt) helper.wrapSpliterator(spliterator),
    +                            skip, limit, size);
    +                }
    +                else {
    +                    return new SliceTask<>(this, helper, spliterator, Integer[]::new, skip, limit).
    +                            invoke().spliterator();
    +                }
    +            }
    +
                 @Override
                  Node opEvaluateParallel(PipelineHelper helper,
                                                         Spliterator spliterator,
                                                         IntFunction generator) {
    -                return new SliceTask<>(this, helper, spliterator, generator, skip, limit).invoke();
    +                long size = helper.exactOutputSizeIfKnown(spliterator);
    +                if (size > 0 && spliterator.hasCharacteristics(Spliterator.SUBSIZED)) {
    +                    // Because the pipeline is SIZED the slice spliterator
    +                    // can be created from the source, this requires matching
    +                    // to shape of the source, and is potentially more efficient
    +                    // than creating the slice spliterator from the pipeline
    +                    // wrapping spliterator
    +                    Spliterator s = sliceSpliterator(helper.getSourceShape(), spliterator, skip, limit);
    +                    return Nodes.collectInt(helper, s, true);
    +                } else if (!StreamOpFlag.ORDERED.isKnown(helper.getStreamAndOpFlags())) {
    +                    Spliterator.OfInt s =  unorderedSkipLimitSpliterator(
    +                            (Spliterator.OfInt) helper.wrapSpliterator(spliterator),
    +                            skip, limit, size);
    +                    // Collect using this pipeline, which is empty and therefore
    +                    // can be used with the pipeline wrapping spliterator
    +                    // Note that we cannot create a slice spliterator from
    +                    // the source spliterator if the pipeline is not SIZED
    +                    return Nodes.collectInt(this, s, true);
    +                }
    +                else {
    +                    return new SliceTask<>(this, helper, spliterator, generator, skip, limit).
    +                            invoke();
    +                }
                 }
     
                 @Override
    @@ -125,6 +295,11 @@ final class SliceOps {
                         long n = skip;
                         long m = limit >= 0 ? limit : Long.MAX_VALUE;
     
    +                    @Override
    +                    public void begin(long size) {
    +                        downstream.begin(calcSize(size, skip, m));
    +                    }
    +
                         @Override
                         public void accept(int t) {
                             if (n == 0) {
    @@ -163,11 +338,64 @@ final class SliceOps {
     
             return new LongPipeline.StatefulOp(upstream, StreamShape.LONG_VALUE,
                                                      flags(limit)) {
    +            Spliterator.OfLong unorderedSkipLimitSpliterator(
    +                    Spliterator.OfLong s, long skip, long limit, long sizeIfKnown) {
    +                if (skip <= sizeIfKnown) {
    +                    // Use just the limit if the number of elements
    +                    // to skip is <= the known pipeline size
    +                    limit = limit >= 0 ? Math.min(limit, sizeIfKnown - skip) : sizeIfKnown - skip;
    +                    skip = 0;
    +                }
    +                return new StreamSpliterators.UnorderedSliceSpliterator.OfLong(s, skip, limit);
    +            }
    +
    +            @Override
    +             Spliterator opEvaluateParallelLazy(PipelineHelper helper,
    +                                                            Spliterator spliterator) {
    +                long size = helper.exactOutputSizeIfKnown(spliterator);
    +                if (size > 0 && spliterator.hasCharacteristics(Spliterator.SUBSIZED)) {
    +                    return new StreamSpliterators.SliceSpliterator.OfLong(
    +                            (Spliterator.OfLong) helper.wrapSpliterator(spliterator),
    +                            skip,
    +                            calcSliceFence(skip, limit));
    +                } else if (!StreamOpFlag.ORDERED.isKnown(helper.getStreamAndOpFlags())) {
    +                    return unorderedSkipLimitSpliterator(
    +                            (Spliterator.OfLong) helper.wrapSpliterator(spliterator),
    +                            skip, limit, size);
    +                }
    +                else {
    +                    return new SliceTask<>(this, helper, spliterator, Long[]::new, skip, limit).
    +                            invoke().spliterator();
    +                }
    +            }
    +
                 @Override
                  Node opEvaluateParallel(PipelineHelper helper,
                                                      Spliterator spliterator,
                                                      IntFunction generator) {
    -                return new SliceTask<>(this, helper, spliterator, generator, skip, limit).invoke();
    +                long size = helper.exactOutputSizeIfKnown(spliterator);
    +                if (size > 0 && spliterator.hasCharacteristics(Spliterator.SUBSIZED)) {
    +                    // Because the pipeline is SIZED the slice spliterator
    +                    // can be created from the source, this requires matching
    +                    // to shape of the source, and is potentially more efficient
    +                    // than creating the slice spliterator from the pipeline
    +                    // wrapping spliterator
    +                    Spliterator s = sliceSpliterator(helper.getSourceShape(), spliterator, skip, limit);
    +                    return Nodes.collectLong(helper, s, true);
    +                } else if (!StreamOpFlag.ORDERED.isKnown(helper.getStreamAndOpFlags())) {
    +                    Spliterator.OfLong s =  unorderedSkipLimitSpliterator(
    +                            (Spliterator.OfLong) helper.wrapSpliterator(spliterator),
    +                            skip, limit, size);
    +                    // Collect using this pipeline, which is empty and therefore
    +                    // can be used with the pipeline wrapping spliterator
    +                    // Note that we cannot create a slice spliterator from
    +                    // the source spliterator if the pipeline is not SIZED
    +                    return Nodes.collectLong(this, s, true);
    +                }
    +                else {
    +                    return new SliceTask<>(this, helper, spliterator, generator, skip, limit).
    +                            invoke();
    +                }
                 }
     
                 @Override
    @@ -176,6 +404,11 @@ final class SliceOps {
                         long n = skip;
                         long m = limit >= 0 ? limit : Long.MAX_VALUE;
     
    +                    @Override
    +                    public void begin(long size) {
    +                        downstream.begin(calcSize(size, skip, m));
    +                    }
    +
                         @Override
                         public void accept(long t) {
                             if (n == 0) {
    @@ -214,11 +447,64 @@ final class SliceOps {
     
             return new DoublePipeline.StatefulOp(upstream, StreamShape.DOUBLE_VALUE,
                                                          flags(limit)) {
    +            Spliterator.OfDouble unorderedSkipLimitSpliterator(
    +                    Spliterator.OfDouble s, long skip, long limit, long sizeIfKnown) {
    +                if (skip <= sizeIfKnown) {
    +                    // Use just the limit if the number of elements
    +                    // to skip is <= the known pipeline size
    +                    limit = limit >= 0 ? Math.min(limit, sizeIfKnown - skip) : sizeIfKnown - skip;
    +                    skip = 0;
    +                }
    +                return new StreamSpliterators.UnorderedSliceSpliterator.OfDouble(s, skip, limit);
    +            }
    +
    +            @Override
    +             Spliterator opEvaluateParallelLazy(PipelineHelper helper,
    +                                                              Spliterator spliterator) {
    +                long size = helper.exactOutputSizeIfKnown(spliterator);
    +                if (size > 0 && spliterator.hasCharacteristics(Spliterator.SUBSIZED)) {
    +                    return new StreamSpliterators.SliceSpliterator.OfDouble(
    +                            (Spliterator.OfDouble) helper.wrapSpliterator(spliterator),
    +                            skip,
    +                            calcSliceFence(skip, limit));
    +                } else if (!StreamOpFlag.ORDERED.isKnown(helper.getStreamAndOpFlags())) {
    +                    return unorderedSkipLimitSpliterator(
    +                            (Spliterator.OfDouble) helper.wrapSpliterator(spliterator),
    +                            skip, limit, size);
    +                }
    +                else {
    +                    return new SliceTask<>(this, helper, spliterator, Double[]::new, skip, limit).
    +                            invoke().spliterator();
    +                }
    +            }
    +
                 @Override
                  Node opEvaluateParallel(PipelineHelper helper,
                                                        Spliterator spliterator,
                                                        IntFunction generator) {
    -                return new SliceTask<>(this, helper, spliterator, generator, skip, limit).invoke();
    +                long size = helper.exactOutputSizeIfKnown(spliterator);
    +                if (size > 0 && spliterator.hasCharacteristics(Spliterator.SUBSIZED)) {
    +                    // Because the pipeline is SIZED the slice spliterator
    +                    // can be created from the source, this requires matching
    +                    // to shape of the source, and is potentially more efficient
    +                    // than creating the slice spliterator from the pipeline
    +                    // wrapping spliterator
    +                    Spliterator s = sliceSpliterator(helper.getSourceShape(), spliterator, skip, limit);
    +                    return Nodes.collectDouble(helper, s, true);
    +                } else if (!StreamOpFlag.ORDERED.isKnown(helper.getStreamAndOpFlags())) {
    +                    Spliterator.OfDouble s =  unorderedSkipLimitSpliterator(
    +                            (Spliterator.OfDouble) helper.wrapSpliterator(spliterator),
    +                            skip, limit, size);
    +                    // Collect using this pipeline, which is empty and therefore
    +                    // can be used with the pipeline wrapping spliterator
    +                    // Note that we cannot create a slice spliterator from
    +                    // the source spliterator if the pipeline is not SIZED
    +                    return Nodes.collectDouble(this, s, true);
    +                }
    +                else {
    +                    return new SliceTask<>(this, helper, spliterator, generator, skip, limit).
    +                            invoke();
    +                }
                 }
     
                 @Override
    @@ -227,6 +513,11 @@ final class SliceOps {
                         long n = skip;
                         long m = limit >= 0 ? limit : Long.MAX_VALUE;
     
    +                    @Override
    +                    public void begin(long size) {
    +                        downstream.begin(calcSize(size, skip, m));
    +                    }
    +
                         @Override
                         public void accept(double t) {
                             if (n == 0) {
    @@ -253,20 +544,6 @@ final class SliceOps {
             return StreamOpFlag.NOT_SIZED | ((limit != -1) ? StreamOpFlag.IS_SHORT_CIRCUIT : 0);
         }
     
    -    // Parallel strategy -- two cases
    -    // IF we have full size information
    -    // - decompose, keeping track of each leaf's (offset, size)
    -    // - calculate leaf only if intersection between (offset, size) and desired slice
    -    // - Construct a Node containing the appropriate sections of the appropriate leaves
    -    // IF we don't
    -    // - decompose, and calculate size of each leaf
    -    // - on complete of any node, compute completed initial size from the root, and if big enough, cancel later nodes
    -    // - @@@ this can be significantly improved
    -
    -    // @@@ Currently we don't do the sized version at all
    -
    -    // @@@ Should take into account ORDERED flag; if not ORDERED, we can limit in temporal order instead
    -
         /**
          * {@code ForkJoinTask} implementing slice computation.
          *
    @@ -319,19 +596,18 @@ final class SliceOps {
                                        ? op.exactOutputSizeIfKnown(spliterator)
                                        : -1;
                     final Node.Builder nb = op.makeNodeBuilder(sizeIfKnown, generator);
    -                Sink opSink = op.opWrapSink(op.sourceOrOpFlags, nb);
    -
    -                if (!StreamOpFlag.SHORT_CIRCUIT.isKnown(op.sourceOrOpFlags))
    -                    helper.wrapAndCopyInto(opSink, spliterator);
    -                else
    -                    helper.copyIntoWithCancel(helper.wrapSink(opSink), spliterator);
    -                return nb.build();
    +                Sink opSink = op.opWrapSink(helper.getStreamAndOpFlags(), nb);
    +                helper.copyIntoWithCancel(helper.wrapSink(opSink), spliterator);
    +                // It is necessary to truncate here since the result at the root
    +                // can only be set once
    +                return doTruncate(nb.build());
                 }
                 else {
                     Node node = helper.wrapAndCopyInto(helper.makeNodeBuilder(-1, generator),
    -                                                      spliterator).build();
    +                                                          spliterator).build();
                     thisNodeSize = node.count();
                     completed = true;
    +                spliterator = null;
                     return node;
                 }
             }
    @@ -339,198 +615,95 @@ final class SliceOps {
             @Override
             public final void onCompletion(CountedCompleter caller) {
                 if (!isLeaf()) {
    +                Node result;
                     thisNodeSize = leftChild.thisNodeSize + rightChild.thisNodeSize;
    -                completed = true;
    -
    -                if (isRoot()) {
    -                    // Only collect nodes once absolute size information is known
    -
    -                    ArrayList> nodes = new ArrayList<>();
    -                    visit(nodes, 0);
    -                    Node result;
    -                    if (nodes.size() == 0)
    -                        result = Nodes.emptyNode(op.getOutputShape());
    -                    else if (nodes.size() == 1)
    -                        result = nodes.get(0);
    -                    else
    -                        // This will create a tree of depth 1 and will not be a sub-tree
    -                        // for leaf nodes within the require range
    -                        result = conc(op.getOutputShape(), nodes);
    -                    setLocalResult(result);
    +                if (canceled) {
    +                    thisNodeSize = 0;
    +                    result = getEmptyResult();
                     }
    +                else if (thisNodeSize == 0)
    +                    result = getEmptyResult();
    +                else if (leftChild.thisNodeSize == 0)
    +                    result = rightChild.getLocalResult();
    +                else {
    +                    result = Nodes.conc(op.getOutputShape(),
    +                                        leftChild.getLocalResult(), rightChild.getLocalResult());
    +                }
    +                setLocalResult(isRoot() ? doTruncate(result) : result);
    +                completed = true;
                 }
    -            if (targetSize >= 0) {
    -                if (((SliceTask) getRoot()).leftSize() >= targetOffset + targetSize)
    +            if (targetSize >= 0
    +                && !isRoot()
    +                && isLeftCompleted(targetOffset + targetSize))
                         cancelLaterNodes();
    -            }
    -            // Don't call super.onCompletion(), we don't look at the child nodes until farther up the tree
    +
    +            super.onCompletion(caller);
             }
     
    -        /** Compute the cumulative size of the longest leading prefix of completed children */
    -        private long leftSize() {
    +        @Override
    +        protected void cancel() {
    +            super.cancel();
    +            if (completed)
    +                setLocalResult(getEmptyResult());
    +        }
    +
    +        private Node doTruncate(Node input) {
    +            long to = targetSize >= 0 ? Math.min(input.count(), targetOffset + targetSize) : thisNodeSize;
    +            return input.truncate(targetOffset, to, generator);
    +        }
    +
    +        /**
    +         * Determine if the number of completed elements in this node and nodes
    +         * to the left of this node is greater than or equal to the target size.
    +         *
    +         * @param target the target size
    +         * @return true if the number of elements is greater than or equal to
    +         *         the target size, otherwise false.
    +         */
    +        private boolean isLeftCompleted(long target) {
    +            long size = completed ? thisNodeSize : completedSize(target);
    +            if (size >= target)
    +                return true;
    +            for (SliceTask parent = getParent(), node = this;
    +                 parent != null;
    +                 node = parent, parent = parent.getParent()) {
    +                if (node == parent.rightChild) {
    +                    SliceTask left = parent.leftChild;
    +                    if (left != null) {
    +                        size += left.completedSize(target);
    +                        if (size >= target)
    +                            return true;
    +                    }
    +                }
    +            }
    +            return size >= target;
    +        }
    +
    +        /**
    +         * Compute the number of completed elements in this node.
    +         * 

    + * Computation terminates if all nodes have been processed or the + * number of completed elements is greater than or equal to the target + * size. + * + * @param target the target size + * @return return the number of completed elements + */ + private long completedSize(long target) { if (completed) return thisNodeSize; - else if (isLeaf()) - return 0; else { - long leftSize = 0; - for (SliceTask child = leftChild, p = null; child != p; - p = child, child = rightChild) { - if (child.completed) - leftSize += child.thisNodeSize; - else { - leftSize += child.leftSize(); - break; - } - } - return leftSize; - } - } - - private void visit(List> results, int offset) { - if (!isLeaf()) { - for (SliceTask child = leftChild, p = null; child != p; - p = child, child = rightChild) { - child.visit(results, offset); - offset += child.thisNodeSize; - } - } - else { - if (results.size() == 0) { - if (offset + thisNodeSize >= targetOffset) - results.add(truncateNode(getLocalResult(), - Math.max(0, targetOffset - offset), - targetSize >= 0 ? Math.max(0, offset + thisNodeSize - (targetOffset + targetSize)) : 0)); + SliceTask left = leftChild; + SliceTask right = rightChild; + if (left == null || right == null) { + // must be completed + return thisNodeSize; } else { - if (targetSize == -1 || offset < targetOffset + targetSize) { - results.add(truncateNode(getLocalResult(), - 0, - targetSize >= 0 ? Math.max(0, offset + thisNodeSize - (targetOffset + targetSize)) : 0)); - } + long leftSize = left.completedSize(target); + return (leftSize >= target) ? leftSize : leftSize + right.completedSize(target); } } } - - /** - * Return a new node describing the result of truncating an existing Node - * at the left and/or right. - */ - private Node truncateNode(Node input, - long skipLeft, long skipRight) { - if (skipLeft == 0 && skipRight == 0) - return input; - else { - return truncateNode(input, skipLeft, thisNodeSize - skipRight, generator); - } - } - /** - * Truncate a {@link Node}, returning a node describing a subsequence of - * the contents of the input node. - * - * @param the type of elements of the input node and truncated node - * @param input the input node - * @param from the starting offset to include in the truncated node (inclusive) - * @param to the ending offset ot include in the truncated node (exclusive) - * @param generator the array factory (only used for reference nodes) - * @return the truncated node - */ - @SuppressWarnings("unchecked") - private static Node truncateNode(Node input, long from, long to, IntFunction generator) { - StreamShape shape = input.getShape(); - long size = truncatedSize(input.count(), from, to); - if (size == 0) - return Nodes.emptyNode(shape); - else if (from == 0 && to >= input.count()) - return input; - - switch (shape) { - case REFERENCE: { - Spliterator spliterator = input.spliterator(); - Node.Builder nodeBuilder = Nodes.builder(size, generator); - nodeBuilder.begin(size); - for (int i = 0; i < from && spliterator.tryAdvance(e -> { }); i++) { } - for (int i = 0; (i < size) && spliterator.tryAdvance(nodeBuilder); i++) { } - nodeBuilder.end(); - return nodeBuilder.build(); - } - case INT_VALUE: { - Spliterator.OfInt spliterator = ((Node.OfInt) input).spliterator(); - Node.Builder.OfInt nodeBuilder = Nodes.intBuilder(size); - nodeBuilder.begin(size); - for (int i = 0; i < from && spliterator.tryAdvance((IntConsumer) e -> { }); i++) { } - for (int i = 0; (i < size) && spliterator.tryAdvance((IntConsumer) nodeBuilder); i++) { } - nodeBuilder.end(); - return (Node) nodeBuilder.build(); - } - case LONG_VALUE: { - Spliterator.OfLong spliterator = ((Node.OfLong) input).spliterator(); - Node.Builder.OfLong nodeBuilder = Nodes.longBuilder(size); - nodeBuilder.begin(size); - for (int i = 0; i < from && spliterator.tryAdvance((LongConsumer) e -> { }); i++) { } - for (int i = 0; (i < size) && spliterator.tryAdvance((LongConsumer) nodeBuilder); i++) { } - nodeBuilder.end(); - return (Node) nodeBuilder.build(); - } - case DOUBLE_VALUE: { - Spliterator.OfDouble spliterator = ((Node.OfDouble) input).spliterator(); - Node.Builder.OfDouble nodeBuilder = Nodes.doubleBuilder(size); - nodeBuilder.begin(size); - for (int i = 0; i < from && spliterator.tryAdvance((DoubleConsumer) e -> { }); i++) { } - for (int i = 0; (i < size) && spliterator.tryAdvance((DoubleConsumer) nodeBuilder); i++) { } - nodeBuilder.end(); - return (Node) nodeBuilder.build(); - } - default: - throw new IllegalStateException("Unknown shape " + shape); - } - } - - private static long truncatedSize(long size, long from, long to) { - if (from >= 0) - size = Math.max(0, size - from); - long limit = to - from; - if (limit >= 0) - size = Math.min(size, limit); - return size; - } - - /** - * Produces a concatenated {@link Node} that has two or more children. - *

    The count of the concatenated node is equal to the sum of the count - * of each child. Traversal of the concatenated node traverses the content - * of each child in encounter order of the list of children. Splitting a - * spliterator obtained from the concatenated node preserves the encounter - * order of the list of children. - * - *

    The result may be a concatenated node, the input sole node if the size - * of the list is 1, or an empty node. - * - * @param the type of elements of the concatenated node - * @param shape the shape of the concatenated node to be created - * @param nodes the input nodes - * @return a {@code Node} covering the elements of the input nodes - * @throws IllegalStateException if all {@link Node} elements of the list - * are an not instance of type supported by this factory. - */ - @SuppressWarnings("unchecked") - private static Node conc(StreamShape shape, List> nodes) { - int size = nodes.size(); - if (size == 0) - return Nodes.emptyNode(shape); - else if (size == 1) - return nodes.get(0); - else { - // Create a right-balanced tree when there are more that 2 nodes - List> refNodes = (List>) nodes; - Node c = Nodes.conc(shape, refNodes.get(size - 2), refNodes.get(size - 1)); - for (int i = size - 3; i >= 0; i--) { - c = Nodes.conc(shape, refNodes.get(i), c); - } - return c; - } - } - } - } diff --git a/jdk/src/share/classes/java/util/stream/Stream.java b/jdk/src/share/classes/java/util/stream/Stream.java index f06a01b7aea..32b3585fdbf 100644 --- a/jdk/src/share/classes/java/util/stream/Stream.java +++ b/jdk/src/share/classes/java/util/stream/Stream.java @@ -880,14 +880,7 @@ public interface Stream extends BaseStream> { */ public static Stream generate(Supplier s) { Objects.requireNonNull(s); - return StreamSupport.stream(Spliterators.spliteratorUnknownSize( - new Iterator() { - @Override - public boolean hasNext() { return true; } - - @Override - public T next() { return s.get(); } - }, - Spliterator.ORDERED | Spliterator.IMMUTABLE)); + return StreamSupport.stream( + new StreamSpliterators.InfiniteSupplyingSpliterator.OfRef<>(Long.MAX_VALUE, s)); } } diff --git a/jdk/src/share/classes/java/util/stream/StreamSpliterators.java b/jdk/src/share/classes/java/util/stream/StreamSpliterators.java index ff669dbaa18..d0dc61ed1e0 100644 --- a/jdk/src/share/classes/java/util/stream/StreamSpliterators.java +++ b/jdk/src/share/classes/java/util/stream/StreamSpliterators.java @@ -26,11 +26,15 @@ package java.util.stream; import java.util.Comparator; import java.util.Spliterator; +import java.util.concurrent.atomic.AtomicLong; import java.util.function.BooleanSupplier; import java.util.function.Consumer; import java.util.function.DoubleConsumer; +import java.util.function.DoubleSupplier; import java.util.function.IntConsumer; +import java.util.function.IntSupplier; import java.util.function.LongConsumer; +import java.util.function.LongSupplier; import java.util.function.Supplier; /** @@ -212,9 +216,10 @@ class StreamSpliterators { @Override public final long estimateSize() { init(); - return StreamOpFlag.SIZED.isKnown(ph.getStreamAndOpFlags()) - ? spliterator.estimateSize() - : Long.MAX_VALUE; + // Use the estimate of the wrapped spliterator + // Note this may not be accurate if there are filter/flatMap + // operations filtering or adding elements to the stream + return spliterator.estimateSize(); } @Override @@ -240,7 +245,7 @@ class StreamSpliterators { // but for sub-splits only an estimate is known if ((c & Spliterator.SIZED) != 0) { c &= ~(Spliterator.SIZED | Spliterator.SUBSIZED); - c |= (spliterator.characteristics() & Spliterator.SIZED & Spliterator.SUBSIZED); + c |= (spliterator.characteristics() & (Spliterator.SIZED | Spliterator.SUBSIZED)); } return c; @@ -304,7 +309,7 @@ class StreamSpliterators { finished = true; } else { - while (tryAdvance(consumer)) { } + do { } while (tryAdvance(consumer)); } } } @@ -360,7 +365,7 @@ class StreamSpliterators { finished = true; } else { - while (tryAdvance(consumer)) { } + do { } while (tryAdvance(consumer)); } } } @@ -416,7 +421,7 @@ class StreamSpliterators { finished = true; } else { - while (tryAdvance(consumer)) { } + do { } while (tryAdvance(consumer)); } } } @@ -472,7 +477,7 @@ class StreamSpliterators { finished = true; } else { - while (tryAdvance(consumer)) { } + do { } while (tryAdvance(consumer)); } } } @@ -483,17 +488,17 @@ class StreamSpliterators { * first call to any spliterator method. * @param */ - static class DelegatingSpliterator implements Spliterator { - private final Supplier> supplier; + static class DelegatingSpliterator> + implements Spliterator { + private final Supplier supplier; - private Spliterator s; + private T_SPLITR s; - @SuppressWarnings("unchecked") - DelegatingSpliterator(Supplier> supplier) { - this.supplier = (Supplier>) supplier; + DelegatingSpliterator(Supplier supplier) { + this.supplier = supplier; } - Spliterator get() { + T_SPLITR get() { if (s == null) { s = supplier.get(); } @@ -501,8 +506,8 @@ class StreamSpliterators { } @Override - public Spliterator trySplit() { - return get().trySplit(); + public T_SPLITR trySplit() { + return (T_SPLITR) get().trySplit(); } @Override @@ -540,97 +545,881 @@ class StreamSpliterators { return getClass().getName() + "[" + get() + "]"; } - static final class OfInt extends DelegatingSpliterator implements Spliterator.OfInt { - private Spliterator.OfInt s; + static class OfPrimitive> + extends DelegatingSpliterator + implements Spliterator.OfPrimitive { + OfPrimitive(Supplier supplier) { + super(supplier); + } + + @Override + public boolean tryAdvance(T_CONS consumer) { + return get().tryAdvance(consumer); + } + + @Override + public void forEachRemaining(T_CONS consumer) { + get().forEachRemaining(consumer); + } + } + + static final class OfInt + extends OfPrimitive + implements Spliterator.OfInt { OfInt(Supplier supplier) { super(supplier); } - - @Override - Spliterator.OfInt get() { - if (s == null) { - s = (Spliterator.OfInt) super.get(); - } - return s; - } - - @Override - public Spliterator.OfInt trySplit() { - return get().trySplit(); - } - - @Override - public boolean tryAdvance(IntConsumer consumer) { - return get().tryAdvance(consumer); - } - - @Override - public void forEachRemaining(IntConsumer consumer) { - get().forEachRemaining(consumer); - } } - static final class OfLong extends DelegatingSpliterator implements Spliterator.OfLong { - private Spliterator.OfLong s; + static final class OfLong + extends OfPrimitive + implements Spliterator.OfLong { OfLong(Supplier supplier) { super(supplier); } - - @Override - Spliterator.OfLong get() { - if (s == null) { - s = (Spliterator.OfLong) super.get(); - } - return s; - } - - @Override - public Spliterator.OfLong trySplit() { - return get().trySplit(); - } - - @Override - public boolean tryAdvance(LongConsumer consumer) { - return get().tryAdvance(consumer); - } - - @Override - public void forEachRemaining(LongConsumer consumer) { - get().forEachRemaining(consumer); - } } - static final class OfDouble extends DelegatingSpliterator implements Spliterator.OfDouble { - private Spliterator.OfDouble s; + static final class OfDouble + extends OfPrimitive + implements Spliterator.OfDouble { OfDouble(Supplier supplier) { super(supplier); } + } + } + + /** + * A slice Spliterator from a source Spliterator that reports + * {@code SUBSIZED}. + * + */ + static abstract class SliceSpliterator> { + // The start index of the slice + final long sliceOrigin; + // One past the last index of the slice + final long sliceFence; + + // The spliterator to slice + T_SPLITR s; + // current (absolute) index, modified on advance/split + long index; + // one past last (absolute) index or sliceFence, which ever is smaller + long fence; + + SliceSpliterator(T_SPLITR s, long sliceOrigin, long sliceFence, long origin, long fence) { + assert s.hasCharacteristics(Spliterator.SUBSIZED); + this.s = s; + this.sliceOrigin = sliceOrigin; + this.sliceFence = sliceFence; + this.index = origin; + this.fence = fence; + } + + protected abstract T_SPLITR makeSpliterator(T_SPLITR s, long sliceOrigin, long sliceFence, long origin, long fence); + + public T_SPLITR trySplit() { + if (sliceOrigin >= fence) + return null; + + if (index >= fence) + return null; + + // Keep splitting until the left and right splits intersect with the slice + // thereby ensuring the size estimate decreases. + // This also avoids creating empty spliterators which can result in + // existing and additionally created F/J tasks that perform + // redundant work on no elements. + while (true) { + T_SPLITR leftSplit = (T_SPLITR) s.trySplit(); + if (leftSplit == null) + return null; + + long leftSplitFenceUnbounded = index + leftSplit.estimateSize(); + long leftSplitFence = Math.min(leftSplitFenceUnbounded, sliceFence); + if (sliceOrigin >= leftSplitFence) { + // The left split does not intersect with, and is to the left of, the slice + // The right split does intersect + // Discard the left split and split further with the right split + index = leftSplitFence; + } + else if (leftSplitFence >= sliceFence) { + // The right split does not intersect with, and is to the right of, the slice + // The left split does intersect + // Discard the right split and split further with the left split + s = leftSplit; + fence = leftSplitFence; + } + else if (index >= sliceOrigin && leftSplitFenceUnbounded <= sliceFence) { + // The left split is contained within the slice, return the underlying left split + // Right split is contained within or intersects with the slice + index = leftSplitFence; + return leftSplit; + } else { + // The left split intersects with the slice + // Right split is contained within or intersects with the slice + return makeSpliterator(leftSplit, sliceOrigin, sliceFence, index, index = leftSplitFence); + } + } + } + + public long estimateSize() { + return (sliceOrigin < fence) + ? fence - Math.max(sliceOrigin, index) : 0; + } + + public int characteristics() { + return s.characteristics(); + } + + static final class OfRef + extends SliceSpliterator> + implements Spliterator { + + OfRef(Spliterator s, long sliceOrigin, long sliceFence) { + this(s, sliceOrigin, sliceFence, 0, Math.min(s.estimateSize(), sliceFence)); + } + + private OfRef(Spliterator s, + long sliceOrigin, long sliceFence, long origin, long fence) { + super(s, sliceOrigin, sliceFence, origin, fence); + } @Override - Spliterator.OfDouble get() { - if (s == null) { - s = (Spliterator.OfDouble) super.get(); + protected Spliterator makeSpliterator(Spliterator s, + long sliceOrigin, long sliceFence, + long origin, long fence) { + return new OfRef<>(s, sliceOrigin, sliceFence, origin, fence); + } + + @Override + public boolean tryAdvance(Consumer action) { + if (sliceOrigin >= fence) + return false; + + while (sliceOrigin > index) { + s.tryAdvance(e -> {}); + index++; } - return s; + + if (index >= fence) + return false; + + index++; + return s.tryAdvance(action); + } + + @Override + public void forEachRemaining(Consumer action) { + if (sliceOrigin >= fence) + return; + + if (index >= fence) + return; + + if (index >= sliceOrigin && (index + s.estimateSize()) <= sliceFence) { + // The spliterator is contained within the slice + s.forEachRemaining(action); + index = fence; + } else { + // The spliterator intersects with the slice + while (sliceOrigin > index) { + s.tryAdvance(e -> {}); + index++; + } + // Traverse elements up to the fence + for (;index < fence; index++) { + s.tryAdvance(action); + } + } + } + } + + static abstract class OfPrimitive, + T_CONS> + extends SliceSpliterator + implements Spliterator.OfPrimitive { + + OfPrimitive(T_SPLITR s, long sliceOrigin, long sliceFence) { + this(s, sliceOrigin, sliceFence, 0, Math.min(s.estimateSize(), sliceFence)); + } + + private OfPrimitive(T_SPLITR s, + long sliceOrigin, long sliceFence, long origin, long fence) { + super(s, sliceOrigin, sliceFence, origin, fence); + } + + @Override + public boolean tryAdvance(T_CONS action) { + if (sliceOrigin >= fence) + return false; + + while (sliceOrigin > index) { + s.tryAdvance(emptyConsumer()); + index++; + } + + if (index >= fence) + return false; + + index++; + return s.tryAdvance(action); + } + + @Override + public void forEachRemaining(T_CONS action) { + if (sliceOrigin >= fence) + return; + + if (index >= fence) + return; + + if (index >= sliceOrigin && (index + s.estimateSize()) <= sliceFence) { + // The spliterator is contained within the slice + s.forEachRemaining(action); + index = fence; + } else { + // The spliterator intersects with the slice + while (sliceOrigin > index) { + s.tryAdvance(emptyConsumer()); + index++; + } + // Traverse elements up to the fence + for (;index < fence; index++) { + s.tryAdvance(action); + } + } + } + + protected abstract T_CONS emptyConsumer(); + } + + static final class OfInt extends OfPrimitive + implements Spliterator.OfInt { + OfInt(Spliterator.OfInt s, long sliceOrigin, long sliceFence) { + super(s, sliceOrigin, sliceFence); + } + + OfInt(Spliterator.OfInt s, + long sliceOrigin, long sliceFence, long origin, long fence) { + super(s, sliceOrigin, sliceFence, origin, fence); + } + + @Override + protected Spliterator.OfInt makeSpliterator(Spliterator.OfInt s, + long sliceOrigin, long sliceFence, + long origin, long fence) { + return new SliceSpliterator.OfInt(s, sliceOrigin, sliceFence, origin, fence); + } + + @Override + protected IntConsumer emptyConsumer() { + return e -> {}; + } + } + + static final class OfLong extends OfPrimitive + implements Spliterator.OfLong { + OfLong(Spliterator.OfLong s, long sliceOrigin, long sliceFence) { + super(s, sliceOrigin, sliceFence); + } + + OfLong(Spliterator.OfLong s, + long sliceOrigin, long sliceFence, long origin, long fence) { + super(s, sliceOrigin, sliceFence, origin, fence); + } + + @Override + protected Spliterator.OfLong makeSpliterator(Spliterator.OfLong s, + long sliceOrigin, long sliceFence, + long origin, long fence) { + return new SliceSpliterator.OfLong(s, sliceOrigin, sliceFence, origin, fence); + } + + @Override + protected LongConsumer emptyConsumer() { + return e -> {}; + } + } + + static final class OfDouble extends OfPrimitive + implements Spliterator.OfDouble { + OfDouble(Spliterator.OfDouble s, long sliceOrigin, long sliceFence) { + super(s, sliceOrigin, sliceFence); + } + + OfDouble(Spliterator.OfDouble s, + long sliceOrigin, long sliceFence, long origin, long fence) { + super(s, sliceOrigin, sliceFence, origin, fence); + } + + @Override + protected Spliterator.OfDouble makeSpliterator(Spliterator.OfDouble s, + long sliceOrigin, long sliceFence, + long origin, long fence) { + return new SliceSpliterator.OfDouble(s, sliceOrigin, sliceFence, origin, fence); + } + + @Override + protected DoubleConsumer emptyConsumer() { + return e -> {}; + } + } + } + + /** + * A slice Spliterator that does not preserve order, if any, of a source + * Spliterator. + * + * Note: The source spliterator may report {@code ORDERED} since that + * spliterator be the result of a previous pipeline stage that was + * collected to a {@code Node}. It is the order of the pipeline stage + * that governs whether the this slice spliterator is to be used or not. + */ + static abstract class UnorderedSliceSpliterator> { + static final int CHUNK_SIZE = 1 << 7; + + // The spliterator to slice + protected final T_SPLITR s; + protected final boolean unlimited; + private final long skipThreshold; + private final AtomicLong permits; + + UnorderedSliceSpliterator(T_SPLITR s, long skip, long limit) { + this.s = s; + this.unlimited = limit < 0; + this.skipThreshold = limit >= 0 ? limit : 0; + this.permits = new AtomicLong(limit >= 0 ? skip + limit : skip); + } + + UnorderedSliceSpliterator(T_SPLITR s, UnorderedSliceSpliterator parent) { + this.s = s; + this.unlimited = parent.unlimited; + this.permits = parent.permits; + this.skipThreshold = parent.skipThreshold; + } + + /** + * Acquire permission to skip or process elements. The caller must + * first acquire the elements, then consult this method for guidance + * as to what to do with the data. + * + *

    We use an {@code AtomicLong} to atomically maintain a counter, + * which is initialized as skip+limit if we are limiting, or skip only + * if we are not limiting. The user should consult the method + * {@code checkPermits()} before acquiring data elements. + * + * @param numElements the number of elements the caller has in hand + * @return the number of elements that should be processed; any + * remaining elements should be discarded. + */ + protected final long acquirePermits(long numElements) { + long remainingPermits; + long grabbing; + // permits never increase, and don't decrease below zero + assert numElements > 0; + do { + remainingPermits = permits.get(); + if (remainingPermits == 0) + return unlimited ? numElements : 0; + grabbing = Math.min(remainingPermits, numElements); + } while (grabbing > 0 && + !permits.compareAndSet(remainingPermits, remainingPermits - grabbing)); + + if (unlimited) + return Math.max(numElements - grabbing, 0); + else if (remainingPermits > skipThreshold) + return Math.max(grabbing - (remainingPermits - skipThreshold), 0); + else + return grabbing; + } + + enum PermitStatus { NO_MORE, MAYBE_MORE, UNLIMITED } + + /** Call to check if permits might be available before acquiring data */ + protected final PermitStatus permitStatus() { + if (permits.get() > 0) + return PermitStatus.MAYBE_MORE; + else + return unlimited ? PermitStatus.UNLIMITED : PermitStatus.NO_MORE; + } + + public final T_SPLITR trySplit() { + // Stop splitting when there are no more limit permits + if (permits.get() == 0) + return null; + T_SPLITR split = (T_SPLITR) s.trySplit(); + return split == null ? null : makeSpliterator(split); + } + + protected abstract T_SPLITR makeSpliterator(T_SPLITR s); + + public final long estimateSize() { + return s.estimateSize(); + } + + public final int characteristics() { + return s.characteristics() & + ~(Spliterator.SIZED | Spliterator.SUBSIZED | Spliterator.ORDERED); + } + + static final class OfRef extends UnorderedSliceSpliterator> + implements Spliterator, Consumer { + T tmpSlot; + + OfRef(Spliterator s, long skip, long limit) { + super(s, skip, limit); + } + + OfRef(Spliterator s, OfRef parent) { + super(s, parent); + } + + @Override + public final void accept(T t) { + tmpSlot = t; + } + + @Override + public boolean tryAdvance(Consumer action) { + while (permitStatus() != PermitStatus.NO_MORE) { + if (!s.tryAdvance(this)) + return false; + else if (acquirePermits(1) == 1) { + action.accept(tmpSlot); + tmpSlot = null; + return true; + } + } + return false; + } + + @Override + public void forEachRemaining(Consumer action) { + ArrayBuffer.OfRef sb = null; + PermitStatus permitStatus; + while ((permitStatus = permitStatus()) != PermitStatus.NO_MORE) { + if (permitStatus == PermitStatus.MAYBE_MORE) { + // Optimistically traverse elements up to a threshold of CHUNK_SIZE + if (sb == null) + sb = new ArrayBuffer.OfRef<>(CHUNK_SIZE); + else + sb.reset(); + long permitsRequested = 0; + do { } while (s.tryAdvance(sb) && ++permitsRequested < CHUNK_SIZE); + if (permitsRequested == 0) + return; + sb.forEach(action, acquirePermits(permitsRequested)); + } + else { + // Must be UNLIMITED; let 'er rip + s.forEachRemaining(action); + return; + } + } + } + + @Override + protected Spliterator makeSpliterator(Spliterator s) { + return new UnorderedSliceSpliterator.OfRef<>(s, this); + } + } + + /** + * Concrete sub-types must also be an instance of type {@code T_CONS}. + * + * @param the type of the spined buffer. Must also be a type of + * {@code T_CONS}. + */ + static abstract class OfPrimitive< + T, + T_CONS, + T_BUFF extends ArrayBuffer.OfPrimitive, + T_SPLITR extends Spliterator.OfPrimitive> + extends UnorderedSliceSpliterator + implements Spliterator.OfPrimitive { + OfPrimitive(T_SPLITR s, long skip, long limit) { + super(s, skip, limit); + } + + OfPrimitive(T_SPLITR s, UnorderedSliceSpliterator.OfPrimitive parent) { + super(s, parent); + } + + @Override + public boolean tryAdvance(T_CONS action) { + while (permitStatus() != PermitStatus.NO_MORE) { + if (!s.tryAdvance((T_CONS) this)) + return false; + else if (acquirePermits(1) == 1) { + acceptConsumed(action); + return true; + } + } + return false; + } + + protected abstract void acceptConsumed(T_CONS action); + + @Override + public void forEachRemaining(T_CONS action) { + T_BUFF sb = null; + PermitStatus permitStatus; + while ((permitStatus = permitStatus()) != PermitStatus.NO_MORE) { + if (permitStatus == PermitStatus.MAYBE_MORE) { + // Optimistically traverse elements up to a threshold of CHUNK_SIZE + if (sb == null) + sb = bufferCreate(CHUNK_SIZE); + else + sb.reset(); + @SuppressWarnings("unchecked") + T_CONS sbc = (T_CONS) sb; + long permitsRequested = 0; + do { } while (s.tryAdvance(sbc) && ++permitsRequested < CHUNK_SIZE); + if (permitsRequested == 0) + return; + sb.forEach(action, acquirePermits(permitsRequested)); + } + else { + // Must be UNLIMITED; let 'er rip + s.forEachRemaining(action); + return; + } + } + } + + protected abstract T_BUFF bufferCreate(int initialCapacity); + } + + static final class OfInt + extends OfPrimitive + implements Spliterator.OfInt, IntConsumer { + + int tmpValue; + + OfInt(Spliterator.OfInt s, long skip, long limit) { + super(s, skip, limit); + } + + OfInt(Spliterator.OfInt s, UnorderedSliceSpliterator.OfInt parent) { + super(s, parent); + } + + @Override + public void accept(int value) { + tmpValue = value; + } + + @Override + protected void acceptConsumed(IntConsumer action) { + action.accept(tmpValue); + } + + @Override + protected ArrayBuffer.OfInt bufferCreate(int initialCapacity) { + return new ArrayBuffer.OfInt(initialCapacity); + } + + @Override + protected Spliterator.OfInt makeSpliterator(Spliterator.OfInt s) { + return new UnorderedSliceSpliterator.OfInt(s, this); + } + } + + static final class OfLong + extends OfPrimitive + implements Spliterator.OfLong, LongConsumer { + + long tmpValue; + + OfLong(Spliterator.OfLong s, long skip, long limit) { + super(s, skip, limit); + } + + OfLong(Spliterator.OfLong s, UnorderedSliceSpliterator.OfLong parent) { + super(s, parent); + } + + @Override + public void accept(long value) { + tmpValue = value; + } + + @Override + protected void acceptConsumed(LongConsumer action) { + action.accept(tmpValue); + } + + @Override + protected ArrayBuffer.OfLong bufferCreate(int initialCapacity) { + return new ArrayBuffer.OfLong(initialCapacity); + } + + @Override + protected Spliterator.OfLong makeSpliterator(Spliterator.OfLong s) { + return new UnorderedSliceSpliterator.OfLong(s, this); + } + } + + static final class OfDouble + extends OfPrimitive + implements Spliterator.OfDouble, DoubleConsumer { + + double tmpValue; + + OfDouble(Spliterator.OfDouble s, long skip, long limit) { + super(s, skip, limit); + } + + OfDouble(Spliterator.OfDouble s, UnorderedSliceSpliterator.OfDouble parent) { + super(s, parent); + } + + @Override + public void accept(double value) { + tmpValue = value; + } + + @Override + protected void acceptConsumed(DoubleConsumer action) { + action.accept(tmpValue); + } + + @Override + protected ArrayBuffer.OfDouble bufferCreate(int initialCapacity) { + return new ArrayBuffer.OfDouble(initialCapacity); + } + + @Override + protected Spliterator.OfDouble makeSpliterator(Spliterator.OfDouble s) { + return new UnorderedSliceSpliterator.OfDouble(s, this); + } + } + } + + /** + * A Spliterator that infinitely supplies elements in no particular order. + * + *

    Splitting divides the estimated size in two and stops when the + * estimate size is 0. + * + *

    The {@code forEachRemaining} method if invoked will never terminate. + * The {@coe tryAdvance} method always returns true. + * + */ + static abstract class InfiniteSupplyingSpliterator implements Spliterator { + long estimate; + + protected InfiniteSupplyingSpliterator(long estimate) { + this.estimate = estimate; + } + + @Override + public long estimateSize() { + return estimate; + } + + @Override + public int characteristics() { + return IMMUTABLE; + } + + static final class OfRef extends InfiniteSupplyingSpliterator { + final Supplier s; + + OfRef(long size, Supplier s) { + super(size); + this.s = s; + } + + @Override + public boolean tryAdvance(Consumer action) { + action.accept(s.get()); + return true; + } + + @Override + public Spliterator trySplit() { + if (estimate == 0) + return null; + return new InfiniteSupplyingSpliterator.OfRef<>(estimate >>>= 1, s); + } + } + + static final class OfInt extends InfiniteSupplyingSpliterator + implements Spliterator.OfInt { + final IntSupplier s; + + OfInt(long size, IntSupplier s) { + super(size); + this.s = s; + } + + @Override + public boolean tryAdvance(IntConsumer action) { + action.accept(s.getAsInt()); + return true; + } + + @Override + public Spliterator.OfInt trySplit() { + if (estimate == 0) + return null; + return new InfiniteSupplyingSpliterator.OfInt(estimate = estimate >>> 1, s); + } + } + + static final class OfLong extends InfiniteSupplyingSpliterator + implements Spliterator.OfLong { + final LongSupplier s; + + OfLong(long size, LongSupplier s) { + super(size); + this.s = s; + } + + @Override + public boolean tryAdvance(LongConsumer action) { + action.accept(s.getAsLong()); + return true; + } + + @Override + public Spliterator.OfLong trySplit() { + if (estimate == 0) + return null; + return new InfiniteSupplyingSpliterator.OfLong(estimate = estimate >>> 1, s); + } + } + + static final class OfDouble extends InfiniteSupplyingSpliterator + implements Spliterator.OfDouble { + final DoubleSupplier s; + + OfDouble(long size, DoubleSupplier s) { + super(size); + this.s = s; + } + + @Override + public boolean tryAdvance(DoubleConsumer action) { + action.accept(s.getAsDouble()); + return true; } @Override public Spliterator.OfDouble trySplit() { - return get().trySplit(); - } - - @Override - public boolean tryAdvance(DoubleConsumer consumer) { - return get().tryAdvance(consumer); - } - - @Override - public void forEachRemaining(DoubleConsumer consumer) { - get().forEachRemaining(consumer); + if (estimate == 0) + return null; + return new InfiniteSupplyingSpliterator.OfDouble(estimate = estimate >>> 1, s); } } } -} + + // @@@ Consolidate with Node.Builder + static abstract class ArrayBuffer { + int index; + + void reset() { + index = 0; + } + + static final class OfRef extends ArrayBuffer implements Consumer { + final Object[] array; + + OfRef(int size) { + this.array = new Object[size]; + } + + @Override + public void accept(T t) { + array[index++] = t; + } + + public void forEach(Consumer action, long fence) { + for (int i = 0; i < fence; i++) { + @SuppressWarnings("unchecked") + T t = (T) array[i]; + action.accept(t); + } + } + } + + static abstract class OfPrimitive extends ArrayBuffer { + int index; + + @Override + void reset() { + index = 0; + } + + abstract void forEach(T_CONS action, long fence); + } + + static final class OfInt extends OfPrimitive + implements IntConsumer { + final int[] array; + + OfInt(int size) { + this.array = new int[size]; + } + + @Override + public void accept(int t) { + array[index++] = t; + } + + @Override + public void forEach(IntConsumer action, long fence) { + for (int i = 0; i < fence; i++) { + action.accept(array[i]); + } + } + } + + static final class OfLong extends OfPrimitive + implements LongConsumer { + final long[] array; + + OfLong(int size) { + this.array = new long[size]; + } + + @Override + public void accept(long t) { + array[index++] = t; + } + + @Override + public void forEach(LongConsumer action, long fence) { + for (int i = 0; i < fence; i++) { + action.accept(array[i]); + } + } + } + + static final class OfDouble extends OfPrimitive + implements DoubleConsumer { + final double[] array; + + OfDouble(int size) { + this.array = new double[size]; + } + + @Override + public void accept(double t) { + array[index++] = t; + } + + @Override + void forEach(DoubleConsumer action, long fence) { + for (int i = 0; i < fence; i++) { + action.accept(array[i]); + } + } + } + } +} \ No newline at end of file diff --git a/jdk/test/java/util/stream/bootlib/java/util/stream/OpTestCase.java b/jdk/test/java/util/stream/bootlib/java/util/stream/OpTestCase.java index 84a574480b5..115a37dc6c5 100644 --- a/jdk/test/java/util/stream/bootlib/java/util/stream/OpTestCase.java +++ b/jdk/test/java/util/stream/bootlib/java/util/stream/OpTestCase.java @@ -79,11 +79,11 @@ public abstract class OpTestCase extends LoggingTestCase { * test. * * @param actual the actual result - * @param excepted the expected result + * @param expected the expected result * @param isOrdered true if the pipeline is ordered * @param isParallel true if the pipeline is parallel */ - void assertResult(R actual, R excepted, boolean isOrdered, boolean isParallel); + void assertResult(R actual, R expected, boolean isOrdered, boolean isParallel); } // Exercise stream operations diff --git a/jdk/test/java/util/stream/bootlib/java/util/stream/SpliteratorTestHelper.java b/jdk/test/java/util/stream/bootlib/java/util/stream/SpliteratorTestHelper.java index 7ba82a64616..4d221735315 100644 --- a/jdk/test/java/util/stream/bootlib/java/util/stream/SpliteratorTestHelper.java +++ b/jdk/test/java/util/stream/bootlib/java/util/stream/SpliteratorTestHelper.java @@ -42,11 +42,33 @@ import static org.testng.Assert.fail; */ public class SpliteratorTestHelper { + public interface ContentAsserter { + void assertContents(Collection actual, Collection expected, boolean isOrdered); + } + + private static ContentAsserter DEFAULT_CONTENT_ASSERTER + = SpliteratorTestHelper::assertContents; + + @SuppressWarnings("unchecked") + private static ContentAsserter defaultContentAsserter() { + return (ContentAsserter) DEFAULT_CONTENT_ASSERTER; + } + public static void testSpliterator(Supplier> supplier) { - testSpliterator(supplier, (Consumer b) -> b); + testSpliterator(supplier, defaultContentAsserter()); + } + + public static void testSpliterator(Supplier> supplier, + ContentAsserter asserter) { + testSpliterator(supplier, (Consumer b) -> b, asserter); } public static void testIntSpliterator(Supplier supplier) { + testIntSpliterator(supplier, defaultContentAsserter()); + } + + public static void testIntSpliterator(Supplier supplier, + ContentAsserter asserter) { class BoxingAdapter implements Consumer, IntConsumer { private final Consumer b; @@ -65,10 +87,15 @@ public class SpliteratorTestHelper { } } - testSpliterator(supplier, BoxingAdapter::new); + testSpliterator(supplier, BoxingAdapter::new, asserter); } public static void testLongSpliterator(Supplier supplier) { + testLongSpliterator(supplier, defaultContentAsserter()); + } + + public static void testLongSpliterator(Supplier supplier, + ContentAsserter asserter) { class BoxingAdapter implements Consumer, LongConsumer { private final Consumer b; @@ -87,10 +114,15 @@ public class SpliteratorTestHelper { } } - testSpliterator(supplier, BoxingAdapter::new); + testSpliterator(supplier, BoxingAdapter::new, asserter); } public static void testDoubleSpliterator(Supplier supplier) { + testDoubleSpliterator(supplier, defaultContentAsserter()); + } + + public static void testDoubleSpliterator(Supplier supplier, + ContentAsserter asserter) { class BoxingAdapter implements Consumer, DoubleConsumer { private final Consumer b; @@ -109,11 +141,12 @@ public class SpliteratorTestHelper { } } - testSpliterator(supplier, BoxingAdapter::new); + testSpliterator(supplier, BoxingAdapter::new, asserter); } static > void testSpliterator(Supplier supplier, - UnaryOperator> boxingAdapter) { + UnaryOperator> boxingAdapter, + ContentAsserter asserter) { ArrayList fromForEach = new ArrayList<>(); Spliterator spliterator = supplier.get(); Consumer addToFromForEach = boxingAdapter.apply(fromForEach::add); @@ -121,14 +154,14 @@ public class SpliteratorTestHelper { Collection exp = Collections.unmodifiableList(fromForEach); - testForEach(exp, supplier, boxingAdapter); - testTryAdvance(exp, supplier, boxingAdapter); - testMixedTryAdvanceForEach(exp, supplier, boxingAdapter); - testMixedTraverseAndSplit(exp, supplier, boxingAdapter); + testForEach(exp, supplier, boxingAdapter, asserter); + testTryAdvance(exp, supplier, boxingAdapter, asserter); + testMixedTryAdvanceForEach(exp, supplier, boxingAdapter, asserter); + testMixedTraverseAndSplit(exp, supplier, boxingAdapter, asserter); testSplitAfterFullTraversal(supplier, boxingAdapter); - testSplitOnce(exp, supplier, boxingAdapter); - testSplitSixDeep(exp, supplier, boxingAdapter); - testSplitUntilNull(exp, supplier, boxingAdapter); + testSplitOnce(exp, supplier, boxingAdapter, asserter); + testSplitSixDeep(exp, supplier, boxingAdapter, asserter); + testSplitUntilNull(exp, supplier, boxingAdapter, asserter); } // @@ -136,7 +169,8 @@ public class SpliteratorTestHelper { private static > void testForEach( Collection exp, Supplier supplier, - UnaryOperator> boxingAdapter) { + UnaryOperator> boxingAdapter, + ContentAsserter asserter) { S spliterator = supplier.get(); long sizeIfKnown = spliterator.getExactSizeIfKnown(); boolean isOrdered = spliterator.hasCharacteristics(Spliterator.ORDERED); @@ -159,13 +193,14 @@ public class SpliteratorTestHelper { } assertEquals(fromForEach.size(), exp.size()); - assertContents(fromForEach, exp, isOrdered); + asserter.assertContents(fromForEach, exp, isOrdered); } private static > void testTryAdvance( Collection exp, Supplier supplier, - UnaryOperator> boxingAdapter) { + UnaryOperator> boxingAdapter, + ContentAsserter asserter) { S spliterator = supplier.get(); long sizeIfKnown = spliterator.getExactSizeIfKnown(); boolean isOrdered = spliterator.hasCharacteristics(Spliterator.ORDERED); @@ -188,13 +223,14 @@ public class SpliteratorTestHelper { } assertEquals(fromTryAdvance.size(), exp.size()); - assertContents(fromTryAdvance, exp, isOrdered); + asserter.assertContents(fromTryAdvance, exp, isOrdered); } private static > void testMixedTryAdvanceForEach( Collection exp, Supplier supplier, - UnaryOperator> boxingAdapter) { + UnaryOperator> boxingAdapter, + ContentAsserter asserter) { S spliterator = supplier.get(); long sizeIfKnown = spliterator.getExactSizeIfKnown(); boolean isOrdered = spliterator.hasCharacteristics(Spliterator.ORDERED); @@ -218,18 +254,14 @@ public class SpliteratorTestHelper { } assertEquals(dest.size(), exp.size()); - if (isOrdered) { - assertEquals(dest, exp); - } - else { - assertContentsUnordered(dest, exp); - } + asserter.assertContents(dest, exp, isOrdered); } private static > void testMixedTraverseAndSplit( Collection exp, Supplier supplier, - UnaryOperator> boxingAdapter) { + UnaryOperator> boxingAdapter, + ContentAsserter asserter) { S spliterator = supplier.get(); long sizeIfKnown = spliterator.getExactSizeIfKnown(); boolean isOrdered = spliterator.hasCharacteristics(Spliterator.ORDERED); @@ -266,12 +298,7 @@ public class SpliteratorTestHelper { } assertEquals(dest.size(), exp.size()); - if (isOrdered) { - assertEquals(dest, exp); - } - else { - assertContentsUnordered(dest, exp); - } + asserter.assertContents(dest, exp, isOrdered); } private static > void testSplitAfterFullTraversal( @@ -285,16 +312,14 @@ public class SpliteratorTestHelper { // Full traversal using forEach spliterator = supplier.get(); - spliterator.forEachRemaining(boxingAdapter.apply(e -> { - })); + spliterator.forEachRemaining(boxingAdapter.apply(e -> { })); split = spliterator.trySplit(); assertNull(split); // Full traversal using tryAdvance then forEach spliterator = supplier.get(); spliterator.tryAdvance(boxingAdapter.apply(e -> { })); - spliterator.forEachRemaining(boxingAdapter.apply(e -> { - })); + spliterator.forEachRemaining(boxingAdapter.apply(e -> { })); split = spliterator.trySplit(); assertNull(split); } @@ -302,7 +327,8 @@ public class SpliteratorTestHelper { private static > void testSplitOnce( Collection exp, Supplier supplier, - UnaryOperator> boxingAdapter) { + UnaryOperator> boxingAdapter, + ContentAsserter asserter) { S spliterator = supplier.get(); long sizeIfKnown = spliterator.getExactSizeIfKnown(); boolean isOrdered = spliterator.hasCharacteristics(Spliterator.ORDERED); @@ -322,13 +348,15 @@ public class SpliteratorTestHelper { if (s1Size >= 0 && s2Size >= 0) assertEquals(sizeIfKnown, s1Size + s2Size); } - assertContents(fromSplit, exp, isOrdered); + + asserter.assertContents(fromSplit, exp, isOrdered); } private static > void testSplitSixDeep( Collection exp, Supplier supplier, - UnaryOperator> boxingAdapter) { + UnaryOperator> boxingAdapter, + ContentAsserter asserter) { S spliterator = supplier.get(); boolean isOrdered = spliterator.hasCharacteristics(Spliterator.ORDERED); @@ -340,13 +368,13 @@ public class SpliteratorTestHelper { // verify splitting with forEach splitSixDeepVisitor(depth, 0, dest, spliterator, boxingAdapter, spliterator.characteristics(), false); - assertContents(dest, exp, isOrdered); + asserter.assertContents(dest, exp, isOrdered); // verify splitting with tryAdvance dest.clear(); spliterator = supplier.get(); splitSixDeepVisitor(depth, 0, dest, spliterator, boxingAdapter, spliterator.characteristics(), true); - assertContents(dest, exp, isOrdered); + asserter.assertContents(dest, exp, isOrdered); } } @@ -411,7 +439,8 @@ public class SpliteratorTestHelper { private static > void testSplitUntilNull( Collection exp, Supplier supplier, - UnaryOperator> boxingAdapter) { + UnaryOperator> boxingAdapter, + ContentAsserter asserter) { Spliterator s = supplier.get(); boolean isOrdered = s.hasCharacteristics(Spliterator.ORDERED); assertSpliterator(s); @@ -420,7 +449,7 @@ public class SpliteratorTestHelper { Consumer c = boxingAdapter.apply(splits::add); testSplitUntilNull(new SplitNode(c, s)); - assertContents(splits, exp, isOrdered); + asserter.assertContents(splits, exp, isOrdered); } private static class SplitNode { @@ -540,23 +569,10 @@ public class SpliteratorTestHelper { assertEquals(actual, expected); } else { - assertContentsUnordered(actual, expected); + LambdaTestHelpers.assertContentsUnordered(actual, expected); } } - private static void assertContentsUnordered(Iterable actual, Iterable expected) { - assertEquals(toBoxedMultiset(actual), toBoxedMultiset(expected)); - } - - private static Map toBoxedMultiset(Iterable c) { - Map result = new HashMap<>(); - c.forEach(e -> { - if (result.containsKey(e)) result.put(e, result.get(e) + 1); - else result.put(e, 1); - }); - return result; - } - static void mixedTraverseAndSplit(Consumer b, Spliterator splTop) { Spliterator spl1, spl2, spl3; splTop.tryAdvance(b); diff --git a/jdk/test/java/util/stream/boottest/java/util/stream/SliceSpliteratorTest.java b/jdk/test/java/util/stream/boottest/java/util/stream/SliceSpliteratorTest.java new file mode 100644 index 00000000000..7aa27bf5b88 --- /dev/null +++ b/jdk/test/java/util/stream/boottest/java/util/stream/SliceSpliteratorTest.java @@ -0,0 +1,201 @@ +/* + * Copyright (c) 2013, 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. + */ +package java.util.stream; + +import org.testng.annotations.DataProvider; +import org.testng.annotations.Test; + +import java.util.ArrayList; +import java.util.Arrays; +import java.util.Collection; +import java.util.List; +import java.util.Spliterator; + +import static java.util.stream.Collectors.toList; +import static org.testng.Assert.assertEquals; + +/** + * @bug 8012987 + */ +@Test +public class SliceSpliteratorTest extends LoggingTestCase { + + static class UnorderedContentAsserter implements SpliteratorTestHelper.ContentAsserter { + Collection source; + + UnorderedContentAsserter(Collection source) { + this.source = source; + } + + @Override + public void assertContents(Collection actual, Collection expected, boolean isOrdered) { + if (isOrdered) { + assertEquals(actual, expected); + } + else { + assertEquals(actual.size(), expected.size()); + assertTrue(source.containsAll(actual)); + } + } + } + + interface SliceTester { + void test(int size, int skip, int limit); + } + + @DataProvider(name = "sliceSpliteratorDataProvider") + public static Object[][] sliceSpliteratorDataProvider() { + List data = new ArrayList<>(); + + // SIZED/SUBSIZED slice spliterator + + { + SliceTester r = (size, skip, limit) -> { + final Collection source = IntStream.range(0, size).boxed().collect(toList()); + + SpliteratorTestHelper.testSpliterator(() -> { + Spliterator s = Arrays.spliterator(source.stream().toArray(Integer[]::new)); + + return new StreamSpliterators.SliceSpliterator.OfRef<>(s, skip, limit); + }); + }; + data.add(new Object[]{"StreamSpliterators.SliceSpliterator.OfRef", r}); + } + + { + SliceTester r = (size, skip, limit) -> { + final Collection source = IntStream.range(0, size).boxed().collect(toList()); + + SpliteratorTestHelper.testIntSpliterator(() -> { + Spliterator.OfInt s = Arrays.spliterator(source.stream().mapToInt(i->i).toArray()); + + return new StreamSpliterators.SliceSpliterator.OfInt(s, skip, limit); + }); + }; + data.add(new Object[]{"StreamSpliterators.SliceSpliterator.OfInt", r}); + } + + { + SliceTester r = (size, skip, limit) -> { + final Collection source = LongStream.range(0, size).boxed().collect(toList()); + + SpliteratorTestHelper.testLongSpliterator(() -> { + Spliterator.OfLong s = Arrays.spliterator(source.stream().mapToLong(i->i).toArray()); + + return new StreamSpliterators.SliceSpliterator.OfLong(s, skip, limit); + }); + }; + data.add(new Object[]{"StreamSpliterators.SliceSpliterator.OfLong", r}); + } + + { + SliceTester r = (size, skip, limit) -> { + final Collection source = LongStream.range(0, size).asDoubleStream().boxed().collect(toList()); + + SpliteratorTestHelper.testDoubleSpliterator(() -> { + Spliterator.OfDouble s = Arrays.spliterator(source.stream().mapToDouble(i->i).toArray()); + + return new StreamSpliterators.SliceSpliterator.OfDouble(s, skip, limit); + }); + }; + data.add(new Object[]{"StreamSpliterators.SliceSpliterator.OfLong", r}); + } + + + // Unordered slice spliterator + + { + SliceTester r = (size, skip, limit) -> { + final Collection source = IntStream.range(0, size).boxed().collect(toList()); + final UnorderedContentAsserter uca = new UnorderedContentAsserter<>(source); + + SpliteratorTestHelper.testSpliterator(() -> { + Spliterator s = Arrays.spliterator(source.stream().toArray(Integer[]::new)); + + return new StreamSpliterators.UnorderedSliceSpliterator.OfRef<>(s, skip, limit); + }, uca); + }; + data.add(new Object[]{"StreamSpliterators.UnorderedSliceSpliterator.OfRef", r}); + } + + { + SliceTester r = (size, skip, limit) -> { + final Collection source = IntStream.range(0, size).boxed().collect(toList()); + final UnorderedContentAsserter uca = new UnorderedContentAsserter<>(source); + + SpliteratorTestHelper.testIntSpliterator(() -> { + Spliterator.OfInt s = Arrays.spliterator(source.stream().mapToInt(i->i).toArray()); + + return new StreamSpliterators.UnorderedSliceSpliterator.OfInt(s, skip, limit); + }, uca); + }; + data.add(new Object[]{"StreamSpliterators.UnorderedSliceSpliterator.OfInt", r}); + } + + { + SliceTester r = (size, skip, limit) -> { + final Collection source = LongStream.range(0, size).boxed().collect(toList()); + final UnorderedContentAsserter uca = new UnorderedContentAsserter<>(source); + + SpliteratorTestHelper.testLongSpliterator(() -> { + Spliterator.OfLong s = Arrays.spliterator(source.stream().mapToLong(i->i).toArray()); + + return new StreamSpliterators.UnorderedSliceSpliterator.OfLong(s, skip, limit); + }, uca); + }; + data.add(new Object[]{"StreamSpliterators.UnorderedSliceSpliterator.OfLong", r}); + } + + { + SliceTester r = (size, skip, limit) -> { + final Collection source = LongStream.range(0, size).asDoubleStream().boxed().collect(toList()); + final UnorderedContentAsserter uca = new UnorderedContentAsserter<>(source); + + SpliteratorTestHelper.testDoubleSpliterator(() -> { + Spliterator.OfDouble s = Arrays.spliterator(LongStream.range(0, SIZE).asDoubleStream().toArray()); + + return new StreamSpliterators.UnorderedSliceSpliterator.OfDouble(s, skip, limit); + }, uca); + }; + data.add(new Object[]{"StreamSpliterators.UnorderedSliceSpliterator.OfLong", r}); + } + + return data.toArray(new Object[0][]); + } + + static final int SIZE = 256; + + static final int STEP = 32; + + @Test(dataProvider = "sliceSpliteratorDataProvider") + public void testSliceSpliterator(String description, SliceTester r) { + setContext("size", SIZE); + for (int skip = 0; skip < SIZE; skip += STEP) { + setContext("skip", skip); + for (int limit = 0; limit < SIZE; limit += STEP) { + setContext("limit", skip); + r.test(SIZE, skip, limit); + } + } + } +} diff --git a/jdk/test/java/util/stream/boottest/java/util/stream/StreamFlagsTest.java b/jdk/test/java/util/stream/boottest/java/util/stream/StreamFlagsTest.java index a5fa364e1e0..29243cfb90a 100644 --- a/jdk/test/java/util/stream/boottest/java/util/stream/StreamFlagsTest.java +++ b/jdk/test/java/util/stream/boottest/java/util/stream/StreamFlagsTest.java @@ -80,8 +80,8 @@ public class StreamFlagsTest { EnumSet.of(ORDERED, DISTINCT, SIZED), EnumSet.of(SORTED, SHORT_CIRCUIT)); assertFlags(OpTestCase.getStreamFlags(repeat), - EnumSet.of(ORDERED), - EnumSet.of(SIZED, DISTINCT, SORTED, SHORT_CIRCUIT)); + EnumSet.noneOf(StreamOpFlag.class), + EnumSet.of(DISTINCT, SORTED, SHORT_CIRCUIT)); } public void testFilter() { diff --git a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/InfiniteStreamWithLimitOpTest.java b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/InfiniteStreamWithLimitOpTest.java index a43802cc419..dc086668f54 100644 --- a/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/InfiniteStreamWithLimitOpTest.java +++ b/jdk/test/java/util/stream/test/org/openjdk/tests/java/util/stream/InfiniteStreamWithLimitOpTest.java @@ -22,45 +22,440 @@ */ package org.openjdk.tests.java.util.stream; -import java.util.stream.OpTestCase; +import org.testng.annotations.DataProvider; import org.testng.annotations.Test; -import java.util.Arrays; +import java.lang.reflect.InvocationHandler; +import java.lang.reflect.Method; +import java.lang.reflect.Proxy; +import java.util.ArrayList; import java.util.List; -import java.util.stream.Collectors; +import java.util.Spliterator; +import java.util.function.Function; +import java.util.function.UnaryOperator; +import java.util.stream.DoubleStream; +import java.util.stream.DoubleStreamTestScenario; +import java.util.stream.IntStream; +import java.util.stream.IntStreamTestScenario; +import java.util.stream.LambdaTestHelpers; +import java.util.stream.LongStream; +import java.util.stream.LongStreamTestScenario; +import java.util.stream.OpTestCase; import java.util.stream.Stream; +import java.util.stream.StreamSupport; +import java.util.stream.StreamTestScenario; +import java.util.stream.TestData; -import static java.util.stream.LambdaTestHelpers.assertContents; +import static java.util.stream.LambdaTestHelpers.assertUnique; @Test public class InfiniteStreamWithLimitOpTest extends OpTestCase { - private static final List tenAs = Arrays.asList("A", "A", "A", "A", "A", "A", "A", "A", "A", "A"); + private static final long SKIP_LIMIT_SIZE = 1 << 16; - public void testRepeatLimit() { - assertContents(Stream.generate(() -> "A").limit(10).iterator(), tenAs.iterator()); + @DataProvider(name = "Stream.limit") + @SuppressWarnings("rawtypes") + public static Object[][] sliceFunctionsDataProvider() { + Function f = s -> String.format(s, SKIP_LIMIT_SIZE); + + List data = new ArrayList<>(); + + data.add(new Object[]{f.apply("Stream.limit(%d)"), + (UnaryOperator) s -> s.limit(SKIP_LIMIT_SIZE)}); + data.add(new Object[]{f.apply("Stream.substream(%d)"), + (UnaryOperator) s -> s.substream(SKIP_LIMIT_SIZE, SKIP_LIMIT_SIZE * 2)}); + data.add(new Object[]{f.apply("Stream.substream(%1$d).limit(%1$d)"), + (UnaryOperator) s -> s.substream(SKIP_LIMIT_SIZE).limit(SKIP_LIMIT_SIZE)}); + + return data.toArray(new Object[0][]); } - public void testIterateLimit() { - assertContents(Stream.iterate("A", s -> s).limit(10).iterator(), tenAs.iterator()); + @DataProvider(name = "IntStream.limit") + public static Object[][] intSliceFunctionsDataProvider() { + Function f = s -> String.format(s, SKIP_LIMIT_SIZE); + + List data = new ArrayList<>(); + + data.add(new Object[]{f.apply("IntStream.limit(%d)"), + (UnaryOperator) s -> s.limit(SKIP_LIMIT_SIZE)}); + data.add(new Object[]{f.apply("IntStream.substream(%d)"), + (UnaryOperator) s -> s.substream(SKIP_LIMIT_SIZE, SKIP_LIMIT_SIZE * 2)}); + data.add(new Object[]{f.apply("IntStream.substream(%1$d).limit(%1$d)"), + (UnaryOperator) s -> s.substream(SKIP_LIMIT_SIZE).limit(SKIP_LIMIT_SIZE)}); + + return data.toArray(new Object[0][]); } - public void testIterateFibLimit() { - Stream fib = Stream.iterate(new int[] {0, 1}, pair -> new int[] {pair[1], pair[0] + pair[1]}) - .map(pair -> pair[0]); + @DataProvider(name = "LongStream.limit") + public static Object[][] longSliceFunctionsDataProvider() { + Function f = s -> String.format(s, SKIP_LIMIT_SIZE); - assertContents( - fib.limit(10).iterator(), - Arrays.asList(0, 1, 1, 2, 3, 5, 8, 13, 21, 34).iterator()); + List data = new ArrayList<>(); + + data.add(new Object[]{f.apply("LongStream.limit(%d)"), + (UnaryOperator) s -> s.limit(SKIP_LIMIT_SIZE)}); + data.add(new Object[]{f.apply("LongStream.substream(%d)"), + (UnaryOperator) s -> s.substream(SKIP_LIMIT_SIZE, SKIP_LIMIT_SIZE * 2)}); + data.add(new Object[]{f.apply("LongStream.substream(%1$d).limit(%1$d)"), + (UnaryOperator) s -> s.substream(SKIP_LIMIT_SIZE).limit(SKIP_LIMIT_SIZE)}); + + return data.toArray(new Object[0][]); } - public void testInfiniteWithLimitToShortCircuitTerminal() { - Object[] array = Stream.generate(() -> 1).limit(4).toArray(); - assertEquals(4, array.length); - array = Stream.generate(() -> 1).limit(4).filter(i -> true).toArray(); - assertEquals(4, array.length); - List result = Stream.generate(() -> 1).limit(4).collect(Collectors.toList()); - assertEquals(result, Arrays.asList(1, 1, 1, 1)); + @DataProvider(name = "DoubleStream.limit") + public static Object[][] doubleSliceFunctionsDataProvider() { + Function f = s -> String.format(s, SKIP_LIMIT_SIZE); + + List data = new ArrayList<>(); + + data.add(new Object[]{f.apply("DoubleStream.limit(%d)"), + (UnaryOperator) s -> s.limit(SKIP_LIMIT_SIZE)}); + data.add(new Object[]{f.apply("DoubleStream.substream(%d)"), + (UnaryOperator) s -> s.substream(SKIP_LIMIT_SIZE, SKIP_LIMIT_SIZE * 2)}); + data.add(new Object[]{f.apply("DoubleStream.substream(%1$d).limit(%1$d)"), + (UnaryOperator) s -> s.substream(SKIP_LIMIT_SIZE).limit(SKIP_LIMIT_SIZE)}); + + return data.toArray(new Object[0][]); + } + + private ResultAsserter> unorderedAsserter() { + return (act, exp, ord, par) -> { + if (par & !ord) { + // Can only assert that all elements of the actual result + // are distinct and that the count is the limit size + // any element within the range [0, Long.MAX_VALUE) may be + // present + assertUnique(act); + long count = 0; + for (T l : act) { + count++; + } + assertEquals(count, SKIP_LIMIT_SIZE, "size not equal"); + } + else { + LambdaTestHelpers.assertContents(act, exp); + } + }; + } + + private TestData.OfRef refLongs() { + return refLongRange(0, Long.MAX_VALUE); + } + + private TestData.OfRef refLongRange(long l, long u) { + return TestData.Factory.ofSupplier( + String.format("[%d, %d)", l, u), + () -> LongStream.range(l, u).boxed()); + } + + private TestData.OfInt ints() { + return intRange(0, Integer.MAX_VALUE); + } + + private TestData.OfInt intRange(int l, int u) { + return TestData.Factory.ofIntSupplier( + String.format("[%d, %d)", l, u), + () -> IntStream.range(l, u)); + } + + private TestData.OfLong longs() { + return longRange(0, Long.MAX_VALUE); + } + + private TestData.OfLong longRange(long l, long u) { + return TestData.Factory.ofLongSupplier( + String.format("[%d, %d)", l, u), + () -> LongStream.range(l, u)); + } + + private TestData.OfDouble doubles() { + return doubleRange(0, 1L << 53); + } + + private TestData.OfDouble doubleRange(long l, long u) { + return TestData.Factory.ofDoubleSupplier( + String.format("[%d, %d)", l, u), + () -> LongStream.range(l, u).mapToDouble(i -> (double) i)); + } + + + // Sized/subsized range + + @Test(dataProvider = "Stream.limit") + public void testSubsizedWithRange(String description, UnaryOperator> fs) { + // Range is [0, Long.MAX_VALUE), splits are SUBSIZED + // Such a size will induce out of memory errors for incorrect + // slice implementations + withData(refLongs()). + stream(s -> fs.apply(s)). + without(StreamTestScenario.PAR_STREAM_TO_ARRAY_CLEAR_SIZED). + exercise(); + } + + @Test(dataProvider = "IntStream.limit") + public void testIntSubsizedWithRange(String description, UnaryOperator fs) { + // Range is [0, Integer.MAX_VALUE), splits are SUBSIZED + // Such a size will induce out of memory errors for incorrect + // slice implementations + withData(ints()). + stream(s -> fs.apply(s)). + without(IntStreamTestScenario.PAR_STREAM_TO_ARRAY_CLEAR_SIZED). + exercise(); + } + + @Test(dataProvider = "LongStream.limit") + public void testLongSubsizedWithRange(String description, UnaryOperator fs) { + // Range is [0, Long.MAX_VALUE), splits are SUBSIZED + // Such a size will induce out of memory errors for incorrect + // slice implementations + withData(longs()). + stream(s -> fs.apply(s)). + without(LongStreamTestScenario.PAR_STREAM_TO_ARRAY_CLEAR_SIZED). + exercise(); + } + + @Test(dataProvider = "DoubleStream.limit") + public void testDoubleSubsizedWithRange(String description, UnaryOperator fs) { + // Range is [0, 2^53), splits are SUBSIZED + // Such a size will induce out of memory errors for incorrect + // slice implementations + withData(doubles()). + stream(s -> fs.apply(s)). + without(DoubleStreamTestScenario.PAR_STREAM_TO_ARRAY_CLEAR_SIZED). + exercise(); + } + + + // Unordered finite not SIZED/SUBSIZED + + @Test(dataProvider = "Stream.limit") + public void testUnorderedFinite(String description, UnaryOperator> fs) { + // Range is [0, Long.MAX_VALUE), splits are SUBSIZED + // Such a size will induce out of memory errors for incorrect + // slice implementations + withData(longs()). + stream(s -> fs.apply(s.filter(i -> true).unordered().boxed())). + resultAsserter(unorderedAsserter()). + exercise(); + } + + @Test(dataProvider = "IntStream.limit") + public void testIntUnorderedFinite(String description, UnaryOperator fs) { + // Range is [0, Integer.MAX_VALUE), splits are SUBSIZED + // Such a size will induce out of memory errors for incorrect + // slice implementations + withData(ints()). + stream(s -> fs.apply(s.filter(i -> true).unordered())). + resultAsserter(unorderedAsserter()). + exercise(); + } + + @Test(dataProvider = "LongStream.limit") + public void testLongUnorderedFinite(String description, UnaryOperator fs) { + // Range is [0, Long.MAX_VALUE), splits are SUBSIZED + // Such a size will induce out of memory errors for incorrect + // slice implementations + withData(longs()). + stream(s -> fs.apply(s.filter(i -> true).unordered())). + resultAsserter(unorderedAsserter()). + exercise(); + } + + @Test(dataProvider = "DoubleStream.limit") + public void testDoubleUnorderedFinite(String description, UnaryOperator fs) { + // Range is [0, 1L << 53), splits are SUBSIZED + // Such a size will induce out of memory errors for incorrect + // slice implementations + // Upper bound ensures values mapped to doubles will be unique + withData(doubles()). + stream(s -> fs.apply(s.filter(i -> true).unordered())). + resultAsserter(unorderedAsserter()). + exercise(); + } + + + // Unordered finite not SUBSIZED + + @SuppressWarnings({"rawtypes", "unchecked"}) + private Spliterator.OfLong proxyNotSubsized(Spliterator.OfLong s) { + InvocationHandler ih = new InvocationHandler() { + @Override + public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { + switch (method.getName()) { + case "characteristics": { + int c = (Integer) method.invoke(s, args); + return c & ~Spliterator.SUBSIZED; + } + case "hasCharacteristics": { + int c = (Integer) args[0]; + boolean b = (Boolean) method.invoke(s, args); + return b & ((c & Spliterator.SUBSIZED) == 0); + } + default: + return method.invoke(s, args); + } + } + }; + + return (Spliterator.OfLong) Proxy.newProxyInstance(this.getClass().getClassLoader(), + new Class[]{Spliterator.OfLong.class}, + ih); + } + + private TestData.OfLong proxiedLongRange(long l, long u) { + return TestData.Factory.ofLongSupplier( + String.format("[%d, %d)", l, u), + () -> StreamSupport.longStream(proxyNotSubsized(LongStream.range(l, u).spliterator()))); + } + + @Test(dataProvider = "Stream.limit") + public void testUnorderedSizedNotSubsizedFinite(String description, UnaryOperator> fs) { + // Range is [0, Long.MAX_VALUE), splits are not SUBSIZED (proxy clears + // the SUBSIZED characteristic) + // Such a size will induce out of memory errors for incorrect + // slice implementations + withData(proxiedLongRange(0, Long.MAX_VALUE)). + stream(s -> fs.apply(s.unordered().boxed())). + resultAsserter(unorderedAsserter()). + exercise(); + } + + @Test(dataProvider = "IntStream.limit") + public void testIntUnorderedSizedNotSubsizedFinite(String description, UnaryOperator fs) { + // Range is [0, Integer.MAX_VALUE), splits are not SUBSIZED (proxy clears + // the SUBSIZED characteristic) + // Such a size will induce out of memory errors for incorrect + // slice implementations + withData(proxiedLongRange(0, Integer.MAX_VALUE)). + stream(s -> fs.apply(s.unordered().mapToInt(i -> (int) i))). + resultAsserter(unorderedAsserter()). + exercise(); + } + + @Test(dataProvider = "LongStream.limit") + public void testLongUnorderedSizedNotSubsizedFinite(String description, UnaryOperator fs) { + // Range is [0, Long.MAX_VALUE), splits are not SUBSIZED (proxy clears + // the SUBSIZED characteristic) + // Such a size will induce out of memory errors for incorrect + // slice implementations + withData(proxiedLongRange(0, Long.MAX_VALUE)). + stream(s -> fs.apply(s.unordered())). + resultAsserter(unorderedAsserter()). + exercise(); + } + + @Test(dataProvider = "DoubleStream.limit") + public void testDoubleUnorderedSizedNotSubsizedFinite(String description, UnaryOperator fs) { + // Range is [0, Double.MAX_VALUE), splits are not SUBSIZED (proxy clears + // the SUBSIZED characteristic) + // Such a size will induce out of memory errors for incorrect + // slice implementations + withData(proxiedLongRange(0, 1L << 53)). + stream(s -> fs.apply(s.unordered().mapToDouble(i -> (double) i))). + resultAsserter(unorderedAsserter()). + exercise(); + } + + + // Unordered generation + + @Test(dataProvider = "Stream.limit") + public void testUnorderedGenerator(String description, UnaryOperator> fs) { + // Source is spliterator of infinite size + TestData.OfRef generator = TestData.Factory.ofSupplier( + "[1L, 1L, ...]", () -> Stream.generate(() -> 1L)); + + withData(generator). + stream(s -> fs.apply(s.filter(i -> true).unordered())). + exercise(); + } + + @Test(dataProvider = "IntStream.limit") + public void testIntUnorderedGenerator(String description, UnaryOperator fs) { + // Source is spliterator of infinite size + TestData.OfInt generator = TestData.Factory.ofIntSupplier( + "[1, 1, ...]", () -> IntStream.generate(() -> 1)); + + withData(generator). + stream(s -> fs.apply(s.filter(i -> true).unordered())). + exercise(); + } + + @Test(dataProvider = "LongStream.limit") + public void testLongUnorderedGenerator(String description, UnaryOperator fs) { + // Source is spliterator of infinite size + TestData.OfLong generator = TestData.Factory.ofLongSupplier( + "[1L, 1L, ...]", () -> LongStream.generate(() -> 1)); + + withData(generator). + stream(s -> fs.apply(s.filter(i -> true).unordered())). + exercise(); + } + + @Test(dataProvider = "DoubleStream.limit") + public void testDoubleUnorderedGenerator(String description, UnaryOperator fs) { + // Source is spliterator of infinite size + TestData.OfDouble generator = TestData.Factory.ofDoubleSupplier( + "[1.0, 1.0, ...]", () -> DoubleStream.generate(() -> 1.0)); + + withData(generator). + stream(s -> fs.apply(s.filter(i -> true).unordered())). + exercise(); + } + + + // Unordered iteration + + @Test(dataProvider = "Stream.limit") + public void testUnorderedIteration(String description, UnaryOperator> fs) { + // Source is a right-balanced tree of infinite size + TestData.OfRef iterator = TestData.Factory.ofSupplier( + "[1L, 2L, 3L, ...]", () -> Stream.iterate(1L, i -> i + 1L)); + + // Ref + withData(iterator). + stream(s -> fs.apply(s.unordered())). + resultAsserter(unorderedAsserter()). + exercise(); + } + + @Test(dataProvider = "IntStream.limit") + public void testIntUnorderedIteration(String description, UnaryOperator fs) { + // Source is a right-balanced tree of infinite size + TestData.OfInt iterator = TestData.Factory.ofIntSupplier( + "[1, 2, 3, ...]", () -> IntStream.iterate(1, i -> i + 1)); + + // Ref + withData(iterator). + stream(s -> fs.apply(s.unordered())). + resultAsserter(unorderedAsserter()). + exercise(); + } + + @Test(dataProvider = "LongStream.limit") + public void testLongUnorderedIteration(String description, UnaryOperator fs) { + // Source is a right-balanced tree of infinite size + TestData.OfLong iterator = TestData.Factory.ofLongSupplier( + "[1L, 2L, 3L, ...]", () -> LongStream.iterate(1, i -> i + 1)); + + // Ref + withData(iterator). + stream(s -> fs.apply(s.unordered())). + resultAsserter(unorderedAsserter()). + exercise(); + } + + @Test(dataProvider = "DoubleStream.limit") + public void testDoubleUnorderedIteration(String description, UnaryOperator fs) { + // Source is a right-balanced tree of infinite size + TestData.OfDouble iterator = TestData.Factory.ofDoubleSupplier( + "[1.0, 2.0, 3.0, ...]", () -> DoubleStream.iterate(1, i -> i + 1)); + + // Ref + withData(iterator). + stream(s -> fs.apply(s.unordered())). + resultAsserter(unorderedAsserter()). + exercise(); } } From 13bcac6e93ca3927ed49920e3f0e8621a3aa1900 Mon Sep 17 00:00:00 2001 From: Alejandro Murillo Date: Fri, 28 Jun 2013 02:33:13 -0700 Subject: [PATCH 074/127] 8019302: new hotspot build - hs25-b40 Reviewed-by: jcoomes --- hotspot/make/hotspot_version | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/hotspot/make/hotspot_version b/hotspot/make/hotspot_version index 17088cd02f9..b597ff990be 100644 --- a/hotspot/make/hotspot_version +++ b/hotspot/make/hotspot_version @@ -35,7 +35,7 @@ HOTSPOT_VM_COPYRIGHT=Copyright 2013 HS_MAJOR_VER=25 HS_MINOR_VER=0 -HS_BUILD_NUMBER=39 +HS_BUILD_NUMBER=40 JDK_MAJOR_VER=1 JDK_MINOR_VER=8 From 0eb360620b9e470ea50a2a9260627e55f8fc6729 Mon Sep 17 00:00:00 2001 From: Doug Lea Date: Fri, 28 Jun 2013 12:10:18 +0100 Subject: [PATCH 075/127] 8017739: ReentrantReadWriteLock is confused by the Threads with reused IDs Reviewed-by: chegar --- .../locks/ReentrantReadWriteLock.java | 50 ++++++++++++++----- 1 file changed, 37 insertions(+), 13 deletions(-) diff --git a/jdk/src/share/classes/java/util/concurrent/locks/ReentrantReadWriteLock.java b/jdk/src/share/classes/java/util/concurrent/locks/ReentrantReadWriteLock.java index 3698bab27bb..519477e5244 100644 --- a/jdk/src/share/classes/java/util/concurrent/locks/ReentrantReadWriteLock.java +++ b/jdk/src/share/classes/java/util/concurrent/locks/ReentrantReadWriteLock.java @@ -45,7 +45,7 @@ import java.util.Collection; *
      *
    • Acquisition order * - *

      This class does not impose a reader or writer preference + *

      This class does not impose a reader or writer preference * ordering for lock access. However, it does support an optional * fairness policy. * @@ -59,7 +59,7 @@ import java.util.Collection; *

      * *

      Fair mode - *
      When constructed as fair, threads contend for entry using an + *
      When constructed as fair, threads contend for entry using an * approximately arrival-order policy. When the currently held lock * is released, either the longest-waiting single writer thread will * be assigned the write lock, or if there is a group of reader threads @@ -277,7 +277,7 @@ public class ReentrantReadWriteLock static final class HoldCounter { int count = 0; // Use id, not reference, to avoid garbage retention - final long tid = Thread.currentThread().getId(); + final long tid = getThreadId(Thread.currentThread()); } /** @@ -420,7 +420,7 @@ public class ReentrantReadWriteLock firstReaderHoldCount--; } else { HoldCounter rh = cachedHoldCounter; - if (rh == null || rh.tid != current.getId()) + if (rh == null || rh.tid != getThreadId(current)) rh = readHolds.get(); int count = rh.count; if (count <= 1) { @@ -478,7 +478,7 @@ public class ReentrantReadWriteLock firstReaderHoldCount++; } else { HoldCounter rh = cachedHoldCounter; - if (rh == null || rh.tid != current.getId()) + if (rh == null || rh.tid != getThreadId(current)) cachedHoldCounter = rh = readHolds.get(); else if (rh.count == 0) readHolds.set(rh); @@ -515,7 +515,7 @@ public class ReentrantReadWriteLock } else { if (rh == null) { rh = cachedHoldCounter; - if (rh == null || rh.tid != current.getId()) { + if (rh == null || rh.tid != getThreadId(current)) { rh = readHolds.get(); if (rh.count == 0) readHolds.remove(); @@ -536,7 +536,7 @@ public class ReentrantReadWriteLock } else { if (rh == null) rh = cachedHoldCounter; - if (rh == null || rh.tid != current.getId()) + if (rh == null || rh.tid != getThreadId(current)) rh = readHolds.get(); else if (rh.count == 0) readHolds.set(rh); @@ -592,7 +592,7 @@ public class ReentrantReadWriteLock firstReaderHoldCount++; } else { HoldCounter rh = cachedHoldCounter; - if (rh == null || rh.tid != current.getId()) + if (rh == null || rh.tid != getThreadId(current)) cachedHoldCounter = rh = readHolds.get(); else if (rh.count == 0) readHolds.set(rh); @@ -643,7 +643,7 @@ public class ReentrantReadWriteLock return firstReaderHoldCount; HoldCounter rh = cachedHoldCounter; - if (rh != null && rh.tid == current.getId()) + if (rh != null && rh.tid == getThreadId(current)) return rh.count; int count = readHolds.get().count; @@ -875,7 +875,7 @@ public class ReentrantReadWriteLock /** * Attempts to release this lock. * - *

      If the number of readers is now zero then the lock + *

      If the number of readers is now zero then the lock * is made available for write lock attempts. */ public void unlock() { @@ -1017,7 +1017,7 @@ public class ReentrantReadWriteLock * #tryLock(long, TimeUnit) tryLock(0, TimeUnit.SECONDS) } * which is almost equivalent (it also detects interruption). * - *

      If the current thread already holds this lock then the + *

      If the current thread already holds this lock then the * hold count is incremented by one and the method returns * {@code true}. * @@ -1126,7 +1126,7 @@ public class ReentrantReadWriteLock * IllegalMonitorStateException} is thrown. * * @throws IllegalMonitorStateException if the current thread does not - * hold this lock. + * hold this lock */ public void unlock() { sync.release(1); @@ -1254,7 +1254,7 @@ public class ReentrantReadWriteLock * Queries the number of read locks held for this lock. This * method is designed for use in monitoring system state, not for * synchronization control. - * @return the number of read locks held. + * @return the number of read locks held */ public int getReadLockCount() { return sync.getReadLockCount(); @@ -1484,4 +1484,28 @@ public class ReentrantReadWriteLock "[Write locks = " + w + ", Read locks = " + r + "]"; } + /** + * Returns the thread id for the given thread. We must access + * this directly rather than via method Thread.getId() because + * getId() is not final, and has been known to be overridden in + * ways that do not preserve unique mappings. + */ + static final long getThreadId(Thread thread) { + return UNSAFE.getLongVolatile(thread, TID_OFFSET); + } + + // Unsafe mechanics + private static final sun.misc.Unsafe UNSAFE; + private static final long TID_OFFSET; + static { + try { + UNSAFE = sun.misc.Unsafe.getUnsafe(); + Class tk = Thread.class; + TID_OFFSET = UNSAFE.objectFieldOffset + (tk.getDeclaredField("tid")); + } catch (Exception e) { + throw new Error(e); + } + } + } From 4535f67d050656b673e4d05101a3213f5dcc97f2 Mon Sep 17 00:00:00 2001 From: Doug Lea Date: Fri, 28 Jun 2013 12:12:37 +0100 Subject: [PATCH 076/127] 8019377: Sync j.u.c locks and atomic from 166 to tl Reviewed-by: chegar --- .../util/concurrent/atomic/AtomicBoolean.java | 10 +- .../util/concurrent/atomic/AtomicInteger.java | 20 ++-- .../concurrent/atomic/AtomicIntegerArray.java | 11 ++- .../atomic/AtomicIntegerFieldUpdater.java | 27 +++--- .../util/concurrent/atomic/AtomicLong.java | 20 ++-- .../concurrent/atomic/AtomicLongArray.java | 10 +- .../atomic/AtomicLongFieldUpdater.java | 32 ++++--- .../atomic/AtomicMarkableReference.java | 12 +-- .../concurrent/atomic/AtomicReference.java | 10 +- .../atomic/AtomicReferenceArray.java | 24 +++-- .../atomic/AtomicReferenceFieldUpdater.java | 39 ++++---- .../atomic/AtomicStampedReference.java | 12 +-- .../concurrent/atomic/DoubleAccumulator.java | 6 +- .../util/concurrent/atomic/DoubleAdder.java | 2 +- .../concurrent/atomic/LongAccumulator.java | 2 + .../util/concurrent/atomic/Striped64.java | 21 ++-- .../util/concurrent/atomic/package-info.java | 32 +++---- .../locks/AbstractOwnableSynchronizer.java | 20 ++-- .../locks/AbstractQueuedLongSynchronizer.java | 57 ++++++----- .../locks/AbstractQueuedSynchronizer.java | 95 +++++++++---------- .../java/util/concurrent/locks/Condition.java | 2 +- .../java/util/concurrent/locks/Lock.java | 8 +- .../util/concurrent/locks/LockSupport.java | 8 +- .../util/concurrent/locks/ReadWriteLock.java | 12 +-- .../util/concurrent/locks/ReentrantLock.java | 24 +++-- .../util/concurrent/locks/StampedLock.java | 19 ++-- 26 files changed, 267 insertions(+), 268 deletions(-) diff --git a/jdk/src/share/classes/java/util/concurrent/atomic/AtomicBoolean.java b/jdk/src/share/classes/java/util/concurrent/atomic/AtomicBoolean.java index 04bc975f9c8..bb2dd42e730 100644 --- a/jdk/src/share/classes/java/util/concurrent/atomic/AtomicBoolean.java +++ b/jdk/src/share/classes/java/util/concurrent/atomic/AtomicBoolean.java @@ -92,7 +92,7 @@ public class AtomicBoolean implements java.io.Serializable { * * @param expect the expected value * @param update the new value - * @return true if successful. False return indicates that + * @return {@code true} if successful. False return indicates that * the actual value was not equal to the expected value. */ public final boolean compareAndSet(boolean expect, boolean update) { @@ -105,13 +105,13 @@ public class AtomicBoolean implements java.io.Serializable { * Atomically sets the value to the given updated value * if the current value {@code ==} the expected value. * - *

      May fail spuriously - * and does not provide ordering guarantees, so is only rarely an - * appropriate alternative to {@code compareAndSet}. + *

      May fail + * spuriously and does not provide ordering guarantees, so is + * only rarely an appropriate alternative to {@code compareAndSet}. * * @param expect the expected value * @param update the new value - * @return true if successful + * @return {@code true} if successful */ public boolean weakCompareAndSet(boolean expect, boolean update) { int e = expect ? 1 : 0; diff --git a/jdk/src/share/classes/java/util/concurrent/atomic/AtomicInteger.java b/jdk/src/share/classes/java/util/concurrent/atomic/AtomicInteger.java index 8fed658a54c..c67e42f3bf1 100644 --- a/jdk/src/share/classes/java/util/concurrent/atomic/AtomicInteger.java +++ b/jdk/src/share/classes/java/util/concurrent/atomic/AtomicInteger.java @@ -126,7 +126,7 @@ public class AtomicInteger extends Number implements java.io.Serializable { * * @param expect the expected value * @param update the new value - * @return true if successful. False return indicates that + * @return {@code true} if successful. False return indicates that * the actual value was not equal to the expected value. */ public final boolean compareAndSet(int expect, int update) { @@ -137,13 +137,13 @@ public class AtomicInteger extends Number implements java.io.Serializable { * Atomically sets the value to the given updated value * if the current value {@code ==} the expected value. * - *

      May fail spuriously - * and does not provide ordering guarantees, so is only rarely an - * appropriate alternative to {@code compareAndSet}. + *

      May fail + * spuriously and does not provide ordering guarantees, so is + * only rarely an appropriate alternative to {@code compareAndSet}. * * @param expect the expected value * @param update the new value - * @return true if successful + * @return {@code true} if successful */ public final boolean weakCompareAndSet(int expect, int update) { return unsafe.compareAndSwapInt(this, valueOffset, expect, update); @@ -155,7 +155,7 @@ public class AtomicInteger extends Number implements java.io.Serializable { * @return the previous value */ public final int getAndIncrement() { - return getAndAdd(1); + return unsafe.getAndAddInt(this, valueOffset, 1); } /** @@ -164,7 +164,7 @@ public class AtomicInteger extends Number implements java.io.Serializable { * @return the previous value */ public final int getAndDecrement() { - return getAndAdd(-1); + return unsafe.getAndAddInt(this, valueOffset, -1); } /** @@ -183,7 +183,7 @@ public class AtomicInteger extends Number implements java.io.Serializable { * @return the updated value */ public final int incrementAndGet() { - return getAndAdd(1) + 1; + return unsafe.getAndAddInt(this, valueOffset, 1) + 1; } /** @@ -192,7 +192,7 @@ public class AtomicInteger extends Number implements java.io.Serializable { * @return the updated value */ public final int decrementAndGet() { - return getAndAdd(-1) - 1; + return unsafe.getAndAddInt(this, valueOffset, -1) - 1; } /** @@ -202,7 +202,7 @@ public class AtomicInteger extends Number implements java.io.Serializable { * @return the updated value */ public final int addAndGet(int delta) { - return getAndAdd(delta) + delta; + return unsafe.getAndAddInt(this, valueOffset, delta) + delta; } /** diff --git a/jdk/src/share/classes/java/util/concurrent/atomic/AtomicIntegerArray.java b/jdk/src/share/classes/java/util/concurrent/atomic/AtomicIntegerArray.java index 7c259fee06f..3cbf3f4b446 100644 --- a/jdk/src/share/classes/java/util/concurrent/atomic/AtomicIntegerArray.java +++ b/jdk/src/share/classes/java/util/concurrent/atomic/AtomicIntegerArray.java @@ -157,7 +157,7 @@ public class AtomicIntegerArray implements java.io.Serializable { * @param i the index * @param expect the expected value * @param update the new value - * @return true if successful. False return indicates that + * @return {@code true} if successful. False return indicates that * the actual value was not equal to the expected value. */ public final boolean compareAndSet(int i, int expect, int update) { @@ -172,14 +172,14 @@ public class AtomicIntegerArray implements java.io.Serializable { * Atomically sets the element at position {@code i} to the given * updated value if the current value {@code ==} the expected value. * - *

      May fail spuriously - * and does not provide ordering guarantees, so is only rarely an - * appropriate alternative to {@code compareAndSet}. + *

      May fail + * spuriously and does not provide ordering guarantees, so is + * only rarely an appropriate alternative to {@code compareAndSet}. * * @param i the index * @param expect the expected value * @param update the new value - * @return true if successful + * @return {@code true} if successful */ public final boolean weakCompareAndSet(int i, int expect, int update) { return compareAndSet(i, expect, update); @@ -247,6 +247,7 @@ public class AtomicIntegerArray implements java.io.Serializable { return getAndAdd(i, delta) + delta; } + /** * Atomically updates the element at index {@code i} with the results * of applying the given function, returning the previous value. The diff --git a/jdk/src/share/classes/java/util/concurrent/atomic/AtomicIntegerFieldUpdater.java b/jdk/src/share/classes/java/util/concurrent/atomic/AtomicIntegerFieldUpdater.java index e761b6ec73d..af72a4755d4 100644 --- a/jdk/src/share/classes/java/util/concurrent/atomic/AtomicIntegerFieldUpdater.java +++ b/jdk/src/share/classes/java/util/concurrent/atomic/AtomicIntegerFieldUpdater.java @@ -37,14 +37,13 @@ package java.util.concurrent.atomic; import java.util.function.IntUnaryOperator; import java.util.function.IntBinaryOperator; import sun.misc.Unsafe; -import sun.reflect.CallerSensitive; -import sun.reflect.Reflection; - import java.lang.reflect.Field; import java.lang.reflect.Modifier; import java.security.AccessController; import java.security.PrivilegedExceptionAction; import java.security.PrivilegedActionException; +import sun.reflect.CallerSensitive; +import sun.reflect.Reflection; /** * A reflection-based utility that enables atomic updates to @@ -81,8 +80,10 @@ public abstract class AtomicIntegerFieldUpdater { * access control */ @CallerSensitive - public static AtomicIntegerFieldUpdater newUpdater(Class tclass, String fieldName) { - return new AtomicIntegerFieldUpdaterImpl(tclass, fieldName, Reflection.getCallerClass()); + public static AtomicIntegerFieldUpdater newUpdater(Class tclass, + String fieldName) { + return new AtomicIntegerFieldUpdaterImpl + (tclass, fieldName, Reflection.getCallerClass()); } /** @@ -101,7 +102,7 @@ public abstract class AtomicIntegerFieldUpdater { * @param obj An object whose field to conditionally set * @param expect the expected value * @param update the new value - * @return true if successful + * @return {@code true} if successful * @throws ClassCastException if {@code obj} is not an instance * of the class possessing the field established in the constructor */ @@ -114,14 +115,14 @@ public abstract class AtomicIntegerFieldUpdater { * other calls to {@code compareAndSet} and {@code set}, but not * necessarily with respect to other changes in the field. * - *

      May fail spuriously - * and does not provide ordering guarantees, so is only rarely an - * appropriate alternative to {@code compareAndSet}. + *

      May fail + * spuriously and does not provide ordering guarantees, so is + * only rarely an appropriate alternative to {@code compareAndSet}. * * @param obj An object whose field to conditionally set * @param expect the expected value * @param update the new value - * @return true if successful + * @return {@code true} if successful * @throws ClassCastException if {@code obj} is not an instance * of the class possessing the field established in the constructor */ @@ -363,7 +364,8 @@ public abstract class AtomicIntegerFieldUpdater { /** * Standard hotspot implementation using intrinsics */ - private static class AtomicIntegerFieldUpdaterImpl extends AtomicIntegerFieldUpdater { + private static class AtomicIntegerFieldUpdaterImpl + extends AtomicIntegerFieldUpdater { private static final Unsafe unsafe = Unsafe.getUnsafe(); private final long offset; private final Class tclass; @@ -371,8 +373,7 @@ public abstract class AtomicIntegerFieldUpdater { AtomicIntegerFieldUpdaterImpl(final Class tclass, final String fieldName, - final Class caller) - { + final Class caller) { final Field field; final int modifiers; try { diff --git a/jdk/src/share/classes/java/util/concurrent/atomic/AtomicLong.java b/jdk/src/share/classes/java/util/concurrent/atomic/AtomicLong.java index 35af7759ac7..85ea910a96c 100644 --- a/jdk/src/share/classes/java/util/concurrent/atomic/AtomicLong.java +++ b/jdk/src/share/classes/java/util/concurrent/atomic/AtomicLong.java @@ -140,7 +140,7 @@ public class AtomicLong extends Number implements java.io.Serializable { * * @param expect the expected value * @param update the new value - * @return true if successful. False return indicates that + * @return {@code true} if successful. False return indicates that * the actual value was not equal to the expected value. */ public final boolean compareAndSet(long expect, long update) { @@ -151,13 +151,13 @@ public class AtomicLong extends Number implements java.io.Serializable { * Atomically sets the value to the given updated value * if the current value {@code ==} the expected value. * - *

      May fail spuriously - * and does not provide ordering guarantees, so is only rarely an - * appropriate alternative to {@code compareAndSet}. + *

      May fail + * spuriously and does not provide ordering guarantees, so is + * only rarely an appropriate alternative to {@code compareAndSet}. * * @param expect the expected value * @param update the new value - * @return true if successful + * @return {@code true} if successful */ public final boolean weakCompareAndSet(long expect, long update) { return unsafe.compareAndSwapLong(this, valueOffset, expect, update); @@ -169,7 +169,7 @@ public class AtomicLong extends Number implements java.io.Serializable { * @return the previous value */ public final long getAndIncrement() { - return getAndAdd(1); + return unsafe.getAndAddLong(this, valueOffset, 1L); } /** @@ -178,7 +178,7 @@ public class AtomicLong extends Number implements java.io.Serializable { * @return the previous value */ public final long getAndDecrement() { - return getAndAdd(-1); + return unsafe.getAndAddLong(this, valueOffset, -1L); } /** @@ -197,7 +197,7 @@ public class AtomicLong extends Number implements java.io.Serializable { * @return the updated value */ public final long incrementAndGet() { - return getAndAdd(1) + 1; + return unsafe.getAndAddLong(this, valueOffset, 1L) + 1L; } /** @@ -206,7 +206,7 @@ public class AtomicLong extends Number implements java.io.Serializable { * @return the updated value */ public final long decrementAndGet() { - return getAndAdd(-1) - 1; + return unsafe.getAndAddLong(this, valueOffset, -1L) - 1L; } /** @@ -216,7 +216,7 @@ public class AtomicLong extends Number implements java.io.Serializable { * @return the updated value */ public final long addAndGet(long delta) { - return getAndAdd(delta) + delta; + return unsafe.getAndAddLong(this, valueOffset, delta) + delta; } /** diff --git a/jdk/src/share/classes/java/util/concurrent/atomic/AtomicLongArray.java b/jdk/src/share/classes/java/util/concurrent/atomic/AtomicLongArray.java index 216479abeca..bf7aa6ecca8 100644 --- a/jdk/src/share/classes/java/util/concurrent/atomic/AtomicLongArray.java +++ b/jdk/src/share/classes/java/util/concurrent/atomic/AtomicLongArray.java @@ -156,7 +156,7 @@ public class AtomicLongArray implements java.io.Serializable { * @param i the index * @param expect the expected value * @param update the new value - * @return true if successful. False return indicates that + * @return {@code true} if successful. False return indicates that * the actual value was not equal to the expected value. */ public final boolean compareAndSet(int i, long expect, long update) { @@ -171,14 +171,14 @@ public class AtomicLongArray implements java.io.Serializable { * Atomically sets the element at position {@code i} to the given * updated value if the current value {@code ==} the expected value. * - *

      May fail spuriously - * and does not provide ordering guarantees, so is only rarely an - * appropriate alternative to {@code compareAndSet}. + *

      May fail + * spuriously and does not provide ordering guarantees, so is + * only rarely an appropriate alternative to {@code compareAndSet}. * * @param i the index * @param expect the expected value * @param update the new value - * @return true if successful + * @return {@code true} if successful */ public final boolean weakCompareAndSet(int i, long expect, long update) { return compareAndSet(i, expect, update); diff --git a/jdk/src/share/classes/java/util/concurrent/atomic/AtomicLongFieldUpdater.java b/jdk/src/share/classes/java/util/concurrent/atomic/AtomicLongFieldUpdater.java index 7ac0e73d601..9a298d64931 100644 --- a/jdk/src/share/classes/java/util/concurrent/atomic/AtomicLongFieldUpdater.java +++ b/jdk/src/share/classes/java/util/concurrent/atomic/AtomicLongFieldUpdater.java @@ -37,14 +37,13 @@ package java.util.concurrent.atomic; import java.util.function.LongUnaryOperator; import java.util.function.LongBinaryOperator; import sun.misc.Unsafe; -import sun.reflect.CallerSensitive; -import sun.reflect.Reflection; - import java.lang.reflect.Field; import java.lang.reflect.Modifier; import java.security.AccessController; import java.security.PrivilegedExceptionAction; import java.security.PrivilegedActionException; +import sun.reflect.CallerSensitive; +import sun.reflect.Reflection; /** * A reflection-based utility that enables atomic updates to @@ -71,17 +70,18 @@ public abstract class AtomicLongFieldUpdater { * generic types match. * * @param tclass the class of the objects holding the field - * @param fieldName the name of the field to be updated. + * @param fieldName the name of the field to be updated * @return the updater * @throws IllegalArgumentException if the field is not a - * volatile long type. + * volatile long type * @throws RuntimeException with a nested reflection-based * exception if the class does not hold field or is the wrong type, * or the field is inaccessible to the caller according to Java language * access control */ @CallerSensitive - public static AtomicLongFieldUpdater newUpdater(Class tclass, String fieldName) { + public static AtomicLongFieldUpdater newUpdater(Class tclass, + String fieldName) { Class caller = Reflection.getCallerClass(); if (AtomicLong.VM_SUPPORTS_LONG_CAS) return new CASUpdater(tclass, fieldName, caller); @@ -105,9 +105,9 @@ public abstract class AtomicLongFieldUpdater { * @param obj An object whose field to conditionally set * @param expect the expected value * @param update the new value - * @return true if successful + * @return {@code true} if successful * @throws ClassCastException if {@code obj} is not an instance - * of the class possessing the field established in the constructor. + * of the class possessing the field established in the constructor */ public abstract boolean compareAndSet(T obj, long expect, long update); @@ -118,16 +118,16 @@ public abstract class AtomicLongFieldUpdater { * other calls to {@code compareAndSet} and {@code set}, but not * necessarily with respect to other changes in the field. * - *

      May fail spuriously - * and does not provide ordering guarantees, so is only rarely an - * appropriate alternative to {@code compareAndSet}. + *

      May fail + * spuriously and does not provide ordering guarantees, so is + * only rarely an appropriate alternative to {@code compareAndSet}. * * @param obj An object whose field to conditionally set * @param expect the expected value * @param update the new value - * @return true if successful + * @return {@code true} if successful * @throws ClassCastException if {@code obj} is not an instance - * of the class possessing the field established in the constructor. + * of the class possessing the field established in the constructor */ public abstract boolean weakCompareAndSet(T obj, long expect, long update); @@ -370,7 +370,8 @@ public abstract class AtomicLongFieldUpdater { private final Class tclass; private final Class cclass; - CASUpdater(final Class tclass, final String fieldName, final Class caller) { + CASUpdater(final Class tclass, final String fieldName, + final Class caller) { final Field field; final int modifiers; try { @@ -493,7 +494,8 @@ public abstract class AtomicLongFieldUpdater { private final Class tclass; private final Class cclass; - LockedUpdater(final Class tclass, final String fieldName, final Class caller) { + LockedUpdater(final Class tclass, final String fieldName, + final Class caller) { Field field = null; int modifiers = 0; try { diff --git a/jdk/src/share/classes/java/util/concurrent/atomic/AtomicMarkableReference.java b/jdk/src/share/classes/java/util/concurrent/atomic/AtomicMarkableReference.java index b1dc71dfdce..f7becccb13a 100644 --- a/jdk/src/share/classes/java/util/concurrent/atomic/AtomicMarkableReference.java +++ b/jdk/src/share/classes/java/util/concurrent/atomic/AtomicMarkableReference.java @@ -112,15 +112,15 @@ public class AtomicMarkableReference { * current reference is {@code ==} to the expected reference * and the current mark is equal to the expected mark. * - *

      May fail spuriously - * and does not provide ordering guarantees, so is only rarely an - * appropriate alternative to {@code compareAndSet}. + *

      May fail + * spuriously and does not provide ordering guarantees, so is + * only rarely an appropriate alternative to {@code compareAndSet}. * * @param expectedReference the expected value of the reference * @param newReference the new value for the reference * @param expectedMark the expected value of the mark * @param newMark the new value for the mark - * @return true if successful + * @return {@code true} if successful */ public boolean weakCompareAndSet(V expectedReference, V newReference, @@ -140,7 +140,7 @@ public class AtomicMarkableReference { * @param newReference the new value for the reference * @param expectedMark the expected value of the mark * @param newMark the new value for the mark - * @return true if successful + * @return {@code true} if successful */ public boolean compareAndSet(V expectedReference, V newReference, @@ -178,7 +178,7 @@ public class AtomicMarkableReference { * * @param expectedReference the expected value of the reference * @param newMark the new value for the mark - * @return true if successful + * @return {@code true} if successful */ public boolean attemptMark(V expectedReference, boolean newMark) { Pair current = pair; diff --git a/jdk/src/share/classes/java/util/concurrent/atomic/AtomicReference.java b/jdk/src/share/classes/java/util/concurrent/atomic/AtomicReference.java index ddce0734300..04fbe52effa 100644 --- a/jdk/src/share/classes/java/util/concurrent/atomic/AtomicReference.java +++ b/jdk/src/share/classes/java/util/concurrent/atomic/AtomicReference.java @@ -109,7 +109,7 @@ public class AtomicReference implements java.io.Serializable { * if the current value {@code ==} the expected value. * @param expect the expected value * @param update the new value - * @return true if successful. False return indicates that + * @return {@code true} if successful. False return indicates that * the actual value was not equal to the expected value. */ public final boolean compareAndSet(V expect, V update) { @@ -120,13 +120,13 @@ public class AtomicReference implements java.io.Serializable { * Atomically sets the value to the given updated value * if the current value {@code ==} the expected value. * - *

      May fail spuriously - * and does not provide ordering guarantees, so is only rarely an - * appropriate alternative to {@code compareAndSet}. + *

      May fail + * spuriously and does not provide ordering guarantees, so is + * only rarely an appropriate alternative to {@code compareAndSet}. * * @param expect the expected value * @param update the new value - * @return true if successful + * @return {@code true} if successful */ public final boolean weakCompareAndSet(V expect, V update) { return unsafe.compareAndSwapObject(this, valueOffset, expect, update); diff --git a/jdk/src/share/classes/java/util/concurrent/atomic/AtomicReferenceArray.java b/jdk/src/share/classes/java/util/concurrent/atomic/AtomicReferenceArray.java index f8787ba1d40..4500bdf2fcb 100644 --- a/jdk/src/share/classes/java/util/concurrent/atomic/AtomicReferenceArray.java +++ b/jdk/src/share/classes/java/util/concurrent/atomic/AtomicReferenceArray.java @@ -34,10 +34,9 @@ */ package java.util.concurrent.atomic; - -import java.util.Arrays; import java.util.function.UnaryOperator; import java.util.function.BinaryOperator; +import java.util.Arrays; import java.lang.reflect.Array; import sun.misc.Unsafe; @@ -60,19 +59,18 @@ public class AtomicReferenceArray implements java.io.Serializable { private final Object[] array; // must have exact type Object[] static { - int scale; try { unsafe = Unsafe.getUnsafe(); arrayFieldOffset = unsafe.objectFieldOffset (AtomicReferenceArray.class.getDeclaredField("array")); base = unsafe.arrayBaseOffset(Object[].class); - scale = unsafe.arrayIndexScale(Object[].class); + int scale = unsafe.arrayIndexScale(Object[].class); + if ((scale & (scale - 1)) != 0) + throw new Error("data type scale not a power of two"); + shift = 31 - Integer.numberOfLeadingZeros(scale); } catch (Exception e) { throw new Error(e); } - if ((scale & (scale - 1)) != 0) - throw new Error("data type scale not a power of two"); - shift = 31 - Integer.numberOfLeadingZeros(scale); } private long checkedByteOffset(int i) { @@ -173,7 +171,7 @@ public class AtomicReferenceArray implements java.io.Serializable { * @param i the index * @param expect the expected value * @param update the new value - * @return true if successful. False return indicates that + * @return {@code true} if successful. False return indicates that * the actual value was not equal to the expected value. */ public final boolean compareAndSet(int i, E expect, E update) { @@ -188,20 +186,20 @@ public class AtomicReferenceArray implements java.io.Serializable { * Atomically sets the element at position {@code i} to the given * updated value if the current value {@code ==} the expected value. * - *

      May fail spuriously - * and does not provide ordering guarantees, so is only rarely an - * appropriate alternative to {@code compareAndSet}. + *

      May fail + * spuriously and does not provide ordering guarantees, so is + * only rarely an appropriate alternative to {@code compareAndSet}. * * @param i the index * @param expect the expected value * @param update the new value - * @return true if successful + * @return {@code true} if successful */ public final boolean weakCompareAndSet(int i, E expect, E update) { return compareAndSet(i, expect, update); } - /** + /** * Atomically updates the element at index {@code i} with the results * of applying the given function, returning the previous value. The * function should be side-effect-free, since it may be re-applied diff --git a/jdk/src/share/classes/java/util/concurrent/atomic/AtomicReferenceFieldUpdater.java b/jdk/src/share/classes/java/util/concurrent/atomic/AtomicReferenceFieldUpdater.java index 2cd0e1df369..901b71c9d2b 100644 --- a/jdk/src/share/classes/java/util/concurrent/atomic/AtomicReferenceFieldUpdater.java +++ b/jdk/src/share/classes/java/util/concurrent/atomic/AtomicReferenceFieldUpdater.java @@ -37,14 +37,13 @@ package java.util.concurrent.atomic; import java.util.function.UnaryOperator; import java.util.function.BinaryOperator; import sun.misc.Unsafe; -import sun.reflect.CallerSensitive; -import sun.reflect.Reflection; - import java.lang.reflect.Field; import java.lang.reflect.Modifier; import java.security.AccessController; import java.security.PrivilegedExceptionAction; import java.security.PrivilegedActionException; +import sun.reflect.CallerSensitive; +import sun.reflect.Reflection; /** * A reflection-based utility that enables atomic updates to @@ -82,29 +81,30 @@ import java.security.PrivilegedActionException; * @param The type of the object holding the updatable field * @param The type of the field */ -public abstract class AtomicReferenceFieldUpdater { +public abstract class AtomicReferenceFieldUpdater { /** * Creates and returns an updater for objects with the given field. * The Class arguments are needed to check that reflective types and * generic types match. * - * @param tclass the class of the objects holding the field. + * @param tclass the class of the objects holding the field * @param vclass the class of the field - * @param fieldName the name of the field to be updated. + * @param fieldName the name of the field to be updated * @return the updater - * @throws IllegalArgumentException if the field is not a volatile reference type. + * @throws ClassCastException if the field is of the wrong type + * @throws IllegalArgumentException if the field is not volatile * @throws RuntimeException with a nested reflection-based * exception if the class does not hold field or is the wrong type, * or the field is inaccessible to the caller according to Java language * access control */ @CallerSensitive - public static AtomicReferenceFieldUpdater newUpdater(Class tclass, Class vclass, String fieldName) { - return new AtomicReferenceFieldUpdaterImpl(tclass, - vclass, - fieldName, - Reflection.getCallerClass()); + public static AtomicReferenceFieldUpdater newUpdater(Class tclass, + Class vclass, + String fieldName) { + return new AtomicReferenceFieldUpdaterImpl + (tclass, vclass, fieldName, Reflection.getCallerClass()); } /** @@ -123,7 +123,7 @@ public abstract class AtomicReferenceFieldUpdater { * @param obj An object whose field to conditionally set * @param expect the expected value * @param update the new value - * @return true if successful + * @return {@code true} if successful */ public abstract boolean compareAndSet(T obj, V expect, V update); @@ -134,14 +134,14 @@ public abstract class AtomicReferenceFieldUpdater { * other calls to {@code compareAndSet} and {@code set}, but not * necessarily with respect to other changes in the field. * - *

      May fail spuriously - * and does not provide ordering guarantees, so is only rarely an - * appropriate alternative to {@code compareAndSet}. + *

      May fail + * spuriously and does not provide ordering guarantees, so is + * only rarely an appropriate alternative to {@code compareAndSet}. * * @param obj An object whose field to conditionally set * @param expect the expected value * @param update the new value - * @return true if successful + * @return {@code true} if successful */ public abstract boolean weakCompareAndSet(T obj, V expect, V update); @@ -301,10 +301,9 @@ public abstract class AtomicReferenceFieldUpdater { */ AtomicReferenceFieldUpdaterImpl(final Class tclass, - Class vclass, + final Class vclass, final String fieldName, - final Class caller) - { + final Class caller) { final Field field; final Class fieldClass; final int modifiers; diff --git a/jdk/src/share/classes/java/util/concurrent/atomic/AtomicStampedReference.java b/jdk/src/share/classes/java/util/concurrent/atomic/AtomicStampedReference.java index 5f8f1a03db9..56feb2febe7 100644 --- a/jdk/src/share/classes/java/util/concurrent/atomic/AtomicStampedReference.java +++ b/jdk/src/share/classes/java/util/concurrent/atomic/AtomicStampedReference.java @@ -112,15 +112,15 @@ public class AtomicStampedReference { * current reference is {@code ==} to the expected reference * and the current stamp is equal to the expected stamp. * - *

      May fail spuriously - * and does not provide ordering guarantees, so is only rarely an - * appropriate alternative to {@code compareAndSet}. + *

      May fail + * spuriously and does not provide ordering guarantees, so is + * only rarely an appropriate alternative to {@code compareAndSet}. * * @param expectedReference the expected value of the reference * @param newReference the new value for the reference * @param expectedStamp the expected value of the stamp * @param newStamp the new value for the stamp - * @return true if successful + * @return {@code true} if successful */ public boolean weakCompareAndSet(V expectedReference, V newReference, @@ -140,7 +140,7 @@ public class AtomicStampedReference { * @param newReference the new value for the reference * @param expectedStamp the expected value of the stamp * @param newStamp the new value for the stamp - * @return true if successful + * @return {@code true} if successful */ public boolean compareAndSet(V expectedReference, V newReference, @@ -178,7 +178,7 @@ public class AtomicStampedReference { * * @param expectedReference the expected value of the reference * @param newStamp the new value for the stamp - * @return true if successful + * @return {@code true} if successful */ public boolean attemptStamp(V expectedReference, int newStamp) { Pair current = pair; diff --git a/jdk/src/share/classes/java/util/concurrent/atomic/DoubleAccumulator.java b/jdk/src/share/classes/java/util/concurrent/atomic/DoubleAccumulator.java index 277f185f869..841f6477d46 100644 --- a/jdk/src/share/classes/java/util/concurrent/atomic/DoubleAccumulator.java +++ b/jdk/src/share/classes/java/util/concurrent/atomic/DoubleAccumulator.java @@ -65,7 +65,7 @@ import java.util.function.DoubleBinaryOperator; *

      Class {@link DoubleAdder} provides analogs of the functionality * of this class for the common special case of maintaining sums. The * call {@code new DoubleAdder()} is equivalent to {@code new - * DoubleAccumulator((x, y) -> x + y, 0.0}. + * DoubleAccumulator((x, y) -> x + y, 0.0)}. * *

      This class extends {@link Number}, but does not define * methods such as {@code equals}, {@code hashCode} and {@code @@ -84,11 +84,13 @@ public class DoubleAccumulator extends Striped64 implements Serializable { /** * Creates a new instance using the given accumulator function * and identity element. + * @param accumulatorFunction a side-effect-free function of two arguments + * @param identity identity (initial value) for the accumulator function */ public DoubleAccumulator(DoubleBinaryOperator accumulatorFunction, double identity) { this.function = accumulatorFunction; - base = this.identity = Double.doubleToRawLongBits(identity); + base = this.identity = Double.doubleToRawLongBits(identity); } /** diff --git a/jdk/src/share/classes/java/util/concurrent/atomic/DoubleAdder.java b/jdk/src/share/classes/java/util/concurrent/atomic/DoubleAdder.java index 30ff552747d..2db7ca89c59 100644 --- a/jdk/src/share/classes/java/util/concurrent/atomic/DoubleAdder.java +++ b/jdk/src/share/classes/java/util/concurrent/atomic/DoubleAdder.java @@ -63,7 +63,7 @@ import java.io.Serializable; public class DoubleAdder extends Striped64 implements Serializable { private static final long serialVersionUID = 7249069246863182397L; - /** + /* * Note that we must use "long" for underlying representations, * because there is no compareAndSet for double, due to the fact * that the bitwise equals used in any CAS implementation is not diff --git a/jdk/src/share/classes/java/util/concurrent/atomic/LongAccumulator.java b/jdk/src/share/classes/java/util/concurrent/atomic/LongAccumulator.java index bfddcd3dcbd..1289e6b52cf 100644 --- a/jdk/src/share/classes/java/util/concurrent/atomic/LongAccumulator.java +++ b/jdk/src/share/classes/java/util/concurrent/atomic/LongAccumulator.java @@ -86,6 +86,8 @@ public class LongAccumulator extends Striped64 implements Serializable { /** * Creates a new instance using the given accumulator function * and identity element. + * @param accumulatorFunction a side-effect-free function of two arguments + * @param identity identity (initial value) for the accumulator function */ public LongAccumulator(LongBinaryOperator accumulatorFunction, long identity) { diff --git a/jdk/src/share/classes/java/util/concurrent/atomic/Striped64.java b/jdk/src/share/classes/java/util/concurrent/atomic/Striped64.java index 708b4c2574f..16dcb4da6cc 100644 --- a/jdk/src/share/classes/java/util/concurrent/atomic/Striped64.java +++ b/jdk/src/share/classes/java/util/concurrent/atomic/Striped64.java @@ -52,13 +52,13 @@ abstract class Striped64 extends Number { * accessed directly by subclasses. * * Table entries are of class Cell; a variant of AtomicLong padded - * to reduce cache contention on most processors. Padding is - * overkill for most Atomics because they are usually irregularly - * scattered in memory and thus don't interfere much with each - * other. But Atomic objects residing in arrays will tend to be - * placed adjacent to each other, and so will most often share - * cache lines (with a huge negative performance impact) without - * this precaution. + * (via @sun.misc.Contended) to reduce cache contention. Padding + * is overkill for most Atomics because they are usually + * irregularly scattered in memory and thus don't interfere much + * with each other. But Atomic objects residing in arrays will + * tend to be placed adjacent to each other, and so will most + * often share cache lines (with a huge negative performance + * impact) without this precaution. * * In part because Cells are relatively large, we avoid creating * them until they are needed. When there is no contention, all @@ -112,18 +112,13 @@ abstract class Striped64 extends Number { /** * Padded variant of AtomicLong supporting only raw accesses plus CAS. - * The value field is placed between pads, hoping that the JVM doesn't - * reorder them. * * JVM intrinsics note: It would be possible to use a release-only * form of CAS here, if it were provided. */ - static final class Cell { - volatile long p0, p1, p2, p3, p4, p5, p6; + @sun.misc.Contended static final class Cell { volatile long value; - volatile long q0, q1, q2, q3, q4, q5, q6; Cell(long x) { value = x; } - final boolean cas(long cmp, long val) { return UNSAFE.compareAndSwapLong(this, valueOffset, cmp, val); } diff --git a/jdk/src/share/classes/java/util/concurrent/atomic/package-info.java b/jdk/src/share/classes/java/util/concurrent/atomic/package-info.java index 5cc25956255..ce497eb53b9 100644 --- a/jdk/src/share/classes/java/util/concurrent/atomic/package-info.java +++ b/jdk/src/share/classes/java/util/concurrent/atomic/package-info.java @@ -84,19 +84,18 @@ * write your utility method as follows: *

       {@code
        * long getAndTransform(AtomicLong var) {
      - *   while (true) {
      - *     long current = var.get();
      - *     long next = transform(current);
      - *     if (var.compareAndSet(current, next))
      - *         return current;
      - *         // return next; for transformAndGet
      - *   }
      + *   long prev, next;
      + *   do {
      + *     prev = var.get();
      + *     next = transform(prev);
      + *   } while (!var.compareAndSet(prev, next));
      + *   return prev; // return next; for transformAndGet
        * }}
      * *

      The memory effects for accesses and updates of atomics generally * follow the rules for volatiles, as stated in - * - * The Java Language Specification, Third Edition (17.4 Memory Model): + * + * The Java Language Specification (17.4 Memory Model): * *

        * @@ -152,13 +151,12 @@ * semantics for their array elements, which is not supported for * ordinary arrays. * - * - *

        The atomic classes also support method {@code weakCompareAndSet}, - * which has limited applicability. On some platforms, the weak version - * may be more efficient than {@code compareAndSet} in the normal case, - * but differs in that any given invocation of the - * {@code weakCompareAndSet} method may return {@code false} - * spuriously (that is, for no apparent reason). A + *

        The atomic classes also support method + * {@code weakCompareAndSet}, which has limited applicability. On some + * platforms, the weak version may be more efficient than {@code + * compareAndSet} in the normal case, but differs in that any given + * invocation of the {@code weakCompareAndSet} method may return {@code + * false} spuriously (that is, for no apparent reason). A * {@code false} return means only that the operation may be retried if * desired, relying on the guarantee that repeated invocation when the * variable holds {@code expectedValue} and no other thread is also @@ -194,7 +192,7 @@ * *

        Atomic classes are not general purpose replacements for * {@code java.lang.Integer} and related classes. They do not - * define methods such as {@code hashCode} and + * define methods such as {@code equals}, {@code hashCode} and * {@code compareTo}. (Because atomic variables are expected to be * mutated, they are poor choices for hash table keys.) Additionally, * classes are provided only for those types that are commonly useful in diff --git a/jdk/src/share/classes/java/util/concurrent/locks/AbstractOwnableSynchronizer.java b/jdk/src/share/classes/java/util/concurrent/locks/AbstractOwnableSynchronizer.java index 39a51e5a90c..30dec97a6e0 100644 --- a/jdk/src/share/classes/java/util/concurrent/locks/AbstractOwnableSynchronizer.java +++ b/jdk/src/share/classes/java/util/concurrent/locks/AbstractOwnableSynchronizer.java @@ -39,7 +39,7 @@ package java.util.concurrent.locks; * A synchronizer that may be exclusively owned by a thread. This * class provides a basis for creating locks and related synchronizers * that may entail a notion of ownership. The - * AbstractOwnableSynchronizer class itself does not manage or + * {@code AbstractOwnableSynchronizer} class itself does not manage or * use this information. However, subclasses and tools may use * appropriately maintained values to help control and monitor access * and provide diagnostics. @@ -64,20 +64,20 @@ public abstract class AbstractOwnableSynchronizer private transient Thread exclusiveOwnerThread; /** - * Sets the thread that currently owns exclusive access. A - * null argument indicates that no thread owns access. + * Sets the thread that currently owns exclusive access. + * A {@code null} argument indicates that no thread owns access. * This method does not otherwise impose any synchronization or - * volatile field accesses. + * {@code volatile} field accesses. + * @param thread the owner thread */ - protected final void setExclusiveOwnerThread(Thread t) { - exclusiveOwnerThread = t; + protected final void setExclusiveOwnerThread(Thread thread) { + exclusiveOwnerThread = thread; } /** - * Returns the thread last set by - * setExclusiveOwnerThread, or null if never - * set. This method does not otherwise impose any synchronization - * or volatile field accesses. + * Returns the thread last set by {@code setExclusiveOwnerThread}, + * or {@code null} if never set. This method does not otherwise + * impose any synchronization or {@code volatile} field accesses. * @return the owner thread */ protected final Thread getExclusiveOwnerThread() { diff --git a/jdk/src/share/classes/java/util/concurrent/locks/AbstractQueuedLongSynchronizer.java b/jdk/src/share/classes/java/util/concurrent/locks/AbstractQueuedLongSynchronizer.java index 46ad577cf10..4d885f44376 100644 --- a/jdk/src/share/classes/java/util/concurrent/locks/AbstractQueuedLongSynchronizer.java +++ b/jdk/src/share/classes/java/util/concurrent/locks/AbstractQueuedLongSynchronizer.java @@ -42,11 +42,11 @@ import sun.misc.Unsafe; /** * A version of {@link AbstractQueuedSynchronizer} in - * which synchronization state is maintained as a long. + * which synchronization state is maintained as a {@code long}. * This class has exactly the same structure, properties, and methods - * as AbstractQueuedSynchronizer with the exception + * as {@code AbstractQueuedSynchronizer} with the exception * that all state-related parameters and results are defined - * as long rather than int. This class + * as {@code long} rather than {@code int}. This class * may be useful when creating synchronizers such as * multilevel locks and barriers that require * 64 bits of state. @@ -71,7 +71,7 @@ public abstract class AbstractQueuedLongSynchronizer */ /** - * Creates a new AbstractQueuedLongSynchronizer instance + * Creates a new {@code AbstractQueuedLongSynchronizer} instance * with initial synchronization state of zero. */ protected AbstractQueuedLongSynchronizer() { } @@ -104,7 +104,7 @@ public abstract class AbstractQueuedLongSynchronizer * *

        Insertion into a CLH queue requires only a single atomic * operation on "tail", so there is a simple atomic point of - * demarcation from unqueued to queued. Similarly, dequeing + * demarcation from unqueued to queued. Similarly, dequeuing * involves only updating the "head". However, it takes a bit * more work for nodes to determine who their successors are, * in part to deal with possible cancellation due to timeouts @@ -211,7 +211,7 @@ public abstract class AbstractQueuedLongSynchronizer /** * Link to predecessor node that current node/thread relies on - * for checking waitStatus. Assigned during enqueing, and nulled + * for checking waitStatus. Assigned during enqueuing, and nulled * out (for sake of GC) only upon dequeuing. Also, upon * cancellation of a predecessor, we short-circuit while * finding a non-cancelled one, which will always exist @@ -256,7 +256,7 @@ public abstract class AbstractQueuedLongSynchronizer Node nextWaiter; /** - * Returns true if node is waiting in shared mode + * Returns true if node is waiting in shared mode. */ final boolean isShared() { return nextWaiter == SHARED; @@ -312,7 +312,7 @@ public abstract class AbstractQueuedLongSynchronizer /** * Returns the current value of synchronization state. - * This operation has memory semantics of a volatile read. + * This operation has memory semantics of a {@code volatile} read. * @return current state value */ protected final long getState() { @@ -321,7 +321,7 @@ public abstract class AbstractQueuedLongSynchronizer /** * Sets the value of synchronization state. - * This operation has memory semantics of a volatile write. + * This operation has memory semantics of a {@code volatile} write. * @param newState the new state value */ protected final void setState(long newState) { @@ -331,12 +331,12 @@ public abstract class AbstractQueuedLongSynchronizer /** * Atomically sets synchronization state to the given updated * value if the current state value equals the expected value. - * This operation has memory semantics of a volatile read + * This operation has memory semantics of a {@code volatile} read * and write. * * @param expect the expected value * @param update the new value - * @return true if successful. False return indicates that the actual + * @return {@code true} if successful. False return indicates that the actual * value was not equal to the expected value. */ protected final boolean compareAndSetState(long expect, long update) { @@ -441,7 +441,7 @@ public abstract class AbstractQueuedLongSynchronizer } /** - * Release action for shared mode -- signal successor and ensure + * Release action for shared mode -- signals successor and ensures * propagation. (Note: For exclusive mode, release just amounts * to calling unparkSuccessor of head if it needs signal.) */ @@ -562,7 +562,7 @@ public abstract class AbstractQueuedLongSynchronizer /** * Checks and updates status for a node that failed to acquire. * Returns true if thread should block. This is the main signal - * control in all acquire loops. Requires that pred == node.prev + * control in all acquire loops. Requires that pred == node.prev. * * @param pred node's predecessor holding status * @param node the node @@ -1066,7 +1066,7 @@ public abstract class AbstractQueuedLongSynchronizer * thread is queued, possibly repeatedly blocking and unblocking, * invoking {@link #tryAcquireShared} until success or the thread * is interrupted. - * @param arg the acquire argument + * @param arg the acquire argument. * This value is conveyed to {@link #tryAcquireShared} but is * otherwise uninterpreted and can represent anything * you like. @@ -1441,7 +1441,7 @@ public abstract class AbstractQueuedLongSynchronizer * Returns true if successful. * @param node the node * @return true if successfully transferred (else the node was - * cancelled before signal). + * cancelled before signal) */ final boolean transferForSignal(Node node) { /* @@ -1464,11 +1464,10 @@ public abstract class AbstractQueuedLongSynchronizer } /** - * Transfers node, if necessary, to sync queue after a cancelled - * wait. Returns true if thread was cancelled before being - * signalled. - * @param current the waiting thread - * @param node its node + * Transfers node, if necessary, to sync queue after a cancelled wait. + * Returns true if thread was cancelled before being signalled. + * + * @param node the node * @return true if cancelled before the node was signalled */ final boolean transferAfterCancelledWait(Node node) { @@ -1516,7 +1515,7 @@ public abstract class AbstractQueuedLongSynchronizer * uses this synchronizer as its lock. * * @param condition the condition - * @return true if owned + * @return {@code true} if owned * @throws NullPointerException if the condition is null */ public final boolean owns(ConditionObject condition) { @@ -1526,13 +1525,13 @@ public abstract class AbstractQueuedLongSynchronizer /** * Queries whether any threads are waiting on the given condition * associated with this synchronizer. Note that because timeouts - * and interrupts may occur at any time, a true return - * does not guarantee that a future signal will awaken + * and interrupts may occur at any time, a {@code true} return + * does not guarantee that a future {@code signal} will awaken * any threads. This method is designed primarily for use in * monitoring of the system state. * * @param condition the condition - * @return true if there are any waiting threads + * @return {@code true} if there are any waiting threads * @throws IllegalMonitorStateException if exclusive synchronization * is not held * @throws IllegalArgumentException if the given condition is @@ -1599,7 +1598,7 @@ public abstract class AbstractQueuedLongSynchronizer * and Condition users. Exported versions of this class will in * general need to be accompanied by documentation describing * condition semantics that rely on those of the associated - * AbstractQueuedLongSynchronizer. + * {@code AbstractQueuedLongSynchronizer}. * *

        This class is Serializable, but all fields are transient, * so deserialized conditions have no waiters. @@ -1614,7 +1613,7 @@ public abstract class AbstractQueuedLongSynchronizer private transient Node lastWaiter; /** - * Creates a new ConditionObject instance. + * Creates a new {@code ConditionObject} instance. */ public ConditionObject() { } @@ -1967,7 +1966,7 @@ public abstract class AbstractQueuedLongSynchronizer /** * Queries whether any threads are waiting on this condition. - * Implements {@link AbstractQueuedLongSynchronizer#hasWaiters}. + * Implements {@link AbstractQueuedLongSynchronizer#hasWaiters(ConditionObject)}. * * @return {@code true} if there are any waiting threads * @throws IllegalMonitorStateException if {@link #isHeldExclusively} @@ -1986,7 +1985,7 @@ public abstract class AbstractQueuedLongSynchronizer /** * Returns an estimate of the number of threads waiting on * this condition. - * Implements {@link AbstractQueuedLongSynchronizer#getWaitQueueLength}. + * Implements {@link AbstractQueuedLongSynchronizer#getWaitQueueLength(ConditionObject)}. * * @return the estimated number of waiting threads * @throws IllegalMonitorStateException if {@link #isHeldExclusively} @@ -2006,7 +2005,7 @@ public abstract class AbstractQueuedLongSynchronizer /** * Returns a collection containing those threads that may be * waiting on this Condition. - * Implements {@link AbstractQueuedLongSynchronizer#getWaitingThreads}. + * Implements {@link AbstractQueuedLongSynchronizer#getWaitingThreads(ConditionObject)}. * * @return the collection of threads * @throws IllegalMonitorStateException if {@link #isHeldExclusively} diff --git a/jdk/src/share/classes/java/util/concurrent/locks/AbstractQueuedSynchronizer.java b/jdk/src/share/classes/java/util/concurrent/locks/AbstractQueuedSynchronizer.java index 6f39256c0d6..f0bdeb9030e 100644 --- a/jdk/src/share/classes/java/util/concurrent/locks/AbstractQueuedSynchronizer.java +++ b/jdk/src/share/classes/java/util/concurrent/locks/AbstractQueuedSynchronizer.java @@ -45,12 +45,12 @@ import sun.misc.Unsafe; * synchronizers (semaphores, events, etc) that rely on * first-in-first-out (FIFO) wait queues. This class is designed to * be a useful basis for most kinds of synchronizers that rely on a - * single atomic int value to represent state. Subclasses + * single atomic {@code int} value to represent state. Subclasses * must define the protected methods that change this state, and which * define what that state means in terms of this object being acquired * or released. Given these, the other methods in this class carry * out all queuing and blocking mechanics. Subclasses can maintain - * other state fields, but only the atomically updated int + * other state fields, but only the atomically updated {@code int} * value manipulated using methods {@link #getState}, {@link * #setState} and {@link #compareAndSetState} is tracked with respect * to synchronization. @@ -58,7 +58,7 @@ import sun.misc.Unsafe; *

        Subclasses should be defined as non-public internal helper * classes that are used to implement the synchronization properties * of their enclosing class. Class - * AbstractQueuedSynchronizer does not implement any + * {@code AbstractQueuedSynchronizer} does not implement any * synchronization interface. Instead it defines methods such as * {@link #acquireInterruptibly} that can be invoked as * appropriate by concrete locks and related synchronizers to @@ -85,7 +85,7 @@ import sun.misc.Unsafe; * invoked with the current {@link #getState} value fully releases * this object, and {@link #acquire}, given this saved state value, * eventually restores this object to its previous acquired state. No - * AbstractQueuedSynchronizer method otherwise creates such a + * {@code AbstractQueuedSynchronizer} method otherwise creates such a * condition, so if this constraint cannot be met, do not use it. The * behavior of {@link ConditionObject} depends of course on the * semantics of its synchronizer implementation. @@ -93,13 +93,13 @@ import sun.misc.Unsafe; *

        This class provides inspection, instrumentation, and monitoring * methods for the internal queue, as well as similar methods for * condition objects. These can be exported as desired into classes - * using an AbstractQueuedSynchronizer for their + * using an {@code AbstractQueuedSynchronizer} for their * synchronization mechanics. * *

        Serialization of this class stores only the underlying atomic * integer maintaining state, so deserialized objects have empty * thread queues. Typical subclasses requiring serializability will - * define a readObject method that restores this to a known + * define a {@code readObject} method that restores this to a known * initial state upon deserialization. * *

        Usage

        @@ -115,14 +115,14 @@ import sun.misc.Unsafe; *
      • {@link #tryAcquireShared} *
      • {@link #tryReleaseShared} *
      • {@link #isHeldExclusively} - *
      + *
    * * Each of these methods by default throws {@link * UnsupportedOperationException}. Implementations of these methods * must be internally thread-safe, and should in general be short and * not block. Defining these methods is the only supported * means of using this class. All other methods are declared - * final because they cannot be independently varied. + * {@code final} because they cannot be independently varied. * *

    You may also find the inherited methods from {@link * AbstractOwnableSynchronizer} useful to keep track of the thread @@ -148,16 +148,16 @@ import sun.misc.Unsafe; * * (Shared mode is similar but may involve cascading signals.) * - *

    Because checks in acquire are invoked before + *

    Because checks in acquire are invoked before * enqueuing, a newly acquiring thread may barge ahead of * others that are blocked and queued. However, you can, if desired, - * define tryAcquire and/or tryAcquireShared to + * define {@code tryAcquire} and/or {@code tryAcquireShared} to * disable barging by internally invoking one or more of the inspection * methods, thereby providing a fair FIFO acquisition order. - * In particular, most fair synchronizers can define tryAcquire - * to return false if {@link #hasQueuedPredecessors} (a method + * In particular, most fair synchronizers can define {@code tryAcquire} + * to return {@code false} if {@link #hasQueuedPredecessors} (a method * specifically designed to be used by fair synchronizers) returns - * true. Other variations are possible. + * {@code true}. Other variations are possible. * *

    Throughput and scalability are generally highest for the * default barging (also known as greedy, @@ -167,7 +167,7 @@ import sun.misc.Unsafe; * threads, and each recontention has an unbiased chance to succeed * against incoming threads. Also, while acquires do not * "spin" in the usual sense, they may perform multiple - * invocations of tryAcquire interspersed with other + * invocations of {@code tryAcquire} interspersed with other * computations before blocking. This gives most of the benefits of * spins when exclusive synchronization is only briefly held, without * most of the liabilities when it isn't. If so desired, you can @@ -178,7 +178,7 @@ import sun.misc.Unsafe; * *

    This class provides an efficient and scalable basis for * synchronization in part by specializing its range of use to - * synchronizers that can rely on int state, acquire, and + * synchronizers that can rely on {@code int} state, acquire, and * release parameters, and an internal FIFO wait queue. When this does * not suffice, you can build synchronizers from a lower level using * {@link java.util.concurrent.atomic atomic} classes, your own custom @@ -200,12 +200,12 @@ import sun.misc.Unsafe; * * // Our internal helper class * private static class Sync extends AbstractQueuedSynchronizer { - * // Report whether in locked state + * // Reports whether in locked state * protected boolean isHeldExclusively() { * return getState() == 1; * } * - * // Acquire the lock if state is zero + * // Acquires the lock if state is zero * public boolean tryAcquire(int acquires) { * assert acquires == 1; // Otherwise unused * if (compareAndSetState(0, 1)) { @@ -215,7 +215,7 @@ import sun.misc.Unsafe; * return false; * } * - * // Release the lock by setting state to zero + * // Releases the lock by setting state to zero * protected boolean tryRelease(int releases) { * assert releases == 1; // Otherwise unused * if (getState() == 0) throw new IllegalMonitorStateException(); @@ -224,10 +224,10 @@ import sun.misc.Unsafe; * return true; * } * - * // Provide a Condition + * // Provides a Condition * Condition newCondition() { return new ConditionObject(); } * - * // Deserialize properly + * // Deserializes properly * private void readObject(ObjectInputStream s) * throws IOException, ClassNotFoundException { * s.defaultReadObject(); @@ -255,8 +255,8 @@ import sun.misc.Unsafe; * *

    Here is a latch class that is like a * {@link java.util.concurrent.CountDownLatch CountDownLatch} - * except that it only requires a single signal to - * fire. Because a latch is non-exclusive, it uses the shared + * except that it only requires a single {@code signal} to + * fire. Because a latch is non-exclusive, it uses the {@code shared} * acquire and release methods. * *

     {@code
    @@ -293,7 +293,7 @@ public abstract class AbstractQueuedSynchronizer
         private static final long serialVersionUID = 7373984972572414691L;
     
         /**
    -     * Creates a new AbstractQueuedSynchronizer instance
    +     * Creates a new {@code AbstractQueuedSynchronizer} instance
          * with initial synchronization state of zero.
          */
         protected AbstractQueuedSynchronizer() { }
    @@ -326,7 +326,7 @@ public abstract class AbstractQueuedSynchronizer
          *
          * 

    Insertion into a CLH queue requires only a single atomic * operation on "tail", so there is a simple atomic point of - * demarcation from unqueued to queued. Similarly, dequeing + * demarcation from unqueued to queued. Similarly, dequeuing * involves only updating the "head". However, it takes a bit * more work for nodes to determine who their successors are, * in part to deal with possible cancellation due to timeouts @@ -433,7 +433,7 @@ public abstract class AbstractQueuedSynchronizer /** * Link to predecessor node that current node/thread relies on - * for checking waitStatus. Assigned during enqueing, and nulled + * for checking waitStatus. Assigned during enqueuing, and nulled * out (for sake of GC) only upon dequeuing. Also, upon * cancellation of a predecessor, we short-circuit while * finding a non-cancelled one, which will always exist @@ -478,7 +478,7 @@ public abstract class AbstractQueuedSynchronizer Node nextWaiter; /** - * Returns true if node is waiting in shared mode + * Returns true if node is waiting in shared mode. */ final boolean isShared() { return nextWaiter == SHARED; @@ -534,7 +534,7 @@ public abstract class AbstractQueuedSynchronizer /** * Returns the current value of synchronization state. - * This operation has memory semantics of a volatile read. + * This operation has memory semantics of a {@code volatile} read. * @return current state value */ protected final int getState() { @@ -543,7 +543,7 @@ public abstract class AbstractQueuedSynchronizer /** * Sets the value of synchronization state. - * This operation has memory semantics of a volatile write. + * This operation has memory semantics of a {@code volatile} write. * @param newState the new state value */ protected final void setState(int newState) { @@ -553,12 +553,12 @@ public abstract class AbstractQueuedSynchronizer /** * Atomically sets synchronization state to the given updated * value if the current state value equals the expected value. - * This operation has memory semantics of a volatile read + * This operation has memory semantics of a {@code volatile} read * and write. * * @param expect the expected value * @param update the new value - * @return true if successful. False return indicates that the actual + * @return {@code true} if successful. False return indicates that the actual * value was not equal to the expected value. */ protected final boolean compareAndSetState(int expect, int update) { @@ -663,7 +663,7 @@ public abstract class AbstractQueuedSynchronizer } /** - * Release action for shared mode -- signal successor and ensure + * Release action for shared mode -- signals successor and ensures * propagation. (Note: For exclusive mode, release just amounts * to calling unparkSuccessor of head if it needs signal.) */ @@ -784,7 +784,7 @@ public abstract class AbstractQueuedSynchronizer /** * Checks and updates status for a node that failed to acquire. * Returns true if thread should block. This is the main signal - * control in all acquire loops. Requires that pred == node.prev + * control in all acquire loops. Requires that pred == node.prev. * * @param pred node's predecessor holding status * @param node the node @@ -1288,7 +1288,7 @@ public abstract class AbstractQueuedSynchronizer * thread is queued, possibly repeatedly blocking and unblocking, * invoking {@link #tryAcquireShared} until success or the thread * is interrupted. - * @param arg the acquire argument + * @param arg the acquire argument. * This value is conveyed to {@link #tryAcquireShared} but is * otherwise uninterpreted and can represent anything * you like. @@ -1663,7 +1663,7 @@ public abstract class AbstractQueuedSynchronizer * Returns true if successful. * @param node the node * @return true if successfully transferred (else the node was - * cancelled before signal). + * cancelled before signal) */ final boolean transferForSignal(Node node) { /* @@ -1686,11 +1686,10 @@ public abstract class AbstractQueuedSynchronizer } /** - * Transfers node, if necessary, to sync queue after a cancelled - * wait. Returns true if thread was cancelled before being - * signalled. - * @param current the waiting thread - * @param node its node + * Transfers node, if necessary, to sync queue after a cancelled wait. + * Returns true if thread was cancelled before being signalled. + * + * @param node the node * @return true if cancelled before the node was signalled */ final boolean transferAfterCancelledWait(Node node) { @@ -1738,7 +1737,7 @@ public abstract class AbstractQueuedSynchronizer * uses this synchronizer as its lock. * * @param condition the condition - * @return true if owned + * @return {@code true} if owned * @throws NullPointerException if the condition is null */ public final boolean owns(ConditionObject condition) { @@ -1748,13 +1747,13 @@ public abstract class AbstractQueuedSynchronizer /** * Queries whether any threads are waiting on the given condition * associated with this synchronizer. Note that because timeouts - * and interrupts may occur at any time, a true return - * does not guarantee that a future signal will awaken + * and interrupts may occur at any time, a {@code true} return + * does not guarantee that a future {@code signal} will awaken * any threads. This method is designed primarily for use in * monitoring of the system state. * * @param condition the condition - * @return true if there are any waiting threads + * @return {@code true} if there are any waiting threads * @throws IllegalMonitorStateException if exclusive synchronization * is not held * @throws IllegalArgumentException if the given condition is @@ -1821,7 +1820,7 @@ public abstract class AbstractQueuedSynchronizer * and Condition users. Exported versions of this class will in * general need to be accompanied by documentation describing * condition semantics that rely on those of the associated - * AbstractQueuedSynchronizer. + * {@code AbstractQueuedSynchronizer}. * *

    This class is Serializable, but all fields are transient, * so deserialized conditions have no waiters. @@ -1834,7 +1833,7 @@ public abstract class AbstractQueuedSynchronizer private transient Node lastWaiter; /** - * Creates a new ConditionObject instance. + * Creates a new {@code ConditionObject} instance. */ public ConditionObject() { } @@ -2187,7 +2186,7 @@ public abstract class AbstractQueuedSynchronizer /** * Queries whether any threads are waiting on this condition. - * Implements {@link AbstractQueuedSynchronizer#hasWaiters}. + * Implements {@link AbstractQueuedSynchronizer#hasWaiters(ConditionObject)}. * * @return {@code true} if there are any waiting threads * @throws IllegalMonitorStateException if {@link #isHeldExclusively} @@ -2206,7 +2205,7 @@ public abstract class AbstractQueuedSynchronizer /** * Returns an estimate of the number of threads waiting on * this condition. - * Implements {@link AbstractQueuedSynchronizer#getWaitQueueLength}. + * Implements {@link AbstractQueuedSynchronizer#getWaitQueueLength(ConditionObject)}. * * @return the estimated number of waiting threads * @throws IllegalMonitorStateException if {@link #isHeldExclusively} @@ -2226,7 +2225,7 @@ public abstract class AbstractQueuedSynchronizer /** * Returns a collection containing those threads that may be * waiting on this Condition. - * Implements {@link AbstractQueuedSynchronizer#getWaitingThreads}. + * Implements {@link AbstractQueuedSynchronizer#getWaitingThreads(ConditionObject)}. * * @return the collection of threads * @throws IllegalMonitorStateException if {@link #isHeldExclusively} diff --git a/jdk/src/share/classes/java/util/concurrent/locks/Condition.java b/jdk/src/share/classes/java/util/concurrent/locks/Condition.java index 02cbee904bc..06fb8f1cf02 100644 --- a/jdk/src/share/classes/java/util/concurrent/locks/Condition.java +++ b/jdk/src/share/classes/java/util/concurrent/locks/Condition.java @@ -324,7 +324,7 @@ public interface Condition { * } * }}

    * - *

    Design note: This method requires a nanosecond argument so + *

    Design note: This method requires a nanosecond argument so * as to avoid truncation errors in reporting remaining times. * Such precision loss would make it difficult for programmers to * ensure that total waiting times are not systematically shorter diff --git a/jdk/src/share/classes/java/util/concurrent/locks/Lock.java b/jdk/src/share/classes/java/util/concurrent/locks/Lock.java index d9ae1bcc4ed..371a6c7c13a 100644 --- a/jdk/src/share/classes/java/util/concurrent/locks/Lock.java +++ b/jdk/src/share/classes/java/util/concurrent/locks/Lock.java @@ -121,8 +121,8 @@ import java.util.concurrent.TimeUnit; *

    All {@code Lock} implementations must enforce the same * memory synchronization semantics as provided by the built-in monitor * lock, as described in - * - * The Java Language Specification, Third Edition (17.4 Memory Model): + * + * The Java Language Specification (17.4 Memory Model): *

      *
    • A successful {@code lock} operation has the same memory * synchronization effects as a successful Lock action. @@ -136,7 +136,7 @@ import java.util.concurrent.TimeUnit; * *

      Implementation Considerations

      * - *

      The three forms of lock acquisition (interruptible, + *

      The three forms of lock acquisition (interruptible, * non-interruptible, and timed) may differ in their performance * characteristics, ordering guarantees, or other implementation * qualities. Further, the ability to interrupt the ongoing @@ -227,7 +227,7 @@ public interface Lock { * * @throws InterruptedException if the current thread is * interrupted while acquiring the lock (and interruption - * of lock acquisition is supported). + * of lock acquisition is supported) */ void lockInterruptibly() throws InterruptedException; diff --git a/jdk/src/share/classes/java/util/concurrent/locks/LockSupport.java b/jdk/src/share/classes/java/util/concurrent/locks/LockSupport.java index 20abfacc3c8..46a0ab597c8 100644 --- a/jdk/src/share/classes/java/util/concurrent/locks/LockSupport.java +++ b/jdk/src/share/classes/java/util/concurrent/locks/LockSupport.java @@ -67,10 +67,10 @@ import sun.misc.Unsafe; * {@code blocker} object parameter. This object is recorded while * the thread is blocked to permit monitoring and diagnostic tools to * identify the reasons that threads are blocked. (Such tools may - * access blockers using method {@link #getBlocker}.) The use of these - * forms rather than the original forms without this parameter is - * strongly encouraged. The normal argument to supply as a - * {@code blocker} within a lock implementation is {@code this}. + * access blockers using method {@link #getBlocker(Thread)}.) + * The use of these forms rather than the original forms without this + * parameter is strongly encouraged. The normal argument to supply as + * a {@code blocker} within a lock implementation is {@code this}. * *

      These methods are designed to be used as tools for creating * higher-level synchronization utilities, and are not in themselves diff --git a/jdk/src/share/classes/java/util/concurrent/locks/ReadWriteLock.java b/jdk/src/share/classes/java/util/concurrent/locks/ReadWriteLock.java index fd6632b0b57..40b0f344238 100644 --- a/jdk/src/share/classes/java/util/concurrent/locks/ReadWriteLock.java +++ b/jdk/src/share/classes/java/util/concurrent/locks/ReadWriteLock.java @@ -36,16 +36,16 @@ package java.util.concurrent.locks; /** - * A ReadWriteLock maintains a pair of associated {@link + * A {@code ReadWriteLock} maintains a pair of associated {@link * Lock locks}, one for read-only operations and one for writing. * The {@link #readLock read lock} may be held simultaneously by * multiple reader threads, so long as there are no writers. The * {@link #writeLock write lock} is exclusive. * - *

      All ReadWriteLock implementations must guarantee that - * the memory synchronization effects of writeLock operations + *

      All {@code ReadWriteLock} implementations must guarantee that + * the memory synchronization effects of {@code writeLock} operations * (as specified in the {@link Lock} interface) also hold with respect - * to the associated readLock. That is, a thread successfully + * to the associated {@code readLock}. That is, a thread successfully * acquiring the read lock will see all updates made upon previous * release of the write lock. * @@ -120,14 +120,14 @@ public interface ReadWriteLock { /** * Returns the lock used for reading. * - * @return the lock used for reading. + * @return the lock used for reading */ Lock readLock(); /** * Returns the lock used for writing. * - * @return the lock used for writing. + * @return the lock used for writing */ Lock writeLock(); } diff --git a/jdk/src/share/classes/java/util/concurrent/locks/ReentrantLock.java b/jdk/src/share/classes/java/util/concurrent/locks/ReentrantLock.java index 5ca1335aaf6..06c7e61ab65 100644 --- a/jdk/src/share/classes/java/util/concurrent/locks/ReentrantLock.java +++ b/jdk/src/share/classes/java/util/concurrent/locks/ReentrantLock.java @@ -64,7 +64,7 @@ import java.util.Collection; * fair lock may obtain it multiple times in succession while other * active threads are not progressing and not currently holding the * lock. - * Also note that the untimed {@link #tryLock() tryLock} method does not + * Also note that the untimed {@link #tryLock()} method does not * honor the fairness setting. It will succeed if the lock * is available even if other threads are waiting. * @@ -88,10 +88,9 @@ import java.util.Collection; * }} * *

      In addition to implementing the {@link Lock} interface, this - * class defines methods {@code isLocked} and - * {@code getLockQueueLength}, as well as some associated - * {@code protected} access methods that may be useful for - * instrumentation and monitoring. + * class defines a number of {@code public} and {@code protected} + * methods for inspecting the state of the lock. Some of these + * methods are only useful for instrumentation and monitoring. * *

      Serialization of this class behaves in the same way as built-in * locks: a deserialized lock is in the unlocked state, regardless of @@ -124,9 +123,8 @@ public class ReentrantLock implements Lock, java.io.Serializable { abstract void lock(); /** - * Performs non-fair tryLock. tryAcquire is - * implemented in subclasses, but both need nonfair - * try for trylock method. + * Performs non-fair tryLock. tryAcquire is implemented in + * subclasses, but both need nonfair try for trylock method. */ final boolean nonfairTryAcquire(int acquires) { final Thread current = Thread.currentThread(); @@ -353,7 +351,7 @@ public class ReentrantLock implements Lock, java.io.Serializable { * {@link #tryLock(long, TimeUnit) tryLock(0, TimeUnit.SECONDS) } * which is almost equivalent (it also detects interruption). * - *

      If the current thread already holds this lock then the hold + *

      If the current thread already holds this lock then the hold * count is incremented by one and the method returns {@code true}. * *

      If the lock is held by another thread then this method will return @@ -538,10 +536,10 @@ public class ReentrantLock implements Lock, java.io.Serializable { /** * Queries if this lock is held by the current thread. * - *

      Analogous to the {@link Thread#holdsLock} method for built-in - * monitor locks, this method is typically used for debugging and - * testing. For example, a method that should only be called while - * a lock is held can assert that this is the case: + *

      Analogous to the {@link Thread#holdsLock(Object)} method for + * built-in monitor locks, this method is typically used for + * debugging and testing. For example, a method that should only be + * called while a lock is held can assert that this is the case: * *

       {@code
            * class X {
      diff --git a/jdk/src/share/classes/java/util/concurrent/locks/StampedLock.java b/jdk/src/share/classes/java/util/concurrent/locks/StampedLock.java
      index 0ca43f630f7..1506e5a4e46 100644
      --- a/jdk/src/share/classes/java/util/concurrent/locks/StampedLock.java
      +++ b/jdk/src/share/classes/java/util/concurrent/locks/StampedLock.java
      @@ -366,6 +366,8 @@ public class StampedLock implements java.io.Serializable {
            * Behavior under timeout and interruption matches that specified
            * for method {@link Lock#tryLock(long,TimeUnit)}.
            *
      +     * @param time the maximum time to wait for the lock
      +     * @param unit the time unit of the {@code time} argument
            * @return a stamp that can be used to unlock or convert mode,
            * or zero if the lock is not available
            * @throws InterruptedException if the current thread is interrupted
      @@ -445,6 +447,8 @@ public class StampedLock implements java.io.Serializable {
            * Behavior under timeout and interruption matches that specified
            * for method {@link Lock#tryLock(long,TimeUnit)}.
            *
      +     * @param time the maximum time to wait for the lock
      +     * @param unit the time unit of the {@code time} argument
            * @return a stamp that can be used to unlock or convert mode,
            * or zero if the lock is not available
            * @throws InterruptedException if the current thread is interrupted
      @@ -510,7 +514,8 @@ public class StampedLock implements java.io.Serializable {
            * obtained from {@link #tryOptimisticRead} or a locking method
            * for this lock has no defined effect or result.
            *
      -     * @return true if the lock has not been exclusively acquired
      +     * @param stamp a stamp
      +     * @return {@code true} if the lock has not been exclusively acquired
            * since issuance of the given stamp; else false
            */
           public boolean validate(long stamp) {
      @@ -723,7 +728,7 @@ public class StampedLock implements java.io.Serializable {
            * stamp value. This method may be useful for recovery after
            * errors.
            *
      -     * @return true if the lock was held, else false
      +     * @return {@code true} if the lock was held, else false
            */
           public boolean tryUnlockWrite() {
               long s; WNode h;
      @@ -741,7 +746,7 @@ public class StampedLock implements java.io.Serializable {
            * requiring a stamp value. This method may be useful for recovery
            * after errors.
            *
      -     * @return true if the read lock was held, else false
      +     * @return {@code true} if the read lock was held, else false
            */
           public boolean tryUnlockRead() {
               long s, m; WNode h;
      @@ -773,18 +778,18 @@ public class StampedLock implements java.io.Serializable {
           }
       
           /**
      -     * Returns true if the lock is currently held exclusively.
      +     * Returns {@code true} if the lock is currently held exclusively.
            *
      -     * @return true if the lock is currently held exclusively
      +     * @return {@code true} if the lock is currently held exclusively
            */
           public boolean isWriteLocked() {
               return (state & WBIT) != 0L;
           }
       
           /**
      -     * Returns true if the lock is currently held non-exclusively.
      +     * Returns {@code true} if the lock is currently held non-exclusively.
            *
      -     * @return true if the lock is currently held non-exclusively
      +     * @return {@code true} if the lock is currently held non-exclusively
            */
           public boolean isReadLocked() {
               return (state & RBITS) != 0L;
      
      From 0eb7f23c990e2498e709dfebc404156e1f500cad Mon Sep 17 00:00:00 2001
      From: Athijegannathan Sundararajan 
      Date: Fri, 28 Jun 2013 19:36:26 +0530
      Subject: [PATCH 077/127] 8019365: Error stack format
      
      Reviewed-by: hannesw
      ---
       .../src/jdk/nashorn/api/scripting/NashornException.java  | 5 +++--
       .../src/jdk/nashorn/internal/objects/NativeError.java    | 8 ++++++--
       nashorn/test/script/basic/JDK-8014781.js.EXPECTED        | 7 ++++---
       nashorn/test/script/basic/JDK-8017950.js.EXPECTED        | 9 +++++----
       nashorn/test/script/basic/JDK-8019226.js                 | 2 +-
       nashorn/test/script/basic/JDK-8019226.js.EXPECTED        | 7 ++++---
       6 files changed, 23 insertions(+), 15 deletions(-)
      
      diff --git a/nashorn/src/jdk/nashorn/api/scripting/NashornException.java b/nashorn/src/jdk/nashorn/api/scripting/NashornException.java
      index 0b479856630..3cd687cce08 100644
      --- a/nashorn/src/jdk/nashorn/api/scripting/NashornException.java
      +++ b/nashorn/src/jdk/nashorn/api/scripting/NashornException.java
      @@ -172,12 +172,13 @@ public abstract class NashornException extends RuntimeException {
               final StringBuilder buf = new StringBuilder();
               final StackTraceElement[] frames = getScriptFrames((Throwable)exception);
               for (final StackTraceElement st : frames) {
      +            buf.append("\tat ");
                   buf.append(st.getMethodName());
      -            buf.append(" @ ");
      +            buf.append(" (");
                   buf.append(st.getFileName());
                   buf.append(':');
                   buf.append(st.getLineNumber());
      -            buf.append('\n');
      +            buf.append(")\n");
               }
               final int len = buf.length();
               // remove trailing '\n'
      diff --git a/nashorn/src/jdk/nashorn/internal/objects/NativeError.java b/nashorn/src/jdk/nashorn/internal/objects/NativeError.java
      index 12029ad091b..25a3f3c74a6 100644
      --- a/nashorn/src/jdk/nashorn/internal/objects/NativeError.java
      +++ b/nashorn/src/jdk/nashorn/internal/objects/NativeError.java
      @@ -129,7 +129,7 @@ public final class NativeError extends ScriptObject {
               Global.checkObject(errorObj);
               final ScriptObject sobj = (ScriptObject)errorObj;
               final ECMAException exp = new ECMAException(sobj, null);
      -        sobj.set("stack", NashornException.getScriptStackString(exp), false);
      +        sobj.set("stack", getScriptStackString(sobj, exp), false);
               return UNDEFINED;
           }
       
      @@ -288,7 +288,7 @@ public final class NativeError extends ScriptObject {
       
               final Object exception = ECMAException.getException(sobj);
               if (exception instanceof Throwable) {
      -            return NashornException.getScriptStackString((Throwable)exception);
      +            return getScriptStackString(sobj, (Throwable)exception);
               } else {
                   return "";
               }
      @@ -362,4 +362,8 @@ public final class NativeError extends ScriptObject {
                   throw new MethodHandleFactory.LookupException(e);
               }
           }
      +
      +    private static String getScriptStackString(final ScriptObject sobj, final Throwable exp) {
      +        return JSType.toString(sobj) + "\n" + NashornException.getScriptStackString(exp);
      +    }
       }
      diff --git a/nashorn/test/script/basic/JDK-8014781.js.EXPECTED b/nashorn/test/script/basic/JDK-8014781.js.EXPECTED
      index 073d3b78bc8..d3586c0ee67 100644
      --- a/nashorn/test/script/basic/JDK-8014781.js.EXPECTED
      +++ b/nashorn/test/script/basic/JDK-8014781.js.EXPECTED
      @@ -1,3 +1,4 @@
      -MyError @ test/script/basic/JDK-8014781.js:32
      -func @ test/script/basic/JDK-8014781.js:36
      - @ test/script/basic/JDK-8014781.js:39
      +[object Object]
      +	at MyError (test/script/basic/JDK-8014781.js:32)
      +	at func (test/script/basic/JDK-8014781.js:36)
      +	at  (test/script/basic/JDK-8014781.js:39)
      diff --git a/nashorn/test/script/basic/JDK-8017950.js.EXPECTED b/nashorn/test/script/basic/JDK-8017950.js.EXPECTED
      index e86d02ef604..8c34d21343f 100644
      --- a/nashorn/test/script/basic/JDK-8017950.js.EXPECTED
      +++ b/nashorn/test/script/basic/JDK-8017950.js.EXPECTED
      @@ -1,4 +1,5 @@
      -func @ test/script/basic/JDK-8017950.js:33
      -f @ test/script/basic/JDK-8017950.js:40
      -g @ test/script/basic/JDK-8017950.js:44
      - @ test/script/basic/JDK-8017950.js:47
      +Error
      +	at func (test/script/basic/JDK-8017950.js:33)
      +	at f (test/script/basic/JDK-8017950.js:40)
      +	at g (test/script/basic/JDK-8017950.js:44)
      +	at  (test/script/basic/JDK-8017950.js:47)
      diff --git a/nashorn/test/script/basic/JDK-8019226.js b/nashorn/test/script/basic/JDK-8019226.js
      index 67bb67ae4ed..3a1cf2f901b 100644
      --- a/nashorn/test/script/basic/JDK-8019226.js
      +++ b/nashorn/test/script/basic/JDK-8019226.js
      @@ -30,7 +30,7 @@
       
       function func1() { func2() }
       
      -function func2() { throw new Error() }
      +function func2() { throw new Error("failed!") }
       
       try {
           func1()
      diff --git a/nashorn/test/script/basic/JDK-8019226.js.EXPECTED b/nashorn/test/script/basic/JDK-8019226.js.EXPECTED
      index 7833bb54706..002a3ddbf0e 100644
      --- a/nashorn/test/script/basic/JDK-8019226.js.EXPECTED
      +++ b/nashorn/test/script/basic/JDK-8019226.js.EXPECTED
      @@ -1,3 +1,4 @@
      -func2 @ test/script/basic/JDK-8019226.js:33
      -func1 @ test/script/basic/JDK-8019226.js:31
      - @ test/script/basic/JDK-8019226.js:36
      +Error: failed!
      +	at func2 (test/script/basic/JDK-8019226.js:33)
      +	at func1 (test/script/basic/JDK-8019226.js:31)
      +	at  (test/script/basic/JDK-8019226.js:36)
      
      From 681764bad08ef527b3ff24e3de3b35ad74a2d728 Mon Sep 17 00:00:00 2001
      From: Dmitry Markov 
      Date: Fri, 28 Jun 2013 18:32:20 +0400
      Subject: [PATCH 078/127] 8016534:
       javax/swing/text/View/8014863/bug8014863.java failed
      
      Reviewed-by: alexp, alexsch
      ---
       jdk/test/javax/swing/text/View/8014863/bug8014863.java | 7 +++++--
       1 file changed, 5 insertions(+), 2 deletions(-)
      
      diff --git a/jdk/test/javax/swing/text/View/8014863/bug8014863.java b/jdk/test/javax/swing/text/View/8014863/bug8014863.java
      index 3ceebd676f2..ba78b4bbbbb 100644
      --- a/jdk/test/javax/swing/text/View/8014863/bug8014863.java
      +++ b/jdk/test/javax/swing/text/View/8014863/bug8014863.java
      @@ -136,9 +136,12 @@ public class bug8014863 {
                               "qqqq pp qqqq pp qqqq pp qqqq pp" +
                               " qqqq pp qqqq pp qqqq pp qqqq

      "); editorPane.setCaretPosition(1); - + // An actual font size depends on OS and might be differnet on various OSs. + // It is necessary to calculate the width to meet the expected number of lines. + int width = SwingUtilities.computeStringWidth(editorPane.getFontMetrics(editorPane.getFont()), + "qqqq pp qqqq pp qqqq pp qqqqqqqq"); frame.add(editorPane); - frame.setSize(200, 200); + frame.setSize(width, 200); frame.setVisible(true); } }); From 8002fd8cbf9483fd1f2b53e4e9b461874fecb42c Mon Sep 17 00:00:00 2001 From: Alan Bateman Date: Fri, 28 Jun 2013 16:10:23 +0100 Subject: [PATCH 079/127] 8019380: doclint warnings in java.nio, java.nio.file.**, java.nio.channels.** Reviewed-by: chegar --- jdk/src/share/classes/java/nio/Buffer.java | 14 ++-- .../classes/java/nio/MappedByteBuffer.java | 2 +- .../classes/java/nio/X-Buffer.java.template | 64 +++++++++++-------- .../nio/channels/AsynchronousByteChannel.java | 4 ++ .../nio/channels/AsynchronousChannel.java | 2 +- .../channels/AsynchronousChannelGroup.java | 6 +- .../nio/channels/AsynchronousFileChannel.java | 8 +++ .../AsynchronousServerSocketChannel.java | 9 ++- .../channels/AsynchronousSocketChannel.java | 19 +++++- .../java/nio/channels/DatagramChannel.java | 5 +- .../java/nio/channels/FileChannel.java | 4 +- .../classes/java/nio/channels/FileLock.java | 7 +- .../java/nio/channels/MulticastChannel.java | 2 +- .../java/nio/channels/NetworkChannel.java | 4 ++ .../share/classes/java/nio/channels/Pipe.java | 13 ++-- .../java/nio/channels/SelectableChannel.java | 7 +- .../java/nio/channels/SelectionKey.java | 2 +- .../classes/java/nio/channels/Selector.java | 20 +++--- .../nio/channels/ServerSocketChannel.java | 5 +- .../java/nio/channels/SocketChannel.java | 7 +- .../spi/AbstractInterruptibleChannel.java | 2 +- .../spi/AbstractSelectableChannel.java | 10 +++ .../nio/channels/spi/AbstractSelector.java | 5 +- .../spi/AsynchronousChannelProvider.java | 4 ++ .../nio/channels/spi/SelectorProvider.java | 15 +++++ .../nio/charset/Charset-X-Coder.java.template | 16 +++++ .../classes/java/nio/charset/Charset.java | 9 ++- .../classes/java/nio/charset/CoderResult.java | 6 ++ .../java/nio/charset/spi/CharsetProvider.java | 4 +- .../classes/java/nio/file/FileStore.java | 2 + .../classes/java/nio/file/FileSystem.java | 2 +- .../classes/java/nio/file/FileSystems.java | 4 ++ .../share/classes/java/nio/file/Files.java | 23 +++++-- jdk/src/share/classes/java/nio/file/Path.java | 6 +- .../java/nio/file/SecureDirectoryStream.java | 6 ++ .../classes/java/nio/file/WatchEvent.java | 7 ++ .../classes/java/nio/file/WatchService.java | 2 +- .../java/nio/file/attribute/AclEntry.java | 18 +++++- .../file/attribute/AclFileAttributeView.java | 10 +-- .../nio/file/attribute/AttributeView.java | 2 + .../attribute/BasicFileAttributeView.java | 2 +- .../file/attribute/BasicFileAttributes.java | 11 ++++ .../file/attribute/DosFileAttributeView.java | 2 +- .../nio/file/attribute/FileAttribute.java | 4 ++ .../attribute/PosixFileAttributeView.java | 6 +- .../java/nio/file/spi/FileSystemProvider.java | 8 +++ jdk/src/share/classes/java/sql/SQLInput.java | 2 +- 47 files changed, 292 insertions(+), 100 deletions(-) diff --git a/jdk/src/share/classes/java/nio/Buffer.java b/jdk/src/share/classes/java/nio/Buffer.java index 068444a9758..f5a9cd4f675 100644 --- a/jdk/src/share/classes/java/nio/Buffer.java +++ b/jdk/src/share/classes/java/nio/Buffer.java @@ -52,7 +52,7 @@ import java.util.Spliterator; *

      There is one subclass of this class for each non-boolean primitive type. * * - *

      Transferring data

      + *

      Transferring data

      * *

      Each subclass of this class defines two categories of get and * put operations:

      @@ -78,7 +78,7 @@ import java.util.Spliterator; * current position. * * - *

      Marking and resetting

      + *

      Marking and resetting

      * *

      A buffer's mark is the index to which its position will be reset * when the {@link #reset reset} method is invoked. The mark is not always @@ -89,7 +89,7 @@ import java.util.Spliterator; * {@link InvalidMarkException} to be thrown. * * - *

      Invariants

      + *

      Invariants

      * *

      The following invariant holds for the mark, position, limit, and * capacity values: @@ -109,7 +109,7 @@ import java.util.Spliterator; * to zero. * * - *

      Clearing, flipping, and rewinding

      + *

      Clearing, flipping, and rewinding

      * *

      In addition to methods for accessing the position, limit, and capacity * values and for marking and resetting, this class also defines the following @@ -132,7 +132,7 @@ import java.util.Spliterator; *

    * * - *

    Read-only buffers

    + *

    Read-only buffers

    * *

    Every buffer is readable, but not every buffer is writable. The * mutation methods of each buffer class are specified as optional @@ -143,14 +143,14 @@ import java.util.Spliterator; * {@link #isReadOnly isReadOnly} method. * * - *

    Thread safety

    + *

    Thread safety

    * *

    Buffers are not safe for use by multiple concurrent threads. If a * buffer is to be used by more than one thread then access to the buffer * should be controlled by appropriate synchronization. * * - *

    Invocation chaining

    + *

    Invocation chaining

    * *

    Methods in this class that do not otherwise have a value to return are * specified to return the buffer upon which they are invoked. This allows diff --git a/jdk/src/share/classes/java/nio/MappedByteBuffer.java b/jdk/src/share/classes/java/nio/MappedByteBuffer.java index 1d26276f10c..25aa60e0b10 100644 --- a/jdk/src/share/classes/java/nio/MappedByteBuffer.java +++ b/jdk/src/share/classes/java/nio/MappedByteBuffer.java @@ -45,7 +45,7 @@ import sun.misc.Unsafe; * this program or another. Whether or not such changes occur, and when they * occur, is operating-system dependent and therefore unspecified. * - *

    All or part of a mapped byte buffer may become + *

    All or part of a mapped byte buffer may become * inaccessible at any time, for example if the mapped file is truncated. An * attempt to access an inaccessible region of a mapped byte buffer will not * change the buffer's content and will cause an unspecified exception to be diff --git a/jdk/src/share/classes/java/nio/X-Buffer.java.template b/jdk/src/share/classes/java/nio/X-Buffer.java.template index c3037adb4d2..03a7255c16a 100644 --- a/jdk/src/share/classes/java/nio/X-Buffer.java.template +++ b/jdk/src/share/classes/java/nio/X-Buffer.java.template @@ -44,23 +44,23 @@ import java.util.stream.$Streamtype$Stream; * *

      * - *
    • Absolute and relative {@link #get() get} and - * {@link #put($type$) put} methods that read and write + *

    • Absolute and relative {@link #get() get} and + * {@link #put($type$) put} methods that read and write * single $type$s;

    • * - *
    • Relative {@link #get($type$[]) bulk get} + *

    • Relative {@link #get($type$[]) bulk get} * methods that transfer contiguous sequences of $type$s from this buffer * into an array; {#if[!byte]?and}

    • * - *
    • Relative {@link #put($type$[]) bulk put} + *

    • Relative {@link #put($type$[]) bulk put} * methods that transfer contiguous sequences of $type$s from $a$ * $type$ array{#if[char]?, a string,} or some other $type$ * buffer into this buffer;{#if[!byte]? and}

    • * #if[byte] * - *
    • Absolute and relative {@link #getChar() get} - * and {@link #putChar(char) put} methods that read and + *

    • Absolute and relative {@link #getChar() get} + * and {@link #putChar(char) put} methods that read and * write values of other primitive types, translating them to and from * sequences of bytes in a particular byte order;

    • * @@ -70,23 +70,23 @@ import java.util.stream.$Streamtype$Stream; * #end[byte] * - *
    • Methods for {@link #compact compacting}, {@link - * #duplicate duplicating}, and {@link #slice - * slicing} $a$ $type$ buffer.

    • + *
    • Methods for {@link #compact compacting}, {@link + * #duplicate duplicating}, and {@link #slice slicing} + * $a$ $type$ buffer.

    • * *
    * *

    $Type$ buffers can be created either by {@link #allocate - * allocation}, which allocates space for the buffer's + * allocation}, which allocates space for the buffer's * #if[byte] * - * content, or by {@link #wrap($type$[]) wrapping} an + * content, or by {@link #wrap($type$[]) wrapping} an * existing $type$ array {#if[char]?or string} into a buffer. * #else[byte] * - * content, by {@link #wrap($type$[]) wrapping} an existing + * content, by {@link #wrap($type$[]) wrapping} an existing * $type$ array {#if[char]?or string} into a buffer, or by creating a * view of an existing byte buffer. * @@ -94,8 +94,8 @@ import java.util.stream.$Streamtype$Stream; * #if[byte] * - * - *

    Direct vs. non-direct buffers

    + * + *

    Direct vs. non-direct buffers

    * *

    A byte buffer is either direct or non-direct. Given a * direct byte buffer, the Java virtual machine will make a best effort to @@ -116,7 +116,7 @@ import java.util.stream.$Streamtype$Stream; * buffers only when they yield a measureable gain in program performance. * *

    A direct byte buffer may also be created by {@link - * java.nio.channels.FileChannel#map mapping} a region of a file + * java.nio.channels.FileChannel#map mapping} a region of a file * directly into memory. An implementation of the Java platform may optionally * support the creation of direct byte buffers from native code via JNI. If an * instance of one of these kinds of buffers refers to an inaccessible region @@ -129,8 +129,8 @@ import java.util.stream.$Streamtype$Stream; * that explicit buffer management can be done in performance-critical code. * * - * - *

    Access to binary data

    + * + *

    Access to binary data

    * *

    This class defines methods for reading and writing values of all other * primitive types, except boolean. Primitive values are translated @@ -156,7 +156,7 @@ import java.util.stream.$Streamtype$Stream; * parameters of the absolute get and put methods are in terms of * bytes rather than of the type being read or written. * - * + * * *

    For access to homogeneous binary data, that is, sequences of values of * the same type, this class defines methods that can create views of a @@ -214,7 +214,7 @@ import java.util.stream.$Streamtype$Stream; #end[char] * #if[byte] - *

    Invocation chaining

    + *

    Invocation chaining

    #end[byte] * *

    Methods in this class that do not otherwise have a value to return are @@ -297,7 +297,7 @@ public abstract class $Type$Buffer *

    The new buffer's position will be zero, its limit will be its * capacity, its mark will be undefined, and each of its elements will be * initialized to zero. Whether or not it has a - * {@link #hasArray backing array} is unspecified. + * {@link #hasArray backing array} is unspecified. * * @param capacity * The new buffer's capacity, in $type$s @@ -318,9 +318,8 @@ public abstract class $Type$Buffer * *

    The new buffer's position will be zero, its limit will be its * capacity, its mark will be undefined, and each of its elements will be - * initialized to zero. It will have a {@link #array - * backing array}, and its {@link #arrayOffset array - * offset} will be zero. + * initialized to zero. It will have a {@link #array backing array}, + * and its {@link #arrayOffset array offset} will be zero. * * @param capacity * The new buffer's capacity, in $type$s @@ -344,8 +343,8 @@ public abstract class $Type$Buffer * and vice versa. The new buffer's capacity will be * array.length, its position will be offset, its limit * will be offset + length, and its mark will be undefined. Its - * {@link #array backing array} will be the given array, and - * its {@link #arrayOffset array offset} will be zero.

    + * {@link #array backing array} will be the given array, and + * its {@link #arrayOffset array offset} will be zero.

    * * @param array * The array that will back the new buffer @@ -384,8 +383,8 @@ public abstract class $Type$Buffer * that is, modifications to the buffer will cause the array to be modified * and vice versa. The new buffer's capacity and limit will be * array.length, its position will be zero, and its mark will be - * undefined. Its {@link #array
    backing array} will be the - * given array, and its {@link #arrayOffset array offset} will + * undefined. Its {@link #array backing array} will be the + * given array, and its {@link #arrayOffset array offset>} will * be zero.

    * * @param array @@ -703,6 +702,9 @@ public abstract class $Type$Buffer *
          *     src.get(a, 0, a.length) 
    * + * @param dst + * The destination array + * * @return This buffer * * @throws BufferUnderflowException @@ -842,6 +844,9 @@ public abstract class $Type$Buffer *
          *     dst.put(a, 0, a.length) 
    * + * @param src + * The source array + * * @return This buffer * * @throws BufferOverflowException @@ -930,6 +935,9 @@ public abstract class $Type$Buffer *
          *     dst.put(s, 0, s.length()) 
    * + * @param src + * The source string + * * @return This buffer * * @throws BufferOverflowException @@ -1419,7 +1427,7 @@ public abstract class $Type$Buffer * *

    The byte order of $a$ $type$ buffer created by allocation or by * wrapping an existing $type$ array is the {@link - * ByteOrder#nativeOrder native order} of the underlying + * ByteOrder#nativeOrder native order} of the underlying * hardware. The byte order of $a$ $type$ buffer created as a view of a byte buffer is that of the * byte buffer at the moment that the view is created.

    diff --git a/jdk/src/share/classes/java/nio/channels/AsynchronousByteChannel.java b/jdk/src/share/classes/java/nio/channels/AsynchronousByteChannel.java index 9fdf7530d16..47ffc87a80b 100644 --- a/jdk/src/share/classes/java/nio/channels/AsynchronousByteChannel.java +++ b/jdk/src/share/classes/java/nio/channels/AsynchronousByteChannel.java @@ -87,6 +87,8 @@ public interface AsynchronousByteChannel * initiates a read operation before a previous read operation has * completed then a {@link ReadPendingException} will be thrown. * + * @param + * The type of the attachment * @param dst * The buffer into which bytes are to be transferred * @param attachment @@ -166,6 +168,8 @@ public interface AsynchronousByteChannel * initiates a write operation before a previous write operation has * completed then a {@link WritePendingException} will be thrown. * + * @param + * The type of the attachment * @param src * The buffer from which bytes are to be retrieved * @param attachment diff --git a/jdk/src/share/classes/java/nio/channels/AsynchronousChannel.java b/jdk/src/share/classes/java/nio/channels/AsynchronousChannel.java index 5aa9fe23b38..98e30d05e79 100644 --- a/jdk/src/share/classes/java/nio/channels/AsynchronousChannel.java +++ b/jdk/src/share/classes/java/nio/channels/AsynchronousChannel.java @@ -61,7 +61,7 @@ import java.util.concurrent.Future; // javadoc * may not allow more than one read and one write operation to be outstanding at * any given time. * - *

    Cancellation

    + *

    Cancellation

    * *

    The {@code Future} interface defines the {@link Future#cancel cancel} * method to cancel execution. This causes all threads waiting on the result of diff --git a/jdk/src/share/classes/java/nio/channels/AsynchronousChannelGroup.java b/jdk/src/share/classes/java/nio/channels/AsynchronousChannelGroup.java index 2eb4b5219d2..ace607323cb 100644 --- a/jdk/src/share/classes/java/nio/channels/AsynchronousChannelGroup.java +++ b/jdk/src/share/classes/java/nio/channels/AsynchronousChannelGroup.java @@ -60,7 +60,7 @@ import java.util.concurrent.TimeUnit; * default group is not configured then the pooled threads of the default group * are {@link Thread#isDaemon daemon} threads. * - * + *
    * * * @@ -89,7 +89,7 @@ import java.util.concurrent.TimeUnit; * *
    System propertyDescription
    * - *

    Threading

    + *

    Threading

    * *

    The completion handler for an I/O operation initiated on a channel bound * to a group is guaranteed to be invoked by one of the pooled threads in the @@ -104,7 +104,7 @@ import java.util.concurrent.TimeUnit; * handler directly by the initiating thread (see {@link * AsynchronousServerSocketChannel#accept(Object,CompletionHandler) accept}). * - *

    Shutdown and Termination

    + *

    Shutdown and Termination

    * *

    The {@link #shutdown() shutdown} method is used to initiate an orderly * shutdown of a group. An orderly shutdown marks the group as shutdown; diff --git a/jdk/src/share/classes/java/nio/channels/AsynchronousFileChannel.java b/jdk/src/share/classes/java/nio/channels/AsynchronousFileChannel.java index b1c6e788c50..c40fb376287 100644 --- a/jdk/src/share/classes/java/nio/channels/AsynchronousFileChannel.java +++ b/jdk/src/share/classes/java/nio/channels/AsynchronousFileChannel.java @@ -425,6 +425,8 @@ public abstract class AsynchronousFileChannel * They are not suitable for controlling access to a file by multiple * threads within the same virtual machine. * + * @param + * The type of the attachment * @param position * The position at which the locked region is to start; must be * non-negative @@ -473,6 +475,8 @@ public abstract class AsynchronousFileChannel * ch.{@link #lock(long,long,boolean,Object,CompletionHandler) lock}(0L, Long.MAX_VALUE, false, att, handler) * * + * @param + * The type of the attachment * @param attachment * The object to attach to the I/O operation; can be {@code null} * @param handler @@ -652,6 +656,8 @@ public abstract class AsynchronousFileChannel * If the given file position is greater than the file's size at the time * that the read is attempted then no bytes are read. * + * @param + * The type of the attachment * @param dst * The buffer into which bytes are to be transferred * @param position @@ -716,6 +722,8 @@ public abstract class AsynchronousFileChannel * bytes; the values of any bytes between the previous end-of-file and the * newly-written bytes are unspecified. * + * @param + * The type of the attachment * @param src * The buffer from which bytes are to be transferred * @param position diff --git a/jdk/src/share/classes/java/nio/channels/AsynchronousServerSocketChannel.java b/jdk/src/share/classes/java/nio/channels/AsynchronousServerSocketChannel.java index 477855572b5..75882008bd1 100644 --- a/jdk/src/share/classes/java/nio/channels/AsynchronousServerSocketChannel.java +++ b/jdk/src/share/classes/java/nio/channels/AsynchronousServerSocketChannel.java @@ -52,7 +52,7 @@ import java.io.IOException; *

    Socket options are configured using the {@link #setOption(SocketOption,Object) * setOption} method. Channels of this type support the following options: *

    - * + *
    * * * @@ -98,6 +98,9 @@ public abstract class AsynchronousServerSocketChannel /** * Initializes a new instance of this class. + * + * @param provider + * The provider that created this channel */ protected AsynchronousServerSocketChannel(AsynchronousChannelProvider provider) { this.provider = provider; @@ -105,6 +108,8 @@ public abstract class AsynchronousServerSocketChannel /** * Returns the provider that created this channel. + * + * @return The provider that created this channel */ public final AsynchronousChannelProvider provider() { return provider; @@ -263,6 +268,8 @@ public abstract class AsynchronousServerSocketChannel * the connection is closed and the operation completes with a {@link * SecurityException}. * + * @param + * The type of the attachment * @param attachment * The object to attach to the I/O operation; can be {@code null} * @param handler diff --git a/jdk/src/share/classes/java/nio/channels/AsynchronousSocketChannel.java b/jdk/src/share/classes/java/nio/channels/AsynchronousSocketChannel.java index 74c93c872af..2c2a1a306d5 100644 --- a/jdk/src/share/classes/java/nio/channels/AsynchronousSocketChannel.java +++ b/jdk/src/share/classes/java/nio/channels/AsynchronousSocketChannel.java @@ -62,7 +62,7 @@ import java.nio.ByteBuffer; *

    Socket options are configured using the {@link #setOption(SocketOption,Object) * setOption} method. Asynchronous socket channels support the following options: *

    - *
    Option NameDescription
    + *
    * * * @@ -91,7 +91,7 @@ import java.nio.ByteBuffer; * * Additional (implementation specific) options may also be supported. * - *

    Timeouts

    + *

    Timeouts

    * *

    The {@link #read(ByteBuffer,long,TimeUnit,Object,CompletionHandler) read} * and {@link #write(ByteBuffer,long,TimeUnit,Object,CompletionHandler) write} @@ -123,6 +123,9 @@ public abstract class AsynchronousSocketChannel /** * Initializes a new instance of this class. + * + * @param provider + * The provider that created this channel */ protected AsynchronousSocketChannel(AsynchronousChannelProvider provider) { this.provider = provider; @@ -130,6 +133,8 @@ public abstract class AsynchronousSocketChannel /** * Returns the provider that created this channel. + * + * @return The provider that created this channel */ public final AsynchronousChannelProvider provider() { return provider; @@ -287,6 +292,8 @@ public abstract class AsynchronousSocketChannel * java.lang.SecurityManager#checkConnect checkConnect} method permits * connecting to the address and port number of the given remote endpoint. * + * @param + * The type of the attachment * @param remote * The remote address to which this channel is to be connected * @param attachment @@ -365,6 +372,8 @@ public abstract class AsynchronousSocketChannel * AsynchronousByteChannel#read(ByteBuffer,Object,CompletionHandler)} * method. * + * @param + * The type of the attachment * @param dst * The buffer into which bytes are to be transferred * @param timeout @@ -461,6 +470,8 @@ public abstract class AsynchronousSocketChannel * read from the channel will cause an unspecific runtime exception to be * thrown. * + * @param + * The type of the attachment * @param dsts * The buffers into which bytes are to be transferred * @param offset @@ -520,6 +531,8 @@ public abstract class AsynchronousSocketChannel * AsynchronousByteChannel#write(ByteBuffer,Object,CompletionHandler)} * method. * + * @param + * The type of the attachment * @param src * The buffer from which bytes are to be retrieved * @param timeout @@ -610,6 +623,8 @@ public abstract class AsynchronousSocketChannel * to write to the channel will cause an unspecific runtime exception to be * thrown. * + * @param + * The type of the attachment * @param srcs * The buffers from which bytes are to be retrieved * @param offset diff --git a/jdk/src/share/classes/java/nio/channels/DatagramChannel.java b/jdk/src/share/classes/java/nio/channels/DatagramChannel.java index fd8b920eebd..3626317a982 100644 --- a/jdk/src/share/classes/java/nio/channels/DatagramChannel.java +++ b/jdk/src/share/classes/java/nio/channels/DatagramChannel.java @@ -57,7 +57,7 @@ import java.nio.channels.spi.SelectorProvider; * setOption} method. A datagram channel to an Internet Protocol socket supports * the following options: *

    - *
    Option NameDescription
    + *
    * * * @@ -117,6 +117,9 @@ public abstract class DatagramChannel /** * Initializes a new instance of this class. + * + * @param provider + * The provider that created this channel */ protected DatagramChannel(SelectorProvider provider) { super(provider); diff --git a/jdk/src/share/classes/java/nio/channels/FileChannel.java b/jdk/src/share/classes/java/nio/channels/FileChannel.java index 02d9082d230..57ce3e10d9e 100644 --- a/jdk/src/share/classes/java/nio/channels/FileChannel.java +++ b/jdk/src/share/classes/java/nio/channels/FileChannel.java @@ -46,7 +46,7 @@ import java.util.Collections; * of bytes that can be read and written and whose current {@link #size * size} can be queried. The size of the file increases * when bytes are written beyond its current size; the size of the file - * decreases when it is {@link #truncate truncated}. The + * decreases when it is {@link #truncate truncated}. The * file may also have some associated metadata such as access * permissions, content type, and last-modification time; this class does not * define methods for metadata access. @@ -830,7 +830,7 @@ public abstract class FileChannel *

    A region of a file may be mapped into memory in one of three modes: *

    * - *
      + *
        * *
      • Read-only: Any attempt to modify the resulting buffer * will cause a {@link java.nio.ReadOnlyBufferException} to be thrown. diff --git a/jdk/src/share/classes/java/nio/channels/FileLock.java b/jdk/src/share/classes/java/nio/channels/FileLock.java index e978af43179..fb584ee163e 100644 --- a/jdk/src/share/classes/java/nio/channels/FileLock.java +++ b/jdk/src/share/classes/java/nio/channels/FileLock.java @@ -72,7 +72,7 @@ import java.io.IOException; *

        File-lock objects are safe for use by multiple concurrent threads. * * - *

        Platform dependencies

        + *

        Platform dependencies

        * *

        This file-locking API is intended to map directly to the native locking * facility of the underlying operating system. Thus the locks held on a file @@ -261,6 +261,11 @@ public abstract class FileLock implements AutoCloseable { /** * Tells whether or not this lock overlaps the given lock range. * + * @param position + * The starting position of the lock range + * @param size + * The size of the lock range + * * @return true if, and only if, this lock and the given lock * range overlap by at least one byte */ diff --git a/jdk/src/share/classes/java/nio/channels/MulticastChannel.java b/jdk/src/share/classes/java/nio/channels/MulticastChannel.java index 0e06633b51f..ca17e2415ce 100644 --- a/jdk/src/share/classes/java/nio/channels/MulticastChannel.java +++ b/jdk/src/share/classes/java/nio/channels/MulticastChannel.java @@ -71,7 +71,7 @@ import java.net.StandardSocketOptions; // javadoc * MembershipKey#drop drop} method drops membership so that datagrams from the * source address can no longer be received. * - *

        Platform dependencies

        + *

        Platform dependencies

        * * The multicast implementation is intended to map directly to the native * multicasting facility. Consequently, the following items should be considered diff --git a/jdk/src/share/classes/java/nio/channels/NetworkChannel.java b/jdk/src/share/classes/java/nio/channels/NetworkChannel.java index 3900f9d284b..b56b5e25cce 100644 --- a/jdk/src/share/classes/java/nio/channels/NetworkChannel.java +++ b/jdk/src/share/classes/java/nio/channels/NetworkChannel.java @@ -106,6 +106,8 @@ public interface NetworkChannel /** * Sets the value of a socket option. * + * @param + * The type of the socket option value * @param name * The socket option * @param value @@ -130,6 +132,8 @@ public interface NetworkChannel /** * Returns the value of a socket option. * + * @param + * The type of the socket option value * @param name * The socket option * diff --git a/jdk/src/share/classes/java/nio/channels/Pipe.java b/jdk/src/share/classes/java/nio/channels/Pipe.java index af0722e99ab..4b5a5a51ca7 100644 --- a/jdk/src/share/classes/java/nio/channels/Pipe.java +++ b/jdk/src/share/classes/java/nio/channels/Pipe.java @@ -33,10 +33,9 @@ import java.nio.channels.spi.*; * A pair of channels that implements a unidirectional pipe. * *

        A pipe consists of a pair of channels: A writable {@link - * Pipe.SinkChannel sink} channel and a readable {@link - * Pipe.SourceChannel source} channel. Once some bytes are - * written to the sink channel they can be read from source channel in exactly - * the order in which they were written. + * Pipe.SinkChannel sink} channel and a readable {@link Pipe.SourceChannel source} + * channel. Once some bytes are written to the sink channel they can be read + * from source channel in exactlyAthe order in which they were written. * *

        Whether or not a thread writing bytes to a pipe will block until another * thread reads those bytes, or some previously-written bytes, from the pipe is @@ -63,6 +62,9 @@ public abstract class Pipe { { /** * Constructs a new instance of this class. + * + * @param provider + * The selector provider */ protected SourceChannel(SelectorProvider provider) { super(provider); @@ -94,6 +96,9 @@ public abstract class Pipe { { /** * Initializes a new instance of this class. + * + * @param provider + * The selector provider */ protected SinkChannel(SelectorProvider provider) { super(provider); diff --git a/jdk/src/share/classes/java/nio/channels/SelectableChannel.java b/jdk/src/share/classes/java/nio/channels/SelectableChannel.java index 7041c34e188..17f86831d6d 100644 --- a/jdk/src/share/classes/java/nio/channels/SelectableChannel.java +++ b/jdk/src/share/classes/java/nio/channels/SelectableChannel.java @@ -64,8 +64,8 @@ import java.nio.channels.spi.SelectorProvider; * threads.

        * * - * - *

        Blocking mode

        + *
        + *

        Blocking mode

        * * A selectable channel is either in blocking mode or in * non-blocking mode. In blocking mode, every I/O operation invoked @@ -142,6 +142,9 @@ public abstract class SelectableChannel * Retrieves the key representing the channel's registration with the given * selector. * + * @param sel + * The selector + * * @return The key returned when this channel was last registered with the * given selector, or null if this channel is not * currently registered with that selector diff --git a/jdk/src/share/classes/java/nio/channels/SelectionKey.java b/jdk/src/share/classes/java/nio/channels/SelectionKey.java index 7a0ab88ac3e..e140ee61952 100644 --- a/jdk/src/share/classes/java/nio/channels/SelectionKey.java +++ b/jdk/src/share/classes/java/nio/channels/SelectionKey.java @@ -42,7 +42,7 @@ import java.io.IOException; * next selection operation. The validity of a key may be tested by invoking * its {@link #isValid isValid} method. * - * + * * *

        A selection key contains two operation sets represented as * integer values. Each bit of an operation set denotes a category of diff --git a/jdk/src/share/classes/java/nio/channels/Selector.java b/jdk/src/share/classes/java/nio/channels/Selector.java index d4c200e6942..3f21727f220 100644 --- a/jdk/src/share/classes/java/nio/channels/Selector.java +++ b/jdk/src/share/classes/java/nio/channels/Selector.java @@ -36,13 +36,13 @@ import java.util.Set; * *

        A selector may be created by invoking the {@link #open open} method of * this class, which will use the system's default {@link - * java.nio.channels.spi.SelectorProvider selector provider} to + * java.nio.channels.spi.SelectorProvider selector provider} to * create a new selector. A selector may also be created by invoking the * {@link java.nio.channels.spi.SelectorProvider#openSelector openSelector} * method of a custom selector provider. A selector remains open until it is * closed via its {@link #close close} method. * - * + * * *

        A selectable channel's registration with a selector is represented by a * {@link SelectionKey} object. A selector maintains three sets of selection @@ -80,18 +80,18 @@ import java.util.Set; * during the next selection operation, at which time the key will removed from * all of the selector's key sets. * - *

        Keys are added to the selected-key set by selection + *

        Keys are added to the selected-key set by selection * operations. A key may be removed directly from the selected-key set by * invoking the set's {@link java.util.Set#remove(java.lang.Object) remove} * method or by invoking the {@link java.util.Iterator#remove() remove} method - * of an {@link java.util.Iterator iterator} obtained from the + * of an {@link java.util.Iterator iterator} obtained from the * set. Keys are never removed from the selected-key set in any other way; * they are not, in particular, removed as a side effect of selection * operations. Keys may not be added directly to the selected-key set.

        * * - * - *

        Selection

        + *
        + *

        Selection

        * *

        During each selection operation, keys may be added to and removed from a * selector's selected-key set and may be removed from its key and @@ -111,7 +111,7 @@ import java.util.Set; * operation began. For a channel that is ready for at least one such * operation, one of the following two actions is performed:

        * - *
          + *
            * *
          1. If the channel's key is not already in the selected-key set then * it is added to that set and its ready-operation set is modified to @@ -126,7 +126,7 @@ import java.util.Set; * words, the ready set returned by the underlying system is * bitwise-disjoined into the key's current ready set.

          2. * - *
          + *
        * * If all of the keys in the key set at the start of this step have empty * interest sets then neither the selected-key set nor any of the keys' @@ -142,7 +142,7 @@ import java.util.Set; * difference between the three selection methods.

        * * - *

        Concurrency

        + *

        Concurrency

        * *

        Selectors are themselves safe for use by multiple concurrent threads; * their key sets, however, are not. @@ -183,7 +183,7 @@ import java.util.Set; *

        The {@link #close close} method synchronizes on the selector and all * three key sets in the same order as in a selection operation. * - * + * * *

        A selector's key and selected-key sets are not, in general, safe for use * by multiple concurrent threads. If such a thread might modify one of these diff --git a/jdk/src/share/classes/java/nio/channels/ServerSocketChannel.java b/jdk/src/share/classes/java/nio/channels/ServerSocketChannel.java index 90e39b529a4..aeda90df031 100644 --- a/jdk/src/share/classes/java/nio/channels/ServerSocketChannel.java +++ b/jdk/src/share/classes/java/nio/channels/ServerSocketChannel.java @@ -46,7 +46,7 @@ import java.nio.channels.spi.SelectorProvider; *

        Socket options are configured using the {@link #setOption(SocketOption,Object) * setOption} method. Server-socket channels support the following options: *

        - *
    Option NameDescription
    + *
    * * * @@ -78,6 +78,9 @@ public abstract class ServerSocketChannel /** * Initializes a new instance of this class. + * + * @param provider + * The provider that created this channel */ protected ServerSocketChannel(SelectorProvider provider) { super(provider); diff --git a/jdk/src/share/classes/java/nio/channels/SocketChannel.java b/jdk/src/share/classes/java/nio/channels/SocketChannel.java index 62033264904..091570cbf64 100644 --- a/jdk/src/share/classes/java/nio/channels/SocketChannel.java +++ b/jdk/src/share/classes/java/nio/channels/SocketChannel.java @@ -66,7 +66,7 @@ import java.nio.channels.spi.SelectorProvider; *

    Socket options are configured using the {@link #setOption(SocketOption,Object) * setOption} method. Socket channels support the following options: *

    - *
    Option NameDescription
    + *
    * * * @@ -120,6 +120,9 @@ public abstract class SocketChannel /** * Initializes a new instance of this class. + * + * @param provider + * The provider that created this channel */ protected SocketChannel(SelectorProvider provider) { super(provider); @@ -153,6 +156,8 @@ public abstract class SocketChannel * @param remote * The remote address to which the new channel is to be connected * + * @return A new, and connected, socket channel + * * @throws AsynchronousCloseException * If another thread closes this channel * while the connect operation is in progress diff --git a/jdk/src/share/classes/java/nio/channels/spi/AbstractInterruptibleChannel.java b/jdk/src/share/classes/java/nio/channels/spi/AbstractInterruptibleChannel.java index a5936832b7a..c8400692ee9 100644 --- a/jdk/src/share/classes/java/nio/channels/spi/AbstractInterruptibleChannel.java +++ b/jdk/src/share/classes/java/nio/channels/spi/AbstractInterruptibleChannel.java @@ -46,7 +46,7 @@ import sun.nio.ch.Interruptible; * before and after, respectively, invoking an I/O operation that might block * indefinitely. In order to ensure that the {@link #end end} method is always * invoked, these methods should be used within a - * try ... finally block: + * try ... finally block: * *
      * boolean completed = false;
    diff --git a/jdk/src/share/classes/java/nio/channels/spi/AbstractSelectableChannel.java b/jdk/src/share/classes/java/nio/channels/spi/AbstractSelectableChannel.java
    index e674d501718..5d1b1ee99a1 100644
    --- a/jdk/src/share/classes/java/nio/channels/spi/AbstractSelectableChannel.java
    +++ b/jdk/src/share/classes/java/nio/channels/spi/AbstractSelectableChannel.java
    @@ -72,6 +72,9 @@ public abstract class AbstractSelectableChannel
     
         /**
          * Initializes a new instance of this class.
    +     *
    +     * @param  provider
    +     *         The provider that created this channel
          */
         protected AbstractSelectableChannel(SelectorProvider provider) {
             this.provider = provider;
    @@ -251,6 +254,9 @@ public abstract class AbstractSelectableChannel
          * that is blocked in an I/O operation upon this channel to return
          * immediately, either by throwing an exception or by returning normally.
          * 

    + * + * @throws IOException + * If an I/O error occurs */ protected abstract void implCloseSelectableChannel() throws IOException; @@ -299,6 +305,10 @@ public abstract class AbstractSelectableChannel * changing the blocking mode. This method is only invoked if the new mode * is different from the current mode.

    * + * @param block If true then this channel will be placed in + * blocking mode; if false then it will be placed + * non-blocking mode + * * @throws IOException * If an I/O error occurs */ diff --git a/jdk/src/share/classes/java/nio/channels/spi/AbstractSelector.java b/jdk/src/share/classes/java/nio/channels/spi/AbstractSelector.java index fea4b0972e9..f4f4a2a74de 100644 --- a/jdk/src/share/classes/java/nio/channels/spi/AbstractSelector.java +++ b/jdk/src/share/classes/java/nio/channels/spi/AbstractSelector.java @@ -43,7 +43,7 @@ import java.util.concurrent.atomic.AtomicBoolean; * after, respectively, invoking an I/O operation that might block * indefinitely. In order to ensure that the {@link #end end} method is always * invoked, these methods should be used within a - * try ... finally block:
    + * try ... finally block: * *
      * try {
    @@ -77,6 +77,9 @@ public abstract class AbstractSelector
     
         /**
          * Initializes a new instance of this class.
    +     *
    +     * @param  provider
    +     *         The provider that created this selector
          */
         protected AbstractSelector(SelectorProvider provider) {
             this.provider = provider;
    diff --git a/jdk/src/share/classes/java/nio/channels/spi/AsynchronousChannelProvider.java b/jdk/src/share/classes/java/nio/channels/spi/AsynchronousChannelProvider.java
    index 827a2c5b981..e768e475c35 100644
    --- a/jdk/src/share/classes/java/nio/channels/spi/AsynchronousChannelProvider.java
    +++ b/jdk/src/share/classes/java/nio/channels/spi/AsynchronousChannelProvider.java
    @@ -174,6 +174,8 @@ public abstract class AsynchronousChannelProvider {
          * @param   threadFactory
          *          The factory to use when creating new threads
          *
    +     * @return  A new asynchronous channel group
    +     *
          * @throws  IllegalArgumentException
          *          If {@code nThreads <= 0}
          * @throws  IOException
    @@ -193,6 +195,8 @@ public abstract class AsynchronousChannelProvider {
          *          A value {@code >=0} or a negative value for implementation
          *          specific default
          *
    +     * @return  A new asynchronous channel group
    +     *
          * @throws  IOException
          *          If an I/O error occurs
          *
    diff --git a/jdk/src/share/classes/java/nio/channels/spi/SelectorProvider.java b/jdk/src/share/classes/java/nio/channels/spi/SelectorProvider.java
    index 62d4bf6ffc0..8d74b43cf64 100644
    --- a/jdk/src/share/classes/java/nio/channels/spi/SelectorProvider.java
    +++ b/jdk/src/share/classes/java/nio/channels/spi/SelectorProvider.java
    @@ -183,6 +183,9 @@ public abstract class SelectorProvider {
          * Opens a datagram channel.
          *
          * @return  The new channel
    +     *
    +     * @throws  IOException
    +     *          If an I/O error occurs
          */
         public abstract DatagramChannel openDatagramChannel()
             throws IOException;
    @@ -209,6 +212,9 @@ public abstract class SelectorProvider {
          * Opens a pipe.
          *
          * @return  The new pipe
    +     *
    +     * @throws  IOException
    +     *          If an I/O error occurs
          */
         public abstract Pipe openPipe()
             throws IOException;
    @@ -217,6 +223,9 @@ public abstract class SelectorProvider {
          * Opens a selector.
          *
          * @return  The new selector
    +     *
    +     * @throws  IOException
    +     *          If an I/O error occurs
          */
         public abstract AbstractSelector openSelector()
             throws IOException;
    @@ -225,6 +234,9 @@ public abstract class SelectorProvider {
          * Opens a server-socket channel.
          *
          * @return  The new channel
    +     *
    +     * @throws  IOException
    +     *          If an I/O error occurs
          */
         public abstract ServerSocketChannel openServerSocketChannel()
             throws IOException;
    @@ -233,6 +245,9 @@ public abstract class SelectorProvider {
          * Opens a socket channel.
          *
          * @return  The new channel
    +     *
    +     * @throws  IOException
    +     *          If an I/O error occurs
          */
         public abstract SocketChannel openSocketChannel()
             throws IOException;
    diff --git a/jdk/src/share/classes/java/nio/charset/Charset-X-Coder.java.template b/jdk/src/share/classes/java/nio/charset/Charset-X-Coder.java.template
    index 34be4eb8375..335194eef52 100644
    --- a/jdk/src/share/classes/java/nio/charset/Charset-X-Coder.java.template
    +++ b/jdk/src/share/classes/java/nio/charset/Charset-X-Coder.java.template
    @@ -163,6 +163,9 @@ public abstract class Charset$Coder$ {
          * Initializes a new $coder$.  The new $coder$ will have the given
          * $otypes-per-itype$ and replacement values.
          *
    +     * @param  cs
    +     *         The charset that created this $coder$
    +     *
          * @param  average$ItypesPerOtype$
          *         A positive float value indicating the expected number of
          *         $otype$s that will be produced for each input $itype$
    @@ -209,6 +212,9 @@ public abstract class Charset$Coder$ {
          * $otypes-per-itype$ values and its replacement will be the
          * $replTypeName$ $defaultReplName$.
          *
    +     * @param  cs
    +     *         The charset that created this $coder$
    +     *
          * @param  average$ItypesPerOtype$
          *         A positive float value indicating the expected number of
          *         $otype$s that will be produced for each input $itype$
    @@ -386,6 +392,8 @@ public abstract class Charset$Coder$ {
          * 

    The default implementation of this method does nothing. This method * should be overridden by $coder$s that require notification of changes to * the malformed-input action.

    + * + * @param newAction The new action */ protected void implOnMalformedInput(CodingErrorAction newAction) { } @@ -428,6 +436,8 @@ public abstract class Charset$Coder$ { *

    The default implementation of this method does nothing. This method * should be overridden by $coder$s that require notification of changes to * the unmappable-character action.

    + * + * @param newAction The new action */ protected void implOnUnmappableCharacter(CodingErrorAction newAction) { } @@ -925,6 +935,9 @@ public abstract class Charset$Coder$ { *

    The default implementation of this method is not very efficient; it * should generally be overridden to improve performance.

    * + * @param c + * The given character + * * @return true if, and only if, this encoder can encode * the given character * @@ -953,6 +966,9 @@ public abstract class Charset$Coder$ { *

    The default implementation of this method is not very efficient; it * should generally be overridden to improve performance.

    * + * @param cs + * The given character sequence + * * @return true if, and only if, this encoder can encode * the given character without throwing any exceptions and without * performing any replacements diff --git a/jdk/src/share/classes/java/nio/charset/Charset.java b/jdk/src/share/classes/java/nio/charset/Charset.java index 69c3ab0e19f..278bacb17c5 100644 --- a/jdk/src/share/classes/java/nio/charset/Charset.java +++ b/jdk/src/share/classes/java/nio/charset/Charset.java @@ -66,7 +66,7 @@ import sun.security.action.GetPropertyAction; * * *
    - *

    Charset names

    + *

    Charset names

    * *

    Charsets are named by strings composed of the following characters: * @@ -140,7 +140,7 @@ import sun.security.action.GetPropertyAction; * previous canonical name be made into an alias. * * - *

    Standard charsets

    + *

    Standard charsets

    * *
    * @@ -217,7 +217,7 @@ import sun.security.action.GetPropertyAction; *

    The {@link StandardCharsets} class defines constants for each of the * standard charsets. * - *

    Terminology

    + *

    Terminology

    * *

    The name of this class is taken from the terms used in * RFC 2278. @@ -737,6 +737,9 @@ public abstract class Charset * it is not necessarily the case that the given charset is not contained * in this charset. * + * @param cs + * The given charset + * * @return true if the given charset is contained in this charset */ public abstract boolean contains(Charset cs); diff --git a/jdk/src/share/classes/java/nio/charset/CoderResult.java b/jdk/src/share/classes/java/nio/charset/CoderResult.java index 5b2c4d41f89..15aad362c06 100644 --- a/jdk/src/share/classes/java/nio/charset/CoderResult.java +++ b/jdk/src/share/classes/java/nio/charset/CoderResult.java @@ -227,6 +227,9 @@ public class CoderResult { * Static factory method that returns the unique object describing a * malformed-input error of the given length. * + * @param length + * The given length + * * @return The requested coder-result object */ public static CoderResult malformedForLength(int length) { @@ -243,6 +246,9 @@ public class CoderResult { * Static factory method that returns the unique result object describing * an unmappable-character error of the given length. * + * @param length + * The given length + * * @return The requested coder-result object */ public static CoderResult unmappableForLength(int length) { diff --git a/jdk/src/share/classes/java/nio/charset/spi/CharsetProvider.java b/jdk/src/share/classes/java/nio/charset/spi/CharsetProvider.java index 3525e201d87..1e31d75fe31 100644 --- a/jdk/src/share/classes/java/nio/charset/spi/CharsetProvider.java +++ b/jdk/src/share/classes/java/nio/charset/spi/CharsetProvider.java @@ -39,8 +39,8 @@ import java.util.Iterator; * the usual extension directories. Providers may also be made available by * adding them to the applet or application class path or by some other * platform-specific means. Charset providers are looked up via the current - * thread's {@link java.lang.Thread#getContextClassLoader() context - * class loader}. + * thread's {@link java.lang.Thread#getContextClassLoader() context class + * loader}. * *

    A charset provider identifies itself with a provider-configuration file * named java.nio.charset.spi.CharsetProvider in the resource diff --git a/jdk/src/share/classes/java/nio/file/FileStore.java b/jdk/src/share/classes/java/nio/file/FileStore.java index 831dba8a5e9..d0bdc013992 100644 --- a/jdk/src/share/classes/java/nio/file/FileStore.java +++ b/jdk/src/share/classes/java/nio/file/FileStore.java @@ -173,6 +173,8 @@ public abstract class FileStore { * The {@code type} parameter is the type of the attribute view required and * the method returns an instance of that type if supported. * + * @param + * The {@code FileStoreAttributeView} type * @param type * the {@code Class} object corresponding to the attribute view * diff --git a/jdk/src/share/classes/java/nio/file/FileSystem.java b/jdk/src/share/classes/java/nio/file/FileSystem.java index e2166079831..2296cada829 100644 --- a/jdk/src/share/classes/java/nio/file/FileSystem.java +++ b/jdk/src/share/classes/java/nio/file/FileSystem.java @@ -315,7 +315,7 @@ public abstract class FileSystem * that resembles regular expressions but with a simpler syntax. For example: * *

    - *
    Option NameDescription
    + *
    * * * diff --git a/jdk/src/share/classes/java/nio/file/FileSystems.java b/jdk/src/share/classes/java/nio/file/FileSystems.java index ef443640af0..d6b4496dda7 100644 --- a/jdk/src/share/classes/java/nio/file/FileSystems.java +++ b/jdk/src/share/classes/java/nio/file/FileSystems.java @@ -200,6 +200,10 @@ public final class FileSystems { * existing file system. In the case of the {@link FileSystems#getDefault * default} file system, no permission check is required. * + * @param uri the URI to locate the file system + * + * @return the reference to the file system + * * @throws IllegalArgumentException * if the pre-conditions for the {@code uri} parameter are not met * @throws FileSystemNotFoundException diff --git a/jdk/src/share/classes/java/nio/file/Files.java b/jdk/src/share/classes/java/nio/file/Files.java index c4065690aa5..ca0263d0660 100644 --- a/jdk/src/share/classes/java/nio/file/Files.java +++ b/jdk/src/share/classes/java/nio/file/Files.java @@ -194,7 +194,7 @@ public final class Files { *

    In the addition to {@code READ} and {@code WRITE}, the following * options may be present: * - *

    {@code *.java}Matches a path that represents a file name ending in {@code .java}
    + *
    * * * @@ -1616,7 +1616,8 @@ public final class Files { * } * * - * + * @param + * The {@code FileAttributeView} type * @param path * the path to the file * @param type @@ -1665,6 +1666,8 @@ public final class Files { * PosixFileAttributes attrs = Files.readAttributes(path, PosixFileAttributes.class, NOFOLLOW_LINKS); * * + * @param + * The {@code BasicFileAttributes} type * @param path * the path to the file * @param type @@ -1863,7 +1866,7 @@ public final class Files { * attributes} parameter: * *
    - *
    Option Description
    {@link StandardOpenOption#APPEND APPEND}
    + *
    * * * @@ -1971,10 +1974,12 @@ public final class Files { * System Interface (POSIX) family of standards. * * @param path - * A file reference that locates the file + * The path to the file * @param perms * The new set of permissions * + * @return The path + * * @throws UnsupportedOperationException * if the associated file system does not support the {@code * PosixFileAttributeView} @@ -2009,7 +2014,7 @@ public final class Files { * access to a file attribute that is the owner of the file. * * @param path - * A file reference that locates the file + * The path to the file * @param options * options indicating how symbolic links are handled * @@ -2052,10 +2057,12 @@ public final class Files { * * * @param path - * A file reference that locates the file + * The path to the file * @param owner * The new file owner * + * @return The path + * * @throws UnsupportedOperationException * if the associated file system does not support the {@code * FileOwnerAttributeView} @@ -2090,6 +2097,8 @@ public final class Files { * readAttributes} method and the file type tested with the {@link * BasicFileAttributes#isSymbolicLink} method. * + * @param path The path to the file + * * @return {@code true} if the file is a symbolic link; {@code false} if * the file does not exist, is not a symbolic link, or it cannot * be determined if the file is a symbolic link or not. @@ -2239,7 +2248,7 @@ public final class Files { * @param time * the new last modified time * - * @return the file + * @return the path * * @throws IOException * if an I/O error occurs diff --git a/jdk/src/share/classes/java/nio/file/Path.java b/jdk/src/share/classes/java/nio/file/Path.java index 57782765854..39afd4d4255 100644 --- a/jdk/src/share/classes/java/nio/file/Path.java +++ b/jdk/src/share/classes/java/nio/file/Path.java @@ -64,7 +64,7 @@ import java.util.Iterator; * those developing custom file system implementations. Methods may be added to * this interface in future releases.

    * - *

    Accessing Files

    + *

    Accessing Files

    *

    Paths may be used with the {@link Files} class to operate on files, * directories, and other types of files. For example, suppose we want a {@link * java.io.BufferedReader} to read text from a file "{@code access.log}". The @@ -75,7 +75,7 @@ import java.util.Iterator; * BufferedReader reader = Files.newBufferedReader(path, StandardCharsets.UTF_8); * * - *

    Interoperability

    + *

    Interoperability

    *

    Paths associated with the default {@link * java.nio.file.spi.FileSystemProvider provider} are generally interoperable * with the {@link java.io.File java.io.File} class. Paths created by other @@ -87,7 +87,7 @@ import java.util.Iterator; * addition, the {@link #toFile toFile} method is useful to construct a {@code * File} from the {@code String} representation of a {@code Path}. * - *

    Concurrency

    + *

    Concurrency

    *

    Implementations of this interface are immutable and safe for use by * multiple concurrent threads. * diff --git a/jdk/src/share/classes/java/nio/file/SecureDirectoryStream.java b/jdk/src/share/classes/java/nio/file/SecureDirectoryStream.java index 6ef4882eae8..2bfa2056b82 100644 --- a/jdk/src/share/classes/java/nio/file/SecureDirectoryStream.java +++ b/jdk/src/share/classes/java/nio/file/SecureDirectoryStream.java @@ -122,6 +122,8 @@ public interface SecureDirectoryStream * an optional list of attributes to set atomically when creating * the file * + * @return the seekable byte channel + * * @throws ClosedDirectoryStreamException * if the directory stream is closed * @throws IllegalArgumentException @@ -260,6 +262,8 @@ public interface SecureDirectoryStream * then all methods to read or update attributes will throw {@link * ClosedDirectoryStreamException ClosedDirectoryStreamException}. * + * @param + * The {@code FileAttributeView} type * @param type * the {@code Class} object corresponding to the file attribute view * @@ -288,6 +292,8 @@ public interface SecureDirectoryStream * is created but methods to read or update attributes of the file will * fail when invoked and the file does not exist. * + * @param + * The {@code FileAttributeView} type * @param path * the path of the file * @param type diff --git a/jdk/src/share/classes/java/nio/file/WatchEvent.java b/jdk/src/share/classes/java/nio/file/WatchEvent.java index cab199f0b57..50848685150 100644 --- a/jdk/src/share/classes/java/nio/file/WatchEvent.java +++ b/jdk/src/share/classes/java/nio/file/WatchEvent.java @@ -55,11 +55,16 @@ public interface WatchEvent { public static interface Kind { /** * Returns the name of the event kind. + * + * @return the name of the event kind */ String name(); /** * Returns the type of the {@link WatchEvent#context context} value. + * + * + * @return the type of the context value */ Class type(); } @@ -76,6 +81,8 @@ public interface WatchEvent { public static interface Modifier { /** * Returns the name of the modifier. + * + * @return the name of the modifier */ String name(); } diff --git a/jdk/src/share/classes/java/nio/file/WatchService.java b/jdk/src/share/classes/java/nio/file/WatchService.java index 5a63fcd8722..c6440b208e4 100644 --- a/jdk/src/share/classes/java/nio/file/WatchService.java +++ b/jdk/src/share/classes/java/nio/file/WatchService.java @@ -78,7 +78,7 @@ import java.util.concurrent.TimeUnit; * The {@link java.nio.channels.FileChannel FileChannel} class defines methods * to lock regions of a file against access by other programs. * - *

    Platform dependencies

    + *

    Platform dependencies

    * *

    The implementation that observes events from the file system is intended * to map directly on to the native file event notification facility where diff --git a/jdk/src/share/classes/java/nio/file/attribute/AclEntry.java b/jdk/src/share/classes/java/nio/file/attribute/AclEntry.java index 9b4ef8a34c3..49bf5292471 100644 --- a/jdk/src/share/classes/java/nio/file/attribute/AclEntry.java +++ b/jdk/src/share/classes/java/nio/file/attribute/AclEntry.java @@ -134,6 +134,7 @@ public final class AclEntry { /** * Sets the type component of this builder. * + * @param type the component type * @return this builder */ public Builder setType(AclEntryType type) { @@ -146,6 +147,7 @@ public final class AclEntry { /** * Sets the principal component of this builder. * + * @param who the principal component * @return this builder */ public Builder setPrincipal(UserPrincipal who) { @@ -168,6 +170,7 @@ public final class AclEntry { * Sets the permissions component of this builder. On return, the * permissions component of this builder is a copy of the given set. * + * @param perms the permissions component * @return this builder * * @throws ClassCastException @@ -193,6 +196,7 @@ public final class AclEntry { * permissions component of this builder is a copy of the permissions in * the given array. * + * @param perms the permissions component * @return this builder */ public Builder setPermissions(AclEntryPermission... perms) { @@ -211,6 +215,7 @@ public final class AclEntry { * Sets the flags component of this builder. On return, the flags * component of this builder is a copy of the given set. * + * @param flags the flags component * @return this builder * * @throws ClassCastException @@ -236,6 +241,7 @@ public final class AclEntry { * component of this builder is a copy of the flags in the given * array. * + * @param flags the flags component * @return this builder */ public Builder setFlags(AclEntryFlag... flags) { @@ -267,9 +273,7 @@ public final class AclEntry { /** * Constructs a new builder with the components of an existing ACL entry. * - * @param entry - * an ACL entry - * + * @param entry an ACL entry * @return a new builder */ public static Builder newBuilder(AclEntry entry) { @@ -278,6 +282,8 @@ public final class AclEntry { /** * Returns the ACL entry type. + * + * @return the ACL entry type */ public AclEntryType type() { return type; @@ -285,6 +291,8 @@ public final class AclEntry { /** * Returns the principal component. + * + * @return the principal component */ public UserPrincipal principal() { return who; @@ -294,6 +302,8 @@ public final class AclEntry { * Returns a copy of the permissions component. * *

    The returned set is a modifiable copy of the permissions. + * + * @return the permissions component */ public Set permissions() { return new HashSet(perms); @@ -303,6 +313,8 @@ public final class AclEntry { * Returns a copy of the flags component. * *

    The returned set is a modifiable copy of the flags. + * + * @return the flags component */ public Set flags() { return new HashSet(flags); diff --git a/jdk/src/share/classes/java/nio/file/attribute/AclFileAttributeView.java b/jdk/src/share/classes/java/nio/file/attribute/AclFileAttributeView.java index 2f94937b6c1..f5d58d41f4a 100644 --- a/jdk/src/share/classes/java/nio/file/attribute/AclFileAttributeView.java +++ b/jdk/src/share/classes/java/nio/file/attribute/AclFileAttributeView.java @@ -54,7 +54,7 @@ import java.io.IOException; * supportsFileAttributeView} method can be used to test if a file system * supports ACLs. * - *

    Interoperability

    + *

    Interoperability

    * * RFC 3530 allows for special user identities to be used on platforms that * support the POSIX defined access permissions. The special user identities @@ -65,7 +65,7 @@ import java.io.IOException; * UserPrincipalLookupService} may be used to obtain a {@link UserPrincipal} * to represent these special identities by invoking the {@link * UserPrincipalLookupService#lookupPrincipalByName lookupPrincipalByName} - * method.

    + * method. * *

    Usage Example: * Suppose we wish to add an entry to an existing ACL to grant "joe" access: @@ -90,11 +90,11 @@ import java.io.IOException; * view.setAcl(acl); * * - *

    Dynamic Access

    + *

    Dynamic Access

    *

    Where dynamic access to file attributes is required, the attributes * supported by this attribute view are as follows: *

    - *
    {@code "*"} Read all {@link BasicFileAttributes basic-file-attributes}.
    + *
    * * * @@ -118,7 +118,7 @@ import java.io.IOException; * update the ACL or owner attributes as if by invoking the {@link #setAcl setAcl} * or {@link #setOwner setOwner} methods. * - *

    Setting the ACL when creating a file

    + *

    Setting the ACL when creating a file

    * *

    Implementations supporting this attribute view may also support setting * the initial ACL when creating a file or directory. The initial ACL diff --git a/jdk/src/share/classes/java/nio/file/attribute/AttributeView.java b/jdk/src/share/classes/java/nio/file/attribute/AttributeView.java index 0b2951b960e..d33f9764a79 100644 --- a/jdk/src/share/classes/java/nio/file/attribute/AttributeView.java +++ b/jdk/src/share/classes/java/nio/file/attribute/AttributeView.java @@ -38,6 +38,8 @@ package java.nio.file.attribute; public interface AttributeView { /** * Returns the name of the attribute view. + * + * @return the name of the attribute view */ String name(); } diff --git a/jdk/src/share/classes/java/nio/file/attribute/BasicFileAttributeView.java b/jdk/src/share/classes/java/nio/file/attribute/BasicFileAttributeView.java index 2a8e2c9585b..3a9c7916969 100644 --- a/jdk/src/share/classes/java/nio/file/attribute/BasicFileAttributeView.java +++ b/jdk/src/share/classes/java/nio/file/attribute/BasicFileAttributeView.java @@ -41,7 +41,7 @@ import java.io.IOException; *

    Where dynamic access to file attributes is required, the attributes * supported by this attribute view have the following names and types: *

    - *
    Name Type
    + *
    * * * diff --git a/jdk/src/share/classes/java/nio/file/attribute/BasicFileAttributes.java b/jdk/src/share/classes/java/nio/file/attribute/BasicFileAttributes.java index d1f715dcea2..df2d10bb27c 100644 --- a/jdk/src/share/classes/java/nio/file/attribute/BasicFileAttributes.java +++ b/jdk/src/share/classes/java/nio/file/attribute/BasicFileAttributes.java @@ -87,22 +87,31 @@ public interface BasicFileAttributes { /** * Tells whether the file is a regular file with opaque content. + * + * @return {@code true} if the file is a regular file with opaque content */ boolean isRegularFile(); /** * Tells whether the file is a directory. + * + * @return {@code true} if the file is a directory */ boolean isDirectory(); /** * Tells whether the file is a symbolic link. + * + * @return {@code true} if the file is a symbolic link */ boolean isSymbolicLink(); /** * Tells whether the file is something other than a regular file, directory, * or symbolic link. + * + * @return {@code true} if the file something other than a regular file, + * directory or symbolic link */ boolean isOther(); @@ -138,6 +147,8 @@ public interface BasicFileAttributes { * and two files are the {@link java.nio.file.Files#isSameFile same} with * non-{@code null} file keys, then their file keys are equal. * + * @return an object that uniquely identifies the given file, or {@code null} + * * @see java.nio.file.Files#walkFileTree */ Object fileKey(); diff --git a/jdk/src/share/classes/java/nio/file/attribute/DosFileAttributeView.java b/jdk/src/share/classes/java/nio/file/attribute/DosFileAttributeView.java index aa99d23322e..1fb53853a61 100644 --- a/jdk/src/share/classes/java/nio/file/attribute/DosFileAttributeView.java +++ b/jdk/src/share/classes/java/nio/file/attribute/DosFileAttributeView.java @@ -41,7 +41,7 @@ import java.io.IOException; * BasicFileAttributeView}, and in addition, the following attributes are * supported: *
    - *
    Name Type
    + *
    * * * diff --git a/jdk/src/share/classes/java/nio/file/attribute/FileAttribute.java b/jdk/src/share/classes/java/nio/file/attribute/FileAttribute.java index d3704cbf821..46168763487 100644 --- a/jdk/src/share/classes/java/nio/file/attribute/FileAttribute.java +++ b/jdk/src/share/classes/java/nio/file/attribute/FileAttribute.java @@ -40,11 +40,15 @@ package java.nio.file.attribute; public interface FileAttribute { /** * Returns the attribute name. + * + * @return The attribute name */ String name(); /** * Returns the attribute value. + * + * @return The attribute value */ T value(); } diff --git a/jdk/src/share/classes/java/nio/file/attribute/PosixFileAttributeView.java b/jdk/src/share/classes/java/nio/file/attribute/PosixFileAttributeView.java index ea5f1e2eaa6..81a6a4156e7 100644 --- a/jdk/src/share/classes/java/nio/file/attribute/PosixFileAttributeView.java +++ b/jdk/src/share/classes/java/nio/file/attribute/PosixFileAttributeView.java @@ -68,13 +68,13 @@ import java.io.IOException; * PosixFilePermissions.toString(attrs.permissions())); * * - *

    Dynamic Access

    + *

    Dynamic Access

    *

    Where dynamic access to file attributes is required, the attributes * supported by this attribute view are as defined by {@link * BasicFileAttributeView} and {@link FileOwnerAttributeView}, and in addition, * the following attributes are supported: *

    - *
    Name Type
    + *
    * * * @@ -102,7 +102,7 @@ import java.io.IOException; * #setPermissions setPermissions}, {@link #setOwner setOwner}, and {@link * #setGroup setGroup} methods respectively. * - *

    Setting Initial Permissions

    + *

    Setting Initial Permissions

    *

    Implementations supporting this attribute view may also support setting * the initial permissions when creating a file or directory. The * initial permissions are provided to the {@link Files#createFile createFile} diff --git a/jdk/src/share/classes/java/nio/file/spi/FileSystemProvider.java b/jdk/src/share/classes/java/nio/file/spi/FileSystemProvider.java index 84e92d9cb92..5b95dcc390d 100644 --- a/jdk/src/share/classes/java/nio/file/spi/FileSystemProvider.java +++ b/jdk/src/share/classes/java/nio/file/spi/FileSystemProvider.java @@ -287,6 +287,8 @@ public abstract class FileSystemProvider { * @param uri * The URI to convert * + * @return The resulting {@code Path} + * * @throws IllegalArgumentException * If the URI scheme does not identify this provider or other * preconditions on the uri parameter do not hold @@ -751,6 +753,8 @@ public abstract class FileSystemProvider { * @param link * the path to the symbolic link * + * @return The target of the symbolic link + * * @throws UnsupportedOperationException * if the implementation does not support symbolic links * @throws NotLinkException @@ -984,6 +988,8 @@ public abstract class FileSystemProvider { * exactly the manner specified by the {@link Files#getFileAttributeView} * method. * + * @param + * The {@code FileAttributeView} type * @param path * the path to the file * @param type @@ -1002,6 +1008,8 @@ public abstract class FileSystemProvider { * exactly the manner specified by the {@link * Files#readAttributes(Path,Class,LinkOption[])} method. * + * @param + * The {@code BasicFileAttributes} type * @param path * the path to the file * @param type diff --git a/jdk/src/share/classes/java/sql/SQLInput.java b/jdk/src/share/classes/java/sql/SQLInput.java index ae65e67ac6f..b768fa95e1e 100644 --- a/jdk/src/share/classes/java/sql/SQLInput.java +++ b/jdk/src/share/classes/java/sql/SQLInput.java @@ -444,7 +444,7 @@ public interface SQLInput { *

    * The default implementation will throw {@code SQLFeatureNotSupportedException} * - * @param the type of the class modeled by this Class object + * @param the type of the class modeled by this Class object * @param type Class representing the Java data type to convert the attribute to. * @return the attribute at the head of the stream as an {@code Object} in the * Java programming language;{@code null} if the attribute is SQL {@code NULL} From 0faa9a064fc62af12d3009994d5f54157b9a9af2 Mon Sep 17 00:00:00 2001 From: John Zavgren Date: Fri, 28 Jun 2013 16:38:09 +0100 Subject: [PATCH 080/127] 8015799: HttpURLConnection.getHeaderFields() throws IllegalArgumentException Reviewed-by: chegar, dsamersoff, khazra --- .../www/protocol/http/HttpURLConnection.java | 3 +- .../net/CookieHandler/EmptyCookieHeader.java | 94 +++++++++++++++++++ 2 files changed, 96 insertions(+), 1 deletion(-) create mode 100644 jdk/test/java/net/CookieHandler/EmptyCookieHeader.java diff --git a/jdk/src/share/classes/sun/net/www/protocol/http/HttpURLConnection.java b/jdk/src/share/classes/sun/net/www/protocol/http/HttpURLConnection.java index 201e236210c..1efb3e1657d 100644 --- a/jdk/src/share/classes/sun/net/www/protocol/http/HttpURLConnection.java +++ b/jdk/src/share/classes/sun/net/www/protocol/http/HttpURLConnection.java @@ -2806,9 +2806,10 @@ public class HttpURLConnection extends java.net.HttpURLConnection { if (SET_COOKIE.equalsIgnoreCase(name) || SET_COOKIE2.equalsIgnoreCase(name)) { + // Filtering only if there is a cookie handler. [Assumption: the // cookie handler will store/retrieve the HttpOnly cookies] - if (cookieHandler == null) + if (cookieHandler == null || value.length() == 0) return value; sun.misc.JavaNetHttpCookieAccess access = diff --git a/jdk/test/java/net/CookieHandler/EmptyCookieHeader.java b/jdk/test/java/net/CookieHandler/EmptyCookieHeader.java new file mode 100644 index 00000000000..f35631741a6 --- /dev/null +++ b/jdk/test/java/net/CookieHandler/EmptyCookieHeader.java @@ -0,0 +1,94 @@ +/* + * Copyright (c) 2013, 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 + * @bug 8015799 + * @summary HttpURLConnection.getHeaderFields() throws IllegalArgumentException + */ + +import com.sun.net.httpserver.*; +import java.io.IOException; +import java.io.OutputStream; +import java.net.*; +import java.util.*; + +public class EmptyCookieHeader { + + public static void main(String[] args) throws Exception { + new EmptyCookieHeader().runTest(); + } + + public void runTest() throws Exception { + final CookieHandler oldHandler = CookieHandler.getDefault(); + CookieHandler.setDefault(new TestCookieHandler()); + HttpServer s = HttpServer.create(new InetSocketAddress(0), 0); + try { + startServer(s); + URL url = new URL("http://localhost:" + s.getAddress().getPort() + "/"); + HttpURLConnection c = (HttpURLConnection)url.openConnection(); + c.getHeaderFields(); + } finally { + CookieHandler.setDefault(oldHandler); + s.stop(0); + } + } + + static void startServer(HttpServer server) throws IOException { + server.createContext("/", new EmptyCookieHandler()); + server.start(); + } + + static class EmptyCookieHandler implements HttpHandler { + + @Override + public void handle(HttpExchange exchange) throws IOException { + String requestMethod = exchange.getRequestMethod(); + if (requestMethod.equalsIgnoreCase("GET")) { + Headers responseHeaders = exchange.getResponseHeaders(); + responseHeaders.set("Content-Type", "text/plain"); + responseHeaders.set("Date", "June 13th 2012"); + + // No domain value set + responseHeaders.set("Set-Cookie2", "name=value"); + responseHeaders.set("Set-Cookie2", ""); + exchange.sendResponseHeaders(200, 0); + try (OutputStream os = exchange.getResponseBody()) { + String str = "This is what the server sent!"; + os.write(str.getBytes()); + } + } + } + } + + class TestCookieHandler extends CookieHandler { + @Override + public Map> get(URI uri, + Map> respH) { + return new HashMap<>(); + } + + @Override + public void put(URI uri, Map> respH) { } + } +} From 0b7143c3ee1530317062b40a2c8eea8f21d6c207 Mon Sep 17 00:00:00 2001 From: Jason Uh Date: Fri, 28 Jun 2013 10:48:02 -0700 Subject: [PATCH 081/127] 8019360: Cleanup of the javadoc tag in java.security.* Convert to {@code ...} tags. convert package.html to package-info.java. Reviewed-by: darcy --- .../java/security/AccessControlContext.java | 40 +-- .../java/security/AccessControlException.java | 6 +- .../java/security/AccessController.java | 176 +++++----- .../security/AlgorithmParameterGenerator.java | 22 +- .../AlgorithmParameterGeneratorSpi.java | 6 +- .../java/security/AlgorithmParameters.java | 48 +-- .../java/security/AlgorithmParametersSpi.java | 18 +- .../classes/java/security/AllPermission.java | 4 +- .../classes/java/security/AuthProvider.java | 48 +-- .../java/security/BasicPermission.java | 18 +- .../classes/java/security/Certificate.java | 12 +- .../classes/java/security/CodeSigner.java | 12 +- .../classes/java/security/CodeSource.java | 10 +- .../java/security/DigestException.java | 14 +- .../java/security/DigestInputStream.java | 24 +- .../java/security/DigestOutputStream.java | 16 +- .../classes/java/security/DomainCombiner.java | 54 +-- .../security/GeneralSecurityException.java | 16 +- .../share/classes/java/security/Guard.java | 10 +- .../classes/java/security/GuardedObject.java | 6 +- .../share/classes/java/security/Identity.java | 50 +-- .../classes/java/security/IdentityScope.java | 18 +- .../InvalidAlgorithmParameterException.java | 14 +- .../java/security/InvalidKeyException.java | 14 +- jdk/src/share/classes/java/security/Key.java | 10 +- .../classes/java/security/KeyException.java | 14 +- .../classes/java/security/KeyFactory.java | 28 +- .../classes/java/security/KeyFactorySpi.java | 16 +- .../java/security/KeyManagementException.java | 14 +- .../share/classes/java/security/KeyPair.java | 4 +- .../java/security/KeyPairGenerator.java | 56 ++-- .../java/security/KeyPairGeneratorSpi.java | 10 +- .../share/classes/java/security/KeyRep.java | 16 +- .../share/classes/java/security/KeyStore.java | 308 +++++++++--------- .../java/security/KeyStoreException.java | 14 +- .../classes/java/security/KeyStoreSpi.java | 142 ++++---- .../classes/java/security/MessageDigest.java | 32 +- .../java/security/MessageDigestSpi.java | 16 +- .../security/NoSuchAlgorithmException.java | 14 +- .../classes/java/security/Permission.java | 32 +- .../java/security/PermissionCollection.java | 32 +- .../classes/java/security/Permissions.java | 26 +- .../share/classes/java/security/Policy.java | 56 ++-- .../classes/java/security/PolicySpi.java | 10 +- .../java/security/PrivilegedAction.java | 12 +- .../security/PrivilegedActionException.java | 18 +- .../security/PrivilegedExceptionAction.java | 14 +- .../java/security/ProtectionDomain.java | 6 +- .../share/classes/java/security/Provider.java | 108 +++--- .../java/security/ProviderException.java | 14 +- .../classes/java/security/PublicKey.java | 4 +- .../java/security/SecureClassLoader.java | 38 +-- .../classes/java/security/SecureRandom.java | 64 ++-- .../java/security/SecureRandomSpi.java | 8 +- .../share/classes/java/security/Security.java | 68 ++-- .../java/security/SecurityPermission.java | 16 +- .../classes/java/security/Signature.java | 68 ++-- .../java/security/SignatureException.java | 14 +- .../classes/java/security/SignatureSpi.java | 28 +- .../classes/java/security/SignedObject.java | 30 +- .../share/classes/java/security/Signer.java | 20 +- .../java/security/UnresolvedPermission.java | 30 +- .../share/classes/java/security/acl/Acl.java | 18 +- .../classes/java/security/acl/AclEntry.java | 4 +- .../classes/java/security/acl/Group.java | 4 +- .../classes/java/security/acl/Owner.java | 4 +- .../java/security/acl/package-info.java | 33 ++ .../classes/java/security/acl/package.html | 54 --- .../java/security/cert/package-info.java | 64 ++++ .../classes/java/security/cert/package.html | 67 ---- .../interfaces/DSAKeyPairGenerator.java | 24 +- .../java/security/interfaces/DSAParams.java | 14 +- .../security/interfaces/DSAPrivateKey.java | 6 +- .../security/interfaces/DSAPublicKey.java | 6 +- .../security/interfaces/package-info.java | 74 +++++ .../java/security/interfaces/package.html | 77 ----- .../classes/java/security/package-info.java | 112 +++++++ .../share/classes/java/security/package.html | 117 ------- .../java/security/spec/package-info.java | 73 +++++ .../classes/java/security/spec/package.html | 78 ----- 80 files changed, 1429 insertions(+), 1466 deletions(-) create mode 100644 jdk/src/share/classes/java/security/acl/package-info.java delete mode 100644 jdk/src/share/classes/java/security/acl/package.html create mode 100644 jdk/src/share/classes/java/security/cert/package-info.java delete mode 100644 jdk/src/share/classes/java/security/cert/package.html create mode 100644 jdk/src/share/classes/java/security/interfaces/package-info.java delete mode 100644 jdk/src/share/classes/java/security/interfaces/package.html create mode 100644 jdk/src/share/classes/java/security/package-info.java delete mode 100644 jdk/src/share/classes/java/security/package.html create mode 100644 jdk/src/share/classes/java/security/spec/package-info.java delete mode 100644 jdk/src/share/classes/java/security/spec/package.html diff --git a/jdk/src/share/classes/java/security/AccessControlContext.java b/jdk/src/share/classes/java/security/AccessControlContext.java index 349de30f01e..9b5bc07225e 100644 --- a/jdk/src/share/classes/java/security/AccessControlContext.java +++ b/jdk/src/share/classes/java/security/AccessControlContext.java @@ -36,10 +36,10 @@ import sun.security.util.SecurityConstants; * based on the context it encapsulates. * *

    More specifically, it encapsulates a context and - * has a single method, checkPermission, - * that is equivalent to the checkPermission method + * has a single method, {@code checkPermission}, + * that is equivalent to the {@code checkPermission} method * in the AccessController class, with one difference: The AccessControlContext - * checkPermission method makes access decisions based on the + * {@code checkPermission} method makes access decisions based on the * context it encapsulates, * rather than that of the current execution thread. * @@ -49,8 +49,8 @@ import sun.security.util.SecurityConstants; * different context (for example, from within a worker thread). * *

    An AccessControlContext is created by calling the - * AccessController.getContext method. - * The getContext method takes a "snapshot" + * {@code AccessController.getContext} method. + * The {@code getContext} method takes a "snapshot" * of the current calling context, and places * it in an AccessControlContext object, which it returns. A sample call is * the following: @@ -61,7 +61,7 @@ import sun.security.util.SecurityConstants; * *

    * Code within a different context can subsequently call the - * checkPermission method on the + * {@code checkPermission} method on the * previously-saved AccessControlContext object. A sample call is the * following: * @@ -121,7 +121,7 @@ public final class AccessControlContext { * @param context the ProtectionDomains associated with this context. * The non-duplicate domains are copied from the array. Subsequent * changes to the array will not affect this AccessControlContext. - * @throws NullPointerException if context is null + * @throws NullPointerException if {@code context} is {@code null} */ public AccessControlContext(ProtectionDomain context[]) { @@ -147,22 +147,22 @@ public final class AccessControlContext { } /** - * Create a new AccessControlContext with the given - * AccessControlContext and DomainCombiner. + * Create a new {@code AccessControlContext} with the given + * {@code AccessControlContext} and {@code DomainCombiner}. * This constructor associates the provided - * DomainCombiner with the provided - * AccessControlContext. + * {@code DomainCombiner} with the provided + * {@code AccessControlContext}. * *

    * - * @param acc the AccessControlContext associated - * with the provided DomainCombiner. + * @param acc the {@code AccessControlContext} associated + * with the provided {@code DomainCombiner}. * - * @param combiner the DomainCombiner to be associated - * with the provided AccessControlContext. + * @param combiner the {@code DomainCombiner} to be associated + * with the provided {@code AccessControlContext}. * * @exception NullPointerException if the provided - * context is null. + * {@code context} is {@code null}. * * @exception SecurityException if a security manager is installed and the * caller does not have the "createAccessControlContext" @@ -320,13 +320,13 @@ public final class AccessControlContext { } /** - * Get the DomainCombiner associated with this - * AccessControlContext. + * Get the {@code DomainCombiner} associated with this + * {@code AccessControlContext}. * *

    * - * @return the DomainCombiner associated with this - * AccessControlContext, or null + * @return the {@code DomainCombiner} associated with this + * {@code AccessControlContext}, or {@code null} * if there is none. * * @exception SecurityException if a security manager is installed and diff --git a/jdk/src/share/classes/java/security/AccessControlException.java b/jdk/src/share/classes/java/security/AccessControlException.java index baab01bc20e..fbdbb77b999 100644 --- a/jdk/src/share/classes/java/security/AccessControlException.java +++ b/jdk/src/share/classes/java/security/AccessControlException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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,7 +48,7 @@ public class AccessControlException extends SecurityException { private Permission perm; /** - * Constructs an AccessControlException with the + * Constructs an {@code AccessControlException} with the * specified, detailed message. * * @param s the detail message. @@ -58,7 +58,7 @@ public class AccessControlException extends SecurityException { } /** - * Constructs an AccessControlException with the + * Constructs an {@code AccessControlException} with the * specified, detailed message, and the requested permission that caused * the exception. * diff --git a/jdk/src/share/classes/java/security/AccessController.java b/jdk/src/share/classes/java/security/AccessController.java index a70251664a5..ed103a9186d 100644 --- a/jdk/src/share/classes/java/security/AccessController.java +++ b/jdk/src/share/classes/java/security/AccessController.java @@ -49,7 +49,7 @@ import sun.reflect.Reflection; *

    The {@link #checkPermission(Permission) checkPermission} method * determines whether the access request indicated by a specified * permission should be granted or denied. A sample call appears - * below. In this example, checkPermission will determine + * below. In this example, {@code checkPermission} will determine * whether or not to grant "read" access to the file named "testFile" in * the "/temp" directory. * @@ -61,7 +61,7 @@ import sun.reflect.Reflection; * * *

    If a requested access is allowed, - * checkPermission returns quietly. If denied, an + * {@code checkPermission} returns quietly. If denied, an * AccessControlException is * thrown. AccessControlException can also be thrown if the requested * permission is of an incorrect type or contains an invalid value. @@ -69,8 +69,8 @@ import sun.reflect.Reflection; * * Suppose the current thread traversed m callers, in the order of caller 1 * to caller 2 to caller m. Then caller m invoked the - * checkPermission method. - * The checkPermission method determines whether access + * {@code checkPermission} method. + * The {@code checkPermission} method determines whether access * is granted or denied based on the following algorithm: * *

     {@code
    @@ -102,20 +102,20 @@ import sun.reflect.Reflection;
      *
      * 

    A caller can be marked as being "privileged" * (see {@link #doPrivileged(PrivilegedAction) doPrivileged} and below). - * When making access control decisions, the checkPermission + * When making access control decisions, the {@code checkPermission} * method stops checking if it reaches a caller that - * was marked as "privileged" via a doPrivileged + * was marked as "privileged" via a {@code doPrivileged} * call without a context argument (see below for information about a * context argument). If that caller's domain has the * specified permission and at least one limiting permission argument (if any) * implies the requested permission, no further checking is done and - * checkPermission + * {@code checkPermission} * returns quietly, indicating that the requested access is allowed. * If that domain does not have the specified permission, an exception * is thrown, as usual. If the caller's domain had the specified permission * but it was not implied by any limiting permission arguments given in the call - * to doPrivileged then the permission checking continues - * until there are no more callers or another doPrivileged + * to {@code doPrivileged} then the permission checking continues + * until there are no more callers or another {@code doPrivileged} * call matches the requested permission and returns normally. * *

    The normal use of the "privileged" feature is as follows. If you @@ -137,17 +137,17 @@ import sun.reflect.Reflection; * *

    * PrivilegedAction is an interface with a single method, named - * run. + * {@code run}. * The above example shows creation of an implementation * of that interface; a concrete implementation of the - * run method is supplied. - * When the call to doPrivileged is made, an + * {@code run} method is supplied. + * When the call to {@code doPrivileged} is made, an * instance of the PrivilegedAction implementation is passed - * to it. The doPrivileged method calls the - * run method from the PrivilegedAction + * to it. The {@code doPrivileged} method calls the + * {@code run} method from the PrivilegedAction * implementation after enabling privileges, and returns the - * run method's return value as the - * doPrivileged return value (which is + * {@code run} method's return value as the + * {@code doPrivileged} return value (which is * ignored in this example). * *

    If you need to return a value, you can do something like the following: @@ -164,11 +164,11 @@ import sun.reflect.Reflection; * ...normal code here... * }}

    * - *

    If the action performed in your run method could - * throw a "checked" exception (those listed in the throws clause + *

    If the action performed in your {@code run} method could + * throw a "checked" exception (those listed in the {@code throws} clause * of a method), then you need to use the - * PrivilegedExceptionAction interface instead of the - * PrivilegedAction interface: + * {@code PrivilegedExceptionAction} interface instead of the + * {@code PrivilegedAction} interface: * *

     {@code
      * somemethod() throws FileNotFoundException {
    @@ -191,18 +191,18 @@ import sun.reflect.Reflection;
      *
      * 

    Be *very* careful in your use of the "privileged" construct, and * always remember to make the privileged code section as small as possible. - * You can pass Permission arguments to further limit the + * You can pass {@code Permission} arguments to further limit the * scope of the "privilege" (see below). * * - *

    Note that checkPermission always performs security checks + *

    Note that {@code checkPermission} always performs security checks * within the context of the currently executing thread. * Sometimes a security check that should be made within a given context * will actually need to be done from within a * different context (for example, from within a worker thread). * The {@link #getContext() getContext} method and * AccessControlContext class are provided - * for this situation. The getContext method takes a "snapshot" + * for this situation. The {@code getContext} method takes a "snapshot" * of the current calling context, and places * it in an AccessControlContext object, which it returns. A sample call is * the following: @@ -214,7 +214,7 @@ import sun.reflect.Reflection; *

    * *

    - * AccessControlContext itself has a checkPermission method + * AccessControlContext itself has a {@code checkPermission} method * that makes access decisions based on the context it encapsulates, * rather than that of the current execution thread. * Code within a different context can thus call that method on the @@ -230,7 +230,7 @@ import sun.reflect.Reflection; *

    There are also times where you don't know a priori which permissions * to check the context against. In these cases you can use the * doPrivileged method that takes a context. You can also limit the scope - * of the privileged code by passing additional Permission + * of the privileged code by passing additional {@code Permission} * parameters. * *

     {@code
    @@ -248,12 +248,12 @@ import sun.reflect.Reflection;
      *     }, acc, new FilePermission("/temp/*", read));
      *     ...normal code here...
      * }}
    - *

    Passing a limiting Permission argument of an instance of - * AllPermission is equivalent to calling the equivalent - * doPrivileged method without limiting Permission - * arguments. Passing a zero length array of Permission disables + *

    Passing a limiting {@code Permission} argument of an instance of + * {@code AllPermission} is equivalent to calling the equivalent + * {@code doPrivileged} method without limiting {@code Permission} + * arguments. Passing a zero length array of {@code Permission} disables * the code privileges so that checking always continues beyond the caller of - * that doPrivileged method. + * that {@code doPrivileged} method. * * @see AccessControlContext * @@ -269,11 +269,11 @@ public final class AccessController { private AccessController() { } /** - * Performs the specified PrivilegedAction with privileges + * Performs the specified {@code PrivilegedAction} with privileges * enabled. The action is performed with all of the permissions * possessed by the caller's protection domain. * - *

    If the action's run method throws an (unchecked) + *

    If the action's {@code run} method throws an (unchecked) * exception, it will propagate through this method. * *

    Note that any DomainCombiner associated with the current @@ -281,9 +281,9 @@ public final class AccessController { * * @param action the action to be performed. * - * @return the value returned by the action's run method. + * @return the value returned by the action's {@code run} method. * - * @exception NullPointerException if the action is null + * @exception NullPointerException if the action is {@code null} * * @see #doPrivileged(PrivilegedAction,AccessControlContext) * @see #doPrivileged(PrivilegedExceptionAction) @@ -295,11 +295,11 @@ public final class AccessController { public static native T doPrivileged(PrivilegedAction action); /** - * Performs the specified PrivilegedAction with privileges + * Performs the specified {@code PrivilegedAction} with privileges * enabled. The action is performed with all of the permissions * possessed by the caller's protection domain. * - *

    If the action's run method throws an (unchecked) + *

    If the action's {@code run} method throws an (unchecked) * exception, it will propagate through this method. * *

    This method preserves the current AccessControlContext's @@ -307,9 +307,9 @@ public final class AccessController { * * @param action the action to be performed. * - * @return the value returned by the action's run method. + * @return the value returned by the action's {@code run} method. * - * @exception NullPointerException if the action is null + * @exception NullPointerException if the action is {@code null} * * @see #doPrivileged(PrivilegedAction) * @see java.security.DomainCombiner @@ -364,17 +364,17 @@ public final class AccessController { /** - * Performs the specified PrivilegedAction with privileges + * Performs the specified {@code PrivilegedAction} with privileges * enabled and restricted by the specified - * AccessControlContext and with a privilege scope limited - * by specified Permission arguments. + * {@code AccessControlContext} and with a privilege scope limited + * by specified {@code Permission} arguments. * * The action is performed with the intersection of the permissions * possessed by the caller's protection domain, and those possessed * by the domains represented by the specified - * AccessControlContext. + * {@code AccessControlContext}. *

    - * If the action's run method throws an (unchecked) exception, + * If the action's {@code run} method throws an (unchecked) exception, * it will propagate through this method. * * @param action the action to be performed. @@ -382,16 +382,16 @@ public final class AccessController { * representing the restriction to be applied to the * caller's domain's privileges before performing * the specified action. If the context is - * null, + * {@code null}, * then no additional restriction is applied. - * @param perms the Permission arguments which limit the + * @param perms the {@code Permission} arguments which limit the * scope of the caller's privileges. The number of arguments * is variable. * - * @return the value returned by the action's run method. + * @return the value returned by the action's {@code run} method. * * @throws NullPointerException if action or perms or any element of - * perms is null + * perms is {@code null} * * @see #doPrivileged(PrivilegedAction) * @see #doPrivileged(PrivilegedExceptionAction,AccessControlContext) @@ -413,17 +413,17 @@ public final class AccessController { /** - * Performs the specified PrivilegedAction with privileges + * Performs the specified {@code PrivilegedAction} with privileges * enabled and restricted by the specified - * AccessControlContext and with a privilege scope limited - * by specified Permission arguments. + * {@code AccessControlContext} and with a privilege scope limited + * by specified {@code Permission} arguments. * * The action is performed with the intersection of the permissions * possessed by the caller's protection domain, and those possessed * by the domains represented by the specified - * AccessControlContext. + * {@code AccessControlContext}. *

    - * If the action's run method throws an (unchecked) exception, + * If the action's {@code run} method throws an (unchecked) exception, * it will propagate through this method. * *

    This method preserves the current AccessControlContext's @@ -434,16 +434,16 @@ public final class AccessController { * representing the restriction to be applied to the * caller's domain's privileges before performing * the specified action. If the context is - * null, + * {@code null}, * then no additional restriction is applied. - * @param perms the Permission arguments which limit the + * @param perms the {@code Permission} arguments which limit the * scope of the caller's privileges. The number of arguments * is variable. * - * @return the value returned by the action's run method. + * @return the value returned by the action's {@code run} method. * * @throws NullPointerException if action or perms or any element of - * perms is null + * perms is {@code null} * * @see #doPrivileged(PrivilegedAction) * @see #doPrivileged(PrivilegedExceptionAction,AccessControlContext) @@ -469,11 +469,11 @@ public final class AccessController { } /** - * Performs the specified PrivilegedExceptionAction with + * Performs the specified {@code PrivilegedExceptionAction} with * privileges enabled. The action is performed with all of the * permissions possessed by the caller's protection domain. * - *

    If the action's run method throws an unchecked + *

    If the action's {@code run} method throws an unchecked * exception, it will propagate through this method. * *

    Note that any DomainCombiner associated with the current @@ -481,11 +481,11 @@ public final class AccessController { * * @param action the action to be performed * - * @return the value returned by the action's run method + * @return the value returned by the action's {@code run} method * * @exception PrivilegedActionException if the specified action's - * run method threw a checked exception - * @exception NullPointerException if the action is null + * {@code run} method threw a checked exception + * @exception NullPointerException if the action is {@code null} * * @see #doPrivileged(PrivilegedAction) * @see #doPrivileged(PrivilegedExceptionAction,AccessControlContext) @@ -499,11 +499,11 @@ public final class AccessController { /** - * Performs the specified PrivilegedExceptionAction with + * Performs the specified {@code PrivilegedExceptionAction} with * privileges enabled. The action is performed with all of the * permissions possessed by the caller's protection domain. * - *

    If the action's run method throws an unchecked + *

    If the action's {@code run} method throws an unchecked * exception, it will propagate through this method. * *

    This method preserves the current AccessControlContext's @@ -511,11 +511,11 @@ public final class AccessController { * * @param action the action to be performed. * - * @return the value returned by the action's run method + * @return the value returned by the action's {@code run} method * * @exception PrivilegedActionException if the specified action's - * run method threw a checked exception - * @exception NullPointerException if the action is null + * {@code run} method threw a checked exception + * @exception NullPointerException if the action is {@code null} * * @see #doPrivileged(PrivilegedAction) * @see #doPrivileged(PrivilegedExceptionAction,AccessControlContext) @@ -609,17 +609,17 @@ public final class AccessController { /** - * Performs the specified PrivilegedExceptionAction with + * Performs the specified {@code PrivilegedExceptionAction} with * privileges enabled and restricted by the specified - * AccessControlContext and with a privilege scope limited by - * specified Permission arguments. + * {@code AccessControlContext} and with a privilege scope limited by + * specified {@code Permission} arguments. * * The action is performed with the intersection of the permissions * possessed by the caller's protection domain, and those possessed * by the domains represented by the specified - * AccessControlContext. + * {@code AccessControlContext}. *

    - * If the action's run method throws an (unchecked) exception, + * If the action's {@code run} method throws an (unchecked) exception, * it will propagate through this method. * * @param action the action to be performed. @@ -627,18 +627,18 @@ public final class AccessController { * representing the restriction to be applied to the * caller's domain's privileges before performing * the specified action. If the context is - * null, + * {@code null}, * then no additional restriction is applied. - * @param perms the Permission arguments which limit the + * @param perms the {@code Permission} arguments which limit the * scope of the caller's privileges. The number of arguments * is variable. * - * @return the value returned by the action's run method. + * @return the value returned by the action's {@code run} method. * * @throws PrivilegedActionException if the specified action's - * run method threw a checked exception + * {@code run} method threw a checked exception * @throws NullPointerException if action or perms or any element of - * perms is null + * perms is {@code null} * * @see #doPrivileged(PrivilegedAction) * @see #doPrivileged(PrivilegedAction,AccessControlContext) @@ -660,17 +660,17 @@ public final class AccessController { /** - * Performs the specified PrivilegedExceptionAction with + * Performs the specified {@code PrivilegedExceptionAction} with * privileges enabled and restricted by the specified - * AccessControlContext and with a privilege scope limited by - * specified Permission arguments. + * {@code AccessControlContext} and with a privilege scope limited by + * specified {@code Permission} arguments. * * The action is performed with the intersection of the permissions * possessed by the caller's protection domain, and those possessed * by the domains represented by the specified - * AccessControlContext. + * {@code AccessControlContext}. *

    - * If the action's run method throws an (unchecked) exception, + * If the action's {@code run} method throws an (unchecked) exception, * it will propagate through this method. * *

    This method preserves the current AccessControlContext's @@ -681,18 +681,18 @@ public final class AccessController { * representing the restriction to be applied to the * caller's domain's privileges before performing * the specified action. If the context is - * null, + * {@code null}, * then no additional restriction is applied. - * @param perms the Permission arguments which limit the + * @param perms the {@code Permission} arguments which limit the * scope of the caller's privileges. The number of arguments * is variable. * - * @return the value returned by the action's run method. + * @return the value returned by the action's {@code run} method. * * @throws PrivilegedActionException if the specified action's - * run method threw a checked exception + * {@code run} method threw a checked exception * @throws NullPointerException if action or perms or any element of - * perms is null + * perms is {@code null} * * @see #doPrivileged(PrivilegedAction) * @see #doPrivileged(PrivilegedAction,AccessControlContext) @@ -770,14 +770,14 @@ public final class AccessController { * This method quietly returns if the access request * is permitted, or throws an AccessControlException otherwise. The * getPermission method of the AccessControlException returns the - * perm Permission object instance. + * {@code perm} Permission object instance. * * @param perm the requested permission. * * @exception AccessControlException if the specified permission * is not permitted, based on the current security policy. * @exception NullPointerException if the specified permission - * is null and is checked based on the + * is {@code null} and is checked based on the * security policy currently in effect. */ diff --git a/jdk/src/share/classes/java/security/AlgorithmParameterGenerator.java b/jdk/src/share/classes/java/security/AlgorithmParameterGenerator.java index b85eac0dc0b..307aaaf17eb 100644 --- a/jdk/src/share/classes/java/security/AlgorithmParameterGenerator.java +++ b/jdk/src/share/classes/java/security/AlgorithmParameterGenerator.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -28,10 +28,10 @@ package java.security; import java.security.spec.AlgorithmParameterSpec; /** - * The AlgorithmParameterGenerator class is used to generate a + * The {@code AlgorithmParameterGenerator} class is used to generate a * set of * parameters to be used with a certain algorithm. Parameter generators - * are constructed using the getInstance factory methods + * are constructed using the {@code getInstance} factory methods * (static methods that return instances of a given class). * *

    The object that will generate the parameters can be initialized @@ -61,17 +61,17 @@ import java.security.spec.AlgorithmParameterSpec; * *

    In case the client does not explicitly initialize the * AlgorithmParameterGenerator - * (via a call to an init method), each provider must supply (and + * (via a call to an {@code init} method), each provider must supply (and * document) a default initialization. For example, the Sun provider uses a * default modulus prime size of 1024 bits for the generation of DSA * parameters. * *

    Every implementation of the Java platform is required to support the - * following standard AlgorithmParameterGenerator algorithms and + * following standard {@code AlgorithmParameterGenerator} algorithms and * keysizes in parentheses: *

      - *
    • DiffieHellman (1024)
    • - *
    • DSA (1024)
    • + *
    • {@code DiffieHellman} (1024)
    • + *
    • {@code DSA} (1024)
    • *
    * These algorithms are described in the
    @@ -272,11 +272,11 @@ public class AlgorithmParameterGenerator { /** * Initializes this parameter generator for a certain size. - * To create the parameters, the SecureRandom + * To create the parameters, the {@code SecureRandom} * implementation of the highest-priority installed provider is used as * the source of randomness. * (If none of the installed providers supply an implementation of - * SecureRandom, a system-provided source of randomness is + * {@code SecureRandom}, a system-provided source of randomness is * used.) * * @param size the size (number of bits). @@ -299,11 +299,11 @@ public class AlgorithmParameterGenerator { /** * Initializes this parameter generator with a set of algorithm-specific * parameter generation values. - * To generate the parameters, the SecureRandom + * To generate the parameters, the {@code SecureRandom} * implementation of the highest-priority installed provider is used as * the source of randomness. * (If none of the installed providers supply an implementation of - * SecureRandom, a system-provided source of randomness is + * {@code SecureRandom}, a system-provided source of randomness is * used.) * * @param genParamSpec the set of algorithm-specific parameter generation values. diff --git a/jdk/src/share/classes/java/security/AlgorithmParameterGeneratorSpi.java b/jdk/src/share/classes/java/security/AlgorithmParameterGeneratorSpi.java index 729470ab85c..721fb52ac18 100644 --- a/jdk/src/share/classes/java/security/AlgorithmParameterGeneratorSpi.java +++ b/jdk/src/share/classes/java/security/AlgorithmParameterGeneratorSpi.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 1999, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -29,7 +29,7 @@ import java.security.spec.AlgorithmParameterSpec; /** * This class defines the Service Provider Interface (SPI) - * for the AlgorithmParameterGenerator class, which + * for the {@code AlgorithmParameterGenerator} class, which * is used to generate a set of parameters to be used with a certain algorithm. * *

    All the abstract methods in this class must be implemented by each @@ -37,7 +37,7 @@ import java.security.spec.AlgorithmParameterSpec; * of a parameter generator for a particular algorithm. * *

    In case the client does not explicitly initialize the - * AlgorithmParameterGenerator (via a call to an engineInit + * AlgorithmParameterGenerator (via a call to an {@code engineInit} * method), each provider must supply (and document) a default initialization. * For example, the Sun provider uses a default modulus prime size of 1024 * bits for the generation of DSA parameters. diff --git a/jdk/src/share/classes/java/security/AlgorithmParameters.java b/jdk/src/share/classes/java/security/AlgorithmParameters.java index 36ba66eb38b..c603a196c9f 100644 --- a/jdk/src/share/classes/java/security/AlgorithmParameters.java +++ b/jdk/src/share/classes/java/security/AlgorithmParameters.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -32,28 +32,28 @@ import java.security.spec.InvalidParameterSpecException; /** * This class is used as an opaque representation of cryptographic parameters. * - *

    An AlgorithmParameters object for managing the parameters + *

    An {@code AlgorithmParameters} object for managing the parameters * for a particular algorithm can be obtained by - * calling one of the getInstance factory methods + * calling one of the {@code getInstance} factory methods * (static methods that return instances of a given class). * - *

    Once an AlgorithmParameters object is obtained, it must be - * initialized via a call to init, using an appropriate parameter + *

    Once an {@code AlgorithmParameters} object is obtained, it must be + * initialized via a call to {@code init}, using an appropriate parameter * specification or parameter encoding. * *

    A transparent parameter specification is obtained from an - * AlgorithmParameters object via a call to - * getParameterSpec, and a byte encoding of the parameters is - * obtained via a call to getEncoded. + * {@code AlgorithmParameters} object via a call to + * {@code getParameterSpec}, and a byte encoding of the parameters is + * obtained via a call to {@code getEncoded}. * *

    Every implementation of the Java platform is required to support the - * following standard AlgorithmParameters algorithms: + * following standard {@code AlgorithmParameters} algorithms: *

      - *
    • AES
    • - *
    • DES
    • - *
    • DESede
    • - *
    • DiffieHellman
    • - *
    • DSA
    • + *
    • {@code AES}
    • + *
    • {@code DES}
    • + *
    • {@code DESede}
    • + *
    • {@code DiffieHellman}
    • + *
    • {@code DSA}
    • *
    * These algorithms are described in the
    @@ -123,7 +123,7 @@ public class AlgorithmParameters { * the {@link Security#getProviders() Security.getProviders()} method. * *

    The returned parameter object must be initialized via a call to - * init, using an appropriate parameter specification or + * {@code init}, using an appropriate parameter specification or * parameter encoding. * * @param algorithm the name of the algorithm requested. @@ -165,7 +165,7 @@ public class AlgorithmParameters { * the {@link Security#getProviders() Security.getProviders()} method. * *

    The returned parameter object must be initialized via a call to - * init, using an appropriate parameter specification or + * {@code init}, using an appropriate parameter specification or * parameter encoding. * * @param algorithm the name of the algorithm requested. @@ -212,7 +212,7 @@ public class AlgorithmParameters { * does not have to be registered in the provider list. * *

    The returned parameter object must be initialized via a call to - * init, using an appropriate parameter specification or + * {@code init}, using an appropriate parameter specification or * parameter encoding. * * @param algorithm the name of the algorithm requested. @@ -259,7 +259,7 @@ public class AlgorithmParameters { /** * Initializes this parameter object using the parameters - * specified in paramSpec. + * specified in {@code paramSpec}. * * @param paramSpec the parameter specification. * @@ -295,9 +295,9 @@ public class AlgorithmParameters { } /** - * Imports the parameters from params and decodes them + * Imports the parameters from {@code params} and decodes them * according to the specified decoding scheme. - * If format is null, the + * If {@code format} is null, the * primary decoding format for parameters is used. The primary decoding * format is ASN.1, if an ASN.1 specification for these parameters * exists. @@ -318,11 +318,11 @@ public class AlgorithmParameters { /** * Returns a (transparent) specification of this parameter object. - * paramSpec identifies the specification class in which + * {@code paramSpec} identifies the specification class in which * the parameters should be returned. It could, for example, be - * DSAParameterSpec.class, to indicate that the + * {@code DSAParameterSpec.class}, to indicate that the * parameters should be returned in an instance of the - * DSAParameterSpec class. + * {@code DSAParameterSpec} class. * * @param paramSpec the specification class in which * the parameters should be returned. @@ -363,7 +363,7 @@ public class AlgorithmParameters { /** * Returns the parameters encoded in the specified scheme. - * If format is null, the + * If {@code format} is null, the * primary encoding format for parameters is used. The primary encoding * format is ASN.1, if an ASN.1 specification for these parameters * exists. diff --git a/jdk/src/share/classes/java/security/AlgorithmParametersSpi.java b/jdk/src/share/classes/java/security/AlgorithmParametersSpi.java index 17db77ed28d..be231a4cafe 100644 --- a/jdk/src/share/classes/java/security/AlgorithmParametersSpi.java +++ b/jdk/src/share/classes/java/security/AlgorithmParametersSpi.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2004, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -31,7 +31,7 @@ import java.security.spec.InvalidParameterSpecException; /** * This class defines the Service Provider Interface (SPI) - * for the AlgorithmParameters class, which is used to manage + * for the {@code AlgorithmParameters} class, which is used to manage * algorithm parameters. * *

    All the abstract methods in this class must be implemented by each @@ -52,7 +52,7 @@ public abstract class AlgorithmParametersSpi { /** * Initializes this parameters object using the parameters - * specified in paramSpec. + * specified in {@code paramSpec}. * * @param paramSpec the parameter specification. * @@ -77,9 +77,9 @@ public abstract class AlgorithmParametersSpi { throws IOException; /** - * Imports the parameters from params and + * Imports the parameters from {@code params} and * decodes them according to the specified decoding format. - * If format is null, the + * If {@code format} is null, the * primary decoding format for parameters is used. The primary decoding * format is ASN.1, if an ASN.1 specification for these parameters * exists. @@ -96,11 +96,11 @@ public abstract class AlgorithmParametersSpi { /** * Returns a (transparent) specification of this parameters * object. - * paramSpec identifies the specification class in which + * {@code paramSpec} identifies the specification class in which * the parameters should be returned. It could, for example, be - * DSAParameterSpec.class, to indicate that the + * {@code DSAParameterSpec.class}, to indicate that the * parameters should be returned in an instance of the - * DSAParameterSpec class. + * {@code DSAParameterSpec} class. * * @param paramSpec the specification class in which * the parameters should be returned. @@ -128,7 +128,7 @@ public abstract class AlgorithmParametersSpi { /** * Returns the parameters encoded in the specified format. - * If format is null, the + * If {@code format} is null, the * primary encoding format for parameters is used. The primary encoding * format is ASN.1, if an ASN.1 specification for these parameters * exists. diff --git a/jdk/src/share/classes/java/security/AllPermission.java b/jdk/src/share/classes/java/security/AllPermission.java index 5ca8b2ad91a..c01b134f074 100644 --- a/jdk/src/share/classes/java/security/AllPermission.java +++ b/jdk/src/share/classes/java/security/AllPermission.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2013, 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 @@ -69,7 +69,7 @@ public final class AllPermission extends Permission { /** * Creates a new AllPermission object. This - * constructor exists for use by the Policy object + * constructor exists for use by the {@code Policy} object * to instantiate new Permission objects. * * @param name ignored diff --git a/jdk/src/share/classes/java/security/AuthProvider.java b/jdk/src/share/classes/java/security/AuthProvider.java index fe37d5c3c60..a5310aa9f42 100644 --- a/jdk/src/share/classes/java/security/AuthProvider.java +++ b/jdk/src/share/classes/java/security/AuthProvider.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2004, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -32,8 +32,8 @@ import javax.security.auth.callback.CallbackHandler; /** * This class defines login and logout methods for a provider. * - *

    While callers may invoke login directly, - * the provider may also invoke login on behalf of callers + *

    While callers may invoke {@code login} directly, + * the provider may also invoke {@code login} on behalf of callers * if it determines that a login must be performed * prior to certain operations. * @@ -56,11 +56,11 @@ public abstract class AuthProvider extends Provider { /** * Log in to this provider. * - *

    The provider relies on a CallbackHandler + *

    The provider relies on a {@code CallbackHandler} * to obtain authentication information from the caller - * (a PIN, for example). If the caller passes a null + * (a PIN, for example). If the caller passes a {@code null} * handler to this method, the provider uses the handler set in the - * setCallbackHandler method. + * {@code setCallbackHandler} method. * If no handler was set in that method, the provider queries the * auth.login.defaultCallbackHandler security property * for the fully qualified class name of a default handler implementation. @@ -68,21 +68,21 @@ public abstract class AuthProvider extends Provider { * the provider is assumed to have alternative means * for obtaining authentication information. * - * @param subject the Subject which may contain + * @param subject the {@code Subject} which may contain * principals/credentials used for authentication, * or may be populated with additional principals/credentials * after successful authentication has completed. - * This parameter may be null. - * @param handler the CallbackHandler used by + * This parameter may be {@code null}. + * @param handler the {@code CallbackHandler} used by * this provider to obtain authentication information - * from the caller, which may be null + * from the caller, which may be {@code null} * * @exception LoginException if the login operation fails * @exception SecurityException if the caller does not pass a * security check for - * SecurityPermission("authProvider.name"), - * where name is the value returned by - * this provider's getName method + * {@code SecurityPermission("authProvider.name")}, + * where {@code name} is the value returned by + * this provider's {@code getName} method */ public abstract void login(Subject subject, CallbackHandler handler) throws LoginException; @@ -93,18 +93,18 @@ public abstract class AuthProvider extends Provider { * @exception LoginException if the logout operation fails * @exception SecurityException if the caller does not pass a * security check for - * SecurityPermission("authProvider.name"), - * where name is the value returned by - * this provider's getName method + * {@code SecurityPermission("authProvider.name")}, + * where {@code name} is the value returned by + * this provider's {@code getName} method */ public abstract void logout() throws LoginException; /** - * Set a CallbackHandler. + * Set a {@code CallbackHandler}. * *

    The provider uses this handler if one is not passed to the - * login method. The provider also uses this handler - * if it invokes login on behalf of callers. + * {@code login} method. The provider also uses this handler + * if it invokes {@code login} on behalf of callers. * In either case if a handler is not set via this method, * the provider queries the * auth.login.defaultCallbackHandler security property @@ -113,14 +113,14 @@ public abstract class AuthProvider extends Provider { * the provider is assumed to have alternative means * for obtaining authentication information. * - * @param handler a CallbackHandler for obtaining - * authentication information, which may be null + * @param handler a {@code CallbackHandler} for obtaining + * authentication information, which may be {@code null} * * @exception SecurityException if the caller does not pass a * security check for - * SecurityPermission("authProvider.name"), - * where name is the value returned by - * this provider's getName method + * {@code SecurityPermission("authProvider.name")}, + * where {@code name} is the value returned by + * this provider's {@code getName} method */ public abstract void setCallbackHandler(CallbackHandler handler); } diff --git a/jdk/src/share/classes/java/security/BasicPermission.java b/jdk/src/share/classes/java/security/BasicPermission.java index 439eefa83f1..2d0c96665ee 100644 --- a/jdk/src/share/classes/java/security/BasicPermission.java +++ b/jdk/src/share/classes/java/security/BasicPermission.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -124,8 +124,8 @@ public abstract class BasicPermission extends Permission * * @param name the name of the BasicPermission. * - * @throws NullPointerException if name is null. - * @throws IllegalArgumentException if name is empty. + * @throws NullPointerException if {@code name} is {@code null}. + * @throws IllegalArgumentException if {@code name} is empty. */ public BasicPermission(String name) { super(name); @@ -141,8 +141,8 @@ public abstract class BasicPermission extends Permission * @param name the name of the BasicPermission. * @param actions ignored. * - * @throws NullPointerException if name is null. - * @throws IllegalArgumentException if name is empty. + * @throws NullPointerException if {@code name} is {@code null}. + * @throws IllegalArgumentException if {@code name} is empty. */ public BasicPermission(String name, String actions) { super(name); @@ -217,7 +217,7 @@ public abstract class BasicPermission extends Permission /** * Returns the hash code value for this object. * The hash code used is the hash code of the name, that is, - * getName().hashCode(), where getName is + * {@code getName().hashCode()}, where {@code getName} is * from the Permission superclass. * * @return a hash code value for this object. @@ -243,7 +243,7 @@ public abstract class BasicPermission extends Permission * *

    BasicPermission objects must be stored in a manner that allows them * to be inserted in any order, but that also enables the - * PermissionCollection implies method + * PermissionCollection {@code implies} method * to be implemented in an efficient (and consistent) manner. * * @return a new PermissionCollection object suitable for @@ -312,7 +312,7 @@ final class BasicPermissionCollection private transient Map perms; /** - * This is set to true if this BasicPermissionCollection + * This is set to {@code true} if this BasicPermissionCollection * contains a BasicPermission with '*' as its permission name. * * @see #serialPersistentFields @@ -477,7 +477,7 @@ final class BasicPermissionCollection * The Hashtable is indexed by the BasicPermission name; the value * of the Hashtable entry is the permission. * @serialField all_allowed boolean - * This is set to true if this BasicPermissionCollection + * This is set to {@code true} if this BasicPermissionCollection * contains a BasicPermission with '*' as its permission name. * @serialField permClass java.lang.Class * The class to which all BasicPermissions in this diff --git a/jdk/src/share/classes/java/security/Certificate.java b/jdk/src/share/classes/java/security/Certificate.java index 000a5e0bb59..489c6d620af 100644 --- a/jdk/src/share/classes/java/security/Certificate.java +++ b/jdk/src/share/classes/java/security/Certificate.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2006, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2013, 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 @@ -96,7 +96,7 @@ public interface Certificate { /** * Encodes the certificate to an output stream in a format that can - * be decoded by the decode method. + * be decoded by the {@code decode} method. * * @param stream the output stream to which to encode the * certificate. @@ -115,8 +115,8 @@ public interface Certificate { /** * Decodes a certificate from an input stream. The format should be - * that returned by getFormat and produced by - * encode. + * that returned by {@code getFormat} and produced by + * {@code encode}. * * @param stream the input stream from which to fetch the data * being decoded. @@ -137,8 +137,8 @@ public interface Certificate { /** * Returns the name of the coding format. This is used as a hint to find * an appropriate parser. It could be "X.509", "PGP", etc. This is - * the format produced and understood by the encode - * and decode methods. + * the format produced and understood by the {@code encode} + * and {@code decode} methods. * * @return the name of the coding format. */ diff --git a/jdk/src/share/classes/java/security/CodeSigner.java b/jdk/src/share/classes/java/security/CodeSigner.java index 0b233d321fa..37c12b153b3 100644 --- a/jdk/src/share/classes/java/security/CodeSigner.java +++ b/jdk/src/share/classes/java/security/CodeSigner.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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,12 @@ public final class CodeSigner implements Serializable { * Constructs a CodeSigner object. * * @param signerCertPath The signer's certificate path. - * It must not be null. + * It must not be {@code null}. * @param timestamp A signature timestamp. - * If null then no timestamp was generated + * If {@code null} then no timestamp was generated * for the signature. - * @throws NullPointerException if signerCertPath is - * null. + * @throws NullPointerException if {@code signerCertPath} is + * {@code null}. */ public CodeSigner(CertPath signerCertPath, Timestamp timestamp) { if (signerCertPath == null) { @@ -90,7 +90,7 @@ public final class CodeSigner implements Serializable { /** * Returns the signature timestamp. * - * @return The timestamp or null if none is present. + * @return The timestamp or {@code null} if none is present. */ public Timestamp getTimestamp() { return timestamp; diff --git a/jdk/src/share/classes/java/security/CodeSource.java b/jdk/src/share/classes/java/security/CodeSource.java index 7ab76111417..b6167cb008b 100644 --- a/jdk/src/share/classes/java/security/CodeSource.java +++ b/jdk/src/share/classes/java/security/CodeSource.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -485,13 +485,13 @@ public class CodeSource implements java.io.Serializable { /** * Writes this object out to a stream (i.e., serializes it). * - * @serialData An initial URL is followed by an - * int indicating the number of certificates to follow + * @serialData An initial {@code URL} is followed by an + * {@code int} indicating the number of certificates to follow * (a value of "zero" denotes that there are no certificates associated * with this object). - * Each certificate is written out starting with a String + * Each certificate is written out starting with a {@code String} * denoting the certificate type, followed by an - * int specifying the length of the certificate encoding, + * {@code int} specifying the length of the certificate encoding, * followed by the certificate encoding itself which is written out as an * array of bytes. Finally, if any code signers are present then the array * of code signers is serialized and written out too. diff --git a/jdk/src/share/classes/java/security/DigestException.java b/jdk/src/share/classes/java/security/DigestException.java index 9d447509478..2327c982845 100644 --- a/jdk/src/share/classes/java/security/DigestException.java +++ b/jdk/src/share/classes/java/security/DigestException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2013, 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 @@ -55,13 +55,13 @@ public class DigestException extends GeneralSecurityException { } /** - * Creates a DigestException with the specified + * Creates a {@code DigestException} with the specified * detail message and cause. * * @param message the detail message (which is saved for later retrieval * by the {@link #getMessage()} method). * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause()} method). (A null value is permitted, + * {@link #getCause()} method). (A {@code null} value is permitted, * and indicates that the cause is nonexistent or unknown.) * @since 1.5 */ @@ -70,13 +70,13 @@ public class DigestException extends GeneralSecurityException { } /** - * Creates a DigestException with the specified cause - * and a detail message of (cause==null ? null : cause.toString()) + * Creates a {@code DigestException} with the specified cause + * and a detail message of {@code (cause==null ? null : cause.toString())} * (which typically contains the class and detail message of - * cause). + * {@code cause}). * * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause()} method). (A null value is permitted, + * {@link #getCause()} method). (A {@code null} value is permitted, * and indicates that the cause is nonexistent or unknown.) * @since 1.5 */ diff --git a/jdk/src/share/classes/java/security/DigestInputStream.java b/jdk/src/share/classes/java/security/DigestInputStream.java index 8aa16dc0f62..a1bf55ac9e7 100644 --- a/jdk/src/share/classes/java/security/DigestInputStream.java +++ b/jdk/src/share/classes/java/security/DigestInputStream.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 1999, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2013, 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 @@ -37,13 +37,13 @@ import java.io.ByteArrayInputStream; * the bits going through the stream. * *

    To complete the message digest computation, call one of the - * digest methods on the associated message + * {@code digest} methods on the associated message * digest after your calls to one of this digest input stream's * {@link #read() read} methods. * *

    It is possible to turn this stream on or off (see * {@link #on(boolean) on}). When it is on, a call to one of the - * read methods + * {@code read} methods * results in an update on the message digest. But when it is off, * the message digest is not updated. The default is for the stream * to be on. @@ -111,7 +111,7 @@ public class DigestInputStream extends FilterInputStream { * function is on). That is, this method reads a byte from the * input stream, blocking until the byte is actually read. If the * digest function is on (see {@link #on(boolean) on}), this method - * will then call update on the message digest associated + * will then call {@code update} on the message digest associated * with this stream, passing it the byte read. * * @return the byte read. @@ -131,25 +131,25 @@ public class DigestInputStream extends FilterInputStream { /** * Reads into a byte array, and updates the message digest (if the * digest function is on). That is, this method reads up to - * len bytes from the input stream into the array - * b, starting at offset off. This method + * {@code len} bytes from the input stream into the array + * {@code b}, starting at offset {@code off}. This method * blocks until the data is actually * read. If the digest function is on (see - * {@link #on(boolean) on}), this method will then call update + * {@link #on(boolean) on}), this method will then call {@code update} * on the message digest associated with this stream, passing it * the data. * * @param b the array into which the data is read. * - * @param off the starting offset into b of where the + * @param off the starting offset into {@code b} of where the * data should be placed. * * @param len the maximum number of bytes to be read from the input - * stream into b, starting at offset off. + * stream into b, starting at offset {@code off}. * * @return the actual number of bytes read. This is less than - * len if the end of the stream is reached prior to - * reading len bytes. -1 is returned if no bytes were + * {@code len} if the end of the stream is reached prior to + * reading {@code len} bytes. -1 is returned if no bytes were * read because the end of the stream had already been reached when * the call was made. * @@ -167,7 +167,7 @@ public class DigestInputStream extends FilterInputStream { /** * Turns the digest function on or off. The default is on. When - * it is on, a call to one of the read methods results in an + * it is on, a call to one of the {@code read} methods results in an * update on the message digest. But when it is off, the message * digest is not updated. * diff --git a/jdk/src/share/classes/java/security/DigestOutputStream.java b/jdk/src/share/classes/java/security/DigestOutputStream.java index 31b77259ea6..5634a2252ec 100644 --- a/jdk/src/share/classes/java/security/DigestOutputStream.java +++ b/jdk/src/share/classes/java/security/DigestOutputStream.java @@ -37,13 +37,13 @@ import java.io.ByteArrayOutputStream; * the bits going through the stream. * *

    To complete the message digest computation, call one of the - * digest methods on the associated message + * {@code digest} methods on the associated message * digest after your calls to one of this digest ouput stream's * {@link #write(int) write} methods. * *

    It is possible to turn this stream on or off (see * {@link #on(boolean) on}). When it is on, a call to one of the - * write methods results in + * {@code write} methods results in * an update on the message digest. But when it is off, the message * digest is not updated. The default is for the stream to be on. * @@ -99,8 +99,8 @@ public class DigestOutputStream extends FilterOutputStream { * the specified byte, and in any case writes the byte * to the output stream. That is, if the digest function is on * (see {@link #on(boolean) on}), this method calls - * update on the message digest associated with this - * stream, passing it the byte b. This method then + * {@code update} on the message digest associated with this + * stream, passing it the byte {@code b}. This method then * writes the byte to the output stream, blocking until the byte * is actually written. * @@ -122,7 +122,7 @@ public class DigestOutputStream extends FilterOutputStream { * Updates the message digest (if the digest function is on) using * the specified subarray, and in any case writes the subarray to * the output stream. That is, if the digest function is on (see - * {@link #on(boolean) on}), this method calls update + * {@link #on(boolean) on}), this method calls {@code update} * on the message digest associated with this stream, passing it * the subarray specifications. This method then writes the subarray * bytes to the output stream, blocking until the bytes are actually @@ -131,11 +131,11 @@ public class DigestOutputStream extends FilterOutputStream { * @param b the array containing the subarray to be used for updating * and writing to the output stream. * - * @param off the offset into b of the first byte to + * @param off the offset into {@code b} of the first byte to * be updated and written. * * @param len the number of bytes of data to be updated and written - * from b, starting at offset off. + * from {@code b}, starting at offset {@code off}. * * @exception IOException if an I/O error occurs. * @@ -150,7 +150,7 @@ public class DigestOutputStream extends FilterOutputStream { /** * Turns the digest function on or off. The default is on. When - * it is on, a call to one of the write methods results in an + * it is on, a call to one of the {@code write} methods results in an * update on the message digest. But when it is off, the message * digest is not updated. * diff --git a/jdk/src/share/classes/java/security/DomainCombiner.java b/jdk/src/share/classes/java/security/DomainCombiner.java index e6549de0888..7aadc7e7b2f 100644 --- a/jdk/src/share/classes/java/security/DomainCombiner.java +++ b/jdk/src/share/classes/java/security/DomainCombiner.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2006, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2013, 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 @@ -26,27 +26,27 @@ package java.security; /** - * A DomainCombiner provides a means to dynamically + * A {@code DomainCombiner} provides a means to dynamically * update the ProtectionDomains associated with the current - * AccessControlContext. + * {@code AccessControlContext}. * - *

    A DomainCombiner is passed as a parameter to the - * appropriate constructor for AccessControlContext. + *

    A {@code DomainCombiner} is passed as a parameter to the + * appropriate constructor for {@code AccessControlContext}. * The newly constructed context is then passed to the - * AccessController.doPrivileged(..., context) method - * to bind the provided context (and associated DomainCombiner) + * {@code AccessController.doPrivileged(..., context)} method + * to bind the provided context (and associated {@code DomainCombiner}) * with the current execution Thread. Subsequent calls to - * AccessController.getContext or - * AccessController.checkPermission - * cause the DomainCombiner.combine to get invoked. + * {@code AccessController.getContext} or + * {@code AccessController.checkPermission} + * cause the {@code DomainCombiner.combine} to get invoked. * *

    The combine method takes two arguments. The first argument represents * an array of ProtectionDomains from the current execution Thread, - * since the most recent call to AccessController.doPrivileged. + * since the most recent call to {@code AccessController.doPrivileged}. * If no call to doPrivileged was made, then the first argument will contain * all the ProtectionDomains from the current execution Thread. * The second argument represents an array of inherited ProtectionDomains, - * which may be null. ProtectionDomains may be inherited + * which may be {@code null}. ProtectionDomains may be inherited * from a parent Thread, or from a privileged context. If no call to * doPrivileged was made, then the second argument will contain the * ProtectionDomains inherited from the parent Thread. If one or more calls @@ -54,25 +54,25 @@ package java.security; * doPrivileged(action, context), then the second argument will contain the * ProtectionDomains from the privileged context. If the most recent call * was to doPrivileged(action), then there is no privileged context, - * and the second argument will be null. + * and the second argument will be {@code null}. * - *

    The combine method investigates the two input arrays + *

    The {@code combine} method investigates the two input arrays * of ProtectionDomains and returns a single array containing the updated - * ProtectionDomains. In the simplest case, the combine + * ProtectionDomains. In the simplest case, the {@code combine} * method merges the two stacks into one. In more complex cases, - * the combine method returns a modified + * the {@code combine} method returns a modified * stack of ProtectionDomains. The modification may have added new * ProtectionDomains, removed certain ProtectionDomains, or simply * updated existing ProtectionDomains. Re-ordering and other optimizations * to the ProtectionDomains are also permitted. Typically the - * combine method bases its updates on the information - * encapsulated in the DomainCombiner. + * {@code combine} method bases its updates on the information + * encapsulated in the {@code DomainCombiner}. * - *

    After the AccessController.getContext method + *

    After the {@code AccessController.getContext} method * receives the combined stack of ProtectionDomains back from - * the DomainCombiner, it returns a new + * the {@code DomainCombiner}, it returns a new * AccessControlContext that has both the combined ProtectionDomains - * as well as the DomainCombiner. + * as well as the {@code DomainCombiner}. * * @see AccessController * @see AccessControlContext @@ -91,21 +91,21 @@ public interface DomainCombiner { * * @param currentDomains the ProtectionDomains associated with the * current execution Thread, up to the most recent - * privileged ProtectionDomain. + * privileged {@code ProtectionDomain}. * The ProtectionDomains are are listed in order of execution, - * with the most recently executing ProtectionDomain + * with the most recently executing {@code ProtectionDomain} * residing at the beginning of the array. This parameter may - * be null if the current execution Thread + * be {@code null} if the current execution Thread * has no associated ProtectionDomains.

    * * @param assignedDomains an array of inherited ProtectionDomains. * ProtectionDomains may be inherited from a parent Thread, - * or from a privileged AccessControlContext. - * This parameter may be null + * or from a privileged {@code AccessControlContext}. + * This parameter may be {@code null} * if there are no inherited ProtectionDomains. * * @return a new array consisting of the updated ProtectionDomains, - * or null. + * or {@code null}. */ ProtectionDomain[] combine(ProtectionDomain[] currentDomains, ProtectionDomain[] assignedDomains); diff --git a/jdk/src/share/classes/java/security/GeneralSecurityException.java b/jdk/src/share/classes/java/security/GeneralSecurityException.java index 60b56885845..dc9ea06ecce 100644 --- a/jdk/src/share/classes/java/security/GeneralSecurityException.java +++ b/jdk/src/share/classes/java/security/GeneralSecurityException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -26,7 +26,7 @@ package java.security; /** - * The GeneralSecurityException class is a generic + * The {@code GeneralSecurityException} class is a generic * security exception class that provides type safety for all the * security-related exception classes that extend from it. * @@ -57,13 +57,13 @@ public class GeneralSecurityException extends Exception { } /** - * Creates a GeneralSecurityException with the specified + * Creates a {@code GeneralSecurityException} with the specified * detail message and cause. * * @param message the detail message (which is saved for later retrieval * by the {@link #getMessage()} method). * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause()} method). (A null value is permitted, + * {@link #getCause()} method). (A {@code null} value is permitted, * and indicates that the cause is nonexistent or unknown.) * @since 1.5 */ @@ -72,13 +72,13 @@ public class GeneralSecurityException extends Exception { } /** - * Creates a GeneralSecurityException with the specified cause - * and a detail message of (cause==null ? null : cause.toString()) + * Creates a {@code GeneralSecurityException} with the specified cause + * and a detail message of {@code (cause==null ? null : cause.toString())} * (which typically contains the class and detail message of - * cause). + * {@code cause}). * * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause()} method). (A null value is permitted, + * {@link #getCause()} method). (A {@code null} value is permitted, * and indicates that the cause is nonexistent or unknown.) * @since 1.5 */ diff --git a/jdk/src/share/classes/java/security/Guard.java b/jdk/src/share/classes/java/security/Guard.java index 7cfd25b6ca1..abafb588659 100644 --- a/jdk/src/share/classes/java/security/Guard.java +++ b/jdk/src/share/classes/java/security/Guard.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 1998, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -29,9 +29,9 @@ package java.security; *

    This interface represents a guard, which is an object that is used * to protect access to another object. * - *

    This interface contains a single method, checkGuard, - * with a single object argument. checkGuard is - * invoked (by the GuardedObject getObject method) + *

    This interface contains a single method, {@code checkGuard}, + * with a single {@code object} argument. {@code checkGuard} is + * invoked (by the GuardedObject {@code getObject} method) * to determine whether or not to allow access to the object. * * @see GuardedObject @@ -44,7 +44,7 @@ public interface Guard { /** * Determines whether or not to allow access to the guarded object - * object. Returns silently if access is allowed. + * {@code object}. Returns silently if access is allowed. * Otherwise, throws a SecurityException. * * @param object the object being protected by the guard. diff --git a/jdk/src/share/classes/java/security/GuardedObject.java b/jdk/src/share/classes/java/security/GuardedObject.java index c4edb234a50..a275ddf043e 100644 --- a/jdk/src/share/classes/java/security/GuardedObject.java +++ b/jdk/src/share/classes/java/security/GuardedObject.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2004, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -33,9 +33,9 @@ package java.security; * such that access to the target object is possible * only if the Guard object allows it. * Once an object is encapsulated by a GuardedObject, - * access to that object is controlled by the getObject + * access to that object is controlled by the {@code getObject} * method, which invokes the - * checkGuard method on the Guard object that is + * {@code checkGuard} method on the Guard object that is * guarding access. If access is not allowed, * an exception is thrown. * diff --git a/jdk/src/share/classes/java/security/Identity.java b/jdk/src/share/classes/java/security/Identity.java index b7a36c4b340..6a5e87e20fa 100644 --- a/jdk/src/share/classes/java/security/Identity.java +++ b/jdk/src/share/classes/java/security/Identity.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2006, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2013, 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 @@ -52,9 +52,9 @@ import java.util.*; * * @author Benjamin Renaud * @deprecated This class is no longer used. Its functionality has been - * replaced by java.security.KeyStore, the - * java.security.cert package, and - * java.security.Principal. + * replaced by {@code java.security.KeyStore}, the + * {@code java.security.cert} package, and + * {@code java.security.Principal}. */ @Deprecated public abstract class Identity implements Principal, Serializable { @@ -164,8 +164,8 @@ public abstract class Identity implements Principal, Serializable { * Sets this identity's public key. The old key and all of this * identity's certificates are removed by this operation. * - *

    First, if there is a security manager, its checkSecurityAccess - * method is called with "setIdentityPublicKey" + *

    First, if there is a security manager, its {@code checkSecurityAccess} + * method is called with {@code "setIdentityPublicKey"} * as its argument to see if it's ok to set the public key. * * @param key the public key for this identity. @@ -174,7 +174,7 @@ public abstract class Identity implements Principal, Serializable { * identity's scope has the same public key, or if another exception occurs. * * @exception SecurityException if a security manager exists and its - * checkSecurityAccess method doesn't allow + * {@code checkSecurityAccess} method doesn't allow * setting the public key. * * @see #getPublicKey @@ -191,14 +191,14 @@ public abstract class Identity implements Principal, Serializable { /** * Specifies a general information string for this identity. * - *

    First, if there is a security manager, its checkSecurityAccess - * method is called with "setIdentityInfo" + *

    First, if there is a security manager, its {@code checkSecurityAccess} + * method is called with {@code "setIdentityInfo"} * as its argument to see if it's ok to specify the information string. * * @param info the information string. * * @exception SecurityException if a security manager exists and its - * checkSecurityAccess method doesn't allow + * {@code checkSecurityAccess} method doesn't allow * setting the information string. * * @see #getInfo @@ -226,8 +226,8 @@ public abstract class Identity implements Principal, Serializable { * the identity does not have a public key, the identity's * public key is set to be that specified in the certificate. * - *

    First, if there is a security manager, its checkSecurityAccess - * method is called with "addIdentityCertificate" + *

    First, if there is a security manager, its {@code checkSecurityAccess} + * method is called with {@code "addIdentityCertificate"} * as its argument to see if it's ok to add a certificate. * * @param certificate the certificate to be added. @@ -237,7 +237,7 @@ public abstract class Identity implements Principal, Serializable { * this identity's public key, or if another exception occurs. * * @exception SecurityException if a security manager exists and its - * checkSecurityAccess method doesn't allow + * {@code checkSecurityAccess} method doesn't allow * adding a certificate. * * @see SecurityManager#checkSecurityAccess @@ -277,8 +277,8 @@ public abstract class Identity implements Principal, Serializable { /** * Removes a certificate from this identity. * - *

    First, if there is a security manager, its checkSecurityAccess - * method is called with "removeIdentityCertificate" + *

    First, if there is a security manager, its {@code checkSecurityAccess} + * method is called with {@code "removeIdentityCertificate"} * as its argument to see if it's ok to remove a certificate. * * @param certificate the certificate to be removed. @@ -287,7 +287,7 @@ public abstract class Identity implements Principal, Serializable { * missing, or if another exception occurs. * * @exception SecurityException if a security manager exists and its - * checkSecurityAccess method doesn't allow + * {@code checkSecurityAccess} method doesn't allow * removing a certificate. * * @see SecurityManager#checkSecurityAccess @@ -390,15 +390,15 @@ public abstract class Identity implements Principal, Serializable { * Returns a short string describing this identity, telling its * name and its scope (if any). * - *

    First, if there is a security manager, its checkSecurityAccess - * method is called with "printIdentity" + *

    First, if there is a security manager, its {@code checkSecurityAccess} + * method is called with {@code "printIdentity"} * as its argument to see if it's ok to return the string. * * @return information about this identity, such as its name and the * name of its scope (if any). * * @exception SecurityException if a security manager exists and its - * checkSecurityAccess method doesn't allow + * {@code checkSecurityAccess} method doesn't allow * returning a string describing this identity. * * @see SecurityManager#checkSecurityAccess @@ -415,20 +415,20 @@ public abstract class Identity implements Principal, Serializable { /** * Returns a string representation of this identity, with * optionally more details than that provided by the - * toString method without any arguments. + * {@code toString} method without any arguments. * - *

    First, if there is a security manager, its checkSecurityAccess - * method is called with "printIdentity" + *

    First, if there is a security manager, its {@code checkSecurityAccess} + * method is called with {@code "printIdentity"} * as its argument to see if it's ok to return the string. * * @param detailed whether or not to provide detailed information. * - * @return information about this identity. If detailed + * @return information about this identity. If {@code detailed} * is true, then this method returns more information than that - * provided by the toString method without any arguments. + * provided by the {@code toString} method without any arguments. * * @exception SecurityException if a security manager exists and its - * checkSecurityAccess method doesn't allow + * {@code checkSecurityAccess} method doesn't allow * returning a string describing this identity. * * @see #toString diff --git a/jdk/src/share/classes/java/security/IdentityScope.java b/jdk/src/share/classes/java/security/IdentityScope.java index 7c58e019473..64c4a634374 100644 --- a/jdk/src/share/classes/java/security/IdentityScope.java +++ b/jdk/src/share/classes/java/security/IdentityScope.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2010, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2013, 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 @@ -57,9 +57,9 @@ import java.util.Properties; * @author Benjamin Renaud * * @deprecated This class is no longer used. Its functionality has been - * replaced by java.security.KeyStore, the - * java.security.cert package, and - * java.security.Principal. + * replaced by {@code java.security.KeyStore}, the + * {@code java.security.cert} package, and + * {@code java.security.Principal}. */ @Deprecated public abstract @@ -146,14 +146,14 @@ class IdentityScope extends Identity { * Sets the system's identity scope. * *

    First, if there is a security manager, its - * checkSecurityAccess - * method is called with "setSystemScope" + * {@code checkSecurityAccess} + * method is called with {@code "setSystemScope"} * as its argument to see if it's ok to set the identity scope. * * @param scope the scope to set. * * @exception SecurityException if a security manager exists and its - * checkSecurityAccess method doesn't allow + * {@code checkSecurityAccess} method doesn't allow * setting the identity scope. * * @see #getSystemScope @@ -176,8 +176,8 @@ class IdentityScope extends Identity { * * @param name the name of the identity to be retrieved. * - * @return the identity named name, or null if there are - * no identities named name in this scope. + * @return the identity named {@code name}, or null if there are + * no identities named {@code name} in this scope. */ public abstract Identity getIdentity(String name); diff --git a/jdk/src/share/classes/java/security/InvalidAlgorithmParameterException.java b/jdk/src/share/classes/java/security/InvalidAlgorithmParameterException.java index b4f1a08eefc..559a8beed09 100644 --- a/jdk/src/share/classes/java/security/InvalidAlgorithmParameterException.java +++ b/jdk/src/share/classes/java/security/InvalidAlgorithmParameterException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -65,13 +65,13 @@ extends GeneralSecurityException { } /** - * Creates a InvalidAlgorithmParameterException with the + * Creates a {@code InvalidAlgorithmParameterException} with the * specified detail message and cause. * * @param message the detail message (which is saved for later retrieval * by the {@link #getMessage()} method). * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause()} method). (A null value is permitted, + * {@link #getCause()} method). (A {@code null} value is permitted, * and indicates that the cause is nonexistent or unknown.) * @since 1.5 */ @@ -80,14 +80,14 @@ extends GeneralSecurityException { } /** - * Creates a InvalidAlgorithmParameterException with the + * Creates a {@code InvalidAlgorithmParameterException} with the * specified cause and a detail message of - * (cause==null ? null : cause.toString()) + * {@code (cause==null ? null : cause.toString())} * (which typically contains the class and detail message of - * cause). + * {@code cause}). * * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause()} method). (A null value is permitted, + * {@link #getCause()} method). (A {@code null} value is permitted, * and indicates that the cause is nonexistent or unknown.) * @since 1.5 */ diff --git a/jdk/src/share/classes/java/security/InvalidKeyException.java b/jdk/src/share/classes/java/security/InvalidKeyException.java index e9130f7104a..35fc64c3d9e 100644 --- a/jdk/src/share/classes/java/security/InvalidKeyException.java +++ b/jdk/src/share/classes/java/security/InvalidKeyException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2013, 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 @@ -58,13 +58,13 @@ public class InvalidKeyException extends KeyException { } /** - * Creates a InvalidKeyException with the specified + * Creates a {@code InvalidKeyException} with the specified * detail message and cause. * * @param message the detail message (which is saved for later retrieval * by the {@link #getMessage()} method). * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause()} method). (A null value is permitted, + * {@link #getCause()} method). (A {@code null} value is permitted, * and indicates that the cause is nonexistent or unknown.) * @since 1.5 */ @@ -73,13 +73,13 @@ public class InvalidKeyException extends KeyException { } /** - * Creates a InvalidKeyException with the specified cause - * and a detail message of (cause==null ? null : cause.toString()) + * Creates a {@code InvalidKeyException} with the specified cause + * and a detail message of {@code (cause==null ? null : cause.toString())} * (which typically contains the class and detail message of - * cause). + * {@code cause}). * * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause()} method). (A null value is permitted, + * {@link #getCause()} method). (A {@code null} value is permitted, * and indicates that the cause is nonexistent or unknown.) * @since 1.5 */ diff --git a/jdk/src/share/classes/java/security/Key.java b/jdk/src/share/classes/java/security/Key.java index 2df0f3e6a48..0ae4e3851b3 100644 --- a/jdk/src/share/classes/java/security/Key.java +++ b/jdk/src/share/classes/java/security/Key.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2006, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2013, 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 @@ -47,9 +47,9 @@ package java.security; * representation of the key is needed outside the Java Virtual Machine, * as when transmitting the key to some other party. The key * is encoded according to a standard format (such as - * X.509 SubjectPublicKeyInfo or PKCS#8), and + * X.509 {@code SubjectPublicKeyInfo} or PKCS#8), and * is returned using the {@link #getEncoded() getEncoded} method. - * Note: The syntax of the ASN.1 type SubjectPublicKeyInfo + * Note: The syntax of the ASN.1 type {@code SubjectPublicKeyInfo} * is defined as follows: * *

    @@ -132,11 +132,11 @@ public interface Key extends java.io.Serializable {
          * For example, the name of the ASN.1 data format for public
          * keys is SubjectPublicKeyInfo, as
          * defined by the X.509 standard; in this case, the returned format is
    -     * "X.509". Similarly,
    +     * {@code "X.509"}. Similarly,
          * the name of the ASN.1 data format for private keys is
          * PrivateKeyInfo,
          * as defined by the PKCS #8 standard; in this case, the returned format is
    -     * "PKCS#8".
    +     * {@code "PKCS#8"}.
          *
          * @return the primary encoding format of the key.
          */
    diff --git a/jdk/src/share/classes/java/security/KeyException.java b/jdk/src/share/classes/java/security/KeyException.java
    index cd79fcb30ba..59cdd6f3ab5 100644
    --- a/jdk/src/share/classes/java/security/KeyException.java
    +++ b/jdk/src/share/classes/java/security/KeyException.java
    @@ -1,5 +1,5 @@
     /*
    - * Copyright (c) 1996, 2003, Oracle and/or its affiliates. All rights reserved.
    + * Copyright (c) 1996, 2013, 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
    @@ -59,13 +59,13 @@ public class KeyException extends GeneralSecurityException {
         }
     
         /**
    -     * Creates a KeyException with the specified
    +     * Creates a {@code KeyException} with the specified
          * detail message and cause.
          *
          * @param message the detail message (which is saved for later retrieval
          *        by the {@link #getMessage()} method).
          * @param cause the cause (which is saved for later retrieval by the
    -     *        {@link #getCause()} method).  (A null value is permitted,
    +     *        {@link #getCause()} method).  (A {@code null} value is permitted,
          *        and indicates that the cause is nonexistent or unknown.)
          * @since 1.5
          */
    @@ -74,13 +74,13 @@ public class KeyException extends GeneralSecurityException {
         }
     
         /**
    -     * Creates a KeyException with the specified cause
    -     * and a detail message of (cause==null ? null : cause.toString())
    +     * Creates a {@code KeyException} with the specified cause
    +     * and a detail message of {@code (cause==null ? null : cause.toString())}
          * (which typically contains the class and detail message of
    -     * cause).
    +     * {@code cause}).
          *
          * @param cause the cause (which is saved for later retrieval by the
    -     *        {@link #getCause()} method).  (A null value is permitted,
    +     *        {@link #getCause()} method).  (A {@code null} value is permitted,
          *        and indicates that the cause is nonexistent or unknown.)
          * @since 1.5
          */
    diff --git a/jdk/src/share/classes/java/security/KeyFactory.java b/jdk/src/share/classes/java/security/KeyFactory.java
    index 85210bb7690..0eb6b754107 100644
    --- a/jdk/src/share/classes/java/security/KeyFactory.java
    +++ b/jdk/src/share/classes/java/security/KeyFactory.java
    @@ -1,5 +1,5 @@
     /*
    - * Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved.
    + * Copyright (c) 1997, 2013, 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
    @@ -37,7 +37,7 @@ import sun.security.jca.GetInstance.Instance;
     
     /**
      * Key factories are used to convert keys (opaque
    - * cryptographic keys of type Key) into key specifications
    + * cryptographic keys of type {@code Key}) into key specifications
      * (transparent representations of the underlying key material), and vice
      * versa.
      *
    @@ -47,8 +47,8 @@ import sun.security.jca.GetInstance.Instance;
      *
      * 

    Multiple compatible key specifications may exist for the same key. * For example, a DSA public key may be specified using - * DSAPublicKeySpec or - * X509EncodedKeySpec. A key factory can be used to translate + * {@code DSAPublicKeySpec} or + * {@code X509EncodedKeySpec}. A key factory can be used to translate * between compatible key specifications. * *

    The following is an example of how to use a key factory in order to @@ -68,11 +68,11 @@ import sun.security.jca.GetInstance.Instance; *

    * *

    Every implementation of the Java platform is required to support the - * following standard KeyFactory algorithms: + * following standard {@code KeyFactory} algorithms: *

      - *
    • DiffieHellman
    • - *
    • DSA
    • - *
    • RSA
    • + *
    • {@code DiffieHellman}
    • + *
    • {@code DSA}
    • + *
    • {@code RSA}
    • *
    * These algorithms are described in the
    @@ -120,7 +120,7 @@ public class KeyFactory { * @param keyFacSpi the delegate * @param provider the provider * @param algorithm the name of the algorithm - * to associate with this KeyFactory + * to associate with this {@code KeyFactory} */ protected KeyFactory(KeyFactorySpi keyFacSpi, Provider provider, String algorithm) { @@ -266,10 +266,10 @@ public class KeyFactory { /** * Gets the name of the algorithm - * associated with this KeyFactory. + * associated with this {@code KeyFactory}. * * @return the name of the algorithm associated with this - * KeyFactory + * {@code KeyFactory} */ public final String getAlgorithm() { return this.algorithm; @@ -389,11 +389,11 @@ public class KeyFactory { /** * Returns a specification (key material) of the given key object. - * keySpec identifies the specification class in which + * {@code keySpec} identifies the specification class in which * the key material should be returned. It could, for example, be - * DSAPublicKeySpec.class, to indicate that the + * {@code DSAPublicKeySpec.class}, to indicate that the * key material should be returned in an instance of the - * DSAPublicKeySpec class. + * {@code DSAPublicKeySpec} class. * * @param key the key. * diff --git a/jdk/src/share/classes/java/security/KeyFactorySpi.java b/jdk/src/share/classes/java/security/KeyFactorySpi.java index f1f4d4a30f3..877c3a11be1 100644 --- a/jdk/src/share/classes/java/security/KeyFactorySpi.java +++ b/jdk/src/share/classes/java/security/KeyFactorySpi.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2004, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -30,13 +30,13 @@ import java.security.spec.InvalidKeySpecException; /** * This class defines the Service Provider Interface (SPI) - * for the KeyFactory class. + * for the {@code KeyFactory} class. * All the abstract methods in this class must be implemented by each * cryptographic service provider who wishes to supply the implementation * of a key factory for a particular algorithm. * *

    Key factories are used to convert keys (opaque - * cryptographic keys of type Key) into key specifications + * cryptographic keys of type {@code Key}) into key specifications * (transparent representations of the underlying key material), and vice * versa. * @@ -46,8 +46,8 @@ import java.security.spec.InvalidKeySpecException; * *

    Multiple compatible key specifications may exist for the same key. * For example, a DSA public key may be specified using - * DSAPublicKeySpec or - * X509EncodedKeySpec. A key factory can be used to translate + * {@code DSAPublicKeySpec} or + * {@code X509EncodedKeySpec}. A key factory can be used to translate * between compatible key specifications. * *

    A provider should document all the key specifications supported by its @@ -100,11 +100,11 @@ public abstract class KeyFactorySpi { /** * Returns a specification (key material) of the given key * object. - * keySpec identifies the specification class in which + * {@code keySpec} identifies the specification class in which * the key material should be returned. It could, for example, be - * DSAPublicKeySpec.class, to indicate that the + * {@code DSAPublicKeySpec.class}, to indicate that the * key material should be returned in an instance of the - * DSAPublicKeySpec class. + * {@code DSAPublicKeySpec} class. * * @param key the key. * diff --git a/jdk/src/share/classes/java/security/KeyManagementException.java b/jdk/src/share/classes/java/security/KeyManagementException.java index 403e36ac55f..be212b9fdc1 100644 --- a/jdk/src/share/classes/java/security/KeyManagementException.java +++ b/jdk/src/share/classes/java/security/KeyManagementException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2013, 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 @@ -68,13 +68,13 @@ public class KeyManagementException extends KeyException { } /** - * Creates a KeyManagementException with the specified + * Creates a {@code KeyManagementException} with the specified * detail message and cause. * * @param message the detail message (which is saved for later retrieval * by the {@link #getMessage()} method). * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause()} method). (A null value is permitted, + * {@link #getCause()} method). (A {@code null} value is permitted, * and indicates that the cause is nonexistent or unknown.) * @since 1.5 */ @@ -83,13 +83,13 @@ public class KeyManagementException extends KeyException { } /** - * Creates a KeyManagementException with the specified cause - * and a detail message of (cause==null ? null : cause.toString()) + * Creates a {@code KeyManagementException} with the specified cause + * and a detail message of {@code (cause==null ? null : cause.toString())} * (which typically contains the class and detail message of - * cause). + * {@code cause}). * * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause()} method). (A null value is permitted, + * {@link #getCause()} method). (A {@code null} value is permitted, * and indicates that the cause is nonexistent or unknown.) * @since 1.5 */ diff --git a/jdk/src/share/classes/java/security/KeyPair.java b/jdk/src/share/classes/java/security/KeyPair.java index 16815533fb4..6147a16aa59 100644 --- a/jdk/src/share/classes/java/security/KeyPair.java +++ b/jdk/src/share/classes/java/security/KeyPair.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2013, 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 @@ -50,7 +50,7 @@ public final class KeyPair implements java.io.Serializable { * *

    Note that this constructor only stores references to the public * and private key components in the generated key pair. This is safe, - * because Key objects are immutable. + * because {@code Key} objects are immutable. * * @param publicKey the public key. * diff --git a/jdk/src/share/classes/java/security/KeyPairGenerator.java b/jdk/src/share/classes/java/security/KeyPairGenerator.java index 2d7f427529d..78b100c3afa 100644 --- a/jdk/src/share/classes/java/security/KeyPairGenerator.java +++ b/jdk/src/share/classes/java/security/KeyPairGenerator.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -37,7 +37,7 @@ import sun.security.jca.GetInstance.Instance; /** * The KeyPairGenerator class is used to generate pairs of * public and private keys. Key pair generators are constructed using the - * getInstance factory methods (static methods that + * {@code getInstance} factory methods (static methods that * return instances of a given class). * *

    A Key pair generator for a particular algorithm creates a public/private @@ -58,21 +58,21 @@ import sun.security.jca.GetInstance.Instance; * {@link #initialize(int, java.security.SecureRandom) initialize} * method in this KeyPairGenerator class that takes these two universally * shared types of arguments. There is also one that takes just a - * keysize argument, and uses the SecureRandom + * {@code keysize} argument, and uses the {@code SecureRandom} * implementation of the highest-priority installed provider as the source * of randomness. (If none of the installed providers supply an implementation - * of SecureRandom, a system-provided source of randomness is + * of {@code SecureRandom}, a system-provided source of randomness is * used.) * *

    Since no other parameters are specified when you call the above - * algorithm-independent initialize methods, it is up to the + * algorithm-independent {@code initialize} methods, it is up to the * provider what to do about the algorithm-specific parameters (if any) to be * associated with each of the keys. * *

    If the algorithm is the DSA algorithm, and the keysize (modulus * size) is 512, 768, or 1024, then the Sun provider uses a set of - * precomputed values for the p, q, and - * g parameters. If the modulus size is not one of the above + * precomputed values for the {@code p}, {@code q}, and + * {@code g} parameters. If the modulus size is not one of the above * values, the Sun provider creates a new set of parameters. Other * providers might have precomputed parameter sets for more than just the * three modulus sizes mentioned above. Still others might not have a list of @@ -83,35 +83,35 @@ import sun.security.jca.GetInstance.Instance; *

    For situations where a set of algorithm-specific parameters already * exists (e.g., so-called community parameters in DSA), there are two * {@link #initialize(java.security.spec.AlgorithmParameterSpec) - * initialize} methods that have an AlgorithmParameterSpec - * argument. One also has a SecureRandom argument, while the - * the other uses the SecureRandom + * initialize} methods that have an {@code AlgorithmParameterSpec} + * argument. One also has a {@code SecureRandom} argument, while the + * the other uses the {@code SecureRandom} * implementation of the highest-priority installed provider as the source * of randomness. (If none of the installed providers supply an implementation - * of SecureRandom, a system-provided source of randomness is + * of {@code SecureRandom}, a system-provided source of randomness is * used.) * * *

    In case the client does not explicitly initialize the KeyPairGenerator - * (via a call to an initialize method), each provider must + * (via a call to an {@code initialize} method), each provider must * supply (and document) a default initialization. * For example, the Sun provider uses a default modulus size (keysize) * of 1024 bits. * *

    Note that this class is abstract and extends from - * KeyPairGeneratorSpi for historical reasons. + * {@code KeyPairGeneratorSpi} for historical reasons. * Application developers should only take notice of the methods defined in - * this KeyPairGenerator class; all the methods in + * this {@code KeyPairGenerator} class; all the methods in * the superclass are intended for cryptographic service providers who wish to * supply their own implementations of key pair generators. * *

    Every implementation of the Java platform is required to support the - * following standard KeyPairGenerator algorithms and keysizes in + * following standard {@code KeyPairGenerator} algorithms and keysizes in * parentheses: *

      - *
    • DiffieHellman (1024)
    • - *
    • DSA (1024)
    • - *
    • RSA (1024, 2048)
    • + *
    • {@code DiffieHellman} (1024)
    • + *
    • {@code DSA} (1024)
    • + *
    • {@code RSA} (1024, 2048)
    • *
    * These algorithms are described in the
    @@ -322,18 +322,18 @@ public abstract class KeyPairGenerator extends KeyPairGeneratorSpi { /** * Initializes the key pair generator for a certain keysize using - * a default parameter set and the SecureRandom + * a default parameter set and the {@code SecureRandom} * implementation of the highest-priority installed provider as the source * of randomness. * (If none of the installed providers supply an implementation of - * SecureRandom, a system-provided source of randomness is + * {@code SecureRandom}, a system-provided source of randomness is * used.) * * @param keysize the keysize. This is an * algorithm-specific metric, such as modulus length, specified in * number of bits. * - * @exception InvalidParameterException if the keysize is not + * @exception InvalidParameterException if the {@code keysize} is not * supported by this KeyPairGenerator object. */ public void initialize(int keysize) { @@ -349,7 +349,7 @@ public abstract class KeyPairGenerator extends KeyPairGeneratorSpi { * number of bits. * @param random the source of randomness. * - * @exception InvalidParameterException if the keysize is not + * @exception InvalidParameterException if the {@code keysize} is not * supported by this KeyPairGenerator object. * * @since 1.2 @@ -369,11 +369,11 @@ public abstract class KeyPairGenerator extends KeyPairGeneratorSpi { /** * Initializes the key pair generator using the specified parameter - * set and the SecureRandom + * set and the {@code SecureRandom} * implementation of the highest-priority installed provider as the source * of randomness. * (If none of the installed providers supply an implementation of - * SecureRandom, a system-provided source of randomness is + * {@code SecureRandom}, a system-provided source of randomness is * used.). * *

    This concrete method has been added to this previously-defined @@ -382,10 +382,10 @@ public abstract class KeyPairGenerator extends KeyPairGeneratorSpi { * {@link KeyPairGeneratorSpi#initialize( * java.security.spec.AlgorithmParameterSpec, * java.security.SecureRandom) initialize} method, - * passing it params and a source of randomness (obtained + * passing it {@code params} and a source of randomness (obtained * from the highest-priority installed provider or system-provided if none * of the installed providers supply one). - * That initialize method always throws an + * That {@code initialize} method always throws an * UnsupportedOperationException if it is not overridden by the provider. * * @param params the parameter set used to generate the keys. @@ -410,8 +410,8 @@ public abstract class KeyPairGenerator extends KeyPairGeneratorSpi { * KeyPairGeneratorSpi#initialize( * java.security.spec.AlgorithmParameterSpec, * java.security.SecureRandom) initialize} method, - * passing it params and random. - * That initialize + * passing it {@code params} and {@code random}. + * That {@code initialize} * method always throws an * UnsupportedOperationException if it is not overridden by the provider. * diff --git a/jdk/src/share/classes/java/security/KeyPairGeneratorSpi.java b/jdk/src/share/classes/java/security/KeyPairGeneratorSpi.java index 28139adcf68..dfe8c04218d 100644 --- a/jdk/src/share/classes/java/security/KeyPairGeneratorSpi.java +++ b/jdk/src/share/classes/java/security/KeyPairGeneratorSpi.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 1999, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -29,7 +29,7 @@ import java.security.spec.AlgorithmParameterSpec; /** *

    This class defines the Service Provider Interface (SPI) - * for the KeyPairGenerator class, which is used to generate + * for the {@code KeyPairGenerator} class, which is used to generate * pairs of public and private keys. * *

    All the abstract methods in this class must be implemented by each @@ -37,7 +37,7 @@ import java.security.spec.AlgorithmParameterSpec; * of a key pair generator for a particular algorithm. * *

    In case the client does not explicitly initialize the KeyPairGenerator - * (via a call to an initialize method), each provider must + * (via a call to an {@code initialize} method), each provider must * supply (and document) a default initialization. * For example, the Sun provider uses a default modulus size (keysize) * of 1024 bits. @@ -61,7 +61,7 @@ public abstract class KeyPairGeneratorSpi { * * @param random the source of randomness for this generator. * - * @exception InvalidParameterException if the keysize is not + * @exception InvalidParameterException if the {@code keysize} is not * supported by this KeyPairGeneratorSpi object. */ public abstract void initialize(int keysize, SecureRandom random); @@ -100,7 +100,7 @@ public abstract class KeyPairGeneratorSpi { * will be used. This will generate a new key pair every time it * is called. * - * @return the newly generated KeyPair + * @return the newly generated {@code KeyPair} */ public abstract KeyPair generateKeyPair(); } diff --git a/jdk/src/share/classes/java/security/KeyRep.java b/jdk/src/share/classes/java/security/KeyRep.java index 6c0231c5497..0b1412c1563 100644 --- a/jdk/src/share/classes/java/security/KeyRep.java +++ b/jdk/src/share/classes/java/security/KeyRep.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -116,17 +116,17 @@ public class KeyRep implements Serializable { * * @param type either one of Type.SECRET, Type.PUBLIC, or Type.PRIVATE * @param algorithm the algorithm returned from - * Key.getAlgorithm() + * {@code Key.getAlgorithm()} * @param format the encoding format returned from - * Key.getFormat() + * {@code Key.getFormat()} * @param encoded the encoded bytes returned from - * Key.getEncoded() + * {@code Key.getEncoded()} * * @exception NullPointerException - * if type is null, - * if algorithm is null, - * if format is null, - * or if encoded is null + * if type is {@code null}, + * if algorithm is {@code null}, + * if format is {@code null}, + * or if encoded is {@code null} */ public KeyRep(Type type, String algorithm, String format, byte[] encoded) { diff --git a/jdk/src/share/classes/java/security/KeyStore.java b/jdk/src/share/classes/java/security/KeyStore.java index 64bb4f261b5..68df16ed113 100644 --- a/jdk/src/share/classes/java/security/KeyStore.java +++ b/jdk/src/share/classes/java/security/KeyStore.java @@ -41,13 +41,13 @@ import javax.security.auth.callback.*; * This class represents a storage facility for cryptographic * keys and certificates. * - *

    A KeyStore manages different types of entries. - * Each type of entry implements the KeyStore.Entry interface. - * Three basic KeyStore.Entry implementations are provided: + *

    A {@code KeyStore} manages different types of entries. + * Each type of entry implements the {@code KeyStore.Entry} interface. + * Three basic {@code KeyStore.Entry} implementations are provided: * *

    Name Type
    * - * - * - * - * - * - - * - * + * + * + * + * + * + + * + * *
    NameValue
    Provider.id nameString.valueOf(provider.getName())
    Provider.id versionString.valueOf(provider.getVersion())
    Provider.id infoString.valueOf(provider.getInfo())
    Provider.id classNameprovider.getClass().getName()
    {@code Provider.id name}{@code String.valueOf(provider.getName())}
    {@code Provider.id version}{@code String.valueOf(provider.getVersion())}
    {@code Provider.id info}{@code String.valueOf(provider.getInfo())}
    {@code Provider.id className}{@code provider.getClass().getName()}
    * * @author Benjamin Renaud @@ -185,18 +185,18 @@ public abstract class Provider extends Properties { * used to look up facilities implemented by the provider. * *

    First, if there is a security manager, its - * checkSecurityAccess method is called with the string - * "clearProviderProperties."+name (where name + * {@code checkSecurityAccess} method is called with the string + * {@code "clearProviderProperties."+name} (where {@code name} * is the provider name) to see if it's ok to clear this provider. - * If the default implementation of checkSecurityAccess + * If the default implementation of {@code checkSecurityAccess} * is used (that is, that method is not overriden), then this results in - * a call to the security manager's checkPermission method - * with a SecurityPermission("clearProviderProperties."+name) + * a call to the security manager's {@code checkPermission} method + * with a {@code SecurityPermission("clearProviderProperties."+name)} * permission. * * @throws SecurityException - * if a security manager exists and its {@link - * java.lang.SecurityManager#checkSecurityAccess} method + * if a security manager exists and its {@link + * java.lang.SecurityManager#checkSecurityAccess} method * denies access to clear this provider * * @since 1.2 @@ -292,17 +292,17 @@ public abstract class Provider extends Properties { } /** - * Sets the key property to have the specified - * value. + * Sets the {@code key} property to have the specified + * {@code value}. * *

    First, if there is a security manager, its - * checkSecurityAccess method is called with the string - * "putProviderProperty."+name, where name is the + * {@code checkSecurityAccess} method is called with the string + * {@code "putProviderProperty."+name}, where {@code name} is the * provider name, to see if it's ok to set this provider's property values. - * If the default implementation of checkSecurityAccess + * If the default implementation of {@code checkSecurityAccess} * is used (that is, that method is not overriden), then this results in - * a call to the security manager's checkPermission method - * with a SecurityPermission("putProviderProperty."+name) + * a call to the security manager's {@code checkPermission} method + * with a {@code SecurityPermission("putProviderProperty."+name)} * permission. * * @param key the property key. @@ -310,11 +310,11 @@ public abstract class Provider extends Properties { * @param value the property value. * * @return the previous value of the specified property - * (key), or null if it did not have one. + * ({@code key}), or null if it did not have one. * * @throws SecurityException - * if a security manager exists and its {@link - * java.lang.SecurityManager#checkSecurityAccess} method + * if a security manager exists and its {@link + * java.lang.SecurityManager#checkSecurityAccess} method * denies access to set property values. * * @since 1.2 @@ -329,18 +329,18 @@ public abstract class Provider extends Properties { } /** - * Removes the key property (and its corresponding - * value). + * Removes the {@code key} property (and its corresponding + * {@code value}). * *

    First, if there is a security manager, its - * checkSecurityAccess method is called with the string - * "removeProviderProperty."+name, where name is + * {@code checkSecurityAccess} method is called with the string + * {@code "removeProviderProperty."+name}, where {@code name} is * the provider name, to see if it's ok to remove this provider's * properties. If the default implementation of - * checkSecurityAccess is used (that is, that method is not + * {@code checkSecurityAccess} is used (that is, that method is not * overriden), then this results in a call to the security manager's - * checkPermission method with a - * SecurityPermission("removeProviderProperty."+name) + * {@code checkPermission} method with a + * {@code SecurityPermission("removeProviderProperty."+name)} * permission. * * @param key the key for the property to be removed. @@ -349,8 +349,8 @@ public abstract class Provider extends Properties { * or null if the key did not have a mapping. * * @throws SecurityException - * if a security manager exists and its {@link - * java.lang.SecurityManager#checkSecurityAccess} method + * if a security manager exists and its {@link + * java.lang.SecurityManager#checkSecurityAccess} method * denies access to remove this provider's properties. * * @since 1.2 @@ -662,9 +662,9 @@ public abstract class Provider extends Properties { * the service added via {@link #putService putService()} is returned. * * @param type the type of {@link Service service} requested - * (for example, MessageDigest) + * (for example, {@code MessageDigest}) * @param algorithm the case insensitive algorithm name (or alternate - * alias) of the service requested (for example, SHA-1) + * alias) of the service requested (for example, {@code SHA-1}) * * @return the service describing this Provider's matching service * or null if no such service exists @@ -739,20 +739,20 @@ public abstract class Provider extends Properties { * Java Cryptography Architecture API Specification & Reference . * *

    Also, if there is a security manager, its - * checkSecurityAccess method is called with the string - * "putProviderProperty."+name, where name is + * {@code checkSecurityAccess} method is called with the string + * {@code "putProviderProperty."+name}, where {@code name} is * the provider name, to see if it's ok to set this provider's property - * values. If the default implementation of checkSecurityAccess + * values. If the default implementation of {@code checkSecurityAccess} * is used (that is, that method is not overriden), then this results in - * a call to the security manager's checkPermission method with - * a SecurityPermission("putProviderProperty."+name) + * a call to the security manager's {@code checkPermission} method with + * a {@code SecurityPermission("putProviderProperty."+name)} * permission. * * @param s the Service to add * * @throws SecurityException - * if a security manager exists and its {@link - * java.lang.SecurityManager#checkSecurityAccess} method denies + * if a security manager exists and its {@link + * java.lang.SecurityManager#checkSecurityAccess} method denies * access to set property values. * @throws NullPointerException if s is null * @@ -830,21 +830,21 @@ public abstract class Provider extends Properties { * from this provider's Hashtable. * *

    Also, if there is a security manager, its - * checkSecurityAccess method is called with the string - * "removeProviderProperty."+name, where name is + * {@code checkSecurityAccess} method is called with the string + * {@code "removeProviderProperty."+name}, where {@code name} is * the provider name, to see if it's ok to remove this provider's * properties. If the default implementation of - * checkSecurityAccess is used (that is, that method is not + * {@code checkSecurityAccess} is used (that is, that method is not * overriden), then this results in a call to the security manager's - * checkPermission method with a - * SecurityPermission("removeProviderProperty."+name) + * {@code checkPermission} method with a + * {@code SecurityPermission("removeProviderProperty."+name)} * permission. * * @param s the Service to be removed * * @throws SecurityException - * if a security manager exists and its {@link - * java.lang.SecurityManager#checkSecurityAccess} method denies + * if a security manager exists and its {@link + * java.lang.SecurityManager#checkSecurityAccess} method denies * access to remove this provider's properties. * @throws NullPointerException if s is null * @@ -1122,7 +1122,7 @@ public abstract class Provider extends Properties { } /** - * Get the type of this service. For example, MessageDigest. + * Get the type of this service. For example, {@code MessageDigest}. * * @return the type of this service */ @@ -1132,7 +1132,7 @@ public abstract class Provider extends Properties { /** * Return the name of the algorithm of this service. For example, - * SHA-1. + * {@code SHA-1}. * * @return the algorithm of this service */ diff --git a/jdk/src/share/classes/java/security/ProviderException.java b/jdk/src/share/classes/java/security/ProviderException.java index 449c8c36168..b372ee75752 100644 --- a/jdk/src/share/classes/java/security/ProviderException.java +++ b/jdk/src/share/classes/java/security/ProviderException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2013, 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 @@ -58,13 +58,13 @@ public class ProviderException extends RuntimeException { } /** - * Creates a ProviderException with the specified + * Creates a {@code ProviderException} with the specified * detail message and cause. * * @param message the detail message (which is saved for later retrieval * by the {@link #getMessage()} method). * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause()} method). (A null value is permitted, + * {@link #getCause()} method). (A {@code null} value is permitted, * and indicates that the cause is nonexistent or unknown.) * @since 1.5 */ @@ -73,13 +73,13 @@ public class ProviderException extends RuntimeException { } /** - * Creates a ProviderException with the specified cause - * and a detail message of (cause==null ? null : cause.toString()) + * Creates a {@code ProviderException} with the specified cause + * and a detail message of {@code (cause==null ? null : cause.toString())} * (which typically contains the class and detail message of - * cause). + * {@code cause}). * * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause()} method). (A null value is permitted, + * {@link #getCause()} method). (A {@code null} value is permitted, * and indicates that the cause is nonexistent or unknown.) * @since 1.5 */ diff --git a/jdk/src/share/classes/java/security/PublicKey.java b/jdk/src/share/classes/java/security/PublicKey.java index c983ff611d9..df49807eea4 100644 --- a/jdk/src/share/classes/java/security/PublicKey.java +++ b/jdk/src/share/classes/java/security/PublicKey.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2001, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2013, 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 @@ -32,7 +32,7 @@ package java.security; * * Note: The specialized public key interfaces extend this interface. * See, for example, the DSAPublicKey interface in - * java.security.interfaces. + * {@code java.security.interfaces}. * * @see Key * @see PrivateKey diff --git a/jdk/src/share/classes/java/security/SecureClassLoader.java b/jdk/src/share/classes/java/security/SecureClassLoader.java index ffcd1a7160f..145f4fc482b 100644 --- a/jdk/src/share/classes/java/security/SecureClassLoader.java +++ b/jdk/src/share/classes/java/security/SecureClassLoader.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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,12 @@ public class SecureClassLoader extends ClassLoader { * class loader for delegation. * *

    If there is a security manager, this method first - * calls the security manager's checkCreateClassLoader + * calls the security manager's {@code checkCreateClassLoader} * method to ensure creation of a class loader is allowed. *

    * @param parent the parent ClassLoader * @exception SecurityException if a security manager exists and its - * checkCreateClassLoader method doesn't allow + * {@code checkCreateClassLoader} method doesn't allow * creation of a class loader. * @see SecurityManager#checkCreateClassLoader */ @@ -87,11 +87,11 @@ public class SecureClassLoader extends ClassLoader { * loader for delegation. * *

    If there is a security manager, this method first - * calls the security manager's checkCreateClassLoader + * calls the security manager's {@code checkCreateClassLoader} * method to ensure creation of a class loader is allowed. * * @exception SecurityException if a security manager exists and its - * checkCreateClassLoader method doesn't allow + * {@code checkCreateClassLoader} method doesn't allow * creation of a class loader. * @see SecurityManager#checkCreateClassLoader */ @@ -113,22 +113,22 @@ public class SecureClassLoader extends ClassLoader { * If a non-null CodeSource is supplied a ProtectionDomain is * constructed and associated with the class being defined. *

    - * @param name the expected name of the class, or null + * @param name the expected name of the class, or {@code null} * if not known, using '.' and not '/' as the separator * and without a trailing ".class" suffix. * @param b the bytes that make up the class data. The bytes in - * positions off through off+len-1 + * positions {@code off} through {@code off+len-1} * should have the format of a valid class file as defined by * The Java™ Virtual Machine Specification. - * @param off the start offset in b of the class data + * @param off the start offset in {@code b} of the class data * @param len the length of the class data - * @param cs the associated CodeSource, or null if none - * @return the Class object created from the data, + * @param cs the associated CodeSource, or {@code null} if none + * @return the {@code Class} object created from the data, * and optional CodeSource. * @exception ClassFormatError if the data did not contain a valid class - * @exception IndexOutOfBoundsException if either off or - * len is negative, or if - * off+len is greater than b.length. + * @exception IndexOutOfBoundsException if either {@code off} or + * {@code len} is negative, or if + * {@code off+len} is greater than {@code b.length}. * * @exception SecurityException if an attempt is made to add this class * to a package that contains classes that were signed by @@ -143,22 +143,22 @@ public class SecureClassLoader extends ClassLoader { } /** - * Converts a {@link java.nio.ByteBuffer ByteBuffer} - * into an instance of class Class, with an optional CodeSource. + * Converts a {@link java.nio.ByteBuffer ByteBuffer} + * into an instance of class {@code Class}, with an optional CodeSource. * Before the class can be used it must be resolved. *

    * If a non-null CodeSource is supplied a ProtectionDomain is * constructed and associated with the class being defined. *

    - * @param name the expected name of the class, or null + * @param name the expected name of the class, or {@code null} * if not known, using '.' and not '/' as the separator * and without a trailing ".class" suffix. * @param b the bytes that make up the class data. The bytes from positions - * b.position() through b.position() + b.limit() -1 + * {@code b.position()} through {@code b.position() + b.limit() -1} * should have the format of a valid class file as defined by * The Java™ Virtual Machine Specification. - * @param cs the associated CodeSource, or null if none - * @return the Class object created from the data, + * @param cs the associated CodeSource, or {@code null} if none + * @return the {@code Class} object created from the data, * and optional CodeSource. * @exception ClassFormatError if the data did not contain a valid class * @exception SecurityException if an attempt is made to add this class diff --git a/jdk/src/share/classes/java/security/SecureRandom.java b/jdk/src/share/classes/java/security/SecureRandom.java index 7d25b147ed3..5afec7b0797 100644 --- a/jdk/src/share/classes/java/security/SecureRandom.java +++ b/jdk/src/share/classes/java/security/SecureRandom.java @@ -50,7 +50,7 @@ import sun.security.jca.GetInstance.Instance; * RFC 1750: Randomness Recommendations for Security. * *

    A caller obtains a SecureRandom instance via the - * no-argument constructor or one of the getInstance methods: + * no-argument constructor or one of the {@code getInstance} methods: * *

      *      SecureRandom random = new SecureRandom();
    @@ -71,15 +71,15 @@ import sun.security.jca.GetInstance.Instance;
      *      random.nextBytes(bytes);
      * 
    * - *

    Callers may also invoke the generateSeed method + *

    Callers may also invoke the {@code generateSeed} method * to generate a given number of seed bytes (to seed other random number * generators, for example): *

      *      byte seed[] = random.generateSeed(20);
      * 
    * - * Note: Depending on the implementation, the generateSeed and - * nextBytes methods may block as entropy is being gathered, + * Note: Depending on the implementation, the {@code generateSeed} and + * {@code nextBytes} methods may block as entropy is being gathered, * for example, if they need to read from /dev/random on various Unix-like * operating systems. * @@ -140,16 +140,16 @@ public class SecureRandom extends java.util.Random { * for information about standard RNG algorithm names. * *

    The returned SecureRandom object has not been seeded. To seed the - * returned object, call the setSeed method. - * If setSeed is not called, the first call to - * nextBytes will force the SecureRandom object to seed itself. - * This self-seeding will not occur if setSeed was + * returned object, call the {@code setSeed} method. + * If {@code setSeed} is not called, the first call to + * {@code nextBytes} will force the SecureRandom object to seed itself. + * This self-seeding will not occur if {@code setSeed} was * previously called. */ public SecureRandom() { /* * This call to our superclass constructor will result in a call - * to our own setSeed method, which will return + * to our own {@code setSeed} method, which will return * immediately when it is passed zero. */ super(0); @@ -250,10 +250,10 @@ public class SecureRandom extends java.util.Random { * the {@link Security#getProviders() Security.getProviders()} method. * *

    The returned SecureRandom object has not been seeded. To seed the - * returned object, call the setSeed method. - * If setSeed is not called, the first call to - * nextBytes will force the SecureRandom object to seed itself. - * This self-seeding will not occur if setSeed was + * returned object, call the {@code setSeed} method. + * If {@code setSeed} is not called, the first call to + * {@code nextBytes} will force the SecureRandom object to seed itself. + * This self-seeding will not occur if {@code setSeed} was * previously called. * * @param algorithm the name of the RNG algorithm. @@ -293,10 +293,10 @@ public class SecureRandom extends java.util.Random { * the {@link Security#getProviders() Security.getProviders()} method. * *

    The returned SecureRandom object has not been seeded. To seed the - * returned object, call the setSeed method. - * If setSeed is not called, the first call to - * nextBytes will force the SecureRandom object to seed itself. - * This self-seeding will not occur if setSeed was + * returned object, call the {@code setSeed} method. + * If {@code setSeed} is not called, the first call to + * {@code nextBytes} will force the SecureRandom object to seed itself. + * This self-seeding will not occur if {@code setSeed} was * previously called. * * @param algorithm the name of the RNG algorithm. @@ -341,10 +341,10 @@ public class SecureRandom extends java.util.Random { * does not have to be registered in the provider list. * *

    The returned SecureRandom object has not been seeded. To seed the - * returned object, call the setSeed method. - * If setSeed is not called, the first call to - * nextBytes will force the SecureRandom object to seed itself. - * This self-seeding will not occur if setSeed was + * returned object, call the {@code setSeed} method. + * If {@code setSeed} is not called, the first call to + * {@code nextBytes} will force the SecureRandom object to seed itself. + * This self-seeding will not occur if {@code setSeed} was * previously called. * * @param algorithm the name of the RNG algorithm. @@ -395,7 +395,7 @@ public class SecureRandom extends java.util.Random { * Returns the name of the algorithm implemented by this SecureRandom * object. * - * @return the name of the algorithm or unknown + * @return the name of the algorithm or {@code unknown} * if the algorithm name cannot be determined. * @since 1.5 */ @@ -418,12 +418,12 @@ public class SecureRandom extends java.util.Random { /** * Reseeds this random object, using the eight bytes contained - * in the given long seed. The given seed supplements, + * in the given {@code long seed}. The given seed supplements, * rather than replaces, the existing seed. Thus, repeated calls * are guaranteed never to reduce randomness. * *

    This method is defined for compatibility with - * java.util.Random. + * {@code java.util.Random}. * * @param seed the seed. * @@ -445,10 +445,10 @@ public class SecureRandom extends java.util.Random { /** * Generates a user-specified number of random bytes. * - *

    If a call to setSeed had not occurred previously, + *

    If a call to {@code setSeed} had not occurred previously, * the first call to this method forces this SecureRandom object * to seed itself. This self-seeding will not occur if - * setSeed was previously called. + * {@code setSeed} was previously called. * * @param bytes the array to be filled in with random bytes. */ @@ -460,15 +460,15 @@ public class SecureRandom extends java.util.Random { /** * Generates an integer containing the user-specified number of * pseudo-random bits (right justified, with leading zeros). This - * method overrides a java.util.Random method, and serves + * method overrides a {@code java.util.Random} method, and serves * to provide a source of random bits to all of the methods inherited - * from that class (for example, nextInt, - * nextLong, and nextFloat). + * from that class (for example, {@code nextInt}, + * {@code nextLong}, and {@code nextFloat}). * * @param numBits number of pseudo-random bits to be generated, where * {@code 0 <= numBits <= 32}. * - * @return an int containing the user-specified number + * @return an {@code int} containing the user-specified number * of pseudo-random bits (right justified, with leading zeros). */ @Override @@ -492,8 +492,8 @@ public class SecureRandom extends java.util.Random { * *

    This method is only included for backwards compatibility. * The caller is encouraged to use one of the alternative - * getInstance methods to obtain a SecureRandom object, and - * then call the generateSeed method to obtain seed bytes + * {@code getInstance} methods to obtain a SecureRandom object, and + * then call the {@code generateSeed} method to obtain seed bytes * from that object. * * @param numBytes the number of seed bytes to generate. diff --git a/jdk/src/share/classes/java/security/SecureRandomSpi.java b/jdk/src/share/classes/java/security/SecureRandomSpi.java index 12652e98a65..ef6c2433630 100644 --- a/jdk/src/share/classes/java/security/SecureRandomSpi.java +++ b/jdk/src/share/classes/java/security/SecureRandomSpi.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2005, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2013, 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 @@ -27,7 +27,7 @@ package java.security; /** * This class defines the Service Provider Interface (SPI) - * for the SecureRandom class. + * for the {@code SecureRandom} class. * All the abstract methods in this class must be implemented by each * service provider who wishes to supply the implementation * of a cryptographically strong pseudo-random number generator. @@ -53,10 +53,10 @@ public abstract class SecureRandomSpi implements java.io.Serializable { /** * Generates a user-specified number of random bytes. * - *

    If a call to engineSetSeed had not occurred previously, + *

    If a call to {@code engineSetSeed} had not occurred previously, * the first call to this method forces this SecureRandom implementation * to seed itself. This self-seeding will not occur if - * engineSetSeed was previously called. + * {@code engineSetSeed} was previously called. * * @param bytes the array to be filled in with random bytes. */ diff --git a/jdk/src/share/classes/java/security/Security.java b/jdk/src/share/classes/java/security/Security.java index eccede10b20..c3dd716058d 100644 --- a/jdk/src/share/classes/java/security/Security.java +++ b/jdk/src/share/classes/java/security/Security.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2013, 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 @@ -298,7 +298,7 @@ public final class Security { * property in the master file of the "SUN" Cryptographic Service * Provider in order to determine how to parse algorithm-specific * parameters. Use the new provider-based and algorithm-independent - * AlgorithmParameters and KeyFactory engine + * {@code AlgorithmParameters} and {@code KeyFactory} engine * classes (introduced in the J2SE version 1.2 platform) instead. */ @Deprecated @@ -321,21 +321,21 @@ public final class Security { * *

    If the given provider is installed at the requested position, * the provider that used to be at that position, and all providers - * with a position greater than position, are shifted up + * with a position greater than {@code position}, are shifted up * one position (towards the end of the list of installed providers). * *

    A provider cannot be added if it is already installed. * *

    First, if there is a security manager, its - * checkSecurityAccess + * {@code checkSecurityAccess} * method is called with the string - * "insertProvider."+provider.getName() + * {@code "insertProvider."+provider.getName()} * to see if it's ok to add a new provider. - * If the default implementation of checkSecurityAccess + * If the default implementation of {@code checkSecurityAccess} * is used (i.e., that method is not overriden), then this will result in - * a call to the security manager's checkPermission method + * a call to the security manager's {@code checkPermission} method * with a - * SecurityPermission("insertProvider."+provider.getName()) + * {@code SecurityPermission("insertProvider."+provider.getName())} * permission. * * @param provider the provider to be added. @@ -349,8 +349,8 @@ public final class Security { * * @throws NullPointerException if provider is null * @throws SecurityException - * if a security manager exists and its {@link - * java.lang.SecurityManager#checkSecurityAccess} method + * if a security manager exists and its {@link + * java.lang.SecurityManager#checkSecurityAccess} method * denies access to add a new provider * * @see #getProvider @@ -374,15 +374,15 @@ public final class Security { * Adds a provider to the next position available. * *

    First, if there is a security manager, its - * checkSecurityAccess + * {@code checkSecurityAccess} * method is called with the string - * "insertProvider."+provider.getName() + * {@code "insertProvider."+provider.getName()} * to see if it's ok to add a new provider. - * If the default implementation of checkSecurityAccess + * If the default implementation of {@code checkSecurityAccess} * is used (i.e., that method is not overriden), then this will result in - * a call to the security manager's checkPermission method + * a call to the security manager's {@code checkPermission} method * with a - * SecurityPermission("insertProvider."+provider.getName()) + * {@code SecurityPermission("insertProvider."+provider.getName())} * permission. * * @param provider the provider to be added. @@ -393,8 +393,8 @@ public final class Security { * * @throws NullPointerException if provider is null * @throws SecurityException - * if a security manager exists and its {@link - * java.lang.SecurityManager#checkSecurityAccess} method + * if a security manager exists and its {@link + * java.lang.SecurityManager#checkSecurityAccess} method * denies access to add a new provider * * @see #getProvider @@ -423,20 +423,20 @@ public final class Security { * if name is null. * *

    First, if there is a security manager, its - * checkSecurityAccess - * method is called with the string "removeProvider."+name + * {@code checkSecurityAccess} + * method is called with the string {@code "removeProvider."+name} * to see if it's ok to remove the provider. - * If the default implementation of checkSecurityAccess + * If the default implementation of {@code checkSecurityAccess} * is used (i.e., that method is not overriden), then this will result in - * a call to the security manager's checkPermission method - * with a SecurityPermission("removeProvider."+name) + * a call to the security manager's {@code checkPermission} method + * with a {@code SecurityPermission("removeProvider."+name)} * permission. * * @param name the name of the provider to remove. * * @throws SecurityException - * if a security manager exists and its {@link - * java.lang.SecurityManager#checkSecurityAccess} method + * if a security manager exists and its {@link + * java.lang.SecurityManager#checkSecurityAccess} method * denies * access to remove the provider * @@ -689,7 +689,7 @@ public final class Security { * an instance of an implementation of the requested algorithm * and type, and the second object in the array identifies the provider * of that implementation. - * The provider argument can be null, in which case all + * The {@code provider} argument can be null, in which case all * configured providers will be searched in order of preference. */ static Object[] getImpl(String algorithm, String type, String provider) @@ -720,7 +720,7 @@ public final class Security { * an instance of an implementation of the requested algorithm * and type, and the second object in the array identifies the provider * of that implementation. - * The provider argument cannot be null. + * The {@code provider} argument cannot be null. */ static Object[] getImpl(String algorithm, String type, Provider provider) throws NoSuchAlgorithmException { @@ -739,8 +739,8 @@ public final class Security { * Gets a security property value. * *

    First, if there is a security manager, its - * checkPermission method is called with a - * java.security.SecurityPermission("getProperty."+key) + * {@code checkPermission} method is called with a + * {@code java.security.SecurityPermission("getProperty."+key)} * permission to see if it's ok to retrieve the specified * security property value.. * @@ -749,8 +749,8 @@ public final class Security { * @return the value of the security property corresponding to key. * * @throws SecurityException - * if a security manager exists and its {@link - * java.lang.SecurityManager#checkPermission} method + * if a security manager exists and its {@link + * java.lang.SecurityManager#checkPermission} method * denies * access to retrieve the specified security property value * @throws NullPointerException is key is null @@ -774,8 +774,8 @@ public final class Security { * Sets a security property value. * *

    First, if there is a security manager, its - * checkPermission method is called with a - * java.security.SecurityPermission("setProperty."+key) + * {@code checkPermission} method is called with a + * {@code java.security.SecurityPermission("setProperty."+key)} * permission to see if it's ok to set the specified * security property value. * @@ -784,8 +784,8 @@ public final class Security { * @param datum the value of the property to be set. * * @throws SecurityException - * if a security manager exists and its {@link - * java.lang.SecurityManager#checkPermission} method + * if a security manager exists and its {@link + * java.lang.SecurityManager#checkPermission} method * denies access to set the specified security property value * @throws NullPointerException if key or datum is null * diff --git a/jdk/src/share/classes/java/security/SecurityPermission.java b/jdk/src/share/classes/java/security/SecurityPermission.java index 69eaf735733..e0f0f92b40c 100644 --- a/jdk/src/share/classes/java/security/SecurityPermission.java +++ b/jdk/src/share/classes/java/security/SecurityPermission.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2006, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -57,7 +57,7 @@ import java.util.StringTokenizer; * createAccessControlContext * Creation of an AccessControlContext * This allows someone to instantiate an AccessControlContext - * with a DomainCombiner. Extreme care must be taken when + * with a {@code DomainCombiner}. Extreme care must be taken when * granting this permission. Malicious code could create a DomainCombiner * that augments the set of permissions granted to code, and even grant the * code {@link java.security.AllPermission}. @@ -67,7 +67,7 @@ import java.util.StringTokenizer; * getDomainCombiner * Retrieval of an AccessControlContext's DomainCombiner * This allows someone to retrieve an AccessControlContext's - * DomainCombiner. Since DomainCombiners may contain + * {@code DomainCombiner}. Since DomainCombiners may contain * sensitive information, this could potentially lead to a privacy leak. * * @@ -76,7 +76,7 @@ import java.util.StringTokenizer; * Retrieval of the system-wide security policy (specifically, of the * currently-installed Policy object) * This allows someone to query the policy via the - * getPermissions call, + * {@code getPermissions} call, * which discloses which permissions would be granted to a given CodeSource. * While revealing the policy does not compromise the security of * the system, it does provide malicious code with additional information @@ -303,8 +303,8 @@ public final class SecurityPermission extends BasicPermission { * * @param name the name of the SecurityPermission * - * @throws NullPointerException if name is null. - * @throws IllegalArgumentException if name is empty. + * @throws NullPointerException if {@code name} is {@code null}. + * @throws IllegalArgumentException if {@code name} is empty. */ public SecurityPermission(String name) @@ -320,8 +320,8 @@ public final class SecurityPermission extends BasicPermission { * @param name the name of the SecurityPermission * @param actions should be null. * - * @throws NullPointerException if name is null. - * @throws IllegalArgumentException if name is empty. + * @throws NullPointerException if {@code name} is {@code null}. + * @throws IllegalArgumentException if {@code name} is empty. */ public SecurityPermission(String name, String actions) diff --git a/jdk/src/share/classes/java/security/Signature.java b/jdk/src/share/classes/java/security/Signature.java index 2d014d21efe..a40290f8c99 100644 --- a/jdk/src/share/classes/java/security/Signature.java +++ b/jdk/src/share/classes/java/security/Signature.java @@ -53,10 +53,10 @@ import sun.security.jca.GetInstance.Instance; * *

    The signature algorithm can be, among others, the NIST standard * DSA, using DSA and SHA-1. The DSA algorithm using the - * SHA-1 message digest algorithm can be specified as SHA1withDSA. + * SHA-1 message digest algorithm can be specified as {@code SHA1withDSA}. * In the case of RSA, there are multiple choices for the message digest * algorithm, so the signing algorithm could be specified as, for example, - * MD2withRSA, MD5withRSA, or SHA1withRSA. + * {@code MD2withRSA}, {@code MD5withRSA}, or {@code SHA1withRSA}. * The algorithm name must be specified, as there is no default. * *

    A Signature object can be used to generate and verify digital @@ -92,18 +92,18 @@ import sun.security.jca.GetInstance.Instance; * * *

    Note that this class is abstract and extends from - * SignatureSpi for historical reasons. + * {@code SignatureSpi} for historical reasons. * Application developers should only take notice of the methods defined in - * this Signature class; all the methods in + * this {@code Signature} class; all the methods in * the superclass are intended for cryptographic service providers who wish to * supply their own implementations of digital signature algorithms. * *

    Every implementation of the Java platform is required to support the - * following standard Signature algorithms: + * following standard {@code Signature} algorithms: *

      - *
    • SHA1withDSA
    • - *
    • SHA1withRSA
    • - *
    • SHA256withRSA
    • + *
    • {@code SHA1withDSA}
    • + *
    • {@code SHA1withRSA}
    • + *
    • {@code SHA256withRSA}
    • *
    * These algorithms are described in the @@ -461,7 +461,7 @@ public abstract class Signature extends SignatureSpi { * extension field implies that the public key in * the certificate and its corresponding private key are not * supposed to be used for digital signatures, an - * InvalidKeyException is thrown. + * {@code InvalidKeyException} is thrown. * * @param certificate the certificate of the identity whose signature is * going to be verified. @@ -538,10 +538,10 @@ public abstract class Signature extends SignatureSpi { * *

    A call to this method resets this signature object to the state * it was in when previously initialized for signing via a - * call to initSign(PrivateKey). That is, the object is + * call to {@code initSign(PrivateKey)}. That is, the object is * reset and available to generate another signature from the same - * signer, if desired, via new calls to update and - * sign. + * signer, if desired, via new calls to {@code update} and + * {@code sign}. * * @return the signature bytes of the signing operation's result. * @@ -559,28 +559,28 @@ public abstract class Signature extends SignatureSpi { /** * Finishes the signature operation and stores the resulting signature - * bytes in the provided buffer outbuf, starting at - * offset. + * bytes in the provided buffer {@code outbuf}, starting at + * {@code offset}. * The format of the signature depends on the underlying * signature scheme. * *

    This signature object is reset to its initial state (the state it - * was in after a call to one of the initSign methods) and + * was in after a call to one of the {@code initSign} methods) and * can be reused to generate further signatures with the same private key. * * @param outbuf buffer for the signature result. * - * @param offset offset into outbuf where the signature is + * @param offset offset into {@code outbuf} where the signature is * stored. * - * @param len number of bytes within outbuf allotted for the + * @param len number of bytes within {@code outbuf} allotted for the * signature. * - * @return the number of bytes placed into outbuf. + * @return the number of bytes placed into {@code outbuf}. * * @exception SignatureException if this signature object is not * initialized properly, if this signature algorithm is unable to - * process the input data provided, or if len is less + * process the input data provided, or if {@code len} is less * than the actual signature length. * * @since 1.2 @@ -606,9 +606,9 @@ public abstract class Signature extends SignatureSpi { * *

    A call to this method resets this signature object to the state * it was in when previously initialized for verification via a - * call to initVerify(PublicKey). That is, the object is + * call to {@code initVerify(PublicKey)}. That is, the object is * reset and available to verify another signature from the identity - * whose public key was specified in the call to initVerify. + * whose public key was specified in the call to {@code initVerify}. * * @param signature the signature bytes to be verified. * @@ -633,9 +633,9 @@ public abstract class Signature extends SignatureSpi { * *

    A call to this method resets this signature object to the state * it was in when previously initialized for verification via a - * call to initVerify(PublicKey). That is, the object is + * call to {@code initVerify(PublicKey)}. That is, the object is * reset and available to verify another signature from the identity - * whose public key was specified in the call to initVerify. + * whose public key was specified in the call to {@code initVerify}. * * * @param signature the signature bytes to be verified. @@ -648,11 +648,11 @@ public abstract class Signature extends SignatureSpi { * initialized properly, the passed-in signature is improperly * encoded or of the wrong type, if this signature algorithm is unable to * process the input data provided, etc. - * @exception IllegalArgumentException if the signature - * byte array is null, or the offset or length - * is less than 0, or the sum of the offset and - * length is greater than the length of the - * signature byte array. + * @exception IllegalArgumentException if the {@code signature} + * byte array is null, or the {@code offset} or {@code length} + * is less than 0, or the sum of the {@code offset} and + * {@code length} is greater than the length of the + * {@code signature} byte array. * @since 1.4 */ public final boolean verify(byte[] signature, int offset, int length) @@ -722,8 +722,8 @@ public abstract class Signature extends SignatureSpi { /** * Updates the data to be signed or verified using the specified - * ByteBuffer. Processes the data.remaining() bytes - * starting at at data.position(). + * ByteBuffer. Processes the {@code data.remaining()} bytes + * starting at at {@code data.position()}. * Upon return, the buffer's position will be equal to its limit; * its limit will not have changed. * @@ -790,7 +790,7 @@ public abstract class Signature extends SignatureSpi { * @param param the string identifier of the parameter. * @param value the parameter value. * - * @exception InvalidParameterException if param is an + * @exception InvalidParameterException if {@code param} is an * invalid parameter for this signature algorithm engine, * the parameter is already set * and cannot be set again, a security exception occurs, and so on. @@ -856,7 +856,7 @@ public abstract class Signature extends SignatureSpi { * @return the object that represents the parameter value, or null if * there is none. * - * @exception InvalidParameterException if param is an invalid + * @exception InvalidParameterException if {@code param} is an invalid * parameter for this engine, or another exception occurs while * trying to get this parameter. * @@ -876,7 +876,7 @@ public abstract class Signature extends SignatureSpi { * @return a clone if the implementation is cloneable. * * @exception CloneNotSupportedException if this is called - * on an implementation that does not support Cloneable. + * on an implementation that does not support {@code Cloneable}. */ public Object clone() throws CloneNotSupportedException { if (this instanceof Cloneable) { @@ -940,7 +940,7 @@ public abstract class Signature extends SignatureSpi { * @return a clone if the delegate is cloneable. * * @exception CloneNotSupportedException if this is called on a - * delegate that does not support Cloneable. + * delegate that does not support {@code Cloneable}. */ public Object clone() throws CloneNotSupportedException { chooseFirstProvider(); diff --git a/jdk/src/share/classes/java/security/SignatureException.java b/jdk/src/share/classes/java/security/SignatureException.java index c47de3124bc..2e1fa592f60 100644 --- a/jdk/src/share/classes/java/security/SignatureException.java +++ b/jdk/src/share/classes/java/security/SignatureException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2003, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2013, 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 @@ -56,13 +56,13 @@ public class SignatureException extends GeneralSecurityException { } /** - * Creates a SignatureException with the specified + * Creates a {@code SignatureException} with the specified * detail message and cause. * * @param message the detail message (which is saved for later retrieval * by the {@link #getMessage()} method). * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause()} method). (A null value is permitted, + * {@link #getCause()} method). (A {@code null} value is permitted, * and indicates that the cause is nonexistent or unknown.) * @since 1.5 */ @@ -71,13 +71,13 @@ public class SignatureException extends GeneralSecurityException { } /** - * Creates a SignatureException with the specified cause - * and a detail message of (cause==null ? null : cause.toString()) + * Creates a {@code SignatureException} with the specified cause + * and a detail message of {@code (cause==null ? null : cause.toString())} * (which typically contains the class and detail message of - * cause). + * {@code cause}). * * @param cause the cause (which is saved for later retrieval by the - * {@link #getCause()} method). (A null value is permitted, + * {@link #getCause()} method). (A {@code null} value is permitted, * and indicates that the cause is nonexistent or unknown.) * @since 1.5 */ diff --git a/jdk/src/share/classes/java/security/SignatureSpi.java b/jdk/src/share/classes/java/security/SignatureSpi.java index cd5318e0e23..d6d2bc39b5e 100644 --- a/jdk/src/share/classes/java/security/SignatureSpi.java +++ b/jdk/src/share/classes/java/security/SignatureSpi.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2006, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -35,7 +35,7 @@ import sun.security.jca.JCAUtil; /** * This class defines the Service Provider Interface (SPI) - * for the Signature class, which is used to provide the + * for the {@code Signature} class, which is used to provide the * functionality of a digital signature algorithm. Digital signatures are used * for authentication and integrity assurance of digital data. *. @@ -130,8 +130,8 @@ public abstract class SignatureSpi { /** * Updates the data to be signed or verified using the specified - * ByteBuffer. Processes the data.remaining() bytes - * starting at at data.position(). + * ByteBuffer. Processes the {@code data.remaining()} bytes + * starting at at {@code data.position()}. * Upon return, the buffer's position will be equal to its limit; * its limit will not have changed. * @@ -183,14 +183,14 @@ public abstract class SignatureSpi { /** * Finishes this signature operation and stores the resulting signature - * bytes in the provided buffer outbuf, starting at - * offset. + * bytes in the provided buffer {@code outbuf}, starting at + * {@code offset}. * The format of the signature depends on the underlying * signature scheme. * *

    The signature implementation is reset to its initial state * (the state it was in after a call to one of the - * engineInitSign methods) + * {@code engineInitSign} methods) * and can be reused to generate further signatures with the same private * key. * @@ -200,10 +200,10 @@ public abstract class SignatureSpi { * * @param outbuf buffer for the signature result. * - * @param offset offset into outbuf where the signature is + * @param offset offset into {@code outbuf} where the signature is * stored. * - * @param len number of bytes within outbuf allotted for the + * @param len number of bytes within {@code outbuf} allotted for the * signature. * Both this default implementation and the SUN provider do not * return partial digests. If the value of this parameter is less @@ -212,11 +212,11 @@ public abstract class SignatureSpi { * This parameter is ignored if its value is greater than or equal to * the actual signature length. * - * @return the number of bytes placed into outbuf + * @return the number of bytes placed into {@code outbuf} * * @exception SignatureException if the engine is not * initialized properly, if this signature algorithm is unable to - * process the input data provided, or if len is less + * process the input data provided, or if {@code len} is less * than the actual signature length. * * @since 1.2 @@ -293,7 +293,7 @@ public abstract class SignatureSpi { * * @param value the parameter value. * - * @exception InvalidParameterException if param is an + * @exception InvalidParameterException if {@code param} is an * invalid parameter for this signature algorithm engine, * the parameter is already set * and cannot be set again, a security exception occurs, and so on. @@ -362,7 +362,7 @@ public abstract class SignatureSpi { * @return the object that represents the parameter value, or null if * there is none. * - * @exception InvalidParameterException if param is an + * @exception InvalidParameterException if {@code param} is an * invalid parameter for this engine, or another exception occurs while * trying to get this parameter. * @@ -378,7 +378,7 @@ public abstract class SignatureSpi { * @return a clone if the implementation is cloneable. * * @exception CloneNotSupportedException if this is called - * on an implementation that does not support Cloneable. + * on an implementation that does not support {@code Cloneable}. */ public Object clone() throws CloneNotSupportedException { if (this instanceof Cloneable) { diff --git a/jdk/src/share/classes/java/security/SignedObject.java b/jdk/src/share/classes/java/security/SignedObject.java index 1f901fa1c77..dba803d88e4 100644 --- a/jdk/src/share/classes/java/security/SignedObject.java +++ b/jdk/src/share/classes/java/security/SignedObject.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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,44 +40,44 @@ import java.io.*; * the original object has no side effect on the copy. * *

    The underlying signing algorithm is designated by the Signature - * object passed to the constructor and the verify method. + * object passed to the constructor and the {@code verify} method. * A typical usage for signing is the following: * - *

    + * 

    {@code
      * Signature signingEngine = Signature.getInstance(algorithm,
      *                                                 provider);
      * SignedObject so = new SignedObject(myobject, signingKey,
      *                                    signingEngine);
    - * 
    + * }
    * *

    A typical usage for verification is the following (having - * received SignedObject so): + * received SignedObject {@code so}): * - *

    + * 

    {@code
      * Signature verificationEngine =
      *     Signature.getInstance(algorithm, provider);
      * if (so.verify(publickey, verificationEngine))
      *     try {
      *         Object myobj = so.getObject();
      *     } catch (java.lang.ClassNotFoundException e) {};
    - * 
    + * }
    * *

    Several points are worth noting. First, there is no need to * initialize the signing or verification engine, as it will be - * re-initialized inside the constructor and the verify + * re-initialized inside the constructor and the {@code verify} * method. Secondly, for verification to succeed, the specified * public key must be the public key corresponding to the private key * used to generate the SignedObject. * *

    More importantly, for flexibility reasons, the - * constructor and verify method allow for + * constructor and {@code verify} method allow for * customized signature engines, which can implement signature * algorithms that are not installed formally as part of a crypto * provider. However, it is crucial that the programmer writing the - * verifier code be aware what Signature engine is being - * used, as its own implementation of the verify method + * verifier code be aware what {@code Signature} engine is being + * used, as its own implementation of the {@code verify} method * is invoked to verify a signature. In other words, a malicious - * Signature may choose to always return true on + * {@code Signature} may choose to always return true on * verification in an attempt to bypass a security check. * *

    The signature algorithm can be, among others, the NIST standard @@ -92,7 +92,7 @@ import java.io.*; * *

    The name of the Cryptography Package Provider is designated * also by the Signature parameter to the constructor and the - * verify method. If the provider is not + * {@code verify} method. If the provider is not * specified, the default provider is used. Each installation can * be configured to use a particular provider as default. * @@ -214,8 +214,8 @@ public final class SignedObject implements Serializable { * @exception SignatureException if signature verification failed. * @exception InvalidKeyException if the verification key is invalid. * - * @return true if the signature - * is valid, false otherwise + * @return {@code true} if the signature + * is valid, {@code false} otherwise */ public boolean verify(PublicKey verificationKey, Signature verificationEngine) diff --git a/jdk/src/share/classes/java/security/Signer.java b/jdk/src/share/classes/java/security/Signer.java index 9224780c650..077538da979 100644 --- a/jdk/src/share/classes/java/security/Signer.java +++ b/jdk/src/share/classes/java/security/Signer.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2006, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2013, 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,9 +40,9 @@ import java.io.*; * @author Benjamin Renaud * * @deprecated This class is no longer used. Its functionality has been - * replaced by java.security.KeyStore, the - * java.security.cert package, and - * java.security.Principal. + * replaced by {@code java.security.KeyStore}, the + * {@code java.security.cert} package, and + * {@code java.security.Principal}. */ @Deprecated public abstract class Signer extends Identity { @@ -92,15 +92,15 @@ public abstract class Signer extends Identity { /** * Returns this signer's private key. * - *

    First, if there is a security manager, its checkSecurityAccess - * method is called with "getSignerPrivateKey" + *

    First, if there is a security manager, its {@code checkSecurityAccess} + * method is called with {@code "getSignerPrivateKey"} * as its argument to see if it's ok to return the private key. * * @return this signer's private key, or null if the private key has * not yet been set. * * @exception SecurityException if a security manager exists and its - * checkSecurityAccess method doesn't allow + * {@code checkSecurityAccess} method doesn't allow * returning the private key. * * @see SecurityManager#checkSecurityAccess @@ -113,8 +113,8 @@ public abstract class Signer extends Identity { /** * Sets the key pair (public key and private key) for this signer. * - *

    First, if there is a security manager, its checkSecurityAccess - * method is called with "setSignerKeyPair" + *

    First, if there is a security manager, its {@code checkSecurityAccess} + * method is called with {@code "setSignerKeyPair"} * as its argument to see if it's ok to set the key pair. * * @param pair an initialized key pair. @@ -124,7 +124,7 @@ public abstract class Signer extends Identity { * @exception KeyException if the key pair cannot be set for any * other reason. * @exception SecurityException if a security manager exists and its - * checkSecurityAccess method doesn't allow + * {@code checkSecurityAccess} method doesn't allow * setting the key pair. * * @see SecurityManager#checkSecurityAccess diff --git a/jdk/src/share/classes/java/security/UnresolvedPermission.java b/jdk/src/share/classes/java/security/UnresolvedPermission.java index 5428d17d82d..e6a6b36ed2a 100644 --- a/jdk/src/share/classes/java/security/UnresolvedPermission.java +++ b/jdk/src/share/classes/java/security/UnresolvedPermission.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -72,11 +72,11 @@ import java.security.cert.*; * the class provides a zero, one, and/or two-argument constructor. * The zero-argument constructor would be used to instantiate * a permission without a name and without actions. - * A one-arg constructor is assumed to take a String + * A one-arg constructor is assumed to take a {@code String} * name as input, and a two-arg constructor is assumed to take a - * String name and String actions + * {@code String} name and {@code String} actions * as input. UnresolvedPermission may invoke a - * constructor with a null name and/or actions. + * constructor with a {@code null} name and/or actions. * If an appropriate permission constructor is not available, * the UnresolvedPermission is ignored and the relevant permission * will not be granted to executing code. @@ -84,9 +84,9 @@ import java.security.cert.*; *

    The newly created permission object replaces the * UnresolvedPermission, which is removed. * - *

    Note that the getName method for an - * UnresolvedPermission returns the - * type (class name) for the underlying permission + *

    Note that the {@code getName} method for an + * {@code UnresolvedPermission} returns the + * {@code type} (class name) for the underlying permission * that has not been resolved. * * @see java.security.Permission @@ -440,7 +440,7 @@ implements java.io.Serializable * has not been resolved. * * @return the target name of the underlying permission that - * has not been resolved, or null, + * has not been resolved, or {@code null}, * if there is no targe name * * @since 1.5 @@ -454,7 +454,7 @@ implements java.io.Serializable * has not been resolved. * * @return the actions for the underlying permission that - * has not been resolved, or null + * has not been resolved, or {@code null} * if there are no actions * * @since 1.5 @@ -503,16 +503,16 @@ implements java.io.Serializable /** * Writes this object out to a stream (i.e., serializes it). * - * @serialData An initial String denoting the - * type is followed by a String denoting the - * name is followed by a String denoting the - * actions is followed by an int indicating the + * @serialData An initial {@code String} denoting the + * {@code type} is followed by a {@code String} denoting the + * {@code name} is followed by a {@code String} denoting the + * {@code actions} is followed by an {@code int} indicating the * number of certificates to follow * (a value of "zero" denotes that there are no certificates associated * with this object). - * Each certificate is written out starting with a String + * Each certificate is written out starting with a {@code String} * denoting the certificate type, followed by an - * int specifying the length of the certificate encoding, + * {@code int} specifying the length of the certificate encoding, * followed by the certificate encoding itself which is written out as an * array of bytes. */ diff --git a/jdk/src/share/classes/java/security/acl/Acl.java b/jdk/src/share/classes/java/security/acl/Acl.java index e90f740b1f0..e7b6a21b28c 100644 --- a/jdk/src/share/classes/java/security/acl/Acl.java +++ b/jdk/src/share/classes/java/security/acl/Acl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2004, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2013, 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 @@ -66,19 +66,19 @@ import java.security.Principal; * * * - * The java.security.acl package provides the + * The {@code java.security.acl } package provides the * interfaces to the ACL and related data structures (ACL entries, - * groups, permissions, etc.), and the sun.security.acl + * groups, permissions, etc.), and the {@code sun.security.acl } * classes provide a default implementation of the interfaces. For - * example, java.security.acl.Acl provides the - * interface to an ACL and the sun.security.acl.AclImpl + * example, {@code java.security.acl.Acl } provides the + * interface to an ACL and the {@code sun.security.acl.AclImpl } * class provides the default implementation of the interface.

    * - * The java.security.acl.Acl interface extends the - * java.security.acl.Owner interface. The Owner + * The {@code java.security.acl.Acl } interface extends the + * {@code java.security.acl.Owner } interface. The Owner * interface is used to maintain a list of owners for each ACL. Only * owners are allowed to modify an ACL. For example, only an owner can - * call the ACL's addEntry method to add a new ACL entry + * call the ACL's {@code addEntry} method to add a new ACL entry * to the ACL. * * @see java.security.acl.AclEntry @@ -217,7 +217,7 @@ public interface Acl extends Owner { * More specifically, this method checks whether the passed permission * is a member of the allowed permission set of the specified principal. * The allowed permission set is determined by the same algorithm as is - * used by the getPermissions method. + * used by the {@code getPermissions} method. * * @param principal the principal, assumed to be a valid authenticated * Principal. diff --git a/jdk/src/share/classes/java/security/acl/AclEntry.java b/jdk/src/share/classes/java/security/acl/AclEntry.java index f8dd3a752e0..cd9675f34a1 100644 --- a/jdk/src/share/classes/java/security/acl/AclEntry.java +++ b/jdk/src/share/classes/java/security/acl/AclEntry.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2004, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2013, 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 @@ -84,7 +84,7 @@ public interface AclEntry extends Cloneable { * specified in the entry. * * Note: ACL entries are by default positive. An entry becomes a - * negative entry only if this setNegativePermissions + * negative entry only if this {@code setNegativePermissions} * method is called on it. */ public void setNegativePermissions(); diff --git a/jdk/src/share/classes/java/security/acl/Group.java b/jdk/src/share/classes/java/security/acl/Group.java index be3578b3c33..ebd9c445282 100644 --- a/jdk/src/share/classes/java/security/acl/Group.java +++ b/jdk/src/share/classes/java/security/acl/Group.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2004, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2013, 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 @@ -35,7 +35,7 @@ import java.security.Principal; * Note that Group extends Principal. Thus, either a Principal or a Group can * be passed as an argument to methods containing a Principal parameter. For * example, you can add either a Principal or a Group to a Group object by - * calling the object's addMember method, passing it the + * calling the object's {@code addMember} method, passing it the * Principal or Group. * * @author Satish Dharmaraj diff --git a/jdk/src/share/classes/java/security/acl/Owner.java b/jdk/src/share/classes/java/security/acl/Owner.java index 313889528d6..2f649d40b33 100644 --- a/jdk/src/share/classes/java/security/acl/Owner.java +++ b/jdk/src/share/classes/java/security/acl/Owner.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 1997, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2013, 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 @@ -30,7 +30,7 @@ import java.security.Principal; /** * Interface for managing owners of Access Control Lists (ACLs) or ACL * configurations. (Note that the Acl interface in the - * java.security.acl package extends this Owner + * {@code java.security.acl} package extends this Owner * interface.) The initial owner Principal should be specified as an * argument to the constructor of the class implementing this interface. * diff --git a/jdk/src/share/classes/java/security/acl/package-info.java b/jdk/src/share/classes/java/security/acl/package-info.java new file mode 100644 index 00000000000..356c102e323 --- /dev/null +++ b/jdk/src/share/classes/java/security/acl/package-info.java @@ -0,0 +1,33 @@ +/* + * Copyright (c) 1998, 2013, 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. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * 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. + */ + +/** + * The classes and interfaces in this package have been + * superseded by classes in the java.security package. + * See that package and, for example, java.security.Permission for details. + * + * @since JDK1.1 + */ +package java.security.acl; diff --git a/jdk/src/share/classes/java/security/acl/package.html b/jdk/src/share/classes/java/security/acl/package.html deleted file mode 100644 index 497dfe8323e..00000000000 --- a/jdk/src/share/classes/java/security/acl/package.html +++ /dev/null @@ -1,54 +0,0 @@ - - - - - - - - -The classes and interfaces in this package have been -superseded by classes in the java.security package. -See that package and, for example, java.security.Permission for details. - - - -@since JDK1.1 - - diff --git a/jdk/src/share/classes/java/security/cert/package-info.java b/jdk/src/share/classes/java/security/cert/package-info.java new file mode 100644 index 00000000000..58f5fb77e0a --- /dev/null +++ b/jdk/src/share/classes/java/security/cert/package-info.java @@ -0,0 +1,64 @@ +/* + * Copyright (c) 1998, 2013, 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. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * 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. + */ + +/** + * Provides classes and interfaces for parsing and managing + * certificates, certificate revocation lists (CRLs), and + * certification paths. It contains support for X.509 v3 + * certificates and X.509 v2 CRLs. + * + *

    Package Specification

    + * + *
    + * + *

    Related Documentation

    + * + * For information about X.509 certificates and CRLs, please see: + * + * + * @since 1.2 + */ +package java.security.cert; diff --git a/jdk/src/share/classes/java/security/cert/package.html b/jdk/src/share/classes/java/security/cert/package.html deleted file mode 100644 index 239f7ffe1dc..00000000000 --- a/jdk/src/share/classes/java/security/cert/package.html +++ /dev/null @@ -1,67 +0,0 @@ - - - - - - -Provides classes and interfaces for parsing and managing -certificates, certificate revocation lists (CRLs), and -certification paths. It contains support for X.509 v3 -certificates and X.509 v2 CRLs. - -

    Package Specification

    - - - -

    Related Documentation

    - -For information about X.509 certificates and CRLs, please see: - - -@since 1.2 - - diff --git a/jdk/src/share/classes/java/security/interfaces/DSAKeyPairGenerator.java b/jdk/src/share/classes/java/security/interfaces/DSAKeyPairGenerator.java index 96a091ef84a..390835725b9 100644 --- a/jdk/src/share/classes/java/security/interfaces/DSAKeyPairGenerator.java +++ b/jdk/src/share/classes/java/security/interfaces/DSAKeyPairGenerator.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -30,8 +30,8 @@ import java.security.*; /** * An interface to an object capable of generating DSA key pairs. * - *

    The initialize methods may each be called any number - * of times. If no initialize method is called on a + *

    The {@code initialize} methods may each be called any number + * of times. If no {@code initialize} method is called on a * DSAKeyPairGenerator, the default is to generate 1024-bit keys, using * precomputed p, q and g parameters and an instance of SecureRandom as * the random bit source. @@ -42,22 +42,22 @@ import java.security.*; *

      * *
    1. Get a key pair generator for the DSA algorithm by calling the - * KeyPairGenerator getInstance method with "DSA" + * KeyPairGenerator {@code getInstance} method with "DSA" * as its argument.

      * *

    2. Initialize the generator by casting the result to a DSAKeyPairGenerator * and calling one of the - * initialize methods from this DSAKeyPairGenerator interface.

      + * {@code initialize} methods from this DSAKeyPairGenerator interface.

      * - *

    3. Generate a key pair by calling the generateKeyPair + *
    4. Generate a key pair by calling the {@code generateKeyPair} * method from the KeyPairGenerator class. * *
    * *

    Note: it is not always necessary to do do algorithm-specific * initialization for a DSA key pair generator. That is, it is not always - * necessary to call an initialize method in this interface. - * Algorithm-independent initialization using the initialize method + * necessary to call an {@code initialize} method in this interface. + * Algorithm-independent initialization using the {@code initialize} method * in the KeyPairGenerator * interface is all that is needed when you accept defaults for algorithm-specific * parameters. @@ -80,7 +80,7 @@ public interface DSAKeyPairGenerator { * @param random the random bit source to use to generate key bits; * can be null. * - * @exception InvalidParameterException if the params + * @exception InvalidParameterException if the {@code params} * value is invalid, null, or unsupported. */ public void initialize(DSAParams params, SecureRandom random) @@ -92,7 +92,7 @@ public interface DSAKeyPairGenerator { * If a SecureRandom bit source is needed but not supplied, i.e. * null, a default SecureRandom instance will be used. * - *

    If genParams is true, this method generates new + *

    If {@code genParams} is true, this method generates new * p, q and g parameters. If it is false, the method uses precomputed * parameters for the modulus length requested. If there are no * precomputed parameters for that modulus length, an exception will be @@ -108,8 +108,8 @@ public interface DSAKeyPairGenerator { * @param genParams whether or not to generate new parameters for * the modulus length requested. * - * @exception InvalidParameterException if modlen is - * invalid, or unsupported, or if genParams is false and there + * @exception InvalidParameterException if {@code modlen} is + * invalid, or unsupported, or if {@code genParams} is false and there * are no precomputed parameters for the requested modulus length. */ public void initialize(int modlen, boolean genParams, SecureRandom random) diff --git a/jdk/src/share/classes/java/security/interfaces/DSAParams.java b/jdk/src/share/classes/java/security/interfaces/DSAParams.java index f20b8ec386b..8c46ed57e27 100644 --- a/jdk/src/share/classes/java/security/interfaces/DSAParams.java +++ b/jdk/src/share/classes/java/security/interfaces/DSAParams.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 1998, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2013, 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 @@ -42,23 +42,23 @@ import java.math.BigInteger; public interface DSAParams { /** - * Returns the prime, p. + * Returns the prime, {@code p}. * - * @return the prime, p. + * @return the prime, {@code p}. */ public BigInteger getP(); /** - * Returns the subprime, q. + * Returns the subprime, {@code q}. * - * @return the subprime, q. + * @return the subprime, {@code q}. */ public BigInteger getQ(); /** - * Returns the base, g. + * Returns the base, {@code g}. * - * @return the base, g. + * @return the base, {@code g}. */ public BigInteger getG(); } diff --git a/jdk/src/share/classes/java/security/interfaces/DSAPrivateKey.java b/jdk/src/share/classes/java/security/interfaces/DSAPrivateKey.java index a0d189372e6..81ab3586f69 100644 --- a/jdk/src/share/classes/java/security/interfaces/DSAPrivateKey.java +++ b/jdk/src/share/classes/java/security/interfaces/DSAPrivateKey.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 1999, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -50,9 +50,9 @@ public interface DSAPrivateKey extends DSAKey, java.security.PrivateKey { static final long serialVersionUID = 7776497482533790279L; /** - * Returns the value of the private key, x. + * Returns the value of the private key, {@code x}. * - * @return the value of the private key, x. + * @return the value of the private key, {@code x}. */ public BigInteger getX(); } diff --git a/jdk/src/share/classes/java/security/interfaces/DSAPublicKey.java b/jdk/src/share/classes/java/security/interfaces/DSAPublicKey.java index b27373880e6..e56b795ae70 100644 --- a/jdk/src/share/classes/java/security/interfaces/DSAPublicKey.java +++ b/jdk/src/share/classes/java/security/interfaces/DSAPublicKey.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 1999, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2013, 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 @@ -50,9 +50,9 @@ public interface DSAPublicKey extends DSAKey, java.security.PublicKey { static final long serialVersionUID = 1234526332779022332L; /** - * Returns the value of the public key, y. + * Returns the value of the public key, {@code y}. * - * @return the value of the public key, y. + * @return the value of the public key, {@code y}. */ public BigInteger getY(); } diff --git a/jdk/src/share/classes/java/security/interfaces/package-info.java b/jdk/src/share/classes/java/security/interfaces/package-info.java new file mode 100644 index 00000000000..54c9397e691 --- /dev/null +++ b/jdk/src/share/classes/java/security/interfaces/package-info.java @@ -0,0 +1,74 @@ +/* + * Copyright (c) 1998, 2013, 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. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * 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. + */ + +/** + * Provides interfaces for generating RSA (Rivest, Shamir and + * Adleman AsymmetricCipher algorithm) + * keys as defined in the RSA Laboratory Technical Note + * PKCS#1, and DSA (Digital Signature + * Algorithm) keys as defined in NIST's FIPS-186. + *

    + * Note that these interfaces are intended only for key + * implementations whose key material is accessible and + * available. These interfaces are not intended for key + * implementations whose key material resides in + * inaccessible, protected storage (such as in a + * hardware device). + *

    + * For more developer information on how to use these + * interfaces, including information on how to design + * {@code Key} classes for hardware devices, please refer + * to these cryptographic provider developer guides: + *

    + * + *

    Package Specification

    + * + *
      + *
    • PKCS #1: RSA Encryption Standard, Version 1.5, November 1993
    • + *
    • Federal Information Processing Standards Publication (FIPS PUB) 186: + * Digital Signature Standard (DSS)
    • + *
    + * + *

    Related Documentation

    + * + * For further documentation, please see: + * + * + * @since JDK1.1 + */ +package java.security.interfaces; diff --git a/jdk/src/share/classes/java/security/interfaces/package.html b/jdk/src/share/classes/java/security/interfaces/package.html deleted file mode 100644 index 70820dd70a5..00000000000 --- a/jdk/src/share/classes/java/security/interfaces/package.html +++ /dev/null @@ -1,77 +0,0 @@ - - - - - - -Provides interfaces for generating RSA (Rivest, Shamir and -Adleman AsymmetricCipher algorithm) -keys as defined in the RSA Laboratory Technical Note -PKCS#1, and DSA (Digital Signature -Algorithm) keys as defined in NIST's FIPS-186. -

    -Note that these interfaces are intended only for key -implementations whose key material is accessible and -available. These interfaces are not intended for key -implementations whose key material resides in -inaccessible, protected storage (such as in a -hardware device). -

    -For more developer information on how to use these -interfaces, including information on how to design -Key classes for hardware devices, please refer -to these cryptographic provider developer guides: -

    - -

    Package Specification

    - -
      -
    • PKCS #1: RSA Encryption Standard, Version 1.5, November 1993
    • -
    • Federal Information Processing Standards Publication (FIPS PUB) 186: - Digital Signature Standard (DSS)
    • -
    - -

    Related Documentation

    - -For further documentation, please see: - - -@since JDK1.1 - - diff --git a/jdk/src/share/classes/java/security/package-info.java b/jdk/src/share/classes/java/security/package-info.java new file mode 100644 index 00000000000..599e95259ba --- /dev/null +++ b/jdk/src/share/classes/java/security/package-info.java @@ -0,0 +1,112 @@ +/* + * Copyright (c) 1998, 2013, 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. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * 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. + */ + +/** + * Provides the classes and interfaces for the security framework. + * This includes classes that implement an easily configurable, + * fine-grained access control security architecture. + * This package also supports + * the generation and storage of cryptographic public key pairs, + * as well as a number of exportable cryptographic operations + * including those for message digest and signature generation. Finally, + * this package provides classes that support signed/guarded objects + * and secure random number generation. + * + * Many of the classes provided in this package (the cryptographic + * and secure random number generator classes in particular) are + * provider-based. The class itself defines a programming interface + * to which applications may write. The implementations themselves may + * then be written by independent third-party vendors and plugged + * in seamlessly as needed. Therefore application developers may + * take advantage of any number of provider-based implementations + * without having to add or rewrite code. + * + *

    Package Specification

    + * + * + * + *

    Related Documentation

    + * + * For further documentation, please see: + * + * + * @since 1.1 + */ +package java.security; diff --git a/jdk/src/share/classes/java/security/package.html b/jdk/src/share/classes/java/security/package.html deleted file mode 100644 index 65eb70c71af..00000000000 --- a/jdk/src/share/classes/java/security/package.html +++ /dev/null @@ -1,117 +0,0 @@ - - - - - - - - -Provides the classes and interfaces for the security framework. -This includes classes that implement an easily configurable, -fine-grained access control security architecture. -This package also supports -the generation and storage of cryptographic public key pairs, -as well as a number of exportable cryptographic operations -including those for message digest and signature generation. Finally, -this package provides classes that support signed/guarded objects -and secure random number generation. - -Many of the classes provided in this package (the cryptographic -and secure random number generator classes in particular) are -provider-based. The class itself defines a programming interface -to which applications may write. The implementations themselves may -then be written by independent third-party vendors and plugged -in seamlessly as needed. Therefore application developers may -take advantage of any number of provider-based implementations -without having to add or rewrite code. - -

    Package Specification

    - - - -

    Related Documentation

    - -For further documentation, please see: - - -@since 1.1 - - diff --git a/jdk/src/share/classes/java/security/spec/package-info.java b/jdk/src/share/classes/java/security/spec/package-info.java new file mode 100644 index 00000000000..cb393088e5b --- /dev/null +++ b/jdk/src/share/classes/java/security/spec/package-info.java @@ -0,0 +1,73 @@ +/* + * Copyright (c) 1998, 2013, 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. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * 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. + */ + +/** + * Provides classes and interfaces for key specifications and algorithm + * parameter specifications. + * + *

    A key specification is a transparent representation of the key material + * that constitutes a key. A key may be specified in an algorithm-specific + * way, or in an algorithm-independent encoding format (such as ASN.1). + * This package contains key specifications for DSA public and private keys, + * RSA public and private keys, PKCS #8 private keys in DER-encoded format, + * and X.509 public and private keys in DER-encoded format. + * + *

    An algorithm parameter specification is a transparent representation + * of the sets of parameters used with an algorithm. This package contains + * an algorithm parameter specification for parameters used with the + * DSA algorithm. + * + *

    Package Specification

    + * + *
      + *
    • PKCS #1: RSA Encryption Standard, Version 1.5, November 1993
    • + *
    • PKCS #8: Private-Key Information Syntax Standard, + * Version 1.2, November 1993
    • + *
    • Federal Information Processing Standards Publication (FIPS PUB) 186: + * Digital Signature Standard (DSS)
    • + *
    + * + *

    Related Documentation

    + * + * For documentation that includes information about algorithm parameter + * and key specifications, please see: + * + * + * @since 1.2 + */ +package java.security.spec; diff --git a/jdk/src/share/classes/java/security/spec/package.html b/jdk/src/share/classes/java/security/spec/package.html deleted file mode 100644 index 54558ae198a..00000000000 --- a/jdk/src/share/classes/java/security/spec/package.html +++ /dev/null @@ -1,78 +0,0 @@ - - - - - - - - -Provides classes and interfaces for key specifications and algorithm -parameter specifications. - -

    A key specification is a transparent representation of the key material -that constitutes a key. A key may be specified in an algorithm-specific -way, or in an algorithm-independent encoding format (such as ASN.1). -This package contains key specifications for DSA public and private keys, -RSA public and private keys, PKCS #8 private keys in DER-encoded format, -and X.509 public and private keys in DER-encoded format. - -

    An algorithm parameter specification is a transparent representation -of the sets of parameters used with an algorithm. This package contains -an algorithm parameter specification for parameters used with the -DSA algorithm. - -

    Package Specification

    - -
      -
    • PKCS #1: RSA Encryption Standard, Version 1.5, November 1993
    • -
    • PKCS #8: Private-Key Information Syntax Standard, - Version 1.2, November 1993
    • -
    • Federal Information Processing Standards Publication (FIPS PUB) 186: - Digital Signature Standard (DSS)
    • -
    - -

    Related Documentation

    - -For documentation that includes information about algorithm parameter -and key specifications, please see: - - -@since 1.2 - - From da1d369ffe96f052279ff46c40f6154c338e8009 Mon Sep 17 00:00:00 2001 From: Joe Darcy Date: Fri, 28 Jun 2013 11:35:36 -0700 Subject: [PATCH 082/127] 8019407: Fix doclint issues in javax.naming.* Reviewed-by: lancea --- .../classes/javax/naming/CompositeName.java | 14 +++++------ .../classes/javax/naming/CompoundName.java | 6 ++--- .../share/classes/javax/naming/Context.java | 24 +++++++++---------- .../classes/javax/naming/InitialContext.java | 6 +++-- .../share/classes/javax/naming/RefAddr.java | 5 ++-- .../javax/naming/ReferralException.java | 6 ++--- .../javax/naming/directory/DirContext.java | 16 ++++++------- .../javax/naming/event/EventContext.java | 12 +++++----- .../javax/naming/ldap/ControlFactory.java | 4 ++-- .../javax/naming/ldap/InitialLdapContext.java | 2 +- .../javax/naming/ldap/LdapContext.java | 18 ++++++-------- 11 files changed, 56 insertions(+), 57 deletions(-) diff --git a/jdk/src/share/classes/javax/naming/CompositeName.java b/jdk/src/share/classes/javax/naming/CompositeName.java index fe9a09966c8..ffa837d4a23 100644 --- a/jdk/src/share/classes/javax/naming/CompositeName.java +++ b/jdk/src/share/classes/javax/naming/CompositeName.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2013, 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 @@ -42,7 +42,7 @@ import java.util.Properties; * The most significant component is at index 0. * An empty composite name has no components. *

    - *

    JNDI Composite Name Syntax

    + *

    JNDI Composite Name Syntax

    * JNDI defines a standard string representation for composite names. This * representation is the concatenation of the components of a composite name * from left to right using the component separator (a forward @@ -73,12 +73,12 @@ import java.util.Properties; * a separator) denotes a trailing empty component. * Adjacent component separators denote an empty component. *

    - *

    Composite Name Examples

    + *

    Composite Name Examples

    *This table shows examples of some composite names. Each row shows *the string form of a composite name and its corresponding structural form *(CompositeName). *

    - +
    @@ -137,14 +137,14 @@ import java.util.Properties;
    String Name
    *

    - *

    Composition Examples

    + *

    Composition Examples

    * Here are some composition examples. The right column shows composing * string composite names while the left column shows composing the * corresponding CompositeNames. Notice that composing the * string forms of two composite names simply involves concatenating * their string forms together. -

    +

    @@ -189,7 +189,7 @@ import java.util.Properties;
    String Names
    *

    - *

    Multithreaded Access

    + *

    Multithreaded Access

    * A CompositeName instance is not synchronized against concurrent * multithreaded access. Multiple threads trying to access and modify a * CompositeName should lock the object. diff --git a/jdk/src/share/classes/javax/naming/CompoundName.java b/jdk/src/share/classes/javax/naming/CompoundName.java index 76bd672cf01..49269e6bc4a 100644 --- a/jdk/src/share/classes/javax/naming/CompoundName.java +++ b/jdk/src/share/classes/javax/naming/CompoundName.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2013, 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 @@ -39,7 +39,7 @@ import java.util.Properties; * The most significant component is at index 0. * An empty compound name has no components. *

    - *

    Compound Name Syntax

    + *

    Compound Name Syntax

    * The syntax of a compound name is specified using a set of properties: *
    *
    jndi.syntax.direction @@ -136,7 +136,7 @@ import java.util.Properties; * so that when the same string is parsed, it will yield the same components * of the original compound name. *

    - *

    Multithreaded Access

    + *

    Multithreaded Access

    * A CompoundName instance is not synchronized against concurrent * multithreaded access. Multiple threads trying to access and modify a * CompoundName should lock the object. diff --git a/jdk/src/share/classes/javax/naming/Context.java b/jdk/src/share/classes/javax/naming/Context.java index 567c401bf8a..36040e70fe3 100644 --- a/jdk/src/share/classes/javax/naming/Context.java +++ b/jdk/src/share/classes/javax/naming/Context.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2006, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2013, 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 @@ -32,7 +32,7 @@ import java.util.Hashtable; * consists of a set of name-to-object bindings. * It contains methods for examining and updating these bindings. *

    - *

    Names

    + *

    Names

    * Each name passed as an argument to a Context method is relative * to that context. The empty name is used to name the context itself. * A name parameter may never be null. @@ -69,12 +69,12 @@ import java.util.Hashtable; * names in a composite namespace, at the discretion of the service * provider. *

    - *

    Exceptions

    + *

    Exceptions

    * All the methods in this interface can throw a NamingException or * any of its subclasses. See NamingException and their subclasses * for details on each exception. *

    - *

    Concurrent Access

    + *

    Concurrent Access

    * A Context instance is not guaranteed to be synchronized against * concurrent access by multiple threads. Threads that need to access * a single Context instance concurrently should synchronize amongst @@ -91,7 +91,7 @@ import java.util.Hashtable; * being followed. * *

    - *

    Parameters

    + *

    Parameters

    * A Name parameter passed to any method of the * Context interface or one of its subinterfaces * will not be modified by the service provider. @@ -103,7 +103,7 @@ import java.util.Hashtable; * The caller may subsequently modify it; the service provider may not. * *

    - *

    Environment Properties

    + *

    Environment Properties

    *

    * JNDI applications need a way to communicate various preferences * and properties that define the environment in which naming and @@ -138,7 +138,7 @@ import java.util.Hashtable; * *

    * - *

    Resource Files

    + *

    Resource Files

    *

    * To simplify the task of setting up the environment * required by a JNDI application, @@ -151,11 +151,11 @@ import java.util.Hashtable; * and the value is a string in the format defined * for that property. Here is an example of a JNDI resource file: * - *

    + * 
    {@code * java.naming.factory.object=com.sun.jndi.ldap.AttrsToCorba:com.wiz.from.Person * java.naming.factory.state=com.sun.jndi.ldap.CorbaToAttrs:com.wiz.from.Person * java.naming.factory.control=com.sun.jndi.ldap.ResponseControlFactory - *
    + * }
    * * The JNDI class library reads the resource files and makes the property * values freely available. Thus JNDI resource files should be considered @@ -165,7 +165,7 @@ import java.util.Hashtable; * There are two kinds of JNDI resource files: * provider and application. * - *
    Provider Resource Files
    + *

    Provider Resource Files

    * * Each service provider has an optional resource that lists properties * specific to that provider. The name of this resource is: @@ -200,7 +200,7 @@ import java.util.Hashtable; * The service provider's documentation should clearly state which * properties are allowed; other properties in the file will be ignored. * - *
    Application Resource Files
    + *

    Application Resource Files

    * * When an application is deployed, it will generally have several * codebase directories and JARs in its classpath. Similarly, when an @@ -232,7 +232,7 @@ import java.util.Hashtable; * collects and uses all of these export lists when searching for factory * classes. * - *
    Search Algorithm for Properties
    + *

    Search Algorithm for Properties

    * * When JNDI constructs an initial context, the context's environment * is initialized with properties defined in the environment parameter diff --git a/jdk/src/share/classes/javax/naming/InitialContext.java b/jdk/src/share/classes/javax/naming/InitialContext.java index 6dbc5be0518..6a10cf6ce72 100644 --- a/jdk/src/share/classes/javax/naming/InitialContext.java +++ b/jdk/src/share/classes/javax/naming/InitialContext.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2013, 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 @@ -258,6 +258,7 @@ public class InitialContext implements Context { * environment may be modified independently and it may be accessed * concurrently). * + * @param the type of the returned object * @param name * the name of the object to look up * @return the object bound to name @@ -276,11 +277,12 @@ public class InitialContext implements Context { /** * A static method to retrieve the named object. * See {@link #doLookup(Name)} for details. + * @param the type of the returned object * @param name * the name of the object to look up * @return the object bound to name * @throws NamingException if a naming exception is encountered - * @since 1.6 + * @since 1.6 */ @SuppressWarnings("unchecked") public static T doLookup(String name) diff --git a/jdk/src/share/classes/javax/naming/RefAddr.java b/jdk/src/share/classes/javax/naming/RefAddr.java index 72ca93334d6..92ac4320f5d 100644 --- a/jdk/src/share/classes/javax/naming/RefAddr.java +++ b/jdk/src/share/classes/javax/naming/RefAddr.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2000, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2013, 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 @@ -91,7 +91,8 @@ public abstract class RefAddr implements java.io.Serializable { * Determines whether obj is equal to this RefAddr. *

    * obj is equal to this RefAddr all of these conditions are true - *

      non-null + *
        + *
      • non-null *
      • instance of RefAddr *
      • obj has the same address type as this RefAddr (using String.compareTo()) *
      • both obj and this RefAddr's contents are null or they are equal diff --git a/jdk/src/share/classes/javax/naming/ReferralException.java b/jdk/src/share/classes/javax/naming/ReferralException.java index 7c67429a4a9..23d77cf3c65 100644 --- a/jdk/src/share/classes/javax/naming/ReferralException.java +++ b/jdk/src/share/classes/javax/naming/ReferralException.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2004, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2013, 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 @@ -38,7 +38,7 @@ import java.util.Hashtable; * constructors and/or corresponding "set" methods). *

        * The following code sample shows how ReferralException can be used. - *

        + * 
        {@code * while (true) { * try { * bindings = ctx.listBindings(name); @@ -51,7 +51,7 @@ import java.util.Hashtable; * ctx = e.getReferralContext(); * } * } - *

        + * } *

        * ReferralException is an abstract class. Concrete implementations * determine its synchronization and serialization properties. diff --git a/jdk/src/share/classes/javax/naming/directory/DirContext.java b/jdk/src/share/classes/javax/naming/directory/DirContext.java index 4b9fc59d6b6..e3728792c58 100644 --- a/jdk/src/share/classes/javax/naming/directory/DirContext.java +++ b/jdk/src/share/classes/javax/naming/directory/DirContext.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2005, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2013, 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 @@ -32,7 +32,7 @@ import javax.naming.*; * methods for examining and updating attributes * associated with objects, and for searching the directory. *

        - *

        Names

        + *

        Names

        * Each name passed as an argument to a DirContext method is relative * to that context. The empty name is used to name the context itself. * The name parameter may never be null. @@ -51,7 +51,7 @@ import javax.naming.*; * name argument to the Context methods. These same rules * apply to the name argument to the DirContext methods. *

        - *

        Attribute Models

        + *

        Attribute Models

        * There are two basic models of what attributes should be * associated with. First, attributes may be directly associated with a * DirContext object. @@ -81,7 +81,7 @@ import javax.naming.*; * whether an object's attributes are stored as part of the object, or stored * within the parent object and associated with the object's name. *

        - *

        Attribute Type Names

        + *

        Attribute Type Names

        * In the getAttributes() and search() methods, * you can supply the attributes to return by supplying a list of * attribute names (strings). @@ -113,7 +113,7 @@ import javax.naming.*; *
      * *

      - *

      Operational Attributes

      + *

      Operational Attributes

      *

      * Some directories have the notion of "operational attributes" which are * attributes associated with a directory object for administrative @@ -127,7 +127,7 @@ import javax.naming.*; * In order to retrieve operational attributes, you must name them explicitly. * *

      - *

      Named Context

      + *

      Named Context

      *

      * There are certain methods in which the name must resolve to a context * (for example, when searching a single level context). The documentation @@ -138,7 +138,7 @@ import javax.naming.*; * Aside from these methods, there is no requirement that the * named object be a DirContext. *

      - *

      Parameters

      + *

      Parameters

      *

      * An Attributes, SearchControls, or array object * passed as a parameter to any method will not be modified by the @@ -150,7 +150,7 @@ import javax.naming.*; * the caller. The caller may subsequently modify it; the service * provider will not. *

      - *

      Exceptions

      + *

      Exceptions

      *

      * All the methods in this interface can throw a NamingException or * any of its subclasses. See NamingException and their subclasses diff --git a/jdk/src/share/classes/javax/naming/event/EventContext.java b/jdk/src/share/classes/javax/naming/event/EventContext.java index f9ae24935a8..fd44876475b 100644 --- a/jdk/src/share/classes/javax/naming/event/EventContext.java +++ b/jdk/src/share/classes/javax/naming/event/EventContext.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2004, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2013, 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 @@ -34,7 +34,7 @@ import javax.naming.NamingException; * Contains methods for registering/deregistering listeners to be notified of * events fired when objects named in a context changes. *

      - *

      Target

      + *

      Target

      * The name parameter in the addNamingListener() methods is referred * to as the target. The target, along with the scope, identify * the object(s) that the listener is interested in. @@ -59,7 +59,7 @@ import javax.naming.NamingException; * whether a EventContext supports registration * of nonexistent targets. *

      - *

      Event Source

      + *

      Event Source

      * The EventContext instance on which you invoke the * registration methods is the event source of the events that are * (potentially) generated. @@ -93,7 +93,7 @@ import javax.naming.NamingException; * it needs to keep a reference to the listener in order to remove it * later). It cannot expect to do a lookup() and get another instance of * a EventContext on which to perform the deregistration. - *

      Lifetime of Registration

      + *

      Lifetime of Registration

      * A registered listener becomes deregistered when: *
        *
      • It is removed using removeNamingListener(). @@ -105,7 +105,7 @@ import javax.naming.NamingException; * Until that point, a EventContext instance that has outstanding * listeners will continue to exist and be maintained by the service provider. * - *

        Listener Implementations

        + *

        Listener Implementations

        * The registration/deregistration methods accept an instance of * NamingListener. There are subinterfaces of NamingListener * for different of event types of NamingEvent. @@ -118,7 +118,7 @@ import javax.naming.NamingException; * of the listeners, this allows some service providers to optimize the * registration. * - *

        Threading Issues

        + *

        Threading Issues

        * * Like Context instances in general, instances of * EventContext are not guaranteed to be thread-safe. diff --git a/jdk/src/share/classes/javax/naming/ldap/ControlFactory.java b/jdk/src/share/classes/javax/naming/ldap/ControlFactory.java index cbd9b8ab853..4ab5a347f66 100644 --- a/jdk/src/share/classes/javax/naming/ldap/ControlFactory.java +++ b/jdk/src/share/classes/javax/naming/ldap/ControlFactory.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2013, 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 @@ -51,7 +51,7 @@ import com.sun.naming.internal.ResourceManager; */ public abstract class ControlFactory { - /* + /** * Creates a new instance of a control factory. */ protected ControlFactory() { diff --git a/jdk/src/share/classes/javax/naming/ldap/InitialLdapContext.java b/jdk/src/share/classes/javax/naming/ldap/InitialLdapContext.java index df77164af5f..8dde5cb7afc 100644 --- a/jdk/src/share/classes/javax/naming/ldap/InitialLdapContext.java +++ b/jdk/src/share/classes/javax/naming/ldap/InitialLdapContext.java @@ -38,7 +38,7 @@ import java.util.Hashtable; * javax.naming.InitialDirContext for details on synchronization, * and the policy for how an initial context is created. * - *

        Request Controls

        + *

        Request Controls

        * When you create an initial context (InitialLdapContext), * you can specify a list of request controls. * These controls will be used as the request controls for any diff --git a/jdk/src/share/classes/javax/naming/ldap/LdapContext.java b/jdk/src/share/classes/javax/naming/ldap/LdapContext.java index 93d60c4afca..8cb5fb0be01 100644 --- a/jdk/src/share/classes/javax/naming/ldap/LdapContext.java +++ b/jdk/src/share/classes/javax/naming/ldap/LdapContext.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2000, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2013, 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 @@ -78,10 +78,8 @@ import java.util.Hashtable; *

        Context Request Controls

        * There are two ways in which a context instance gets its request controls: *
          - * - *
        1. ldapContext.newInstance(reqCtls) - *
        2. ldapContext.setRequestControls(reqCtls) - * + *
        3. ldapContext.newInstance(reqCtls) + *
        4. ldapContext.setRequestControls(reqCtls) *
        * where ldapContext is an instance of LdapContext. * Specifying null or an empty array for reqCtls @@ -102,12 +100,10 @@ import java.util.Hashtable; *

        Connection Request Controls

        * There are three ways in which connection request controls are set: *
          - * - *
        1. - * new InitialLdapContext(env, connCtls) - *
        2. refException.getReferralContext(env, connCtls) - *
        3. ldapContext.reconnect(connCtls); - * + *
        4. + * new InitialLdapContext(env, connCtls) + *
        5. refException.getReferralContext(env, connCtls) + *
        6. ldapContext.reconnect(connCtls); *
        * where refException is an instance of * LdapReferralException, and ldapContext is an From 6084db7277a91e75dd2acc7ed93624aab6322a4b Mon Sep 17 00:00:00 2001 From: Alan Bateman Date: Fri, 28 Jun 2013 19:45:06 +0100 Subject: [PATCH 083/127] 8019384: jps and jcmd tests fail when there is a process started with a .war file Reviewed-by: dcubed, sla, mchung --- jdk/test/sun/tools/jcmd/jcmd_Output1.awk | 4 ++-- jdk/test/sun/tools/jps/jps-l_Output1.awk | 4 ++-- jdk/test/sun/tools/jps/jps_Output1.awk | 4 ++-- 3 files changed, 6 insertions(+), 6 deletions(-) diff --git a/jdk/test/sun/tools/jcmd/jcmd_Output1.awk b/jdk/test/sun/tools/jcmd/jcmd_Output1.awk index 986951dc178..5bf0403fa2d 100644 --- a/jdk/test/sun/tools/jcmd/jcmd_Output1.awk +++ b/jdk/test/sun/tools/jcmd/jcmd_Output1.awk @@ -8,10 +8,10 @@ BEGIN { current=1; } -# or match on a path name to a jar file followed by arbitraty arguments +# or match on a path name to a jar or war file followed by arbitraty arguments # - note, jar files ending with ".jar" is only a convention, not a requirement. #Theoretically, any valid file name could occur here. -/^[0-9]+ .*\.jar($| .*$)/ { +/^[0-9]+ .*\.(jar|war)($| .*$)/ { current=1; } diff --git a/jdk/test/sun/tools/jps/jps-l_Output1.awk b/jdk/test/sun/tools/jps/jps-l_Output1.awk index 5280197ed6b..08a48c17659 100644 --- a/jdk/test/sun/tools/jps/jps-l_Output1.awk +++ b/jdk/test/sun/tools/jps/jps-l_Output1.awk @@ -8,10 +8,10 @@ BEGIN { matched++; } -# or match on a jar file name - note, jar files ending with +# or match on a jar or war file name - note, jar files ending with # ".jar" is only a convention , not a requirement. Theoretically, # any valid file name could occur here. -/^[0-9]+ .*\.jar$/ { +/^[0-9]+ .*\.(jar|war)$/ { matched++; } diff --git a/jdk/test/sun/tools/jps/jps_Output1.awk b/jdk/test/sun/tools/jps/jps_Output1.awk index 1781bc560e3..c64b0f104f5 100644 --- a/jdk/test/sun/tools/jps/jps_Output1.awk +++ b/jdk/test/sun/tools/jps/jps_Output1.awk @@ -8,10 +8,10 @@ BEGIN { matched++; } -# or match on a path name to a jar file - note, jar files ending with +# or match on a path name to a jar or war file - note, jar files ending with # ".jar" is only a convention, not a requirement. Theoretically, # any valid file name could occur here. -/^[0-9]+ .*\.jar$/ { +/^[0-9]+ .*\.(jar|war)$/ { matched++; } From 36967c98e4a86c50a94cc5c4edee952008574f6f Mon Sep 17 00:00:00 2001 From: Per Liden Date: Sun, 30 Jun 2013 21:42:07 +0200 Subject: [PATCH 084/127] 8014022: G1: Non Java threads should lock the shared SATB queue lock without safepoint checks Reviewed-by: tschatzl, brutisso, jmasa, ysr --- .../share/vm/gc_implementation/g1/g1SATBCardTableModRefBS.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/hotspot/src/share/vm/gc_implementation/g1/g1SATBCardTableModRefBS.cpp b/hotspot/src/share/vm/gc_implementation/g1/g1SATBCardTableModRefBS.cpp index 9cee1eb1ba2..218be0c0e40 100644 --- a/hotspot/src/share/vm/gc_implementation/g1/g1SATBCardTableModRefBS.cpp +++ b/hotspot/src/share/vm/gc_implementation/g1/g1SATBCardTableModRefBS.cpp @@ -47,7 +47,7 @@ void G1SATBCardTableModRefBS::enqueue(oop pre_val) { JavaThread* jt = (JavaThread*)thr; jt->satb_mark_queue().enqueue(pre_val); } else { - MutexLocker x(Shared_SATB_Q_lock); + MutexLockerEx x(Shared_SATB_Q_lock, Mutex::_no_safepoint_check_flag); JavaThread::satb_mark_queue_set().shared_satb_queue()->enqueue(pre_val); } } From f93ee2a9ddd0e83d187b283c16c7c40a5166efb3 Mon Sep 17 00:00:00 2001 From: John Cuthbertson Date: Mon, 1 Jul 2013 09:30:23 -0700 Subject: [PATCH 085/127] 8017070: G1: assert(_card_counts[card_num] <= G1ConcRSHotCardLimit) failed The assert is invalid when a card is being refined by two different threads and its count crosses the hot threshold - the refinement count will be updated once by each thread triggering the assert. Remove the assert and update the count using a bounded expression. Reviewed-by: jmasa, tamao, brutisso --- hotspot/src/share/vm/gc_implementation/g1/g1CardCounts.cpp | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) diff --git a/hotspot/src/share/vm/gc_implementation/g1/g1CardCounts.cpp b/hotspot/src/share/vm/gc_implementation/g1/g1CardCounts.cpp index 00ea5b54850..f75e518facc 100644 --- a/hotspot/src/share/vm/gc_implementation/g1/g1CardCounts.cpp +++ b/hotspot/src/share/vm/gc_implementation/g1/g1CardCounts.cpp @@ -152,12 +152,9 @@ uint G1CardCounts::add_card_count(jbyte* card_ptr) { if (card_num < _committed_max_card_num) { count = (uint) _card_counts[card_num]; if (count < G1ConcRSHotCardLimit) { - _card_counts[card_num] += 1; + _card_counts[card_num] = + (jubyte)(MIN2((uintx)(_card_counts[card_num] + 1), G1ConcRSHotCardLimit)); } - assert(_card_counts[card_num] <= G1ConcRSHotCardLimit, - err_msg("Refinement count overflow? " - "new count: "UINT32_FORMAT, - (uint) _card_counts[card_num])); } } return count; From 7109e85e4301779f00bbfb190b11cd6dab078937 Mon Sep 17 00:00:00 2001 From: Tao Mao Date: Fri, 28 Jun 2013 20:18:04 -0700 Subject: [PATCH 086/127] 8017611: Auto corrector for mistyped vm options The auto corrector for mistyped vm options fuzzy-matches existing flags based on string similarity (Dice's coefficient). Reviewed-by: kvn, dsamersoff, hseigel, johnc --- hotspot/src/share/vm/runtime/arguments.cpp | 10 ++- hotspot/src/share/vm/runtime/globals.cpp | 50 +++++++++++++- hotspot/src/share/vm/runtime/globals.hpp | 3 +- .../TestUnrecognizedVMOptionsHandling.java | 69 +++++++++++++++++++ 4 files changed, 128 insertions(+), 4 deletions(-) create mode 100644 hotspot/test/gc/arguments/TestUnrecognizedVMOptionsHandling.java diff --git a/hotspot/src/share/vm/runtime/arguments.cpp b/hotspot/src/share/vm/runtime/arguments.cpp index 3fc9761f787..fe3ab30e043 100644 --- a/hotspot/src/share/vm/runtime/arguments.cpp +++ b/hotspot/src/share/vm/runtime/arguments.cpp @@ -849,7 +849,7 @@ bool Arguments::process_argument(const char* arg, arg_len = equal_sign - argname; } - Flag* found_flag = Flag::find_flag((char*)argname, arg_len, true); + Flag* found_flag = Flag::find_flag((const char*)argname, arg_len, true); if (found_flag != NULL) { char locked_message_buf[BUFLEN]; found_flag->get_locked_message(locked_message_buf, BUFLEN); @@ -870,6 +870,14 @@ bool Arguments::process_argument(const char* arg, } else { jio_fprintf(defaultStream::error_stream(), "Unrecognized VM option '%s'\n", argname); + Flag* fuzzy_matched = Flag::fuzzy_match((const char*)argname, arg_len, true); + if (fuzzy_matched != NULL) { + jio_fprintf(defaultStream::error_stream(), + "Did you mean '%s%s%s'?\n", + (fuzzy_matched->is_bool()) ? "(+/-)" : "", + fuzzy_matched->name, + (fuzzy_matched->is_bool()) ? "" : "="); + } } // allow for commandline "commenting out" options like -XX:#+Verbose diff --git a/hotspot/src/share/vm/runtime/globals.cpp b/hotspot/src/share/vm/runtime/globals.cpp index b45e15c9560..a6c47bfe1de 100644 --- a/hotspot/src/share/vm/runtime/globals.cpp +++ b/hotspot/src/share/vm/runtime/globals.cpp @@ -276,14 +276,14 @@ static Flag flagTable[] = { Flag* Flag::flags = flagTable; size_t Flag::numFlags = (sizeof(flagTable) / sizeof(Flag)); -inline bool str_equal(const char* s, char* q, size_t len) { +inline bool str_equal(const char* s, const char* q, size_t len) { // s is null terminated, q is not! if (strlen(s) != (unsigned int) len) return false; return strncmp(s, q, len) == 0; } // Search the flag table for a named flag -Flag* Flag::find_flag(char* name, size_t length, bool allow_locked) { +Flag* Flag::find_flag(const char* name, size_t length, bool allow_locked) { for (Flag* current = &flagTable[0]; current->name != NULL; current++) { if (str_equal(current->name, name, length)) { // Found a matching entry. Report locked flags only if allowed. @@ -301,6 +301,52 @@ Flag* Flag::find_flag(char* name, size_t length, bool allow_locked) { return NULL; } +// Compute string similarity based on Dice's coefficient +static float str_similar(const char* str1, const char* str2, size_t len2) { + int len1 = (int) strlen(str1); + int total = len1 + (int) len2; + + int hit = 0; + + for (int i = 0; i < len1 -1; ++i) { + for (int j = 0; j < (int) len2 -1; ++j) { + if ((str1[i] == str2[j]) && (str1[i+1] == str2[j+1])) { + ++hit; + break; + } + } + } + + return 2.0f * (float) hit / (float) total; +} + +Flag* Flag::fuzzy_match(const char* name, size_t length, bool allow_locked) { + float VMOptionsFuzzyMatchSimilarity = 0.7f; + Flag* match = NULL; + float score; + float max_score = -1; + + for (Flag* current = &flagTable[0]; current->name != NULL; current++) { + score = str_similar(current->name, name, length); + if (score > max_score) { + max_score = score; + match = current; + } + } + + if (!(match->is_unlocked() || match->is_unlocker())) { + if (!allow_locked) { + return NULL; + } + } + + if (max_score < VMOptionsFuzzyMatchSimilarity) { + return NULL; + } + + return match; +} + // Returns the address of the index'th element static Flag* address_of_flag(CommandLineFlagWithType flag) { assert((size_t)flag < Flag::numFlags, "bad command line flag index"); diff --git a/hotspot/src/share/vm/runtime/globals.hpp b/hotspot/src/share/vm/runtime/globals.hpp index b1adcf7fce1..a8383d9a5af 100644 --- a/hotspot/src/share/vm/runtime/globals.hpp +++ b/hotspot/src/share/vm/runtime/globals.hpp @@ -220,7 +220,8 @@ struct Flag { // number of flags static size_t numFlags; - static Flag* find_flag(char* name, size_t length, bool allow_locked = false); + static Flag* find_flag(const char* name, size_t length, bool allow_locked = false); + static Flag* fuzzy_match(const char* name, size_t length, bool allow_locked = false); bool is_bool() const { return strcmp(type, "bool") == 0; } bool get_bool() const { return *((bool*) addr); } diff --git a/hotspot/test/gc/arguments/TestUnrecognizedVMOptionsHandling.java b/hotspot/test/gc/arguments/TestUnrecognizedVMOptionsHandling.java new file mode 100644 index 00000000000..a61b5f30940 --- /dev/null +++ b/hotspot/test/gc/arguments/TestUnrecognizedVMOptionsHandling.java @@ -0,0 +1,69 @@ +/* +* Copyright (c) 2013, 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 TestUnrecognizedVMOptionsHandling + * @key gc + * @bug 8017611 + * @summary Tests handling unrecognized VM options + * @library /testlibrary + * @run main/othervm TestUnrecognizedVMOptionsHandling + */ + +import com.oracle.java.testlibrary.*; + +public class TestUnrecognizedVMOptionsHandling { + + public static void main(String args[]) throws Exception { + // The first two JAVA processes are expected to fail, but with a correct VM option suggestion + ProcessBuilder pb = ProcessTools.createJavaProcessBuilder( + "-XX:+PrintGc", + "-version" + ); + OutputAnalyzer outputWithError = new OutputAnalyzer(pb.start()); + outputWithError.shouldContain("Did you mean '(+/-)PrintGC'?"); + if (outputWithError.getExitValue() == 0) { + throw new RuntimeException("Not expected to get exit value 0"); + } + + pb = ProcessTools.createJavaProcessBuilder( + "-XX:MaxiumHeapSize=500m", + "-version" + ); + outputWithError = new OutputAnalyzer(pb.start()); + outputWithError.shouldContain("Did you mean 'MaxHeapSize='?"); + if (outputWithError.getExitValue() == 0) { + throw new RuntimeException("Not expected to get exit value 0"); + } + + // The last JAVA process should run successfully for the purpose of sanity check + pb = ProcessTools.createJavaProcessBuilder( + "-XX:+PrintGC", + "-version" + ); + OutputAnalyzer outputWithNoError = new OutputAnalyzer(pb.start()); + outputWithNoError.shouldNotContain("Did you mean '(+/-)PrintGC'?"); + outputWithNoError.shouldHaveExitValue(0); + } +} + From 607de236dcf50695a183fc082eef6dc1523e2af0 Mon Sep 17 00:00:00 2001 From: Lance Andersen Date: Sat, 29 Jun 2013 06:12:28 -0400 Subject: [PATCH 087/127] 8019286: Fix javadoc typo in ResultSet.next Reviewed-by: darcy, mchung --- jdk/src/share/classes/java/sql/ResultSet.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/jdk/src/share/classes/java/sql/ResultSet.java b/jdk/src/share/classes/java/sql/ResultSet.java index 9c912416308..ad954e89d1d 100644 --- a/jdk/src/share/classes/java/sql/ResultSet.java +++ b/jdk/src/share/classes/java/sql/ResultSet.java @@ -148,7 +148,7 @@ import java.io.InputStream; public interface ResultSet extends Wrapper, AutoCloseable { /** - * Moves the cursor froward one row from its current position. + * Moves the cursor forward one row from its current position. * A ResultSet cursor is initially positioned * before the first row; the first call to the method * next makes the first row the current row; the From 60782578cb5d33194a9c9d11f266ea59bbdc4b42 Mon Sep 17 00:00:00 2001 From: Joe Darcy Date: Sun, 30 Jun 2013 16:02:11 -0700 Subject: [PATCH 088/127] 8019466: Fix doclint issues in java.util.function Reviewed-by: briangoetz --- jdk/src/share/classes/java/util/function/BinaryOperator.java | 2 ++ jdk/src/share/classes/java/util/function/Function.java | 1 + jdk/src/share/classes/java/util/function/UnaryOperator.java | 1 + 3 files changed, 4 insertions(+) diff --git a/jdk/src/share/classes/java/util/function/BinaryOperator.java b/jdk/src/share/classes/java/util/function/BinaryOperator.java index 85b3db797b1..195eba1c3c1 100644 --- a/jdk/src/share/classes/java/util/function/BinaryOperator.java +++ b/jdk/src/share/classes/java/util/function/BinaryOperator.java @@ -42,6 +42,7 @@ public interface BinaryOperator extends BiFunction { * Returns a {@link BinaryOperator} which returns the lesser of two elements * according to the specified {@code Comparator} * + * @param the type of values to be compared and returned * @param comparator a {@code Comparator} for comparing the two values * @return a {@code BinaryOperator} which returns the lesser of its operands, * according to the supplied {@code Comparator} @@ -56,6 +57,7 @@ public interface BinaryOperator extends BiFunction { * Returns a {@link BinaryOperator} which returns the greater of two elements * according to the specified {@code Comparator} * + * @param the type of values to be compared and returned * @param comparator a {@code Comparator} for comparing the two values * @return a {@code BinaryOperator} which returns the greater of its operands, * according to the supplied {@code Comparator} diff --git a/jdk/src/share/classes/java/util/function/Function.java b/jdk/src/share/classes/java/util/function/Function.java index 3cab4bf99d8..084ba4cc9c7 100644 --- a/jdk/src/share/classes/java/util/function/Function.java +++ b/jdk/src/share/classes/java/util/function/Function.java @@ -87,6 +87,7 @@ public interface Function { * Returns a {@code Function} whose {@code apply} method returns its input. * * @param the type of the input and output objects to the function + * @return a {@code Function} whose {@code apply} method returns its input */ static Function identity() { return t -> t; diff --git a/jdk/src/share/classes/java/util/function/UnaryOperator.java b/jdk/src/share/classes/java/util/function/UnaryOperator.java index 87fda16bbeb..e7794ca19e5 100644 --- a/jdk/src/share/classes/java/util/function/UnaryOperator.java +++ b/jdk/src/share/classes/java/util/function/UnaryOperator.java @@ -40,6 +40,7 @@ public interface UnaryOperator extends Function { /** * Returns a unary operator that provides its input value as the result. * + * @param the type of the input and output objects to the function * @return a unary operator that provides its input value as the result */ static UnaryOperator identity() { From 8de97d93a093243279ec227f9d4f9ff9621dee76 Mon Sep 17 00:00:00 2001 From: Joe Darcy Date: Sun, 30 Jun 2013 17:15:47 -0700 Subject: [PATCH 089/127] 8019467: Fix doclint issues in java.util.jar.Pack200 Reviewed-by: lancea, ksrini --- jdk/src/share/classes/java/util/jar/Pack200.java | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) diff --git a/jdk/src/share/classes/java/util/jar/Pack200.java b/jdk/src/share/classes/java/util/jar/Pack200.java index dbefe59305d..cf4fb98db8f 100644 --- a/jdk/src/share/classes/java/util/jar/Pack200.java +++ b/jdk/src/share/classes/java/util/jar/Pack200.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -112,7 +112,7 @@ public abstract class Pack200 { // Static methods of the Pack200 class. /** * Obtain new instance of a class that implements Packer. - * + *
          *
        • If the system property java.util.jar.Pack200.Packer * is defined, then the value is taken to be the fully-qualified name * of a concrete implementation class, which must implement Packer. @@ -122,6 +122,7 @@ public abstract class Pack200 { *

        • If an implementation has not been specified with the system * property, then the system-default implementation class is instantiated, * and the result is returned.

        • + *
        * *

        Note: The returned object is not guaranteed to operate * correctly if multiple threads use it at the same time. @@ -137,7 +138,7 @@ public abstract class Pack200 { /** * Obtain new instance of a class that implements Unpacker. - * + *

          *
        • If the system property java.util.jar.Pack200.Unpacker * is defined, then the value is taken to be the fully-qualified * name of a concrete implementation class, which must implement Unpacker. @@ -147,6 +148,7 @@ public abstract class Pack200 { *

        • If an implementation has not been specified with the * system property, then the system-default implementation class * is instantiated, and the result is returned.

        • + *
        * *

        Note: The returned object is not guaranteed to operate * correctly if multiple threads use it at the same time. @@ -350,14 +352,14 @@ public abstract class Pack200 { * directory will be passed also. *

        * Examples: - *

        
        +         * 
        {@code
                  *     Map p = packer.properties();
                  *     p.put(PASS_FILE_PFX+0, "mutants/Rogue.class");
                  *     p.put(PASS_FILE_PFX+1, "mutants/Wolverine.class");
                  *     p.put(PASS_FILE_PFX+2, "mutants/Storm.class");
                  *     # Pass all files in an entire directory hierarchy:
                  *     p.put(PASS_FILE_PFX+3, "police/");
        -         * 
        . + * }
        */ String PASS_FILE_PFX = "pack.pass.file."; @@ -378,12 +380,12 @@ public abstract class Pack200 { * This is the default value for this property. *

        * Examples: - *

        
        +         * 
        {@code
                  *     Map p = pack200.getProperties();
                  *     p.put(UNKNOWN_ATTRIBUTE, ERROR);
                  *     p.put(UNKNOWN_ATTRIBUTE, STRIP);
                  *     p.put(UNKNOWN_ATTRIBUTE, PASS);
        -         * 
        + * }
        */ String UNKNOWN_ATTRIBUTE = "pack.unknown.attribute"; From 1a0fc187f41987e3f460c27e39afb1e09d7aa229 Mon Sep 17 00:00:00 2001 From: Athijegannathan Sundararajan Date: Mon, 1 Jul 2013 12:38:01 +0530 Subject: [PATCH 090/127] 8019473: Parser issues related to functions and blocks Reviewed-by: lagergren --- .../jdk/nashorn/internal/parser/Parser.java | 8 ++- nashorn/test/script/basic/JDK-8019473.js | 62 +++++++++++++++++++ 2 files changed, 67 insertions(+), 3 deletions(-) create mode 100644 nashorn/test/script/basic/JDK-8019473.js diff --git a/nashorn/src/jdk/nashorn/internal/parser/Parser.java b/nashorn/src/jdk/nashorn/internal/parser/Parser.java index 0c2c1633591..3c609cc9be3 100644 --- a/nashorn/src/jdk/nashorn/internal/parser/Parser.java +++ b/nashorn/src/jdk/nashorn/internal/parser/Parser.java @@ -767,8 +767,6 @@ loop: case LBRACE: block(); break; - case RBRACE: - break; case VAR: variableStatement(true); break; @@ -1267,6 +1265,7 @@ loop: case RBRACE: case SEMICOLON: case EOL: + case EOF: break; default: @@ -1314,6 +1313,7 @@ loop: case RBRACE: case SEMICOLON: case EOL: + case EOF: break; default: @@ -1368,6 +1368,7 @@ loop: case RBRACE: case SEMICOLON: case EOL: + case EOF: break; default: @@ -1403,6 +1404,7 @@ loop: case RBRACE: case SEMICOLON: case EOL: + case EOF: break; default: @@ -2566,7 +2568,7 @@ loop: */ // just expression as function body - final Node expr = expression(); + final Node expr = assignmentExpression(true); assert lc.getCurrentBlock() == lc.getFunctionBody(functionNode); // create a return statement - this creates code in itself and does not need to be // wrapped into an ExecuteNode diff --git a/nashorn/test/script/basic/JDK-8019473.js b/nashorn/test/script/basic/JDK-8019473.js new file mode 100644 index 00000000000..5001f3d7311 --- /dev/null +++ b/nashorn/test/script/basic/JDK-8019473.js @@ -0,0 +1,62 @@ +/* + * Copyright (c) 2010, 2013, 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. + */ + +/** + * JDK-8019473: Parser issues related to functions and blocks + * + * @test + * @run + */ + +function checkNoError(code) { + try { + Function(code); + } catch (e) { + print("no error expected for: " + code + " , got " + e); + } +} + +// implicit newlines at EOF should be accepted +checkNoError("for(;;) continue") +checkNoError("return") +checkNoError("yield") +checkNoError("for(;;) break") + +function checkError(code) { + try { + eval(code); + print("SyntaxError expected for: " + code); + } catch (e) { + if (! (e instanceof SyntaxError)) { + fail("SyntaxError expected, got " + e); + } + } +} + +checkError("function f() { case0: }"); +checkError("function f() { if(0) }"); +checkError("function f() { if(0); else }"); +checkError("function f() { while(0) }"); + +// comma expression as closure expression +checkError("function sq(x) x, x*x"); From 1a074a8b66c98e9ff2ae56dde9ff0d2626154d20 Mon Sep 17 00:00:00 2001 From: Athijegannathan Sundararajan Date: Mon, 1 Jul 2013 14:15:07 +0530 Subject: [PATCH 091/127] 8019478: Object.prototype.toString.call(/a/.exec("a")) === "[object Array]" should be true Reviewed-by: hannesw --- .../objects/NativeRegExpExecResult.java | 5 +++ nashorn/test/script/basic/JDK-8019478.js | 33 +++++++++++++++++++ 2 files changed, 38 insertions(+) create mode 100644 nashorn/test/script/basic/JDK-8019478.js diff --git a/nashorn/src/jdk/nashorn/internal/objects/NativeRegExpExecResult.java b/nashorn/src/jdk/nashorn/internal/objects/NativeRegExpExecResult.java index 6b75e70cf16..667205528ed 100644 --- a/nashorn/src/jdk/nashorn/internal/objects/NativeRegExpExecResult.java +++ b/nashorn/src/jdk/nashorn/internal/objects/NativeRegExpExecResult.java @@ -61,6 +61,11 @@ public final class NativeRegExpExecResult extends ScriptObject { this.input = result.getInput(); } + @Override + public String getClassName() { + return "Array"; + } + /** * Length getter * @param self self reference diff --git a/nashorn/test/script/basic/JDK-8019478.js b/nashorn/test/script/basic/JDK-8019478.js new file mode 100644 index 00000000000..f5e2a645214 --- /dev/null +++ b/nashorn/test/script/basic/JDK-8019478.js @@ -0,0 +1,33 @@ +/* + * Copyright (c) 2010, 2013, 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. + */ + +/** + * JDK-8019478: Object.prototype.toString.call(/a/.exec("a")) === "[object Array]" should be true + * + * @test + * @run + */ + +if (Object.prototype.toString.call(/a/.exec("a")) !== "[object Array]") { + fail("Object.prototype.toString.call(/a/.exec('a')) !== '[object Array]'"); +} From 7addcb118b984362dd2fbd10fa8c9930a2bb70dd Mon Sep 17 00:00:00 2001 From: Daniel Fuchs Date: Mon, 1 Jul 2013 11:13:56 +0200 Subject: [PATCH 092/127] 8014045: test/java/lang/management/PlatformLoggingMXBean/LoggingMXBeanTest.java failing intermittently This test was failing because it didn't take into account the fact that Loggers could be garbage collected. Reviewed-by: mchung --- .../LoggingMXBeanTest.java | 36 +++++++++++++------ 1 file changed, 25 insertions(+), 11 deletions(-) diff --git a/jdk/test/java/lang/management/PlatformLoggingMXBean/LoggingMXBeanTest.java b/jdk/test/java/lang/management/PlatformLoggingMXBean/LoggingMXBeanTest.java index 26b3b661531..b88710c81a6 100644 --- a/jdk/test/java/lang/management/PlatformLoggingMXBean/LoggingMXBeanTest.java +++ b/jdk/test/java/lang/management/PlatformLoggingMXBean/LoggingMXBeanTest.java @@ -36,12 +36,14 @@ import javax.management.MBeanServer; import java.util.logging.*; import java.util.ArrayList; import java.util.List; +import java.util.Map; +import java.util.HashMap; public class LoggingMXBeanTest { - static String LOGGER_NAME_1 = "com.sun.management.Logger"; - static String LOGGER_NAME_2 = "com.sun.management.Logger.Logger2"; - static String UNKNOWN_LOGGER_NAME = "com.sun.management.Unknown"; + static final String LOGGER_NAME_1 = "com.sun.management.Logger"; + static final String LOGGER_NAME_2 = "com.sun.management.Logger.Logger2"; + static final String UNKNOWN_LOGGER_NAME = "com.sun.management.Unknown"; // These instance variables prevent premature logger garbage collection // See getLogger() weak reference warnings. @@ -213,23 +215,35 @@ public class LoggingMXBeanTest PlatformLoggingMXBean mxbean2) { // verify logger names List loggers1 = mxbean1.getLoggerNames(); + System.out.println("Loggers: " + loggers1); + + // Retrieve the named loggers to prevent them from being + // spontaneously gc'ed. + Map loggersMap = new HashMap<>(); + for (String n : loggers1) { + loggersMap.put(n, Logger.getLogger(n)); + } + List loggers2 = mxbean2.getLoggerNames(); + // loggers1 and loggers2 should be identical - no new logger should + // have been created in between (at least no new logger name) + // if (loggers1.size() != loggers2.size()) throw new RuntimeException("LoggerNames: unmatched number of entries"); - List loggers3 = new ArrayList<>(loggers1); - loggers3.removeAll(loggers2); - if (loggers3.size() != 0) + if (!loggers2.containsAll(loggersMap.keySet())) throw new RuntimeException("LoggerNames: unmatched loggers"); + // verify logger's level and parent for (String logger : loggers1) { - if (!mxbean1.getLoggerLevel(logger) - .equals(mxbean2.getLoggerLevel(logger))) + String level1 = mxbean1.getLoggerLevel(logger); + String level2 = mxbean2.getLoggerLevel(logger); + if (!java.util.Objects.equals(level1, level2)) { throw new RuntimeException( - "LoggerLevel: unmatched level for " + logger - + ", " + mxbean1.getLoggerLevel(logger) - + ", " + mxbean2.getLoggerLevel(logger)); + "LoggerLevel: unmatched level for " + logger + + ", " + level1 + ", " + level2); + } if (!mxbean1.getParentLoggerName(logger) .equals(mxbean2.getParentLoggerName(logger))) From 135ccaceef2558ab4d4c369adced5ef100057a02 Mon Sep 17 00:00:00 2001 From: Athijegannathan Sundararajan Date: Mon, 1 Jul 2013 17:21:09 +0530 Subject: [PATCH 093/127] 8019482: Number("0x0.0p0") should evaluate to NaN Reviewed-by: lagergren --- .../nashorn/internal/objects/NativeError.java | 5 +-- .../internal/runtime/ECMAException.java | 2 +- .../jdk/nashorn/internal/runtime/JSType.java | 2 +- nashorn/test/script/basic/JDK-8019482.js | 41 +++++++++++++++++++ 4 files changed, 44 insertions(+), 6 deletions(-) create mode 100644 nashorn/test/script/basic/JDK-8019482.js diff --git a/nashorn/src/jdk/nashorn/internal/objects/NativeError.java b/nashorn/src/jdk/nashorn/internal/objects/NativeError.java index 25a3f3c74a6..07f5d65aa7b 100644 --- a/nashorn/src/jdk/nashorn/internal/objects/NativeError.java +++ b/nashorn/src/jdk/nashorn/internal/objects/NativeError.java @@ -30,10 +30,7 @@ import static jdk.nashorn.internal.lookup.Lookup.MH; import java.lang.invoke.MethodHandle; import java.lang.invoke.MethodHandles; -import java.util.ArrayList; -import java.util.List; import jdk.nashorn.api.scripting.NashornException; -import jdk.nashorn.internal.codegen.CompilerConstants; import jdk.nashorn.internal.lookup.MethodHandleFactory; import jdk.nashorn.internal.objects.annotations.Attribute; import jdk.nashorn.internal.objects.annotations.Constructor; @@ -41,7 +38,6 @@ import jdk.nashorn.internal.objects.annotations.Function; import jdk.nashorn.internal.objects.annotations.Property; import jdk.nashorn.internal.objects.annotations.ScriptClass; import jdk.nashorn.internal.objects.annotations.Where; -import jdk.nashorn.internal.runtime.ECMAErrors; import jdk.nashorn.internal.runtime.ECMAException; import jdk.nashorn.internal.runtime.JSType; import jdk.nashorn.internal.runtime.PropertyMap; @@ -123,6 +119,7 @@ public final class NativeError extends ScriptObject { * Nashorn extension: Error.captureStackTrace. Capture stack trace at the point of call into the Error object provided. * * @param self self reference + * @return undefined */ @Function(attributes = Attribute.NOT_ENUMERABLE, where = Where.CONSTRUCTOR) public static Object captureStackTrace(final Object self, final Object errorObj) { diff --git a/nashorn/src/jdk/nashorn/internal/runtime/ECMAException.java b/nashorn/src/jdk/nashorn/internal/runtime/ECMAException.java index bb4e49a0c1b..a32e721cc46 100644 --- a/nashorn/src/jdk/nashorn/internal/runtime/ECMAException.java +++ b/nashorn/src/jdk/nashorn/internal/runtime/ECMAException.java @@ -51,7 +51,7 @@ public final class ECMAException extends NashornException { /** Field handle to the{@link ECMAException#thrown} field, so that it can be accessed from generated code */ public static final FieldAccess THROWN = virtualField(ECMAException.class, "thrown", Object.class); - public static final String EXCEPTION_PROPERTY = "nashornException"; + private static final String EXCEPTION_PROPERTY = "nashornException"; /** Object thrown. */ public final Object thrown; diff --git a/nashorn/src/jdk/nashorn/internal/runtime/JSType.java b/nashorn/src/jdk/nashorn/internal/runtime/JSType.java index 8f1f1e9e616..9507f0d3205 100644 --- a/nashorn/src/jdk/nashorn/internal/runtime/JSType.java +++ b/nashorn/src/jdk/nashorn/internal/runtime/JSType.java @@ -911,7 +911,7 @@ public enum JSType { for (int i = start; i < length ; i++) { if (digit(chars[i], radix) == -1) { - break; + return Double.NaN; } pos++; } diff --git a/nashorn/test/script/basic/JDK-8019482.js b/nashorn/test/script/basic/JDK-8019482.js new file mode 100644 index 00000000000..09f91e42ea9 --- /dev/null +++ b/nashorn/test/script/basic/JDK-8019482.js @@ -0,0 +1,41 @@ +/* + * Copyright (c) 2010, 2013, 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. + */ + +/** + * JDK-8019482: Number("0x0.0p0") should evaluate to NaN + * + * @test + * @run + */ + +function checkHexLiteral(str) { + if (! isNaN(Number(str))) { + fail("Number(" + str + ") is not NaN"); + } +} + +checkHexLiteral("0x0.0"); +checkHexLiteral("0x0.0p"); +checkHexLiteral("0x12tu"); +checkHexLiteral("0x12.2e22"); +checkHexLiteral("0xtu"); From 53ecefacacdba409a907a6219699f397311a4d35 Mon Sep 17 00:00:00 2001 From: Vinnie Ryan Date: Mon, 1 Jul 2013 14:39:47 +0100 Subject: [PATCH 094/127] 8019259: Failover to CRL checking does not happen if wrong OCSP responder URL is set Reviewed-by: xuelei --- .../provider/certpath/RevocationChecker.java | 8 ++++-- .../CertPathValidator/OCSP/FailoverToCRL.java | 26 ++++++++++++++++--- 2 files changed, 29 insertions(+), 5 deletions(-) diff --git a/jdk/src/share/classes/sun/security/provider/certpath/RevocationChecker.java b/jdk/src/share/classes/sun/security/provider/certpath/RevocationChecker.java index 98d8a9d2272..05b517892fe 100644 --- a/jdk/src/share/classes/sun/security/provider/certpath/RevocationChecker.java +++ b/jdk/src/share/classes/sun/security/provider/certpath/RevocationChecker.java @@ -675,8 +675,12 @@ class RevocationChecker extends PKIXRevocationChecker { responderURI, respCert, params.date(), ocspExtensions); } - } catch (IOException e) { - throw new CertPathValidatorException(e); + } catch (Exception e) { + if (e instanceof CertPathValidatorException) { + throw (CertPathValidatorException) e; + } else { + throw new CertPathValidatorException(e); + } } RevocationStatus rs = diff --git a/jdk/test/java/security/cert/CertPathValidator/OCSP/FailoverToCRL.java b/jdk/test/java/security/cert/CertPathValidator/OCSP/FailoverToCRL.java index df69edc7f22..25eaab56eea 100644 --- a/jdk/test/java/security/cert/CertPathValidator/OCSP/FailoverToCRL.java +++ b/jdk/test/java/security/cert/CertPathValidator/OCSP/FailoverToCRL.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2009, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2009, 2013, 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 @@ -23,7 +23,7 @@ /** * @test - * @bug 6383095 + * @bug 6383095 8019259 * @summary CRL revoked certificate failures masked by OCSP failures * * Note that the certificate validity is from Mar 16 14:55:35 2009 GMT to @@ -254,12 +254,32 @@ public class FailoverToCRL { CertPathValidator validator = CertPathValidator.getInstance("PKIX"); try { + System.out.println("Validating cert via OCSP: no responder URL"); validator.validate(path, params); } catch (CertPathValidatorException cpve) { if (cpve.getReason() != BasicReason.REVOKED) { throw new Exception( - "unexpect exception, should be a REVOKED CPVE", cpve); + "unexpected exception, should be a REVOKED CPVE", cpve); } + System.out.println(" successful failover to using CRLs"); + } + + java.security.cert.PKIXRevocationChecker revocationChecker = + (java.security.cert.PKIXRevocationChecker) + validator.getRevocationChecker(); + revocationChecker.setOCSPResponder( + new java.net.URI("bad_ocsp_responder_url")); + params.addCertPathChecker(revocationChecker); + + try { + System.out.println("Validating cert via OCSP: bad responder URL"); + validator.validate(path, params); + } catch (CertPathValidatorException cpve) { + if (cpve.getReason() != BasicReason.REVOKED) { + throw new Exception( + "unexpected exception, should be a REVOKED CPVE", cpve); + } + System.out.println(" successful failover to using CRLs"); } } } From c6b05141128414a3909efaf26c6d7af51cd36840 Mon Sep 17 00:00:00 2001 From: Athijegannathan Sundararajan Date: Mon, 1 Jul 2013 19:52:07 +0530 Subject: [PATCH 095/127] 8019488: switch on literals result in NoSuchMethodError or VerifyError Reviewed-by: hannesw --- .../internal/codegen/CodeGenerator.java | 3 +- .../internal/runtime/ScriptRuntime.java | 11 +++ nashorn/test/script/basic/JDK-8019488.js | 68 +++++++++++++++++++ 3 files changed, 81 insertions(+), 1 deletion(-) create mode 100644 nashorn/test/script/basic/JDK-8019488.js diff --git a/nashorn/src/jdk/nashorn/internal/codegen/CodeGenerator.java b/nashorn/src/jdk/nashorn/internal/codegen/CodeGenerator.java index c4b0af9938b..6205888f1ff 100644 --- a/nashorn/src/jdk/nashorn/internal/codegen/CodeGenerator.java +++ b/nashorn/src/jdk/nashorn/internal/codegen/CodeGenerator.java @@ -1845,7 +1845,8 @@ final class CodeGenerator extends NodeOperatorVisitor Date: Mon, 1 Jul 2013 23:36:40 +0530 Subject: [PATCH 096/127] 8019508: Comma handling in object literal parsing is wrong Reviewed-by: hannesw --- .../jdk/nashorn/internal/parser/Parser.java | 5 +- .../runtime/resources/Messages.properties | 1 + nashorn/test/script/basic/JDK-8019508.js | 56 +++++++++++++++++++ .../test/script/basic/JDK-8019508.js.EXPECTED | 12 ++++ 4 files changed, 73 insertions(+), 1 deletion(-) create mode 100644 nashorn/test/script/basic/JDK-8019508.js create mode 100644 nashorn/test/script/basic/JDK-8019508.js.EXPECTED diff --git a/nashorn/src/jdk/nashorn/internal/parser/Parser.java b/nashorn/src/jdk/nashorn/internal/parser/Parser.java index 3c609cc9be3..bc3b7598896 100644 --- a/nashorn/src/jdk/nashorn/internal/parser/Parser.java +++ b/nashorn/src/jdk/nashorn/internal/parser/Parser.java @@ -1930,7 +1930,7 @@ loop: // Object context. // Prepare to accumulate elements. - // final List elements = new ArrayList<>(); + // final List elements = new ArrayList<>(); final Map map = new LinkedHashMap<>(); // Create a block for the object literal. @@ -1943,6 +1943,9 @@ loop: break loop; case COMMARIGHT: + if (commaSeen) { + throw error(AbstractParser.message("expected.property.id", type.getNameOrType())); + } next(); commaSeen = true; break; diff --git a/nashorn/src/jdk/nashorn/internal/runtime/resources/Messages.properties b/nashorn/src/jdk/nashorn/internal/runtime/resources/Messages.properties index f058fa3354f..a9c6c589093 100644 --- a/nashorn/src/jdk/nashorn/internal/runtime/resources/Messages.properties +++ b/nashorn/src/jdk/nashorn/internal/runtime/resources/Messages.properties @@ -42,6 +42,7 @@ parser.error.expected.literal=Expected a literal but found {0} parser.error.expected.operand=Expected an operand but found {0} parser.error.expected.stmt=Expected statement but found {0} parser.error.expected.comma=Expected comma but found {0} +parser.error.expected.property.id=Expected property id but found {0} parser.error.expected=Expected {0} but found {1} parser.error.invalid.return=Invalid return statement parser.error.no.func.decl.here=Function declarations can only occur at program or function body level. You should use a function expression here instead. diff --git a/nashorn/test/script/basic/JDK-8019508.js b/nashorn/test/script/basic/JDK-8019508.js new file mode 100644 index 00000000000..d23035c638a --- /dev/null +++ b/nashorn/test/script/basic/JDK-8019508.js @@ -0,0 +1,56 @@ +/* + * Copyright (c) 2010, 2013, 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. + */ + +/** + * JDK-8019508: Comma handling in object literal parsing is wrong + * + * @test + * @run + */ + +function checkObjLiteral(str) { + try { + eval(str); + fail("SyntaxError expected for: " + str); + } catch (e) { + if (! (e instanceof SyntaxError)) { + fail("expected SyntaxError, got " + e); + } + print(e.message.replace(/\\/g, '/')); + } +} + +// only comma +checkObjLiteral("({,})"); + +// starting with comma +checkObjLiteral("({, a:2 })"); + +// consecutive commas +checkObjLiteral("({a:3,,})"); + +// missing comma +checkObjLiteral("({a:3 b:2}"); + +// single trailing comma is okay! +var obj = { a: 3, }; diff --git a/nashorn/test/script/basic/JDK-8019508.js.EXPECTED b/nashorn/test/script/basic/JDK-8019508.js.EXPECTED new file mode 100644 index 00000000000..d5f81409803 --- /dev/null +++ b/nashorn/test/script/basic/JDK-8019508.js.EXPECTED @@ -0,0 +1,12 @@ +test/script/basic/JDK-8019508.js#33:1:2 Expected property id but found , +({,}) + ^ +test/script/basic/JDK-8019508.js#33:1:2 Expected property id but found , +({, a:2 }) + ^ +test/script/basic/JDK-8019508.js#33:1:6 Expected property id but found , +({a:3,,}) + ^ +test/script/basic/JDK-8019508.js#33:1:6 Expected comma but found ident +({a:3 b:2} + ^ From 329abc40280c43e5f8d99e00c02a794a67b578ec Mon Sep 17 00:00:00 2001 From: Peter Levart Date: Mon, 1 Jul 2013 11:30:14 -0700 Subject: [PATCH 097/127] 8017540: Improve multi-threaded contention behavior of radix conversion cache Replace array of ArrayList of BigIntegers with a volatile two-dimensional BigInteger array eliminate the synchronization of getRadixConversionCache() Co-authored-by: Dmitry Nadezhin Co-authored-by: Aleksey Shipilev Reviewed-by: plevart, shade, bpb, alanb --- .../share/classes/java/math/BigInteger.java | 39 ++++++++++--------- 1 file changed, 20 insertions(+), 19 deletions(-) diff --git a/jdk/src/share/classes/java/math/BigInteger.java b/jdk/src/share/classes/java/math/BigInteger.java index 48354a9559c..6569fcb1796 100644 --- a/jdk/src/share/classes/java/math/BigInteger.java +++ b/jdk/src/share/classes/java/math/BigInteger.java @@ -1042,7 +1042,7 @@ public class BigInteger extends Number implements Comparable { * recalculate powers of radix^(2^n) more than once. This speeds * Schoenhage recursive base conversion significantly. */ - private static ArrayList[] powerCache; + private static volatile BigInteger[][] powerCache; /** The cache of logarithms of radices for base conversion. */ private static final double[] logCache; @@ -1063,14 +1063,12 @@ public class BigInteger extends Number implements Comparable { * with just the very first value. Additional values will be created * on demand. */ - powerCache = (ArrayList[]) - new ArrayList[Character.MAX_RADIX+1]; + powerCache = new BigInteger[Character.MAX_RADIX+1][]; logCache = new double[Character.MAX_RADIX+1]; for (int i=Character.MIN_RADIX; i<=Character.MAX_RADIX; i++) { - powerCache[i] = new ArrayList(1); - powerCache[i].add(BigInteger.valueOf(i)); + powerCache[i] = new BigInteger[] { BigInteger.valueOf(i) }; logCache[i] = Math.log(i); } } @@ -3454,22 +3452,25 @@ public class BigInteger extends Number implements Comparable { * This could be changed to a more complicated caching method using * Future. */ - private static synchronized BigInteger getRadixConversionCache(int radix, - int exponent) { - BigInteger retVal = null; - ArrayList cacheLine = powerCache[radix]; - int oldSize = cacheLine.size(); - if (exponent >= oldSize) { - cacheLine.ensureCapacity(exponent+1); - for (int i=oldSize; i<=exponent; i++) { - retVal = cacheLine.get(i-1).square(); - cacheLine.add(i, retVal); - } + private static BigInteger getRadixConversionCache(int radix, int exponent) { + BigInteger[] cacheLine = powerCache[radix]; // volatile read + if (exponent < cacheLine.length) { + return cacheLine[exponent]; } - else - retVal = cacheLine.get(exponent); - return retVal; + int oldLength = cacheLine.length; + cacheLine = Arrays.copyOf(cacheLine, exponent + 1); + for (int i = oldLength; i <= exponent; i++) { + cacheLine[i] = cacheLine[i - 1].pow(2); + } + + BigInteger[][] pc = powerCache; // volatile read again + if (exponent >= pc[radix].length) { + pc = pc.clone(); + pc[radix] = cacheLine; + powerCache = pc; // volatile write, publish + } + return cacheLine[exponent]; } /* zero[i] is a string of i consecutive zeros. */ From 68c516f654b888ccdec31b126b4c13caab7ff387 Mon Sep 17 00:00:00 2001 From: Filipp Zhinkin Date: Mon, 1 Jul 2013 12:22:34 -0700 Subject: [PATCH 098/127] 8006629: NEED_TEST: need test for JDK-8001071 Added regression test Reviewed-by: kvn, coleenp --- hotspot/test/runtime/8001071/Test8001071.java | 45 +++++++++++++ hotspot/test/runtime/8001071/Test8001071.sh | 63 +++++++++++++++++++ 2 files changed, 108 insertions(+) create mode 100644 hotspot/test/runtime/8001071/Test8001071.java create mode 100644 hotspot/test/runtime/8001071/Test8001071.sh diff --git a/hotspot/test/runtime/8001071/Test8001071.java b/hotspot/test/runtime/8001071/Test8001071.java new file mode 100644 index 00000000000..df03e197de8 --- /dev/null +++ b/hotspot/test/runtime/8001071/Test8001071.java @@ -0,0 +1,45 @@ +/* + * Copyright (c) 2013, 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. + */ + +import sun.misc.Unsafe; +import java.lang.reflect.Field; + +@SuppressWarnings("sunapi") +public class Test8001071 { + public static Unsafe unsafe; + + static { + try { + Field f = Unsafe.class.getDeclaredField("theUnsafe"); + f.setAccessible(true); + unsafe = (Unsafe) f.get(null); + } catch ( Exception e ) { + e.printStackTrace(); + } + } + + public static void main(String args[]) { + unsafe.getObject(new Test8001071(), Short.MAX_VALUE); + } + +} diff --git a/hotspot/test/runtime/8001071/Test8001071.sh b/hotspot/test/runtime/8001071/Test8001071.sh new file mode 100644 index 00000000000..79ba2fe503d --- /dev/null +++ b/hotspot/test/runtime/8001071/Test8001071.sh @@ -0,0 +1,63 @@ +#!/bin/sh + +# Copyright (c) 2013, 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 +## @bug 8001071 +## @summary Add simple range check into VM implemenation of Unsafe access methods +## @compile Test8001071.java +## @run shell Test8001071.sh +## @author filipp.zhinkin@oracle.com + +VERSION=`${TESTJAVA}/bin/java ${TESTVMOPTS} -version 2>&1` + +if [ -n "`echo $VERSION | grep debug`" -o -n "`echo $VERSION | grep jvmg`" ]; then + echo "Build type check passed" + echo "Continue testing" +else + echo "Fastdebug build is required for this test" + exit 0 +fi + +${TESTJAVA}/bin/java -cp ${TESTCLASSES} ${TESTVMOPTS} Test8001071 2>&1 + +HS_ERR_FILE=hs_err_pid*.log + +if [ ! -f $HS_ERR_FILE ] +then + echo "hs_err_pid log file was not found" + echo "Test failed" + exit 1 +fi + +grep "assert(byte_offset < p_size) failed: Unsafe access: offset.*> object's size.*" $HS_ERR_FILE + +if [ "0" = "$?" ]; +then + echo "Range check assertion failed as expected" + echo "Test passed" + exit 0 +else + echo "Range check assertion was not failed" + echo "Test failed" + exit 1 +fi From 71a1e79eeb4dac0db8f3dbe69706e66e932d4142 Mon Sep 17 00:00:00 2001 From: Phil Race Date: Mon, 1 Jul 2013 12:39:26 -0700 Subject: [PATCH 099/127] 8015144: Performance regression in ICU OpenType Layout library Reviewed-by: srl, jgodinez --- jdk/make/sun/font/Makefile | 2 +- jdk/makefiles/CompileNativeLibraries.gmk | 3 +- .../native/sun/font/layout/GlyphIterator.cpp | 68 ++++++++++++------- .../native/sun/font/layout/GlyphIterator.h | 10 ++- .../native/sun/font/layout/LETableReference.h | 18 ++--- .../sun/font/layout/OpenTypeUtilities.cpp | 11 +-- 6 files changed, 70 insertions(+), 42 deletions(-) diff --git a/jdk/make/sun/font/Makefile b/jdk/make/sun/font/Makefile index 1cdd11934cc..49497661ee4 100644 --- a/jdk/make/sun/font/Makefile +++ b/jdk/make/sun/font/Makefile @@ -36,7 +36,7 @@ PRODUCT = sun CPLUSPLUSLIBRARY=true # Use higher optimization level -OPTIMIZATION_LEVEL = HIGHER +OPTIMIZATION_LEVEL = HIGHEST include $(BUILDDIR)/common/Defs.gmk diff --git a/jdk/makefiles/CompileNativeLibraries.gmk b/jdk/makefiles/CompileNativeLibraries.gmk index 4fcb6e84695..0dd803cb4d8 100644 --- a/jdk/makefiles/CompileNativeLibraries.gmk +++ b/jdk/makefiles/CompileNativeLibraries.gmk @@ -1327,12 +1327,11 @@ else BUILD_LIBFONTMANAGER_FONTLIB:=$(FREETYPE2_LIBS) endif -LIBFONTMANAGER_OPTIMIZATION:=HIGH +LIBFONTMANAGER_OPTIMIZATION:=HIGHEST ifeq ($(OPENJDK_TARGET_OS),windows) LIBFONTMANAGER_EXCLUDE_FILES += X11FontScaler.c \ X11TextRenderer.c - LIBFONTMANAGER_OPTIMIZATION:=LOW else LIBFONTMANAGER_EXCLUDE_FILES += fontpath.c \ lcdglyph.c diff --git a/jdk/src/share/native/sun/font/layout/GlyphIterator.cpp b/jdk/src/share/native/sun/font/layout/GlyphIterator.cpp index d0cd46732ed..3ccf66fdc60 100644 --- a/jdk/src/share/native/sun/font/layout/GlyphIterator.cpp +++ b/jdk/src/share/native/sun/font/layout/GlyphIterator.cpp @@ -66,6 +66,7 @@ GlyphIterator::GlyphIterator(LEGlyphStorage &theGlyphStorage, GlyphPositionAdjus nextLimit = -1; prevLimit = glyphCount; } + filterResetCache(); } GlyphIterator::GlyphIterator(GlyphIterator &that) @@ -84,6 +85,7 @@ GlyphIterator::GlyphIterator(GlyphIterator &that) glyphGroup = that.glyphGroup; glyphClassDefinitionTable = that.glyphClassDefinitionTable; markAttachClassDefinitionTable = that.markAttachClassDefinitionTable; + filterResetCache(); } GlyphIterator::GlyphIterator(GlyphIterator &that, FeatureMask newFeatureMask) @@ -102,6 +104,7 @@ GlyphIterator::GlyphIterator(GlyphIterator &that, FeatureMask newFeatureMask) glyphGroup = 0; glyphClassDefinitionTable = that.glyphClassDefinitionTable; markAttachClassDefinitionTable = that.markAttachClassDefinitionTable; + filterResetCache(); } GlyphIterator::GlyphIterator(GlyphIterator &that, le_uint16 newLookupFlags) @@ -120,6 +123,7 @@ GlyphIterator::GlyphIterator(GlyphIterator &that, le_uint16 newLookupFlags) glyphGroup = that.glyphGroup; glyphClassDefinitionTable = that.glyphClassDefinitionTable; markAttachClassDefinitionTable = that.markAttachClassDefinitionTable; + filterResetCache(); } GlyphIterator::~GlyphIterator() @@ -133,6 +137,7 @@ void GlyphIterator::reset(le_uint16 newLookupFlags, FeatureMask newFeatureMask) featureMask = newFeatureMask; glyphGroup = 0; lookupFlags = newLookupFlags; + filterResetCache(); } LEGlyphID *GlyphIterator::insertGlyphs(le_int32 count, LEErrorCode& success) @@ -381,53 +386,68 @@ void GlyphIterator::setCursiveGlyph() glyphPositionAdjustments->setCursiveGlyph(position, baselineIsLogicalEnd()); } -le_bool GlyphIterator::filterGlyph(le_uint32 index) const -{ - LEErrorCode success = LE_NO_ERROR; - LEGlyphID glyphID = glyphStorage[index]; - le_int32 glyphClass = gcdNoGlyphClass; - - if (LE_GET_GLYPH(glyphID) >= 0xFFFE) { - return TRUE; +void GlyphIterator::filterResetCache(void) { + filterCacheValid = FALSE; } +le_bool GlyphIterator::filterGlyph(le_uint32 index) +{ + LEGlyphID glyphID = glyphStorage[index]; + + if (!filterCacheValid || filterCache.id != glyphID) { + filterCache.id = glyphID; + + le_bool &filterResult = filterCache.result; // NB: Making this a reference to accept the updated value, in case + // we want more fancy cacheing in the future. + if (LE_GET_GLYPH(glyphID) >= 0xFFFE) { + filterResult = TRUE; + } else { + LEErrorCode success = LE_NO_ERROR; + le_int32 glyphClass = gcdNoGlyphClass; if (glyphClassDefinitionTable.isValid()) { glyphClass = glyphClassDefinitionTable->getGlyphClass(glyphClassDefinitionTable, glyphID, success); } - - switch (glyphClass) - { + switch (glyphClass) { case gcdNoGlyphClass: - return FALSE; + filterResult = FALSE; + break; case gcdSimpleGlyph: - return (lookupFlags & lfIgnoreBaseGlyphs) != 0; + filterResult = (lookupFlags & lfIgnoreBaseGlyphs) != 0; + break; case gcdLigatureGlyph: - return (lookupFlags & lfIgnoreLigatures) != 0; + filterResult = (lookupFlags & lfIgnoreLigatures) != 0; + break; case gcdMarkGlyph: - { if ((lookupFlags & lfIgnoreMarks) != 0) { - return TRUE; - } - + filterResult = TRUE; + } else { le_uint16 markAttachType = (lookupFlags & lfMarkAttachTypeMask) >> lfMarkAttachTypeShift; if ((markAttachType != 0) && (markAttachClassDefinitionTable.isValid())) { - return markAttachClassDefinitionTable - -> getGlyphClass(markAttachClassDefinitionTable, glyphID, success) != markAttachType; + filterResult = (markAttachClassDefinitionTable + -> getGlyphClass(markAttachClassDefinitionTable, glyphID, success) != markAttachType); + } else { + filterResult = FALSE; } - - return FALSE; } + break; case gcdComponentGlyph: - return (lookupFlags & lfIgnoreBaseGlyphs) != 0; + filterResult = ((lookupFlags & lfIgnoreBaseGlyphs) != 0); + break; default: - return FALSE; + filterResult = FALSE; + break; } + } + filterCacheValid = TRUE; + } + + return filterCache.result; } le_bool GlyphIterator::hasFeatureTag(le_bool matchGroup) const diff --git a/jdk/src/share/native/sun/font/layout/GlyphIterator.h b/jdk/src/share/native/sun/font/layout/GlyphIterator.h index d8db62a1298..666b94dbcf3 100644 --- a/jdk/src/share/native/sun/font/layout/GlyphIterator.h +++ b/jdk/src/share/native/sun/font/layout/GlyphIterator.h @@ -98,7 +98,7 @@ public: le_int32 applyInsertions(); private: - le_bool filterGlyph(le_uint32 index) const; + le_bool filterGlyph(le_uint32 index); le_bool hasFeatureTag(le_bool matchGroup) const; le_bool nextInternal(le_uint32 delta = 1); le_bool prevInternal(le_uint32 delta = 1); @@ -121,6 +121,14 @@ private: LEReferenceTo markAttachClassDefinitionTable; GlyphIterator &operator=(const GlyphIterator &other); // forbid copying of this class + + struct { + LEGlyphID id; + le_bool result; + } filterCache; + le_bool filterCacheValid; + + void filterResetCache(void); }; U_NAMESPACE_END diff --git a/jdk/src/share/native/sun/font/layout/LETableReference.h b/jdk/src/share/native/sun/font/layout/LETableReference.h index dab52b664a8..dbee61fba7f 100644 --- a/jdk/src/share/native/sun/font/layout/LETableReference.h +++ b/jdk/src/share/native/sun/font/layout/LETableReference.h @@ -376,7 +376,7 @@ public: * @param success error status * @param atPtr location of reference - if NULL, will be at offset zero (i.e. downcast of parent). Otherwise must be a pointer within parent's bounds. */ - LEReferenceTo(const LETableReference &parent, LEErrorCode &success, const void* atPtr) + inline LEReferenceTo(const LETableReference &parent, LEErrorCode &success, const void* atPtr) : LETableReference(parent, parent.ptrToOffset(atPtr, success), LE_UINTPTR_MAX, success) { verifyLength(0, LETableVarSizer::getSize(), success); if(LE_FAILURE(success)) clear(); @@ -384,31 +384,31 @@ public: /** * ptr plus offset */ - LEReferenceTo(const LETableReference &parent, LEErrorCode &success, const void* atPtr, size_t offset) + inline LEReferenceTo(const LETableReference &parent, LEErrorCode &success, const void* atPtr, size_t offset) : LETableReference(parent, parent.ptrToOffset(atPtr, success)+offset, LE_UINTPTR_MAX, success) { verifyLength(0, LETableVarSizer::getSize(), success); if(LE_FAILURE(success)) clear(); } - LEReferenceTo(const LETableReference &parent, LEErrorCode &success, size_t offset) + inline LEReferenceTo(const LETableReference &parent, LEErrorCode &success, size_t offset) : LETableReference(parent, offset, LE_UINTPTR_MAX, success) { verifyLength(0, LETableVarSizer::getSize(), success); if(LE_FAILURE(success)) clear(); } - LEReferenceTo(const LETableReference &parent, LEErrorCode &success) + inline LEReferenceTo(const LETableReference &parent, LEErrorCode &success) : LETableReference(parent, 0, LE_UINTPTR_MAX, success) { verifyLength(0, LETableVarSizer::getSize(), success); if(LE_FAILURE(success)) clear(); } - LEReferenceTo(const LEFontInstance *font, LETag tableTag, LEErrorCode &success) + inline LEReferenceTo(const LEFontInstance *font, LETag tableTag, LEErrorCode &success) : LETableReference(font, tableTag, success) { verifyLength(0, LETableVarSizer::getSize(), success); if(LE_FAILURE(success)) clear(); } - LEReferenceTo(const le_uint8 *data, size_t length = LE_UINTPTR_MAX) : LETableReference(data, length) {} - LEReferenceTo(const T *data, size_t length = LE_UINTPTR_MAX) : LETableReference((const le_uint8*)data, length) {} - LEReferenceTo() : LETableReference(NULL) {} + inline LEReferenceTo(const le_uint8 *data, size_t length = LE_UINTPTR_MAX) : LETableReference(data, length) {} + inline LEReferenceTo(const T *data, size_t length = LE_UINTPTR_MAX) : LETableReference((const le_uint8*)data, length) {} + inline LEReferenceTo() : LETableReference(NULL) {} - LEReferenceTo& operator=(const T* other) { + inline LEReferenceTo& operator=(const T* other) { setRaw(other); return *this; } diff --git a/jdk/src/share/native/sun/font/layout/OpenTypeUtilities.cpp b/jdk/src/share/native/sun/font/layout/OpenTypeUtilities.cpp index f234e9484e2..4d810df69f8 100644 --- a/jdk/src/share/native/sun/font/layout/OpenTypeUtilities.cpp +++ b/jdk/src/share/native/sun/font/layout/OpenTypeUtilities.cpp @@ -79,6 +79,7 @@ le_int8 OpenTypeUtilities::highBit(le_int32 value) Offset OpenTypeUtilities::getTagOffset(LETag tag, const LEReferenceToArrayOf &records, LEErrorCode &success) { + const TagAndOffsetRecord *r0 = (const TagAndOffsetRecord*)records.getAlias(); if(LE_FAILURE(success)) return 0; le_uint32 recordCount = records.getCount(); @@ -89,17 +90,17 @@ Offset OpenTypeUtilities::getTagOffset(LETag tag, const LEReferenceToArrayOftag; + const ATag &aTag = (r0+extra)->tag; if (SWAPT(aTag) <= tag) { index = extra; } } - while (probe > (1 << 0) && LE_SUCCESS(success)) { + while (probe > (1 << 0)) { probe >>= 1; { - const ATag &aTag = records.getAlias(index+probe,success)->tag; + const ATag &aTag = (r0+index+probe)->tag; if (SWAPT(aTag) <= tag) { index += probe; } @@ -107,9 +108,9 @@ Offset OpenTypeUtilities::getTagOffset(LETag tag, const LEReferenceToArrayOftag; + const ATag &aTag = (r0+index)->tag; if (SWAPT(aTag) == tag) { - return SWAPW(records.getAlias(index,success)->offset); + return SWAPW((r0+index)->offset); } } From 04e9fa3289186eee8a9b6f10644b7c3e8025d3f5 Mon Sep 17 00:00:00 2001 From: Joe Darcy Date: Mon, 1 Jul 2013 13:29:32 -0700 Subject: [PATCH 100/127] 8019527: Fix doclint issues in java.lang.instrument Reviewed-by: lancea, alanb --- .../java/lang/instrument/Instrumentation.java | 24 ++++++++++--------- 1 file changed, 13 insertions(+), 11 deletions(-) diff --git a/jdk/src/share/classes/java/lang/instrument/Instrumentation.java b/jdk/src/share/classes/java/lang/instrument/Instrumentation.java index 1844837fd3b..4cdb2de9c9a 100644 --- a/jdk/src/share/classes/java/lang/instrument/Instrumentation.java +++ b/jdk/src/share/classes/java/lang/instrument/Instrumentation.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -363,6 +363,8 @@ public interface Instrumentation { * Primitive classes (for example, java.lang.Integer.TYPE) * and array classes are never modifiable. * + * @param theClass the class to check for being modifiable + * @return whether or not the argument class is modifiable * @throws java.lang.NullPointerException if the specified class is null. * * @see #retransformClasses @@ -549,14 +551,14 @@ public interface Instrumentation { * {@link java.lang.instrument.ClassFileTransformer ClassFileTransformer}, * it enables native methods to be * instrumented. - *

        + *

        * Since native methods cannot be directly instrumented * (they have no bytecodes), they must be wrapped with * a non-native method which can be instrumented. * For example, if we had: *

              *   native boolean foo(int x);
        - *

        + *

        * We could transform the class file (with the * ClassFileTransformer during the initial definition * of the class) so that this becomes: @@ -567,14 +569,14 @@ public interface Instrumentation { * } * * native boolean wrapped_foo(int x); - *

        + *

        * Where foo becomes a wrapper for the actual native * method with the appended prefix "wrapped_". Note that * "wrapped_" would be a poor choice of prefix since it * might conceivably form the name of an existing method * thus something like "$$$MyAgentWrapped$$$_" would be * better but would make these examples less readable. - *

        + *

        * The wrapper will allow data to be collected on the native * method call, but now the problem becomes linking up the * wrapped method with the native implementation. @@ -583,7 +585,7 @@ public interface Instrumentation { * which might be: *

              *   Java_somePackage_someClass_foo(JNIEnv* env, jint x)
        - *

        + *

        * This function allows the prefix to be specified and the * proper resolution to occur. * Specifically, when the standard resolution fails, the @@ -596,29 +598,29 @@ public interface Instrumentation { *

        {@code
              *   method(foo) -> nativeImplementation(foo)
              * }
        - *

        + *

        * When this fails, the resolution will be retried with * the specified prefix prepended to the method name, * yielding the correct resolution: *

        {@code
              *   method(wrapped_foo) -> nativeImplementation(foo)
              * }
        - *

        + *

        * For automatic resolution, the JVM will attempt: *

        {@code
              *   method(wrapped_foo) -> nativeImplementation(wrapped_foo)
              * }
        - *

        + *

        * When this fails, the resolution will be retried with * the specified prefix deleted from the implementation name, * yielding the correct resolution: *

        {@code
              *   method(wrapped_foo) -> nativeImplementation(foo)
              * }
        - *

        + *

        * Note that since the prefix is only used when standard * resolution fails, native methods can be wrapped selectively. - *

        + *

        * Since each ClassFileTransformer * can do its own transformation of the bytecodes, more * than one layer of wrappers may be applied. Thus each From 6db464070823840013d58d6b8e0c235dd54ff1ca Mon Sep 17 00:00:00 2001 From: Joe Darcy Date: Mon, 1 Jul 2013 13:42:03 -0700 Subject: [PATCH 101/127] 8019529: Fix doclint issues in java.util.spi Reviewed-by: lancea --- .../share/classes/java/util/spi/LocaleServiceProvider.java | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/jdk/src/share/classes/java/util/spi/LocaleServiceProvider.java b/jdk/src/share/classes/java/util/spi/LocaleServiceProvider.java index c490dbadf85..87af9788f50 100644 --- a/jdk/src/share/classes/java/util/spi/LocaleServiceProvider.java +++ b/jdk/src/share/classes/java/util/spi/LocaleServiceProvider.java @@ -42,7 +42,7 @@ import java.util.Locale; * interfaces to offer support for locales beyond the set of locales * supported by the Java runtime environment itself. *

        - *

        Packaging of Locale Sensitive Service Provider Implementations

        + *

        Packaging of Locale Sensitive Service Provider Implementations

        * Implementations of these locale sensitive services are packaged using the * Java Extension Mechanism * as installed extensions. A provider identifies itself with a @@ -165,7 +165,7 @@ public abstract class LocaleServiceProvider { /** * Returns {@code true} if the given {@code locale} is supported by * this locale service provider. The given {@code locale} may contain - * extensions that should be + * extensions that should be * taken into account for the support determination. * *

        The default implementation returns {@code true} if the given {@code locale} From 425681caeccd3664771ff346e44725769f199690 Mon Sep 17 00:00:00 2001 From: Tomas Hurka Date: Mon, 1 Jul 2013 14:13:12 -0700 Subject: [PATCH 102/127] 8009204: [dtrace] signatures returned by Java 7 jstack() are corrupted on Solaris The fix is basically a backport of JDK-7019165 (pstack issue) to jhelper.d. Reviewed-by: coleenp, sspitsyn --- hotspot/src/os/solaris/dtrace/jhelper.d | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/hotspot/src/os/solaris/dtrace/jhelper.d b/hotspot/src/os/solaris/dtrace/jhelper.d index 976a832107f..752f5ae535e 100644 --- a/hotspot/src/os/solaris/dtrace/jhelper.d +++ b/hotspot/src/os/solaris/dtrace/jhelper.d @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -332,12 +332,15 @@ dtrace:helper:ustack: this->nameSymbol = copyin_ptr(this->constantPool + this->nameIndex * sizeof (pointer) + SIZE_ConstantPool); + /* The symbol is a CPSlot and has lower bit set to indicate metadata */ + this->nameSymbol &= (~1); /* remove metadata lsb */ this->nameSymbolLength = copyin_uint16(this->nameSymbol + OFFSET_Symbol_length); this->signatureSymbol = copyin_ptr(this->constantPool + this->signatureIndex * sizeof (pointer) + SIZE_ConstantPool); + this->signatureSymbol &= (~1); /* remove metadata lsb */ this->signatureSymbolLength = copyin_uint16(this->signatureSymbol + OFFSET_Symbol_length); From 7936ee54bfa34a853cadd66f7efe3fccda923287 Mon Sep 17 00:00:00 2001 From: Volker Simonis Date: Mon, 1 Jul 2013 14:14:16 -0700 Subject: [PATCH 103/127] 8019382: PPC64: Fix bytecodeInterpreter to compile with '-Wunused-value' Cast the offending expressions to (void) Reviewed-by: kvn, coleenp --- .../src/share/vm/interpreter/bytecodeInterpreter.cpp | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/hotspot/src/share/vm/interpreter/bytecodeInterpreter.cpp b/hotspot/src/share/vm/interpreter/bytecodeInterpreter.cpp index b51ba870568..538b836f08a 100644 --- a/hotspot/src/share/vm/interpreter/bytecodeInterpreter.cpp +++ b/hotspot/src/share/vm/interpreter/bytecodeInterpreter.cpp @@ -1581,7 +1581,7 @@ run: #define ARRAY_LOADTO32(T, T2, format, stackRes, extra) \ { \ ARRAY_INTRO(-2); \ - extra; \ + (void)extra; \ SET_ ## stackRes(*(T2 *)(((address) arrObj->base(T)) + index * sizeof(T2)), \ -2); \ UPDATE_PC_AND_TOS_AND_CONTINUE(1, -1); \ @@ -1592,8 +1592,8 @@ run: { \ ARRAY_INTRO(-2); \ SET_ ## stackRes(*(T2 *)(((address) arrObj->base(T)) + index * sizeof(T2)), -1); \ - extra; \ - UPDATE_PC_AND_CONTINUE(1); \ + (void)extra; \ + UPDATE_PC_AND_CONTINUE(1); \ } CASE(_iaload): @@ -1617,7 +1617,7 @@ run: #define ARRAY_STOREFROM32(T, T2, format, stackSrc, extra) \ { \ ARRAY_INTRO(-3); \ - extra; \ + (void)extra; \ *(T2 *)(((address) arrObj->base(T)) + index * sizeof(T2)) = stackSrc( -1); \ UPDATE_PC_AND_TOS_AND_CONTINUE(1, -3); \ } @@ -1626,7 +1626,7 @@ run: #define ARRAY_STOREFROM64(T, T2, stackSrc, extra) \ { \ ARRAY_INTRO(-4); \ - extra; \ + (void)extra; \ *(T2 *)(((address) arrObj->base(T)) + index * sizeof(T2)) = stackSrc( -1); \ UPDATE_PC_AND_TOS_AND_CONTINUE(1, -4); \ } From a0fa326cb41098d52aa931b13c70c612a42e9b03 Mon Sep 17 00:00:00 2001 From: Joe Darcy Date: Mon, 1 Jul 2013 14:33:08 -0700 Subject: [PATCH 104/127] 8019535: Fix doclint issues in java.time.format Reviewed-by: lancea, rriggs --- jdk/src/share/classes/java/time/format/DateTimeFormatter.java | 2 ++ 1 file changed, 2 insertions(+) diff --git a/jdk/src/share/classes/java/time/format/DateTimeFormatter.java b/jdk/src/share/classes/java/time/format/DateTimeFormatter.java index 158c741dff4..2552f96e5ad 100644 --- a/jdk/src/share/classes/java/time/format/DateTimeFormatter.java +++ b/jdk/src/share/classes/java/time/format/DateTimeFormatter.java @@ -1304,6 +1304,7 @@ public final class DateTimeFormatter { * LocalTime time = parsed.query(LocalTime::from); * Period extraDays = parsed.query(DateTimeFormatter.parsedExcessDays()); * + * @return a query that provides access to the excess days that were parsed */ public static final TemporalQuery parsedExcessDays() { return PARSED_EXCESS_DAYS; @@ -1344,6 +1345,7 @@ public final class DateTimeFormatter { * // validate leap-second is correct and apply correct smoothing * } * + * @return a query that provides access to whether a leap-second was parsed */ public static final TemporalQuery parsedLeapSecond() { return PARSED_LEAP_SECOND; From bf2a400ca2e78e4e9ec6564df9cae11c75ae5800 Mon Sep 17 00:00:00 2001 From: Jiangli Zhou Date: Mon, 1 Jul 2013 19:44:37 -0400 Subject: [PATCH 105/127] 8006023: Embedded Builds fail management test because of requirement for UsePerfData being enabled Added -XX:+UsePerfData to Test7196045.java. Reviewed-by: dholmes, collins --- hotspot/test/runtime/7196045/Test7196045.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/hotspot/test/runtime/7196045/Test7196045.java b/hotspot/test/runtime/7196045/Test7196045.java index 59704f72590..4c6fcc8c072 100644 --- a/hotspot/test/runtime/7196045/Test7196045.java +++ b/hotspot/test/runtime/7196045/Test7196045.java @@ -26,7 +26,7 @@ * @test * @bug 7196045 * @summary Possible JVM deadlock in ThreadTimesClosure when using HotspotInternal non-public API. - * @run main/othervm Test7196045 + * @run main/othervm -XX:+UsePerfData Test7196045 */ import java.lang.management.ManagementFactory; From 200428aa69f677b2c1d79a1706a1f3d439206f15 Mon Sep 17 00:00:00 2001 From: Jason Uh Date: Mon, 1 Jul 2013 17:46:12 -0700 Subject: [PATCH 106/127] 8019539: Fix doclint errors in java.security and its subpackages Reviewed-by: darcy --- .../share/classes/java/security/KeyStore.java | 6 ++-- .../share/classes/java/security/Provider.java | 1 + .../share/classes/java/security/Security.java | 30 ++++++++++-------- .../classes/java/security/cert/X509CRL.java | 6 ++-- .../java/security/cert/X509CRLEntry.java | 6 ++-- .../java/security/cert/X509Certificate.java | 31 ++++++++++++------- 6 files changed, 46 insertions(+), 34 deletions(-) diff --git a/jdk/src/share/classes/java/security/KeyStore.java b/jdk/src/share/classes/java/security/KeyStore.java index 68df16ed113..c363d0719f7 100644 --- a/jdk/src/share/classes/java/security/KeyStore.java +++ b/jdk/src/share/classes/java/security/KeyStore.java @@ -227,15 +227,13 @@ public class KeyStore { * {@link #store(KeyStore.LoadStoreParameter) store} operations. *

        * The following syntax is supported for configuration data: - *

        -     *
        +     * 
        {@code
              *     domain  [ ...] {
              *         keystore  [ ...] ;
              *         ...
              *     };
              *     ...
        -     *
        -     * 
        + * }
        * where {@code domainName} and {@code keystoreName} are identifiers * and {@code property} is a key/value pairing. The key and value are * separated by an 'equals' symbol and the value is enclosed in double diff --git a/jdk/src/share/classes/java/security/Provider.java b/jdk/src/share/classes/java/security/Provider.java index 54cf9327d1d..89a7b492669 100644 --- a/jdk/src/share/classes/java/security/Provider.java +++ b/jdk/src/share/classes/java/security/Provider.java @@ -67,6 +67,7 @@ import java.lang.reflect.*; * or modified by applications. * The following attributes are automatically placed in each Provider object: * + * * * * diff --git a/jdk/src/share/classes/java/security/Security.java b/jdk/src/share/classes/java/security/Security.java index c3dd716058d..98699da8149 100644 --- a/jdk/src/share/classes/java/security/Security.java +++ b/jdk/src/share/classes/java/security/Security.java @@ -480,8 +480,8 @@ public final class Security { * Returns an array containing all installed providers that satisfy the * specified selection criterion, or null if no such providers have been * installed. The returned providers are ordered - * according to their preference order. + * according to their + * {@linkplain #insertProviderAt(java.security.Provider, int) preference order}. * *

        A cryptographic service is always associated with a particular * algorithm or type. For example, a digital signature service is @@ -492,8 +492,8 @@ public final class Security { *

        The selection criterion must be specified in one of the following two * formats: *

          - *
        • <crypto_service>.<algorithm_or_type>

          The - * cryptographic service name must not contain any dots. + *

        • {@literal .} + *

          The cryptographic service name must not contain any dots. *

          A * provider satisfies the specified selection criterion iff the provider * implements the @@ -501,11 +501,12 @@ public final class Security { *

          For example, "CertificateFactory.X.509" * would be satisfied by any provider that supplied * a CertificateFactory implementation for X.509 certificates. - *

        • <crypto_service>.<algorithm_or_type> - * <attribute_name>:< attribute_value> + *
        • {@literal . + * :} *

          The cryptographic service name must not contain any dots. There * must be one or more space charaters between the - * <algorithm_or_type> and the <attribute_name>. + * {@literal } and the + * {@literal }. *

          A provider satisfies this selection criterion iff the * provider implements the specified algorithm or type for the specified * cryptographic service and its implementation meets the @@ -558,8 +559,9 @@ public final class Security { * Returns an array containing all installed providers that satisfy the * specified* selection criteria, or null if no such providers have been * installed. The returned providers are ordered - * according to their preference order. + * according to their + * {@linkplain #insertProviderAt(java.security.Provider, int) + * preference order}. * *

          The selection criteria are represented by a map. * Each map entry represents a selection criterion. @@ -567,16 +569,18 @@ public final class Security { * criteria. The key for any entry in such a map must be in one of the * following two formats: *

            - *
          • <crypto_service>.<algorithm_or_type> + *
          • {@literal .} *

            The cryptographic service name must not contain any dots. *

            The value associated with the key must be an empty string. *

            A provider * satisfies this selection criterion iff the provider implements the * specified algorithm or type for the specified cryptographic service. - *

          • <crypto_service>.<algorithm_or_type> <attribute_name> + *
          • {@literal }. + * {@literal } *

            The cryptographic service name must not contain any dots. There - * must be one or more space charaters between the <algorithm_or_type> - * and the <attribute_name>. + * must be one or more space charaters between the + * {@literal } + * and the {@literal }. *

            The value associated with the key must be a non-empty string. * A provider satisfies this selection criterion iff the * provider implements the specified algorithm or type for the specified diff --git a/jdk/src/share/classes/java/security/cert/X509CRL.java b/jdk/src/share/classes/java/security/cert/X509CRL.java index 0909ac0a6e6..5ce84847fa5 100644 --- a/jdk/src/share/classes/java/security/cert/X509CRL.java +++ b/jdk/src/share/classes/java/security/cert/X509CRL.java @@ -249,7 +249,8 @@ public abstract class X509CRL extends CRL implements X509Extension { * The ASN.1 definition for this is: *

                  * version    Version OPTIONAL,
            -     *             -- if present, must be v2

            + * -- if present, must be v2 + * * Version ::= INTEGER { v1(0), v2(1), v3(2) } * -- v3 does not apply to CRLs but appears for consistency * -- with definition of Version for certs @@ -413,7 +414,8 @@ public abstract class X509CRL extends CRL implements X509Extension { * signature algorithm. An example is the string "SHA256withRSA". * The ASN.1 definition for this is: *

            -     * signatureAlgorithm   AlgorithmIdentifier

            + * signatureAlgorithm AlgorithmIdentifier + * * AlgorithmIdentifier ::= SEQUENCE { * algorithm OBJECT IDENTIFIER, * parameters ANY DEFINED BY algorithm OPTIONAL } diff --git a/jdk/src/share/classes/java/security/cert/X509CRLEntry.java b/jdk/src/share/classes/java/security/cert/X509CRLEntry.java index f355f62bcb8..268fa819587 100644 --- a/jdk/src/share/classes/java/security/cert/X509CRLEntry.java +++ b/jdk/src/share/classes/java/security/cert/X509CRLEntry.java @@ -43,11 +43,11 @@ import sun.security.x509.X509CRLEntryImpl; * crlEntryExtensions Extensions OPTIONAL * -- if present, must be v2 * } OPTIONAL - *

            + * * CertificateSerialNumber ::= INTEGER - *

            + * * Extensions ::= SEQUENCE SIZE (1..MAX) OF Extension - *

            + * * Extension ::= SEQUENCE { * extnId OBJECT IDENTIFIER, * critical BOOLEAN DEFAULT FALSE, diff --git a/jdk/src/share/classes/java/security/cert/X509Certificate.java b/jdk/src/share/classes/java/security/cert/X509Certificate.java index 9094dfcc95d..0aba5da60c0 100644 --- a/jdk/src/share/classes/java/security/cert/X509Certificate.java +++ b/jdk/src/share/classes/java/security/cert/X509Certificate.java @@ -126,10 +126,12 @@ implements X509Extension { * is valid. It is defined in * ASN.1 as: *

            -     * validity             Validity

            + * validity Validity + * * Validity ::= SEQUENCE { * notBefore CertificateValidityDate, - * notAfter CertificateValidityDate }

            + * notAfter CertificateValidityDate } + * * CertificateValidityDate ::= CHOICE { * utcTime UTCTime, * generalTime GeneralizedTime } @@ -165,7 +167,8 @@ implements X509Extension { * certificate. * The ASN.1 definition for this is: *

            -     * version  [0] EXPLICIT Version DEFAULT v1

            + * version [0] EXPLICIT Version DEFAULT v1 + * * Version ::= INTEGER { v1(0), v2(1), v3(2) } *

            * @return the version number, i.e. 1, 2 or 3. @@ -180,7 +183,7 @@ implements X509Extension { * serial number identify a unique certificate). * The ASN.1 definition for this is: *
            -     * serialNumber     CertificateSerialNumber

            + * serialNumber CertificateSerialNumber * * CertificateSerialNumber ::= INTEGER *

            @@ -204,7 +207,7 @@ implements X509Extension { * X.500 distinguished name (DN). * The ASN.1 definition for this is: *
            -     * issuer    Name

            + * issuer Name * * Name ::= CHOICE { RDNSequence } * RDNSequence ::= SEQUENCE OF RelativeDistinguishedName @@ -295,11 +298,12 @@ implements X509Extension { * the certificate. * The relevant ASN.1 definitions are: *

            -     * validity             Validity

            + * validity Validity * * Validity ::= SEQUENCE { * notBefore CertificateValidityDate, - * notAfter CertificateValidityDate }

            + * notAfter CertificateValidityDate } + * * CertificateValidityDate ::= CHOICE { * utcTime UTCTime, * generalTime GeneralizedTime } @@ -348,7 +352,8 @@ implements X509Extension { * signature algorithm. An example is the string "SHA256withRSA". * The ASN.1 definition for this is: *

            -     * signatureAlgorithm   AlgorithmIdentifier

            + * signatureAlgorithm AlgorithmIdentifier + * * AlgorithmIdentifier ::= SEQUENCE { * algorithm OBJECT IDENTIFIER, * parameters ANY DEFINED BY algorithm OPTIONAL } @@ -410,7 +415,8 @@ implements X509Extension { * *

            The ASN.1 definition for this is: *

            -     * issuerUniqueID  [1]  IMPLICIT UniqueIdentifier OPTIONAL

            + * issuerUniqueID [1] IMPLICIT UniqueIdentifier OPTIONAL + * * UniqueIdentifier ::= BIT STRING *

            * @@ -424,7 +430,8 @@ implements X509Extension { * *

            The ASN.1 definition for this is: *

            -     * subjectUniqueID  [2]  IMPLICIT UniqueIdentifier OPTIONAL

            + * subjectUniqueID [2] IMPLICIT UniqueIdentifier OPTIONAL + * * UniqueIdentifier ::= BIT STRING *

            * @@ -474,9 +481,9 @@ implements X509Extension { * indicated in the key usage extension field. The ASN.1 * definition for this is: *
            -     * ExtKeyUsageSyntax ::= SEQUENCE SIZE (1..MAX) OF KeyPurposeId

            + * ExtKeyUsageSyntax ::= SEQUENCE SIZE (1..MAX) OF KeyPurposeId * - * KeyPurposeId ::= OBJECT IDENTIFIER

            + * KeyPurposeId ::= OBJECT IDENTIFIER *

            * * Key purposes may be defined by any organization with a From fc1302ea9569cce3957223185d79c902460f9e3a Mon Sep 17 00:00:00 2001 From: Vladimir Kozlov Date: Tue, 2 Jul 2013 10:30:49 -0700 Subject: [PATCH 107/127] 8019247: SIGSEGV in compiled method c8e.e.t_.getArray(Ljava/lang/Class;)[Ljava/lang/Object Undo recent changes (and add more comments) in Ideal_allocation(). Reviewed-by: roland --- hotspot/src/share/vm/opto/graphKit.cpp | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/hotspot/src/share/vm/opto/graphKit.cpp b/hotspot/src/share/vm/opto/graphKit.cpp index 590770b7c72..a363b11a5b8 100644 --- a/hotspot/src/share/vm/opto/graphKit.cpp +++ b/hotspot/src/share/vm/opto/graphKit.cpp @@ -3332,9 +3332,14 @@ AllocateNode* AllocateNode::Ideal_allocation(Node* ptr, PhaseTransform* phase) { if (ptr == NULL) { // reduce dumb test in callers return NULL; } - ptr = ptr->uncast(); // strip a raw-to-oop cast - if (ptr == NULL) return NULL; - + if (ptr->is_CheckCastPP()) { // strip only one raw-to-oop cast + ptr = ptr->in(1); + if (ptr == NULL) return NULL; + } + // Return NULL for allocations with several casts: + // j.l.reflect.Array.newInstance(jobject, jint) + // Object.clone() + // to keep more precise type from last cast. if (ptr->is_Proj()) { Node* allo = ptr->in(0); if (allo != NULL && allo->is_Allocate()) { From 386e37ba15ba121ea16eeb0d9e98162d283c9462 Mon Sep 17 00:00:00 2001 From: Albert Noll Date: Tue, 2 Jul 2013 07:51:31 +0200 Subject: [PATCH 108/127] 8014972: Crash with specific values for -XX:InitialCodeCacheSize=500K -XX:ReservedCodeCacheSize=500k Introduce a minimum code cache size that guarantees that the VM can startup. Reviewed-by: kvn, twisti --- hotspot/src/cpu/sparc/vm/c1_globals_sparc.hpp | 5 ++-- hotspot/src/cpu/sparc/vm/c2_globals_sparc.hpp | 3 +- hotspot/src/cpu/x86/vm/c1_globals_x86.hpp | 5 ++-- hotspot/src/cpu/x86/vm/c2_globals_x86.hpp | 3 +- .../src/cpu/zero/vm/shark_globals_zero.hpp | 4 ++- hotspot/src/share/vm/runtime/arguments.cpp | 29 +++++++++++++++++-- hotspot/src/share/vm/runtime/globals.hpp | 3 ++ 7 files changed, 42 insertions(+), 10 deletions(-) diff --git a/hotspot/src/cpu/sparc/vm/c1_globals_sparc.hpp b/hotspot/src/cpu/sparc/vm/c1_globals_sparc.hpp index a43a9cee538..c6cf521272d 100644 --- a/hotspot/src/cpu/sparc/vm/c1_globals_sparc.hpp +++ b/hotspot/src/cpu/sparc/vm/c1_globals_sparc.hpp @@ -49,8 +49,9 @@ define_pd_global(intx, FreqInlineSize, 325 ); define_pd_global(bool, ResizeTLAB, true ); define_pd_global(intx, ReservedCodeCacheSize, 32*M ); define_pd_global(intx, CodeCacheExpansionSize, 32*K ); -define_pd_global(uintx,CodeCacheMinBlockLength, 1); -define_pd_global(uintx,MetaspaceSize, 12*M ); +define_pd_global(uintx, CodeCacheMinBlockLength, 1); +define_pd_global(uintx, CodeCacheMinimumUseSpace, 400*K); +define_pd_global(uintx, MetaspaceSize, 12*M ); define_pd_global(bool, NeverActAsServerClassMachine, true ); define_pd_global(intx, NewSizeThreadIncrease, 16*K ); define_pd_global(uint64_t,MaxRAM, 1ULL*G); diff --git a/hotspot/src/cpu/sparc/vm/c2_globals_sparc.hpp b/hotspot/src/cpu/sparc/vm/c2_globals_sparc.hpp index c642e915fe1..e32094deb06 100644 --- a/hotspot/src/cpu/sparc/vm/c2_globals_sparc.hpp +++ b/hotspot/src/cpu/sparc/vm/c2_globals_sparc.hpp @@ -86,7 +86,8 @@ define_pd_global(intx, CodeCacheExpansionSize, 32*K); // Ergonomics related flags define_pd_global(uint64_t,MaxRAM, 4ULL*G); #endif -define_pd_global(uintx,CodeCacheMinBlockLength, 4); +define_pd_global(uintx, CodeCacheMinBlockLength, 4); +define_pd_global(uintx, CodeCacheMinimumUseSpace, 400*K); // Heap related flags define_pd_global(uintx,MetaspaceSize, ScaleForWordSize(16*M)); diff --git a/hotspot/src/cpu/x86/vm/c1_globals_x86.hpp b/hotspot/src/cpu/x86/vm/c1_globals_x86.hpp index 98e02b16cd0..13f3df82c29 100644 --- a/hotspot/src/cpu/x86/vm/c1_globals_x86.hpp +++ b/hotspot/src/cpu/x86/vm/c1_globals_x86.hpp @@ -50,8 +50,9 @@ define_pd_global(intx, InitialCodeCacheSize, 160*K); define_pd_global(intx, ReservedCodeCacheSize, 32*M ); define_pd_global(bool, ProfileInterpreter, false); define_pd_global(intx, CodeCacheExpansionSize, 32*K ); -define_pd_global(uintx,CodeCacheMinBlockLength, 1); -define_pd_global(uintx,MetaspaceSize, 12*M ); +define_pd_global(uintx, CodeCacheMinBlockLength, 1); +define_pd_global(uintx, CodeCacheMinimumUseSpace, 400*K); +define_pd_global(uintx, MetaspaceSize, 12*M ); define_pd_global(bool, NeverActAsServerClassMachine, true ); define_pd_global(uint64_t,MaxRAM, 1ULL*G); define_pd_global(bool, CICompileOSR, true ); diff --git a/hotspot/src/cpu/x86/vm/c2_globals_x86.hpp b/hotspot/src/cpu/x86/vm/c2_globals_x86.hpp index f63b8c46d58..ce92123e818 100644 --- a/hotspot/src/cpu/x86/vm/c2_globals_x86.hpp +++ b/hotspot/src/cpu/x86/vm/c2_globals_x86.hpp @@ -85,7 +85,8 @@ define_pd_global(bool, OptoScheduling, false); define_pd_global(bool, OptoBundling, false); define_pd_global(intx, ReservedCodeCacheSize, 48*M); -define_pd_global(uintx,CodeCacheMinBlockLength, 4); +define_pd_global(uintx, CodeCacheMinBlockLength, 4); +define_pd_global(uintx, CodeCacheMinimumUseSpace, 400*K); // Heap related flags define_pd_global(uintx,MetaspaceSize, ScaleForWordSize(16*M)); diff --git a/hotspot/src/cpu/zero/vm/shark_globals_zero.hpp b/hotspot/src/cpu/zero/vm/shark_globals_zero.hpp index 1d17143761a..c04b225b830 100644 --- a/hotspot/src/cpu/zero/vm/shark_globals_zero.hpp +++ b/hotspot/src/cpu/zero/vm/shark_globals_zero.hpp @@ -58,7 +58,9 @@ define_pd_global(intx, ReservedCodeCacheSize, 32*M ); define_pd_global(bool, ProfileInterpreter, false); define_pd_global(intx, CodeCacheExpansionSize, 32*K ); define_pd_global(uintx, CodeCacheMinBlockLength, 1 ); -define_pd_global(uintx, MetaspaceSize, 12*M ); +define_pd_global(uintx, CodeCacheMinimumUseSpace, 200*K); + +define_pd_global(uintx, MetaspaceSize, 12*M ); define_pd_global(bool, NeverActAsServerClassMachine, true ); define_pd_global(uint64_t, MaxRAM, 1ULL*G); define_pd_global(bool, CICompileOSR, true ); diff --git a/hotspot/src/share/vm/runtime/arguments.cpp b/hotspot/src/share/vm/runtime/arguments.cpp index 625feda03f9..b00beff9a22 100644 --- a/hotspot/src/share/vm/runtime/arguments.cpp +++ b/hotspot/src/share/vm/runtime/arguments.cpp @@ -2211,11 +2211,24 @@ bool Arguments::check_vm_args_consistency() { status = false; } - if (ReservedCodeCacheSize < InitialCodeCacheSize) { + // Check lower bounds of the code cache + // Template Interpreter code is approximately 3X larger in debug builds. + uint min_code_cache_size = (CodeCacheMinimumUseSpace DEBUG_ONLY(* 3)) + CodeCacheMinimumFreeSpace; + if (InitialCodeCacheSize < (uintx)os::vm_page_size()) { jio_fprintf(defaultStream::error_stream(), - "Invalid ReservedCodeCacheSize: %dK. Should be greater than InitialCodeCacheSize=%dK\n", + "Invalid InitialCodeCacheSize=%dK. Must be at least %dK.\n", InitialCodeCacheSize/K, + os::vm_page_size()/K); + status = false; + } else if (ReservedCodeCacheSize < InitialCodeCacheSize) { + jio_fprintf(defaultStream::error_stream(), + "Invalid ReservedCodeCacheSize: %dK. Must be at least InitialCodeCacheSize=%dK.\n", ReservedCodeCacheSize/K, InitialCodeCacheSize/K); status = false; + } else if (ReservedCodeCacheSize < min_code_cache_size) { + jio_fprintf(defaultStream::error_stream(), + "Invalid ReservedCodeCacheSize=%dK. Must be at least %uK.\n", ReservedCodeCacheSize/K, + min_code_cache_size/K); + status = false; } return status; @@ -2616,10 +2629,20 @@ jint Arguments::parse_each_vm_init_arg(const JavaVMInitArgs* args, // -Xoss } else if (match_option(option, "-Xoss", &tail)) { // HotSpot does not have separate native and Java stacks, ignore silently for compatibility - // -Xmaxjitcodesize + } else if (match_option(option, "-XX:CodeCacheExpansionSize=", &tail)) { + julong long_CodeCacheExpansionSize = 0; + ArgsRange errcode = parse_memory_size(tail, &long_CodeCacheExpansionSize, os::vm_page_size()); + if (errcode != arg_in_range) { + jio_fprintf(defaultStream::error_stream(), + "Invalid argument: %s. Must be at least %luK.\n", option->optionString, + os::vm_page_size()/K); + return JNI_EINVAL; + } + FLAG_SET_CMDLINE(uintx, CodeCacheExpansionSize, (uintx)long_CodeCacheExpansionSize); } else if (match_option(option, "-Xmaxjitcodesize", &tail) || match_option(option, "-XX:ReservedCodeCacheSize=", &tail)) { julong long_ReservedCodeCacheSize = 0; + ArgsRange errcode = parse_memory_size(tail, &long_ReservedCodeCacheSize, 1); if (errcode != arg_in_range) { jio_fprintf(defaultStream::error_stream(), diff --git a/hotspot/src/share/vm/runtime/globals.hpp b/hotspot/src/share/vm/runtime/globals.hpp index b1adcf7fce1..c94f6bdbb17 100644 --- a/hotspot/src/share/vm/runtime/globals.hpp +++ b/hotspot/src/share/vm/runtime/globals.hpp @@ -3160,6 +3160,9 @@ class CommandLineFlags { product_pd(uintx, InitialCodeCacheSize, \ "Initial code cache size (in bytes)") \ \ + develop_pd(uintx, CodeCacheMinimumUseSpace, \ + "Minimum code cache size (in bytes) required to start VM.") \ + \ product_pd(uintx, ReservedCodeCacheSize, \ "Reserved code cache size (in bytes) - maximum code cache size") \ \ From 677643324ed495e52d1d5dbdd8795ad13fbf24c4 Mon Sep 17 00:00:00 2001 From: Daniel Fuchs Date: Tue, 2 Jul 2013 11:30:31 +0200 Subject: [PATCH 109/127] 8017174: NPE when using Logger.getAnonymousLogger or LogManager.getLogManager().getLogger This patch makes sure that LoggerContext instances created for applets have a root and global logger. Reviewed-by: mchung --- .../classes/java/util/logging/LogManager.java | 121 +++- .../util/logging/LogManagerInstanceTest.java | 2 +- .../util/logging/TestAppletLoggerContext.java | 610 ++++++++++++++++++ 3 files changed, 719 insertions(+), 14 deletions(-) create mode 100644 jdk/test/java/util/logging/TestAppletLoggerContext.java diff --git a/jdk/src/share/classes/java/util/logging/LogManager.java b/jdk/src/share/classes/java/util/logging/LogManager.java index 6ecfe69a981..228d4636f5d 100644 --- a/jdk/src/share/classes/java/util/logging/LogManager.java +++ b/jdk/src/share/classes/java/util/logging/LogManager.java @@ -193,13 +193,22 @@ public class LogManager { // Create and retain Logger for the root of the namespace. manager.rootLogger = manager.new RootLogger(); + // since by design the global manager's userContext and + // systemContext don't have their requiresDefaultLoggers + // flag set - we make sure to add the root logger to + // the global manager's default contexts here. manager.addLogger(manager.rootLogger); - manager.systemContext.addLocalLogger(manager.rootLogger); + manager.systemContext.addLocalLogger(manager.rootLogger, false); + manager.userContext.addLocalLogger(manager.rootLogger, false); // Adding the global Logger. Doing so in the Logger. // would deadlock with the LogManager.. Logger.global.setLogManager(manager); + // Make sure the global logger will be registered in the + // global manager's default contexts. manager.addLogger(Logger.global); + manager.systemContext.addLocalLogger(Logger.global, false); + manager.userContext.addLocalLogger(Logger.global, false); // We don't call readConfiguration() here, as we may be running // very early in the JVM startup sequence. Instead readConfiguration @@ -401,7 +410,11 @@ public class LogManager { if (javaAwtAccess.isMainAppContext()) { context = userContext; } else { - context = new LoggerContext(); + // Create a new LoggerContext for the applet. + // The new logger context has its requiresDefaultLoggers + // flag set to true - so that these loggers will be + // lazily added when the context is firt accessed. + context = new LoggerContext(true); } javaAwtAccess.put(ecx, LoggerContext.class, context); } @@ -508,9 +521,13 @@ public class LogManager { private final Hashtable namedLoggers = new Hashtable<>(); // Tree of named Loggers private final LogNode root; - + private final boolean requiresDefaultLoggers; private LoggerContext() { + this(false); + } + private LoggerContext(boolean requiresDefaultLoggers) { this.root = new LogNode(null, this); + this.requiresDefaultLoggers = requiresDefaultLoggers; } Logger demandLogger(String name, String resourceBundleName) { @@ -519,7 +536,27 @@ public class LogManager { return manager.demandLogger(name, resourceBundleName, null); } + + // Due to subtle deadlock issues getUserContext() no longer + // calls addLocalLogger(rootLogger); + // Therefore - we need to add the default loggers later on. + // Checks that the context is properly initialized + // This is necessary before calling e.g. find(name) + // or getLoggerNames() + // + private void ensureInitialized() { + if (requiresDefaultLoggers) { + // Ensure that the root and global loggers are set. + ensureDefaultLogger(manager.rootLogger); + ensureDefaultLogger(Logger.global); + } + } + + synchronized Logger findLogger(String name) { + // ensure that this context is properly initialized before + // looking for loggers. + ensureInitialized(); LoggerWeakRef ref = namedLoggers.get(name); if (ref == null) { return null; @@ -533,21 +570,76 @@ public class LogManager { return logger; } - synchronized void ensureRootLogger(Logger logger) { - if (logger.getName().isEmpty()) - return; - - // during initialization, rootLogger is null when - // instantiating itself RootLogger - if (findLogger("") == null && manager.rootLogger != null) { - addLocalLogger(manager.rootLogger); + // This method is called before adding a logger to the + // context. + // 'logger' is the context that will be added. + // This method will ensure that the defaults loggers are added + // before adding 'logger'. + // + private void ensureAllDefaultLoggers(Logger logger) { + if (requiresDefaultLoggers) { + final String name = logger.getName(); + if (!name.isEmpty()) { + ensureDefaultLogger(manager.rootLogger); + } + if (!Logger.GLOBAL_LOGGER_NAME.equals(name)) { + ensureDefaultLogger(Logger.global); + } } } + private void ensureDefaultLogger(Logger logger) { + // Used for lazy addition of root logger and global logger + // to a LoggerContext. + + // This check is simple sanity: we do not want that this + // method be called for anything else than Logger.global + // or owner.rootLogger. + if (!requiresDefaultLoggers || logger == null + || logger != Logger.global && logger != manager.rootLogger) { + + // the case where we have a non null logger which is neither + // Logger.global nor manager.rootLogger indicates a serious + // issue - as ensureDefaultLogger should never be called + // with any other loggers than one of these two (or null - if + // e.g manager.rootLogger is not yet initialized)... + assert logger == null; + + return; + } + + // Adds the logger if it's not already there. + if (!namedLoggers.containsKey(logger.getName())) { + // It is important to prevent addLocalLogger to + // call ensureAllDefaultLoggers when we're in the process + // off adding one of those default loggers - as this would + // immediately cause a stack overflow. + // Therefore we must pass addDefaultLoggersIfNeeded=false, + // even if requiresDefaultLoggers is true. + addLocalLogger(logger, false); + } + } + + boolean addLocalLogger(Logger logger) { + // no need to add default loggers if it's not required + return addLocalLogger(logger, requiresDefaultLoggers); + } + // Add a logger to this context. This method will only set its level // and process parent loggers. It doesn't set its handlers. - synchronized boolean addLocalLogger(Logger logger) { - ensureRootLogger(logger); + synchronized boolean addLocalLogger(Logger logger, boolean addDefaultLoggersIfNeeded) { + // addDefaultLoggersIfNeeded serves to break recursion when adding + // default loggers. If we're adding one of the default loggers + // (we're being called from ensureDefaultLogger()) then + // addDefaultLoggersIfNeeded will be false: we don't want to + // call ensureAllDefaultLoggers again. + // + // Note: addDefaultLoggersIfNeeded can also be false when + // requiresDefaultLoggers is false - since calling + // ensureAllDefaultLoggers would have no effect in this case. + if (addDefaultLoggersIfNeeded) { + ensureAllDefaultLoggers(logger); + } final String name = logger.getName(); if (name == null) { @@ -615,6 +707,9 @@ public class LogManager { } synchronized Enumeration getLoggerNames() { + // ensure that this context is properly initialized before + // returning logger names. + ensureInitialized(); return namedLoggers.keys(); } diff --git a/jdk/test/java/util/logging/LogManagerInstanceTest.java b/jdk/test/java/util/logging/LogManagerInstanceTest.java index 3d3714d5656..c6fbe1e56d7 100644 --- a/jdk/test/java/util/logging/LogManagerInstanceTest.java +++ b/jdk/test/java/util/logging/LogManagerInstanceTest.java @@ -63,7 +63,7 @@ public class LogManagerInstanceTest { if (!super.addLogger(root)) throw new RuntimeException("Fail to addLogger " + root); } else { - System.out.println("Root logger already exists"); + throw new RuntimeException("Root logger already exists"); } this.base = root; } diff --git a/jdk/test/java/util/logging/TestAppletLoggerContext.java b/jdk/test/java/util/logging/TestAppletLoggerContext.java new file mode 100644 index 00000000000..c7f3d4f4991 --- /dev/null +++ b/jdk/test/java/util/logging/TestAppletLoggerContext.java @@ -0,0 +1,610 @@ +/* + * Copyright (c) 2013, 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. + */ + +import java.security.CodeSource; +import java.security.Permission; +import java.security.PermissionCollection; +import java.security.Permissions; +import java.security.Policy; +import java.security.ProtectionDomain; +import java.util.EnumSet; +import java.util.HashMap; +import java.util.Map; +import java.util.logging.LogManager; +import java.util.logging.Logger; +import java.util.logging.LoggingPermission; +import sun.misc.JavaAWTAccess; +import sun.misc.SharedSecrets; + +/* + * @test + * @bug 8017174 8010727 + * @summary NPE when using Logger.getAnonymousLogger or + * LogManager.getLogManager().getLogger + * + * @run main/othervm -Dtest.security=off TestAppletLoggerContext LoadingApplet + * @run main/othervm -Dtest.security=on TestAppletLoggerContext LoadingApplet + * @run main/othervm -Dtest.security=off TestAppletLoggerContext LoadingMain + * @run main/othervm -Dtest.security=on TestAppletLoggerContext LoadingMain + * @run main/othervm -Dtest.security=off TestAppletLoggerContext One + * @run main/othervm -Dtest.security=on TestAppletLoggerContext One + * @run main/othervm -Dtest.security=off TestAppletLoggerContext Two + * @run main/othervm -Dtest.security=on TestAppletLoggerContext Two + * @run main/othervm -Dtest.security=off TestAppletLoggerContext Three + * @run main/othervm -Dtest.security=on TestAppletLoggerContext Three + * @run main/othervm -Dtest.security=off TestAppletLoggerContext Four + * @run main/othervm -Dtest.security=on TestAppletLoggerContext Four + * @run main/othervm -Dtest.security=off TestAppletLoggerContext Five + * @run main/othervm -Dtest.security=on TestAppletLoggerContext Five + * @run main/othervm -Dtest.security=off TestAppletLoggerContext Six + * @run main/othervm -Dtest.security=on TestAppletLoggerContext Six + * @run main/othervm -Dtest.security=off TestAppletLoggerContext Seven + * @run main/othervm -Dtest.security=on TestAppletLoggerContext Seven + * @run main/othervm -Dtest.security=off TestAppletLoggerContext + * @run main/othervm -Dtest.security=on TestAppletLoggerContext + */ + +// NOTE: We run in other VM in order to 1. switch security manager and 2. cause +// LogManager class to be loaded anew. +public class TestAppletLoggerContext { + + // Avoids the hassle of dealing with files and system props... + static class SimplePolicy extends Policy { + private final Permissions perms; + public SimplePolicy(Permission... permissions) { + perms = new Permissions(); + for (Permission permission : permissions) { + perms.add(permission); + } + } + @Override + public PermissionCollection getPermissions(CodeSource cs) { + return perms; + } + @Override + public PermissionCollection getPermissions(ProtectionDomain pd) { + return perms; + } + @Override + public boolean implies(ProtectionDomain pd, Permission p) { + return perms.implies(p); + } + } + + // The bridge class initializes the logging system. + // It stubs the applet context in order to simulate context changes. + // + public static class Bridge { + + private static class JavaAWTAccessStub implements JavaAWTAccess { + boolean active = true; + + private static class TestExc { + private final Map map = new HashMap<>(); + void put(Object key, Object v) { map.put(key, v); } + Object get(Object key) { return map.get(key); } + void remove(Object o) { map.remove(o); } + public static TestExc exc(Object o) { + return TestExc.class.cast(o); + } + } + + TestExc exc; + TestExc global = new TestExc(); + + @Override + public Object getContext() { return active ? global : null; } + @Override + public Object getExecutionContext() { return active ? exc : null; } + @Override + public Object get(Object o, Object o1) { return TestExc.exc(o).get(o1); } + @Override + public void put(Object o, Object o1, Object o2) { TestExc.exc(o).put(o1, o2); } + @Override + public void remove(Object o, Object o1) { TestExc.exc(o).remove(o1); } + @Override + public Object get(Object o) { return global.get(o); } + @Override + public void put(Object o, Object o1) { global.put(o, o1); } + @Override + public void remove(Object o) { global.remove(o); } + @Override + public boolean isDisposed() { return false; } + @Override + public boolean isMainAppContext() { return exc == null; } + } + + final static JavaAWTAccessStub javaAwtAccess = new JavaAWTAccessStub(); + public static void init() { + SharedSecrets.setJavaAWTAccess(javaAwtAccess); + if (System.getProperty("test.security", "on").equals("on")) { + Policy p = new SimplePolicy(new LoggingPermission("control", null), + new RuntimePermission("setContextClassLoader"), + new RuntimePermission("shutdownHooks")); + Policy.setPolicy(p); + System.setSecurityManager(new SecurityManager()); + } + } + + public static void changeContext() { + System.out.println("... Switching to a new applet context ..."); + javaAwtAccess.active = true; + javaAwtAccess.exc = new JavaAWTAccessStub.TestExc(); + } + + public static void desactivate() { + System.out.println("... Running with no applet context ..."); + javaAwtAccess.exc = null; + javaAwtAccess.active = false; + } + + public static class CustomAnonymousLogger extends Logger { + public CustomAnonymousLogger() { + this(""); + } + public CustomAnonymousLogger(String name) { + super(null, null); + System.out.println( " LogManager: " +LogManager.getLogManager()); + System.out.println( " getLogger: " +LogManager.getLogManager().getLogger(name)); + setParent(LogManager.getLogManager().getLogger(name)); + } + } + + public static class CustomLogger extends Logger { + CustomLogger(String name) { + super(name, null); + } + } + } + + public static enum TestCase { + LoadingApplet, LoadingMain, One, Two, Three, Four, Five, Six, Seven; + public void test() { + switch(this) { + // When run - each of these two tests must be + // run before any other tests and before each other. + case LoadingApplet: testLoadingApplet(); break; + case LoadingMain: testLoadingMain(); break; + case One: testOne(); break; + case Two: testTwo(); break; + case Three: testThree(); break; + case Four: testFour(); break; + case Five: testFive(); break; + case Six: testSix(); break; + case Seven: testSeven(); break; + } + } + public String describe() { + switch(this) { + case LoadingApplet: + return "Test that when the LogManager class is" + + " loaded in an applet thread first," + + "\n all LoggerContexts are correctly initialized"; + case LoadingMain: + return "Test that when the LogManager class is" + + " loaded in the main thread first," + + "\n all LoggerContexts are correctly initialized"; + case One: + return "Test that Logger.getAnonymousLogger()" + + " and new CustomAnonymousLogger() don't throw NPE"; + case Two: + return "Test that Logger.getLogger(\"\")" + + " does not return null nor throws NPE"; + case Three: + return "Test that LogManager.getLogManager().getLogger(\"\")" + + " does not return null nor throws NPE"; + case Four: + return "Test that Logger.getLogger(Logger.GLOBAL_LOGGER_NAME)" + + " does not return null,\n and that" + + " new CustomAnonymousLogger(Logger.GLOBAL_LOGGER_NAME)" + + " does not throw NPE"; + case Five: + return "Test that LogManager.getLogManager().getLogger(Logger.GLOBAL_LOGGER_NAME)" + + "\n does not return null nor throws NPE"; + case Six: + return "Test that manager.getLogger(Logger.GLOBAL_LOGGER_NAME)" + + " returns null\n when manager is not the default" + + " LogManager instance.\n" + + "Test adding a new logger named \"global\" in that" + + " non default instance."; + case Seven: return "Test that manager.getLogger(\"\")" + + " returns null\n when manager is not the default" + + " LogManager instance.\n" + + "Test adding a new logger named \"\" in that" + + " non default instance."; + default: return "Undefined"; + } + } + }; + + /** + * @param args the command line arguments + */ + public static void main(String[] args) { + Bridge.init(); + EnumSet tests = EnumSet.noneOf(TestCase.class); + for (String arg : args) { + tests.add(TestCase.valueOf(arg)); + } + if (args.length == 0) { + tests = EnumSet.complementOf(EnumSet.of(TestCase.LoadingMain)); + } + final EnumSet loadingTests = + EnumSet.of(TestCase.LoadingApplet, TestCase.LoadingMain); + int testrun = 0; + for (TestCase test : tests) { + if (loadingTests.contains(test)) { + if (testrun > 0) { + throw new UnsupportedOperationException("Test case " + + test + " must be executed first!"); + } + } + System.out.println("Testing "+ test+": "); + System.out.println(test.describe()); + try { + test.test(); + } catch (Exception x) { + throw new Error(String.valueOf(test) + + (System.getSecurityManager() == null ? " without " : " with ") + + "security failed: "+x+"\n "+"FAILED: "+test.describe()+"\n", x); + } finally { + testrun++; + } + Bridge.changeContext(); + System.out.println("PASSED: "+ test); + } + } + + public static void testLoadingApplet() { + Bridge.changeContext(); + + Logger bar = new Bridge.CustomLogger("com.foo.Bar"); + LogManager.getLogManager().addLogger(bar); + assertNotNull(bar.getParent()); + testParent(bar); + testParent(LogManager.getLogManager().getLogger("global")); + testParent(LogManager.getLogManager().getLogger(bar.getName())); + + Bridge.desactivate(); + + Logger foo = new Bridge.CustomLogger("com.foo.Foo"); + boolean b = LogManager.getLogManager().addLogger(foo); + assertEquals(Boolean.TRUE, Boolean.valueOf(b)); + assertNotNull(foo.getParent()); + testParent(foo); + testParent(LogManager.getLogManager().getLogger("global")); + testParent(LogManager.getLogManager().getLogger(foo.getName())); + } + + public static void testLoadingMain() { + Bridge.desactivate(); + + Logger bar = new Bridge.CustomLogger("com.foo.Bar"); + LogManager.getLogManager().addLogger(bar); + assertNotNull(bar.getParent()); + testParent(bar); + testParent(LogManager.getLogManager().getLogger("global")); + testParent(LogManager.getLogManager().getLogger(bar.getName())); + + Bridge.changeContext(); + + Logger foo = new Bridge.CustomLogger("com.foo.Foo"); + boolean b = LogManager.getLogManager().addLogger(foo); + assertEquals(Boolean.TRUE, Boolean.valueOf(b)); + assertNotNull(foo.getParent()); + testParent(foo); + testParent(LogManager.getLogManager().getLogger("global")); + testParent(LogManager.getLogManager().getLogger(foo.getName())); + + } + + public static void testOne() { + for (int i=0; i<3 ; i++) { + Logger logger1 = Logger.getAnonymousLogger(); + Logger logger1b = Logger.getAnonymousLogger(); + Bridge.changeContext(); + Logger logger2 = Logger.getAnonymousLogger(); + Logger logger2b = Logger.getAnonymousLogger(); + Bridge.changeContext(); + Logger logger3 = new Bridge.CustomAnonymousLogger(); + Logger logger3b = new Bridge.CustomAnonymousLogger(); + Bridge.changeContext(); + Logger logger4 = new Bridge.CustomAnonymousLogger(); + Logger logger4b = new Bridge.CustomAnonymousLogger(); + } + } + + + public static void testTwo() { + for (int i=0; i<3 ; i++) { + Logger logger1 = Logger.getLogger(""); + Logger logger1b = Logger.getLogger(""); + assertNotNull(logger1); + assertNotNull(logger1b); + assertEquals(logger1, logger1b); + Bridge.changeContext(); + Logger logger2 = Logger.getLogger(""); + Logger logger2b = Logger.getLogger(""); + assertNotNull(logger2); + assertNotNull(logger2b); + assertEquals(logger2, logger2b); + assertEquals(logger1, logger2); + } + } + + public static void testThree() { + for (int i=0; i<3 ; i++) { + Logger logger1 = LogManager.getLogManager().getLogger(""); + Logger logger1b = LogManager.getLogManager().getLogger(""); + assertNotNull(logger1); + assertNotNull(logger1b); + assertEquals(logger1, logger1b); + Bridge.changeContext(); + Logger logger2 = LogManager.getLogManager().getLogger(""); + Logger logger2b = LogManager.getLogManager().getLogger(""); + assertNotNull(logger2); + assertNotNull(logger2b); + assertEquals(logger2, logger2b); + assertEquals(logger1, logger2); + } + } + + public static void testFour() { + for (int i=0; i<3 ; i++) { + Logger logger1 = Logger.getLogger(Logger.GLOBAL_LOGGER_NAME); + Logger logger1b = Logger.getLogger(Logger.GLOBAL_LOGGER_NAME); + assertNotNull(logger1); + assertNotNull(logger1b); + assertEquals(logger1, logger1b); + Bridge.changeContext(); + + Logger logger2 = Logger.getLogger(Logger.GLOBAL_LOGGER_NAME); + Logger logger2b = Logger.getLogger(Logger.GLOBAL_LOGGER_NAME); + assertNotNull(logger2); + assertNotNull(logger2b); + assertEquals(logger2, logger2b); + + assertEquals(logger1, logger2); + + Bridge.changeContext(); + Logger logger3 = new Bridge.CustomAnonymousLogger(Logger.GLOBAL_LOGGER_NAME); + Logger logger3b = new Bridge.CustomAnonymousLogger(Logger.GLOBAL_LOGGER_NAME); + Bridge.changeContext(); + Logger logger4 = new Bridge.CustomAnonymousLogger(Logger.GLOBAL_LOGGER_NAME); + Logger logger4b = new Bridge.CustomAnonymousLogger(Logger.GLOBAL_LOGGER_NAME); + } + } + + public static void testFive() { + for (int i=0; i<3 ; i++) { + Logger logger1 = LogManager.getLogManager().getLogger(Logger.GLOBAL_LOGGER_NAME); + Logger logger1b = LogManager.getLogManager().getLogger(Logger.GLOBAL_LOGGER_NAME); + assertNotNull(logger1); + assertNotNull(logger1b); + assertEquals(logger1, logger1b); + + Bridge.changeContext(); + + Logger logger2 = LogManager.getLogManager().getLogger(Logger.GLOBAL_LOGGER_NAME); + Logger logger2b = LogManager.getLogManager().getLogger(Logger.GLOBAL_LOGGER_NAME); + assertNotNull(logger2); + assertNotNull(logger2b); + assertEquals(logger2, logger2b); + + assertEquals(logger1, logger2); + } + } + + /** + * This test is designed to test the behavior of additional LogManager instances. + * It must be noted that if the security manager is off, then calling + * Bridge.changeContext() has actually no effect - which explains why we have + * some differences between the cases security manager on & security manager + * off. + **/ + public static void testSix() { + for (int i=0; i<3 ; i++) { + Bridge.desactivate(); + LogManager manager = new LogManager() {}; + Logger logger1 = manager.getLogger(Logger.GLOBAL_LOGGER_NAME); + Logger logger1b = manager.getLogger(Logger.GLOBAL_LOGGER_NAME); + assertNull(logger1); + assertNull(logger1b); + Logger global = new Bridge.CustomLogger(Logger.GLOBAL_LOGGER_NAME); + manager.addLogger(global); + Logger logger2 = manager.getLogger(Logger.GLOBAL_LOGGER_NAME); + Logger logger2b = manager.getLogger(Logger.GLOBAL_LOGGER_NAME); + assertNotNull(logger2); + assertNotNull(logger2b); + assertEquals(logger2, global); + assertEquals(logger2b, global); + assertNull(manager.getLogger("")); + assertNull(manager.getLogger("")); + + Bridge.changeContext(); + + // this is not a supported configuration: + // We are in an applet context with several log managers. + // We however need to check our assumptions... + + // Applet context => root logger and global logger are not null. + // root == LogManager.getLogManager().rootLogger + // global == Logger.global + + Logger logger3 = manager.getLogger(Logger.GLOBAL_LOGGER_NAME); + Logger logger3b = manager.getLogger(Logger.GLOBAL_LOGGER_NAME); + assertNotNull(logger3); + assertNotNull(logger3b); + Logger expected = (System.getSecurityManager() != null + ? Logger.getGlobal() + : global); + assertEquals(logger3, expected); // in applet context, we will not see + // the LogManager's custom global logger added above... + assertEquals(logger3b, expected); // in applet context, we will not see + // the LogManager's custom global logger added above... + Logger global2 = new Bridge.CustomLogger(Logger.GLOBAL_LOGGER_NAME); + manager.addLogger(global2); // adding a global logger will not work in applet context + // we will always get back the global logger. + // this could be considered as a bug... + Logger logger4 = manager.getLogger(Logger.GLOBAL_LOGGER_NAME); + Logger logger4b = manager.getLogger(Logger.GLOBAL_LOGGER_NAME); + assertNotNull(logger4); + assertNotNull(logger4b); + assertEquals(logger4, expected); // adding a global logger will not work in applet context + assertEquals(logger4b, expected); // adding a global logger will not work in applet context + + Logger logger5 = manager.getLogger(""); + Logger logger5b = manager.getLogger(""); + Logger expectedRoot = (System.getSecurityManager() != null + ? LogManager.getLogManager().getLogger("") + : null); + assertEquals(logger5, expectedRoot); + assertEquals(logger5b, expectedRoot); + + } + } + + /** + * This test is designed to test the behavior of additional LogManager instances. + * It must be noted that if the security manager is off, then calling + * Bridge.changeContext() has actually no effect - which explains why we have + * some differences between the cases security manager on & security manager + * off. + **/ + public static void testSeven() { + for (int i=0; i<3 ; i++) { + Bridge.desactivate(); + LogManager manager = new LogManager() {}; + Logger logger1 = manager.getLogger(""); + Logger logger1b = manager.getLogger(""); + assertNull(logger1); + assertNull(logger1b); + Logger global = new Bridge.CustomLogger(Logger.GLOBAL_LOGGER_NAME); + manager.addLogger(global); + Logger logger2 = manager.getLogger(Logger.GLOBAL_LOGGER_NAME); + Logger logger2b = manager.getLogger(Logger.GLOBAL_LOGGER_NAME); + assertNotNull(logger2); + assertNotNull(logger2b); + assertEquals(logger2, global); + assertEquals(logger2b, global); + Logger logger3 = manager.getLogger(""); + Logger logger3b = manager.getLogger(""); + assertNull(logger3); + assertNull(logger3b); + Logger root = new Bridge.CustomLogger(""); + manager.addLogger(root); + Logger logger4 = manager.getLogger(""); + Logger logger4b = manager.getLogger(""); + assertNotNull(logger4); + assertNotNull(logger4b); + assertEquals(logger4, root); + assertEquals(logger4b, root); + + Bridge.changeContext(); + + // this is not a supported configuration: + // We are in an applet context with several log managers. + // We haowever need to check our assumptions... + + // Applet context => root logger and global logger are not null. + // root == LogManager.getLogManager().rootLogger + // global == Logger.global + + Logger logger5 = manager.getLogger(""); + Logger logger5b = manager.getLogger(""); + Logger expectedRoot = (System.getSecurityManager() != null + ? LogManager.getLogManager().getLogger("") + : root); + + assertNotNull(logger5); + assertNotNull(logger5b); + assertEquals(logger5, expectedRoot); + assertEquals(logger5b, expectedRoot); + if (System.getSecurityManager() != null) { + assertNotEquals(logger5, root); + assertNotEquals(logger5b, root); + } + + Logger global2 = new Bridge.CustomLogger(Logger.GLOBAL_LOGGER_NAME); + manager.addLogger(global2); // adding a global logger will not work in applet context + // we will always get back the global logger. + // this could be considered as a bug... + Logger logger6 = manager.getLogger(Logger.GLOBAL_LOGGER_NAME); + Logger logger6b = manager.getLogger(Logger.GLOBAL_LOGGER_NAME); + Logger expectedGlobal = (System.getSecurityManager() != null + ? Logger.getGlobal() + : global); + assertNotNull(logger6); + assertNotNull(logger6b); + assertEquals(logger6, expectedGlobal); // adding a global logger will not work in applet context + assertEquals(logger6b, expectedGlobal); // adding a global logger will not work in applet context + + Logger root2 = new Bridge.CustomLogger(""); + manager.addLogger(root2); // adding a root logger will not work in applet context + // we will always get back the default manager's root logger. + // this could be considered as a bug... + Logger logger7 = manager.getLogger(""); + Logger logger7b = manager.getLogger(""); + assertNotNull(logger7); + assertNotNull(logger7b); + assertEquals(logger7, expectedRoot); // adding a global logger will not work in applet context + assertEquals(logger7b, expectedRoot); // adding a global logger will not work in applet context + assertNotEquals(logger7, root2); + assertNotEquals(logger7b, root2); + } + } + + public static void testParent(Logger logger) { + Logger l = logger; + while (l.getParent() != null) { + l = l.getParent(); + } + assertEquals("", l.getName()); + } + + public static class TestError extends RuntimeException { + public TestError(String msg) { + super(msg); + } + } + + public static void assertNotNull(Object obj) { + if (obj == null) throw new NullPointerException(); + } + + public static void assertNull(Object obj) { + if (obj != null) throw new TestError("Null expected, got "+obj); + } + + public static void assertEquals(Object o1, Object o2) { + if (o1 != o2) { + throw new TestError(o1 + " != " + o2); + } + } + + public static void assertNotEquals(Object o1, Object o2) { + if (o1 == o2) { + throw new TestError(o1 + " == " + o2); + } + } +} From e8a1440b915ef8825198fef6c3286fd8b94fbef0 Mon Sep 17 00:00:00 2001 From: Eugene Drobitko Date: Tue, 2 Jul 2013 07:45:16 -0300 Subject: [PATCH 110/127] 8019580: Build Script Change for Nashorn promotion testing Reviewed-by: jlaskey --- nashorn/make/build.xml | 22 ++++++++++++++-------- 1 file changed, 14 insertions(+), 8 deletions(-) diff --git a/nashorn/make/build.xml b/nashorn/make/build.xml index 7c05e789fe9..7e2d999d328 100644 --- a/nashorn/make/build.xml +++ b/nashorn/make/build.xml @@ -124,7 +124,7 @@ - + @@ -139,7 +139,13 @@ - + + + + + + + Builds the javafx shell. @@ -238,7 +244,7 @@ - + @@ -462,24 +468,24 @@ - + - + - + - + - + From 518a9bf3d069b990f4f91ccf67040f06123c2c2b Mon Sep 17 00:00:00 2001 From: Marcus Lagergren Date: Tue, 2 Jul 2013 13:50:19 +0200 Subject: [PATCH 111/127] 8016667: Wrong bytecode when testing/setting due to null check shortcut checking against primitive too Reviewed-by: jlaskey, sundar --- .../internal/codegen/CodeGenerator.java | 4 ++- nashorn/test/script/basic/JDK-8016667.js | 34 +++++++++++++++++++ 2 files changed, 37 insertions(+), 1 deletion(-) create mode 100644 nashorn/test/script/basic/JDK-8016667.js diff --git a/nashorn/src/jdk/nashorn/internal/codegen/CodeGenerator.java b/nashorn/src/jdk/nashorn/internal/codegen/CodeGenerator.java index 6205888f1ff..1b25bd1b697 100644 --- a/nashorn/src/jdk/nashorn/internal/codegen/CodeGenerator.java +++ b/nashorn/src/jdk/nashorn/internal/codegen/CodeGenerator.java @@ -1462,7 +1462,9 @@ final class CodeGenerator extends NodeOperatorVisitor Date: Tue, 2 Jul 2013 05:28:31 -0700 Subject: [PATCH 112/127] 8017463: [TEST_BUG] 2 tests from tools/pack200/ remain about 1 GB of data in work directory after execution Reviewed-by: mchung --- jdk/test/tools/pack200/AttributeTests.java | 1 + jdk/test/tools/pack200/BandIntegrity.java | 5 ++- jdk/test/tools/pack200/CommandLineTests.java | 8 +++- jdk/test/tools/pack200/InstructionTests.java | 1 + jdk/test/tools/pack200/Pack200Props.java | 6 ++- jdk/test/tools/pack200/Pack200Test.java | 5 ++- .../tools/pack200/PackageVersionTest.java | 6 +-- jdk/test/tools/pack200/RepackTest.java | 3 +- jdk/test/tools/pack200/T7007157.java | 3 +- jdk/test/tools/pack200/TestExceptions.java | 5 ++- jdk/test/tools/pack200/TimeStamp.java | 3 +- .../tools/pack200/UnpackerMemoryTest.java | 3 +- jdk/test/tools/pack200/Utils.java | 38 +++++++++++++++++-- .../typeannos/TestTypeAnnotations.java | 1 + 14 files changed, 68 insertions(+), 20 deletions(-) diff --git a/jdk/test/tools/pack200/AttributeTests.java b/jdk/test/tools/pack200/AttributeTests.java index bcf4c7c9282..09b9986175c 100644 --- a/jdk/test/tools/pack200/AttributeTests.java +++ b/jdk/test/tools/pack200/AttributeTests.java @@ -37,6 +37,7 @@ public class AttributeTests { public static void main(String... args) throws Exception { test6746111(); testMethodParameters(); + Utils.cleanup(); } /* diff --git a/jdk/test/tools/pack200/BandIntegrity.java b/jdk/test/tools/pack200/BandIntegrity.java index 1145972267f..2a59f3b8c13 100644 --- a/jdk/test/tools/pack200/BandIntegrity.java +++ b/jdk/test/tools/pack200/BandIntegrity.java @@ -40,7 +40,7 @@ import java.util.List; * the java packer and unpacker must be called in the same java instance. */ public class BandIntegrity { - public static void main(String... args) throws IOException { + public static void main(String... args) throws IOException { File testFile = new File("test.jar"); Utils.jar("cvf", testFile.getName(), "-C", Utils.TEST_CLS_DIR.getAbsolutePath(), @@ -56,6 +56,7 @@ public class BandIntegrity { Utils.createFile(configFile, scratch); File outFile = new File("out.jar"); Utils.repack(testFile, outFile, true, - "-v", "--config-file=" + configFile.getName()); + "-v", "--config-file=" + configFile.getName()); + Utils.cleanup(); } } diff --git a/jdk/test/tools/pack200/CommandLineTests.java b/jdk/test/tools/pack200/CommandLineTests.java index 4e0c8b1e003..2a53b309046 100644 --- a/jdk/test/tools/pack200/CommandLineTests.java +++ b/jdk/test/tools/pack200/CommandLineTests.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2007, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2007, 2013, 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 @@ -83,6 +83,11 @@ public class CommandLineTests { Utils.recursiveCopy(Utils.JavaSDK, EXP_SDK); creatConfigFile(); } + // cleanup the test area + static void cleanup() throws IOException { + Utils.recursiveDelete(EXP_SDK); + Utils.cleanup(); + } // Hopefully, this should be kept in sync with what the installer does. static void creatConfigFile() throws IOException { @@ -172,6 +177,7 @@ public class CommandLineTests { init(); testJRE(); testJDK(); + cleanup(); // cleanup only if we pass successfully } catch (IOException ioe) { throw new RuntimeException(ioe); } diff --git a/jdk/test/tools/pack200/InstructionTests.java b/jdk/test/tools/pack200/InstructionTests.java index 171fe4ee88a..569b7a0acb0 100644 --- a/jdk/test/tools/pack200/InstructionTests.java +++ b/jdk/test/tools/pack200/InstructionTests.java @@ -35,6 +35,7 @@ import java.util.List; public class InstructionTests { public static void main(String... args) throws Exception { testInvokeOpCodes(); + Utils.cleanup(); } /* * the following should produce invokestatic and invokespecial diff --git a/jdk/test/tools/pack200/Pack200Props.java b/jdk/test/tools/pack200/Pack200Props.java index 61b718ea9d9..50fb0b14743 100644 --- a/jdk/test/tools/pack200/Pack200Props.java +++ b/jdk/test/tools/pack200/Pack200Props.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2010, 2013, 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 @@ -31,6 +31,7 @@ */ import java.io.File; +import java.io.IOException; import java.util.ArrayList; import java.util.HashMap; import java.util.List; @@ -45,11 +46,12 @@ import java.util.jar.Pack200.Packer; public class Pack200Props { - public static void main(String... args) { + public static void main(String... args) throws IOException { verifyDefaults(); File out = new File("test" + Utils.PACK_FILE_EXT); out.delete(); verifySegmentLimit(out); + Utils.cleanup(); } static void verifySegmentLimit(File outFile) { diff --git a/jdk/test/tools/pack200/Pack200Test.java b/jdk/test/tools/pack200/Pack200Test.java index d897bf86824..b4226f2845a 100644 --- a/jdk/test/tools/pack200/Pack200Test.java +++ b/jdk/test/tools/pack200/Pack200Test.java @@ -66,7 +66,7 @@ public class Pack200Test { } } - private static void doPackUnpack() { + private static void doPackUnpack() throws IOException { for (File in : jarList) { JarOutputStream javaUnpackerStream = null; JarOutputStream nativeUnpackerStream = null; @@ -117,12 +117,13 @@ public class Pack200Test { Utils.close((Closeable) jarFile); } } + Utils.cleanup(); // cleanup artifacts, if successful run } /** * @param args the command line arguments */ - public static void main(String[] args) { + public static void main(String[] args) throws IOException { // select the jars carefully, adding more jars will increase the // testing time, especially for jprt. jarList.add(Utils.locateJar("tools.jar")); diff --git a/jdk/test/tools/pack200/PackageVersionTest.java b/jdk/test/tools/pack200/PackageVersionTest.java index fe6d5d9cb59..dc109b8a391 100644 --- a/jdk/test/tools/pack200/PackageVersionTest.java +++ b/jdk/test/tools/pack200/PackageVersionTest.java @@ -1,6 +1,5 @@ - /* - * Copyright (c) 2010, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2010, 2013, 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 @@ -54,7 +53,7 @@ public class PackageVersionTest { public final static int JAVA7_PACKAGE_MAJOR_VERSION = 170; public final static int JAVA7_PACKAGE_MINOR_VERSION = 1; - public static void main(String... args) { + public static void main(String... args) throws IOException { if (!javaHome.getName().endsWith("jre")) { throw new RuntimeException("Error: requires an SDK to run"); } @@ -78,6 +77,7 @@ public class PackageVersionTest { // test for resource file, ie. no class files verifyPack("Test6.java", JAVA5_PACKAGE_MAJOR_VERSION, JAVA5_PACKAGE_MINOR_VERSION); + Utils.cleanup(); } static void verify6991164() { diff --git a/jdk/test/tools/pack200/RepackTest.java b/jdk/test/tools/pack200/RepackTest.java index 774e0d66eb3..8a3d86e7c94 100644 --- a/jdk/test/tools/pack200/RepackTest.java +++ b/jdk/test/tools/pack200/RepackTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2013, 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 @@ -36,6 +36,7 @@ public class RepackTest { public static void main(String... args) throws Exception { testRepack(); + Utils.cleanup(); } /* diff --git a/jdk/test/tools/pack200/T7007157.java b/jdk/test/tools/pack200/T7007157.java index 72f8792c22b..29a8ca7fc1f 100644 --- a/jdk/test/tools/pack200/T7007157.java +++ b/jdk/test/tools/pack200/T7007157.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2010, 2013, 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,5 +63,6 @@ public class T7007157 { Utils.close(fos); Utils.close(jarFile); } + Utils.cleanup(); } } diff --git a/jdk/test/tools/pack200/TestExceptions.java b/jdk/test/tools/pack200/TestExceptions.java index 0778cf5c7e1..1b6f39a78cc 100644 --- a/jdk/test/tools/pack200/TestExceptions.java +++ b/jdk/test/tools/pack200/TestExceptions.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2010, 2013, 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 @@ -219,12 +219,13 @@ public class TestExceptions { } } - public static void main(String... args) { + public static void main(String... args) throws IOException { init(); pack200Test1(); pack200Test2(); pack200Test3(); unpack200Test1(); + Utils.cleanup(); } // containers for test inputs and management diff --git a/jdk/test/tools/pack200/TimeStamp.java b/jdk/test/tools/pack200/TimeStamp.java index 8dfc2d9bc2e..acce4624aab 100644 --- a/jdk/test/tools/pack200/TimeStamp.java +++ b/jdk/test/tools/pack200/TimeStamp.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2010, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2010, 2013, 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 @@ -149,6 +149,7 @@ public class TimeStamp { Utils.close(jf1); Utils.close(jf2); } + Utils.cleanup(); if (errors > 0) { throw new RuntimeException("FAIL:" + errors + " error(s) encounted"); } diff --git a/jdk/test/tools/pack200/UnpackerMemoryTest.java b/jdk/test/tools/pack200/UnpackerMemoryTest.java index fc63d154f90..ec8ffb6a402 100644 --- a/jdk/test/tools/pack200/UnpackerMemoryTest.java +++ b/jdk/test/tools/pack200/UnpackerMemoryTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2010, 2013, 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 @@ -81,6 +81,7 @@ public class UnpackerMemoryTest { Utils.close(fos); } } + Utils.cleanup(); } } diff --git a/jdk/test/tools/pack200/Utils.java b/jdk/test/tools/pack200/Utils.java index df3426431d4..b1bc2f894b1 100644 --- a/jdk/test/tools/pack200/Utils.java +++ b/jdk/test/tools/pack200/Utils.java @@ -75,6 +75,7 @@ class Utils { static final File TEST_CLS_DIR = new File(System.getProperty("test.classes")); static final String VERIFIER_DIR_NAME = "pack200-verifier"; static final File VerifierJar = new File(VERIFIER_DIR_NAME + JAR_FILE_EXT); + static final File XCLASSES = new File("xclasses"); private Utils() {} // all static @@ -95,8 +96,7 @@ class Utils { } List javaFileList = findFiles(srcDir, createFilter(JAVA_FILE_EXT)); File tmpFile = File.createTempFile("javac", ".tmp"); - File classesDir = new File("xclasses"); - classesDir.mkdirs(); + XCLASSES.mkdirs(); FileOutputStream fos = null; PrintStream ps = null; try { @@ -111,14 +111,14 @@ class Utils { } compiler("-d", - "xclasses", + XCLASSES.getName(), "@" + tmpFile.getAbsolutePath()); jar("cvfe", VerifierJar.getName(), "sun.tools.pack.verify.Main", "-C", - "xclasses", + XCLASSES.getName(), "."); } @@ -175,6 +175,33 @@ class Utils { }; } + /* + * clean up all the usual suspects + */ + static void cleanup() throws IOException { + recursiveDelete(XCLASSES); + List toDelete = new ArrayList<>(); + toDelete.addAll(Utils.findFiles(new File("."), + Utils.createFilter(".out"))); + toDelete.addAll(Utils.findFiles(new File("."), + Utils.createFilter(".bak"))); + toDelete.addAll(Utils.findFiles(new File("."), + Utils.createFilter(".jar"))); + toDelete.addAll(Utils.findFiles(new File("."), + Utils.createFilter(".pack"))); + toDelete.addAll(Utils.findFiles(new File("."), + Utils.createFilter(".bnd"))); + toDelete.addAll(Utils.findFiles(new File("."), + Utils.createFilter(".txt"))); + toDelete.addAll(Utils.findFiles(new File("."), + Utils.createFilter(".idx"))); + toDelete.addAll(Utils.findFiles(new File("."), + Utils.createFilter(".gidx"))); + for (File f : toDelete) { + f.delete(); + } + } + static final FileFilter DIR_FILTER = new FileFilter() { public boolean accept(File pathname) { if (pathname.isDirectory()) { @@ -199,6 +226,9 @@ class Utils { Files.createDirectories(parent); } Files.copy(src.toPath(), dst.toPath(), COPY_ATTRIBUTES, REPLACE_EXISTING); + if (dst.isDirectory() && !dst.canWrite()) { + dst.setWritable(true); + } } static String baseName(File file, String extension) { diff --git a/jdk/test/tools/pack200/typeannos/TestTypeAnnotations.java b/jdk/test/tools/pack200/typeannos/TestTypeAnnotations.java index 598185aaabc..f00801b5b14 100644 --- a/jdk/test/tools/pack200/typeannos/TestTypeAnnotations.java +++ b/jdk/test/tools/pack200/typeannos/TestTypeAnnotations.java @@ -41,5 +41,6 @@ public class TestTypeAnnotations { "-C", Utils.TEST_CLS_DIR.getAbsolutePath(), "."); Utils.testWithRepack(testFile, "--unknown-attribute=error"); + Utils.cleanup(); } } From f05a001210e3def3d85a39d99fc4cd323b1f70e2 Mon Sep 17 00:00:00 2001 From: Athijegannathan Sundararajan Date: Tue, 2 Jul 2013 18:00:15 +0530 Subject: [PATCH 113/127] 8019553: NPE on illegal l-value for increment and decrement Reviewed-by: jlaskey, attila, lagergren --- .../jdk/nashorn/internal/parser/Parser.java | 29 +++--- .../runtime/resources/Messages.properties | 1 + nashorn/test/script/basic/JDK-8019553.js | 43 +++++++++ .../test/script/basic/JDK-8019553.js.EXPECTED | 12 +++ nashorn/test/script/basic/NASHORN-51.js | 8 +- .../test/script/basic/NASHORN-51.js.EXPECTED | 96 ++++++++++++++----- .../test/script/error/NASHORN-57.js.EXPECTED | 2 +- 7 files changed, 150 insertions(+), 41 deletions(-) create mode 100644 nashorn/test/script/basic/JDK-8019553.js create mode 100644 nashorn/test/script/basic/JDK-8019553.js.EXPECTED diff --git a/nashorn/src/jdk/nashorn/internal/parser/Parser.java b/nashorn/src/jdk/nashorn/internal/parser/Parser.java index bc3b7598896..181dcf83dd4 100644 --- a/nashorn/src/jdk/nashorn/internal/parser/Parser.java +++ b/nashorn/src/jdk/nashorn/internal/parser/Parser.java @@ -535,15 +535,12 @@ loop: if (!(lhs instanceof AccessNode || lhs instanceof IndexNode || lhs instanceof IdentNode)) { - if (env._early_lvalue_error) { - throw error(JSErrorType.REFERENCE_ERROR, AbstractParser.message("invalid.lvalue"), lhs.getToken()); - } - return referenceError(lhs, rhs); + return referenceError(lhs, rhs, env._early_lvalue_error); } if (lhs instanceof IdentNode) { if (!checkIdentLValue((IdentNode)lhs)) { - return referenceError(lhs, rhs); + return referenceError(lhs, rhs, false); } verifyStrictIdent((IdentNode)lhs, "assignment"); } @@ -2617,7 +2614,10 @@ loop: } } - private static RuntimeNode referenceError(final Node lhs, final Node rhs) { + private RuntimeNode referenceError(final Node lhs, final Node rhs, final boolean earlyError) { + if (earlyError) { + throw error(JSErrorType.REFERENCE_ERROR, AbstractParser.message("invalid.lvalue"), lhs.getToken()); + } final ArrayList args = new ArrayList<>(); args.add(lhs); if (rhs == null) { @@ -2695,18 +2695,18 @@ loop: final Node lhs = leftHandSideExpression(); // ++, -- without operand.. if (lhs == null) { - // error would have been issued when looking for 'lhs' - return null; + throw error(AbstractParser.message("expected.lvalue", type.getNameOrType())); } + if (!(lhs instanceof AccessNode || lhs instanceof IndexNode || lhs instanceof IdentNode)) { - return referenceError(lhs, null); + return referenceError(lhs, null, env._early_lvalue_error); } if (lhs instanceof IdentNode) { if (!checkIdentLValue((IdentNode)lhs)) { - return referenceError(lhs, null); + return referenceError(lhs, null, false); } verifyStrictIdent((IdentNode)lhs, "operand for " + opType.getName() + " operator"); } @@ -2725,16 +2725,21 @@ loop: case DECPREFIX: final TokenType opType = type; final Node lhs = expression; + // ++, -- without operand.. + if (lhs == null) { + throw error(AbstractParser.message("expected.lvalue", type.getNameOrType())); + } + if (!(lhs instanceof AccessNode || lhs instanceof IndexNode || lhs instanceof IdentNode)) { next(); - return referenceError(lhs, null); + return referenceError(lhs, null, env._early_lvalue_error); } if (lhs instanceof IdentNode) { if (!checkIdentLValue((IdentNode)lhs)) { next(); - return referenceError(lhs, null); + return referenceError(lhs, null, false); } verifyStrictIdent((IdentNode)lhs, "operand for " + opType.getName() + " operator"); } diff --git a/nashorn/src/jdk/nashorn/internal/runtime/resources/Messages.properties b/nashorn/src/jdk/nashorn/internal/runtime/resources/Messages.properties index a9c6c589093..83c0a5abb00 100644 --- a/nashorn/src/jdk/nashorn/internal/runtime/resources/Messages.properties +++ b/nashorn/src/jdk/nashorn/internal/runtime/resources/Messages.properties @@ -43,6 +43,7 @@ parser.error.expected.operand=Expected an operand but found {0} parser.error.expected.stmt=Expected statement but found {0} parser.error.expected.comma=Expected comma but found {0} parser.error.expected.property.id=Expected property id but found {0} +parser.error.expected.lvalue=Expected l-value but found {0} parser.error.expected=Expected {0} but found {1} parser.error.invalid.return=Invalid return statement parser.error.no.func.decl.here=Function declarations can only occur at program or function body level. You should use a function expression here instead. diff --git a/nashorn/test/script/basic/JDK-8019553.js b/nashorn/test/script/basic/JDK-8019553.js new file mode 100644 index 00000000000..d754618718a --- /dev/null +++ b/nashorn/test/script/basic/JDK-8019553.js @@ -0,0 +1,43 @@ +/* + * Copyright (c) 2010, 2013, 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. + */ + +/** + * JDK-8019553: NPE on illegal l-value for increment and decrement + * + * @test + * @run + */ + +function check(str) { + try { + eval(str); + fail("SyntaxError expected for: " + str); + } catch (e) { + print(e.toString().replace(/\\/g, '/')); + } +} + +check("++ +3"); +check("++ -7"); +check("-- +2"); +check("-- -8"); diff --git a/nashorn/test/script/basic/JDK-8019553.js.EXPECTED b/nashorn/test/script/basic/JDK-8019553.js.EXPECTED new file mode 100644 index 00000000000..78d22beac0f --- /dev/null +++ b/nashorn/test/script/basic/JDK-8019553.js.EXPECTED @@ -0,0 +1,12 @@ +SyntaxError: test/script/basic/JDK-8019553.js#33:1:3 Expected l-value but found + +++ +3 + ^ +SyntaxError: test/script/basic/JDK-8019553.js#33:1:3 Expected l-value but found - +++ -7 + ^ +SyntaxError: test/script/basic/JDK-8019553.js#33:1:3 Expected l-value but found + +-- +2 + ^ +SyntaxError: test/script/basic/JDK-8019553.js#33:1:3 Expected l-value but found - +-- -8 + ^ diff --git a/nashorn/test/script/basic/NASHORN-51.js b/nashorn/test/script/basic/NASHORN-51.js index 044bce94062..bc41d79bebf 100644 --- a/nashorn/test/script/basic/NASHORN-51.js +++ b/nashorn/test/script/basic/NASHORN-51.js @@ -35,28 +35,28 @@ for (i in literals) { eval(literals[i] + "++"); print("ERROR!! post increment : " + literals[i]); } catch (e) { - print(e); + print(e.toString().replace(/\\/g, '/')); } try { eval(literals[i] + "--"); print("ERROR!! post decrement : " + literals[i]); } catch (e) { - print(e); + print(e.toString().replace(/\\/g, '/')); } try { eval("++" + literals[i]); print("ERROR!! pre increment : " + literals[i]); } catch (e) { - print(e); + print(e.toString().replace(/\\/g, '/')); } try { eval("--" + literals[i]); print("ERROR!! pre decrement : " + literals[i]); } catch (e) { - print(e); + print(e.toString().replace(/\\/g, '/')); } } diff --git a/nashorn/test/script/basic/NASHORN-51.js.EXPECTED b/nashorn/test/script/basic/NASHORN-51.js.EXPECTED index 9fc05c3f1b4..9479f7e1995 100644 --- a/nashorn/test/script/basic/NASHORN-51.js.EXPECTED +++ b/nashorn/test/script/basic/NASHORN-51.js.EXPECTED @@ -1,24 +1,72 @@ -ReferenceError: "1" can not be used as the left-hand side of assignment -ReferenceError: "1" can not be used as the left-hand side of assignment -ReferenceError: "1" can not be used as the left-hand side of assignment -ReferenceError: "1" can not be used as the left-hand side of assignment -ReferenceError: "0" can not be used as the left-hand side of assignment -ReferenceError: "0" can not be used as the left-hand side of assignment -ReferenceError: "0" can not be used as the left-hand side of assignment -ReferenceError: "0" can not be used as the left-hand side of assignment -ReferenceError: "3.14" can not be used as the left-hand side of assignment -ReferenceError: "3.14" can not be used as the left-hand side of assignment -ReferenceError: "3.14" can not be used as the left-hand side of assignment -ReferenceError: "3.14" can not be used as the left-hand side of assignment -ReferenceError: "true" can not be used as the left-hand side of assignment -ReferenceError: "true" can not be used as the left-hand side of assignment -ReferenceError: "true" can not be used as the left-hand side of assignment -ReferenceError: "true" can not be used as the left-hand side of assignment -ReferenceError: "false" can not be used as the left-hand side of assignment -ReferenceError: "false" can not be used as the left-hand side of assignment -ReferenceError: "false" can not be used as the left-hand side of assignment -ReferenceError: "false" can not be used as the left-hand side of assignment -ReferenceError: "null" can not be used as the left-hand side of assignment -ReferenceError: "null" can not be used as the left-hand side of assignment -ReferenceError: "null" can not be used as the left-hand side of assignment -ReferenceError: "null" can not be used as the left-hand side of assignment +ReferenceError: test/script/basic/NASHORN-51.js#35:1:0 Invalid left hand side for assignment +1++ +^ +ReferenceError: test/script/basic/NASHORN-51.js#42:1:0 Invalid left hand side for assignment +1-- +^ +ReferenceError: test/script/basic/NASHORN-51.js#49:1:2 Invalid left hand side for assignment +++1 + ^ +ReferenceError: test/script/basic/NASHORN-51.js#56:1:2 Invalid left hand side for assignment +--1 + ^ +ReferenceError: test/script/basic/NASHORN-51.js#35:1:0 Invalid left hand side for assignment +0++ +^ +ReferenceError: test/script/basic/NASHORN-51.js#42:1:0 Invalid left hand side for assignment +0-- +^ +ReferenceError: test/script/basic/NASHORN-51.js#49:1:2 Invalid left hand side for assignment +++0 + ^ +ReferenceError: test/script/basic/NASHORN-51.js#56:1:2 Invalid left hand side for assignment +--0 + ^ +ReferenceError: test/script/basic/NASHORN-51.js#35:1:0 Invalid left hand side for assignment +3.14++ +^ +ReferenceError: test/script/basic/NASHORN-51.js#42:1:0 Invalid left hand side for assignment +3.14-- +^ +ReferenceError: test/script/basic/NASHORN-51.js#49:1:2 Invalid left hand side for assignment +++3.14 + ^ +ReferenceError: test/script/basic/NASHORN-51.js#56:1:2 Invalid left hand side for assignment +--3.14 + ^ +ReferenceError: test/script/basic/NASHORN-51.js#35:1:0 Invalid left hand side for assignment +true++ +^ +ReferenceError: test/script/basic/NASHORN-51.js#42:1:0 Invalid left hand side for assignment +true-- +^ +ReferenceError: test/script/basic/NASHORN-51.js#49:1:2 Invalid left hand side for assignment +++true + ^ +ReferenceError: test/script/basic/NASHORN-51.js#56:1:2 Invalid left hand side for assignment +--true + ^ +ReferenceError: test/script/basic/NASHORN-51.js#35:1:0 Invalid left hand side for assignment +false++ +^ +ReferenceError: test/script/basic/NASHORN-51.js#42:1:0 Invalid left hand side for assignment +false-- +^ +ReferenceError: test/script/basic/NASHORN-51.js#49:1:2 Invalid left hand side for assignment +++false + ^ +ReferenceError: test/script/basic/NASHORN-51.js#56:1:2 Invalid left hand side for assignment +--false + ^ +ReferenceError: test/script/basic/NASHORN-51.js#35:1:0 Invalid left hand side for assignment +null++ +^ +ReferenceError: test/script/basic/NASHORN-51.js#42:1:0 Invalid left hand side for assignment +null-- +^ +ReferenceError: test/script/basic/NASHORN-51.js#49:1:2 Invalid left hand side for assignment +++null + ^ +ReferenceError: test/script/basic/NASHORN-51.js#56:1:2 Invalid left hand side for assignment +--null + ^ diff --git a/nashorn/test/script/error/NASHORN-57.js.EXPECTED b/nashorn/test/script/error/NASHORN-57.js.EXPECTED index 5a93b597c0e..c9c51de1292 100644 --- a/nashorn/test/script/error/NASHORN-57.js.EXPECTED +++ b/nashorn/test/script/error/NASHORN-57.js.EXPECTED @@ -1,3 +1,3 @@ -test/script/error/NASHORN-57.js:35:2 Expected statement but found ; +test/script/error/NASHORN-57.js:35:2 Expected l-value but found ; ++; ^ From 1e7c006d39af10810f916e1c05e9c7b970d9f6aa Mon Sep 17 00:00:00 2001 From: Coleen Phillimore Date: Tue, 2 Jul 2013 08:42:37 -0400 Subject: [PATCH 114/127] 8015391: NPG: With -XX:+UseCompressedKlassPointers OOME due to exhausted metadata space could occur when metaspace is almost empty Allocate medium chunks for class metaspace when class loader has lots of classes Reviewed-by: mgerdin, jmasa --- hotspot/src/share/vm/memory/metaspace.cpp | 74 ++++++++++++---------- hotspot/src/share/vm/memory/universe.cpp | 16 +++-- hotspot/src/share/vm/memory/universe.hpp | 13 ++-- hotspot/src/share/vm/runtime/vmStructs.cpp | 4 -- 4 files changed, 61 insertions(+), 46 deletions(-) diff --git a/hotspot/src/share/vm/memory/metaspace.cpp b/hotspot/src/share/vm/memory/metaspace.cpp index c840b9363ef..07aa706d5fc 100644 --- a/hotspot/src/share/vm/memory/metaspace.cpp +++ b/hotspot/src/share/vm/memory/metaspace.cpp @@ -70,7 +70,7 @@ enum ChunkSizes { // in words. SpecializedChunk = 128, ClassSmallChunk = 256, SmallChunk = 512, - ClassMediumChunk = 1 * K, + ClassMediumChunk = 4 * K, MediumChunk = 8 * K, HumongousChunkGranularity = 8 }; @@ -580,7 +580,6 @@ class SpaceManager : public CHeapObj { // Number of small chunks to allocate to a manager // If class space manager, small chunks are unlimited static uint const _small_chunk_limit; - bool has_small_chunk_limit() { return !vs_list()->is_class(); } // Sum of all space in allocated chunks size_t _allocated_blocks_words; @@ -1298,13 +1297,18 @@ size_t MetaspaceGC::delta_capacity_until_GC(size_t word_size) { bool MetaspaceGC::should_expand(VirtualSpaceList* vsl, size_t word_size) { - size_t committed_capacity_bytes = MetaspaceAux::allocated_capacity_bytes(); // If the user wants a limit, impose one. - size_t max_metaspace_size_bytes = MaxMetaspaceSize; - size_t metaspace_size_bytes = MetaspaceSize; - if (!FLAG_IS_DEFAULT(MaxMetaspaceSize) && - MetaspaceAux::reserved_in_bytes() >= MaxMetaspaceSize) { - return false; + // The reason for someone using this flag is to limit reserved space. So + // for non-class virtual space, compare against virtual spaces that are reserved. + // For class virtual space, we only compare against the committed space, not + // reserved space, because this is a larger space prereserved for compressed + // class pointers. + if (!FLAG_IS_DEFAULT(MaxMetaspaceSize)) { + size_t real_allocated = Metaspace::space_list()->virtual_space_total() + + MetaspaceAux::allocated_capacity_bytes(Metaspace::ClassType); + if (real_allocated >= MaxMetaspaceSize) { + return false; + } } // Class virtual space should always be expanded. Call GC for the other @@ -1318,11 +1322,12 @@ bool MetaspaceGC::should_expand(VirtualSpaceList* vsl, size_t word_size) { } - // If the capacity is below the minimum capacity, allow the // expansion. Also set the high-water-mark (capacity_until_GC) // to that minimum capacity so that a GC will not be induced // until that minimum capacity is exceeded. + size_t committed_capacity_bytes = MetaspaceAux::allocated_capacity_bytes(); + size_t metaspace_size_bytes = MetaspaceSize; if (committed_capacity_bytes < metaspace_size_bytes || capacity_until_GC() == 0) { set_capacity_until_GC(metaspace_size_bytes); @@ -1866,13 +1871,11 @@ size_t SpaceManager::sum_waste_in_chunks_in_use(ChunkIndex index) const { Metachunk* chunk = chunks_in_use(index); // Count the free space in all the chunk but not the // current chunk from which allocations are still being done. - if (chunk != NULL) { - Metachunk* prev = chunk; - while (chunk != NULL && chunk != current_chunk()) { + while (chunk != NULL) { + if (chunk != current_chunk()) { result += chunk->free_word_size(); - prev = chunk; - chunk = chunk->next(); } + chunk = chunk->next(); } return result; } @@ -1961,8 +1964,7 @@ size_t SpaceManager::calc_chunk_size(size_t word_size) { // chunks will be allocated. size_t chunk_word_size; if (chunks_in_use(MediumIndex) == NULL && - (!has_small_chunk_limit() || - sum_count_in_chunks_in_use(SmallIndex) < _small_chunk_limit)) { + sum_count_in_chunks_in_use(SmallIndex) < _small_chunk_limit) { chunk_word_size = (size_t) small_chunk_size(); if (word_size + Metachunk::overhead() > small_chunk_size()) { chunk_word_size = medium_chunk_size(); @@ -2671,10 +2673,10 @@ void MetaspaceAux::print_on(outputStream* out, Metaspace::MetadataType mdtype) { // Print total fragmentation for class and data metaspaces separately void MetaspaceAux::print_waste(outputStream* out) { - size_t specialized_waste = 0, small_waste = 0, medium_waste = 0, large_waste = 0; - size_t specialized_count = 0, small_count = 0, medium_count = 0, large_count = 0; - size_t cls_specialized_waste = 0, cls_small_waste = 0, cls_medium_waste = 0, cls_large_waste = 0; - size_t cls_specialized_count = 0, cls_small_count = 0, cls_medium_count = 0, cls_large_count = 0; + size_t specialized_waste = 0, small_waste = 0, medium_waste = 0; + size_t specialized_count = 0, small_count = 0, medium_count = 0, humongous_count = 0; + size_t cls_specialized_waste = 0, cls_small_waste = 0, cls_medium_waste = 0; + size_t cls_specialized_count = 0, cls_small_count = 0, cls_medium_count = 0, cls_humongous_count = 0; ClassLoaderDataGraphMetaspaceIterator iter; while (iter.repeat()) { @@ -2686,8 +2688,7 @@ void MetaspaceAux::print_waste(outputStream* out) { small_count += msp->vsm()->sum_count_in_chunks_in_use(SmallIndex); medium_waste += msp->vsm()->sum_waste_in_chunks_in_use(MediumIndex); medium_count += msp->vsm()->sum_count_in_chunks_in_use(MediumIndex); - large_waste += msp->vsm()->sum_waste_in_chunks_in_use(HumongousIndex); - large_count += msp->vsm()->sum_count_in_chunks_in_use(HumongousIndex); + humongous_count += msp->vsm()->sum_count_in_chunks_in_use(HumongousIndex); cls_specialized_waste += msp->class_vsm()->sum_waste_in_chunks_in_use(SpecializedIndex); cls_specialized_count += msp->class_vsm()->sum_count_in_chunks_in_use(SpecializedIndex); @@ -2695,20 +2696,23 @@ void MetaspaceAux::print_waste(outputStream* out) { cls_small_count += msp->class_vsm()->sum_count_in_chunks_in_use(SmallIndex); cls_medium_waste += msp->class_vsm()->sum_waste_in_chunks_in_use(MediumIndex); cls_medium_count += msp->class_vsm()->sum_count_in_chunks_in_use(MediumIndex); - cls_large_waste += msp->class_vsm()->sum_waste_in_chunks_in_use(HumongousIndex); - cls_large_count += msp->class_vsm()->sum_count_in_chunks_in_use(HumongousIndex); + cls_humongous_count += msp->class_vsm()->sum_count_in_chunks_in_use(HumongousIndex); } } out->print_cr("Total fragmentation waste (words) doesn't count free space"); out->print_cr(" data: " SIZE_FORMAT " specialized(s) " SIZE_FORMAT ", " SIZE_FORMAT " small(s) " SIZE_FORMAT ", " - SIZE_FORMAT " medium(s) " SIZE_FORMAT, + SIZE_FORMAT " medium(s) " SIZE_FORMAT ", " + "large count " SIZE_FORMAT, specialized_count, specialized_waste, small_count, - small_waste, medium_count, medium_waste); + small_waste, medium_count, medium_waste, humongous_count); out->print_cr(" class: " SIZE_FORMAT " specialized(s) " SIZE_FORMAT ", " - SIZE_FORMAT " small(s) " SIZE_FORMAT, + SIZE_FORMAT " small(s) " SIZE_FORMAT ", " + SIZE_FORMAT " medium(s) " SIZE_FORMAT ", " + "large count " SIZE_FORMAT, cls_specialized_count, cls_specialized_waste, - cls_small_count, cls_small_waste); + cls_small_count, cls_small_waste, + cls_medium_count, cls_medium_waste, cls_humongous_count); } // Dump global metaspace things from the end of ClassLoaderDataGraph @@ -3049,18 +3053,24 @@ Metablock* Metaspace::allocate(ClassLoaderData* loader_data, size_t word_size, if (Verbose && TraceMetadataChunkAllocation) { gclog_or_tty->print_cr("Metaspace allocation failed for size " SIZE_FORMAT, word_size); - if (loader_data->metaspace_or_null() != NULL) loader_data->metaspace_or_null()->dump(gclog_or_tty); + if (loader_data->metaspace_or_null() != NULL) loader_data->dump(gclog_or_tty); MetaspaceAux::dump(gclog_or_tty); } // -XX:+HeapDumpOnOutOfMemoryError and -XX:OnOutOfMemoryError support - report_java_out_of_memory("Metadata space"); + const char* space_string = (mdtype == ClassType) ? "Class Metadata space" : + "Metadata space"; + report_java_out_of_memory(space_string); if (JvmtiExport::should_post_resource_exhausted()) { JvmtiExport::post_resource_exhausted( JVMTI_RESOURCE_EXHAUSTED_OOM_ERROR, - "Metadata space"); + space_string); + } + if (mdtype == ClassType) { + THROW_OOP_0(Universe::out_of_memory_error_class_metaspace()); + } else { + THROW_OOP_0(Universe::out_of_memory_error_metaspace()); } - THROW_OOP_0(Universe::out_of_memory_error_perm_gen()); } } return Metablock::initialize(result, word_size); diff --git a/hotspot/src/share/vm/memory/universe.cpp b/hotspot/src/share/vm/memory/universe.cpp index 2b3576d6784..fe91faa9922 100644 --- a/hotspot/src/share/vm/memory/universe.cpp +++ b/hotspot/src/share/vm/memory/universe.cpp @@ -110,7 +110,8 @@ LatestMethodOopCache* Universe::_finalizer_register_cache = NULL; LatestMethodOopCache* Universe::_loader_addClass_cache = NULL; ActiveMethodOopsCache* Universe::_reflect_invoke_cache = NULL; oop Universe::_out_of_memory_error_java_heap = NULL; -oop Universe::_out_of_memory_error_perm_gen = NULL; +oop Universe::_out_of_memory_error_metaspace = NULL; +oop Universe::_out_of_memory_error_class_metaspace = NULL; oop Universe::_out_of_memory_error_array_size = NULL; oop Universe::_out_of_memory_error_gc_overhead_limit = NULL; objArrayOop Universe::_preallocated_out_of_memory_error_array = NULL; @@ -179,7 +180,8 @@ void Universe::oops_do(OopClosure* f, bool do_all) { f->do_oop((oop*)&_the_null_string); f->do_oop((oop*)&_the_min_jint_string); f->do_oop((oop*)&_out_of_memory_error_java_heap); - f->do_oop((oop*)&_out_of_memory_error_perm_gen); + f->do_oop((oop*)&_out_of_memory_error_metaspace); + f->do_oop((oop*)&_out_of_memory_error_class_metaspace); f->do_oop((oop*)&_out_of_memory_error_array_size); f->do_oop((oop*)&_out_of_memory_error_gc_overhead_limit); f->do_oop((oop*)&_preallocated_out_of_memory_error_array); @@ -561,7 +563,8 @@ bool Universe::should_fill_in_stack_trace(Handle throwable) { // a potential loop which could happen if an out of memory occurs when attempting // to allocate the backtrace. return ((throwable() != Universe::_out_of_memory_error_java_heap) && - (throwable() != Universe::_out_of_memory_error_perm_gen) && + (throwable() != Universe::_out_of_memory_error_metaspace) && + (throwable() != Universe::_out_of_memory_error_class_metaspace) && (throwable() != Universe::_out_of_memory_error_array_size) && (throwable() != Universe::_out_of_memory_error_gc_overhead_limit)); } @@ -1011,7 +1014,8 @@ bool universe_post_init() { k = SystemDictionary::resolve_or_fail(vmSymbols::java_lang_OutOfMemoryError(), true, CHECK_false); k_h = instanceKlassHandle(THREAD, k); Universe::_out_of_memory_error_java_heap = k_h->allocate_instance(CHECK_false); - Universe::_out_of_memory_error_perm_gen = k_h->allocate_instance(CHECK_false); + Universe::_out_of_memory_error_metaspace = k_h->allocate_instance(CHECK_false); + Universe::_out_of_memory_error_class_metaspace = k_h->allocate_instance(CHECK_false); Universe::_out_of_memory_error_array_size = k_h->allocate_instance(CHECK_false); Universe::_out_of_memory_error_gc_overhead_limit = k_h->allocate_instance(CHECK_false); @@ -1044,7 +1048,9 @@ bool universe_post_init() { java_lang_Throwable::set_message(Universe::_out_of_memory_error_java_heap, msg()); msg = java_lang_String::create_from_str("Metadata space", CHECK_false); - java_lang_Throwable::set_message(Universe::_out_of_memory_error_perm_gen, msg()); + java_lang_Throwable::set_message(Universe::_out_of_memory_error_metaspace, msg()); + msg = java_lang_String::create_from_str("Class Metadata space", CHECK_false); + java_lang_Throwable::set_message(Universe::_out_of_memory_error_class_metaspace, msg()); msg = java_lang_String::create_from_str("Requested array size exceeds VM limit", CHECK_false); java_lang_Throwable::set_message(Universe::_out_of_memory_error_array_size, msg()); diff --git a/hotspot/src/share/vm/memory/universe.hpp b/hotspot/src/share/vm/memory/universe.hpp index b9ff266a008..23a29489193 100644 --- a/hotspot/src/share/vm/memory/universe.hpp +++ b/hotspot/src/share/vm/memory/universe.hpp @@ -177,10 +177,12 @@ class Universe: AllStatic { static LatestMethodOopCache* _finalizer_register_cache; // static method for registering finalizable objects static LatestMethodOopCache* _loader_addClass_cache; // method for registering loaded classes in class loader vector static ActiveMethodOopsCache* _reflect_invoke_cache; // method for security checks - static oop _out_of_memory_error_java_heap; // preallocated error object (no backtrace) - static oop _out_of_memory_error_perm_gen; // preallocated error object (no backtrace) - static oop _out_of_memory_error_array_size;// preallocated error object (no backtrace) - static oop _out_of_memory_error_gc_overhead_limit; // preallocated error object (no backtrace) + // preallocated error objects (no backtrace) + static oop _out_of_memory_error_java_heap; + static oop _out_of_memory_error_metaspace; + static oop _out_of_memory_error_class_metaspace; + static oop _out_of_memory_error_array_size; + static oop _out_of_memory_error_gc_overhead_limit; static Array* _the_empty_int_array; // Canonicalized int array static Array* _the_empty_short_array; // Canonicalized short array @@ -348,7 +350,8 @@ class Universe: AllStatic { // may or may not have a backtrace. If error has a backtrace then the stack trace is already // filled in. static oop out_of_memory_error_java_heap() { return gen_out_of_memory_error(_out_of_memory_error_java_heap); } - static oop out_of_memory_error_perm_gen() { return gen_out_of_memory_error(_out_of_memory_error_perm_gen); } + static oop out_of_memory_error_metaspace() { return gen_out_of_memory_error(_out_of_memory_error_metaspace); } + static oop out_of_memory_error_class_metaspace() { return gen_out_of_memory_error(_out_of_memory_error_class_metaspace); } static oop out_of_memory_error_array_size() { return gen_out_of_memory_error(_out_of_memory_error_array_size); } static oop out_of_memory_error_gc_overhead_limit() { return gen_out_of_memory_error(_out_of_memory_error_gc_overhead_limit); } diff --git a/hotspot/src/share/vm/runtime/vmStructs.cpp b/hotspot/src/share/vm/runtime/vmStructs.cpp index dff270f1631..232577f9b51 100644 --- a/hotspot/src/share/vm/runtime/vmStructs.cpp +++ b/hotspot/src/share/vm/runtime/vmStructs.cpp @@ -437,10 +437,6 @@ typedef BinaryTreeDictionary MetablockTreeDictionary; static_field(Universe, _main_thread_group, oop) \ static_field(Universe, _system_thread_group, oop) \ static_field(Universe, _the_empty_class_klass_array, objArrayOop) \ - static_field(Universe, _out_of_memory_error_java_heap, oop) \ - static_field(Universe, _out_of_memory_error_perm_gen, oop) \ - static_field(Universe, _out_of_memory_error_array_size, oop) \ - static_field(Universe, _out_of_memory_error_gc_overhead_limit, oop) \ static_field(Universe, _null_ptr_exception_instance, oop) \ static_field(Universe, _arithmetic_exception_instance, oop) \ static_field(Universe, _vm_exception, oop) \ From 8ff9291b055305538c1b550d6a34f12aa8950bc1 Mon Sep 17 00:00:00 2001 From: Marcus Lagergren Date: Tue, 2 Jul 2013 14:50:39 +0200 Subject: [PATCH 115/127] 8017082: Long array literals were slightly broken Reviewed-by: sundar, attila --- .../internal/codegen/CodeGenerator.java | 2 +- .../nashorn/internal/codegen/types/Type.java | 10 +++--- .../jdk/nashorn/internal/ir/LiteralNode.java | 25 +++++++++++++- nashorn/test/script/basic/JDK-8017082.js | 33 +++++++++++++++++++ 4 files changed, 64 insertions(+), 6 deletions(-) create mode 100644 nashorn/test/script/basic/JDK-8017082.js diff --git a/nashorn/src/jdk/nashorn/internal/codegen/CodeGenerator.java b/nashorn/src/jdk/nashorn/internal/codegen/CodeGenerator.java index 1b25bd1b697..414d1bb8bc3 100644 --- a/nashorn/src/jdk/nashorn/internal/codegen/CodeGenerator.java +++ b/nashorn/src/jdk/nashorn/internal/codegen/CodeGenerator.java @@ -1110,7 +1110,7 @@ final class CodeGenerator extends NodeOperatorVisitor, BytecodeOps { @Override public Type aload(final MethodVisitor method) { - method.visitInsn(IALOAD); - return INT; + method.visitInsn(LALOAD); + return LONG; } @Override public Type newarray(final MethodVisitor method) { - method.visitIntInsn(NEWARRAY, T_INT); + method.visitIntInsn(NEWARRAY, T_LONG); return this; } @Override public Type getElementType() { - return INT; + return LONG; } }; diff --git a/nashorn/src/jdk/nashorn/internal/ir/LiteralNode.java b/nashorn/src/jdk/nashorn/internal/ir/LiteralNode.java index c34f9d94c5b..a7cea66a256 100644 --- a/nashorn/src/jdk/nashorn/internal/ir/LiteralNode.java +++ b/nashorn/src/jdk/nashorn/internal/ir/LiteralNode.java @@ -621,8 +621,10 @@ public abstract class LiteralNode extends Node implements PropertyKey { elementType = Type.INT; analyzeElements(); - if (elementType == Type.INT) { + if (elementType.isInteger()) { presetIntArray(); + } else if (elementType.isLong()) { + presetLongArray(); } else if (elementType.isNumeric()) { presetNumberArray(); } else { @@ -649,6 +651,25 @@ public abstract class LiteralNode extends Node implements PropertyKey { postsets = Arrays.copyOf(computed, nComputed); } + private void presetLongArray() { + final long[] array = new long[value.length]; + final int[] computed = new int[value.length]; + int nComputed = 0; + + for (int i = 0; i < value.length; i++) { + final Object element = objectAsConstant(value[i]); + + if (element instanceof Number) { + array[i] = ((Number)element).longValue(); + } else { + computed[nComputed++] = i; + } + } + + presets = array; + postsets = Arrays.copyOf(computed, nComputed); + } + private void presetNumberArray() { final double[] array = new double[value.length]; final int[] computed = new int[value.length]; @@ -746,6 +767,8 @@ public abstract class LiteralNode extends Node implements PropertyKey { public Type getType() { if (elementType.isInteger()) { return Type.INT_ARRAY; + } else if (elementType.isLong()) { + return Type.LONG_ARRAY; } else if (elementType.isNumeric()) { return Type.NUMBER_ARRAY; } else { diff --git a/nashorn/test/script/basic/JDK-8017082.js b/nashorn/test/script/basic/JDK-8017082.js new file mode 100644 index 00000000000..5ac96324fcc --- /dev/null +++ b/nashorn/test/script/basic/JDK-8017082.js @@ -0,0 +1,33 @@ +/* + * Copyright (c) 2010, 2013, 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. + */ + +/** + * Long array literals were broken + * + * @test + * @run + */ +function f() { + var z= c>>e>>>0; + var x = [z]; +} From 5f717a6674fbce21a4d9691389defad6f8182cfe Mon Sep 17 00:00:00 2001 From: Daniel Fuchs Date: Tue, 2 Jul 2013 19:47:58 +0200 Subject: [PATCH 116/127] 7184195: java.util.logging.Logger.getGlobal().info() doesn't log without configuration Due to subtle synchronization issues between LogManager & Logger class initialization the global logger doesn't have its 'manager' field initialized until the LogManager is initialized. This fix will ensure that the global logger has its 'manager' field set when getGlobal() is called. Reviewed-by: mchung, plevart --- .../classes/java/util/logging/LogManager.java | 13 +- .../classes/java/util/logging/Logger.java | 21 ++ .../Logger/getGlobal/TestGetGlobal.java | 73 +++++++ .../Logger/getGlobal/TestGetGlobalByName.java | 73 +++++++ .../getGlobal/TestGetGlobalConcurrent.java | 184 ++++++++++++++++++ .../Logger/getGlobal/logging.properties | 2 + .../java/util/logging/Logger/getGlobal/policy | 7 + .../testgetglobal/BadLogManagerImpl.java | 46 +++++ .../testgetglobal/DummyLogManagerImpl.java | 35 ++++ .../getGlobal/testgetglobal/HandlerImpl.java | 46 +++++ .../testgetglobal/LogManagerImpl1.java | 42 ++++ .../testgetglobal/LogManagerImpl2.java | 42 ++++ .../testgetglobal/LogManagerImpl3.java | 59 ++++++ 13 files changed, 639 insertions(+), 4 deletions(-) create mode 100644 jdk/test/java/util/logging/Logger/getGlobal/TestGetGlobal.java create mode 100644 jdk/test/java/util/logging/Logger/getGlobal/TestGetGlobalByName.java create mode 100644 jdk/test/java/util/logging/Logger/getGlobal/TestGetGlobalConcurrent.java create mode 100644 jdk/test/java/util/logging/Logger/getGlobal/logging.properties create mode 100644 jdk/test/java/util/logging/Logger/getGlobal/policy create mode 100644 jdk/test/java/util/logging/Logger/getGlobal/testgetglobal/BadLogManagerImpl.java create mode 100644 jdk/test/java/util/logging/Logger/getGlobal/testgetglobal/DummyLogManagerImpl.java create mode 100644 jdk/test/java/util/logging/Logger/getGlobal/testgetglobal/HandlerImpl.java create mode 100644 jdk/test/java/util/logging/Logger/getGlobal/testgetglobal/LogManagerImpl1.java create mode 100644 jdk/test/java/util/logging/Logger/getGlobal/testgetglobal/LogManagerImpl2.java create mode 100644 jdk/test/java/util/logging/Logger/getGlobal/testgetglobal/LogManagerImpl3.java diff --git a/jdk/src/share/classes/java/util/logging/LogManager.java b/jdk/src/share/classes/java/util/logging/LogManager.java index 228d4636f5d..0d63468b3cc 100644 --- a/jdk/src/share/classes/java/util/logging/LogManager.java +++ b/jdk/src/share/classes/java/util/logging/LogManager.java @@ -203,12 +203,17 @@ public class LogManager { // Adding the global Logger. Doing so in the Logger. // would deadlock with the LogManager.. - Logger.global.setLogManager(manager); + // Do not call Logger.getGlobal() here as this might trigger + // the deadlock too. + @SuppressWarnings("deprecation") + final Logger global = Logger.global; + global.setLogManager(manager); + // Make sure the global logger will be registered in the // global manager's default contexts. - manager.addLogger(Logger.global); - manager.systemContext.addLocalLogger(Logger.global, false); - manager.userContext.addLocalLogger(Logger.global, false); + manager.addLogger(global); + manager.systemContext.addLocalLogger(global, false); + manager.userContext.addLocalLogger(global, false); // We don't call readConfiguration() here, as we may be running // very early in the JVM startup sequence. Instead readConfiguration diff --git a/jdk/src/share/classes/java/util/logging/Logger.java b/jdk/src/share/classes/java/util/logging/Logger.java index 11b0c0ce672..1c959ecd6a1 100644 --- a/jdk/src/share/classes/java/util/logging/Logger.java +++ b/jdk/src/share/classes/java/util/logging/Logger.java @@ -232,6 +232,27 @@ public class Logger { * @since 1.7 */ public static final Logger getGlobal() { + // In order to break a cyclic dependence between the LogManager + // and Logger static initializers causing deadlocks, the global + // logger is created with a special constructor that does not + // initialize its log manager. + // + // If an application calls Logger.getGlobal() before any logger + // has been initialized, it is therefore possible that the + // LogManager class has not been initialized yet, and therefore + // Logger.global.manager will be null. + // + // In order to finish the initialization of the global logger, we + // will therefore call LogManager.getLogManager() here. + // + // Care must be taken *not* to call Logger.getGlobal() in + // LogManager static initializers in order to avoid such + // deadlocks. + // + if (global != null && global.manager == null) { + // Complete initialization of the global Logger. + global.manager = LogManager.getLogManager(); + } return global; } diff --git a/jdk/test/java/util/logging/Logger/getGlobal/TestGetGlobal.java b/jdk/test/java/util/logging/Logger/getGlobal/TestGetGlobal.java new file mode 100644 index 00000000000..dd901ed5f92 --- /dev/null +++ b/jdk/test/java/util/logging/Logger/getGlobal/TestGetGlobal.java @@ -0,0 +1,73 @@ +/* + * Copyright (c) 2013, 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. + */ +import java.util.Arrays; +import java.util.List; +import java.util.logging.Logger; + +/** + * @test + * @bug 7184195 + * @summary checks that java.util.logging.Logger.getGlobal().info() logs without configuration + * @build TestGetGlobal testgetglobal.HandlerImpl testgetglobal.LogManagerImpl1 testgetglobal.LogManagerImpl2 testgetglobal.LogManagerImpl3 testgetglobal.BadLogManagerImpl testgetglobal.DummyLogManagerImpl + * @run main/othervm/timeout=10 TestGetGlobal + * @run main/othervm/timeout=10/policy=policy -Djava.security.manager TestGetGlobal + * @run main/othervm/timeout=10 -Djava.util.logging.manager=testgetglobal.LogManagerImpl1 TestGetGlobal + * @run main/othervm/timeout=10/policy=policy -Djava.security.manager -Djava.util.logging.manager=testgetglobal.LogManagerImpl1 TestGetGlobal + * @run main/othervm/timeout=10 -Djava.util.logging.manager=testgetglobal.LogManagerImpl2 TestGetGlobal + * @run main/othervm/timeout=10/policy=policy -Djava.security.manager -Djava.util.logging.manager=testgetglobal.LogManagerImpl2 TestGetGlobal + * @run main/othervm/timeout=10 -Djava.util.logging.manager=testgetglobal.LogManagerImpl3 TestGetGlobal + * @run main/othervm/timeout=10/policy=policy -Djava.security.manager -Djava.util.logging.manager=testgetglobal.LogManagerImpl3 TestGetGlobal + * @run main/othervm/timeout=10 -Djava.util.logging.manager=testgetglobal.BadLogManagerImpl TestGetGlobal + * @run main/othervm/timeout=10/policy=policy -Djava.security.manager -Djava.util.logging.manager=testgetglobal.BadLogManagerImpl TestGetGlobal + * @run main/othervm/timeout=10 -Djava.util.logging.manager=testgetglobal.DummyLogManagerImpl TestGetGlobal + * @run main/othervm/timeout=10/policy=policy -Djava.security.manager -Djava.util.logging.manager=testgetglobal.DummyLogManagerImpl TestGetGlobal + * @author danielfuchs + */ +public class TestGetGlobal { + + final static String[] messages = { + "1. This message should not appear on the console.", + "2. This message should appear on the console.", + "3. This message should now appear on the console too." + }; + + static { + System.setProperty("java.util.logging.config.file", + System.getProperty("test.src", ".") + java.io.File.separator + "logging.properties"); + } + + public static void main(String... args) { + + Logger.global.info(messages[0]); // at this point LogManager is not + // initialized yet, so this message should not appear. + Logger.getGlobal().info(messages[1]); // calling getGlobal() will + // initialize the LogManager - and thus this message should appear. + Logger.global.info(messages[2]); // Now that the LogManager is + // initialized, this message should appear too. + + final List expected = Arrays.asList(Arrays.copyOfRange(messages, 1, messages.length)); + if (!testgetglobal.HandlerImpl.received.equals(expected)) { + throw new Error("Unexpected message list: "+testgetglobal.HandlerImpl.received+" vs "+ expected); + } + } +} diff --git a/jdk/test/java/util/logging/Logger/getGlobal/TestGetGlobalByName.java b/jdk/test/java/util/logging/Logger/getGlobal/TestGetGlobalByName.java new file mode 100644 index 00000000000..62580a8bc3b --- /dev/null +++ b/jdk/test/java/util/logging/Logger/getGlobal/TestGetGlobalByName.java @@ -0,0 +1,73 @@ +/* + * Copyright (c) 2013, 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. + */ +import java.util.Arrays; +import java.util.List; +import java.util.logging.Logger; + +/** + * @test + * @bug 7184195 + * @summary checks that java.util.logging.Logger.getLogger(Logger.GLOBAL_LOGGER_NAME).info() logs without configuration + * @build TestGetGlobalByName testgetglobal.HandlerImpl testgetglobal.LogManagerImpl1 testgetglobal.LogManagerImpl2 testgetglobal.LogManagerImpl3 testgetglobal.BadLogManagerImpl testgetglobal.DummyLogManagerImpl + * @run main/othervm/timeout=10 TestGetGlobalByName + * @run main/othervm/timeout=10/policy=policy -Djava.security.manager TestGetGlobalByName + * @run main/othervm/timeout=10 -Djava.util.logging.manager=testgetglobal.LogManagerImpl1 TestGetGlobalByName + * @run main/othervm/timeout=10/policy=policy -Djava.security.manager -Djava.util.logging.manager=testgetglobal.LogManagerImpl TestGetGlobalByName + * @run main/othervm/timeout=10 -Djava.util.logging.manager=testgetglobal.LogManagerImpl2 TestGetGlobalByName + * @run main/othervm/timeout=10/policy=policy -Djava.security.manager -Djava.util.logging.manager=testgetglobal.LogManagerImpl2 TestGetGlobalByName + * @run main/othervm/timeout=10 -Djava.util.logging.manager=testgetglobal.LogManagerImpl3 TestGetGlobalByName + * @run main/othervm/timeout=10/policy=policy -Djava.security.manager -Djava.util.logging.manager=testgetglobal.LogManagerImpl3 TestGetGlobalByName + * @run main/othervm/timeout=10 -Djava.util.logging.manager=testgetglobal.BadLogManagerImpl TestGetGlobalByName + * @run main/othervm/timeout=10/policy=policy -Djava.security.manager -Djava.util.logging.manager=testgetglobal.BadLogManagerImpl TestGetGlobalByName + * @run main/othervm/timeout=10 -Djava.util.logging.manager=testgetglobal.DummyLogManagerImpl TestGetGlobalByName + * @run main/othervm/timeout=10/policy=policy -Djava.security.manager -Djava.util.logging.manager=testgetglobal.DummyLogManagerImpl TestGetGlobalByName + * @author danielfuchs + */ +public class TestGetGlobalByName { + + final static String[] messages = { + "1. This message should not appear on the console.", + "2. This message should appear on the console.", + "3. This message should now appear on the console too." + }; + + static { + System.setProperty("java.util.logging.config.file", + System.getProperty("test.src", ".") + java.io.File.separator + "logging.properties"); + } + + public static void main(String... args) { + + Logger.global.info(messages[0]); // at this point LogManager is not + // initialized yet, so this message should not appear. + Logger.getLogger(Logger.GLOBAL_LOGGER_NAME).info(messages[1]); // calling getLogger() will + // initialize the LogManager - and thus this message should appear. + Logger.global.info(messages[2]); // Now that the LogManager is + // initialized, this message should appear too. + + final List expected = Arrays.asList(Arrays.copyOfRange(messages, 1, messages.length)); + if (!testgetglobal.HandlerImpl.received.equals(expected)) { + throw new Error("Unexpected message list: "+testgetglobal.HandlerImpl.received+" vs "+ expected); + } + } +} diff --git a/jdk/test/java/util/logging/Logger/getGlobal/TestGetGlobalConcurrent.java b/jdk/test/java/util/logging/Logger/getGlobal/TestGetGlobalConcurrent.java new file mode 100644 index 00000000000..4ef38ce3611 --- /dev/null +++ b/jdk/test/java/util/logging/Logger/getGlobal/TestGetGlobalConcurrent.java @@ -0,0 +1,184 @@ +/* + * Copyright (c) 2013, 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. + */ +import java.util.Arrays; +import java.util.List; +import java.util.logging.Logger; + +/** + * @test + * @bug 7184195 + * @summary checks that java.util.logging.Logger.getGlobal().info() logs without configuration + * @build TestGetGlobalConcurrent testgetglobal.HandlerImpl testgetglobal.LogManagerImpl1 testgetglobal.LogManagerImpl2 testgetglobal.LogManagerImpl3 testgetglobal.BadLogManagerImpl testgetglobal.DummyLogManagerImpl + * @run main/othervm/timeout=10 TestGetGlobalConcurrent + * @run main/othervm/timeout=10/policy=policy -Djava.security.manager TestGetGlobalConcurrent + * @run main/othervm/timeout=10 -Djava.util.logging.manager=testgetglobal.LogManagerImpl TestGetGlobalConcurrent + * @run main/othervm/timeout=10/policy=policy -Djava.security.manager -Djava.util.logging.manager=testgetglobal.LogManagerImpl TestGetGlobalConcurrent + * @run main/othervm/timeout=10 -Djava.util.logging.manager=testgetglobal.LogManagerImpl2 TestGetGlobalConcurrent + * @run main/othervm/timeout=10/policy=policy -Djava.security.manager -Djava.util.logging.manager=testgetglobal.LogManagerImpl2 TestGetGlobalConcurrent + * @run main/othervm/timeout=10 -Djava.util.logging.manager=testgetglobal.LogManagerImpl3 TestGetGlobalConcurrent + * @run main/othervm/timeout=10/policy=policy -Djava.security.manager -Djava.util.logging.manager=testgetglobal.LogManagerImpl3 TestGetGlobalConcurrent + * @run main/othervm/timeout=10 -Djava.util.logging.manager=testgetglobal.BadLogManagerImpl TestGetGlobalConcurrent + * @run main/othervm/timeout=10/policy=policy -Djava.security.manager -Djava.util.logging.manager=testgetglobal.BadLogManagerImpl TestGetGlobalConcurrent + * @run main/othervm/timeout=10 -Djava.util.logging.manager=testgetglobal.DummyLogManagerImpl TestGetGlobalConcurrent + * @run main/othervm/timeout=10/policy=policy -Djava.security.manager -Djava.util.logging.manager=testgetglobal.DummyLogManagerImpl TestGetGlobalConcurrent + * @author danielfuchs + */ +public class TestGetGlobalConcurrent { + + final static String[] messages = { + "1. This message should not appear on the console.", + "2. This message should appear on the console.", + "3. This message should now appear on the console too.", + "4. This message should appear on the console.", + "5. This message should now appear on the console too.", + "6. This message should appear on the console.", + "7. This message should now appear on the console too.", + "8. This message should appear on the console.", + "9. This message should now appear on the console too." + }; + + static { + System.setProperty("java.util.logging.config.file", + System.getProperty("test.src", ".") + java.io.File.separator + "logging.properties"); + } + + public static void test1() { + final int nb = 1; + final int i = 2*nb + 1; + Logger.getGlobal().info(messages[i]); // calling getGlobal() will + // initialize the LogManager - and thus this message should appear. + Logger.global.info(messages[i+1]); // Now that the LogManager is + // initialized, this message should appear too. + + final List expected = Arrays.asList(Arrays.copyOfRange(messages, i, i+2)); + if (!testgetglobal.HandlerImpl.received.containsAll(expected)) { + fail(new Error("Unexpected message list: "+testgetglobal.HandlerImpl.received+" vs "+ expected)); + } + } + public static void test2() { + final int nb = 2; + final int i = 2*nb + 1; + Logger.getLogger(Logger.GLOBAL_LOGGER_NAME).info(messages[i]); // calling getGlobal() will + // initialize the LogManager - and thus this message should appear. + Logger.global.info(messages[i+1]); // Now that the LogManager is + // initialized, this message should appear too. + + final List expected = Arrays.asList(Arrays.copyOfRange(messages, i, i+2)); + if (!testgetglobal.HandlerImpl.received.containsAll(expected)) { + fail(new Error("Unexpected message list: "+testgetglobal.HandlerImpl.received+" vs "+ expected)); + } + } + public static void test3() { + final int nb = 3; + final int i = 2*nb + 1; + java.util.logging.LogManager.getLogManager(); + Logger.getGlobal().info(messages[i]); // calling getGlobal() will + // initialize the LogManager - and thus this message should appear. + Logger.global.info(messages[i+1]); // Now that the LogManager is + // initialized, this message should appear too. + + final List expected = Arrays.asList(Arrays.copyOfRange(messages, i, i+2)); + if (!testgetglobal.HandlerImpl.received.containsAll(expected)) { + fail(new Error("Unexpected message list: "+testgetglobal.HandlerImpl.received+" vs "+ expected)); + } + } + public static void test4() { + log = new MyLogger("foo.bar"); + java.util.logging.LogManager.getLogManager().addLogger(log); + } + + + private static volatile Throwable failed = null; + private static volatile Logger log = null; + + public static class MyLogger extends Logger { + public MyLogger(String name) { + super(name, null); + } + } + + public static void fail(Throwable failure) { + failure.printStackTrace(); + if (failed == null) failed = failure; + } + + public static class WaitAndRun implements Runnable { + private final Runnable run; + public WaitAndRun(Runnable run) { + this.run = run; + } + public void run() { + try { + Thread.sleep(10); + run.run(); + } catch (Exception | Error x) { + fail(x); + } + } + } + + final static class Run1 implements Runnable { + public void run() { test1(); } + } + final static class Run2 implements Runnable { + public void run() { test2(); } + } + final static class Run3 implements Runnable { + public void run() { test3(); } + } + final static class Run4 implements Runnable { + public void run() { test4(); } + } + + public static void main(String... args) throws Exception { + + final Thread t1 = new Thread(new WaitAndRun(new Run1()), "test1"); + final Thread t2 = new Thread(new WaitAndRun(new Run2()), "test2"); + final Thread t3 = new Thread(new WaitAndRun(new Run3()), "test3"); + final Thread t4 = new Thread(new WaitAndRun(new Run4()), "test4"); + + t1.setDaemon(true); t2.setDaemon(true); t3.setDaemon(true); t4.setDaemon(true); + t1.start(); t2.start(); t3.start(); t4.start(); + + Thread.sleep(10); + + Logger.getGlobal().info(messages[1]); // calling getGlobal() will + // initialize the LogManager - and thus this message should appear. + Logger.global.info(messages[2]); // Now that the LogManager is + // initialized, this message should appear too. + + final List expected = Arrays.asList(Arrays.copyOfRange(messages, 1, 3)); + if (!testgetglobal.HandlerImpl.received.containsAll(expected)) { + throw new Error("Unexpected message list: "+testgetglobal.HandlerImpl.received+" vs "+ expected); + } + + + t1.join(); t2.join(); t3.join(); t4.join(); + + if (failed != null) { + throw new Error("Test failed.", failed); + } + + System.out.println("Test passed"); + } +} diff --git a/jdk/test/java/util/logging/Logger/getGlobal/logging.properties b/jdk/test/java/util/logging/Logger/getGlobal/logging.properties new file mode 100644 index 00000000000..0e201a9c60c --- /dev/null +++ b/jdk/test/java/util/logging/Logger/getGlobal/logging.properties @@ -0,0 +1,2 @@ +.level=INFO +handlers=testgetglobal.HandlerImpl diff --git a/jdk/test/java/util/logging/Logger/getGlobal/policy b/jdk/test/java/util/logging/Logger/getGlobal/policy new file mode 100644 index 00000000000..bcb7cde0da3 --- /dev/null +++ b/jdk/test/java/util/logging/Logger/getGlobal/policy @@ -0,0 +1,7 @@ +grant { + permission java.util.PropertyPermission "java.util.logging.config.file", "write"; + permission java.util.PropertyPermission "test.src", "read"; + permission java.lang.RuntimePermission "setContextClassLoader"; + permission java.lang.RuntimePermission "shutdownHooks"; + permission java.util.logging.LoggingPermission "control"; +}; diff --git a/jdk/test/java/util/logging/Logger/getGlobal/testgetglobal/BadLogManagerImpl.java b/jdk/test/java/util/logging/Logger/getGlobal/testgetglobal/BadLogManagerImpl.java new file mode 100644 index 00000000000..e3fd771ffd7 --- /dev/null +++ b/jdk/test/java/util/logging/Logger/getGlobal/testgetglobal/BadLogManagerImpl.java @@ -0,0 +1,46 @@ +/* + * Copyright (c) 2013, 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. + */ +package testgetglobal; + +import java.util.logging.LogManager; +import java.util.logging.Logger; + +/** + * This class is used to verify that calling Logger.getLogger(Logger.GLOBAL_LOGGER_NAME) + * in the constructor of a LogManager subclass installed as default + * LogManager does not cause issues beyond throwing the expected NPE. + * In that case the default LogManager class will simply be used. + * @author danielfuchs + */ +public class BadLogManagerImpl extends LogManager { + + final Logger globalLogger; + public BadLogManagerImpl() { + // The call below should generate an NPE, which will be + // catched in LogManager initializer. + globalLogger = Logger.getLogger(Logger.GLOBAL_LOGGER_NAME); + System.err.println("Global is: " + globalLogger); + throw new Error("Should not have reached here"); + } + +} diff --git a/jdk/test/java/util/logging/Logger/getGlobal/testgetglobal/DummyLogManagerImpl.java b/jdk/test/java/util/logging/Logger/getGlobal/testgetglobal/DummyLogManagerImpl.java new file mode 100644 index 00000000000..e3a48372fa7 --- /dev/null +++ b/jdk/test/java/util/logging/Logger/getGlobal/testgetglobal/DummyLogManagerImpl.java @@ -0,0 +1,35 @@ +/* + * Copyright (c) 2013, 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. + */ +package testgetglobal; + +import java.util.logging.LogManager; +import java.util.logging.Logger; + +/** + * A dummy LogManager subclass that does nothing beyond extending LogManager. + * @author danielfuchs + */ +public class DummyLogManagerImpl extends LogManager { + + +} diff --git a/jdk/test/java/util/logging/Logger/getGlobal/testgetglobal/HandlerImpl.java b/jdk/test/java/util/logging/Logger/getGlobal/testgetglobal/HandlerImpl.java new file mode 100644 index 00000000000..f8737acb25f --- /dev/null +++ b/jdk/test/java/util/logging/Logger/getGlobal/testgetglobal/HandlerImpl.java @@ -0,0 +1,46 @@ +/* + * Copyright (c) 2013, 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. + */ +package testgetglobal; + +import java.util.concurrent.CopyOnWriteArrayList; +import java.util.List; +import java.util.logging.ConsoleHandler; +import java.util.logging.LogRecord; + +/** + * + * @author danielfuchs + */ +public class HandlerImpl extends ConsoleHandler { + + public final static List received = new CopyOnWriteArrayList<>(); + + public HandlerImpl() { + } + + @Override + public void publish(LogRecord record) { + received.add(record.getMessage()); + super.publish(record); + } +} diff --git a/jdk/test/java/util/logging/Logger/getGlobal/testgetglobal/LogManagerImpl1.java b/jdk/test/java/util/logging/Logger/getGlobal/testgetglobal/LogManagerImpl1.java new file mode 100644 index 00000000000..9f3f6432a58 --- /dev/null +++ b/jdk/test/java/util/logging/Logger/getGlobal/testgetglobal/LogManagerImpl1.java @@ -0,0 +1,42 @@ +/* + * Copyright (c) 2013, 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. + */ +package testgetglobal; + +import java.util.logging.LogManager; +import java.util.logging.Logger; + +/** + * This class is used to verify that calling Logger.getGlobal() in the static + * initializer of a LogManager subclass installed as default LogManager + * does not cause issues. + * @author danielfuchs + */ +public class LogManagerImpl1 extends LogManager { + + static final Logger global; + static { + global = Logger.getGlobal(); + System.err.println("Global is: " + global); + } + +} diff --git a/jdk/test/java/util/logging/Logger/getGlobal/testgetglobal/LogManagerImpl2.java b/jdk/test/java/util/logging/Logger/getGlobal/testgetglobal/LogManagerImpl2.java new file mode 100644 index 00000000000..dd9d7aeca7f --- /dev/null +++ b/jdk/test/java/util/logging/Logger/getGlobal/testgetglobal/LogManagerImpl2.java @@ -0,0 +1,42 @@ +/* + * Copyright (c) 2013, 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. + */ +package testgetglobal; + +import java.util.logging.LogManager; +import java.util.logging.Logger; + +/** + * This class is used to verify that calling Logger.getGlobal() in the constructor + * initializer of a LogManager subclass installed as default LogManager + * does not cause issues. + * @author danielfuchs + */ +public class LogManagerImpl2 extends LogManager { + + final Logger globalLogger; + public LogManagerImpl2() { + globalLogger = Logger.getGlobal(); + System.err.println("Global is: " + globalLogger); + } + +} diff --git a/jdk/test/java/util/logging/Logger/getGlobal/testgetglobal/LogManagerImpl3.java b/jdk/test/java/util/logging/Logger/getGlobal/testgetglobal/LogManagerImpl3.java new file mode 100644 index 00000000000..f5ce01cd90d --- /dev/null +++ b/jdk/test/java/util/logging/Logger/getGlobal/testgetglobal/LogManagerImpl3.java @@ -0,0 +1,59 @@ +/* + * Copyright (c) 2013, 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. + */ +package testgetglobal; + +import java.util.logging.LogManager; +import java.util.logging.Logger; + +/** + * This class is used to verify that calling Logger.getLogger(Logger.GLOBAL_LOGGER_NAME) + * in the static initializer of a LogManager subclass installed as default + * LogManager does not cause issues beyond throwing the expected NPE. + * @author danielfuchs + */ +public class LogManagerImpl3 extends LogManager { + + static final Logger global; + static { + Logger g = null; + try { + g = Logger.getLogger(Logger.GLOBAL_LOGGER_NAME); + throw new Error("Should not have reached here"); + } catch (Exception x) { + // This is to be expected: Logger.getLogger(Logger.GLOBAL_LOGGER_NAME) + // will call LogManager.getLogManager() which will return null, since + // we haven't manage to do new LogManagerImpl3() yet. + // + System.err.println("Got expected exception - you cannot call" + + " Logger.getLogger(Logger.GLOBAL_LOGGER_NAME)" + + " in LogManager subclass static initializer: " + x); + x.printStackTrace(); + } + if (g == null) { + g = Logger.getGlobal(); + } + global = g; + System.err.println("Global is: " + global); + } + +} From 467296964c9bfb6117774b420e1807e320e398f3 Mon Sep 17 00:00:00 2001 From: Phil Race Date: Tue, 2 Jul 2013 14:25:56 -0700 Subject: [PATCH 117/127] 8019692: JDK build CC_OPT_HIGHEST setting isn't valid for Sun C++ compiler Reviewed-by: jgodinez --- jdk/make/sun/font/Makefile | 4 ++++ jdk/makefiles/CompileNativeLibraries.gmk | 3 ++- 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/jdk/make/sun/font/Makefile b/jdk/make/sun/font/Makefile index 49497661ee4..fd8c8a2c448 100644 --- a/jdk/make/sun/font/Makefile +++ b/jdk/make/sun/font/Makefile @@ -36,7 +36,11 @@ PRODUCT = sun CPLUSPLUSLIBRARY=true # Use higher optimization level +ifeq ($(PLATFORM), windows) OPTIMIZATION_LEVEL = HIGHEST +else +OPTIMIZATION_LEVEL = HIGHER +endif include $(BUILDDIR)/common/Defs.gmk diff --git a/jdk/makefiles/CompileNativeLibraries.gmk b/jdk/makefiles/CompileNativeLibraries.gmk index 0dd803cb4d8..02bf3be808c 100644 --- a/jdk/makefiles/CompileNativeLibraries.gmk +++ b/jdk/makefiles/CompileNativeLibraries.gmk @@ -1327,11 +1327,12 @@ else BUILD_LIBFONTMANAGER_FONTLIB:=$(FREETYPE2_LIBS) endif -LIBFONTMANAGER_OPTIMIZATION:=HIGHEST +LIBFONTMANAGER_OPTIMIZATION:=HIGH ifeq ($(OPENJDK_TARGET_OS),windows) LIBFONTMANAGER_EXCLUDE_FILES += X11FontScaler.c \ X11TextRenderer.c +LIBFONTMANAGER_OPTIMIZATION:=HIGHEST else LIBFONTMANAGER_EXCLUDE_FILES += fontpath.c \ lcdglyph.c From 9a359984c2c0f2e44abca5f6b0d405a99a7b647d Mon Sep 17 00:00:00 2001 From: David Chase Date: Tue, 2 Jul 2013 20:42:12 -0400 Subject: [PATCH 118/127] 7088419: Use x86 Hardware CRC32 Instruction with java.util.zip.CRC32 Add intrinsics using new instruction to interpreter, C1, C2, for suitable x86; add test Reviewed-by: kvn, twisti --- .../cpu/sparc/vm/c1_LIRAssembler_sparc.cpp | 5 +- .../cpu/sparc/vm/c1_LIRGenerator_sparc.cpp | 6 +- hotspot/src/cpu/x86/vm/assembler_x86.cpp | 49 ++- hotspot/src/cpu/x86/vm/assembler_x86.hpp | 12 + .../src/cpu/x86/vm/c1_LIRAssembler_x86.cpp | 18 +- .../src/cpu/x86/vm/c1_LIRGenerator_x86.cpp | 77 +++- hotspot/src/cpu/x86/vm/globals_x86.hpp | 3 + .../cpu/x86/vm/interpreterGenerator_x86.hpp | 4 +- hotspot/src/cpu/x86/vm/macroAssembler_x86.cpp | 198 +++++++++- hotspot/src/cpu/x86/vm/macroAssembler_x86.hpp | 27 +- .../src/cpu/x86/vm/stubGenerator_x86_32.cpp | 61 +++- .../src/cpu/x86/vm/stubGenerator_x86_64.cpp | 45 ++- hotspot/src/cpu/x86/vm/stubRoutines_x86.cpp | 130 +++++++ hotspot/src/cpu/x86/vm/stubRoutines_x86.hpp | 45 +++ .../src/cpu/x86/vm/stubRoutines_x86_32.cpp | 4 +- .../src/cpu/x86/vm/stubRoutines_x86_32.hpp | 9 +- .../src/cpu/x86/vm/stubRoutines_x86_64.cpp | 5 +- .../src/cpu/x86/vm/stubRoutines_x86_64.hpp | 12 +- .../cpu/x86/vm/templateInterpreter_x86_32.cpp | 141 +++++++- .../cpu/x86/vm/templateInterpreter_x86_64.cpp | 139 +++++++- hotspot/src/cpu/x86/vm/vm_version_x86.cpp | 24 +- hotspot/src/cpu/x86/vm/vm_version_x86.hpp | 11 +- hotspot/src/share/vm/c1/c1_GraphBuilder.cpp | 10 +- hotspot/src/share/vm/c1/c1_LIR.cpp | 32 ++ hotspot/src/share/vm/c1/c1_LIR.hpp | 28 +- hotspot/src/share/vm/c1/c1_LIRAssembler.hpp | 3 +- hotspot/src/share/vm/c1/c1_LIRGenerator.cpp | 6 + hotspot/src/share/vm/c1/c1_LIRGenerator.hpp | 3 +- hotspot/src/share/vm/c1/c1_Runtime1.cpp | 1 + hotspot/src/share/vm/classfile/vmSymbols.hpp | 11 + .../vm/interpreter/abstractInterpreter.hpp | 5 +- .../src/share/vm/interpreter/interpreter.cpp | 16 +- .../vm/interpreter/templateInterpreter.cpp | 8 +- hotspot/src/share/vm/opto/escape.cpp | 1 + hotspot/src/share/vm/opto/library_call.cpp | 337 ++++++++++++------ hotspot/src/share/vm/opto/runtime.cpp | 24 +- hotspot/src/share/vm/opto/runtime.hpp | 4 +- hotspot/src/share/vm/runtime/globals.hpp | 3 + hotspot/src/share/vm/runtime/stubRoutines.cpp | 5 +- hotspot/src/share/vm/runtime/stubRoutines.hpp | 6 + hotspot/test/compiler/7088419/CRCTest.java | 132 +++++++ 41 files changed, 1487 insertions(+), 173 deletions(-) create mode 100644 hotspot/src/cpu/x86/vm/stubRoutines_x86.cpp create mode 100644 hotspot/src/cpu/x86/vm/stubRoutines_x86.hpp create mode 100644 hotspot/test/compiler/7088419/CRCTest.java diff --git a/hotspot/src/cpu/sparc/vm/c1_LIRAssembler_sparc.cpp b/hotspot/src/cpu/sparc/vm/c1_LIRAssembler_sparc.cpp index 1cbc5c41316..64745015923 100644 --- a/hotspot/src/cpu/sparc/vm/c1_LIRAssembler_sparc.cpp +++ b/hotspot/src/cpu/sparc/vm/c1_LIRAssembler_sparc.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -2946,6 +2946,9 @@ void LIR_Assembler::monitor_address(int monitor_no, LIR_Opr dst_opr) { } } +void LIR_Assembler::emit_updatecrc32(LIR_OpUpdateCRC32* op) { + fatal("CRC32 intrinsic is not implemented on this platform"); +} void LIR_Assembler::emit_lock(LIR_OpLock* op) { Register obj = op->obj_opr()->as_register(); diff --git a/hotspot/src/cpu/sparc/vm/c1_LIRGenerator_sparc.cpp b/hotspot/src/cpu/sparc/vm/c1_LIRGenerator_sparc.cpp index 82cc696e8b7..dc3bc8691ac 100644 --- a/hotspot/src/cpu/sparc/vm/c1_LIRGenerator_sparc.cpp +++ b/hotspot/src/cpu/sparc/vm/c1_LIRGenerator_sparc.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2013, 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 @@ -784,6 +784,10 @@ void LIRGenerator::do_ArrayCopy(Intrinsic* x) { set_no_result(x); } +void LIRGenerator::do_update_CRC32(Intrinsic* x) { + fatal("CRC32 intrinsic is not implemented on this platform"); +} + // _i2l, _i2f, _i2d, _l2i, _l2f, _l2d, _f2i, _f2l, _f2d, _d2i, _d2l, _d2f // _i2b, _i2c, _i2s void LIRGenerator::do_Convert(Convert* x) { diff --git a/hotspot/src/cpu/x86/vm/assembler_x86.cpp b/hotspot/src/cpu/x86/vm/assembler_x86.cpp index 02a438f2f40..761b5c3259f 100644 --- a/hotspot/src/cpu/x86/vm/assembler_x86.cpp +++ b/hotspot/src/cpu/x86/vm/assembler_x86.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -1673,6 +1673,11 @@ void Assembler::movdqa(XMMRegister dst, XMMRegister src) { emit_simd_arith_nonds(0x6F, dst, src, VEX_SIMD_66); } +void Assembler::movdqa(XMMRegister dst, Address src) { + NOT_LP64(assert(VM_Version::supports_sse2(), "")); + emit_simd_arith_nonds(0x6F, dst, src, VEX_SIMD_66); +} + void Assembler::movdqu(XMMRegister dst, Address src) { NOT_LP64(assert(VM_Version::supports_sse2(), "")); emit_simd_arith_nonds(0x6F, dst, src, VEX_SIMD_F3); @@ -2286,6 +2291,38 @@ void Assembler::pcmpestri(XMMRegister dst, XMMRegister src, int imm8) { emit_int8(imm8); } +void Assembler::pextrd(Register dst, XMMRegister src, int imm8) { + assert(VM_Version::supports_sse4_1(), ""); + int encode = simd_prefix_and_encode(as_XMMRegister(dst->encoding()), xnoreg, src, VEX_SIMD_66, VEX_OPCODE_0F_3A, false); + emit_int8(0x16); + emit_int8((unsigned char)(0xC0 | encode)); + emit_int8(imm8); +} + +void Assembler::pextrq(Register dst, XMMRegister src, int imm8) { + assert(VM_Version::supports_sse4_1(), ""); + int encode = simd_prefix_and_encode(as_XMMRegister(dst->encoding()), xnoreg, src, VEX_SIMD_66, VEX_OPCODE_0F_3A, true); + emit_int8(0x16); + emit_int8((unsigned char)(0xC0 | encode)); + emit_int8(imm8); +} + +void Assembler::pinsrd(XMMRegister dst, Register src, int imm8) { + assert(VM_Version::supports_sse4_1(), ""); + int encode = simd_prefix_and_encode(dst, dst, as_XMMRegister(src->encoding()), VEX_SIMD_66, VEX_OPCODE_0F_3A, false); + emit_int8(0x22); + emit_int8((unsigned char)(0xC0 | encode)); + emit_int8(imm8); +} + +void Assembler::pinsrq(XMMRegister dst, Register src, int imm8) { + assert(VM_Version::supports_sse4_1(), ""); + int encode = simd_prefix_and_encode(dst, dst, as_XMMRegister(src->encoding()), VEX_SIMD_66, VEX_OPCODE_0F_3A, true); + emit_int8(0x22); + emit_int8((unsigned char)(0xC0 | encode)); + emit_int8(imm8); +} + void Assembler::pmovzxbw(XMMRegister dst, Address src) { assert(VM_Version::supports_sse4_1(), ""); InstructionMark im(this); @@ -3691,6 +3728,16 @@ void Assembler::vpbroadcastd(XMMRegister dst, XMMRegister src) { emit_int8((unsigned char)(0xC0 | encode)); } +// Carry-Less Multiplication Quadword +void Assembler::vpclmulqdq(XMMRegister dst, XMMRegister nds, XMMRegister src, int mask) { + assert(VM_Version::supports_avx() && VM_Version::supports_clmul(), ""); + bool vector256 = false; + int encode = vex_prefix_and_encode(dst, nds, src, VEX_SIMD_66, vector256, VEX_OPCODE_0F_3A); + emit_int8(0x44); + emit_int8((unsigned char)(0xC0 | encode)); + emit_int8((unsigned char)mask); +} + void Assembler::vzeroupper() { assert(VM_Version::supports_avx(), ""); (void)vex_prefix_and_encode(xmm0, xmm0, xmm0, VEX_SIMD_NONE); diff --git a/hotspot/src/cpu/x86/vm/assembler_x86.hpp b/hotspot/src/cpu/x86/vm/assembler_x86.hpp index 97a5bfc0368..31481b5808f 100644 --- a/hotspot/src/cpu/x86/vm/assembler_x86.hpp +++ b/hotspot/src/cpu/x86/vm/assembler_x86.hpp @@ -1266,6 +1266,7 @@ private: // Move Aligned Double Quadword void movdqa(XMMRegister dst, XMMRegister src); + void movdqa(XMMRegister dst, Address src); // Move Unaligned Double Quadword void movdqu(Address dst, XMMRegister src); @@ -1404,6 +1405,14 @@ private: void pcmpestri(XMMRegister xmm1, XMMRegister xmm2, int imm8); void pcmpestri(XMMRegister xmm1, Address src, int imm8); + // SSE 4.1 extract + void pextrd(Register dst, XMMRegister src, int imm8); + void pextrq(Register dst, XMMRegister src, int imm8); + + // SSE 4.1 insert + void pinsrd(XMMRegister dst, Register src, int imm8); + void pinsrq(XMMRegister dst, Register src, int imm8); + // SSE4.1 packed move void pmovzxbw(XMMRegister dst, XMMRegister src); void pmovzxbw(XMMRegister dst, Address src); @@ -1764,6 +1773,9 @@ private: // duplicate 4-bytes integer data from src into 8 locations in dest void vpbroadcastd(XMMRegister dst, XMMRegister src); + // Carry-Less Multiplication Quadword + void vpclmulqdq(XMMRegister dst, XMMRegister nds, XMMRegister src, int mask); + // AVX instruction which is used to clear upper 128 bits of YMM registers and // to avoid transaction penalty between AVX and SSE states. There is no // penalty if legacy SSE instructions are encoded using VEX prefix because diff --git a/hotspot/src/cpu/x86/vm/c1_LIRAssembler_x86.cpp b/hotspot/src/cpu/x86/vm/c1_LIRAssembler_x86.cpp index a99d7939373..b5bceeb60c6 100644 --- a/hotspot/src/cpu/x86/vm/c1_LIRAssembler_x86.cpp +++ b/hotspot/src/cpu/x86/vm/c1_LIRAssembler_x86.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -3512,6 +3512,22 @@ void LIR_Assembler::emit_arraycopy(LIR_OpArrayCopy* op) { __ bind(*stub->continuation()); } +void LIR_Assembler::emit_updatecrc32(LIR_OpUpdateCRC32* op) { + assert(op->crc()->is_single_cpu(), "crc must be register"); + assert(op->val()->is_single_cpu(), "byte value must be register"); + assert(op->result_opr()->is_single_cpu(), "result must be register"); + Register crc = op->crc()->as_register(); + Register val = op->val()->as_register(); + Register res = op->result_opr()->as_register(); + + assert_different_registers(val, crc, res); + + __ lea(res, ExternalAddress(StubRoutines::crc_table_addr())); + __ notl(crc); // ~crc + __ update_byte_crc32(crc, val, res); + __ notl(crc); // ~crc + __ mov(res, crc); +} void LIR_Assembler::emit_lock(LIR_OpLock* op) { Register obj = op->obj_opr()->as_register(); // may not be an oop diff --git a/hotspot/src/cpu/x86/vm/c1_LIRGenerator_x86.cpp b/hotspot/src/cpu/x86/vm/c1_LIRGenerator_x86.cpp index 6810ae54216..e6638581bcf 100644 --- a/hotspot/src/cpu/x86/vm/c1_LIRGenerator_x86.cpp +++ b/hotspot/src/cpu/x86/vm/c1_LIRGenerator_x86.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2013, 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 @@ -932,6 +932,81 @@ void LIRGenerator::do_ArrayCopy(Intrinsic* x) { __ arraycopy(src.result(), src_pos.result(), dst.result(), dst_pos.result(), length.result(), tmp, expected_type, flags, info); // does add_safepoint } +void LIRGenerator::do_update_CRC32(Intrinsic* x) { + assert(UseCRC32Intrinsics, "need AVX and LCMUL instructions support"); + // Make all state_for calls early since they can emit code + LIR_Opr result = rlock_result(x); + int flags = 0; + switch (x->id()) { + case vmIntrinsics::_updateCRC32: { + LIRItem crc(x->argument_at(0), this); + LIRItem val(x->argument_at(1), this); + crc.load_item(); + val.load_item(); + __ update_crc32(crc.result(), val.result(), result); + break; + } + case vmIntrinsics::_updateBytesCRC32: + case vmIntrinsics::_updateByteBufferCRC32: { + bool is_updateBytes = (x->id() == vmIntrinsics::_updateBytesCRC32); + + LIRItem crc(x->argument_at(0), this); + LIRItem buf(x->argument_at(1), this); + LIRItem off(x->argument_at(2), this); + LIRItem len(x->argument_at(3), this); + buf.load_item(); + off.load_nonconstant(); + + LIR_Opr index = off.result(); + int offset = is_updateBytes ? arrayOopDesc::base_offset_in_bytes(T_BYTE) : 0; + if(off.result()->is_constant()) { + index = LIR_OprFact::illegalOpr; + offset += off.result()->as_jint(); + } + LIR_Opr base_op = buf.result(); + +#ifndef _LP64 + if (!is_updateBytes) { // long b raw address + base_op = new_register(T_INT); + __ convert(Bytecodes::_l2i, buf.result(), base_op); + } +#else + if (index->is_valid()) { + LIR_Opr tmp = new_register(T_LONG); + __ convert(Bytecodes::_i2l, index, tmp); + index = tmp; + } +#endif + + LIR_Address* a = new LIR_Address(base_op, + index, + LIR_Address::times_1, + offset, + T_BYTE); + BasicTypeList signature(3); + signature.append(T_INT); + signature.append(T_ADDRESS); + signature.append(T_INT); + CallingConvention* cc = frame_map()->c_calling_convention(&signature); + const LIR_Opr result_reg = result_register_for(x->type()); + + LIR_Opr addr = new_pointer_register(); + __ leal(LIR_OprFact::address(a), addr); + + crc.load_item_force(cc->at(0)); + __ move(addr, cc->at(1)); + len.load_item_force(cc->at(2)); + + __ call_runtime_leaf(StubRoutines::updateBytesCRC32(), getThreadTemp(), result_reg, cc->args()); + __ move(result_reg, result); + + break; + } + default: { + ShouldNotReachHere(); + } + } +} // _i2l, _i2f, _i2d, _l2i, _l2f, _l2d, _f2i, _f2l, _f2d, _d2i, _d2l, _d2f // _i2b, _i2c, _i2s diff --git a/hotspot/src/cpu/x86/vm/globals_x86.hpp b/hotspot/src/cpu/x86/vm/globals_x86.hpp index 07ab0cfcdce..c47f7d1c193 100644 --- a/hotspot/src/cpu/x86/vm/globals_x86.hpp +++ b/hotspot/src/cpu/x86/vm/globals_x86.hpp @@ -96,6 +96,9 @@ define_pd_global(uintx, CMSYoungGenPerWorker, 64*M); // default max size of CMS product(intx, UseAVX, 99, \ "Highest supported AVX instructions set on x86/x64") \ \ + product(bool, UseCLMUL, false, \ + "Control whether CLMUL instructions can be used on x86/x64") \ + \ diagnostic(bool, UseIncDec, true, \ "Use INC, DEC instructions on x86") \ \ diff --git a/hotspot/src/cpu/x86/vm/interpreterGenerator_x86.hpp b/hotspot/src/cpu/x86/vm/interpreterGenerator_x86.hpp index 13786e4149a..08f47708cdc 100644 --- a/hotspot/src/cpu/x86/vm/interpreterGenerator_x86.hpp +++ b/hotspot/src/cpu/x86/vm/interpreterGenerator_x86.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -39,6 +39,8 @@ address generate_empty_entry(void); address generate_accessor_entry(void); address generate_Reference_get_entry(); + address generate_CRC32_update_entry(); + address generate_CRC32_updateBytes_entry(AbstractInterpreter::MethodKind kind); void lock_method(void); void generate_stack_overflow_check(void); diff --git a/hotspot/src/cpu/x86/vm/macroAssembler_x86.cpp b/hotspot/src/cpu/x86/vm/macroAssembler_x86.cpp index 98c93f99a0f..8aad6965156 100644 --- a/hotspot/src/cpu/x86/vm/macroAssembler_x86.cpp +++ b/hotspot/src/cpu/x86/vm/macroAssembler_x86.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -2794,6 +2794,15 @@ void MacroAssembler::movdqu(XMMRegister dst, AddressLiteral src) { } } +void MacroAssembler::movdqa(XMMRegister dst, AddressLiteral src) { + if (reachable(src)) { + Assembler::movdqa(dst, as_Address(src)); + } else { + lea(rscratch1, src); + Assembler::movdqa(dst, Address(rscratch1, 0)); + } +} + void MacroAssembler::movsd(XMMRegister dst, AddressLiteral src) { if (reachable(src)) { Assembler::movsd(dst, as_Address(src)); @@ -6388,6 +6397,193 @@ void MacroAssembler::encode_iso_array(Register src, Register dst, Register len, bind(L_done); } +/** + * Emits code to update CRC-32 with a byte value according to constants in table + * + * @param [in,out]crc Register containing the crc. + * @param [in]val Register containing the byte to fold into the CRC. + * @param [in]table Register containing the table of crc constants. + * + * uint32_t crc; + * val = crc_table[(val ^ crc) & 0xFF]; + * crc = val ^ (crc >> 8); + * + */ +void MacroAssembler::update_byte_crc32(Register crc, Register val, Register table) { + xorl(val, crc); + andl(val, 0xFF); + shrl(crc, 8); // unsigned shift + xorl(crc, Address(table, val, Address::times_4, 0)); +} + +/** + * Fold 128-bit data chunk + */ +void MacroAssembler::fold_128bit_crc32(XMMRegister xcrc, XMMRegister xK, XMMRegister xtmp, Register buf, int offset) { + vpclmulhdq(xtmp, xK, xcrc); // [123:64] + vpclmulldq(xcrc, xK, xcrc); // [63:0] + vpxor(xcrc, xcrc, Address(buf, offset), false /* vector256 */); + pxor(xcrc, xtmp); +} + +void MacroAssembler::fold_128bit_crc32(XMMRegister xcrc, XMMRegister xK, XMMRegister xtmp, XMMRegister xbuf) { + vpclmulhdq(xtmp, xK, xcrc); + vpclmulldq(xcrc, xK, xcrc); + pxor(xcrc, xbuf); + pxor(xcrc, xtmp); +} + +/** + * 8-bit folds to compute 32-bit CRC + * + * uint64_t xcrc; + * timesXtoThe32[xcrc & 0xFF] ^ (xcrc >> 8); + */ +void MacroAssembler::fold_8bit_crc32(XMMRegister xcrc, Register table, XMMRegister xtmp, Register tmp) { + movdl(tmp, xcrc); + andl(tmp, 0xFF); + movdl(xtmp, Address(table, tmp, Address::times_4, 0)); + psrldq(xcrc, 1); // unsigned shift one byte + pxor(xcrc, xtmp); +} + +/** + * uint32_t crc; + * timesXtoThe32[crc & 0xFF] ^ (crc >> 8); + */ +void MacroAssembler::fold_8bit_crc32(Register crc, Register table, Register tmp) { + movl(tmp, crc); + andl(tmp, 0xFF); + shrl(crc, 8); + xorl(crc, Address(table, tmp, Address::times_4, 0)); +} + +/** + * @param crc register containing existing CRC (32-bit) + * @param buf register pointing to input byte buffer (byte*) + * @param len register containing number of bytes + * @param table register that will contain address of CRC table + * @param tmp scratch register + */ +void MacroAssembler::kernel_crc32(Register crc, Register buf, Register len, Register table, Register tmp) { + assert_different_registers(crc, buf, len, table, tmp, rax); + + Label L_tail, L_tail_restore, L_tail_loop, L_exit, L_align_loop, L_aligned; + Label L_fold_tail, L_fold_128b, L_fold_512b, L_fold_512b_loop, L_fold_tail_loop; + + lea(table, ExternalAddress(StubRoutines::crc_table_addr())); + notl(crc); // ~crc + cmpl(len, 16); + jcc(Assembler::less, L_tail); + + // Align buffer to 16 bytes + movl(tmp, buf); + andl(tmp, 0xF); + jccb(Assembler::zero, L_aligned); + subl(tmp, 16); + addl(len, tmp); + + align(4); + BIND(L_align_loop); + movsbl(rax, Address(buf, 0)); // load byte with sign extension + update_byte_crc32(crc, rax, table); + increment(buf); + incrementl(tmp); + jccb(Assembler::less, L_align_loop); + + BIND(L_aligned); + movl(tmp, len); // save + shrl(len, 4); + jcc(Assembler::zero, L_tail_restore); + + // Fold crc into first bytes of vector + movdqa(xmm1, Address(buf, 0)); + movdl(rax, xmm1); + xorl(crc, rax); + pinsrd(xmm1, crc, 0); + addptr(buf, 16); + subl(len, 4); // len > 0 + jcc(Assembler::less, L_fold_tail); + + movdqa(xmm2, Address(buf, 0)); + movdqa(xmm3, Address(buf, 16)); + movdqa(xmm4, Address(buf, 32)); + addptr(buf, 48); + subl(len, 3); + jcc(Assembler::lessEqual, L_fold_512b); + + // Fold total 512 bits of polynomial on each iteration, + // 128 bits per each of 4 parallel streams. + movdqu(xmm0, ExternalAddress(StubRoutines::x86::crc_by128_masks_addr() + 32)); + + align(32); + BIND(L_fold_512b_loop); + fold_128bit_crc32(xmm1, xmm0, xmm5, buf, 0); + fold_128bit_crc32(xmm2, xmm0, xmm5, buf, 16); + fold_128bit_crc32(xmm3, xmm0, xmm5, buf, 32); + fold_128bit_crc32(xmm4, xmm0, xmm5, buf, 48); + addptr(buf, 64); + subl(len, 4); + jcc(Assembler::greater, L_fold_512b_loop); + + // Fold 512 bits to 128 bits. + BIND(L_fold_512b); + movdqu(xmm0, ExternalAddress(StubRoutines::x86::crc_by128_masks_addr() + 16)); + fold_128bit_crc32(xmm1, xmm0, xmm5, xmm2); + fold_128bit_crc32(xmm1, xmm0, xmm5, xmm3); + fold_128bit_crc32(xmm1, xmm0, xmm5, xmm4); + + // Fold the rest of 128 bits data chunks + BIND(L_fold_tail); + addl(len, 3); + jccb(Assembler::lessEqual, L_fold_128b); + movdqu(xmm0, ExternalAddress(StubRoutines::x86::crc_by128_masks_addr() + 16)); + + BIND(L_fold_tail_loop); + fold_128bit_crc32(xmm1, xmm0, xmm5, buf, 0); + addptr(buf, 16); + decrementl(len); + jccb(Assembler::greater, L_fold_tail_loop); + + // Fold 128 bits in xmm1 down into 32 bits in crc register. + BIND(L_fold_128b); + movdqu(xmm0, ExternalAddress(StubRoutines::x86::crc_by128_masks_addr())); + vpclmulqdq(xmm2, xmm0, xmm1, 0x1); + vpand(xmm3, xmm0, xmm2, false /* vector256 */); + vpclmulqdq(xmm0, xmm0, xmm3, 0x1); + psrldq(xmm1, 8); + psrldq(xmm2, 4); + pxor(xmm0, xmm1); + pxor(xmm0, xmm2); + + // 8 8-bit folds to compute 32-bit CRC. + for (int j = 0; j < 4; j++) { + fold_8bit_crc32(xmm0, table, xmm1, rax); + } + movdl(crc, xmm0); // mov 32 bits to general register + for (int j = 0; j < 4; j++) { + fold_8bit_crc32(crc, table, rax); + } + + BIND(L_tail_restore); + movl(len, tmp); // restore + BIND(L_tail); + andl(len, 0xf); + jccb(Assembler::zero, L_exit); + + // Fold the rest of bytes + align(4); + BIND(L_tail_loop); + movsbl(rax, Address(buf, 0)); // load byte with sign extension + update_byte_crc32(crc, rax, table); + increment(buf); + decrementl(len); + jccb(Assembler::greater, L_tail_loop); + + BIND(L_exit); + notl(crc); // ~c +} + #undef BIND #undef BLOCK_COMMENT diff --git a/hotspot/src/cpu/x86/vm/macroAssembler_x86.hpp b/hotspot/src/cpu/x86/vm/macroAssembler_x86.hpp index e9f409dc500..3acef073c0e 100644 --- a/hotspot/src/cpu/x86/vm/macroAssembler_x86.hpp +++ b/hotspot/src/cpu/x86/vm/macroAssembler_x86.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -899,6 +899,11 @@ public: void movdqu(XMMRegister dst, XMMRegister src) { Assembler::movdqu(dst, src); } void movdqu(XMMRegister dst, AddressLiteral src); + // Move Aligned Double Quadword + void movdqa(XMMRegister dst, Address src) { Assembler::movdqa(dst, src); } + void movdqa(XMMRegister dst, XMMRegister src) { Assembler::movdqa(dst, src); } + void movdqa(XMMRegister dst, AddressLiteral src); + void movsd(XMMRegister dst, XMMRegister src) { Assembler::movsd(dst, src); } void movsd(Address dst, XMMRegister src) { Assembler::movsd(dst, src); } void movsd(XMMRegister dst, Address src) { Assembler::movsd(dst, src); } @@ -1027,6 +1032,16 @@ public: Assembler::vinsertf128h(dst, nds, src); } + // Carry-Less Multiplication Quadword + void vpclmulldq(XMMRegister dst, XMMRegister nds, XMMRegister src) { + // 0x00 - multiply lower 64 bits [0:63] + Assembler::vpclmulqdq(dst, nds, src, 0x00); + } + void vpclmulhdq(XMMRegister dst, XMMRegister nds, XMMRegister src) { + // 0x11 - multiply upper 64 bits [64:127] + Assembler::vpclmulqdq(dst, nds, src, 0x11); + } + // Data void cmov32( Condition cc, Register dst, Address src); @@ -1143,6 +1158,16 @@ public: XMMRegister tmp1, XMMRegister tmp2, XMMRegister tmp3, XMMRegister tmp4, Register tmp5, Register result); + // CRC32 code for java.util.zip.CRC32::updateBytes() instrinsic. + void update_byte_crc32(Register crc, Register val, Register table); + void kernel_crc32(Register crc, Register buf, Register len, Register table, Register tmp); + // Fold 128-bit data chunk + void fold_128bit_crc32(XMMRegister xcrc, XMMRegister xK, XMMRegister xtmp, Register buf, int offset); + void fold_128bit_crc32(XMMRegister xcrc, XMMRegister xK, XMMRegister xtmp, XMMRegister xbuf); + // Fold 8-bit data + void fold_8bit_crc32(Register crc, Register table, Register tmp); + void fold_8bit_crc32(XMMRegister crc, Register table, XMMRegister xtmp, Register tmp); + #undef VIRTUAL }; diff --git a/hotspot/src/cpu/x86/vm/stubGenerator_x86_32.cpp b/hotspot/src/cpu/x86/vm/stubGenerator_x86_32.cpp index f24c5fdb38d..82e4183ef47 100644 --- a/hotspot/src/cpu/x86/vm/stubGenerator_x86_32.cpp +++ b/hotspot/src/cpu/x86/vm/stubGenerator_x86_32.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2013, 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 @@ -2713,6 +2713,59 @@ class StubGenerator: public StubCodeGenerator { return start; } + /** + * Arguments: + * + * Inputs: + * rsp(4) - int crc + * rsp(8) - byte* buf + * rsp(12) - int length + * + * Ouput: + * rax - int crc result + */ + address generate_updateBytesCRC32() { + assert(UseCRC32Intrinsics, "need AVX and CLMUL instructions"); + + __ align(CodeEntryAlignment); + StubCodeMark mark(this, "StubRoutines", "updateBytesCRC32"); + + address start = __ pc(); + + const Register crc = rdx; // crc + const Register buf = rsi; // source java byte array address + const Register len = rcx; // length + const Register table = rdi; // crc_table address (reuse register) + const Register tmp = rbx; + assert_different_registers(crc, buf, len, table, tmp, rax); + + BLOCK_COMMENT("Entry:"); + __ enter(); // required for proper stackwalking of RuntimeStub frame + __ push(rsi); + __ push(rdi); + __ push(rbx); + + Address crc_arg(rbp, 8 + 0); + Address buf_arg(rbp, 8 + 4); + Address len_arg(rbp, 8 + 8); + + // Load up: + __ movl(crc, crc_arg); + __ movptr(buf, buf_arg); + __ movl(len, len_arg); + + __ kernel_crc32(crc, buf, len, table, tmp); + + __ movl(rax, crc); + __ pop(rbx); + __ pop(rdi); + __ pop(rsi); + __ leave(); // required for proper stackwalking of RuntimeStub frame + __ ret(0); + + return start; + } + public: // Information about frame layout at time of blocking runtime call. @@ -2887,6 +2940,12 @@ class StubGenerator: public StubCodeGenerator { // Build this early so it's available for the interpreter StubRoutines::_throw_StackOverflowError_entry = generate_throw_exception("StackOverflowError throw_exception", CAST_FROM_FN_PTR(address, SharedRuntime::throw_StackOverflowError)); + + if (UseCRC32Intrinsics) { + // set table address before stub generation which use it + StubRoutines::_crc_table_adr = (address)StubRoutines::x86::_crc_table; + StubRoutines::_updateBytesCRC32 = generate_updateBytesCRC32(); + } } diff --git a/hotspot/src/cpu/x86/vm/stubGenerator_x86_64.cpp b/hotspot/src/cpu/x86/vm/stubGenerator_x86_64.cpp index 7b8408d7131..2d94642f828 100644 --- a/hotspot/src/cpu/x86/vm/stubGenerator_x86_64.cpp +++ b/hotspot/src/cpu/x86/vm/stubGenerator_x86_64.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -3584,7 +3584,45 @@ class StubGenerator: public StubCodeGenerator { return start; } + /** + * Arguments: + * + * Inputs: + * c_rarg0 - int crc + * c_rarg1 - byte* buf + * c_rarg2 - int length + * + * Ouput: + * rax - int crc result + */ + address generate_updateBytesCRC32() { + assert(UseCRC32Intrinsics, "need AVX and CLMUL instructions"); + __ align(CodeEntryAlignment); + StubCodeMark mark(this, "StubRoutines", "updateBytesCRC32"); + + address start = __ pc(); + // Win64: rcx, rdx, r8, r9 (c_rarg0, c_rarg1, ...) + // Unix: rdi, rsi, rdx, rcx, r8, r9 (c_rarg0, c_rarg1, ...) + // rscratch1: r10 + const Register crc = c_rarg0; // crc + const Register buf = c_rarg1; // source java byte array address + const Register len = c_rarg2; // length + const Register table = c_rarg3; // crc_table address (reuse register) + const Register tmp = r11; + assert_different_registers(crc, buf, len, table, tmp, rax); + + BLOCK_COMMENT("Entry:"); + __ enter(); // required for proper stackwalking of RuntimeStub frame + + __ kernel_crc32(crc, buf, len, table, tmp); + + __ movl(rax, crc); + __ leave(); // required for proper stackwalking of RuntimeStub frame + __ ret(0); + + return start; + } #undef __ #define __ masm-> @@ -3736,6 +3774,11 @@ class StubGenerator: public StubCodeGenerator { CAST_FROM_FN_PTR(address, SharedRuntime:: throw_StackOverflowError)); + if (UseCRC32Intrinsics) { + // set table address before stub generation which use it + StubRoutines::_crc_table_adr = (address)StubRoutines::x86::_crc_table; + StubRoutines::_updateBytesCRC32 = generate_updateBytesCRC32(); + } } void generate_all() { diff --git a/hotspot/src/cpu/x86/vm/stubRoutines_x86.cpp b/hotspot/src/cpu/x86/vm/stubRoutines_x86.cpp new file mode 100644 index 00000000000..200f2aff80d --- /dev/null +++ b/hotspot/src/cpu/x86/vm/stubRoutines_x86.cpp @@ -0,0 +1,130 @@ +/* + * Copyright (c) 2013, 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. + * + */ + +#include "precompiled.hpp" +#include "runtime/deoptimization.hpp" +#include "runtime/frame.inline.hpp" +#include "runtime/stubRoutines.hpp" +#include "runtime/thread.inline.hpp" + +// Implementation of the platform-specific part of StubRoutines - for +// a description of how to extend it, see the stubRoutines.hpp file. + +address StubRoutines::x86::_verify_mxcsr_entry = NULL; +address StubRoutines::x86::_key_shuffle_mask_addr = NULL; + +uint64_t StubRoutines::x86::_crc_by128_masks[] = +{ + /* The fields in this structure are arranged so that they can be + * picked up two at a time with 128-bit loads. + * + * Because of flipped bit order for this CRC polynomials + * the constant for X**N is left-shifted by 1. This is because + * a 64 x 64 polynomial multiply produces a 127-bit result + * but the highest term is always aligned to bit 0 in the container. + * Pre-shifting by one fixes this, at the cost of potentially making + * the 32-bit constant no longer fit in a 32-bit container (thus the + * use of uint64_t, though this is also the size used by the carry- + * less multiply instruction. + * + * In addition, the flipped bit order and highest-term-at-least-bit + * multiply changes the constants used. The 96-bit result will be + * aligned to the high-term end of the target 128-bit container, + * not the low-term end; that is, instead of a 512-bit or 576-bit fold, + * instead it is a 480 (=512-32) or 544 (=512+64-32) bit fold. + * + * This cause additional problems in the 128-to-64-bit reduction; see the + * code for details. By storing a mask in the otherwise unused half of + * a 128-bit constant, bits can be cleared before multiplication without + * storing and reloading. Note that staying on a 128-bit datapath means + * that some data is uselessly stored and some unused data is intersected + * with an irrelevant constant. + */ + + ((uint64_t) 0xffffffffUL), /* low of K_M_64 */ + ((uint64_t) 0xb1e6b092U << 1), /* high of K_M_64 */ + ((uint64_t) 0xba8ccbe8U << 1), /* low of K_160_96 */ + ((uint64_t) 0x6655004fU << 1), /* high of K_160_96 */ + ((uint64_t) 0xaa2215eaU << 1), /* low of K_544_480 */ + ((uint64_t) 0xe3720acbU << 1) /* high of K_544_480 */ +}; + +/** + * crc_table[] from jdk/src/share/native/java/util/zip/zlib-1.2.5/crc32.h + */ +juint StubRoutines::x86::_crc_table[] = +{ + 0x00000000UL, 0x77073096UL, 0xee0e612cUL, 0x990951baUL, 0x076dc419UL, + 0x706af48fUL, 0xe963a535UL, 0x9e6495a3UL, 0x0edb8832UL, 0x79dcb8a4UL, + 0xe0d5e91eUL, 0x97d2d988UL, 0x09b64c2bUL, 0x7eb17cbdUL, 0xe7b82d07UL, + 0x90bf1d91UL, 0x1db71064UL, 0x6ab020f2UL, 0xf3b97148UL, 0x84be41deUL, + 0x1adad47dUL, 0x6ddde4ebUL, 0xf4d4b551UL, 0x83d385c7UL, 0x136c9856UL, + 0x646ba8c0UL, 0xfd62f97aUL, 0x8a65c9ecUL, 0x14015c4fUL, 0x63066cd9UL, + 0xfa0f3d63UL, 0x8d080df5UL, 0x3b6e20c8UL, 0x4c69105eUL, 0xd56041e4UL, + 0xa2677172UL, 0x3c03e4d1UL, 0x4b04d447UL, 0xd20d85fdUL, 0xa50ab56bUL, + 0x35b5a8faUL, 0x42b2986cUL, 0xdbbbc9d6UL, 0xacbcf940UL, 0x32d86ce3UL, + 0x45df5c75UL, 0xdcd60dcfUL, 0xabd13d59UL, 0x26d930acUL, 0x51de003aUL, + 0xc8d75180UL, 0xbfd06116UL, 0x21b4f4b5UL, 0x56b3c423UL, 0xcfba9599UL, + 0xb8bda50fUL, 0x2802b89eUL, 0x5f058808UL, 0xc60cd9b2UL, 0xb10be924UL, + 0x2f6f7c87UL, 0x58684c11UL, 0xc1611dabUL, 0xb6662d3dUL, 0x76dc4190UL, + 0x01db7106UL, 0x98d220bcUL, 0xefd5102aUL, 0x71b18589UL, 0x06b6b51fUL, + 0x9fbfe4a5UL, 0xe8b8d433UL, 0x7807c9a2UL, 0x0f00f934UL, 0x9609a88eUL, + 0xe10e9818UL, 0x7f6a0dbbUL, 0x086d3d2dUL, 0x91646c97UL, 0xe6635c01UL, + 0x6b6b51f4UL, 0x1c6c6162UL, 0x856530d8UL, 0xf262004eUL, 0x6c0695edUL, + 0x1b01a57bUL, 0x8208f4c1UL, 0xf50fc457UL, 0x65b0d9c6UL, 0x12b7e950UL, + 0x8bbeb8eaUL, 0xfcb9887cUL, 0x62dd1ddfUL, 0x15da2d49UL, 0x8cd37cf3UL, + 0xfbd44c65UL, 0x4db26158UL, 0x3ab551ceUL, 0xa3bc0074UL, 0xd4bb30e2UL, + 0x4adfa541UL, 0x3dd895d7UL, 0xa4d1c46dUL, 0xd3d6f4fbUL, 0x4369e96aUL, + 0x346ed9fcUL, 0xad678846UL, 0xda60b8d0UL, 0x44042d73UL, 0x33031de5UL, + 0xaa0a4c5fUL, 0xdd0d7cc9UL, 0x5005713cUL, 0x270241aaUL, 0xbe0b1010UL, + 0xc90c2086UL, 0x5768b525UL, 0x206f85b3UL, 0xb966d409UL, 0xce61e49fUL, + 0x5edef90eUL, 0x29d9c998UL, 0xb0d09822UL, 0xc7d7a8b4UL, 0x59b33d17UL, + 0x2eb40d81UL, 0xb7bd5c3bUL, 0xc0ba6cadUL, 0xedb88320UL, 0x9abfb3b6UL, + 0x03b6e20cUL, 0x74b1d29aUL, 0xead54739UL, 0x9dd277afUL, 0x04db2615UL, + 0x73dc1683UL, 0xe3630b12UL, 0x94643b84UL, 0x0d6d6a3eUL, 0x7a6a5aa8UL, + 0xe40ecf0bUL, 0x9309ff9dUL, 0x0a00ae27UL, 0x7d079eb1UL, 0xf00f9344UL, + 0x8708a3d2UL, 0x1e01f268UL, 0x6906c2feUL, 0xf762575dUL, 0x806567cbUL, + 0x196c3671UL, 0x6e6b06e7UL, 0xfed41b76UL, 0x89d32be0UL, 0x10da7a5aUL, + 0x67dd4accUL, 0xf9b9df6fUL, 0x8ebeeff9UL, 0x17b7be43UL, 0x60b08ed5UL, + 0xd6d6a3e8UL, 0xa1d1937eUL, 0x38d8c2c4UL, 0x4fdff252UL, 0xd1bb67f1UL, + 0xa6bc5767UL, 0x3fb506ddUL, 0x48b2364bUL, 0xd80d2bdaUL, 0xaf0a1b4cUL, + 0x36034af6UL, 0x41047a60UL, 0xdf60efc3UL, 0xa867df55UL, 0x316e8eefUL, + 0x4669be79UL, 0xcb61b38cUL, 0xbc66831aUL, 0x256fd2a0UL, 0x5268e236UL, + 0xcc0c7795UL, 0xbb0b4703UL, 0x220216b9UL, 0x5505262fUL, 0xc5ba3bbeUL, + 0xb2bd0b28UL, 0x2bb45a92UL, 0x5cb36a04UL, 0xc2d7ffa7UL, 0xb5d0cf31UL, + 0x2cd99e8bUL, 0x5bdeae1dUL, 0x9b64c2b0UL, 0xec63f226UL, 0x756aa39cUL, + 0x026d930aUL, 0x9c0906a9UL, 0xeb0e363fUL, 0x72076785UL, 0x05005713UL, + 0x95bf4a82UL, 0xe2b87a14UL, 0x7bb12baeUL, 0x0cb61b38UL, 0x92d28e9bUL, + 0xe5d5be0dUL, 0x7cdcefb7UL, 0x0bdbdf21UL, 0x86d3d2d4UL, 0xf1d4e242UL, + 0x68ddb3f8UL, 0x1fda836eUL, 0x81be16cdUL, 0xf6b9265bUL, 0x6fb077e1UL, + 0x18b74777UL, 0x88085ae6UL, 0xff0f6a70UL, 0x66063bcaUL, 0x11010b5cUL, + 0x8f659effUL, 0xf862ae69UL, 0x616bffd3UL, 0x166ccf45UL, 0xa00ae278UL, + 0xd70dd2eeUL, 0x4e048354UL, 0x3903b3c2UL, 0xa7672661UL, 0xd06016f7UL, + 0x4969474dUL, 0x3e6e77dbUL, 0xaed16a4aUL, 0xd9d65adcUL, 0x40df0b66UL, + 0x37d83bf0UL, 0xa9bcae53UL, 0xdebb9ec5UL, 0x47b2cf7fUL, 0x30b5ffe9UL, + 0xbdbdf21cUL, 0xcabac28aUL, 0x53b39330UL, 0x24b4a3a6UL, 0xbad03605UL, + 0xcdd70693UL, 0x54de5729UL, 0x23d967bfUL, 0xb3667a2eUL, 0xc4614ab8UL, + 0x5d681b02UL, 0x2a6f2b94UL, 0xb40bbe37UL, 0xc30c8ea1UL, 0x5a05df1bUL, + 0x2d02ef8dUL +}; diff --git a/hotspot/src/cpu/x86/vm/stubRoutines_x86.hpp b/hotspot/src/cpu/x86/vm/stubRoutines_x86.hpp new file mode 100644 index 00000000000..d8e52ab3b11 --- /dev/null +++ b/hotspot/src/cpu/x86/vm/stubRoutines_x86.hpp @@ -0,0 +1,45 @@ +/* + * Copyright (c) 2013, 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. + * + */ + +#ifndef CPU_X86_VM_STUBROUTINES_X86_HPP +#define CPU_X86_VM_STUBROUTINES_X86_HPP + +// This file holds the platform specific parts of the StubRoutines +// definition. See stubRoutines.hpp for a description on how to +// extend it. + + private: + static address _verify_mxcsr_entry; + // shuffle mask for fixing up 128-bit words consisting of big-endian 32-bit integers + static address _key_shuffle_mask_addr; + // masks and table for CRC32 + static uint64_t _crc_by128_masks[]; + static juint _crc_table[]; + + public: + static address verify_mxcsr_entry() { return _verify_mxcsr_entry; } + static address key_shuffle_mask_addr() { return _key_shuffle_mask_addr; } + static address crc_by128_masks_addr() { return (address)_crc_by128_masks; } + +#endif // CPU_X86_VM_STUBROUTINES_X86_32_HPP diff --git a/hotspot/src/cpu/x86/vm/stubRoutines_x86_32.cpp b/hotspot/src/cpu/x86/vm/stubRoutines_x86_32.cpp index 65e773ed53c..53464dcccdf 100644 --- a/hotspot/src/cpu/x86/vm/stubRoutines_x86_32.cpp +++ b/hotspot/src/cpu/x86/vm/stubRoutines_x86_32.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -31,6 +31,4 @@ // Implementation of the platform-specific part of StubRoutines - for // a description of how to extend it, see the stubRoutines.hpp file. -address StubRoutines::x86::_verify_mxcsr_entry = NULL; address StubRoutines::x86::_verify_fpu_cntrl_wrd_entry = NULL; -address StubRoutines::x86::_key_shuffle_mask_addr = NULL; diff --git a/hotspot/src/cpu/x86/vm/stubRoutines_x86_32.hpp b/hotspot/src/cpu/x86/vm/stubRoutines_x86_32.hpp index d53124fc6c8..bca5d493ce4 100644 --- a/hotspot/src/cpu/x86/vm/stubRoutines_x86_32.hpp +++ b/hotspot/src/cpu/x86/vm/stubRoutines_x86_32.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -39,15 +39,12 @@ class x86 { friend class VMStructs; private: - static address _verify_mxcsr_entry; static address _verify_fpu_cntrl_wrd_entry; - // shuffle mask for fixing up 128-bit words consisting of big-endian 32-bit integers - static address _key_shuffle_mask_addr; public: - static address verify_mxcsr_entry() { return _verify_mxcsr_entry; } static address verify_fpu_cntrl_wrd_entry() { return _verify_fpu_cntrl_wrd_entry; } - static address key_shuffle_mask_addr() { return _key_shuffle_mask_addr; } + +# include "stubRoutines_x86.hpp" }; diff --git a/hotspot/src/cpu/x86/vm/stubRoutines_x86_64.cpp b/hotspot/src/cpu/x86/vm/stubRoutines_x86_64.cpp index 9f0a94200a5..5c11734cc97 100644 --- a/hotspot/src/cpu/x86/vm/stubRoutines_x86_64.cpp +++ b/hotspot/src/cpu/x86/vm/stubRoutines_x86_64.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -34,8 +34,6 @@ address StubRoutines::x86::_get_previous_fp_entry = NULL; address StubRoutines::x86::_get_previous_sp_entry = NULL; -address StubRoutines::x86::_verify_mxcsr_entry = NULL; - address StubRoutines::x86::_f2i_fixup = NULL; address StubRoutines::x86::_f2l_fixup = NULL; address StubRoutines::x86::_d2i_fixup = NULL; @@ -45,4 +43,3 @@ address StubRoutines::x86::_float_sign_flip = NULL; address StubRoutines::x86::_double_sign_mask = NULL; address StubRoutines::x86::_double_sign_flip = NULL; address StubRoutines::x86::_mxcsr_std = NULL; -address StubRoutines::x86::_key_shuffle_mask_addr = NULL; diff --git a/hotspot/src/cpu/x86/vm/stubRoutines_x86_64.hpp b/hotspot/src/cpu/x86/vm/stubRoutines_x86_64.hpp index c3efeecb759..d63e9fdf57f 100644 --- a/hotspot/src/cpu/x86/vm/stubRoutines_x86_64.hpp +++ b/hotspot/src/cpu/x86/vm/stubRoutines_x86_64.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2013, 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 @@ -42,7 +42,6 @@ class x86 { private: static address _get_previous_fp_entry; static address _get_previous_sp_entry; - static address _verify_mxcsr_entry; static address _f2i_fixup; static address _f2l_fixup; @@ -54,8 +53,6 @@ class x86 { static address _double_sign_mask; static address _double_sign_flip; static address _mxcsr_std; - // shuffle mask for fixing up 128-bit words consisting of big-endian 32-bit integers - static address _key_shuffle_mask_addr; public: @@ -69,11 +66,6 @@ class x86 { return _get_previous_sp_entry; } - static address verify_mxcsr_entry() - { - return _verify_mxcsr_entry; - } - static address f2i_fixup() { return _f2i_fixup; @@ -119,7 +111,7 @@ class x86 { return _mxcsr_std; } - static address key_shuffle_mask_addr() { return _key_shuffle_mask_addr; } +# include "stubRoutines_x86.hpp" }; diff --git a/hotspot/src/cpu/x86/vm/templateInterpreter_x86_32.cpp b/hotspot/src/cpu/x86/vm/templateInterpreter_x86_32.cpp index 3908a8c09da..2efa59f8b33 100644 --- a/hotspot/src/cpu/x86/vm/templateInterpreter_x86_32.cpp +++ b/hotspot/src/cpu/x86/vm/templateInterpreter_x86_32.cpp @@ -868,6 +868,120 @@ address InterpreterGenerator::generate_Reference_get_entry(void) { return generate_accessor_entry(); } +/** + * Method entry for static native methods: + * int java.util.zip.CRC32.update(int crc, int b) + */ +address InterpreterGenerator::generate_CRC32_update_entry() { + if (UseCRC32Intrinsics) { + address entry = __ pc(); + + // rbx,: Method* + // rsi: senderSP must preserved for slow path, set SP to it on fast path + // rdx: scratch + // rdi: scratch + + Label slow_path; + // If we need a safepoint check, generate full interpreter entry. + ExternalAddress state(SafepointSynchronize::address_of_state()); + __ cmp32(ExternalAddress(SafepointSynchronize::address_of_state()), + SafepointSynchronize::_not_synchronized); + __ jcc(Assembler::notEqual, slow_path); + + // We don't generate local frame and don't align stack because + // we call stub code and there is no safepoint on this path. + + // Load parameters + const Register crc = rax; // crc + const Register val = rdx; // source java byte value + const Register tbl = rdi; // scratch + + // Arguments are reversed on java expression stack + __ movl(val, Address(rsp, wordSize)); // byte value + __ movl(crc, Address(rsp, 2*wordSize)); // Initial CRC + + __ lea(tbl, ExternalAddress(StubRoutines::crc_table_addr())); + __ notl(crc); // ~crc + __ update_byte_crc32(crc, val, tbl); + __ notl(crc); // ~crc + // result in rax + + // _areturn + __ pop(rdi); // get return address + __ mov(rsp, rsi); // set sp to sender sp + __ jmp(rdi); + + // generate a vanilla native entry as the slow path + __ bind(slow_path); + + (void) generate_native_entry(false); + + return entry; + } + return generate_native_entry(false); +} + +/** + * Method entry for static native methods: + * int java.util.zip.CRC32.updateBytes(int crc, byte[] b, int off, int len) + * int java.util.zip.CRC32.updateByteBuffer(int crc, long buf, int off, int len) + */ +address InterpreterGenerator::generate_CRC32_updateBytes_entry(AbstractInterpreter::MethodKind kind) { + if (UseCRC32Intrinsics) { + address entry = __ pc(); + + // rbx,: Method* + // rsi: senderSP must preserved for slow path, set SP to it on fast path + // rdx: scratch + // rdi: scratch + + Label slow_path; + // If we need a safepoint check, generate full interpreter entry. + ExternalAddress state(SafepointSynchronize::address_of_state()); + __ cmp32(ExternalAddress(SafepointSynchronize::address_of_state()), + SafepointSynchronize::_not_synchronized); + __ jcc(Assembler::notEqual, slow_path); + + // We don't generate local frame and don't align stack because + // we call stub code and there is no safepoint on this path. + + // Load parameters + const Register crc = rax; // crc + const Register buf = rdx; // source java byte array address + const Register len = rdi; // length + + // Arguments are reversed on java expression stack + __ movl(len, Address(rsp, wordSize)); // Length + // Calculate address of start element + if (kind == Interpreter::java_util_zip_CRC32_updateByteBuffer) { + __ movptr(buf, Address(rsp, 3*wordSize)); // long buf + __ addptr(buf, Address(rsp, 2*wordSize)); // + offset + __ movl(crc, Address(rsp, 5*wordSize)); // Initial CRC + } else { + __ movptr(buf, Address(rsp, 3*wordSize)); // byte[] array + __ addptr(buf, arrayOopDesc::base_offset_in_bytes(T_BYTE)); // + header size + __ addptr(buf, Address(rsp, 2*wordSize)); // + offset + __ movl(crc, Address(rsp, 4*wordSize)); // Initial CRC + } + + __ super_call_VM_leaf(CAST_FROM_FN_PTR(address, StubRoutines::updateBytesCRC32()), crc, buf, len); + // result in rax + + // _areturn + __ pop(rdi); // get return address + __ mov(rsp, rsi); // set sp to sender sp + __ jmp(rdi); + + // generate a vanilla native entry as the slow path + __ bind(slow_path); + + (void) generate_native_entry(false); + + return entry; + } + return generate_native_entry(false); +} + // // Interpreter stub for calling a native method. (asm interpreter) // This sets up a somewhat different looking stack for calling the native method @@ -1501,15 +1615,16 @@ address AbstractInterpreterGenerator::generate_method_entry(AbstractInterpreter: // determine code generation flags bool synchronized = false; address entry_point = NULL; + InterpreterGenerator* ig_this = (InterpreterGenerator*)this; switch (kind) { - case Interpreter::zerolocals : break; - case Interpreter::zerolocals_synchronized: synchronized = true; break; - case Interpreter::native : entry_point = ((InterpreterGenerator*)this)->generate_native_entry(false); break; - case Interpreter::native_synchronized : entry_point = ((InterpreterGenerator*)this)->generate_native_entry(true); break; - case Interpreter::empty : entry_point = ((InterpreterGenerator*)this)->generate_empty_entry(); break; - case Interpreter::accessor : entry_point = ((InterpreterGenerator*)this)->generate_accessor_entry(); break; - case Interpreter::abstract : entry_point = ((InterpreterGenerator*)this)->generate_abstract_entry(); break; + case Interpreter::zerolocals : break; + case Interpreter::zerolocals_synchronized: synchronized = true; break; + case Interpreter::native : entry_point = ig_this->generate_native_entry(false); break; + case Interpreter::native_synchronized : entry_point = ig_this->generate_native_entry(true); break; + case Interpreter::empty : entry_point = ig_this->generate_empty_entry(); break; + case Interpreter::accessor : entry_point = ig_this->generate_accessor_entry(); break; + case Interpreter::abstract : entry_point = ig_this->generate_abstract_entry(); break; case Interpreter::java_lang_math_sin : // fall thru case Interpreter::java_lang_math_cos : // fall thru @@ -1519,9 +1634,15 @@ address AbstractInterpreterGenerator::generate_method_entry(AbstractInterpreter: case Interpreter::java_lang_math_log10 : // fall thru case Interpreter::java_lang_math_sqrt : // fall thru case Interpreter::java_lang_math_pow : // fall thru - case Interpreter::java_lang_math_exp : entry_point = ((InterpreterGenerator*)this)->generate_math_entry(kind); break; + case Interpreter::java_lang_math_exp : entry_point = ig_this->generate_math_entry(kind); break; case Interpreter::java_lang_ref_reference_get - : entry_point = ((InterpreterGenerator*)this)->generate_Reference_get_entry(); break; + : entry_point = ig_this->generate_Reference_get_entry(); break; + case Interpreter::java_util_zip_CRC32_update + : entry_point = ig_this->generate_CRC32_update_entry(); break; + case Interpreter::java_util_zip_CRC32_updateBytes + : // fall thru + case Interpreter::java_util_zip_CRC32_updateByteBuffer + : entry_point = ig_this->generate_CRC32_updateBytes_entry(kind); break; default: fatal(err_msg("unexpected method kind: %d", kind)); break; @@ -1529,7 +1650,7 @@ address AbstractInterpreterGenerator::generate_method_entry(AbstractInterpreter: if (entry_point) return entry_point; - return ((InterpreterGenerator*)this)->generate_normal_entry(synchronized); + return ig_this->generate_normal_entry(synchronized); } diff --git a/hotspot/src/cpu/x86/vm/templateInterpreter_x86_64.cpp b/hotspot/src/cpu/x86/vm/templateInterpreter_x86_64.cpp index 50bb8a968f6..f0a2258a70e 100644 --- a/hotspot/src/cpu/x86/vm/templateInterpreter_x86_64.cpp +++ b/hotspot/src/cpu/x86/vm/templateInterpreter_x86_64.cpp @@ -840,6 +840,117 @@ address InterpreterGenerator::generate_Reference_get_entry(void) { return generate_accessor_entry(); } +/** + * Method entry for static native methods: + * int java.util.zip.CRC32.update(int crc, int b) + */ +address InterpreterGenerator::generate_CRC32_update_entry() { + if (UseCRC32Intrinsics) { + address entry = __ pc(); + + // rbx,: Method* + // rsi: senderSP must preserved for slow path, set SP to it on fast path + // rdx: scratch + // rdi: scratch + + Label slow_path; + // If we need a safepoint check, generate full interpreter entry. + ExternalAddress state(SafepointSynchronize::address_of_state()); + __ cmp32(ExternalAddress(SafepointSynchronize::address_of_state()), + SafepointSynchronize::_not_synchronized); + __ jcc(Assembler::notEqual, slow_path); + + // We don't generate local frame and don't align stack because + // we call stub code and there is no safepoint on this path. + + // Load parameters + const Register crc = rax; // crc + const Register val = rdx; // source java byte value + const Register tbl = rdi; // scratch + + // Arguments are reversed on java expression stack + __ movl(val, Address(rsp, wordSize)); // byte value + __ movl(crc, Address(rsp, 2*wordSize)); // Initial CRC + + __ lea(tbl, ExternalAddress(StubRoutines::crc_table_addr())); + __ notl(crc); // ~crc + __ update_byte_crc32(crc, val, tbl); + __ notl(crc); // ~crc + // result in rax + + // _areturn + __ pop(rdi); // get return address + __ mov(rsp, rsi); // set sp to sender sp + __ jmp(rdi); + + // generate a vanilla native entry as the slow path + __ bind(slow_path); + + (void) generate_native_entry(false); + + return entry; + } + return generate_native_entry(false); +} + +/** + * Method entry for static native methods: + * int java.util.zip.CRC32.updateBytes(int crc, byte[] b, int off, int len) + * int java.util.zip.CRC32.updateByteBuffer(int crc, long buf, int off, int len) + */ +address InterpreterGenerator::generate_CRC32_updateBytes_entry(AbstractInterpreter::MethodKind kind) { + if (UseCRC32Intrinsics) { + address entry = __ pc(); + + // rbx,: Method* + // r13: senderSP must preserved for slow path, set SP to it on fast path + + Label slow_path; + // If we need a safepoint check, generate full interpreter entry. + ExternalAddress state(SafepointSynchronize::address_of_state()); + __ cmp32(ExternalAddress(SafepointSynchronize::address_of_state()), + SafepointSynchronize::_not_synchronized); + __ jcc(Assembler::notEqual, slow_path); + + // We don't generate local frame and don't align stack because + // we call stub code and there is no safepoint on this path. + + // Load parameters + const Register crc = c_rarg0; // crc + const Register buf = c_rarg1; // source java byte array address + const Register len = c_rarg2; // length + + // Arguments are reversed on java expression stack + __ movl(len, Address(rsp, wordSize)); // Length + // Calculate address of start element + if (kind == Interpreter::java_util_zip_CRC32_updateByteBuffer) { + __ movptr(buf, Address(rsp, 3*wordSize)); // long buf + __ addptr(buf, Address(rsp, 2*wordSize)); // + offset + __ movl(crc, Address(rsp, 5*wordSize)); // Initial CRC + } else { + __ movptr(buf, Address(rsp, 3*wordSize)); // byte[] array + __ addptr(buf, arrayOopDesc::base_offset_in_bytes(T_BYTE)); // + header size + __ addptr(buf, Address(rsp, 2*wordSize)); // + offset + __ movl(crc, Address(rsp, 4*wordSize)); // Initial CRC + } + + __ super_call_VM_leaf(CAST_FROM_FN_PTR(address, StubRoutines::updateBytesCRC32()), crc, buf, len); + // result in rax + + // _areturn + __ pop(rdi); // get return address + __ mov(rsp, r13); // set sp to sender sp + __ jmp(rdi); + + // generate a vanilla native entry as the slow path + __ bind(slow_path); + + (void) generate_native_entry(false); + + return entry; + } + return generate_native_entry(false); +} // Interpreter stub for calling a native method. (asm interpreter) // This sets up a somewhat different looking stack for calling the @@ -1510,15 +1621,16 @@ address AbstractInterpreterGenerator::generate_method_entry( // determine code generation flags bool synchronized = false; address entry_point = NULL; + InterpreterGenerator* ig_this = (InterpreterGenerator*)this; switch (kind) { - case Interpreter::zerolocals : break; - case Interpreter::zerolocals_synchronized: synchronized = true; break; - case Interpreter::native : entry_point = ((InterpreterGenerator*)this)->generate_native_entry(false); break; - case Interpreter::native_synchronized : entry_point = ((InterpreterGenerator*)this)->generate_native_entry(true); break; - case Interpreter::empty : entry_point = ((InterpreterGenerator*)this)->generate_empty_entry(); break; - case Interpreter::accessor : entry_point = ((InterpreterGenerator*)this)->generate_accessor_entry(); break; - case Interpreter::abstract : entry_point = ((InterpreterGenerator*)this)->generate_abstract_entry(); break; + case Interpreter::zerolocals : break; + case Interpreter::zerolocals_synchronized: synchronized = true; break; + case Interpreter::native : entry_point = ig_this->generate_native_entry(false); break; + case Interpreter::native_synchronized : entry_point = ig_this->generate_native_entry(true); break; + case Interpreter::empty : entry_point = ig_this->generate_empty_entry(); break; + case Interpreter::accessor : entry_point = ig_this->generate_accessor_entry(); break; + case Interpreter::abstract : entry_point = ig_this->generate_abstract_entry(); break; case Interpreter::java_lang_math_sin : // fall thru case Interpreter::java_lang_math_cos : // fall thru @@ -1528,9 +1640,15 @@ address AbstractInterpreterGenerator::generate_method_entry( case Interpreter::java_lang_math_log10 : // fall thru case Interpreter::java_lang_math_sqrt : // fall thru case Interpreter::java_lang_math_pow : // fall thru - case Interpreter::java_lang_math_exp : entry_point = ((InterpreterGenerator*)this)->generate_math_entry(kind); break; + case Interpreter::java_lang_math_exp : entry_point = ig_this->generate_math_entry(kind); break; case Interpreter::java_lang_ref_reference_get - : entry_point = ((InterpreterGenerator*)this)->generate_Reference_get_entry(); break; + : entry_point = ig_this->generate_Reference_get_entry(); break; + case Interpreter::java_util_zip_CRC32_update + : entry_point = ig_this->generate_CRC32_update_entry(); break; + case Interpreter::java_util_zip_CRC32_updateBytes + : // fall thru + case Interpreter::java_util_zip_CRC32_updateByteBuffer + : entry_point = ig_this->generate_CRC32_updateBytes_entry(kind); break; default: fatal(err_msg("unexpected method kind: %d", kind)); break; @@ -1540,8 +1658,7 @@ address AbstractInterpreterGenerator::generate_method_entry( return entry_point; } - return ((InterpreterGenerator*) this)-> - generate_normal_entry(synchronized); + return ig_this->generate_normal_entry(synchronized); } // These should never be compiled since the interpreter will prefer diff --git a/hotspot/src/cpu/x86/vm/vm_version_x86.cpp b/hotspot/src/cpu/x86/vm/vm_version_x86.cpp index 90066c1041a..de38b4a3a53 100644 --- a/hotspot/src/cpu/x86/vm/vm_version_x86.cpp +++ b/hotspot/src/cpu/x86/vm/vm_version_x86.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -446,6 +446,7 @@ void VM_Version::get_processor_features() { (supports_avx() ? ", avx" : ""), (supports_avx2() ? ", avx2" : ""), (supports_aes() ? ", aes" : ""), + (supports_clmul() ? ", clmul" : ""), (supports_erms() ? ", erms" : ""), (supports_mmx_ext() ? ", mmxext" : ""), (supports_3dnow_prefetch() ? ", 3dnowpref" : ""), @@ -489,6 +490,27 @@ void VM_Version::get_processor_features() { FLAG_SET_DEFAULT(UseAES, false); } + // Use CLMUL instructions if available. + if (supports_clmul()) { + if (FLAG_IS_DEFAULT(UseCLMUL)) { + UseCLMUL = true; + } + } else if (UseCLMUL) { + if (!FLAG_IS_DEFAULT(UseCLMUL)) + warning("CLMUL instructions not available on this CPU (AVX may also be required)"); + FLAG_SET_DEFAULT(UseCLMUL, false); + } + + if (UseCLMUL && (UseAVX > 0) && (UseSSE > 2)) { + if (FLAG_IS_DEFAULT(UseCRC32Intrinsics)) { + UseCRC32Intrinsics = true; + } + } else if (UseCRC32Intrinsics) { + if (!FLAG_IS_DEFAULT(UseCRC32Intrinsics)) + warning("CRC32 Intrinsics requires AVX and CLMUL instructions (not available on this CPU)"); + FLAG_SET_DEFAULT(UseCRC32Intrinsics, false); + } + // The AES intrinsic stubs require AES instruction support (of course) // but also require sse3 mode for instructions it use. if (UseAES && (UseSSE > 2)) { diff --git a/hotspot/src/cpu/x86/vm/vm_version_x86.hpp b/hotspot/src/cpu/x86/vm/vm_version_x86.hpp index ec8caba23f0..86e9b662d52 100644 --- a/hotspot/src/cpu/x86/vm/vm_version_x86.hpp +++ b/hotspot/src/cpu/x86/vm/vm_version_x86.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -61,7 +61,8 @@ public: uint32_t value; struct { uint32_t sse3 : 1, - : 2, + clmul : 1, + : 1, monitor : 1, : 1, vmx : 1, @@ -249,7 +250,8 @@ protected: CPU_AVX = (1 << 17), CPU_AVX2 = (1 << 18), CPU_AES = (1 << 19), - CPU_ERMS = (1 << 20) // enhanced 'rep movsb/stosb' instructions + CPU_ERMS = (1 << 20), // enhanced 'rep movsb/stosb' instructions + CPU_CLMUL = (1 << 21) // carryless multiply for CRC } cpuFeatureFlags; enum { @@ -429,6 +431,8 @@ protected: result |= CPU_AES; if (_cpuid_info.sef_cpuid7_ebx.bits.erms != 0) result |= CPU_ERMS; + if (_cpuid_info.std_cpuid1_ecx.bits.clmul != 0) + result |= CPU_CLMUL; // AMD features. if (is_amd()) { @@ -555,6 +559,7 @@ public: static bool supports_tsc() { return (_cpuFeatures & CPU_TSC) != 0; } static bool supports_aes() { return (_cpuFeatures & CPU_AES) != 0; } static bool supports_erms() { return (_cpuFeatures & CPU_ERMS) != 0; } + static bool supports_clmul() { return (_cpuFeatures & CPU_CLMUL) != 0; } // Intel features static bool is_intel_family_core() { return is_intel() && diff --git a/hotspot/src/share/vm/c1/c1_GraphBuilder.cpp b/hotspot/src/share/vm/c1/c1_GraphBuilder.cpp index 8d7619eedd6..b84c8911e4c 100644 --- a/hotspot/src/share/vm/c1/c1_GraphBuilder.cpp +++ b/hotspot/src/share/vm/c1/c1_GraphBuilder.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2013, 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 @@ -3461,6 +3461,14 @@ bool GraphBuilder::try_inline_intrinsics(ciMethod* callee) { preserves_state = true; break; + case vmIntrinsics::_updateCRC32: + case vmIntrinsics::_updateBytesCRC32: + case vmIntrinsics::_updateByteBufferCRC32: + if (!UseCRC32Intrinsics) return false; + cantrap = false; + preserves_state = true; + break; + case vmIntrinsics::_loadFence : case vmIntrinsics::_storeFence: case vmIntrinsics::_fullFence : diff --git a/hotspot/src/share/vm/c1/c1_LIR.cpp b/hotspot/src/share/vm/c1/c1_LIR.cpp index e2611534ea1..cb0ceab90c0 100644 --- a/hotspot/src/share/vm/c1/c1_LIR.cpp +++ b/hotspot/src/share/vm/c1/c1_LIR.cpp @@ -430,6 +430,11 @@ LIR_OpArrayCopy::LIR_OpArrayCopy(LIR_Opr src, LIR_Opr src_pos, LIR_Opr dst, LIR_ _stub = new ArrayCopyStub(this); } +LIR_OpUpdateCRC32::LIR_OpUpdateCRC32(LIR_Opr crc, LIR_Opr val, LIR_Opr res) + : LIR_Op(lir_updatecrc32, res, NULL) + , _crc(crc) + , _val(val) { +} //-------------------verify-------------------------- @@ -876,6 +881,20 @@ void LIR_OpVisitState::visit(LIR_Op* op) { } +// LIR_OpUpdateCRC32 + case lir_updatecrc32: { + assert(op->as_OpUpdateCRC32() != NULL, "must be"); + LIR_OpUpdateCRC32* opUp = (LIR_OpUpdateCRC32*)op; + + assert(opUp->_crc->is_valid(), "used"); do_input(opUp->_crc); do_temp(opUp->_crc); + assert(opUp->_val->is_valid(), "used"); do_input(opUp->_val); do_temp(opUp->_val); + assert(opUp->_result->is_valid(), "used"); do_output(opUp->_result); + assert(opUp->_info == NULL, "no info for LIR_OpUpdateCRC32"); + + break; + } + + // LIR_OpLock case lir_lock: case lir_unlock: { @@ -1056,6 +1075,10 @@ void LIR_OpArrayCopy::emit_code(LIR_Assembler* masm) { masm->emit_code_stub(stub()); } +void LIR_OpUpdateCRC32::emit_code(LIR_Assembler* masm) { + masm->emit_updatecrc32(this); +} + void LIR_Op0::emit_code(LIR_Assembler* masm) { masm->emit_op0(this); } @@ -1763,6 +1786,8 @@ const char * LIR_Op::name() const { case lir_dynamic_call: s = "dynamic"; break; // LIR_OpArrayCopy case lir_arraycopy: s = "arraycopy"; break; + // LIR_OpUpdateCRC32 + case lir_updatecrc32: s = "updatecrc32"; break; // LIR_OpLock case lir_lock: s = "lock"; break; case lir_unlock: s = "unlock"; break; @@ -1815,6 +1840,13 @@ void LIR_OpArrayCopy::print_instr(outputStream* out) const { tmp()->print(out); out->print(" "); } +// LIR_OpUpdateCRC32 +void LIR_OpUpdateCRC32::print_instr(outputStream* out) const { + crc()->print(out); out->print(" "); + val()->print(out); out->print(" "); + result_opr()->print(out); out->print(" "); +} + // LIR_OpCompareAndSwap void LIR_OpCompareAndSwap::print_instr(outputStream* out) const { addr()->print(out); out->print(" "); diff --git a/hotspot/src/share/vm/c1/c1_LIR.hpp b/hotspot/src/share/vm/c1/c1_LIR.hpp index 61dd59e3fe9..fab85e5750f 100644 --- a/hotspot/src/share/vm/c1/c1_LIR.hpp +++ b/hotspot/src/share/vm/c1/c1_LIR.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -877,6 +877,7 @@ class LIR_OpCall; class LIR_OpJavaCall; class LIR_OpRTCall; class LIR_OpArrayCopy; +class LIR_OpUpdateCRC32; class LIR_OpLock; class LIR_OpTypeCheck; class LIR_OpCompareAndSwap; @@ -982,6 +983,9 @@ enum LIR_Code { , begin_opArrayCopy , lir_arraycopy , end_opArrayCopy + , begin_opUpdateCRC32 + , lir_updatecrc32 + , end_opUpdateCRC32 , begin_opLock , lir_lock , lir_unlock @@ -1137,6 +1141,7 @@ class LIR_Op: public CompilationResourceObj { virtual LIR_Op2* as_Op2() { return NULL; } virtual LIR_Op3* as_Op3() { return NULL; } virtual LIR_OpArrayCopy* as_OpArrayCopy() { return NULL; } + virtual LIR_OpUpdateCRC32* as_OpUpdateCRC32() { return NULL; } virtual LIR_OpTypeCheck* as_OpTypeCheck() { return NULL; } virtual LIR_OpCompareAndSwap* as_OpCompareAndSwap() { return NULL; } virtual LIR_OpProfileCall* as_OpProfileCall() { return NULL; } @@ -1293,6 +1298,25 @@ public: void print_instr(outputStream* out) const PRODUCT_RETURN; }; +// LIR_OpUpdateCRC32 +class LIR_OpUpdateCRC32: public LIR_Op { + friend class LIR_OpVisitState; + +private: + LIR_Opr _crc; + LIR_Opr _val; + +public: + + LIR_OpUpdateCRC32(LIR_Opr crc, LIR_Opr val, LIR_Opr res); + + LIR_Opr crc() const { return _crc; } + LIR_Opr val() const { return _val; } + + virtual void emit_code(LIR_Assembler* masm); + virtual LIR_OpUpdateCRC32* as_OpUpdateCRC32() { return this; } + void print_instr(outputStream* out) const PRODUCT_RETURN; +}; // -------------------------------------------------- // LIR_Op0 @@ -2212,6 +2236,8 @@ class LIR_List: public CompilationResourceObj { void arraycopy(LIR_Opr src, LIR_Opr src_pos, LIR_Opr dst, LIR_Opr dst_pos, LIR_Opr length, LIR_Opr tmp, ciArrayKlass* expected_type, int flags, CodeEmitInfo* info) { append(new LIR_OpArrayCopy(src, src_pos, dst, dst_pos, length, tmp, expected_type, flags, info)); } + void update_crc32(LIR_Opr crc, LIR_Opr val, LIR_Opr res) { append(new LIR_OpUpdateCRC32(crc, val, res)); } + void fpop_raw() { append(new LIR_Op0(lir_fpop_raw)); } void instanceof(LIR_Opr result, LIR_Opr object, ciKlass* klass, LIR_Opr tmp1, LIR_Opr tmp2, LIR_Opr tmp3, bool fast_check, CodeEmitInfo* info_for_patch, ciMethod* profiled_method, int profiled_bci); diff --git a/hotspot/src/share/vm/c1/c1_LIRAssembler.hpp b/hotspot/src/share/vm/c1/c1_LIRAssembler.hpp index 87dd8dbae15..4ced297c07b 100644 --- a/hotspot/src/share/vm/c1/c1_LIRAssembler.hpp +++ b/hotspot/src/share/vm/c1/c1_LIRAssembler.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2000, 2013, 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 @@ -195,6 +195,7 @@ class LIR_Assembler: public CompilationResourceObj { void emit_opBranch(LIR_OpBranch* op); void emit_opLabel(LIR_OpLabel* op); void emit_arraycopy(LIR_OpArrayCopy* op); + void emit_updatecrc32(LIR_OpUpdateCRC32* op); void emit_opConvert(LIR_OpConvert* op); void emit_alloc_obj(LIR_OpAllocObj* op); void emit_alloc_array(LIR_OpAllocArray* op); diff --git a/hotspot/src/share/vm/c1/c1_LIRGenerator.cpp b/hotspot/src/share/vm/c1/c1_LIRGenerator.cpp index fcd6910ed95..3af2d23b7d6 100644 --- a/hotspot/src/share/vm/c1/c1_LIRGenerator.cpp +++ b/hotspot/src/share/vm/c1/c1_LIRGenerator.cpp @@ -2994,6 +2994,12 @@ void LIRGenerator::do_Intrinsic(Intrinsic* x) { do_Reference_get(x); break; + case vmIntrinsics::_updateCRC32: + case vmIntrinsics::_updateBytesCRC32: + case vmIntrinsics::_updateByteBufferCRC32: + do_update_CRC32(x); + break; + default: ShouldNotReachHere(); break; } } diff --git a/hotspot/src/share/vm/c1/c1_LIRGenerator.hpp b/hotspot/src/share/vm/c1/c1_LIRGenerator.hpp index d3c76865dbd..0a029207308 100644 --- a/hotspot/src/share/vm/c1/c1_LIRGenerator.hpp +++ b/hotspot/src/share/vm/c1/c1_LIRGenerator.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2013, 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 @@ -247,6 +247,7 @@ class LIRGenerator: public InstructionVisitor, public BlockClosure { void do_NIOCheckIndex(Intrinsic* x); void do_FPIntrinsics(Intrinsic* x); void do_Reference_get(Intrinsic* x); + void do_update_CRC32(Intrinsic* x); void do_UnsafePrefetch(UnsafePrefetch* x, bool is_store); diff --git a/hotspot/src/share/vm/c1/c1_Runtime1.cpp b/hotspot/src/share/vm/c1/c1_Runtime1.cpp index 53d1f5326a8..908571f6cc4 100644 --- a/hotspot/src/share/vm/c1/c1_Runtime1.cpp +++ b/hotspot/src/share/vm/c1/c1_Runtime1.cpp @@ -299,6 +299,7 @@ const char* Runtime1::name_for_address(address entry) { #ifdef TRACE_HAVE_INTRINSICS FUNCTION_CASE(entry, TRACE_TIME_METHOD); #endif + FUNCTION_CASE(entry, StubRoutines::updateBytesCRC32()); #undef FUNCTION_CASE diff --git a/hotspot/src/share/vm/classfile/vmSymbols.hpp b/hotspot/src/share/vm/classfile/vmSymbols.hpp index 49def1e8d26..7ec43bd7e86 100644 --- a/hotspot/src/share/vm/classfile/vmSymbols.hpp +++ b/hotspot/src/share/vm/classfile/vmSymbols.hpp @@ -771,6 +771,17 @@ do_name( decrypt_name, "decrypt") \ do_signature(byteArray_int_int_byteArray_int_signature, "([BII[BI)V") \ \ + /* support for java.util.zip */ \ + do_class(java_util_zip_CRC32, "java/util/zip/CRC32") \ + do_intrinsic(_updateCRC32, java_util_zip_CRC32, update_name, int2_int_signature, F_SN) \ + do_name( update_name, "update") \ + do_intrinsic(_updateBytesCRC32, java_util_zip_CRC32, updateBytes_name, updateBytes_signature, F_SN) \ + do_name( updateBytes_name, "updateBytes") \ + do_signature(updateBytes_signature, "(I[BII)I") \ + do_intrinsic(_updateByteBufferCRC32, java_util_zip_CRC32, updateByteBuffer_name, updateByteBuffer_signature, F_SN) \ + do_name( updateByteBuffer_name, "updateByteBuffer") \ + do_signature(updateByteBuffer_signature, "(IJII)I") \ + \ /* support for sun.misc.Unsafe */ \ do_class(sun_misc_Unsafe, "sun/misc/Unsafe") \ \ diff --git a/hotspot/src/share/vm/interpreter/abstractInterpreter.hpp b/hotspot/src/share/vm/interpreter/abstractInterpreter.hpp index 264d4fffbf6..77471ad3d5f 100644 --- a/hotspot/src/share/vm/interpreter/abstractInterpreter.hpp +++ b/hotspot/src/share/vm/interpreter/abstractInterpreter.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -102,6 +102,9 @@ class AbstractInterpreter: AllStatic { java_lang_math_pow, // implementation of java.lang.Math.pow (x,y) java_lang_math_exp, // implementation of java.lang.Math.exp (x) java_lang_ref_reference_get, // implementation of java.lang.ref.Reference.get() + java_util_zip_CRC32_update, // implementation of java.util.zip.CRC32.update() + java_util_zip_CRC32_updateBytes, // implementation of java.util.zip.CRC32.updateBytes() + java_util_zip_CRC32_updateByteBuffer, // implementation of java.util.zip.CRC32.updateByteBuffer() number_of_method_entries, invalid = -1 }; diff --git a/hotspot/src/share/vm/interpreter/interpreter.cpp b/hotspot/src/share/vm/interpreter/interpreter.cpp index 06554172bf1..dfd8b5b145a 100644 --- a/hotspot/src/share/vm/interpreter/interpreter.cpp +++ b/hotspot/src/share/vm/interpreter/interpreter.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -195,6 +195,17 @@ AbstractInterpreter::MethodKind AbstractInterpreter::method_kind(methodHandle m) return kind; } +#ifndef CC_INTERP + if (UseCRC32Intrinsics && m->is_native()) { + // Use optimized stub code for CRC32 native methods. + switch (m->intrinsic_id()) { + case vmIntrinsics::_updateCRC32 : return java_util_zip_CRC32_update; + case vmIntrinsics::_updateBytesCRC32 : return java_util_zip_CRC32_updateBytes; + case vmIntrinsics::_updateByteBufferCRC32 : return java_util_zip_CRC32_updateByteBuffer; + } + } +#endif + // Native method? // Note: This test must come _before_ the test for intrinsic // methods. See also comments below. @@ -297,6 +308,9 @@ void AbstractInterpreter::print_method_kind(MethodKind kind) { case java_lang_math_sqrt : tty->print("java_lang_math_sqrt" ); break; case java_lang_math_log : tty->print("java_lang_math_log" ); break; case java_lang_math_log10 : tty->print("java_lang_math_log10" ); break; + case java_util_zip_CRC32_update : tty->print("java_util_zip_CRC32_update"); break; + case java_util_zip_CRC32_updateBytes : tty->print("java_util_zip_CRC32_updateBytes"); break; + case java_util_zip_CRC32_updateByteBuffer : tty->print("java_util_zip_CRC32_updateByteBuffer"); break; default: if (kind >= method_handle_invoke_FIRST && kind <= method_handle_invoke_LAST) { diff --git a/hotspot/src/share/vm/interpreter/templateInterpreter.cpp b/hotspot/src/share/vm/interpreter/templateInterpreter.cpp index 53e50b1c7fe..9f7ed4c7e97 100644 --- a/hotspot/src/share/vm/interpreter/templateInterpreter.cpp +++ b/hotspot/src/share/vm/interpreter/templateInterpreter.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -373,6 +373,12 @@ void TemplateInterpreterGenerator::generate_all() { method_entry(java_lang_math_pow ) method_entry(java_lang_ref_reference_get) + if (UseCRC32Intrinsics) { + method_entry(java_util_zip_CRC32_update) + method_entry(java_util_zip_CRC32_updateBytes) + method_entry(java_util_zip_CRC32_updateByteBuffer) + } + initialize_method_handle_entries(); // all native method kinds (must be one contiguous block) diff --git a/hotspot/src/share/vm/opto/escape.cpp b/hotspot/src/share/vm/opto/escape.cpp index fd561a0c20c..c95226f110c 100644 --- a/hotspot/src/share/vm/opto/escape.cpp +++ b/hotspot/src/share/vm/opto/escape.cpp @@ -933,6 +933,7 @@ void ConnectionGraph::process_call_arguments(CallNode *call) { (call->as_CallLeaf()->_name != NULL && (strcmp(call->as_CallLeaf()->_name, "g1_wb_pre") == 0 || strcmp(call->as_CallLeaf()->_name, "g1_wb_post") == 0 || + strcmp(call->as_CallLeaf()->_name, "updateBytesCRC32") == 0 || strcmp(call->as_CallLeaf()->_name, "aescrypt_encryptBlock") == 0 || strcmp(call->as_CallLeaf()->_name, "aescrypt_decryptBlock") == 0 || strcmp(call->as_CallLeaf()->_name, "cipherBlockChaining_encryptAESCrypt") == 0 || diff --git a/hotspot/src/share/vm/opto/library_call.cpp b/hotspot/src/share/vm/opto/library_call.cpp index 728d892534b..df84634832a 100644 --- a/hotspot/src/share/vm/opto/library_call.cpp +++ b/hotspot/src/share/vm/opto/library_call.cpp @@ -291,6 +291,9 @@ class LibraryCallKit : public GraphKit { Node* inline_cipherBlockChaining_AESCrypt_predicate(bool decrypting); Node* get_key_start_from_aescrypt_object(Node* aescrypt_object); bool inline_encodeISOArray(); + bool inline_updateCRC32(); + bool inline_updateBytesCRC32(); + bool inline_updateByteBufferCRC32(); }; @@ -488,6 +491,12 @@ CallGenerator* Compile::make_vm_intrinsic(ciMethod* m, bool is_virtual) { is_predicted = true; break; + case vmIntrinsics::_updateCRC32: + case vmIntrinsics::_updateBytesCRC32: + case vmIntrinsics::_updateByteBufferCRC32: + if (!UseCRC32Intrinsics) return NULL; + break; + default: assert(id <= vmIntrinsics::LAST_COMPILER_INLINE, "caller responsibility"); assert(id != vmIntrinsics::_Object_init && id != vmIntrinsics::_invoke, "enum out of order?"); @@ -807,6 +816,13 @@ bool LibraryCallKit::try_to_inline() { case vmIntrinsics::_encodeISOArray: return inline_encodeISOArray(); + case vmIntrinsics::_updateCRC32: + return inline_updateCRC32(); + case vmIntrinsics::_updateBytesCRC32: + return inline_updateBytesCRC32(); + case vmIntrinsics::_updateByteBufferCRC32: + return inline_updateByteBufferCRC32(); + default: // If you get here, it may be that someone has added a new intrinsic // to the list in vmSymbols.hpp without implementing it here. @@ -884,7 +900,7 @@ Node* LibraryCallKit::generate_guard(Node* test, RegionNode* region, float true_ IfNode* iff = create_and_map_if(control(), test, true_prob, COUNT_UNKNOWN); - Node* if_slow = _gvn.transform( new (C) IfTrueNode(iff) ); + Node* if_slow = _gvn.transform(new (C) IfTrueNode(iff)); if (if_slow == top()) { // The slow branch is never taken. No need to build this guard. return NULL; @@ -893,7 +909,7 @@ Node* LibraryCallKit::generate_guard(Node* test, RegionNode* region, float true_ if (region != NULL) region->add_req(if_slow); - Node* if_fast = _gvn.transform( new (C) IfFalseNode(iff) ); + Node* if_fast = _gvn.transform(new (C) IfFalseNode(iff)); set_control(if_fast); return if_slow; @@ -912,8 +928,8 @@ inline Node* LibraryCallKit::generate_negative_guard(Node* index, RegionNode* re return NULL; // already stopped if (_gvn.type(index)->higher_equal(TypeInt::POS)) // [0,maxint] return NULL; // index is already adequately typed - Node* cmp_lt = _gvn.transform( new (C) CmpINode(index, intcon(0)) ); - Node* bol_lt = _gvn.transform( new (C) BoolNode(cmp_lt, BoolTest::lt) ); + Node* cmp_lt = _gvn.transform(new (C) CmpINode(index, intcon(0))); + Node* bol_lt = _gvn.transform(new (C) BoolNode(cmp_lt, BoolTest::lt)); Node* is_neg = generate_guard(bol_lt, region, PROB_MIN); if (is_neg != NULL && pos_index != NULL) { // Emulate effect of Parse::adjust_map_after_if. @@ -930,9 +946,9 @@ inline Node* LibraryCallKit::generate_nonpositive_guard(Node* index, bool never_ return NULL; // already stopped if (_gvn.type(index)->higher_equal(TypeInt::POS1)) // [1,maxint] return NULL; // index is already adequately typed - Node* cmp_le = _gvn.transform( new (C) CmpINode(index, intcon(0)) ); + Node* cmp_le = _gvn.transform(new (C) CmpINode(index, intcon(0))); BoolTest::mask le_or_eq = (never_negative ? BoolTest::eq : BoolTest::le); - Node* bol_le = _gvn.transform( new (C) BoolNode(cmp_le, le_or_eq) ); + Node* bol_le = _gvn.transform(new (C) BoolNode(cmp_le, le_or_eq)); Node* is_notp = generate_guard(bol_le, NULL, PROB_MIN); if (is_notp != NULL && pos_index != NULL) { // Emulate effect of Parse::adjust_map_after_if. @@ -968,9 +984,9 @@ inline Node* LibraryCallKit::generate_limit_guard(Node* offset, return NULL; // common case of whole-array copy Node* last = subseq_length; if (!zero_offset) // last += offset - last = _gvn.transform( new (C) AddINode(last, offset)); - Node* cmp_lt = _gvn.transform( new (C) CmpUNode(array_length, last) ); - Node* bol_lt = _gvn.transform( new (C) BoolNode(cmp_lt, BoolTest::lt) ); + last = _gvn.transform(new (C) AddINode(last, offset)); + Node* cmp_lt = _gvn.transform(new (C) CmpUNode(array_length, last)); + Node* bol_lt = _gvn.transform(new (C) BoolNode(cmp_lt, BoolTest::lt)); Node* is_over = generate_guard(bol_lt, region, PROB_MIN); return is_over; } @@ -1151,8 +1167,8 @@ bool LibraryCallKit::inline_string_equals() { Node* argument_cnt = load_String_length(no_ctrl, argument); // Check for receiver count != argument count - Node* cmp = _gvn.transform( new(C) CmpINode(receiver_cnt, argument_cnt) ); - Node* bol = _gvn.transform( new(C) BoolNode(cmp, BoolTest::ne) ); + Node* cmp = _gvn.transform(new(C) CmpINode(receiver_cnt, argument_cnt)); + Node* bol = _gvn.transform(new(C) BoolNode(cmp, BoolTest::ne)); Node* if_ne = generate_slow_guard(bol, NULL); if (if_ne != NULL) { phi->init_req(4, intcon(0)); @@ -1258,7 +1274,7 @@ Node* LibraryCallKit::string_indexOf(Node* string_object, ciTypeArray* target_ar Node* sourceOffset = load_String_offset(no_ctrl, string_object); Node* sourceCount = load_String_length(no_ctrl, string_object); - Node* target = _gvn.transform( makecon(TypeOopPtr::make_from_constant(target_array, true)) ); + Node* target = _gvn.transform( makecon(TypeOopPtr::make_from_constant(target_array, true))); jint target_length = target_array->length(); const TypeAry* target_array_type = TypeAry::make(TypeInt::CHAR, TypeInt::make(0, target_length, Type::WidenMin)); const TypeAryPtr* target_type = TypeAryPtr::make(TypePtr::BotPTR, target_array_type, target_array->klass(), true, Type::OffsetBot); @@ -1365,8 +1381,8 @@ bool LibraryCallKit::inline_string_indexOf() { Node* substr_cnt = load_String_length(no_ctrl, arg); // Check for substr count > string count - Node* cmp = _gvn.transform( new(C) CmpINode(substr_cnt, source_cnt) ); - Node* bol = _gvn.transform( new(C) BoolNode(cmp, BoolTest::gt) ); + Node* cmp = _gvn.transform(new(C) CmpINode(substr_cnt, source_cnt)); + Node* bol = _gvn.transform(new(C) BoolNode(cmp, BoolTest::gt)); Node* if_gt = generate_slow_guard(bol, NULL); if (if_gt != NULL) { result_phi->init_req(2, intcon(-1)); @@ -1375,8 +1391,8 @@ bool LibraryCallKit::inline_string_indexOf() { if (!stopped()) { // Check for substr count == 0 - cmp = _gvn.transform( new(C) CmpINode(substr_cnt, intcon(0)) ); - bol = _gvn.transform( new(C) BoolNode(cmp, BoolTest::eq) ); + cmp = _gvn.transform(new(C) CmpINode(substr_cnt, intcon(0))); + bol = _gvn.transform(new(C) BoolNode(cmp, BoolTest::eq)); Node* if_zero = generate_slow_guard(bol, NULL); if (if_zero != NULL) { result_phi->init_req(3, intcon(0)); @@ -1552,7 +1568,7 @@ bool LibraryCallKit::inline_trig(vmIntrinsics::ID id) { // Check PI/4 : abs(arg) Node *cmp = _gvn.transform(new (C) CmpDNode(pi4,abs)); // Check: If PI/4 < abs(arg) then go slow - Node *bol = _gvn.transform( new (C) BoolNode( cmp, BoolTest::lt ) ); + Node *bol = _gvn.transform(new (C) BoolNode( cmp, BoolTest::lt )); // Branch either way IfNode *iff = create_and_xform_if(control(),bol, PROB_STATIC_FREQUENT, COUNT_UNKNOWN); set_control(opt_iff(r,iff)); @@ -1617,8 +1633,8 @@ void LibraryCallKit::finish_pow_exp(Node* result, Node* x, Node* y, const TypeFu // to the runtime to properly handle corner cases IfNode* iff = create_and_xform_if(control(), bolisnum, PROB_STATIC_FREQUENT, COUNT_UNKNOWN); - Node* if_slow = _gvn.transform( new (C) IfFalseNode(iff) ); - Node* if_fast = _gvn.transform( new (C) IfTrueNode(iff) ); + Node* if_slow = _gvn.transform(new (C) IfFalseNode(iff)); + Node* if_fast = _gvn.transform(new (C) IfTrueNode(iff)); if (!if_slow->is_top()) { RegionNode* result_region = new (C) RegionNode(3); @@ -1704,42 +1720,42 @@ bool LibraryCallKit::inline_pow() { // Check x:0 Node *cmp = _gvn.transform(new (C) CmpDNode(x, zeronode)); // Check: If (x<=0) then go complex path - Node *bol1 = _gvn.transform( new (C) BoolNode( cmp, BoolTest::le ) ); + Node *bol1 = _gvn.transform(new (C) BoolNode( cmp, BoolTest::le )); // Branch either way IfNode *if1 = create_and_xform_if(control(),bol1, PROB_STATIC_INFREQUENT, COUNT_UNKNOWN); // Fast path taken; set region slot 3 - Node *fast_taken = _gvn.transform( new (C) IfFalseNode(if1) ); + Node *fast_taken = _gvn.transform(new (C) IfFalseNode(if1)); r->init_req(3,fast_taken); // Capture fast-control // Fast path not-taken, i.e. slow path - Node *complex_path = _gvn.transform( new (C) IfTrueNode(if1) ); + Node *complex_path = _gvn.transform(new (C) IfTrueNode(if1)); // Set fast path result - Node *fast_result = _gvn.transform( new (C) PowDNode(C, control(), x, y) ); + Node *fast_result = _gvn.transform(new (C) PowDNode(C, control(), x, y)); phi->init_req(3, fast_result); // Complex path // Build the second if node (if y is long) // Node for (long)y - Node *longy = _gvn.transform( new (C) ConvD2LNode(y)); + Node *longy = _gvn.transform(new (C) ConvD2LNode(y)); // Node for (double)((long) y) - Node *doublelongy= _gvn.transform( new (C) ConvL2DNode(longy)); + Node *doublelongy= _gvn.transform(new (C) ConvL2DNode(longy)); // Check (double)((long) y) : y Node *cmplongy= _gvn.transform(new (C) CmpDNode(doublelongy, y)); // Check if (y isn't long) then go to slow path - Node *bol2 = _gvn.transform( new (C) BoolNode( cmplongy, BoolTest::ne ) ); + Node *bol2 = _gvn.transform(new (C) BoolNode( cmplongy, BoolTest::ne )); // Branch either way IfNode *if2 = create_and_xform_if(complex_path,bol2, PROB_STATIC_INFREQUENT, COUNT_UNKNOWN); - Node* ylong_path = _gvn.transform( new (C) IfFalseNode(if2)); + Node* ylong_path = _gvn.transform(new (C) IfFalseNode(if2)); - Node *slow_path = _gvn.transform( new (C) IfTrueNode(if2) ); + Node *slow_path = _gvn.transform(new (C) IfTrueNode(if2)); // Calculate DPow(abs(x), y)*(1 & (long)y) // Node for constant 1 Node *conone = longcon(1); // 1& (long)y - Node *signnode= _gvn.transform( new (C) AndLNode(conone, longy) ); + Node *signnode= _gvn.transform(new (C) AndLNode(conone, longy)); // A huge number is always even. Detect a huge number by checking // if y + 1 == y and set integer to be tested for parity to 0. @@ -1747,9 +1763,9 @@ bool LibraryCallKit::inline_pow() { // (long)9.223372036854776E18 = max_jlong // (double)(long)9.223372036854776E18 = 9.223372036854776E18 // max_jlong is odd but 9.223372036854776E18 is even - Node* yplus1 = _gvn.transform( new (C) AddDNode(y, makecon(TypeD::make(1)))); + Node* yplus1 = _gvn.transform(new (C) AddDNode(y, makecon(TypeD::make(1)))); Node *cmpyplus1= _gvn.transform(new (C) CmpDNode(yplus1, y)); - Node *bolyplus1 = _gvn.transform( new (C) BoolNode( cmpyplus1, BoolTest::eq ) ); + Node *bolyplus1 = _gvn.transform(new (C) BoolNode( cmpyplus1, BoolTest::eq )); Node* correctedsign = NULL; if (ConditionalMoveLimit != 0) { correctedsign = _gvn.transform( CMoveNode::make(C, NULL, bolyplus1, signnode, longcon(0), TypeLong::LONG)); @@ -1757,8 +1773,8 @@ bool LibraryCallKit::inline_pow() { IfNode *ifyplus1 = create_and_xform_if(ylong_path,bolyplus1, PROB_FAIR, COUNT_UNKNOWN); RegionNode *r = new (C) RegionNode(3); Node *phi = new (C) PhiNode(r, TypeLong::LONG); - r->init_req(1, _gvn.transform( new (C) IfFalseNode(ifyplus1))); - r->init_req(2, _gvn.transform( new (C) IfTrueNode(ifyplus1))); + r->init_req(1, _gvn.transform(new (C) IfFalseNode(ifyplus1))); + r->init_req(2, _gvn.transform(new (C) IfTrueNode(ifyplus1))); phi->init_req(1, signnode); phi->init_req(2, longcon(0)); correctedsign = _gvn.transform(phi); @@ -1771,11 +1787,11 @@ bool LibraryCallKit::inline_pow() { // Check (1&(long)y)==0? Node *cmpeq1 = _gvn.transform(new (C) CmpLNode(correctedsign, conzero)); // Check if (1&(long)y)!=0?, if so the result is negative - Node *bol3 = _gvn.transform( new (C) BoolNode( cmpeq1, BoolTest::ne ) ); + Node *bol3 = _gvn.transform(new (C) BoolNode( cmpeq1, BoolTest::ne )); // abs(x) - Node *absx=_gvn.transform( new (C) AbsDNode(x)); + Node *absx=_gvn.transform(new (C) AbsDNode(x)); // abs(x)^y - Node *absxpowy = _gvn.transform( new (C) PowDNode(C, control(), absx, y) ); + Node *absxpowy = _gvn.transform(new (C) PowDNode(C, control(), absx, y)); // -abs(x)^y Node *negabsxpowy = _gvn.transform(new (C) NegDNode (absxpowy)); // (1&(long)y)==1?-DPow(abs(x), y):DPow(abs(x), y) @@ -1786,8 +1802,8 @@ bool LibraryCallKit::inline_pow() { IfNode *ifyeven = create_and_xform_if(ylong_path,bol3, PROB_FAIR, COUNT_UNKNOWN); RegionNode *r = new (C) RegionNode(3); Node *phi = new (C) PhiNode(r, Type::DOUBLE); - r->init_req(1, _gvn.transform( new (C) IfFalseNode(ifyeven))); - r->init_req(2, _gvn.transform( new (C) IfTrueNode(ifyeven))); + r->init_req(1, _gvn.transform(new (C) IfFalseNode(ifyeven))); + r->init_req(2, _gvn.transform(new (C) IfTrueNode(ifyeven))); phi->init_req(1, absxpowy); phi->init_req(2, negabsxpowy); signresult = _gvn.transform(phi); @@ -1920,7 +1936,7 @@ LibraryCallKit::generate_min_max(vmIntrinsics::ID id, Node* x0, Node* y0) { int cmp_op = Op_CmpI; Node* xkey = xvalue; Node* ykey = yvalue; - Node* ideal_cmpxy = _gvn.transform( new(C) CmpINode(xkey, ykey) ); + Node* ideal_cmpxy = _gvn.transform(new(C) CmpINode(xkey, ykey)); if (ideal_cmpxy->is_Cmp()) { // E.g., if we have CmpI(length - offset, count), // it might idealize to CmpI(length, count + offset) @@ -2013,7 +2029,7 @@ LibraryCallKit::generate_min_max(vmIntrinsics::ID id, Node* x0, Node* y0) { default: if (cmpxy == NULL) cmpxy = ideal_cmpxy; - best_bol = _gvn.transform( new(C) BoolNode(cmpxy, BoolTest::lt) ); + best_bol = _gvn.transform(new(C) BoolNode(cmpxy, BoolTest::lt)); // and fall through: case BoolTest::lt: // x < y case BoolTest::le: // x <= y @@ -2073,7 +2089,7 @@ LibraryCallKit::classify_unsafe_addr(Node* &base, Node* &offset) { return Type::AnyPtr; } else if (base_type == TypePtr::NULL_PTR) { // Since this is a NULL+long form, we have to switch to a rawptr. - base = _gvn.transform( new (C) CastX2PNode(offset) ); + base = _gvn.transform(new (C) CastX2PNode(offset)); offset = MakeConX(0); return Type::RawPtr; } else if (base_type->base() == Type::RawPtr) { @@ -2467,7 +2483,7 @@ bool LibraryCallKit::inline_unsafe_access(bool is_native_ptr, bool is_store, Bas case T_ADDRESS: // Repackage the long as a pointer. val = ConvL2X(val); - val = _gvn.transform( new (C) CastX2PNode(val) ); + val = _gvn.transform(new (C) CastX2PNode(val)); break; } @@ -2775,7 +2791,7 @@ bool LibraryCallKit::inline_unsafe_load_store(BasicType type, LoadStoreKind kind // SCMemProjNodes represent the memory state of a LoadStore. Their // main role is to prevent LoadStore nodes from being optimized away // when their results aren't used. - Node* proj = _gvn.transform( new (C) SCMemProjNode(load_store)); + Node* proj = _gvn.transform(new (C) SCMemProjNode(load_store)); set_memory(proj, alias_idx); // Add the trailing membar surrounding the access @@ -3010,8 +3026,8 @@ bool LibraryCallKit::inline_native_isInterrupted() { Node* rec_thr = argument(0); Node* tls_ptr = NULL; Node* cur_thr = generate_current_thread(tls_ptr); - Node* cmp_thr = _gvn.transform( new (C) CmpPNode(cur_thr, rec_thr) ); - Node* bol_thr = _gvn.transform( new (C) BoolNode(cmp_thr, BoolTest::ne) ); + Node* cmp_thr = _gvn.transform(new (C) CmpPNode(cur_thr, rec_thr)); + Node* bol_thr = _gvn.transform(new (C) BoolNode(cmp_thr, BoolTest::ne)); generate_slow_guard(bol_thr, slow_region); @@ -3022,36 +3038,36 @@ bool LibraryCallKit::inline_native_isInterrupted() { // Set the control input on the field _interrupted read to prevent it floating up. Node* int_bit = make_load(control(), p, TypeInt::BOOL, T_INT); - Node* cmp_bit = _gvn.transform( new (C) CmpINode(int_bit, intcon(0)) ); - Node* bol_bit = _gvn.transform( new (C) BoolNode(cmp_bit, BoolTest::ne) ); + Node* cmp_bit = _gvn.transform(new (C) CmpINode(int_bit, intcon(0))); + Node* bol_bit = _gvn.transform(new (C) BoolNode(cmp_bit, BoolTest::ne)); IfNode* iff_bit = create_and_map_if(control(), bol_bit, PROB_UNLIKELY_MAG(3), COUNT_UNKNOWN); // First fast path: if (!TLS._interrupted) return false; - Node* false_bit = _gvn.transform( new (C) IfFalseNode(iff_bit) ); + Node* false_bit = _gvn.transform(new (C) IfFalseNode(iff_bit)); result_rgn->init_req(no_int_result_path, false_bit); result_val->init_req(no_int_result_path, intcon(0)); // drop through to next case - set_control( _gvn.transform(new (C) IfTrueNode(iff_bit)) ); + set_control( _gvn.transform(new (C) IfTrueNode(iff_bit))); // (c) Or, if interrupt bit is set and clear_int is false, use 2nd fast path. Node* clr_arg = argument(1); - Node* cmp_arg = _gvn.transform( new (C) CmpINode(clr_arg, intcon(0)) ); - Node* bol_arg = _gvn.transform( new (C) BoolNode(cmp_arg, BoolTest::ne) ); + Node* cmp_arg = _gvn.transform(new (C) CmpINode(clr_arg, intcon(0))); + Node* bol_arg = _gvn.transform(new (C) BoolNode(cmp_arg, BoolTest::ne)); IfNode* iff_arg = create_and_map_if(control(), bol_arg, PROB_FAIR, COUNT_UNKNOWN); // Second fast path: ... else if (!clear_int) return true; - Node* false_arg = _gvn.transform( new (C) IfFalseNode(iff_arg) ); + Node* false_arg = _gvn.transform(new (C) IfFalseNode(iff_arg)); result_rgn->init_req(no_clear_result_path, false_arg); result_val->init_req(no_clear_result_path, intcon(1)); // drop through to next case - set_control( _gvn.transform(new (C) IfTrueNode(iff_arg)) ); + set_control( _gvn.transform(new (C) IfTrueNode(iff_arg))); // (d) Otherwise, go to the slow path. slow_region->add_req(control()); - set_control( _gvn.transform(slow_region) ); + set_control( _gvn.transform(slow_region)); if (stopped()) { // There is no slow path. @@ -3107,7 +3123,7 @@ Node* LibraryCallKit::load_klass_from_mirror_common(Node* mirror, if (region == NULL) never_see_null = true; Node* p = basic_plus_adr(mirror, offset); const TypeKlassPtr* kls_type = TypeKlassPtr::OBJECT_OR_NULL; - Node* kls = _gvn.transform( LoadKlassNode::make(_gvn, immutable_memory(), p, TypeRawPtr::BOTTOM, kls_type) ); + Node* kls = _gvn.transform( LoadKlassNode::make(_gvn, immutable_memory(), p, TypeRawPtr::BOTTOM, kls_type)); Node* null_ctl = top(); kls = null_check_oop(kls, &null_ctl, never_see_null); if (region != NULL) { @@ -3129,9 +3145,9 @@ Node* LibraryCallKit::generate_access_flags_guard(Node* kls, int modifier_mask, Node* mods = make_load(NULL, modp, TypeInt::INT, T_INT); Node* mask = intcon(modifier_mask); Node* bits = intcon(modifier_bits); - Node* mbit = _gvn.transform( new (C) AndINode(mods, mask) ); - Node* cmp = _gvn.transform( new (C) CmpINode(mbit, bits) ); - Node* bol = _gvn.transform( new (C) BoolNode(cmp, BoolTest::ne) ); + Node* mbit = _gvn.transform(new (C) AndINode(mods, mask)); + Node* cmp = _gvn.transform(new (C) CmpINode(mbit, bits)); + Node* bol = _gvn.transform(new (C) BoolNode(cmp, BoolTest::ne)); return generate_fair_guard(bol, region); } Node* LibraryCallKit::generate_interface_guard(Node* kls, RegionNode* region) { @@ -3282,7 +3298,7 @@ bool LibraryCallKit::inline_native_Class_query(vmIntrinsics::ID id) { phi->add_req(makecon(TypeInstPtr::make(env()->Object_klass()->java_mirror()))); // If we fall through, it's a plain class. Get its _super. p = basic_plus_adr(kls, in_bytes(Klass::super_offset())); - kls = _gvn.transform( LoadKlassNode::make(_gvn, immutable_memory(), p, TypeRawPtr::BOTTOM, TypeKlassPtr::OBJECT_OR_NULL) ); + kls = _gvn.transform( LoadKlassNode::make(_gvn, immutable_memory(), p, TypeRawPtr::BOTTOM, TypeKlassPtr::OBJECT_OR_NULL)); null_ctl = top(); kls = null_check_oop(kls, &null_ctl); if (null_ctl != top()) { @@ -3395,8 +3411,8 @@ bool LibraryCallKit::inline_native_subtype_check() { set_control(region->in(_prim_0_path)); // go back to first null check if (!stopped()) { // Since superc is primitive, make a guard for the superc==subc case. - Node* cmp_eq = _gvn.transform( new (C) CmpPNode(args[0], args[1]) ); - Node* bol_eq = _gvn.transform( new (C) BoolNode(cmp_eq, BoolTest::eq) ); + Node* cmp_eq = _gvn.transform(new (C) CmpPNode(args[0], args[1])); + Node* bol_eq = _gvn.transform(new (C) BoolNode(cmp_eq, BoolTest::eq)); generate_guard(bol_eq, region, PROB_FAIR); if (region->req() == PATH_LIMIT+1) { // A guard was added. If the added guard is taken, superc==subc. @@ -3461,11 +3477,11 @@ Node* LibraryCallKit::generate_array_guard_common(Node* kls, RegionNode* region, ? ((jint)Klass::_lh_array_tag_type_value << Klass::_lh_array_tag_shift) : Klass::_lh_neutral_value); - Node* cmp = _gvn.transform( new(C) CmpINode(layout_val, intcon(nval)) ); + Node* cmp = _gvn.transform(new(C) CmpINode(layout_val, intcon(nval))); BoolTest::mask btest = BoolTest::lt; // correct for testing is_[obj]array // invert the test if we are looking for a non-array if (not_array) btest = BoolTest(btest).negate(); - Node* bol = _gvn.transform( new(C) BoolNode(cmp, btest) ); + Node* bol = _gvn.transform(new(C) BoolNode(cmp, btest)); return generate_fair_guard(bol, region); } @@ -3525,7 +3541,7 @@ bool LibraryCallKit::inline_native_newArray() { // Return the combined state. set_i_o( _gvn.transform(result_io) ); - set_all_memory( _gvn.transform(result_mem) ); + set_all_memory( _gvn.transform(result_mem)); C->set_has_split_ifs(true); // Has chance for split-if optimization set_result(result_reg, result_val); @@ -3678,8 +3694,8 @@ Node* LibraryCallKit::generate_virtual_guard(Node* obj_klass, const TypePtr* native_call_addr = TypeMetadataPtr::make(method); Node* native_call = makecon(native_call_addr); - Node* chk_native = _gvn.transform( new(C) CmpPNode(target_call, native_call) ); - Node* test_native = _gvn.transform( new(C) BoolNode(chk_native, BoolTest::ne) ); + Node* chk_native = _gvn.transform(new(C) CmpPNode(target_call, native_call)); + Node* test_native = _gvn.transform(new(C) BoolNode(chk_native, BoolTest::ne)); return generate_slow_guard(test_native, slow_region); } @@ -3800,10 +3816,10 @@ bool LibraryCallKit::inline_native_hashcode(bool is_virtual, bool is_static) { // Test the header to see if it is unlocked. Node *lock_mask = _gvn.MakeConX(markOopDesc::biased_lock_mask_in_place); - Node *lmasked_header = _gvn.transform( new (C) AndXNode(header, lock_mask) ); + Node *lmasked_header = _gvn.transform(new (C) AndXNode(header, lock_mask)); Node *unlocked_val = _gvn.MakeConX(markOopDesc::unlocked_value); - Node *chk_unlocked = _gvn.transform( new (C) CmpXNode( lmasked_header, unlocked_val)); - Node *test_unlocked = _gvn.transform( new (C) BoolNode( chk_unlocked, BoolTest::ne) ); + Node *chk_unlocked = _gvn.transform(new (C) CmpXNode( lmasked_header, unlocked_val)); + Node *test_unlocked = _gvn.transform(new (C) BoolNode( chk_unlocked, BoolTest::ne)); generate_slow_guard(test_unlocked, slow_region); @@ -3813,17 +3829,17 @@ bool LibraryCallKit::inline_native_hashcode(bool is_virtual, bool is_static) { // vm: see markOop.hpp. Node *hash_mask = _gvn.intcon(markOopDesc::hash_mask); Node *hash_shift = _gvn.intcon(markOopDesc::hash_shift); - Node *hshifted_header= _gvn.transform( new (C) URShiftXNode(header, hash_shift) ); + Node *hshifted_header= _gvn.transform(new (C) URShiftXNode(header, hash_shift)); // This hack lets the hash bits live anywhere in the mark object now, as long // as the shift drops the relevant bits into the low 32 bits. Note that // Java spec says that HashCode is an int so there's no point in capturing // an 'X'-sized hashcode (32 in 32-bit build or 64 in 64-bit build). hshifted_header = ConvX2I(hshifted_header); - Node *hash_val = _gvn.transform( new (C) AndINode(hshifted_header, hash_mask) ); + Node *hash_val = _gvn.transform(new (C) AndINode(hshifted_header, hash_mask)); Node *no_hash_val = _gvn.intcon(markOopDesc::no_hash); - Node *chk_assigned = _gvn.transform( new (C) CmpINode( hash_val, no_hash_val)); - Node *test_assigned = _gvn.transform( new (C) BoolNode( chk_assigned, BoolTest::eq) ); + Node *chk_assigned = _gvn.transform(new (C) CmpINode( hash_val, no_hash_val)); + Node *test_assigned = _gvn.transform(new (C) BoolNode( chk_assigned, BoolTest::eq)); generate_slow_guard(test_assigned, slow_region); @@ -3854,7 +3870,7 @@ bool LibraryCallKit::inline_native_hashcode(bool is_virtual, bool is_static) { // Return the combined state. set_i_o( _gvn.transform(result_io) ); - set_all_memory( _gvn.transform(result_mem) ); + set_all_memory( _gvn.transform(result_mem)); set_result(result_reg, result_val); return true; @@ -3982,7 +3998,7 @@ bool LibraryCallKit::inline_fp_conversions(vmIntrinsics::ID id) { Node *opt_isnan = _gvn.transform(ifisnan); assert( opt_isnan->is_If(), "Expect an IfNode"); IfNode *opt_ifisnan = (IfNode*)opt_isnan; - Node *iftrue = _gvn.transform( new (C) IfTrueNode(opt_ifisnan) ); + Node *iftrue = _gvn.transform(new (C) IfTrueNode(opt_ifisnan)); set_control(iftrue); @@ -4023,7 +4039,7 @@ bool LibraryCallKit::inline_fp_conversions(vmIntrinsics::ID id) { Node *opt_isnan = _gvn.transform(ifisnan); assert( opt_isnan->is_If(), "Expect an IfNode"); IfNode *opt_ifisnan = (IfNode*)opt_isnan; - Node *iftrue = _gvn.transform( new (C) IfTrueNode(opt_ifisnan) ); + Node *iftrue = _gvn.transform(new (C) IfTrueNode(opt_ifisnan)); set_control(iftrue); @@ -4152,8 +4168,8 @@ void LibraryCallKit::copy_to_clone(Node* obj, Node* alloc_obj, Node* obj_size, b // Compute the length also, if needed: Node* countx = size; - countx = _gvn.transform( new (C) SubXNode(countx, MakeConX(base_off)) ); - countx = _gvn.transform( new (C) URShiftXNode(countx, intcon(LogBytesPerLong) )); + countx = _gvn.transform(new (C) SubXNode(countx, MakeConX(base_off))); + countx = _gvn.transform(new (C) URShiftXNode(countx, intcon(LogBytesPerLong) )); const TypePtr* raw_adr_type = TypeRawPtr::BOTTOM; bool disjoint_bases = true; @@ -4357,9 +4373,9 @@ bool LibraryCallKit::inline_native_clone(bool is_virtual) { } // Return the combined state. - set_control( _gvn.transform(result_reg) ); - set_i_o( _gvn.transform(result_i_o) ); - set_all_memory( _gvn.transform(result_mem) ); + set_control( _gvn.transform(result_reg)); + set_i_o( _gvn.transform(result_i_o)); + set_all_memory( _gvn.transform(result_mem)); } // original reexecute is set back here set_result(_gvn.transform(result_val)); @@ -4684,8 +4700,8 @@ LibraryCallKit::generate_arraycopy(const TypePtr* adr_type, // are dest_head = dest[0..off] and dest_tail = dest[off+len..dest.length]. Node* dest_size = alloc->in(AllocateNode::AllocSize); Node* dest_length = alloc->in(AllocateNode::ALength); - Node* dest_tail = _gvn.transform( new(C) AddINode(dest_offset, - copy_length) ); + Node* dest_tail = _gvn.transform(new(C) AddINode(dest_offset, + copy_length)); // If there is a head section that needs zeroing, do it now. if (find_int_con(dest_offset, -1) != 0) { @@ -4701,8 +4717,8 @@ LibraryCallKit::generate_arraycopy(const TypePtr* adr_type, // the copy to a more hardware-friendly word size of 64 bits. Node* tail_ctl = NULL; if (!stopped() && !dest_tail->eqv_uncast(dest_length)) { - Node* cmp_lt = _gvn.transform( new(C) CmpINode(dest_tail, dest_length) ); - Node* bol_lt = _gvn.transform( new(C) BoolNode(cmp_lt, BoolTest::lt) ); + Node* cmp_lt = _gvn.transform(new(C) CmpINode(dest_tail, dest_length)); + Node* bol_lt = _gvn.transform(new(C) BoolNode(cmp_lt, BoolTest::lt)); tail_ctl = generate_slow_guard(bol_lt, NULL); assert(tail_ctl != NULL || !stopped(), "must be an outcome"); } @@ -4745,7 +4761,7 @@ LibraryCallKit::generate_arraycopy(const TypePtr* adr_type, dest_size); done_ctl->init_req(2, control()); done_mem->init_req(2, memory(adr_type)); - set_control( _gvn.transform(done_ctl) ); + set_control( _gvn.transform(done_ctl)); set_memory( _gvn.transform(done_mem), adr_type ); } } @@ -4832,18 +4848,18 @@ LibraryCallKit::generate_arraycopy(const TypePtr* adr_type, // Clean up after the checked call. // The returned value is either 0 or -1^K, // where K = number of partially transferred array elements. - Node* cmp = _gvn.transform( new(C) CmpINode(checked_value, intcon(0)) ); - Node* bol = _gvn.transform( new(C) BoolNode(cmp, BoolTest::eq) ); + Node* cmp = _gvn.transform(new(C) CmpINode(checked_value, intcon(0))); + Node* bol = _gvn.transform(new(C) BoolNode(cmp, BoolTest::eq)); IfNode* iff = create_and_map_if(control(), bol, PROB_MAX, COUNT_UNKNOWN); // If it is 0, we are done, so transfer to the end. - Node* checks_done = _gvn.transform( new(C) IfTrueNode(iff) ); + Node* checks_done = _gvn.transform(new(C) IfTrueNode(iff)); result_region->init_req(checked_path, checks_done); result_i_o ->init_req(checked_path, checked_i_o); result_memory->init_req(checked_path, checked_mem); // If it is not zero, merge into the slow call. - set_control( _gvn.transform( new(C) IfFalseNode(iff) )); + set_control( _gvn.transform(new(C) IfFalseNode(iff) )); RegionNode* slow_reg2 = new(C) RegionNode(3); PhiNode* slow_i_o2 = new(C) PhiNode(slow_reg2, Type::ABIO); PhiNode* slow_mem2 = new(C) PhiNode(slow_reg2, Type::MEMORY, adr_type); @@ -4866,16 +4882,16 @@ LibraryCallKit::generate_arraycopy(const TypePtr* adr_type, } else { // We must continue the copy exactly where it failed, or else // another thread might see the wrong number of writes to dest. - Node* checked_offset = _gvn.transform( new(C) XorINode(checked_value, intcon(-1)) ); + Node* checked_offset = _gvn.transform(new(C) XorINode(checked_value, intcon(-1))); Node* slow_offset = new(C) PhiNode(slow_reg2, TypeInt::INT); slow_offset->init_req(1, intcon(0)); slow_offset->init_req(2, checked_offset); slow_offset = _gvn.transform(slow_offset); // Adjust the arguments by the conditionally incoming offset. - Node* src_off_plus = _gvn.transform( new(C) AddINode(src_offset, slow_offset) ); - Node* dest_off_plus = _gvn.transform( new(C) AddINode(dest_offset, slow_offset) ); - Node* length_minus = _gvn.transform( new(C) SubINode(copy_length, slow_offset) ); + Node* src_off_plus = _gvn.transform(new(C) AddINode(src_offset, slow_offset)); + Node* dest_off_plus = _gvn.transform(new(C) AddINode(dest_offset, slow_offset)); + Node* length_minus = _gvn.transform(new(C) SubINode(copy_length, slow_offset)); // Tweak the node variables to adjust the code produced below: src_offset = src_off_plus; @@ -4914,7 +4930,7 @@ LibraryCallKit::generate_arraycopy(const TypePtr* adr_type, } // Finished; return the combined state. - set_control( _gvn.transform(result_region) ); + set_control( _gvn.transform(result_region)); set_i_o( _gvn.transform(result_i_o) ); set_memory( _gvn.transform(result_memory), adr_type ); @@ -5096,10 +5112,10 @@ LibraryCallKit::generate_clear_array(const TypePtr* adr_type, int end_round = (-1 << scale) & (BytesPerLong - 1); Node* end = ConvI2X(slice_len); if (scale != 0) - end = _gvn.transform( new(C) LShiftXNode(end, intcon(scale) )); + end = _gvn.transform(new(C) LShiftXNode(end, intcon(scale) )); end_base += end_round; - end = _gvn.transform( new(C) AddXNode(end, MakeConX(end_base)) ); - end = _gvn.transform( new(C) AndXNode(end, MakeConX(~end_round)) ); + end = _gvn.transform(new(C) AddXNode(end, MakeConX(end_base))); + end = _gvn.transform(new(C) AndXNode(end, MakeConX(~end_round))); mem = ClearArrayNode::clear_memory(control(), mem, dest, start_con, end, &_gvn); } else if (start_con < 0 && dest_size != top()) { @@ -5108,8 +5124,8 @@ LibraryCallKit::generate_clear_array(const TypePtr* adr_type, Node* start = slice_idx; start = ConvI2X(start); if (scale != 0) - start = _gvn.transform( new(C) LShiftXNode( start, intcon(scale) )); - start = _gvn.transform( new(C) AddXNode(start, MakeConX(abase)) ); + start = _gvn.transform(new(C) LShiftXNode( start, intcon(scale) )); + start = _gvn.transform(new(C) AddXNode(start, MakeConX(abase))); if ((bump_bit | clear_low) != 0) { int to_clear = (bump_bit | clear_low); // Align up mod 8, then store a jint zero unconditionally @@ -5120,14 +5136,14 @@ LibraryCallKit::generate_clear_array(const TypePtr* adr_type, assert((abase & to_clear) == 0, "array base must be long-aligned"); } else { // Bump 'start' up to (or past) the next jint boundary: - start = _gvn.transform( new(C) AddXNode(start, MakeConX(bump_bit)) ); + start = _gvn.transform(new(C) AddXNode(start, MakeConX(bump_bit))); assert((abase & clear_low) == 0, "array base must be int-aligned"); } // Round bumped 'start' down to jlong boundary in body of array. - start = _gvn.transform( new(C) AndXNode(start, MakeConX(~to_clear)) ); + start = _gvn.transform(new(C) AndXNode(start, MakeConX(~to_clear))); if (bump_bit != 0) { // Store a zero to the immediately preceding jint: - Node* x1 = _gvn.transform( new(C) AddXNode(start, MakeConX(-bump_bit)) ); + Node* x1 = _gvn.transform(new(C) AddXNode(start, MakeConX(-bump_bit))); Node* p1 = basic_plus_adr(dest, x1); mem = StoreNode::make(_gvn, control(), mem, p1, adr_type, intcon(0), T_INT); mem = _gvn.transform(mem); @@ -5194,8 +5210,8 @@ LibraryCallKit::generate_block_arraycopy(const TypePtr* adr_type, Node* sptr = basic_plus_adr(src, src_off); Node* dptr = basic_plus_adr(dest, dest_off); Node* countx = dest_size; - countx = _gvn.transform( new (C) SubXNode(countx, MakeConX(dest_off)) ); - countx = _gvn.transform( new (C) URShiftXNode(countx, intcon(LogBytesPerLong)) ); + countx = _gvn.transform(new (C) SubXNode(countx, MakeConX(dest_off))); + countx = _gvn.transform(new (C) URShiftXNode(countx, intcon(LogBytesPerLong))); bool disjoint_bases = true; // since alloc != NULL generate_unchecked_arraycopy(adr_type, T_LONG, disjoint_bases, @@ -5360,6 +5376,117 @@ bool LibraryCallKit::inline_encodeISOArray() { return true; } +/** + * Calculate CRC32 for byte. + * int java.util.zip.CRC32.update(int crc, int b) + */ +bool LibraryCallKit::inline_updateCRC32() { + assert(UseCRC32Intrinsics, "need AVX and LCMUL instructions support"); + assert(callee()->signature()->size() == 2, "update has 2 parameters"); + // no receiver since it is static method + Node* crc = argument(0); // type: int + Node* b = argument(1); // type: int + + /* + * int c = ~ crc; + * b = timesXtoThe32[(b ^ c) & 0xFF]; + * b = b ^ (c >>> 8); + * crc = ~b; + */ + + Node* M1 = intcon(-1); + crc = _gvn.transform(new (C) XorINode(crc, M1)); + Node* result = _gvn.transform(new (C) XorINode(crc, b)); + result = _gvn.transform(new (C) AndINode(result, intcon(0xFF))); + + Node* base = makecon(TypeRawPtr::make(StubRoutines::crc_table_addr())); + Node* offset = _gvn.transform(new (C) LShiftINode(result, intcon(0x2))); + Node* adr = basic_plus_adr(top(), base, ConvI2X(offset)); + result = make_load(control(), adr, TypeInt::INT, T_INT); + + crc = _gvn.transform(new (C) URShiftINode(crc, intcon(8))); + result = _gvn.transform(new (C) XorINode(crc, result)); + result = _gvn.transform(new (C) XorINode(result, M1)); + set_result(result); + return true; +} + +/** + * Calculate CRC32 for byte[] array. + * int java.util.zip.CRC32.updateBytes(int crc, byte[] buf, int off, int len) + */ +bool LibraryCallKit::inline_updateBytesCRC32() { + assert(UseCRC32Intrinsics, "need AVX and LCMUL instructions support"); + assert(callee()->signature()->size() == 4, "updateBytes has 4 parameters"); + // no receiver since it is static method + Node* crc = argument(0); // type: int + Node* src = argument(1); // type: oop + Node* offset = argument(2); // type: int + Node* length = argument(3); // type: int + + const Type* src_type = src->Value(&_gvn); + const TypeAryPtr* top_src = src_type->isa_aryptr(); + if (top_src == NULL || top_src->klass() == NULL) { + // failed array check + return false; + } + + // Figure out the size and type of the elements we will be copying. + BasicType src_elem = src_type->isa_aryptr()->klass()->as_array_klass()->element_type()->basic_type(); + if (src_elem != T_BYTE) { + return false; + } + + // 'src_start' points to src array + scaled offset + Node* src_start = array_element_address(src, offset, src_elem); + + // We assume that range check is done by caller. + // TODO: generate range check (offset+length < src.length) in debug VM. + + // Call the stub. + address stubAddr = StubRoutines::updateBytesCRC32(); + const char *stubName = "updateBytesCRC32"; + + Node* call = make_runtime_call(RC_LEAF|RC_NO_FP, OptoRuntime::updateBytesCRC32_Type(), + stubAddr, stubName, TypePtr::BOTTOM, + crc, src_start, length); + Node* result = _gvn.transform(new (C) ProjNode(call, TypeFunc::Parms)); + set_result(result); + return true; +} + +/** + * Calculate CRC32 for ByteBuffer. + * int java.util.zip.CRC32.updateByteBuffer(int crc, long buf, int off, int len) + */ +bool LibraryCallKit::inline_updateByteBufferCRC32() { + assert(UseCRC32Intrinsics, "need AVX and LCMUL instructions support"); + assert(callee()->signature()->size() == 5, "updateByteBuffer has 4 parameters and one is long"); + // no receiver since it is static method + Node* crc = argument(0); // type: int + Node* src = argument(1); // type: long + Node* offset = argument(3); // type: int + Node* length = argument(4); // type: int + + src = ConvL2X(src); // adjust Java long to machine word + Node* base = _gvn.transform(new (C) CastX2PNode(src)); + offset = ConvI2X(offset); + + // 'src_start' points to src array + scaled offset + Node* src_start = basic_plus_adr(top(), base, offset); + + // Call the stub. + address stubAddr = StubRoutines::updateBytesCRC32(); + const char *stubName = "updateBytesCRC32"; + + Node* call = make_runtime_call(RC_LEAF|RC_NO_FP, OptoRuntime::updateBytesCRC32_Type(), + stubAddr, stubName, TypePtr::BOTTOM, + crc, src_start, length); + Node* result = _gvn.transform(new (C) ProjNode(call, TypeFunc::Parms)); + set_result(result); + return true; +} + //----------------------------inline_reference_get---------------------------- // public T java.lang.ref.Reference.get(); bool LibraryCallKit::inline_reference_get() { diff --git a/hotspot/src/share/vm/opto/runtime.cpp b/hotspot/src/share/vm/opto/runtime.cpp index d0aefad66b7..9a278c5ac1c 100644 --- a/hotspot/src/share/vm/opto/runtime.cpp +++ b/hotspot/src/share/vm/opto/runtime.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2013, 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 @@ -829,6 +829,28 @@ const TypeFunc* OptoRuntime::aescrypt_block_Type() { return TypeFunc::make(domain, range); } +/** + * int updateBytesCRC32(int crc, byte* b, int len) + */ +const TypeFunc* OptoRuntime::updateBytesCRC32_Type() { + // create input type (domain) + int num_args = 3; + int argcnt = num_args; + const Type** fields = TypeTuple::fields(argcnt); + int argp = TypeFunc::Parms; + fields[argp++] = TypeInt::INT; // crc + fields[argp++] = TypePtr::NOTNULL; // src + fields[argp++] = TypeInt::INT; // len + assert(argp == TypeFunc::Parms+argcnt, "correct decoding"); + const TypeTuple* domain = TypeTuple::make(TypeFunc::Parms+argcnt, fields); + + // result type needed + fields = TypeTuple::fields(1); + fields[TypeFunc::Parms+0] = TypeInt::INT; // crc result + const TypeTuple* range = TypeTuple::make(TypeFunc::Parms+1, fields); + return TypeFunc::make(domain, range); +} + // for cipherBlockChaining calls of aescrypt encrypt/decrypt, four pointers and a length, returning void const TypeFunc* OptoRuntime::cipherBlockChaining_aescrypt_Type() { // create input type (domain) diff --git a/hotspot/src/share/vm/opto/runtime.hpp b/hotspot/src/share/vm/opto/runtime.hpp index 295b7123757..b3f7ff4cb1a 100644 --- a/hotspot/src/share/vm/opto/runtime.hpp +++ b/hotspot/src/share/vm/opto/runtime.hpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2013, 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 @@ -284,6 +284,8 @@ private: static const TypeFunc* aescrypt_block_Type(); static const TypeFunc* cipherBlockChaining_aescrypt_Type(); + static const TypeFunc* updateBytesCRC32_Type(); + // leaf on stack replacement interpreter accessor types static const TypeFunc* osr_end_Type(); diff --git a/hotspot/src/share/vm/runtime/globals.hpp b/hotspot/src/share/vm/runtime/globals.hpp index c94f6bdbb17..1ae802302e0 100644 --- a/hotspot/src/share/vm/runtime/globals.hpp +++ b/hotspot/src/share/vm/runtime/globals.hpp @@ -644,6 +644,9 @@ class CommandLineFlags { product(bool, UseAESIntrinsics, false, \ "use intrinsics for AES versions of crypto") \ \ + product(bool, UseCRC32Intrinsics, false, \ + "use intrinsics for java.util.zip.CRC32") \ + \ develop(bool, TraceCallFixup, false, \ "traces all call fixups") \ \ diff --git a/hotspot/src/share/vm/runtime/stubRoutines.cpp b/hotspot/src/share/vm/runtime/stubRoutines.cpp index c559865b821..a1179acd543 100644 --- a/hotspot/src/share/vm/runtime/stubRoutines.cpp +++ b/hotspot/src/share/vm/runtime/stubRoutines.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2013, 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 @@ -125,6 +125,9 @@ address StubRoutines::_aescrypt_decryptBlock = NULL; address StubRoutines::_cipherBlockChaining_encryptAESCrypt = NULL; address StubRoutines::_cipherBlockChaining_decryptAESCrypt = NULL; +address StubRoutines::_updateBytesCRC32 = NULL; +address StubRoutines::_crc_table_adr = NULL; + double (* StubRoutines::_intrinsic_log )(double) = NULL; double (* StubRoutines::_intrinsic_log10 )(double) = NULL; double (* StubRoutines::_intrinsic_exp )(double) = NULL; diff --git a/hotspot/src/share/vm/runtime/stubRoutines.hpp b/hotspot/src/share/vm/runtime/stubRoutines.hpp index 7ad66371300..b8d61ea0cbf 100644 --- a/hotspot/src/share/vm/runtime/stubRoutines.hpp +++ b/hotspot/src/share/vm/runtime/stubRoutines.hpp @@ -204,6 +204,9 @@ class StubRoutines: AllStatic { static address _cipherBlockChaining_encryptAESCrypt; static address _cipherBlockChaining_decryptAESCrypt; + static address _updateBytesCRC32; + static address _crc_table_adr; + // These are versions of the java.lang.Math methods which perform // the same operations as the intrinsic version. They are used for // constant folding in the compiler to ensure equivalence. If the @@ -342,6 +345,9 @@ class StubRoutines: AllStatic { static address cipherBlockChaining_encryptAESCrypt() { return _cipherBlockChaining_encryptAESCrypt; } static address cipherBlockChaining_decryptAESCrypt() { return _cipherBlockChaining_decryptAESCrypt; } + static address updateBytesCRC32() { return _updateBytesCRC32; } + static address crc_table_addr() { return _crc_table_adr; } + static address select_fill_function(BasicType t, bool aligned, const char* &name); static address zero_aligned_words() { return _zero_aligned_words; } diff --git a/hotspot/test/compiler/7088419/CRCTest.java b/hotspot/test/compiler/7088419/CRCTest.java new file mode 100644 index 00000000000..fa1f520cca8 --- /dev/null +++ b/hotspot/test/compiler/7088419/CRCTest.java @@ -0,0 +1,132 @@ +/* + * Copyright (c) 2013, 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 + @bug 7088419 + @run main CRCTest + @summary Use x86 Hardware CRC32 Instruction with java.util.zip.CRC32 and java.util.zip.Adler32 + */ + +import java.nio.ByteBuffer; +import java.util.zip.CRC32; +import java.util.zip.Checksum; + +public class CRCTest { + + public static void main(String[] args) throws Exception { + + byte[] b = initializedBytes(4096 * 4096); + + { + CRC32 crc1 = new CRC32(); + CRC32 crc2 = new CRC32(); + CRC32 crc3 = new CRC32(); + CRC32 crc4 = new CRC32(); + + crc1.update(b, 0, b.length); + updateSerial(crc2, b, 0, b.length); + updateDirect(crc3, b, 0, b.length); + updateSerialSlow(crc4, b, 0, b.length); + + check(crc1, crc2); + check(crc3, crc4); + check(crc1, crc3); + + crc1.update(17); + crc2.update(17); + crc3.update(17); + crc4.update(17); + + crc1.update(b, 1, b.length-2); + updateSerial(crc2, b, 1, b.length-2); + updateDirect(crc3, b, 1, b.length-2); + updateSerialSlow(crc4, b, 1, b.length-2); + + check(crc1, crc2); + check(crc3, crc4); + check(crc1, crc3); + + report("finished huge crc", crc1, crc2, crc3, crc4); + + for (int i = 0; i < 256; i++) { + for (int j = 0; j < 256; j += 1) { + crc1.update(b, i, j); + updateSerial(crc2, b, i, j); + updateDirect(crc3, b, i, j); + updateSerialSlow(crc4, b, i, j); + + check(crc1, crc2); + check(crc3, crc4); + check(crc1, crc3); + + } + } + + report("finished small survey crc", crc1, crc2, crc3, crc4); + } + + } + + private static void report(String s, Checksum crc1, Checksum crc2, + Checksum crc3, Checksum crc4) { + System.out.println(s + ", crc1 = " + crc1.getValue() + + ", crc2 = " + crc2.getValue()+ + ", crc3 = " + crc3.getValue()+ + ", crc4 = " + crc4.getValue()); + } + + private static void check(Checksum crc1, Checksum crc2) throws Exception { + if (crc1.getValue() != crc2.getValue()) { + String s = "value 1 = " + crc1.getValue() + ", value 2 = " + crc2.getValue(); + System.err.println(s); + throw new Exception(s); + } + } + + private static byte[] initializedBytes(int M) { + byte[] bytes = new byte[M]; + for (int i = 0; i < bytes.length; i++) { + bytes[i] = (byte) i; + } + return bytes; + } + + private static void updateSerial(Checksum crc, byte[] b, int start, int length) { + for (int i = 0; i < length; i++) + crc.update(b[i+start]); + } + + private static void updateSerialSlow(Checksum crc, byte[] b, int start, int length) { + for (int i = 0; i < length; i++) + crc.update(b[i+start]); + crc.getValue(); + } + + private static void updateDirect(CRC32 crc3, byte[] b, int start, int length) { + ByteBuffer buf = ByteBuffer.allocateDirect(length); + buf.put(b, start, length); + buf.flip(); + crc3.update(buf); + } +} From 90c790728d4e081f71af85ee0b7b1e53d681a892 Mon Sep 17 00:00:00 2001 From: Christian Thalinger Date: Tue, 2 Jul 2013 20:27:00 -0700 Subject: [PATCH 119/127] 8017571: JSR292: JVM crashing on assert "cast to instanceKlass" while producing MethodHandle for array methods with MethodHandle.findVirtual Reviewed-by: kvn --- hotspot/src/share/vm/prims/methodHandles.cpp | 7 ++++++- hotspot/src/share/vm/runtime/reflection.cpp | 2 +- 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/hotspot/src/share/vm/prims/methodHandles.cpp b/hotspot/src/share/vm/prims/methodHandles.cpp index bb9da0034e4..ac1c796eb31 100644 --- a/hotspot/src/share/vm/prims/methodHandles.cpp +++ b/hotspot/src/share/vm/prims/methodHandles.cpp @@ -1137,7 +1137,12 @@ JVM_ENTRY(jobject, MHN_resolve_Mem(JNIEnv *env, jobject igcls, jobject mname_jh, if (VerifyMethodHandles && caller_jh != NULL && java_lang_invoke_MemberName::clazz(mname()) != NULL) { Klass* reference_klass = java_lang_Class::as_Klass(java_lang_invoke_MemberName::clazz(mname())); - if (reference_klass != NULL) { + if (reference_klass != NULL && reference_klass->oop_is_objArray()) { + reference_klass = ObjArrayKlass::cast(reference_klass)->bottom_klass(); + } + + // Reflection::verify_class_access can only handle instance classes. + if (reference_klass != NULL && reference_klass->oop_is_instance()) { // Emulate LinkResolver::check_klass_accessability. Klass* caller = java_lang_Class::as_Klass(JNIHandles::resolve_non_null(caller_jh)); if (!Reflection::verify_class_access(caller, diff --git a/hotspot/src/share/vm/runtime/reflection.cpp b/hotspot/src/share/vm/runtime/reflection.cpp index 15869cc5c0e..f06a7f922aa 100644 --- a/hotspot/src/share/vm/runtime/reflection.cpp +++ b/hotspot/src/share/vm/runtime/reflection.cpp @@ -458,7 +458,7 @@ bool Reflection::verify_class_access(Klass* current_class, Klass* new_class, boo // doesn't have a classloader. if ((current_class == NULL) || (current_class == new_class) || - (InstanceKlass::cast(new_class)->is_public()) || + (new_class->is_public()) || is_same_class_package(current_class, new_class)) { return true; } From 36a8e303163c1c19e6ae1027566bf15ddf1070fc Mon Sep 17 00:00:00 2001 From: Christine Lu Date: Thu, 4 Jul 2013 01:00:06 -0700 Subject: [PATCH 120/127] Added tag jdk8-b97 for changeset 1c0d035d6968 --- .hgtags-top-repo | 1 + 1 file changed, 1 insertion(+) diff --git a/.hgtags-top-repo b/.hgtags-top-repo index 03af8b5ef30..64129189d67 100644 --- a/.hgtags-top-repo +++ b/.hgtags-top-repo @@ -218,3 +218,4 @@ cb51fb4789ac0b8be4056482077ddfb8f3bd3805 jdk8-b91 50d2bde060f2a9bbbe4da0c8986e20aca61f2e2e jdk8-b94 785d07fe38901ecc1b7e0145e53e1c3da9361fee jdk8-b95 c156084add486f941c12d886a0b1b2854795d557 jdk8-b96 +a1c1e8bf71f354f3aec0214cf13d6668811e021d jdk8-b97 From 4f3801a66f45f2efe4f106b482c97dc2bc0fdd1b Mon Sep 17 00:00:00 2001 From: Christine Lu Date: Thu, 4 Jul 2013 01:00:08 -0700 Subject: [PATCH 121/127] Added tag jdk8-b97 for changeset 1ebe717664d4 --- corba/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/corba/.hgtags b/corba/.hgtags index 77bfead7060..28f0b92d88b 100644 --- a/corba/.hgtags +++ b/corba/.hgtags @@ -218,3 +218,4 @@ c8286839d0df04aba819ec4bef12b86babccf30e jdk8-b90 22f5d7f261d9d61a953d2d9a53f2e9ce0ca361d1 jdk8-b94 2cf36f43df36137980d9828cec27003ec10daeee jdk8-b95 3357c2776431d51a8de326a85e0f41420e40774f jdk8-b96 +469995a8e97424f450c880606d689bf345277b19 jdk8-b97 From 8007f4f434cc3eaf9110c1a4f16b3da302681892 Mon Sep 17 00:00:00 2001 From: Christine Lu Date: Thu, 4 Jul 2013 01:00:19 -0700 Subject: [PATCH 122/127] Added tag jdk8-b97 for changeset 3a6f15473944 --- hotspot/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/hotspot/.hgtags b/hotspot/.hgtags index 0363e7ebd3e..5488b90fb22 100644 --- a/hotspot/.hgtags +++ b/hotspot/.hgtags @@ -355,3 +355,4 @@ b786c04b7be15194febe88dc1f0c9443e737a84b hs25-b35 2cc5a9d1ba66dfdff578918b393c727bd9450210 hs25-b38 e6a4b8c71fa6f225bd989a34de2d0d0a656a8be8 jdk8-b96 2b9380b0bf0b649f40704735773e8956c2d88ba0 hs25-b39 +d197d377ab2e016d024e8c86cb06a57bd7eae590 jdk8-b97 From f1406aa65edc820c782f0c8816a22a6daa225d38 Mon Sep 17 00:00:00 2001 From: Christine Lu Date: Thu, 4 Jul 2013 01:00:52 -0700 Subject: [PATCH 123/127] Added tag jdk8-b97 for changeset a23062727b66 --- jdk/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/jdk/.hgtags b/jdk/.hgtags index 782b2fe3716..e86f63c268a 100644 --- a/jdk/.hgtags +++ b/jdk/.hgtags @@ -218,3 +218,4 @@ a2a2a91075ad85becbe10a39d7fd04ef9bea8df5 jdk8-b92 51479fa56b7c4363c6d87c2e8b898d8185cf4b22 jdk8-b94 42aa9f1828852bb8b77e98ec695211493ae0759d jdk8-b95 4a5d3cf2b3af1660db0237e8da324c140e534fa4 jdk8-b96 +978a95239044f26dcc8a6d59246be07ad6ca6be2 jdk8-b97 From 277da6e5173728b810f197b2a6440cd2b95d6573 Mon Sep 17 00:00:00 2001 From: Christine Lu Date: Thu, 4 Jul 2013 01:01:10 -0700 Subject: [PATCH 124/127] Added tag jdk8-b97 for changeset f9f7fb94f515 --- nashorn/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/nashorn/.hgtags b/nashorn/.hgtags index d23a6e85666..cbbd166c330 100644 --- a/nashorn/.hgtags +++ b/nashorn/.hgtags @@ -206,3 +206,4 @@ ddbf41575a2bdb12ccb9f91e169018bf04073038 jdk8-b93 d92b756bc73966f1bfd111f44f3216cea3bba129 jdk8-b94 cbc9926f5b40a24025c1e15d8870157d651a9ff7 jdk8-b95 d6bd440ac5b97bb1205b6c3274569c1cfe626723 jdk8-b96 +1bf1d6ce30427e1f9dc1ada18db409d1f14d99fe jdk8-b97 From f2930397a1e5272e04339a92e3ac3b1ff1670d16 Mon Sep 17 00:00:00 2001 From: Alejandro Murillo Date: Thu, 4 Jul 2013 14:45:58 -0700 Subject: [PATCH 125/127] Added tag hs25-b40 for changeset d5b4e1fe16bd --- hotspot/.hgtags | 1 + 1 file changed, 1 insertion(+) diff --git a/hotspot/.hgtags b/hotspot/.hgtags index 5488b90fb22..89d305f1d94 100644 --- a/hotspot/.hgtags +++ b/hotspot/.hgtags @@ -356,3 +356,4 @@ b786c04b7be15194febe88dc1f0c9443e737a84b hs25-b35 e6a4b8c71fa6f225bd989a34de2d0d0a656a8be8 jdk8-b96 2b9380b0bf0b649f40704735773e8956c2d88ba0 hs25-b39 d197d377ab2e016d024e8c86cb06a57bd7eae590 jdk8-b97 +c9dd82da51ed34a28f7c6b3245163ee962e94572 hs25-b40 From 7ca1f129930b435222f07cde92142c8149175f2b Mon Sep 17 00:00:00 2001 From: Petr Pchelko Date: Mon, 8 Jul 2013 07:20:44 -0700 Subject: [PATCH 126/127] 8012925: [parfait] Missing return value in jdk/src/macosx/native/sun/awt/AWTEvent.m Reviewed-by: katleman, leonidr --- jdk/src/macosx/native/sun/awt/AWTEvent.m | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/jdk/src/macosx/native/sun/awt/AWTEvent.m b/jdk/src/macosx/native/sun/awt/AWTEvent.m index fd3caa6051f..b2d54f7e705 100644 --- a/jdk/src/macosx/native/sun/awt/AWTEvent.m +++ b/jdk/src/macosx/native/sun/awt/AWTEvent.m @@ -382,7 +382,7 @@ static unichar NsGetDeadKeyChar(unsigned short keyCode) { TISInputSourceRef currentKeyboard = TISCopyCurrentKeyboardInputSource(); CFDataRef uchr = (CFDataRef)TISGetInputSourceProperty(currentKeyboard, kTISPropertyUnicodeKeyLayoutData); - if (uchr == nil) { return; } + if (uchr == nil) { return 0; } const UCKeyboardLayout *keyboardLayout = (const UCKeyboardLayout*)CFDataGetBytePtr(uchr); // Carbon modifiers should be used instead of NSEvent modifiers UInt32 modifierKeyState = (GetCurrentEventKeyModifiers() >> 8) & 0xFF; From da494c8bc9535ab6c9a3b58824a6a96e7c162f25 Mon Sep 17 00:00:00 2001 From: Tim Bell Date: Tue, 9 Jul 2013 08:35:20 -0700 Subject: [PATCH 127/127] 8009315: F# on PATH breaks Cygwin tools (mkdir, echo, mktemp ...) Reviewed-by: erikj --- common/autoconf/generated-configure.sh | 491 +++++++++++++------------ common/autoconf/toolchain_windows.m4 | 2 + 2 files changed, 260 insertions(+), 233 deletions(-) diff --git a/common/autoconf/generated-configure.sh b/common/autoconf/generated-configure.sh index b9c2b38a47e..1f084da68c9 100644 --- a/common/autoconf/generated-configure.sh +++ b/common/autoconf/generated-configure.sh @@ -1,6 +1,6 @@ #! /bin/sh # Guess values for system-dependent variables and create Makefiles. -# Generated by GNU Autoconf 2.67 for OpenJDK jdk8. +# Generated by GNU Autoconf 2.68 for OpenJDK jdk8. # # Report bugs to . # @@ -91,6 +91,7 @@ fi IFS=" "" $as_nl" # Find who we are. Look in the path if we contain no directory separator. +as_myself= case $0 in #(( *[\\/]* ) as_myself=$0 ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR @@ -216,11 +217,18 @@ IFS=$as_save_IFS # We cannot yet assume a decent shell, so we have to provide a # neutralization value for shells without unset; and this also # works around shells that cannot unset nonexistent variables. + # Preserve -v and -x to the replacement shell. BASH_ENV=/dev/null ENV=/dev/null (unset BASH_ENV) >/dev/null 2>&1 && unset BASH_ENV ENV export CONFIG_SHELL - exec "$CONFIG_SHELL" "$as_myself" ${1+"$@"} + case $- in # (((( + *v*x* | *x*v* ) as_opts=-vx ;; + *v* ) as_opts=-v ;; + *x* ) as_opts=-x ;; + * ) as_opts= ;; + esac + exec "$CONFIG_SHELL" $as_opts "$as_myself" ${1+"$@"} fi if test x$as_have_required = xno; then : @@ -1461,7 +1469,7 @@ Try \`$0 --help' for more information" $as_echo "$as_me: WARNING: you should use --build, --host, --target" >&2 expr "x$ac_option" : ".*[^-._$as_cr_alnum]" >/dev/null && $as_echo "$as_me: WARNING: invalid host type: $ac_option" >&2 - : ${build_alias=$ac_option} ${host_alias=$ac_option} ${target_alias=$ac_option} + : "${build_alias=$ac_option} ${host_alias=$ac_option} ${target_alias=$ac_option}" ;; esac @@ -1897,7 +1905,7 @@ test -n "$ac_init_help" && exit $ac_status if $ac_init_version; then cat <<\_ACEOF OpenJDK configure jdk8 -generated by GNU Autoconf 2.67 +generated by GNU Autoconf 2.68 Copyright (C) 2010 Free Software Foundation, Inc. This configure script is free software; the Free Software Foundation @@ -1943,7 +1951,7 @@ sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_c_try_compile @@ -1981,7 +1989,7 @@ sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_cxx_try_compile @@ -2019,7 +2027,7 @@ sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_objc_try_compile @@ -2056,7 +2064,7 @@ sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_c_try_cpp @@ -2093,7 +2101,7 @@ sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_cxx_try_cpp @@ -2106,10 +2114,10 @@ fi ac_fn_cxx_check_header_mongrel () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack - if eval "test \"\${$3+set}\"" = set; then : + if eval \${$3+:} false; then : { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } -if eval "test \"\${$3+set}\"" = set; then : +if eval \${$3+:} false; then : $as_echo_n "(cached) " >&6 fi eval ac_res=\$$3 @@ -2176,7 +2184,7 @@ $as_echo "$as_me: WARNING: $2: proceeding with the compiler's result" >&2;} esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } -if eval "test \"\${$3+set}\"" = set; then : +if eval \${$3+:} false; then : $as_echo_n "(cached) " >&6 else eval "$3=\$ac_header_compiler" @@ -2185,7 +2193,7 @@ eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } fi - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno } # ac_fn_cxx_check_header_mongrel @@ -2226,7 +2234,7 @@ sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=$ac_status fi rm -rf conftest.dSYM conftest_ipa8_conftest.oo - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_cxx_try_run @@ -2240,7 +2248,7 @@ ac_fn_cxx_check_header_compile () as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } -if eval "test \"\${$3+set}\"" = set; then : +if eval \${$3+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext @@ -2258,7 +2266,7 @@ fi eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno } # ac_fn_cxx_check_header_compile @@ -2435,7 +2443,7 @@ rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext \ rm -f conftest.val fi - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_cxx_compute_int @@ -2481,7 +2489,7 @@ fi # interfere with the next link command; also delete a directory that is # left behind by Apple's compiler. We do this before executing the actions. rm -rf conftest.dSYM conftest_ipa8_conftest.oo - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_cxx_try_link @@ -2494,7 +2502,7 @@ ac_fn_cxx_check_func () as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } -if eval "test \"\${$3+set}\"" = set; then : +if eval \${$3+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext @@ -2549,7 +2557,7 @@ fi eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno } # ac_fn_cxx_check_func @@ -2562,7 +2570,7 @@ ac_fn_c_check_header_compile () as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 $as_echo_n "checking for $2... " >&6; } -if eval "test \"\${$3+set}\"" = set; then : +if eval \${$3+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext @@ -2580,7 +2588,7 @@ fi eval ac_res=\$$3 { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 $as_echo "$ac_res" >&6; } - eval $as_lineno_stack; test "x$as_lineno_stack" = x && { as_lineno=; unset as_lineno;} + eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno } # ac_fn_c_check_header_compile cat >config.log <<_ACEOF @@ -2588,7 +2596,7 @@ This file contains any messages produced by compilers while running configure, to aid debugging if configure makes a mistake. It was created by OpenJDK $as_me jdk8, which was -generated by GNU Autoconf 2.67. Invocation command line was +generated by GNU Autoconf 2.68. Invocation command line was $ $0 $@ @@ -2846,7 +2854,7 @@ $as_echo "$as_me: loading site script $ac_site_file" >&6;} || { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "failed to load site script $ac_site_file -See \`config.log' for more details" "$LINENO" 5 ; } +See \`config.log' for more details" "$LINENO" 5; } fi done @@ -3786,7 +3794,7 @@ fi #CUSTOM_AUTOCONF_INCLUDE # Do not change or remove the following line, it is needed for consistency checks: -DATE_WHEN_GENERATED=1372770384 +DATE_WHEN_GENERATED=1373384053 ############################################################################### # @@ -3824,7 +3832,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_BASENAME+set}" = set; then : +if ${ac_cv_path_BASENAME+:} false; then : $as_echo_n "(cached) " >&6 else case $BASENAME in @@ -3883,7 +3891,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_BASH+set}" = set; then : +if ${ac_cv_path_BASH+:} false; then : $as_echo_n "(cached) " >&6 else case $BASH in @@ -3942,7 +3950,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CAT+set}" = set; then : +if ${ac_cv_path_CAT+:} false; then : $as_echo_n "(cached) " >&6 else case $CAT in @@ -4001,7 +4009,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CHMOD+set}" = set; then : +if ${ac_cv_path_CHMOD+:} false; then : $as_echo_n "(cached) " >&6 else case $CHMOD in @@ -4060,7 +4068,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CMP+set}" = set; then : +if ${ac_cv_path_CMP+:} false; then : $as_echo_n "(cached) " >&6 else case $CMP in @@ -4119,7 +4127,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_COMM+set}" = set; then : +if ${ac_cv_path_COMM+:} false; then : $as_echo_n "(cached) " >&6 else case $COMM in @@ -4178,7 +4186,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CP+set}" = set; then : +if ${ac_cv_path_CP+:} false; then : $as_echo_n "(cached) " >&6 else case $CP in @@ -4237,7 +4245,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CPIO+set}" = set; then : +if ${ac_cv_path_CPIO+:} false; then : $as_echo_n "(cached) " >&6 else case $CPIO in @@ -4296,7 +4304,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CUT+set}" = set; then : +if ${ac_cv_path_CUT+:} false; then : $as_echo_n "(cached) " >&6 else case $CUT in @@ -4355,7 +4363,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_DATE+set}" = set; then : +if ${ac_cv_path_DATE+:} false; then : $as_echo_n "(cached) " >&6 else case $DATE in @@ -4414,7 +4422,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_DIFF+set}" = set; then : +if ${ac_cv_path_DIFF+:} false; then : $as_echo_n "(cached) " >&6 else case $DIFF in @@ -4473,7 +4481,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_DIRNAME+set}" = set; then : +if ${ac_cv_path_DIRNAME+:} false; then : $as_echo_n "(cached) " >&6 else case $DIRNAME in @@ -4532,7 +4540,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_ECHO+set}" = set; then : +if ${ac_cv_path_ECHO+:} false; then : $as_echo_n "(cached) " >&6 else case $ECHO in @@ -4591,7 +4599,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_EXPR+set}" = set; then : +if ${ac_cv_path_EXPR+:} false; then : $as_echo_n "(cached) " >&6 else case $EXPR in @@ -4650,7 +4658,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_FILE+set}" = set; then : +if ${ac_cv_path_FILE+:} false; then : $as_echo_n "(cached) " >&6 else case $FILE in @@ -4709,7 +4717,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_FIND+set}" = set; then : +if ${ac_cv_path_FIND+:} false; then : $as_echo_n "(cached) " >&6 else case $FIND in @@ -4768,7 +4776,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_HEAD+set}" = set; then : +if ${ac_cv_path_HEAD+:} false; then : $as_echo_n "(cached) " >&6 else case $HEAD in @@ -4827,7 +4835,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_LN+set}" = set; then : +if ${ac_cv_path_LN+:} false; then : $as_echo_n "(cached) " >&6 else case $LN in @@ -4886,7 +4894,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_LS+set}" = set; then : +if ${ac_cv_path_LS+:} false; then : $as_echo_n "(cached) " >&6 else case $LS in @@ -4945,7 +4953,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_MKDIR+set}" = set; then : +if ${ac_cv_path_MKDIR+:} false; then : $as_echo_n "(cached) " >&6 else case $MKDIR in @@ -5004,7 +5012,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_MKTEMP+set}" = set; then : +if ${ac_cv_path_MKTEMP+:} false; then : $as_echo_n "(cached) " >&6 else case $MKTEMP in @@ -5063,7 +5071,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_MV+set}" = set; then : +if ${ac_cv_path_MV+:} false; then : $as_echo_n "(cached) " >&6 else case $MV in @@ -5122,7 +5130,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_PRINTF+set}" = set; then : +if ${ac_cv_path_PRINTF+:} false; then : $as_echo_n "(cached) " >&6 else case $PRINTF in @@ -5181,7 +5189,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_RM+set}" = set; then : +if ${ac_cv_path_RM+:} false; then : $as_echo_n "(cached) " >&6 else case $RM in @@ -5240,7 +5248,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_SH+set}" = set; then : +if ${ac_cv_path_SH+:} false; then : $as_echo_n "(cached) " >&6 else case $SH in @@ -5299,7 +5307,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_SORT+set}" = set; then : +if ${ac_cv_path_SORT+:} false; then : $as_echo_n "(cached) " >&6 else case $SORT in @@ -5358,7 +5366,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_TAIL+set}" = set; then : +if ${ac_cv_path_TAIL+:} false; then : $as_echo_n "(cached) " >&6 else case $TAIL in @@ -5417,7 +5425,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_TAR+set}" = set; then : +if ${ac_cv_path_TAR+:} false; then : $as_echo_n "(cached) " >&6 else case $TAR in @@ -5476,7 +5484,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_TEE+set}" = set; then : +if ${ac_cv_path_TEE+:} false; then : $as_echo_n "(cached) " >&6 else case $TEE in @@ -5535,7 +5543,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_TOUCH+set}" = set; then : +if ${ac_cv_path_TOUCH+:} false; then : $as_echo_n "(cached) " >&6 else case $TOUCH in @@ -5594,7 +5602,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_TR+set}" = set; then : +if ${ac_cv_path_TR+:} false; then : $as_echo_n "(cached) " >&6 else case $TR in @@ -5653,7 +5661,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_UNAME+set}" = set; then : +if ${ac_cv_path_UNAME+:} false; then : $as_echo_n "(cached) " >&6 else case $UNAME in @@ -5712,7 +5720,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_UNIQ+set}" = set; then : +if ${ac_cv_path_UNIQ+:} false; then : $as_echo_n "(cached) " >&6 else case $UNIQ in @@ -5771,7 +5779,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_WC+set}" = set; then : +if ${ac_cv_path_WC+:} false; then : $as_echo_n "(cached) " >&6 else case $WC in @@ -5830,7 +5838,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_WHICH+set}" = set; then : +if ${ac_cv_path_WHICH+:} false; then : $as_echo_n "(cached) " >&6 else case $WHICH in @@ -5889,7 +5897,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_XARGS+set}" = set; then : +if ${ac_cv_path_XARGS+:} false; then : $as_echo_n "(cached) " >&6 else case $XARGS in @@ -5949,7 +5957,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_AWK+set}" = set; then : +if ${ac_cv_prog_AWK+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$AWK"; then @@ -5999,7 +6007,7 @@ $as_echo "$as_me: Could not find $PROG_NAME!" >&6;} { $as_echo "$as_me:${as_lineno-$LINENO}: checking for grep that handles long lines and -e" >&5 $as_echo_n "checking for grep that handles long lines and -e... " >&6; } -if test "${ac_cv_path_GREP+set}" = set; then : +if ${ac_cv_path_GREP+:} false; then : $as_echo_n "(cached) " >&6 else if test -z "$GREP"; then @@ -6074,7 +6082,7 @@ $as_echo "$as_me: Could not find $PROG_NAME!" >&6;} { $as_echo "$as_me:${as_lineno-$LINENO}: checking for egrep" >&5 $as_echo_n "checking for egrep... " >&6; } -if test "${ac_cv_path_EGREP+set}" = set; then : +if ${ac_cv_path_EGREP+:} false; then : $as_echo_n "(cached) " >&6 else if echo a | $GREP -E '(a|b)' >/dev/null 2>&1 @@ -6153,7 +6161,7 @@ $as_echo "$as_me: Could not find $PROG_NAME!" >&6;} { $as_echo "$as_me:${as_lineno-$LINENO}: checking for fgrep" >&5 $as_echo_n "checking for fgrep... " >&6; } -if test "${ac_cv_path_FGREP+set}" = set; then : +if ${ac_cv_path_FGREP+:} false; then : $as_echo_n "(cached) " >&6 else if echo 'ab*c' | $GREP -F 'ab*c' >/dev/null 2>&1 @@ -6232,7 +6240,7 @@ $as_echo "$as_me: Could not find $PROG_NAME!" >&6;} { $as_echo "$as_me:${as_lineno-$LINENO}: checking for a sed that does not truncate output" >&5 $as_echo_n "checking for a sed that does not truncate output... " >&6; } -if test "${ac_cv_path_SED+set}" = set; then : +if ${ac_cv_path_SED+:} false; then : $as_echo_n "(cached) " >&6 else ac_script=s/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/ @@ -6318,7 +6326,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_NAWK+set}" = set; then : +if ${ac_cv_path_NAWK+:} false; then : $as_echo_n "(cached) " >&6 else case $NAWK in @@ -6382,7 +6390,7 @@ THEPWDCMD=pwd set dummy cygpath; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CYGPATH+set}" = set; then : +if ${ac_cv_path_CYGPATH+:} false; then : $as_echo_n "(cached) " >&6 else case $CYGPATH in @@ -6422,7 +6430,7 @@ fi set dummy readlink; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_READLINK+set}" = set; then : +if ${ac_cv_path_READLINK+:} false; then : $as_echo_n "(cached) " >&6 else case $READLINK in @@ -6462,7 +6470,7 @@ fi set dummy df; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_DF+set}" = set; then : +if ${ac_cv_path_DF+:} false; then : $as_echo_n "(cached) " >&6 else case $DF in @@ -6502,7 +6510,7 @@ fi set dummy SetFile; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_SETFILE+set}" = set; then : +if ${ac_cv_path_SETFILE+:} false; then : $as_echo_n "(cached) " >&6 else case $SETFILE in @@ -6548,7 +6556,7 @@ $SHELL "$ac_aux_dir/config.sub" sun4 >/dev/null 2>&1 || { $as_echo "$as_me:${as_lineno-$LINENO}: checking build system type" >&5 $as_echo_n "checking build system type... " >&6; } -if test "${ac_cv_build+set}" = set; then : +if ${ac_cv_build+:} false; then : $as_echo_n "(cached) " >&6 else ac_build_alias=$build_alias @@ -6564,7 +6572,7 @@ fi $as_echo "$ac_cv_build" >&6; } case $ac_cv_build in *-*-*) ;; -*) as_fn_error $? "invalid value of canonical build" "$LINENO" 5 ;; +*) as_fn_error $? "invalid value of canonical build" "$LINENO" 5;; esac build=$ac_cv_build ac_save_IFS=$IFS; IFS='-' @@ -6582,7 +6590,7 @@ case $build_os in *\ *) build_os=`echo "$build_os" | sed 's/ /-/g'`;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking host system type" >&5 $as_echo_n "checking host system type... " >&6; } -if test "${ac_cv_host+set}" = set; then : +if ${ac_cv_host+:} false; then : $as_echo_n "(cached) " >&6 else if test "x$host_alias" = x; then @@ -6597,7 +6605,7 @@ fi $as_echo "$ac_cv_host" >&6; } case $ac_cv_host in *-*-*) ;; -*) as_fn_error $? "invalid value of canonical host" "$LINENO" 5 ;; +*) as_fn_error $? "invalid value of canonical host" "$LINENO" 5;; esac host=$ac_cv_host ac_save_IFS=$IFS; IFS='-' @@ -6615,7 +6623,7 @@ case $host_os in *\ *) host_os=`echo "$host_os" | sed 's/ /-/g'`;; esac { $as_echo "$as_me:${as_lineno-$LINENO}: checking target system type" >&5 $as_echo_n "checking target system type... " >&6; } -if test "${ac_cv_target+set}" = set; then : +if ${ac_cv_target+:} false; then : $as_echo_n "(cached) " >&6 else if test "x$target_alias" = x; then @@ -6630,7 +6638,7 @@ fi $as_echo "$ac_cv_target" >&6; } case $ac_cv_target in *-*-*) ;; -*) as_fn_error $? "invalid value of canonical target" "$LINENO" 5 ;; +*) as_fn_error $? "invalid value of canonical target" "$LINENO" 5;; esac target=$ac_cv_target ac_save_IFS=$IFS; IFS='-' @@ -8156,7 +8164,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_PKGHANDLER+set}" = set; then : +if ${ac_cv_prog_PKGHANDLER+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$PKGHANDLER"; then @@ -8521,7 +8529,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CHECK_GMAKE+set}" = set; then : +if ${ac_cv_path_CHECK_GMAKE+:} false; then : $as_echo_n "(cached) " >&6 else case $CHECK_GMAKE in @@ -8875,7 +8883,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CHECK_MAKE+set}" = set; then : +if ${ac_cv_path_CHECK_MAKE+:} false; then : $as_echo_n "(cached) " >&6 else case $CHECK_MAKE in @@ -9234,7 +9242,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CHECK_TOOLSDIR_GMAKE+set}" = set; then : +if ${ac_cv_path_CHECK_TOOLSDIR_GMAKE+:} false; then : $as_echo_n "(cached) " >&6 else case $CHECK_TOOLSDIR_GMAKE in @@ -9587,7 +9595,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CHECK_TOOLSDIR_MAKE+set}" = set; then : +if ${ac_cv_path_CHECK_TOOLSDIR_MAKE+:} false; then : $as_echo_n "(cached) " >&6 else case $CHECK_TOOLSDIR_MAKE in @@ -9983,7 +9991,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_UNZIP+set}" = set; then : +if ${ac_cv_path_UNZIP+:} false; then : $as_echo_n "(cached) " >&6 else case $UNZIP in @@ -10042,7 +10050,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_ZIP+set}" = set; then : +if ${ac_cv_path_ZIP+:} false; then : $as_echo_n "(cached) " >&6 else case $ZIP in @@ -10101,7 +10109,7 @@ $as_echo "$as_me: Could not find $PROG_NAME!" >&6;} set dummy ldd; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_LDD+set}" = set; then : +if ${ac_cv_path_LDD+:} false; then : $as_echo_n "(cached) " >&6 else case $LDD in @@ -10147,7 +10155,7 @@ fi set dummy otool; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_OTOOL+set}" = set; then : +if ${ac_cv_path_OTOOL+:} false; then : $as_echo_n "(cached) " >&6 else case $OTOOL in @@ -10192,7 +10200,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_READELF+set}" = set; then : +if ${ac_cv_path_READELF+:} false; then : $as_echo_n "(cached) " >&6 else case $READELF in @@ -10235,7 +10243,7 @@ done set dummy hg; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_HG+set}" = set; then : +if ${ac_cv_path_HG+:} false; then : $as_echo_n "(cached) " >&6 else case $HG in @@ -10275,7 +10283,7 @@ fi set dummy stat; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_STAT+set}" = set; then : +if ${ac_cv_path_STAT+:} false; then : $as_echo_n "(cached) " >&6 else case $STAT in @@ -10315,7 +10323,7 @@ fi set dummy time; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_TIME+set}" = set; then : +if ${ac_cv_path_TIME+:} false; then : $as_echo_n "(cached) " >&6 else case $TIME in @@ -10368,7 +10376,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_COMM+set}" = set; then : +if ${ac_cv_path_COMM+:} false; then : $as_echo_n "(cached) " >&6 else case $COMM in @@ -10430,7 +10438,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_XATTR+set}" = set; then : +if ${ac_cv_path_XATTR+:} false; then : $as_echo_n "(cached) " >&6 else case $XATTR in @@ -10486,7 +10494,7 @@ $as_echo "$as_me: Could not find $PROG_NAME!" >&6;} set dummy codesign; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CODESIGN+set}" = set; then : +if ${ac_cv_path_CODESIGN+:} false; then : $as_echo_n "(cached) " >&6 else case $CODESIGN in @@ -10550,7 +10558,7 @@ if test "x$ac_cv_env_PKG_CONFIG_set" != "xset"; then set dummy ${ac_tool_prefix}pkg-config; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_PKG_CONFIG+set}" = set; then : +if ${ac_cv_path_PKG_CONFIG+:} false; then : $as_echo_n "(cached) " >&6 else case $PKG_CONFIG in @@ -10593,7 +10601,7 @@ if test -z "$ac_cv_path_PKG_CONFIG"; then set dummy pkg-config; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_ac_pt_PKG_CONFIG+set}" = set; then : +if ${ac_cv_path_ac_pt_PKG_CONFIG+:} false; then : $as_echo_n "(cached) " >&6 else case $ac_pt_PKG_CONFIG in @@ -10766,7 +10774,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_BDEPS_UNZIP+set}" = set; then : +if ${ac_cv_prog_BDEPS_UNZIP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$BDEPS_UNZIP"; then @@ -10812,7 +10820,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_BDEPS_FTP+set}" = set; then : +if ${ac_cv_prog_BDEPS_FTP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$BDEPS_FTP"; then @@ -12108,7 +12116,7 @@ $as_echo "$BOOT_JDK_VERSION" >&6; } set dummy javac; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_JAVAC_CHECK+set}" = set; then : +if ${ac_cv_path_JAVAC_CHECK+:} false; then : $as_echo_n "(cached) " >&6 else case $JAVAC_CHECK in @@ -12148,7 +12156,7 @@ fi set dummy java; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_JAVA_CHECK+set}" = set; then : +if ${ac_cv_path_JAVA_CHECK+:} false; then : $as_echo_n "(cached) " >&6 else case $JAVA_CHECK in @@ -16477,7 +16485,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_JTREGEXE+set}" = set; then : +if ${ac_cv_path_JTREGEXE+:} false; then : $as_echo_n "(cached) " >&6 else case $JTREGEXE in @@ -16545,7 +16553,7 @@ if test "x$OPENJDK_TARGET_OS" = "xwindows"; then set dummy link; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CYGWIN_LINK+set}" = set; then : +if ${ac_cv_path_CYGWIN_LINK+:} false; then : $as_echo_n "(cached) " >&6 else case $CYGWIN_LINK in @@ -17319,6 +17327,8 @@ $as_echo "ok" >&6; } # Remove any trailing \ from INCLUDE and LIB to avoid trouble in spec.gmk. VS_INCLUDE=`$ECHO "$INCLUDE" | $SED 's/\\\\$//'` VS_LIB=`$ECHO "$LIB" | $SED 's/\\\\$//'` + # Remove any paths containing # (typically F#) as that messes up make + PATH=`$ECHO "$PATH" | $SED 's/[^:#]*#[^:]*://g'` VS_PATH="$PATH" @@ -17986,7 +17996,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_BUILD_CC+set}" = set; then : +if ${ac_cv_path_BUILD_CC+:} false; then : $as_echo_n "(cached) " >&6 else case $BUILD_CC in @@ -18297,7 +18307,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_BUILD_CXX+set}" = set; then : +if ${ac_cv_path_BUILD_CXX+:} false; then : $as_echo_n "(cached) " >&6 else case $BUILD_CXX in @@ -18606,7 +18616,7 @@ $as_echo "$as_me: Rewriting BUILD_CXX to \"$new_complete\"" >&6;} set dummy ld; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_BUILD_LD+set}" = set; then : +if ${ac_cv_path_BUILD_LD+:} false; then : $as_echo_n "(cached) " >&6 else case $BUILD_LD in @@ -19113,7 +19123,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_TOOLS_DIR_CC+set}" = set; then : +if ${ac_cv_path_TOOLS_DIR_CC+:} false; then : $as_echo_n "(cached) " >&6 else case $TOOLS_DIR_CC in @@ -19165,7 +19175,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_POTENTIAL_CC+set}" = set; then : +if ${ac_cv_path_POTENTIAL_CC+:} false; then : $as_echo_n "(cached) " >&6 else case $POTENTIAL_CC in @@ -19578,7 +19588,7 @@ $as_echo "yes, trying to find proper $COMPILER_NAME compiler" >&6; } set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_PROPER_COMPILER_CC+set}" = set; then : +if ${ac_cv_prog_PROPER_COMPILER_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$PROPER_COMPILER_CC"; then @@ -19622,7 +19632,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_ac_ct_PROPER_COMPILER_CC+set}" = set; then : +if ${ac_cv_prog_ac_ct_PROPER_COMPILER_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_PROPER_COMPILER_CC"; then @@ -20072,7 +20082,7 @@ if test -n "$ac_tool_prefix"; then set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_CC+set}" = set; then : +if ${ac_cv_prog_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$CC"; then @@ -20116,7 +20126,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_ac_ct_CC+set}" = set; then : +if ${ac_cv_prog_ac_ct_CC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_CC"; then @@ -20169,7 +20179,7 @@ fi test -z "$CC" && { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "no acceptable C compiler found in \$PATH -See \`config.log' for more details" "$LINENO" 5 ; } +See \`config.log' for more details" "$LINENO" 5; } # Provide some information about the compiler. $as_echo "$as_me:${as_lineno-$LINENO}: checking for C compiler version" >&5 @@ -20284,7 +20294,7 @@ sed 's/^/| /' conftest.$ac_ext >&5 { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 77 "C compiler cannot create executables -See \`config.log' for more details" "$LINENO" 5 ; } +See \`config.log' for more details" "$LINENO" 5; } else { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5 $as_echo "yes" >&6; } @@ -20327,7 +20337,7 @@ else { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "cannot compute suffix of executables: cannot compile and link -See \`config.log' for more details" "$LINENO" 5 ; } +See \`config.log' for more details" "$LINENO" 5; } fi rm -f conftest conftest$ac_cv_exeext { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_exeext" >&5 @@ -20386,7 +20396,7 @@ $as_echo "$ac_try_echo"; } >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "cannot run C compiled programs. If you meant to cross compile, use \`--host'. -See \`config.log' for more details" "$LINENO" 5 ; } +See \`config.log' for more details" "$LINENO" 5; } fi fi fi @@ -20397,7 +20407,7 @@ rm -f conftest.$ac_ext conftest$ac_cv_exeext conftest.out ac_clean_files=$ac_clean_files_save { $as_echo "$as_me:${as_lineno-$LINENO}: checking for suffix of object files" >&5 $as_echo_n "checking for suffix of object files... " >&6; } -if test "${ac_cv_objext+set}" = set; then : +if ${ac_cv_objext+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext @@ -20438,7 +20448,7 @@ sed 's/^/| /' conftest.$ac_ext >&5 { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "cannot compute suffix of object files: cannot compile -See \`config.log' for more details" "$LINENO" 5 ; } +See \`config.log' for more details" "$LINENO" 5; } fi rm -f conftest.$ac_cv_objext conftest.$ac_ext fi @@ -20448,7 +20458,7 @@ OBJEXT=$ac_cv_objext ac_objext=$OBJEXT { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are using the GNU C compiler" >&5 $as_echo_n "checking whether we are using the GNU C compiler... " >&6; } -if test "${ac_cv_c_compiler_gnu+set}" = set; then : +if ${ac_cv_c_compiler_gnu+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext @@ -20485,7 +20495,7 @@ ac_test_CFLAGS=${CFLAGS+set} ac_save_CFLAGS=$CFLAGS { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CC accepts -g" >&5 $as_echo_n "checking whether $CC accepts -g... " >&6; } -if test "${ac_cv_prog_cc_g+set}" = set; then : +if ${ac_cv_prog_cc_g+:} false; then : $as_echo_n "(cached) " >&6 else ac_save_c_werror_flag=$ac_c_werror_flag @@ -20563,7 +20573,7 @@ else fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $CC option to accept ISO C89" >&5 $as_echo_n "checking for $CC option to accept ISO C89... " >&6; } -if test "${ac_cv_prog_cc_c89+set}" = set; then : +if ${ac_cv_prog_cc_c89+:} false; then : $as_echo_n "(cached) " >&6 else ac_cv_prog_cc_c89=no @@ -20686,7 +20696,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_TOOLS_DIR_CXX+set}" = set; then : +if ${ac_cv_path_TOOLS_DIR_CXX+:} false; then : $as_echo_n "(cached) " >&6 else case $TOOLS_DIR_CXX in @@ -20738,7 +20748,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_POTENTIAL_CXX+set}" = set; then : +if ${ac_cv_path_POTENTIAL_CXX+:} false; then : $as_echo_n "(cached) " >&6 else case $POTENTIAL_CXX in @@ -21151,7 +21161,7 @@ $as_echo "yes, trying to find proper $COMPILER_NAME compiler" >&6; } set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_PROPER_COMPILER_CXX+set}" = set; then : +if ${ac_cv_prog_PROPER_COMPILER_CXX+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$PROPER_COMPILER_CXX"; then @@ -21195,7 +21205,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_ac_ct_PROPER_COMPILER_CXX+set}" = set; then : +if ${ac_cv_prog_ac_ct_PROPER_COMPILER_CXX+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_PROPER_COMPILER_CXX"; then @@ -21649,7 +21659,7 @@ if test -z "$CXX"; then set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_CXX+set}" = set; then : +if ${ac_cv_prog_CXX+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$CXX"; then @@ -21693,7 +21703,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_ac_ct_CXX+set}" = set; then : +if ${ac_cv_prog_ac_ct_CXX+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_CXX"; then @@ -21771,7 +21781,7 @@ done { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are using the GNU C++ compiler" >&5 $as_echo_n "checking whether we are using the GNU C++ compiler... " >&6; } -if test "${ac_cv_cxx_compiler_gnu+set}" = set; then : +if ${ac_cv_cxx_compiler_gnu+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext @@ -21808,7 +21818,7 @@ ac_test_CXXFLAGS=${CXXFLAGS+set} ac_save_CXXFLAGS=$CXXFLAGS { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $CXX accepts -g" >&5 $as_echo_n "checking whether $CXX accepts -g... " >&6; } -if test "${ac_cv_prog_cxx_g+set}" = set; then : +if ${ac_cv_prog_cxx_g+:} false; then : $as_echo_n "(cached) " >&6 else ac_save_cxx_werror_flag=$ac_cxx_werror_flag @@ -21906,7 +21916,7 @@ if test -n "$ac_tool_prefix"; then set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_OBJC+set}" = set; then : +if ${ac_cv_prog_OBJC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$OBJC"; then @@ -21950,7 +21960,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_ac_ct_OBJC+set}" = set; then : +if ${ac_cv_prog_ac_ct_OBJC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_OBJC"; then @@ -22026,7 +22036,7 @@ done { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether we are using the GNU Objective C compiler" >&5 $as_echo_n "checking whether we are using the GNU Objective C compiler... " >&6; } -if test "${ac_cv_objc_compiler_gnu+set}" = set; then : +if ${ac_cv_objc_compiler_gnu+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext @@ -22063,7 +22073,7 @@ ac_test_OBJCFLAGS=${OBJCFLAGS+set} ac_save_OBJCFLAGS=$OBJCFLAGS { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether $OBJC accepts -g" >&5 $as_echo_n "checking whether $OBJC accepts -g... " >&6; } -if test "${ac_cv_prog_objc_g+set}" = set; then : +if ${ac_cv_prog_objc_g+:} false; then : $as_echo_n "(cached) " >&6 else ac_save_objc_werror_flag=$ac_objc_werror_flag @@ -22439,7 +22449,7 @@ if test "x$OPENJDK_TARGET_OS" != xwindows; then set dummy ${ac_tool_prefix}ar; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_AR+set}" = set; then : +if ${ac_cv_prog_AR+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$AR"; then @@ -22479,7 +22489,7 @@ if test -z "$ac_cv_prog_AR"; then set dummy ar; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_ac_ct_AR+set}" = set; then : +if ${ac_cv_prog_ac_ct_AR+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_AR"; then @@ -22821,7 +22831,7 @@ if test "x$OPENJDK_TARGET_OS" = xwindows; then : set dummy link; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_WINLD+set}" = set; then : +if ${ac_cv_prog_WINLD+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$WINLD"; then @@ -23160,7 +23170,7 @@ $as_echo "yes" >&6; } set dummy mt; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_MT+set}" = set; then : +if ${ac_cv_prog_MT+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$MT"; then @@ -23481,7 +23491,7 @@ $as_echo "$as_me: Rewriting MT to \"$new_complete\"" >&6;} set dummy rc; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_RC+set}" = set; then : +if ${ac_cv_prog_RC+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$RC"; then @@ -23873,7 +23883,7 @@ fi set dummy lib; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_WINAR+set}" = set; then : +if ${ac_cv_prog_WINAR+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$WINAR"; then @@ -24179,7 +24189,7 @@ $as_echo "$as_me: Rewriting WINAR to \"$new_complete\"" >&6;} set dummy dumpbin; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_DUMPBIN+set}" = set; then : +if ${ac_cv_prog_DUMPBIN+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$DUMPBIN"; then @@ -24498,7 +24508,7 @@ if test -n "$CPP" && test -d "$CPP"; then CPP= fi if test -z "$CPP"; then - if test "${ac_cv_prog_CPP+set}" = set; then : + if ${ac_cv_prog_CPP+:} false; then : $as_echo_n "(cached) " >&6 else # Double quotes because CPP needs to be expanded @@ -24614,7 +24624,7 @@ else { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "C preprocessor \"$CPP\" fails sanity check -See \`config.log' for more details" "$LINENO" 5 ; } +See \`config.log' for more details" "$LINENO" 5; } fi ac_ext=cpp @@ -24898,7 +24908,7 @@ ac_compiler_gnu=$ac_cv_cxx_compiler_gnu { $as_echo "$as_me:${as_lineno-$LINENO}: checking how to run the C++ preprocessor" >&5 $as_echo_n "checking how to run the C++ preprocessor... " >&6; } if test -z "$CXXCPP"; then - if test "${ac_cv_prog_CXXCPP+set}" = set; then : + if ${ac_cv_prog_CXXCPP+:} false; then : $as_echo_n "(cached) " >&6 else # Double quotes because CXXCPP needs to be expanded @@ -25014,7 +25024,7 @@ else { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "C++ preprocessor \"$CXXCPP\" fails sanity check -See \`config.log' for more details" "$LINENO" 5 ; } +See \`config.log' for more details" "$LINENO" 5; } fi ac_ext=cpp @@ -25316,7 +25326,7 @@ if test "x$OPENJDK_TARGET_OS" = xsolaris; then set dummy as; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_AS+set}" = set; then : +if ${ac_cv_path_AS+:} false; then : $as_echo_n "(cached) " >&6 else case $AS in @@ -25628,7 +25638,7 @@ if test "x$OPENJDK_TARGET_OS" = xsolaris; then set dummy nm; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_NM+set}" = set; then : +if ${ac_cv_path_NM+:} false; then : $as_echo_n "(cached) " >&6 else case $NM in @@ -25934,7 +25944,7 @@ $as_echo "$as_me: Rewriting NM to \"$new_complete\"" >&6;} set dummy gnm; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_GNM+set}" = set; then : +if ${ac_cv_path_GNM+:} false; then : $as_echo_n "(cached) " >&6 else case $GNM in @@ -26240,7 +26250,7 @@ $as_echo "$as_me: Rewriting GNM to \"$new_complete\"" >&6;} set dummy strip; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_STRIP+set}" = set; then : +if ${ac_cv_path_STRIP+:} false; then : $as_echo_n "(cached) " >&6 else case $STRIP in @@ -26546,7 +26556,7 @@ $as_echo "$as_me: Rewriting STRIP to \"$new_complete\"" >&6;} set dummy mcs; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_MCS+set}" = set; then : +if ${ac_cv_path_MCS+:} false; then : $as_echo_n "(cached) " >&6 else case $MCS in @@ -26854,7 +26864,7 @@ elif test "x$OPENJDK_TARGET_OS" != xwindows; then set dummy ${ac_tool_prefix}nm; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_NM+set}" = set; then : +if ${ac_cv_prog_NM+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$NM"; then @@ -26894,7 +26904,7 @@ if test -z "$ac_cv_prog_NM"; then set dummy nm; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_ac_ct_NM+set}" = set; then : +if ${ac_cv_prog_ac_ct_NM+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_NM"; then @@ -27214,7 +27224,7 @@ $as_echo "$as_me: Rewriting NM to \"$new_complete\"" >&6;} set dummy ${ac_tool_prefix}strip; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_STRIP+set}" = set; then : +if ${ac_cv_prog_STRIP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$STRIP"; then @@ -27254,7 +27264,7 @@ if test -z "$ac_cv_prog_STRIP"; then set dummy strip; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_ac_ct_STRIP+set}" = set; then : +if ${ac_cv_prog_ac_ct_STRIP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_STRIP"; then @@ -27579,7 +27589,7 @@ if test "x$OPENJDK_TARGET_OS" = xsolaris || test "x$OPENJDK_TARGET_OS" = xlinux; set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_OBJCOPY+set}" = set; then : +if ${ac_cv_prog_OBJCOPY+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$OBJCOPY"; then @@ -27623,7 +27633,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_ac_ct_OBJCOPY+set}" = set; then : +if ${ac_cv_prog_ac_ct_OBJCOPY+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_OBJCOPY"; then @@ -27950,7 +27960,7 @@ if test -n "$ac_tool_prefix"; then set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_OBJDUMP+set}" = set; then : +if ${ac_cv_prog_OBJDUMP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$OBJDUMP"; then @@ -27994,7 +28004,7 @@ do set dummy $ac_prog; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_ac_ct_OBJDUMP+set}" = set; then : +if ${ac_cv_prog_ac_ct_OBJDUMP+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$ac_ct_OBJDUMP"; then @@ -28318,7 +28328,7 @@ if test "x$OPENJDK_TARGET_OS" = "xmacosx"; then set dummy lipo; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_LIPO+set}" = set; then : +if ${ac_cv_path_LIPO+:} false; then : $as_echo_n "(cached) " >&6 else case $LIPO in @@ -28635,7 +28645,7 @@ PATH="$OLD_PATH" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for ANSI C header files" >&5 $as_echo_n "checking for ANSI C header files... " >&6; } -if test "${ac_cv_header_stdc+set}" = set; then : +if ${ac_cv_header_stdc+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext @@ -28812,7 +28822,7 @@ fi for ac_header in stdio.h do : ac_fn_cxx_check_header_mongrel "$LINENO" "stdio.h" "ac_cv_header_stdio_h" "$ac_includes_default" -if test "x$ac_cv_header_stdio_h" = x""yes; then : +if test "x$ac_cv_header_stdio_h" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_STDIO_H 1 _ACEOF @@ -28841,7 +28851,7 @@ done # This bug is HP SR number 8606223364. { $as_echo "$as_me:${as_lineno-$LINENO}: checking size of int *" >&5 $as_echo_n "checking size of int *... " >&6; } -if test "${ac_cv_sizeof_int_p+set}" = set; then : +if ${ac_cv_sizeof_int_p+:} false; then : $as_echo_n "(cached) " >&6 else if ac_fn_cxx_compute_int "$LINENO" "(long int) (sizeof (int *))" "ac_cv_sizeof_int_p" "$ac_includes_default"; then : @@ -28851,7 +28861,7 @@ else { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 $as_echo "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 77 "cannot compute sizeof (int *) -See \`config.log' for more details" "$LINENO" 5 ; } +See \`config.log' for more details" "$LINENO" 5; } else ac_cv_sizeof_int_p=0 fi @@ -28898,7 +28908,7 @@ $as_echo "$OPENJDK_TARGET_CPU_BITS bits" >&6; } # { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether byte ordering is bigendian" >&5 $as_echo_n "checking whether byte ordering is bigendian... " >&6; } -if test "${ac_cv_c_bigendian+set}" = set; then : +if ${ac_cv_c_bigendian+:} false; then : $as_echo_n "(cached) " >&6 else ac_cv_c_bigendian=unknown @@ -30074,8 +30084,8 @@ if test "x$with_x" = xno; then have_x=disabled else case $x_includes,$x_libraries in #( - *\'*) as_fn_error $? "cannot use X directory names containing '" "$LINENO" 5 ;; #( - *,NONE | NONE,*) if test "${ac_cv_have_x+set}" = set; then : + *\'*) as_fn_error $? "cannot use X directory names containing '" "$LINENO" 5;; #( + *,NONE | NONE,*) if ${ac_cv_have_x+:} false; then : $as_echo_n "(cached) " >&6 else # One or both of the vars are not set, and there is no cached value. @@ -30352,7 +30362,7 @@ if ac_fn_cxx_try_link "$LINENO"; then : else { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dnet_ntoa in -ldnet" >&5 $as_echo_n "checking for dnet_ntoa in -ldnet... " >&6; } -if test "${ac_cv_lib_dnet_dnet_ntoa+set}" = set; then : +if ${ac_cv_lib_dnet_dnet_ntoa+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -30386,14 +30396,14 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dnet_dnet_ntoa" >&5 $as_echo "$ac_cv_lib_dnet_dnet_ntoa" >&6; } -if test "x$ac_cv_lib_dnet_dnet_ntoa" = x""yes; then : +if test "x$ac_cv_lib_dnet_dnet_ntoa" = xyes; then : X_EXTRA_LIBS="$X_EXTRA_LIBS -ldnet" fi if test $ac_cv_lib_dnet_dnet_ntoa = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dnet_ntoa in -ldnet_stub" >&5 $as_echo_n "checking for dnet_ntoa in -ldnet_stub... " >&6; } -if test "${ac_cv_lib_dnet_stub_dnet_ntoa+set}" = set; then : +if ${ac_cv_lib_dnet_stub_dnet_ntoa+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -30427,7 +30437,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dnet_stub_dnet_ntoa" >&5 $as_echo "$ac_cv_lib_dnet_stub_dnet_ntoa" >&6; } -if test "x$ac_cv_lib_dnet_stub_dnet_ntoa" = x""yes; then : +if test "x$ac_cv_lib_dnet_stub_dnet_ntoa" = xyes; then : X_EXTRA_LIBS="$X_EXTRA_LIBS -ldnet_stub" fi @@ -30446,14 +30456,14 @@ rm -f core conftest.err conftest.$ac_objext \ # The functions gethostbyname, getservbyname, and inet_addr are # in -lbsd on LynxOS 3.0.1/i386, according to Lars Hecking. ac_fn_cxx_check_func "$LINENO" "gethostbyname" "ac_cv_func_gethostbyname" -if test "x$ac_cv_func_gethostbyname" = x""yes; then : +if test "x$ac_cv_func_gethostbyname" = xyes; then : fi if test $ac_cv_func_gethostbyname = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for gethostbyname in -lnsl" >&5 $as_echo_n "checking for gethostbyname in -lnsl... " >&6; } -if test "${ac_cv_lib_nsl_gethostbyname+set}" = set; then : +if ${ac_cv_lib_nsl_gethostbyname+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -30487,14 +30497,14 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_nsl_gethostbyname" >&5 $as_echo "$ac_cv_lib_nsl_gethostbyname" >&6; } -if test "x$ac_cv_lib_nsl_gethostbyname" = x""yes; then : +if test "x$ac_cv_lib_nsl_gethostbyname" = xyes; then : X_EXTRA_LIBS="$X_EXTRA_LIBS -lnsl" fi if test $ac_cv_lib_nsl_gethostbyname = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for gethostbyname in -lbsd" >&5 $as_echo_n "checking for gethostbyname in -lbsd... " >&6; } -if test "${ac_cv_lib_bsd_gethostbyname+set}" = set; then : +if ${ac_cv_lib_bsd_gethostbyname+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -30528,7 +30538,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_bsd_gethostbyname" >&5 $as_echo "$ac_cv_lib_bsd_gethostbyname" >&6; } -if test "x$ac_cv_lib_bsd_gethostbyname" = x""yes; then : +if test "x$ac_cv_lib_bsd_gethostbyname" = xyes; then : X_EXTRA_LIBS="$X_EXTRA_LIBS -lbsd" fi @@ -30543,14 +30553,14 @@ fi # must be given before -lnsl if both are needed. We assume that # if connect needs -lnsl, so does gethostbyname. ac_fn_cxx_check_func "$LINENO" "connect" "ac_cv_func_connect" -if test "x$ac_cv_func_connect" = x""yes; then : +if test "x$ac_cv_func_connect" = xyes; then : fi if test $ac_cv_func_connect = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for connect in -lsocket" >&5 $as_echo_n "checking for connect in -lsocket... " >&6; } -if test "${ac_cv_lib_socket_connect+set}" = set; then : +if ${ac_cv_lib_socket_connect+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -30584,7 +30594,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_socket_connect" >&5 $as_echo "$ac_cv_lib_socket_connect" >&6; } -if test "x$ac_cv_lib_socket_connect" = x""yes; then : +if test "x$ac_cv_lib_socket_connect" = xyes; then : X_EXTRA_LIBS="-lsocket $X_EXTRA_LIBS" fi @@ -30592,14 +30602,14 @@ fi # Guillermo Gomez says -lposix is necessary on A/UX. ac_fn_cxx_check_func "$LINENO" "remove" "ac_cv_func_remove" -if test "x$ac_cv_func_remove" = x""yes; then : +if test "x$ac_cv_func_remove" = xyes; then : fi if test $ac_cv_func_remove = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for remove in -lposix" >&5 $as_echo_n "checking for remove in -lposix... " >&6; } -if test "${ac_cv_lib_posix_remove+set}" = set; then : +if ${ac_cv_lib_posix_remove+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -30633,7 +30643,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_posix_remove" >&5 $as_echo "$ac_cv_lib_posix_remove" >&6; } -if test "x$ac_cv_lib_posix_remove" = x""yes; then : +if test "x$ac_cv_lib_posix_remove" = xyes; then : X_EXTRA_LIBS="$X_EXTRA_LIBS -lposix" fi @@ -30641,14 +30651,14 @@ fi # BSDI BSD/OS 2.1 needs -lipc for XOpenDisplay. ac_fn_cxx_check_func "$LINENO" "shmat" "ac_cv_func_shmat" -if test "x$ac_cv_func_shmat" = x""yes; then : +if test "x$ac_cv_func_shmat" = xyes; then : fi if test $ac_cv_func_shmat = no; then { $as_echo "$as_me:${as_lineno-$LINENO}: checking for shmat in -lipc" >&5 $as_echo_n "checking for shmat in -lipc... " >&6; } -if test "${ac_cv_lib_ipc_shmat+set}" = set; then : +if ${ac_cv_lib_ipc_shmat+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -30682,7 +30692,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_ipc_shmat" >&5 $as_echo "$ac_cv_lib_ipc_shmat" >&6; } -if test "x$ac_cv_lib_ipc_shmat" = x""yes; then : +if test "x$ac_cv_lib_ipc_shmat" = xyes; then : X_EXTRA_LIBS="$X_EXTRA_LIBS -lipc" fi @@ -30700,7 +30710,7 @@ fi # John Interrante, Karl Berry { $as_echo "$as_me:${as_lineno-$LINENO}: checking for IceConnectionNumber in -lICE" >&5 $as_echo_n "checking for IceConnectionNumber in -lICE... " >&6; } -if test "${ac_cv_lib_ICE_IceConnectionNumber+set}" = set; then : +if ${ac_cv_lib_ICE_IceConnectionNumber+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -30734,7 +30744,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_ICE_IceConnectionNumber" >&5 $as_echo "$ac_cv_lib_ICE_IceConnectionNumber" >&6; } -if test "x$ac_cv_lib_ICE_IceConnectionNumber" = x""yes; then : +if test "x$ac_cv_lib_ICE_IceConnectionNumber" = xyes; then : X_PRE_LIBS="$X_PRE_LIBS -lSM -lICE" fi @@ -31752,7 +31762,7 @@ $as_echo "$FREETYPE2_FOUND" >&6; } LDFLAGS="$FREETYPE2_LIBS" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for FT_Init_FreeType in -lfreetype" >&5 $as_echo_n "checking for FT_Init_FreeType in -lfreetype... " >&6; } -if test "${ac_cv_lib_freetype_FT_Init_FreeType+set}" = set; then : +if ${ac_cv_lib_freetype_FT_Init_FreeType+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -31786,7 +31796,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_freetype_FT_Init_FreeType" >&5 $as_echo "$ac_cv_lib_freetype_FT_Init_FreeType" >&6; } -if test "x$ac_cv_lib_freetype_FT_Init_FreeType" = x""yes; then : +if test "x$ac_cv_lib_freetype_FT_Init_FreeType" = xyes; then : FREETYPE2_FOUND=true else as_fn_error $? "Could not find freetype2! $HELP_MSG " "$LINENO" 5 @@ -32074,7 +32084,7 @@ fi for ac_header in alsa/asoundlib.h do : ac_fn_cxx_check_header_mongrel "$LINENO" "alsa/asoundlib.h" "ac_cv_header_alsa_asoundlib_h" "$ac_includes_default" -if test "x$ac_cv_header_alsa_asoundlib_h" = x""yes; then : +if test "x$ac_cv_header_alsa_asoundlib_h" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_ALSA_ASOUNDLIB_H 1 _ACEOF @@ -32133,7 +32143,7 @@ fi USE_EXTERNAL_LIBJPEG=true { $as_echo "$as_me:${as_lineno-$LINENO}: checking for main in -ljpeg" >&5 $as_echo_n "checking for main in -ljpeg... " >&6; } -if test "${ac_cv_lib_jpeg_main+set}" = set; then : +if ${ac_cv_lib_jpeg_main+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -32161,7 +32171,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_jpeg_main" >&5 $as_echo "$ac_cv_lib_jpeg_main" >&6; } -if test "x$ac_cv_lib_jpeg_main" = x""yes; then : +if test "x$ac_cv_lib_jpeg_main" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_LIBJPEG 1 _ACEOF @@ -32210,7 +32220,7 @@ if test "x${with_giflib}" = "xbundled"; then USE_EXTERNAL_LIBGIF=false elif test "x${with_giflib}" = "xsystem"; then ac_fn_cxx_check_header_mongrel "$LINENO" "gif_lib.h" "ac_cv_header_gif_lib_h" "$ac_includes_default" -if test "x$ac_cv_header_gif_lib_h" = x""yes; then : +if test "x$ac_cv_header_gif_lib_h" = xyes; then : else as_fn_error $? "--with-giflib=system specified, but gif_lib.h not found!" "$LINENO" 5 @@ -32219,7 +32229,7 @@ fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for DGifGetCode in -lgif" >&5 $as_echo_n "checking for DGifGetCode in -lgif... " >&6; } -if test "${ac_cv_lib_gif_DGifGetCode+set}" = set; then : +if ${ac_cv_lib_gif_DGifGetCode+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -32253,7 +32263,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_gif_DGifGetCode" >&5 $as_echo "$ac_cv_lib_gif_DGifGetCode" >&6; } -if test "x$ac_cv_lib_gif_DGifGetCode" = x""yes; then : +if test "x$ac_cv_lib_gif_DGifGetCode" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_LIBGIF 1 _ACEOF @@ -32285,7 +32295,7 @@ fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for compress in -lz" >&5 $as_echo_n "checking for compress in -lz... " >&6; } -if test "${ac_cv_lib_z_compress+set}" = set; then : +if ${ac_cv_lib_z_compress+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -32319,7 +32329,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_z_compress" >&5 $as_echo "$ac_cv_lib_z_compress" >&6; } -if test "x$ac_cv_lib_z_compress" = x""yes; then : +if test "x$ac_cv_lib_z_compress" = xyes; then : ZLIB_FOUND=yes else ZLIB_FOUND=no @@ -32412,7 +32422,7 @@ fi { $as_echo "$as_me:${as_lineno-$LINENO}: checking for cos in -lm" >&5 $as_echo_n "checking for cos in -lm... " >&6; } -if test "${ac_cv_lib_m_cos+set}" = set; then : +if ${ac_cv_lib_m_cos+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -32446,7 +32456,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_m_cos" >&5 $as_echo "$ac_cv_lib_m_cos" >&6; } -if test "x$ac_cv_lib_m_cos" = x""yes; then : +if test "x$ac_cv_lib_m_cos" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_LIBM 1 _ACEOF @@ -32470,7 +32480,7 @@ save_LIBS="$LIBS" LIBS="" { $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlopen in -ldl" >&5 $as_echo_n "checking for dlopen in -ldl... " >&6; } -if test "${ac_cv_lib_dl_dlopen+set}" = set; then : +if ${ac_cv_lib_dl_dlopen+:} false; then : $as_echo_n "(cached) " >&6 else ac_check_lib_save_LIBS=$LIBS @@ -32504,7 +32514,7 @@ LIBS=$ac_check_lib_save_LIBS fi { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dl_dlopen" >&5 $as_echo "$ac_cv_lib_dl_dlopen" >&6; } -if test "x$ac_cv_lib_dl_dlopen" = x""yes; then : +if test "x$ac_cv_lib_dl_dlopen" = xyes; then : cat >>confdefs.h <<_ACEOF #define HAVE_LIBDL 1 _ACEOF @@ -32734,7 +32744,7 @@ and LIBFFI_LIBS to avoid the need to call pkg-config. See the pkg-config man page for more details. To get pkg-config, see . -See \`config.log' for more details" "$LINENO" 5 ; } +See \`config.log' for more details" "$LINENO" 5; } else LIBFFI_CFLAGS=$pkg_cv_LIBFFI_CFLAGS LIBFFI_LIBS=$pkg_cv_LIBFFI_LIBS @@ -32750,7 +32760,7 @@ if test "x$JVM_VARIANT_ZEROSHARK" = xtrue; then set dummy llvm-config; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_prog_LLVM_CONFIG+set}" = set; then : +if ${ac_cv_prog_LLVM_CONFIG+:} false; then : $as_echo_n "(cached) " >&6 else if test -n "$LLVM_CONFIG"; then @@ -33366,7 +33376,7 @@ fi set dummy ccache; ac_word=$2 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 $as_echo_n "checking for $ac_word... " >&6; } -if test "${ac_cv_path_CCACHE+set}" = set; then : +if ${ac_cv_path_CCACHE+:} false; then : $as_echo_n "(cached) " >&6 else case $CCACHE in @@ -33628,10 +33638,21 @@ $as_echo "$as_me: WARNING: cache variable $ac_var contains a newline" >&2;} ;; :end' >>confcache if diff "$cache_file" confcache >/dev/null 2>&1; then :; else if test -w "$cache_file"; then - test "x$cache_file" != "x/dev/null" && + if test "x$cache_file" != "x/dev/null"; then { $as_echo "$as_me:${as_lineno-$LINENO}: updating cache $cache_file" >&5 $as_echo "$as_me: updating cache $cache_file" >&6;} - cat confcache >$cache_file + if test ! -f "$cache_file" || test -h "$cache_file"; then + cat confcache >"$cache_file" + else + case $cache_file in #( + */* | ?:*) + mv -f confcache "$cache_file"$$ && + mv -f "$cache_file"$$ "$cache_file" ;; #( + *) + mv -f confcache "$cache_file" ;; + esac + fi + fi else { $as_echo "$as_me:${as_lineno-$LINENO}: not updating unwritable cache $cache_file" >&5 $as_echo "$as_me: not updating unwritable cache $cache_file" >&6;} @@ -33663,7 +33684,7 @@ LTLIBOBJS=$ac_ltlibobjs -: ${CONFIG_STATUS=./config.status} +: "${CONFIG_STATUS=./config.status}" ac_write_fail=0 ac_clean_files_save=$ac_clean_files ac_clean_files="$ac_clean_files $CONFIG_STATUS" @@ -33764,6 +33785,7 @@ fi IFS=" "" $as_nl" # Find who we are. Look in the path if we contain no directory separator. +as_myself= case $0 in #(( *[\\/]* ) as_myself=$0 ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR @@ -34071,7 +34093,7 @@ cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # values after options handling. ac_log=" This file was extended by OpenJDK $as_me jdk8, which was -generated by GNU Autoconf 2.67. Invocation command line was +generated by GNU Autoconf 2.68. Invocation command line was CONFIG_FILES = $CONFIG_FILES CONFIG_HEADERS = $CONFIG_HEADERS @@ -34134,7 +34156,7 @@ cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 ac_cs_config="`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`" ac_cs_version="\\ OpenJDK config.status jdk8 -configured by $0, generated by GNU Autoconf 2.67, +configured by $0, generated by GNU Autoconf 2.68, with options \\"\$ac_cs_config\\" Copyright (C) 2010 Free Software Foundation, Inc. @@ -34263,7 +34285,7 @@ do "$OUTPUT_ROOT/spec.sh") CONFIG_FILES="$CONFIG_FILES $OUTPUT_ROOT/spec.sh:$AUTOCONF_DIR/spec.sh.in" ;; "$OUTPUT_ROOT/Makefile") CONFIG_FILES="$CONFIG_FILES $OUTPUT_ROOT/Makefile:$AUTOCONF_DIR/Makefile.in" ;; - *) as_fn_error $? "invalid argument: \`$ac_config_target'" "$LINENO" 5 ;; + *) as_fn_error $? "invalid argument: \`$ac_config_target'" "$LINENO" 5;; esac done @@ -34285,9 +34307,10 @@ fi # after its creation but before its name has been assigned to `$tmp'. $debug || { - tmp= + tmp= ac_tmp= trap 'exit_status=$? - { test -z "$tmp" || test ! -d "$tmp" || rm -fr "$tmp"; } && exit $exit_status + : "${ac_tmp:=$tmp}" + { test ! -d "$ac_tmp" || rm -fr "$ac_tmp"; } && exit $exit_status ' 0 trap 'as_fn_exit 1' 1 2 13 15 } @@ -34295,12 +34318,13 @@ $debug || { tmp=`(umask 077 && mktemp -d "./confXXXXXX") 2>/dev/null` && - test -n "$tmp" && test -d "$tmp" + test -d "$tmp" } || { tmp=./conf$$-$RANDOM (umask 077 && mkdir "$tmp") } || as_fn_error $? "cannot create a temporary directory in ." "$LINENO" 5 +ac_tmp=$tmp # Set up the scripts for CONFIG_FILES section. # No need to generate them if there are no CONFIG_FILES. @@ -34322,7 +34346,7 @@ else ac_cs_awk_cr=$ac_cr fi -echo 'BEGIN {' >"$tmp/subs1.awk" && +echo 'BEGIN {' >"$ac_tmp/subs1.awk" && _ACEOF @@ -34350,7 +34374,7 @@ done rm -f conf$$subs.sh cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 -cat >>"\$tmp/subs1.awk" <<\\_ACAWK && +cat >>"\$ac_tmp/subs1.awk" <<\\_ACAWK && _ACEOF sed -n ' h @@ -34398,7 +34422,7 @@ t delim rm -f conf$$subs.awk cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 _ACAWK -cat >>"\$tmp/subs1.awk" <<_ACAWK && +cat >>"\$ac_tmp/subs1.awk" <<_ACAWK && for (key in S) S_is_set[key] = 1 FS = "" @@ -34430,7 +34454,7 @@ if sed "s/$ac_cr//" < /dev/null > /dev/null 2>&1; then sed "s/$ac_cr\$//; s/$ac_cr/$ac_cs_awk_cr/g" else cat -fi < "$tmp/subs1.awk" > "$tmp/subs.awk" \ +fi < "$ac_tmp/subs1.awk" > "$ac_tmp/subs.awk" \ || as_fn_error $? "could not setup config files machinery" "$LINENO" 5 _ACEOF @@ -34464,7 +34488,7 @@ fi # test -n "$CONFIG_FILES" # No need to generate them if there are no CONFIG_HEADERS. # This happens for instance with `./config.status Makefile'. if test -n "$CONFIG_HEADERS"; then -cat >"$tmp/defines.awk" <<\_ACAWK || +cat >"$ac_tmp/defines.awk" <<\_ACAWK || BEGIN { _ACEOF @@ -34476,8 +34500,8 @@ _ACEOF # handling of long lines. ac_delim='%!_!# ' for ac_last_try in false false :; do - ac_t=`sed -n "/$ac_delim/p" confdefs.h` - if test -z "$ac_t"; then + ac_tt=`sed -n "/$ac_delim/p" confdefs.h` + if test -z "$ac_tt"; then break elif $ac_last_try; then as_fn_error $? "could not make $CONFIG_HEADERS" "$LINENO" 5 @@ -34578,7 +34602,7 @@ do esac case $ac_mode$ac_tag in :[FHL]*:*);; - :L* | :C*:*) as_fn_error $? "invalid tag \`$ac_tag'" "$LINENO" 5 ;; + :L* | :C*:*) as_fn_error $? "invalid tag \`$ac_tag'" "$LINENO" 5;; :[FH]-) ac_tag=-:-;; :[FH]*) ac_tag=$ac_tag:$ac_tag.in;; esac @@ -34597,7 +34621,7 @@ do for ac_f do case $ac_f in - -) ac_f="$tmp/stdin";; + -) ac_f="$ac_tmp/stdin";; *) # Look for the file first in the build tree, then in the source tree # (if the path is not absolute). The absolute path cannot be DOS-style, # because $ac_f cannot contain `:'. @@ -34606,7 +34630,7 @@ do [\\/$]*) false;; *) test -f "$srcdir/$ac_f" && ac_f="$srcdir/$ac_f";; esac || - as_fn_error 1 "cannot find input file: \`$ac_f'" "$LINENO" 5 ;; + as_fn_error 1 "cannot find input file: \`$ac_f'" "$LINENO" 5;; esac case $ac_f in *\'*) ac_f=`$as_echo "$ac_f" | sed "s/'/'\\\\\\\\''/g"`;; esac as_fn_append ac_file_inputs " '$ac_f'" @@ -34632,8 +34656,8 @@ $as_echo "$as_me: creating $ac_file" >&6;} esac case $ac_tag in - *:-:* | *:-) cat >"$tmp/stdin" \ - || as_fn_error $? "could not create $ac_file" "$LINENO" 5 ;; + *:-:* | *:-) cat >"$ac_tmp/stdin" \ + || as_fn_error $? "could not create $ac_file" "$LINENO" 5 ;; esac ;; esac @@ -34758,21 +34782,22 @@ s&@abs_builddir@&$ac_abs_builddir&;t t s&@abs_top_builddir@&$ac_abs_top_builddir&;t t $ac_datarootdir_hack " -eval sed \"\$ac_sed_extra\" "$ac_file_inputs" | $AWK -f "$tmp/subs.awk" >$tmp/out \ - || as_fn_error $? "could not create $ac_file" "$LINENO" 5 +eval sed \"\$ac_sed_extra\" "$ac_file_inputs" | $AWK -f "$ac_tmp/subs.awk" \ + >$ac_tmp/out || as_fn_error $? "could not create $ac_file" "$LINENO" 5 test -z "$ac_datarootdir_hack$ac_datarootdir_seen" && - { ac_out=`sed -n '/\${datarootdir}/p' "$tmp/out"`; test -n "$ac_out"; } && - { ac_out=`sed -n '/^[ ]*datarootdir[ ]*:*=/p' "$tmp/out"`; test -z "$ac_out"; } && + { ac_out=`sed -n '/\${datarootdir}/p' "$ac_tmp/out"`; test -n "$ac_out"; } && + { ac_out=`sed -n '/^[ ]*datarootdir[ ]*:*=/p' \ + "$ac_tmp/out"`; test -z "$ac_out"; } && { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $ac_file contains a reference to the variable \`datarootdir' which seems to be undefined. Please make sure it is defined" >&5 $as_echo "$as_me: WARNING: $ac_file contains a reference to the variable \`datarootdir' which seems to be undefined. Please make sure it is defined" >&2;} - rm -f "$tmp/stdin" + rm -f "$ac_tmp/stdin" case $ac_file in - -) cat "$tmp/out" && rm -f "$tmp/out";; - *) rm -f "$ac_file" && mv "$tmp/out" "$ac_file";; + -) cat "$ac_tmp/out" && rm -f "$ac_tmp/out";; + *) rm -f "$ac_file" && mv "$ac_tmp/out" "$ac_file";; esac \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 ;; @@ -34783,20 +34808,20 @@ which seems to be undefined. Please make sure it is defined" >&2;} if test x"$ac_file" != x-; then { $as_echo "/* $configure_input */" \ - && eval '$AWK -f "$tmp/defines.awk"' "$ac_file_inputs" - } >"$tmp/config.h" \ + && eval '$AWK -f "$ac_tmp/defines.awk"' "$ac_file_inputs" + } >"$ac_tmp/config.h" \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 - if diff "$ac_file" "$tmp/config.h" >/dev/null 2>&1; then + if diff "$ac_file" "$ac_tmp/config.h" >/dev/null 2>&1; then { $as_echo "$as_me:${as_lineno-$LINENO}: $ac_file is unchanged" >&5 $as_echo "$as_me: $ac_file is unchanged" >&6;} else rm -f "$ac_file" - mv "$tmp/config.h" "$ac_file" \ + mv "$ac_tmp/config.h" "$ac_file" \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 fi else $as_echo "/* $configure_input */" \ - && eval '$AWK -f "$tmp/defines.awk"' "$ac_file_inputs" \ + && eval '$AWK -f "$ac_tmp/defines.awk"' "$ac_file_inputs" \ || as_fn_error $? "could not create -" "$LINENO" 5 fi ;; diff --git a/common/autoconf/toolchain_windows.m4 b/common/autoconf/toolchain_windows.m4 index 966c0133995..e5d4fff38f9 100644 --- a/common/autoconf/toolchain_windows.m4 +++ b/common/autoconf/toolchain_windows.m4 @@ -208,6 +208,8 @@ AC_DEFUN([TOOLCHAIN_SETUP_VISUAL_STUDIO_ENV], # Remove any trailing \ from INCLUDE and LIB to avoid trouble in spec.gmk. VS_INCLUDE=`$ECHO "$INCLUDE" | $SED 's/\\\\$//'` VS_LIB=`$ECHO "$LIB" | $SED 's/\\\\$//'` + # Remove any paths containing # (typically F#) as that messes up make + PATH=`$ECHO "$PATH" | $SED 's/[[^:#]]*#[^:]*://g'` VS_PATH="$PATH" AC_SUBST(VS_INCLUDE) AC_SUBST(VS_LIB)
        Attributes Automatically Placed in a Provider Object
        NameValue
        {@code Provider.id name}{@code String.valueOf(provider.getName())}