From 58faa32cfe46f5ae66d1494c7afec9f0df6edfaf Mon Sep 17 00:00:00 2001 From: Chris Dennis Date: Tue, 11 Apr 2017 17:25:09 -0400 Subject: [PATCH 01/39] 8178117: Add public state constructors for Int/Long/DoubleSummaryStatistics Reviewed-by: psandoz, bpb, briangoetz --- .../java/util/DoubleSummaryStatistics.java | 58 ++++++++++++++++++- .../java/util/IntSummaryStatistics.java | 49 +++++++++++++++- .../java/util/LongSummaryStatistics.java | 49 +++++++++++++++- .../CollectAndSummaryStatisticsTest.java | 47 ++++++++++++++- 4 files changed, 195 insertions(+), 8 deletions(-) diff --git a/src/java.base/share/classes/java/util/DoubleSummaryStatistics.java b/src/java.base/share/classes/java/util/DoubleSummaryStatistics.java index 066c5d2d115..192a5bcb985 100644 --- a/src/java.base/share/classes/java/util/DoubleSummaryStatistics.java +++ b/src/java.base/share/classes/java/util/DoubleSummaryStatistics.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2017, Oracle and/or its affiliates. All rights reserved. * 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,6 +26,7 @@ package java.util; import java.util.function.DoubleConsumer; import java.util.stream.Collector; +import java.util.stream.DoubleStream; /** * A state object for collecting statistics such as count, min, max, sum, and @@ -69,12 +70,65 @@ public class DoubleSummaryStatistics implements DoubleConsumer { private double max = Double.NEGATIVE_INFINITY; /** - * Construct an empty instance with zero count, zero sum, + * Constructs an empty instance with zero count, zero sum, * {@code Double.POSITIVE_INFINITY} min, {@code Double.NEGATIVE_INFINITY} * max and zero average. */ public DoubleSummaryStatistics() { } + /** + * Constructs a non-empty instance with the specified {@code count}, + * {@code min}, {@code max}, and {@code sum}. + * + *

If {@code count} is zero then the remaining arguments are ignored and + * an empty instance is constructed. + * + *

If the arguments are inconsistent then an {@code IllegalArgumentException} + * is thrown. The necessary consistent argument conditions are: + *

+ * @apiNote + * The enforcement of argument correctness means that the retrieved set of + * recorded values obtained from a {@code DoubleSummaryStatistics} source + * instance may not be a legal set of arguments for this constructor due to + * arithmetic overflow of the source's recorded count of values. + * The consistent argument conditions are not sufficient to prevent the + * creation of an internally inconsistent instance. An example of such a + * state would be an instance with: {@code count} = 2, {@code min} = 1, + * {@code max} = 2, and {@code sum} = 0. + * + * @param count the count of values + * @param min the minimum value + * @param max the maximum value + * @param sum the sum of all values + * @throws IllegalArgumentException if the arguments are inconsistent + * @since 10 + */ + public DoubleSummaryStatistics(long count, double min, double max, double sum) + throws IllegalArgumentException { + if (count < 0L) { + throw new IllegalArgumentException("Negative count value"); + } else if (count > 0L) { + if (min > max) + throw new IllegalArgumentException("Minimum greater than maximum"); + + // All NaN or non NaN + var ncount = DoubleStream.of(min, max, sum).filter(Double::isNaN).count(); + if (ncount > 0 && ncount < 3) + throw new IllegalArgumentException("Some, not all, of the minimum, maximum, or sum is NaN"); + + this.count = count; + this.sum = sum; + this.simpleSum = sum; + this.sumCompensation = 0.0d; + this.min = min; + this.max = max; + } + // Use default field values if count == 0 + } + /** * Records another value into the summary information. * diff --git a/src/java.base/share/classes/java/util/IntSummaryStatistics.java b/src/java.base/share/classes/java/util/IntSummaryStatistics.java index f5691a8b672..9043c8a15cd 100644 --- a/src/java.base/share/classes/java/util/IntSummaryStatistics.java +++ b/src/java.base/share/classes/java/util/IntSummaryStatistics.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2017, Oracle and/or its affiliates. All rights reserved. * 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,12 +69,57 @@ public class IntSummaryStatistics implements IntConsumer { private int max = Integer.MIN_VALUE; /** - * Construct an empty instance with zero count, zero sum, + * Constructs an empty instance with zero count, zero sum, * {@code Integer.MAX_VALUE} min, {@code Integer.MIN_VALUE} max and zero * average. */ public IntSummaryStatistics() { } + /** + * Constructs a non-empty instance with the specified {@code count}, + * {@code min}, {@code max}, and {@code sum}. + * + *

If {@code count} is zero then the remaining arguments are ignored and + * an empty instance is constructed. + * + *

If the arguments are inconsistent then an {@code IllegalArgumentException} + * is thrown. The necessary consistent argument conditions are: + *

+ * @apiNote + * The enforcement of argument correctness means that the retrieved set of + * recorded values obtained from a {@code IntSummaryStatistics} source + * instance may not be a legal set of arguments for this constructor due to + * arithmetic overflow of the source's recorded count of values. + * The consistent argument conditions are not sufficient to prevent the + * creation of an internally inconsistent instance. An example of such a + * state would be an instance with: {@code count} = 2, {@code min} = 1, + * {@code max} = 2, and {@code sum} = 0. + * + * @param count the count of values + * @param min the minimum value + * @param max the maximum value + * @param sum the sum of all values + * @throws IllegalArgumentException if the arguments are inconsistent + * @since 10 + */ + public IntSummaryStatistics(long count, int min, int max, long sum) + throws IllegalArgumentException { + if (count < 0L) { + throw new IllegalArgumentException("Negative count value"); + } else if (count > 0L) { + if (min > max) throw new IllegalArgumentException("Minimum greater than maximum"); + + this.count = count; + this.sum = sum; + this.min = min; + this.max = max; + } + // Use default field values if count == 0 + } + /** * Records a new value into the summary information * diff --git a/src/java.base/share/classes/java/util/LongSummaryStatistics.java b/src/java.base/share/classes/java/util/LongSummaryStatistics.java index 1ae091c1102..06ad64795da 100644 --- a/src/java.base/share/classes/java/util/LongSummaryStatistics.java +++ b/src/java.base/share/classes/java/util/LongSummaryStatistics.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2017, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -70,12 +70,57 @@ public class LongSummaryStatistics implements LongConsumer, IntConsumer { private long max = Long.MIN_VALUE; /** - * Construct an empty instance with zero count, zero sum, + * Constructs an empty instance with zero count, zero sum, * {@code Long.MAX_VALUE} min, {@code Long.MIN_VALUE} max and zero * average. */ public LongSummaryStatistics() { } + /** + * Constructs a non-empty instance with the specified {@code count}, + * {@code min}, {@code max}, and {@code sum}. + * + *

If {@code count} is zero then the remaining arguments are ignored and + * an empty instance is constructed. + * + *

If the arguments are inconsistent then an {@code IllegalArgumentException} + * is thrown. The necessary consistent argument conditions are: + *

+ * @apiNote + * The enforcement of argument correctness means that the retrieved set of + * recorded values obtained from a {@code LongSummaryStatistics} source + * instance may not be a legal set of arguments for this constructor due to + * arithmetic overflow of the source's recorded count of values. + * The consistent argument conditions are not sufficient to prevent the + * creation of an internally inconsistent instance. An example of such a + * state would be an instance with: {@code count} = 2, {@code min} = 1, + * {@code max} = 2, and {@code sum} = 0. + * + * @param count the count of values + * @param min the minimum value + * @param max the maximum value + * @param sum the sum of all values + * @throws IllegalArgumentException if the arguments are inconsistent + * @since 10 + */ + public LongSummaryStatistics(long count, long min, long max, long sum) + throws IllegalArgumentException { + if (count < 0L) { + throw new IllegalArgumentException("Negative count value"); + } else if (count > 0L) { + if (min > max) throw new IllegalArgumentException("Minimum greater than maximum"); + + this.count = count; + this.sum = sum; + this.min = min; + this.max = max; + } + // Use default field values if count == 0 + } + /** * Records a new {@code int} value into the summary information. * diff --git a/test/jdk/java/util/stream/test/org/openjdk/tests/java/util/stream/CollectAndSummaryStatisticsTest.java b/test/jdk/java/util/stream/test/org/openjdk/tests/java/util/stream/CollectAndSummaryStatisticsTest.java index 22d91ba3f84..3b703eab7f9 100644 --- a/test/jdk/java/util/stream/test/org/openjdk/tests/java/util/stream/CollectAndSummaryStatisticsTest.java +++ b/test/jdk/java/util/stream/test/org/openjdk/tests/java/util/stream/CollectAndSummaryStatisticsTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2017, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -24,7 +24,7 @@ /* * @test * @summary primtive stream collection with summary statistics - * @bug 8044047 + * @bug 8044047 8178117 */ package org.openjdk.tests.java.util.stream; @@ -91,11 +91,19 @@ public class CollectAndSummaryStatisticsTest extends OpTestCase { instances.add(countTo(1000).stream().mapToInt(i -> i).collect(IntSummaryStatistics::new, IntSummaryStatistics::accept, IntSummaryStatistics::combine)); + instances.add(countTo(1000).stream().mapToInt(i -> i).collect(() -> new IntSummaryStatistics(0, -1, 1001, 2), + IntSummaryStatistics::accept, + IntSummaryStatistics::combine)); instances.add(countTo(1000).parallelStream().collect(Collectors.summarizingInt(i -> i))); instances.add(countTo(1000).parallelStream().mapToInt(i -> i).summaryStatistics()); instances.add(countTo(1000).parallelStream().mapToInt(i -> i).collect(IntSummaryStatistics::new, IntSummaryStatistics::accept, IntSummaryStatistics::combine)); + instances.add(countTo(1000).parallelStream().mapToInt(i -> i).collect(() -> new IntSummaryStatistics(0, -1, 1001, 2), + IntSummaryStatistics::accept, + IntSummaryStatistics::combine)); + IntSummaryStatistics original = instances.get(0); + instances.add(new IntSummaryStatistics(original.getCount(), original.getMin(), original.getMax(), original.getSum())); for (IntSummaryStatistics stats : instances) { assertEquals(stats.getCount(), 1000); @@ -104,6 +112,9 @@ public class CollectAndSummaryStatisticsTest extends OpTestCase { assertEquals(stats.getMax(), 1000); assertEquals(stats.getMin(), 1); } + + expectThrows(IllegalArgumentException.class, () -> new IntSummaryStatistics(-1, 0, 0, 0)); + expectThrows(IllegalArgumentException.class, () -> new IntSummaryStatistics(1, 3, 2, 0)); } @@ -114,11 +125,19 @@ public class CollectAndSummaryStatisticsTest extends OpTestCase { instances.add(countTo(1000).stream().mapToLong(i -> i).collect(LongSummaryStatistics::new, LongSummaryStatistics::accept, LongSummaryStatistics::combine)); + instances.add(countTo(1000).stream().mapToInt(i -> i).collect(() -> new LongSummaryStatistics(0, -1, 1001, 2), + LongSummaryStatistics::accept, + LongSummaryStatistics::combine)); instances.add(countTo(1000).parallelStream().collect(Collectors.summarizingLong(i -> i))); instances.add(countTo(1000).parallelStream().mapToLong(i -> i).summaryStatistics()); instances.add(countTo(1000).parallelStream().mapToLong(i -> i).collect(LongSummaryStatistics::new, LongSummaryStatistics::accept, LongSummaryStatistics::combine)); + instances.add(countTo(1000).parallelStream().mapToInt(i -> i).collect(() -> new LongSummaryStatistics(0, -1, 1001, 2), + LongSummaryStatistics::accept, + LongSummaryStatistics::combine)); + LongSummaryStatistics original = instances.get(0); + instances.add(new LongSummaryStatistics(original.getCount(), original.getMin(), original.getMax(), original.getSum())); for (LongSummaryStatistics stats : instances) { assertEquals(stats.getCount(), 1000); @@ -127,6 +146,9 @@ public class CollectAndSummaryStatisticsTest extends OpTestCase { assertEquals(stats.getMax(), 1000L); assertEquals(stats.getMin(), 1L); } + + expectThrows(IllegalArgumentException.class, () -> new LongSummaryStatistics(-1, 0, 0, 0)); + expectThrows(IllegalArgumentException.class, () -> new LongSummaryStatistics(1, 3, 2, 0)); } public void testDoubleStatistics() { @@ -136,11 +158,19 @@ public class CollectAndSummaryStatisticsTest extends OpTestCase { instances.add(countTo(1000).stream().mapToDouble(i -> i).collect(DoubleSummaryStatistics::new, DoubleSummaryStatistics::accept, DoubleSummaryStatistics::combine)); + instances.add(countTo(1000).stream().mapToInt(i -> i).collect(() -> new DoubleSummaryStatistics(0, -1, 1001, 2), + DoubleSummaryStatistics::accept, + DoubleSummaryStatistics::combine)); instances.add(countTo(1000).parallelStream().collect(Collectors.summarizingDouble(i -> i))); instances.add(countTo(1000).parallelStream().mapToDouble(i -> i).summaryStatistics()); instances.add(countTo(1000).parallelStream().mapToDouble(i -> i).collect(DoubleSummaryStatistics::new, DoubleSummaryStatistics::accept, DoubleSummaryStatistics::combine)); + instances.add(countTo(1000).parallelStream().mapToInt(i -> i).collect(() -> new DoubleSummaryStatistics(0, -1, 1001, 2), + DoubleSummaryStatistics::accept, + DoubleSummaryStatistics::combine)); + DoubleSummaryStatistics original = instances.get(0); + instances.add(new DoubleSummaryStatistics(original.getCount(), original.getMin(), original.getMax(), original.getSum())); for (DoubleSummaryStatistics stats : instances) { assertEquals(stats.getCount(), 1000); @@ -149,5 +179,18 @@ public class CollectAndSummaryStatisticsTest extends OpTestCase { assertEquals(stats.getMax(), 1000.0); assertEquals(stats.getMin(), 1.0); } + + expectThrows(IllegalArgumentException.class, () -> new DoubleSummaryStatistics(-1, 0, 0, 0)); + expectThrows(IllegalArgumentException.class, () -> new DoubleSummaryStatistics(1, 3, 2, 0)); + double[] values = {1.0, Double.NaN}; + for (var min : values) { + for (var max : values) { + for (var sum : values) { + if (Double.isNaN(min) && Double.isNaN(max) && Double.isNaN(sum)) continue; + if (!Double.isNaN(min) && !Double.isNaN(max) && !Double.isNaN(sum)) continue; + expectThrows(IllegalArgumentException.class, () -> new DoubleSummaryStatistics(1, min, max, sum)); + } + } + } } } From 5852f663bfa105a24e3c1ae72888860562499736 Mon Sep 17 00:00:00 2001 From: Sergey Bylokhov Date: Fri, 20 Oct 2017 15:12:45 -0700 Subject: [PATCH 02/39] 8187399: Different problems in the javadoc's links in java.desktop package Reviewed-by: azvegint --- .../share/classes/java/awt/Desktop.java | 30 +++++++++---------- .../classes/java/awt/event/MouseEvent.java | 1 - .../standard/PresentationDirection.java | 8 ++--- .../share/classes/javax/swing/JComponent.java | 2 +- .../classes/javax/swing/JEditorPane.java | 10 ++++--- .../classes/javax/swing/JOptionPane.java | 2 +- .../javax/swing/SpinnerNumberModel.java | 3 +- .../classes/javax/swing/text/Document.java | 8 ++--- 8 files changed, 32 insertions(+), 32 deletions(-) diff --git a/src/java.desktop/share/classes/java/awt/Desktop.java b/src/java.desktop/share/classes/java/awt/Desktop.java index c27dbcfb4b1..f1dc4429af6 100644 --- a/src/java.desktop/share/classes/java/awt/Desktop.java +++ b/src/java.desktop/share/classes/java/awt/Desktop.java @@ -768,13 +768,13 @@ public class Desktop { * Installs the handler which is notified when the application is asked to * open a list of files. * - * @implNote Please note that for Mac OS, notifications + * @implNote Please note that for macOS, notifications * are only sent if the Java app is a bundled application, * with a {@code CFBundleDocumentTypes} array present in its - * Info.plist. See the - * - * Info.plist Key Reference for more information about adding a - * {@code CFBundleDocumentTypes} key to your app's Info.plist. + * {@code Info.plist}. Check the + * + * Apple Developer Documentation for more information about + * {@code Info.plist}. * * @param openFileHandler handler * @@ -800,13 +800,13 @@ public class Desktop { * Installs the handler which is notified when the application is asked to * print a list of files. * - * @implNote Please note that for Mac OS, notifications + * @implNote Please note that for macOS, notifications * are only sent if the Java app is a bundled application, * with a {@code CFBundleDocumentTypes} array present in its - * Info.plist. See the - * - * Info.plist Key Reference for more information about adding a - * {@code CFBundleDocumentTypes} key to your app's Info.plist. + * {@code Info.plist}. Check the + * + * Apple Developer Documentation for more information about + * {@code Info.plist}. * * @param printFileHandler handler * @throws SecurityException if a security manager exists and its @@ -835,13 +835,13 @@ public class Desktop { * {@link OpenURIHandler#openURI(OpenURIEvent)} requests to be * enqueued until another handler is set. * - * @implNote Please note that for Mac OS, notifications + * @implNote Please note that for macOS, notifications * are only sent if the Java app is a bundled application, * with a {@code CFBundleDocumentTypes} array present in its - * Info.plist. See the - * - * Info.plist Key Reference for more information about adding a - * {@code CFBundleDocumentTypes} key to your app's Info.plist. + * {@code Info.plist}. Check the + * + * Apple Developer Documentation for more information about + * {@code Info.plist}. * * @param openURIHandler handler * diff --git a/src/java.desktop/share/classes/java/awt/event/MouseEvent.java b/src/java.desktop/share/classes/java/awt/event/MouseEvent.java index 77513074c8d..b8485253917 100644 --- a/src/java.desktop/share/classes/java/awt/event/MouseEvent.java +++ b/src/java.desktop/share/classes/java/awt/event/MouseEvent.java @@ -745,7 +745,6 @@ public class MouseEvent extends InputEvent { * @see #getClickCount() * @see #isPopupTrigger() * @see #getButton() - * @see #button * @see Toolkit#areExtraMouseButtonsEnabled() * @see java.awt.MouseInfo#getNumberOfButtons() * @see InputEvent#getMaskForButton(int) diff --git a/src/java.desktop/share/classes/javax/print/attribute/standard/PresentationDirection.java b/src/java.desktop/share/classes/javax/print/attribute/standard/PresentationDirection.java index 261824ce07f..5a4a46ba3a6 100644 --- a/src/java.desktop/share/classes/javax/print/attribute/standard/PresentationDirection.java +++ b/src/java.desktop/share/classes/javax/print/attribute/standard/PresentationDirection.java @@ -41,10 +41,10 @@ import javax.print.attribute.PrintRequestAttribute; *

* IPP Compatibility: This attribute is not an IPP 1.1 attribute; it is * an attribute in the Production Printing Extension - * (PDF) of IPP - * 1.1. The category name returned by {@code getName()} is the IPP attribute - * name. The enumeration's integer value is the IPP enum value. The - * {@code toString()} method returns the IPP string representation of the + * ( + * PDF) of IPP 1.1. The category name returned by {@code getName()} is the + * IPP attribute name. The enumeration's integer value is the IPP enum value. + * The {@code toString()} method returns the IPP string representation of the * attribute value. * * @author Phil Race diff --git a/src/java.desktop/share/classes/javax/swing/JComponent.java b/src/java.desktop/share/classes/javax/swing/JComponent.java index 90c515f09fc..19f39890a11 100644 --- a/src/java.desktop/share/classes/javax/swing/JComponent.java +++ b/src/java.desktop/share/classes/javax/swing/JComponent.java @@ -121,7 +121,7 @@ import sun.swing.SwingUtilities2; * both of which are sections in The Java Tutorial. * * For more information on these subjects, see the - * Swing package description + * {@link javax.swing Swing package description} * and The Java Tutorial section * The JComponent Class. *

diff --git a/src/java.desktop/share/classes/javax/swing/JEditorPane.java b/src/java.desktop/share/classes/javax/swing/JEditorPane.java index f80c41f1f98..fa019e39834 100644 --- a/src/java.desktop/share/classes/javax/swing/JEditorPane.java +++ b/src/java.desktop/share/classes/javax/swing/JEditorPane.java @@ -1914,11 +1914,13 @@ public class JEditorPane extends JTextComponent { /** * Return an object that represents the link anchor, - * as appropriate for that link. E.g. from HTML: - * Accessibility + * as appropriate for that link. + *

+ * E.g. from HTML: + * <a href="http://openjdk.java.net">OpenJDK</a> * this method would return a String containing the text: - * 'Accessibility'. - * + * 'OpenJDK'. + *

* Similarly, from this HTML: * <a HREF="#top"><img src="top-hat.gif" alt="top hat"></a> * this might return the object ImageIcon("top-hat.gif", "top hat"); diff --git a/src/java.desktop/share/classes/javax/swing/JOptionPane.java b/src/java.desktop/share/classes/javax/swing/JOptionPane.java index 34a1488b0cf..ad5a5061649 100644 --- a/src/java.desktop/share/classes/javax/swing/JOptionPane.java +++ b/src/java.desktop/share/classes/javax/swing/JOptionPane.java @@ -148,7 +148,7 @@ import sun.awt.AWTAccessor; * in which case a default Frame is used as the parent, * and the dialog will be * centered on the screen (depending on the {@literal L&F}). - *

message
+ *
message
* A descriptive message to be placed in the dialog box. * In the most common usage, message is just a String or * String constant. diff --git a/src/java.desktop/share/classes/javax/swing/SpinnerNumberModel.java b/src/java.desktop/share/classes/javax/swing/SpinnerNumberModel.java index 3fbd668bb80..d8db7b3ae0f 100644 --- a/src/java.desktop/share/classes/javax/swing/SpinnerNumberModel.java +++ b/src/java.desktop/share/classes/javax/swing/SpinnerNumberModel.java @@ -260,8 +260,7 @@ public class SpinnerNumberModel extends AbstractSpinnerModel implements Serializ * as the value however it's possible to use any * Comparable with a compareTo * method for a Number with the same type as the value. - * See - * setMinimum for an example. + * See {@link #setMinimum(Comparable)} for an example. *

* This method fires a ChangeEvent if the * maximum has changed. diff --git a/src/java.desktop/share/classes/javax/swing/text/Document.java b/src/java.desktop/share/classes/javax/swing/text/Document.java index 4cab9c4fe2d..037fae71d63 100644 --- a/src/java.desktop/share/classes/javax/swing/text/Document.java +++ b/src/java.desktop/share/classes/javax/swing/text/Document.java @@ -146,10 +146,10 @@ import javax.swing.event.*; *

* The methods related to observing mutations to the document are: *

* *

Properties From 49c29ca97402d64c0e42e49adc5673489997f6cb Mon Sep 17 00:00:00 2001 From: Sergey Bylokhov Date: Fri, 20 Oct 2017 15:39:50 -0700 Subject: [PATCH 03/39] 8184219: Fix accessibility of tables in the java.desktop module Reviewed-by: jjg --- .../classes/java/applet/AppletContext.java | 38 +- .../share/classes/java/awt/AWTKeyStroke.java | 32 +- .../share/classes/java/awt/AWTPermission.java | 246 ++++++------ .../classes/java/awt/AlphaComposite.java | 86 +++-- .../share/classes/java/awt/Component.java | 36 +- .../share/classes/java/awt/Container.java | 45 +-- .../share/classes/java/awt/EventQueue.java | 45 +-- .../java/awt/KeyboardFocusManager.java | 49 ++- .../share/classes/java/awt/Scrollbar.java | 86 ++--- .../share/classes/java/awt/SystemTray.java | 38 +- .../classes/java/awt/font/NumericShaper.java | 55 ++- .../classes/java/awt/font/TextAttribute.java | 282 +++++++------- .../classes/javax/imageio/package-info.java | 133 +++---- .../plugins/bmp/BMPImageWriteParam.java | 35 +- .../javax/imageio/plugins/tiff/TIFFField.java | 290 ++++---------- .../share/classes/javax/print/DocFlavor.java | 38 +- .../attribute/standard/Chromaticity.java | 11 +- .../print/attribute/standard/JobKOctets.java | 23 +- .../attribute/standard/package-info.java | 165 ++++---- .../javax/sound/midi/MidiFileFormat.java | 22 +- .../classes/javax/sound/midi/MidiSystem.java | 16 +- .../javax/sound/sampled/AudioFileFormat.java | 24 +- .../javax/sound/sampled/AudioFormat.java | 12 +- .../javax/sound/sampled/AudioPermission.java | 10 +- .../javax/sound/sampled/AudioSystem.java | 16 +- .../javax/sound/sampled/ReverbType.java | 22 +- .../share/classes/javax/swing/Action.java | 174 ++++----- .../javax/swing/JFormattedTextField.java | 39 +- .../share/classes/javax/swing/JList.java | 35 +- .../classes/javax/swing/JOptionPane.java | 37 +- .../javax/swing/plaf/basic/BasicListUI.java | 85 +++-- .../swing/plaf/metal/MetalLookAndFeel.java | 108 +++--- .../javax/swing/plaf/metal/MetalTreeUI.java | 35 +- .../javax/swing/text/JTextComponent.java | 53 +-- .../javax/swing/text/MaskFormatter.java | 59 +-- .../javax/swing/text/html/FormView.java | 91 ++--- .../javax/swing/text/html/HTMLDocument.java | 361 ++++++++++++------ .../javax/swing/text/html/HTMLEditorKit.java | 183 +++++---- .../swing/tree/DefaultTreeCellRenderer.java | 36 +- 39 files changed, 1597 insertions(+), 1554 deletions(-) diff --git a/src/java.desktop/share/classes/java/applet/AppletContext.java b/src/java.desktop/share/classes/java/applet/AppletContext.java index 2a34faa6e77..8c955c5db06 100644 --- a/src/java.desktop/share/classes/java/applet/AppletContext.java +++ b/src/java.desktop/share/classes/java/applet/AppletContext.java @@ -117,24 +117,30 @@ public interface AppletContext { * * * - * - * + * + * * - * - * - * - * - * + * + * + * + * + * + * *
Target arguments and their descriptions
Target ArgumentDescription
Target Argument + * Description *
{@code "_self"} Show in the window and frame that - * contain the applet.
{@code "_parent"}Show in the applet's parent frame. If - * the applet's frame has no parent frame, - * acts the same as "_self".
{@code "_top"} Show in the top-level frame of the applet's - * window. If the applet's frame is the - * top-level frame, acts the same as "_self".
{@code "_blank"} Show in a new, unnamed - * top-level window.
nameShow in the frame or window named name. If - * a target named name does not already exist, a - * new top-level window with the specified name is created, - * and the document is shown there.
{@code "_self"} + * Show in the window and frame that contain the applet. + *
{@code "_parent"} + * Show in the applet's parent frame. If the applet's frame has no + * parent frame, acts the same as "_self". + *
{@code "_top"} + * Show in the top-level frame of the applet's window. If the + * applet's frame is the top-level frame, acts the same as "_self". + *
{@code "_blank"} + * Show in a new, unnamed top-level window. + *
name + * Show in the frame or window named name. If a target named + * name does not already exist, a new top-level window with the + * specified name is created, and the document is shown there. *
*

diff --git a/src/java.desktop/share/classes/java/awt/AWTKeyStroke.java b/src/java.desktop/share/classes/java/awt/AWTKeyStroke.java index 8406294c5e9..2328b110a9e 100644 --- a/src/java.desktop/share/classes/java/awt/AWTKeyStroke.java +++ b/src/java.desktop/share/classes/java/awt/AWTKeyStroke.java @@ -94,25 +94,23 @@ public class AWTKeyStroke implements Serializable { * * * - * + * + * * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * + * + * + * + * + * *
AWTKeyStroke default values
PropertyDefault Value
Property + * Default Value *
Key Char{@code KeyEvent.CHAR_UNDEFINED}
Key Code{@code KeyEvent.VK_UNDEFINED}
Modifiersnone
On key release?{@code false}
Key Char + * {@code KeyEvent.CHAR_UNDEFINED} + *
Key Code + * {@code KeyEvent.VK_UNDEFINED} + *
Modifiers + * none + *
On key release? + * {@code false} *
* diff --git a/src/java.desktop/share/classes/java/awt/AWTPermission.java b/src/java.desktop/share/classes/java/awt/AWTPermission.java index c1a2b0baaf9..587591cae98 100644 --- a/src/java.desktop/share/classes/java/awt/AWTPermission.java +++ b/src/java.desktop/share/classes/java/awt/AWTPermission.java @@ -48,144 +48,116 @@ import java.security.BasicPermission; * AWTPermission target names, descriptions, and associated risks * * - * - * Permission Target Name - * What the Permission Allows - * Risks of Allowing this Permission - * + * + * Permission Target Name + * What the Permission Allows + * Risks of Allowing this Permission * * - * - * accessClipboard - * Posting and retrieval of information to and from the AWT clipboard - * This would allow malfeasant code to share - * potentially sensitive or confidential information. - * - * - * - * accessEventQueue - * Access to the AWT event queue - * After retrieving the AWT event queue, - * malicious code may peek at and even remove existing events - * from its event queue, as well as post bogus events which may purposefully - * cause the application or applet to misbehave in an insecure manner. - * - * - * - * accessSystemTray - * Access to the AWT SystemTray instance - * This would allow malicious code to add tray icons to the system tray. - * First, such an icon may look like the icon of some known application - * (such as a firewall or anti-virus) and order a user to do something unsafe - * (with help of balloon messages). Second, the system tray may be glutted with - * tray icons so that no one could add a tray icon anymore. - * - * - * - * createRobot - * Create java.awt.Robot objects - * The java.awt.Robot object allows code to generate native-level - * mouse and keyboard events as well as read the screen. It could allow - * malicious code to control the system, run other programs, read the - * display, and deny mouse and keyboard access to the user. - * - * - * - * fullScreenExclusive - * Enter full-screen exclusive mode - * Entering full-screen exclusive mode allows direct access to - * low-level graphics card memory. This could be used to spoof the - * system, since the program is in direct control of rendering. Depending on - * the implementation, the security warning may not be shown for the windows - * used to enter the full-screen exclusive mode (assuming that the {@code - * fullScreenExclusive} permission has been granted to this application). Note - * that this behavior does not mean that the {@code - * showWindowWithoutWarningBanner} permission will be automatically granted to - * the application which has the {@code fullScreenExclusive} permission: - * non-full-screen windows will continue to be shown with the security - * warning. - * - * - * - * listenToAllAWTEvents - * Listen to all AWT events, system-wide - * After adding an AWT event listener, - * malicious code may scan all AWT events dispatched in the system, - * allowing it to read all user input (such as passwords). Each - * AWT event listener is called from within the context of that - * event queue's EventDispatchThread, so if the accessEventQueue - * permission is also enabled, malicious code could modify the - * contents of AWT event queues system-wide, causing the application - * or applet to misbehave in an insecure manner. - * - * - * - * readDisplayPixels - * Readback of pixels from the display screen - * Interfaces such as the java.awt.Composite interface or the - * java.awt.Robot class allow arbitrary code to examine pixels on the - * display enable malicious code to snoop on the activities of the user. - * - * - * - * replaceKeyboardFocusManager - * Sets the {@code KeyboardFocusManager} for - * a particular thread. - * When {@code SecurityManager} is installed, the invoking - * thread must be granted this permission in order to replace - * the current {@code KeyboardFocusManager}. If permission - * is not granted, a {@code SecurityException} will be thrown. - * - * - * - * setAppletStub - * Setting the stub which implements Applet container services - * Malicious code could set an applet's stub and result in unexpected - * behavior or denial of service to an applet. - * - * - * - * setWindowAlwaysOnTop - * Setting always-on-top property of the window: {@link Window#setAlwaysOnTop} - * The malicious window might make itself look and behave like a real full desktop, so that - * information entered by the unsuspecting user is captured and subsequently misused - * - * - * - * showWindowWithoutWarningBanner - * Display of a window without also displaying a banner warning - * that the window was created by an applet - * Without this warning, - * an applet may pop up windows without the user knowing that they - * belong to an applet. Since users may make security-sensitive - * decisions based on whether or not the window belongs to an applet - * (entering a username and password into a dialog box, for example), - * disabling this warning banner may allow applets to trick the user - * into entering such information. - * - * - * - * toolkitModality - * Creating {@link Dialog.ModalityType#TOOLKIT_MODAL TOOLKIT_MODAL} dialogs - * and setting the {@link Dialog.ModalExclusionType#TOOLKIT_EXCLUDE - * TOOLKIT_EXCLUDE} window property. - * When a toolkit-modal dialog is shown from an applet, it blocks all other - * applets in the browser. When launching applications from Java Web Start, - * its windows (such as the security dialog) may also be blocked by toolkit-modal - * dialogs, shown from these applications. - * - * - * - * watchMousePointer - * Getting the information about the mouse pointer position at any - * time - * Constantly watching the mouse pointer, - * an applet can make guesses about what the user is doing, i.e. moving - * the mouse to the lower left corner of the screen most likely means that - * the user is about to launch an application. If a virtual keypad is used - * so that keyboard is emulated using the mouse, an applet may guess what - * is being typed. - * + * + * accessClipboard + * Posting and retrieval of information to and from the AWT clipboard + * This would allow malfeasant code to share potentially sensitive or + * confidential information. + * + * accessEventQueue + * Access to the AWT event queue + * After retrieving the AWT event queue, malicious code may peek at and + * even remove existing events from its event queue, as well as post bogus + * events which may purposefully cause the application or applet to + * misbehave in an insecure manner. + * + * accessSystemTray + * Access to the AWT SystemTray instance + * This would allow malicious code to add tray icons to the system tray. + * First, such an icon may look like the icon of some known application + * (such as a firewall or anti-virus) and order a user to do something + * unsafe (with help of balloon messages). Second, the system tray may be + * glutted with tray icons so that no one could add a tray icon anymore. + * + * createRobot + * Create java.awt.Robot objects + * The java.awt.Robot object allows code to generate native-level mouse + * and keyboard events as well as read the screen. It could allow malicious + * code to control the system, run other programs, read the display, and + * deny mouse and keyboard access to the user. + * + * fullScreenExclusive + * Enter full-screen exclusive mode + * Entering full-screen exclusive mode allows direct access to low-level + * graphics card memory. This could be used to spoof the system, since the + * program is in direct control of rendering. Depending on the + * implementation, the security warning may not be shown for the windows + * used to enter the full-screen exclusive mode (assuming that the + * {@code fullScreenExclusive} permission has been granted to this + * application). Note that this behavior does not mean that the + * {@code showWindowWithoutWarningBanner} permission will be automatically + * granted to the application which has the {@code fullScreenExclusive} + * permission: non-full-screen windows will continue to be shown with the + * security warning. + * + * listenToAllAWTEvents + * Listen to all AWT events, system-wide + * After adding an AWT event listener, malicious code may scan all AWT + * events dispatched in the system, allowing it to read all user input (such + * as passwords). Each AWT event listener is called from within the context + * of that event queue's EventDispatchThread, so if the accessEventQueue + * permission is also enabled, malicious code could modify the contents of + * AWT event queues system-wide, causing the application or applet to + * misbehave in an insecure manner. + * + * readDisplayPixels + * Readback of pixels from the display screen + * Interfaces such as the java.awt.Composite interface or the + * java.awt.Robot class allow arbitrary code to examine pixels on the + * display enable malicious code to snoop on the activities of the user. + * + * replaceKeyboardFocusManager + * Sets the {@code KeyboardFocusManager} for a particular thread. + * When {@code SecurityManager} is installed, the invoking thread must + * be granted this permission in order to replace the current + * {@code KeyboardFocusManager}. If permission is not granted, a + * {@code SecurityException} will be thrown. + * + * setAppletStub + * Setting the stub which implements Applet container services + * Malicious code could set an applet's stub and result in unexpected + * behavior or denial of service to an applet. + * + * setWindowAlwaysOnTop + * Setting always-on-top property of the window: + * {@link Window#setAlwaysOnTop} + * The malicious window might make itself look and behave like a real + * full desktop, so that information entered by the unsuspecting user is + * captured and subsequently misused + * + * showWindowWithoutWarningBanner + * Display of a window without also displaying a banner warning that the + * window was created by an applet + * Without this warning, an applet may pop up windows without the user + * knowing that they belong to an applet. Since users may make + * security-sensitive decisions based on whether or not the window belongs + * to an applet (entering a username and password into a dialog box, for + * example), disabling this warning banner may allow applets to trick the + * user into entering such information. + * + * toolkitModality + * Creating {@link Dialog.ModalityType#TOOLKIT_MODAL TOOLKIT_MODAL} + * dialogs and setting the + * {@link Dialog.ModalExclusionType#TOOLKIT_EXCLUDE TOOLKIT_EXCLUDE} window + * property. + * When a toolkit-modal dialog is shown from an applet, it blocks all + * other applets in the browser. When launching applications from Java Web + * Start, its windows (such as the security dialog) may also be blocked by + * toolkit-modal dialogs, shown from these applications. + * + * watchMousePointer + * Getting the information about the mouse pointer position at any time + * Constantly watching the mouse pointer, an applet can make guesses + * about what the user is doing, i.e. moving the mouse to the lower left + * corner of the screen most likely means that the user is about to launch + * an application. If a virtual keypad is used so that keyboard is emulated + * using the mouse, an applet may guess what is being typed. * * * @@ -195,11 +167,9 @@ import java.security.BasicPermission; * @see java.security.PermissionCollection * @see java.lang.SecurityManager * - * * @author Marianne Mueller * @author Roland Schemers */ - public final class AWTPermission extends BasicPermission { /** use serialVersionUID from the Java 2 platform for interoperability */ diff --git a/src/java.desktop/share/classes/java/awt/AlphaComposite.java b/src/java.desktop/share/classes/java/awt/AlphaComposite.java index 5abb31fe62d..370dcb9b6db 100644 --- a/src/java.desktop/share/classes/java/awt/AlphaComposite.java +++ b/src/java.desktop/share/classes/java/awt/AlphaComposite.java @@ -72,22 +72,40 @@ import sun.java2d.SunCompositeContext; * The following factors are used in the description of the blending * equation in the Porter and Duff paper: * - *

- * + *
* - * + * + * + * + * + * + * + * + * + * + * + * + * *
Factors
Factor  Definition - *
Asthe alpha component of the source pixel - *
Csa color component of the source pixel in premultiplied form - *
Adthe alpha component of the destination pixel - *
Cda color component of the destination pixel in premultiplied form - *
Fsthe fraction of the source pixel that contributes to the output - *
Fdthe fraction of the destination pixel that contributes - * to the output - *
Arthe alpha component of the result - *
Cra color component of the result in premultiplied form + *
Factor + * Definition + *
As + * the alpha component of the source pixel + *
Cs + * a color component of the source pixel in premultiplied form + *
Ad + * the alpha component of the destination pixel + *
Cd + * a color component of the destination pixel in premultiplied form + *
Fs + * the fraction of the source pixel that contributes to the output + *
Fd + * the fraction of the destination pixel that contributes to the output + *
Ar + * the alpha component of the result + *
Cr + * a color component of the result in premultiplied form + *
- *
- * *

* Using these factors, Porter and Duff define 12 ways of choosing * the blending factors Fs and Fd to @@ -113,19 +131,37 @@ import sun.java2d.SunCompositeContext; * The following factors will be used to discuss our extensions to * the blending equation in the Porter and Duff paper: * - *

- * + *
* - * + * + * + * + * + * + * + * + * + * + * + * *
Factors
Factor  Definition - *
Csr one of the raw color components of the source pixel - *
Cdr one of the raw color components of the destination pixel - *
Aac the "extra" alpha component from the AlphaComposite instance - *
Asr the raw alpha component of the source pixel - *
Adrthe raw alpha component of the destination pixel - *
Adf the final alpha component stored in the destination - *
Cdf the final raw color component stored in the destination + *
Factor + * Definition + *
Csr + * one of the raw color components of the source pixel + *
Cdr + * one of the raw color components of the destination pixel + *
Aac + * the "extra" alpha component from the AlphaComposite instance + *
Asr + * the raw alpha component of the source pixel + *
Adr + * the raw alpha component of the destination pixel + *
Adf + * the final alpha component stored in the destination + *
Cdf + * the final raw color component stored in the destination + *
- *
* *

Preparing Inputs

* diff --git a/src/java.desktop/share/classes/java/awt/Component.java b/src/java.desktop/share/classes/java/awt/Component.java index da468fa1fae..6461f9bc24d 100644 --- a/src/java.desktop/share/classes/java/awt/Component.java +++ b/src/java.desktop/share/classes/java/awt/Component.java @@ -7247,28 +7247,24 @@ public abstract class Component implements ImageObserver, MenuContainer, * Recommended default values for a Component's focus traversal * keys * - * - * Identifier - * Meaning - * Default - * + * + * Identifier + * Meaning + * Default * * - * - * KeyboardFocusManager.FORWARD_TRAVERSAL_KEYS - * Normal forward keyboard traversal - * TAB on KEY_PRESSED, CTRL-TAB on KEY_PRESSED - * - * - * KeyboardFocusManager.BACKWARD_TRAVERSAL_KEYS - * Normal reverse keyboard traversal - * SHIFT-TAB on KEY_PRESSED, CTRL-SHIFT-TAB on KEY_PRESSED - * - * - * KeyboardFocusManager.UP_CYCLE_TRAVERSAL_KEYS - * Go up one focus traversal cycle - * none - * + * + * KeyboardFocusManager.FORWARD_TRAVERSAL_KEYS + * Normal forward keyboard traversal + * TAB on KEY_PRESSED, CTRL-TAB on KEY_PRESSED + * + * KeyboardFocusManager.BACKWARD_TRAVERSAL_KEYS + * Normal reverse keyboard traversal + * SHIFT-TAB on KEY_PRESSED, CTRL-SHIFT-TAB on KEY_PRESSED + * + * KeyboardFocusManager.UP_CYCLE_TRAVERSAL_KEYS + * Go up one focus traversal cycle + * none * * * diff --git a/src/java.desktop/share/classes/java/awt/Container.java b/src/java.desktop/share/classes/java/awt/Container.java index 2594b059192..c8e2943f74b 100644 --- a/src/java.desktop/share/classes/java/awt/Container.java +++ b/src/java.desktop/share/classes/java/awt/Container.java @@ -3069,33 +3069,28 @@ public class Container extends Component { * Recommended default values for a Container's focus traversal * keys * - * - * Identifier - * Meaning - * Default - * + * + * Identifier + * Meaning + * Default * * - * - * KeyboardFocusManager.FORWARD_TRAVERSAL_KEYS - * Normal forward keyboard traversal - * TAB on KEY_PRESSED, CTRL-TAB on KEY_PRESSED - * - * - * KeyboardFocusManager.BACKWARD_TRAVERSAL_KEYS - * Normal reverse keyboard traversal - * SHIFT-TAB on KEY_PRESSED, CTRL-SHIFT-TAB on KEY_PRESSED - * - * - * KeyboardFocusManager.UP_CYCLE_TRAVERSAL_KEYS - * Go up one focus traversal cycle - * none - * - * - * KeyboardFocusManager.DOWN_CYCLE_TRAVERSAL_KEYS - * Go down one focus traversal cycle - * none - * + * + * KeyboardFocusManager.FORWARD_TRAVERSAL_KEYS + * Normal forward keyboard traversal + * TAB on KEY_PRESSED, CTRL-TAB on KEY_PRESSED + * + * KeyboardFocusManager.BACKWARD_TRAVERSAL_KEYS + * Normal reverse keyboard traversal + * SHIFT-TAB on KEY_PRESSED, CTRL-SHIFT-TAB on KEY_PRESSED + * + * KeyboardFocusManager.UP_CYCLE_TRAVERSAL_KEYS + * Go up one focus traversal cycle + * none + * + * KeyboardFocusManager.DOWN_CYCLE_TRAVERSAL_KEYS + * Go down one focus traversal cycle + * none * * * diff --git a/src/java.desktop/share/classes/java/awt/EventQueue.java b/src/java.desktop/share/classes/java/awt/EventQueue.java index cb499396a87..c4847544507 100644 --- a/src/java.desktop/share/classes/java/awt/EventQueue.java +++ b/src/java.desktop/share/classes/java/awt/EventQueue.java @@ -680,33 +680,28 @@ public class EventQueue { * * * - * - * - * - * - * + * + * * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * + * + * + * + * + * *
Event types, source types, and dispatch methods
Event TypeSource TypeDispatched To
Event Type + * Source Type + * Dispatched To *
ActiveEventAnyevent.dispatch()
OtherComponentsource.dispatchEvent(AWTEvent)
OtherMenuComponentsource.dispatchEvent(AWTEvent)
OtherOtherNo action (ignored)
ActiveEvent + * Any + * event.dispatch() + *
Other + * Component + * source.dispatchEvent(AWTEvent) + *
Other + * MenuComponent + * source.dispatchEvent(AWTEvent) + *
Other + * Other + * No action (ignored) *
* diff --git a/src/java.desktop/share/classes/java/awt/KeyboardFocusManager.java b/src/java.desktop/share/classes/java/awt/KeyboardFocusManager.java index 564d64f56de..553f0963bef 100644 --- a/src/java.desktop/share/classes/java/awt/KeyboardFocusManager.java +++ b/src/java.desktop/share/classes/java/awt/KeyboardFocusManager.java @@ -1042,35 +1042,30 @@ public abstract class KeyboardFocusManager * * * - * - * - * - * - * + * + * * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * + * + * + * + * + * *
Recommended default values for focus traversal keys
IdentifierMeaningDefault
Identifier + * Meaning + * Default *
{@code KeyboardFocusManager.FORWARD_TRAVERSAL_KEYS}Normal forward keyboard traversal{@code TAB} on {@code KEY_PRESSED}, - * {@code CTRL-TAB} on {@code KEY_PRESSED}
{@code KeyboardFocusManager.BACKWARD_TRAVERSAL_KEYS}Normal reverse keyboard traversal{@code SHIFT-TAB} on {@code KEY_PRESSED}, - * {@code CTRL-SHIFT-TAB} on {@code KEY_PRESSED}
{@code KeyboardFocusManager.UP_CYCLE_TRAVERSAL_KEYS}Go up one focus traversal cyclenone
{@code KeyboardFocusManager.DOWN_CYCLE_TRAVERSAL_KEYS}Go down one focus traversal cyclenone
{@code KeyboardFocusManager.FORWARD_TRAVERSAL_KEYS} + * Normal forward keyboard traversal + * {@code TAB} on {@code KEY_PRESSED}, {@code CTRL-TAB} on + * {@code KEY_PRESSED} + *
{@code KeyboardFocusManager.BACKWARD_TRAVERSAL_KEYS} + * Normal reverse keyboard traversal + * {@code SHIFT-TAB} on {@code KEY_PRESSED}, {@code CTRL-SHIFT-TAB} + * on {@code KEY_PRESSED} + *
{@code KeyboardFocusManager.UP_CYCLE_TRAVERSAL_KEYS} + * Go up one focus traversal cycle + * none + *
{@code KeyboardFocusManager.DOWN_CYCLE_TRAVERSAL_KEYS} + * Go down one focus traversal cycle + * none *
* diff --git a/src/java.desktop/share/classes/java/awt/Scrollbar.java b/src/java.desktop/share/classes/java/awt/Scrollbar.java index c6b37805e29..b3cfcac2ae0 100644 --- a/src/java.desktop/share/classes/java/awt/Scrollbar.java +++ b/src/java.desktop/share/classes/java/awt/Scrollbar.java @@ -299,58 +299,44 @@ public class Scrollbar extends Component implements Adjustable, Accessible { * * * - * - * - * - * - * + * + * * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * + * + * + * + * + * + * + * + * *
Scrollbar default properties
PropertyDescriptionDefault Value
Property + * Description + * Default Value *
orientationindicates whether the scroll bar is vertical - *
or horizontal
{@code Scrollbar.VERTICAL}
valuevalue which controls the location - *
of the scroll bar's bubble
0
visible amountvisible amount of the scroll bar's range, - *
typically represented by the size of the - *
scroll bar's bubble
10
minimumminimum value of the scroll bar0
maximummaximum value of the scroll bar100
unit incrementamount the value changes when the - *
Line Up or Line Down key is pressed, - *
or when the end arrows of the scrollbar - *
are clicked
1
block incrementamount the value changes when the - *
Page Up or Page Down key is pressed, - *
or when the scrollbar track is clicked - *
on either side of the bubble
10
orientation + * indicates whether the scroll bar is vertical or horizontal + * {@code Scrollbar.VERTICAL} + *
value + * value which controls the location of the scroll bar's bubble + * 0 + *
visible amount + * visible amount of the scroll bar's range, typically represented + * by the size of the scroll bar's bubble + * 10 + *
minimum + * minimum value of the scroll bar + * 0 + *
maximum + * maximum value of the scroll bar + * 100 + *
unit increment + * amount the value changes when the Line Up or Line Down key is + * pressed, or when the end arrows of the scrollbar are clicked + * 1 + *
block increment + * amount the value changes when the Page Up or Page Down key is + * pressed, or when the scrollbar track is clicked
on either side of + * the bubble + *
10 *
* diff --git a/src/java.desktop/share/classes/java/awt/SystemTray.java b/src/java.desktop/share/classes/java/awt/SystemTray.java index c5c5507a2e9..a374f109044 100644 --- a/src/java.desktop/share/classes/java/awt/SystemTray.java +++ b/src/java.desktop/share/classes/java/awt/SystemTray.java @@ -371,28 +371,26 @@ public class SystemTray { * * * - * - * - * - * + * + * * - * - * - * - * - * - * - * - * + * + * + * *
SystemTray properties
PropertyDescription
Property + * Description *
{@code trayIcons}The {@code SystemTray}'s array of {@code TrayIcon} objects. - * The array is accessed via the {@link #getTrayIcons} method.
- * This property is changed when a tray icon is added to (or removed - * from) the system tray.
For example, this property is changed - * when the system tray becomes unavailable on the desktop
- * and the tray icons are automatically removed.
{@code systemTray}This property contains {@code SystemTray} instance when the system tray - * is available or {@code null} otherwise.
This property is changed - * when the system tray becomes available or unavailable on the desktop.
- * The property is accessed by the {@link #getSystemTray} method.
{@code trayIcons} + * The {@code SystemTray}'s array of {@code TrayIcon} objects. The + * array is accessed via the {@link #getTrayIcons} method. This property + * is changed when a tray icon is added to (or removed from) the system + * tray. For example, this property is changed when the system tray + * becomes unavailable on the desktop and the tray icons are + * automatically removed. + *
{@code systemTray} + * This property contains {@code SystemTray} instance when the + * system tray is available or {@code null} otherwise. This property is + * changed when the system tray becomes available or unavailable on the + * desktop. The property is accessed by the {@link #getSystemTray} + * method. *
*

diff --git a/src/java.desktop/share/classes/java/awt/font/NumericShaper.java b/src/java.desktop/share/classes/java/awt/font/NumericShaper.java index 76b390c065d..31e7011715a 100644 --- a/src/java.desktop/share/classes/java/awt/font/NumericShaper.java +++ b/src/java.desktop/share/classes/java/awt/font/NumericShaper.java @@ -108,39 +108,36 @@ import jdk.internal.misc.SharedSecrets; * * * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * + * + * + * + * + * + * + * + * + * *
NumericShaper constants precedence
Unicode Range{@code NumericShaper} ConstantsPrecedence
Arabic{@link NumericShaper#ARABIC NumericShaper.ARABIC}
- * {@link NumericShaper#EASTERN_ARABIC NumericShaper.EASTERN_ARABIC}
{@link NumericShaper#EASTERN_ARABIC NumericShaper.EASTERN_ARABIC}
{@link NumericShaper.Range#ARABIC}
- * {@link NumericShaper.Range#EASTERN_ARABIC}
{@link NumericShaper.Range#EASTERN_ARABIC}
Tai Tham{@link NumericShaper.Range#TAI_THAM_HORA}
- * {@link NumericShaper.Range#TAI_THAM_THAM}
{@link NumericShaper.Range#TAI_THAM_THAM}
Unicode Range + * {@code NumericShaper} Constants + * Precedence + *
Arabic + * {@link NumericShaper#ARABIC NumericShaper.ARABIC} + *
+ * {@link NumericShaper#EASTERN_ARABIC NumericShaper.EASTERN_ARABIC} + *
{@link NumericShaper#EASTERN_ARABIC NumericShaper.EASTERN_ARABIC} + *
{@link NumericShaper.Range#ARABIC} + *
+ * {@link NumericShaper.Range#EASTERN_ARABIC} + *
{@link NumericShaper.Range#EASTERN_ARABIC} + *
Tai Tham + * {@link NumericShaper.Range#TAI_THAM_HORA} + *
+ * {@link NumericShaper.Range#TAI_THAM_THAM} + *
{@link NumericShaper.Range#TAI_THAM_THAM} + *
* * @since 1.4 */ - public final class NumericShaper implements java.io.Serializable { // For access from java.text.Bidi diff --git a/src/java.desktop/share/classes/java/awt/font/TextAttribute.java b/src/java.desktop/share/classes/java/awt/font/TextAttribute.java index 9f27573e21d..d357ff974a4 100644 --- a/src/java.desktop/share/classes/java/awt/font/TextAttribute.java +++ b/src/java.desktop/share/classes/java/awt/font/TextAttribute.java @@ -96,159 +96,141 @@ import jdk.internal.misc.SharedSecrets; * * *

Summary of attributes

- * - * + * + *
Key, value type, principal constants, and - * default value behavior of all TextAttributes
+ * * - * - * - * - * - * - * + * + * * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * * *
Key, value type, principal constants, and default value behavior of + * all TextAttributes
KeyValue TypePrincipal ConstantsDefault Value
Key + * Value Type + * Principal Constants + * Default Value *
{@link #FAMILY}StringSee Font {@link java.awt.Font#DIALOG DIALOG}, - * {@link java.awt.Font#DIALOG_INPUT DIALOG_INPUT},
{@link java.awt.Font#SERIF SERIF}, - * {@link java.awt.Font#SANS_SERIF SANS_SERIF}, and {@link java.awt.Font#MONOSPACED MONOSPACED}. - *
"Default" (use platform default)
{@link #WEIGHT}NumberWEIGHT_REGULAR, WEIGHT_BOLDWEIGHT_REGULAR
{@link #WIDTH}NumberWIDTH_CONDENSED, WIDTH_REGULAR,
WIDTH_EXTENDED
WIDTH_REGULAR
{@link #POSTURE}NumberPOSTURE_REGULAR, POSTURE_OBLIQUEPOSTURE_REGULAR
{@link #SIZE}Numbernone12.0
{@link #TRANSFORM}{@link TransformAttribute}See TransformAttribute {@link TransformAttribute#IDENTITY IDENTITY}TransformAttribute.IDENTITY
{@link #SUPERSCRIPT}IntegerSUPERSCRIPT_SUPER, SUPERSCRIPT_SUB0 (use the standard glyphs and metrics)
{@link #FONT}{@link java.awt.Font}nonenull (do not override font resolution)
{@link #CHAR_REPLACEMENT}{@link GraphicAttribute}nonenull (draw text using font glyphs)
{@link #FOREGROUND}{@link java.awt.Paint}nonenull (use current graphics paint)
{@link #BACKGROUND}{@link java.awt.Paint}nonenull (do not render background)
{@link #UNDERLINE}IntegerUNDERLINE_ON-1 (do not render underline)
{@link #STRIKETHROUGH}BooleanSTRIKETHROUGH_ONfalse (do not render strikethrough)
{@link #RUN_DIRECTION}BooleanRUN_DIRECTION_LTR
RUN_DIRECTION_RTL
null (use {@link java.text.Bidi} standard default)
{@link #BIDI_EMBEDDING}Integernone0 (use base line direction)
{@link #JUSTIFICATION}NumberJUSTIFICATION_FULLJUSTIFICATION_FULL
{@link #INPUT_METHOD_HIGHLIGHT}{@link java.awt.im.InputMethodHighlight},
{@link java.text.Annotation}
(see class)null (do not apply input highlighting)
{@link #INPUT_METHOD_UNDERLINE}IntegerUNDERLINE_LOW_ONE_PIXEL,
UNDERLINE_LOW_TWO_PIXEL
-1 (do not render underline)
{@link #SWAP_COLORS}BooleanSWAP_COLORS_ONfalse (do not swap colors)
{@link #NUMERIC_SHAPING}{@link java.awt.font.NumericShaper}nonenull (do not shape digits)
{@link #KERNING}IntegerKERNING_ON0 (do not request kerning)
{@link #LIGATURES}IntegerLIGATURES_ON0 (do not form optional ligatures)
{@link #TRACKING}NumberTRACKING_LOOSE, TRACKING_TIGHT0 (do not add tracking)
{@link #FAMILY} + * String + * See Font {@link java.awt.Font#DIALOG DIALOG}, + * {@link java.awt.Font#DIALOG_INPUT DIALOG_INPUT}, + *
+ * {@link java.awt.Font#SERIF SERIF}, + * {@link java.awt.Font#SANS_SERIF SANS_SERIF}, and + * {@link java.awt.Font#MONOSPACED MONOSPACED}. + *
"Default" (use platform default) + *
{@link #WEIGHT} + * Number + * WEIGHT_REGULAR, WEIGHT_BOLD + * WEIGHT_REGULAR + *
{@link #WIDTH} + * Number + * WIDTH_CONDENSED, WIDTH_REGULAR,
WIDTH_EXTENDED + *
WIDTH_REGULAR + *
{@link #POSTURE} + * Number + * POSTURE_REGULAR, POSTURE_OBLIQUE + * POSTURE_REGULAR + *
{@link #SIZE} + * Number + * none + * 12.0 + *
{@link #TRANSFORM} + * {@link TransformAttribute} + * See TransformAttribute {@link TransformAttribute#IDENTITY IDENTITY} + * TransformAttribute.IDENTITY + *
{@link #SUPERSCRIPT} + * Integer + * SUPERSCRIPT_SUPER, SUPERSCRIPT_SUB + * 0 (use the standard glyphs and metrics) + *
{@link #FONT} + * {@link java.awt.Font} + * none + * null (do not override font resolution) + *
{@link #CHAR_REPLACEMENT} + * {@link GraphicAttribute} + * none + * null (draw text using font glyphs) + *
{@link #FOREGROUND} + * {@link java.awt.Paint} + * none + * null (use current graphics paint) + *
{@link #BACKGROUND} + * {@link java.awt.Paint} + * none + * null (do not render background) + *
{@link #UNDERLINE} + * Integer + * UNDERLINE_ON + * -1 (do not render underline) + *
{@link #STRIKETHROUGH} + * Boolean + * STRIKETHROUGH_ON + * false (do not render strikethrough) + *
{@link #RUN_DIRECTION} + * Boolean + * RUN_DIRECTION_LTR
RUN_DIRECTION_RTL + *
null (use {@link java.text.Bidi} standard default) + *
{@link #BIDI_EMBEDDING} + * Integer + * none + * 0 (use base line direction) + *
{@link #JUSTIFICATION} + * Number + * JUSTIFICATION_FULL + * JUSTIFICATION_FULL + *
{@link #INPUT_METHOD_HIGHLIGHT} + * {@link java.awt.im.InputMethodHighlight}, + *
+ * {@link java.text.Annotation} + *
(see class) + * null (do not apply input highlighting) + *
{@link #INPUT_METHOD_UNDERLINE} + * Integer + * UNDERLINE_LOW_ONE_PIXEL,
UNDERLINE_LOW_TWO_PIXEL + *
-1 (do not render underline) + *
{@link #SWAP_COLORS} + * Boolean + * SWAP_COLORS_ON + * false (do not swap colors) + *
{@link #NUMERIC_SHAPING} + * {@link java.awt.font.NumericShaper} + * none + * null (do not shape digits) + *
{@link #KERNING} + * Integer + * KERNING_ON + * 0 (do not request kerning) + *
{@link #LIGATURES} + * Integer + * LIGATURES_ON + * 0 (do not form optional ligatures) + *
{@link #TRACKING} + * Number + * TRACKING_LOOSE, TRACKING_TIGHT + * 0 (do not add tracking) + *
* diff --git a/src/java.desktop/share/classes/javax/imageio/package-info.java b/src/java.desktop/share/classes/javax/imageio/package-info.java index 342a6afc146..976f40e6ec5 100644 --- a/src/java.desktop/share/classes/javax/imageio/package-info.java +++ b/src/java.desktop/share/classes/javax/imageio/package-info.java @@ -39,84 +39,77 @@ *

* All implementations of javax.imageio provide the following standard image * format plug-ins: - *

- * - * - * - * - * * + *
 ReadingWritingNotesMetadata
+ * + * + * + * + * * - * - * - * - * - * - * - * - * + * + * - * - * - * - * - * - * - * + * + * - * - * - * - * - * - * - * + * + * - * - * - * - * - * - * - * + * + * - * - * - * - * - * - * - * + * + * - * - * - * - * - * - * + * + * *
Standard image format plug-ins
Image format + * Reading + * Writing + * Notes + * Metadata + *
- * BMPyesyesnoneBMP - * metadata format
+ * BMP + * yes + * yes + * none + * BMP + * metadata format * - *
GIF - * yesyesGIF plug-in notes - * GIF - * metadata format
+ * GIF + * yes + * yes + * GIF plug-in notes + * GIF + * metadata format * - *
JPEGyesyesnone - * JPEG metadata format
JPEG + * yes + * yes + * none + * + * JPEG metadata format * - *
PNGyesyesnonePNG - * metadata format
PNG + * yes + * yes + * none + * PNG + * metadata format * - *
- * TIFFyesyes - * TIFF plug-in notes - * TIFF metadata format
+ * + * TIFF + * yes + * yes + * + * TIFF plug-in + * notes + * + * TIFF + * metadata format * - *
- * WBMPyesyesnone - * WBMP metadata format
+ * + * WBMP + * yes + * yes + * none + * + * WBMP metadata format + *
- *
- *
- *
- *
* *

Standard Plug-in Notes

* diff --git a/src/java.desktop/share/classes/javax/imageio/plugins/bmp/BMPImageWriteParam.java b/src/java.desktop/share/classes/javax/imageio/plugins/bmp/BMPImageWriteParam.java index 741a51b866d..8c4b7c40855 100644 --- a/src/java.desktop/share/classes/javax/imageio/plugins/bmp/BMPImageWriteParam.java +++ b/src/java.desktop/share/classes/javax/imageio/plugins/bmp/BMPImageWriteParam.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2017, Oracle and/or its affiliates. All rights reserved. * 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,13 +54,32 @@ import com.sun.imageio.plugins.bmp.BMPCompressionTypes; * listed in the following * table: * - * - * - * - * - * - * - * + *
Compression Types
Type String Description Image Types
BI_RGB Uncompressed RLE {@literal <= } 8-bits/sample
BI_RLE8 8-bit Run Length Encoding {@literal <=} 8-bits/sample
BI_RLE4 4-bit Run Length Encoding {@literal <=} 4-bits/sample
BI_BITFIELDS Packed data 16 or 32 bits/sample
+ * + * + * + * + * + * + * + * + * + * *
Compression Types
Type String + * Description + * Image Types + *
BI_RGB + * Uncompressed RLE + * {@literal <= } 8-bits/sample + *
BI_RLE8 + * 8-bit Run Length Encoding + * {@literal <=} 8-bits/sample + *
BI_RLE4 + * 4-bit Run Length Encoding + * {@literal <=} 4-bits/sample + *
BI_BITFIELDS + * Packed data + * 16 or 32 bits/sample + *
*/ public class BMPImageWriteParam extends ImageWriteParam { diff --git a/src/java.desktop/share/classes/javax/imageio/plugins/tiff/TIFFField.java b/src/java.desktop/share/classes/javax/imageio/plugins/tiff/TIFFField.java index abc041abca0..3ed11d20753 100644 --- a/src/java.desktop/share/classes/javax/imageio/plugins/tiff/TIFFField.java +++ b/src/java.desktop/share/classes/javax/imageio/plugins/tiff/TIFFField.java @@ -40,221 +40,83 @@ import com.sun.imageio.plugins.tiff.TIFFIFD; * TIFF data types are referred to by Java constants and mapped internally * onto Java language data types and type names as follows: * - *
- *
- * + *
* - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * *
TIFF Data Type to Java Data Type Mapping
- * TIFF Data Type - * - * Java Constant - * - * Java Data Type - * - * Java Type Name - *
- * {@code BYTE} - * - * {@link TIFFTag#TIFF_BYTE} - * - * {@code byte} - * - * {@code "Byte"} - *
- * {@code ASCII} - * - * {@link TIFFTag#TIFF_ASCII} - * - * {@code String} - * - * {@code "Ascii"} - *
- * {@code SHORT} - * - * {@link TIFFTag#TIFF_SHORT} - * - * {@code char} - * - * {@code "Short"} - *
- * {@code LONG} - * - * {@link TIFFTag#TIFF_LONG} - * - * {@code long} - * - * {@code "Long"} - *
- * {@code RATIONAL} - * - * {@link TIFFTag#TIFF_RATIONAL} - * - * {@code long[2]} {numerator, denominator} - * - * {@code "Rational"} - *
- * {@code SBYTE} - * - * {@link TIFFTag#TIFF_SBYTE} - * - * {@code byte} - * - * {@code "SByte"} - *
- * {@code UNDEFINED} - * - * {@link TIFFTag#TIFF_UNDEFINED} - * - * {@code byte} - * - * {@code "Undefined"} - *
- * {@code SSHORT} - * - * {@link TIFFTag#TIFF_SSHORT} - * - * {@code short} - * - * {@code "SShort"} - *
- * {@code SLONG} - * - * {@link TIFFTag#TIFF_SLONG} - * - * {@code int} - * - * {@code "SLong"} - *
- * {@code SRATIONAL} - * - * {@link TIFFTag#TIFF_SRATIONAL} - * - * {@code int[2]} {numerator, denominator} - * - * {@code "SRational"} - *
- * {@code FLOAT} - * - * {@link TIFFTag#TIFF_FLOAT} - * - * {@code float} - * - * {@code "Float"} - *
- * {@code DOUBLE} - * - * {@link TIFFTag#TIFF_DOUBLE} - * - * {@code double} - * - * {@code "Double"} - *
- * {@code IFD} - * - * {@link TIFFTag#TIFF_IFD_POINTER} - * - * {@code long} - * - * {@code "IFDPointer"} - *
TIFF Data Type + * Java Constant + * Java Data Type + * Java Type Name + *
{@code BYTE} + * {@link TIFFTag#TIFF_BYTE} + * {@code byte} + * {@code "Byte"} + *
{@code ASCII} + * {@link TIFFTag#TIFF_ASCII} + * {@code String} + * {@code "Ascii"} + *
{@code SHORT} + * {@link TIFFTag#TIFF_SHORT} + * {@code char} + * {@code "Short"} + *
{@code LONG} + * {@link TIFFTag#TIFF_LONG} + * {@code long} + * {@code "Long"} + *
{@code RATIONAL} + * {@link TIFFTag#TIFF_RATIONAL} + * {@code long[2]} {numerator, denominator} + * {@code "Rational"} + *
{@code SBYTE} + * {@link TIFFTag#TIFF_SBYTE} + * {@code byte} + * {@code "SByte"} + *
{@code UNDEFINED} + * {@link TIFFTag#TIFF_UNDEFINED} + * {@code byte} + * {@code "Undefined"} + *
{@code SSHORT} + * {@link TIFFTag#TIFF_SSHORT} + * {@code short} + * {@code "SShort"} + *
{@code SLONG} + * {@link TIFFTag#TIFF_SLONG} + * {@code int} + * {@code "SLong"} + *
{@code SRATIONAL} + * {@link TIFFTag#TIFF_SRATIONAL} + * {@code int[2]} {numerator, denominator} + * {@code "SRational"} + *
{@code FLOAT} + * {@link TIFFTag#TIFF_FLOAT} + * {@code float} + * {@code "Float"} + *
{@code DOUBLE} + * {@link TIFFTag#TIFF_DOUBLE} + * {@code double} + * {@code "Double"} + *
{@code IFD} + * {@link TIFFTag#TIFF_IFD_POINTER} + * {@code long} + * {@code "IFDPointer"} + *
* * @since 9 diff --git a/src/java.desktop/share/classes/javax/print/DocFlavor.java b/src/java.desktop/share/classes/javax/print/DocFlavor.java index 5c48cf29011..4247fe96b0c 100644 --- a/src/java.desktop/share/classes/javax/print/DocFlavor.java +++ b/src/java.desktop/share/classes/javax/print/DocFlavor.java @@ -175,21 +175,21 @@ import java.io.Serializable; * MIME-Types and their descriptions * * - * MIME-Type - * Description + * MIME-Type + * Description * * * - * {@code "text/plain"} + * {@code "text/plain"} * Plain text in the default character set (US-ASCII) * - * "text/plain; charset=xxx" + * "text/plain; charset=xxx" * Plain text in character set xxx * - * {@code "text/html"} + * {@code "text/html"} * HyperText Markup Language in the default character set (US-ASCII) * - * "text/html; charset=xxx" + * "text/html; charset=xxx" * HyperText Markup Language in character set xxx * * @@ -201,18 +201,18 @@ import java.io.Serializable; * MIME-Types and their descriptions * * - * MIME-Type - * Description + * MIME-Type + * Description * * * - * {@code "application/pdf"} + * {@code "application/pdf"} * Portable Document Format document * - * {@code "application/postscript"} + * {@code "application/postscript"} * PostScript document * - * {@code "application/vnd.hp-PCL"} + * {@code "application/vnd.hp-PCL"} * Printer Control Language document * * @@ -223,18 +223,18 @@ import java.io.Serializable; * MIME-Types and their descriptions * * - * MIME-Type - * Description + * MIME-Type + * Description * * * - * {@code "image/gif"} + * {@code "image/gif"} * Graphics Interchange Format image * - * {@code "image/jpeg"} + * {@code "image/jpeg"} * Joint Photographic Experts Group image * - * {@code "image/png"} + * {@code "image/png"} * Portable Network Graphics image * * @@ -245,12 +245,12 @@ import java.io.Serializable; * MIME-Types and their descriptions * * - * MIME-Type - * Description + * MIME-Type + * Description * * * - * {@code "application/octet-stream"} + * {@code "application/octet-stream"} * The print data format is unspecified (just an octet stream) * * diff --git a/src/java.desktop/share/classes/javax/print/attribute/standard/Chromaticity.java b/src/java.desktop/share/classes/javax/print/attribute/standard/Chromaticity.java index 68f6e49eb81..efb79172df9 100644 --- a/src/java.desktop/share/classes/javax/print/attribute/standard/Chromaticity.java +++ b/src/java.desktop/share/classes/javax/print/attribute/standard/Chromaticity.java @@ -42,22 +42,23 @@ import javax.print.attribute.PrintRequestAttribute; * The table below shows the effects of specifying a Chromaticity attribute of * {@link #MONOCHROME MONOCHROME} or {@link #COLOR COLOR} for a monochrome or * color document. + * * * * * - * * * - * - * diff --git a/src/java.desktop/share/classes/javax/print/attribute/standard/JobKOctets.java b/src/java.desktop/share/classes/javax/print/attribute/standard/JobKOctets.java index eba1e3c231f..5e138f292a0 100644 --- a/src/java.desktop/share/classes/javax/print/attribute/standard/JobKOctets.java +++ b/src/java.desktop/share/classes/javax/print/attribute/standard/JobKOctets.java @@ -69,40 +69,41 @@ import javax.print.attribute.PrintRequestAttribute; * The size of a doc is computed based on the print data representation class as * specified by the doc's {@link javax.print.DocFlavor DocFlavor}, as shown in * the table below. + * *
Shows effects of specifying {@code MONOCHROME} or {@code COLOR} * Chromaticity attributes
Chromaticity
Attribute - *
Effect on
Monochrome Document - *
Effect on
Color Document + *
Chromaticity
Attribute + *
Effect on
Monochrome Document + *
Effect on
Color Document *
{@link #MONOCHROME MONOCHROME} + * {@link #MONOCHROME MONOCHROME} * Printed as is, in monochrome * Printed in monochrome, with colors converted to shades of gray *
{@link #COLOR COLOR} + * {@link #COLOR COLOR} * Printed as is, in monochrome * Printed as is, in color *
* * * - * * * - * - * - * - * - * - * - * - * - * *
Table showing computation of doc sizes
Representation Class - * Document Size + * Representation Class + * Document Size *
{@code byte[]} + * {@code byte[]} * Length of the byte array *
{@code java.io.InputStream} + * {@code java.io.InputStream} * Number of bytes read from the stream *
{@code char[]} + * {@code char[]} * Length of the character array x 2 *
{@code java.lang.String} + * {@code java.lang.String} * Length of the string x 2 *
{@code java.io.Reader} + * {@code java.io.Reader} * Number of characters read from the stream x 2 *
{@code java.net.URL} + * {@code java.net.URL} * Number of bytes read from the file at the given {@code URL} address *
{@code java.awt.image.renderable.RenderableImage} + * {@code java.awt.image.renderable.RenderableImage} * Implementation dependent* *
{@code java.awt.print.Printable} + * {@code java.awt.print.Printable} * Implementation dependent* *
{@code java.awt.print.Pageable} + * {@code java.awt.print.Pageable} * Implementation dependent* *
diff --git a/src/java.desktop/share/classes/javax/print/attribute/standard/package-info.java b/src/java.desktop/share/classes/javax/print/attribute/standard/package-info.java index 9ded7f55cf2..3f386b8560e 100644 --- a/src/java.desktop/share/classes/javax/print/attribute/standard/package-info.java +++ b/src/java.desktop/share/classes/javax/print/attribute/standard/package-info.java @@ -150,412 +150,437 @@ * attribute, the column marked "SupportedValuesAttribute" lists the * supported-values attribute class, if any, with which a print service * indicates the supported values for that attribute category. - * - * - * * * - * * * - * - * - * - * *
Attribute Class - * Doc
Attribute - *
Print
Request
Attribute - *
Print
Job
Attribute - *
Print
Service
Attribute - *
SupportedValuesAttribute + * + * + * + * * - * + * + * + * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * *
Lists all printing attributes as described above
Compression + * Attribute Class + * Doc
Attribute + *
Print
Request
Attribute + *
Print
Job
Attribute + *
Print
Service
Attribute + *
SupportedValuesAttribute + *
Compression * X *   *   *   *   *
DocumentName + * DocumentName * X *   *   *   *   *
Chromaticity + * Chromaticity * X * X * X *   *   *
Copies + * Copies *   * X * X *   * CopiesSupported *
Finishings + * Finishings * X * X * X *   *   *
JobHoldUntil + * JobHoldUntil *   * X * X *   *   *
JobImpressions + * JobImpressions *   * X * X *   * JobImpressionsSupported *
JobKOctets + * JobKOctets *   * X * X *   * JobKOctetsSupported *
JobMediaSheets + * JobMediaSheets *   * X * X *   * JobMediaSheetsSupported *
JobName + * JobName *   * X * X *   *   *
JobPriority + * JobPriority *   * X * X *   * JobPrioritySupported *
JobSheets + * JobSheets *   * X * X *   *   *
Media + * Media * X * X * X *   *   *
MediaSize + * MediaSize *   *   *   *   *   *
MultipleDocumentHandling + * + * MultipleDocumentHandling *   * X * X *   *   *
NumberUp + * NumberUp * X * X * X *   * NumberUpSupported *
OrientationRequested + * + * OrientationRequested * X * X * X *   *   *
PageRanges + * PageRanges * X * X * X *   *   *
PresentationDirection + * + * PresentationDirection * X * X * X *   *   *
PrinterResolution + * PrinterResolution * X * X * X *   *   *
PrintQuality + * PrintQuality * X * X * X *   *   *
RequestingUserName + * RequestingUserName *   * X * X *   *   *
SheetCollate + * SheetCollate * X * X * X *   *   *
Sides + * Sides * X * X * X *   *   *
DateTimeAtCompleted + * + * DateTimeAtCompleted *   *   * X *   *   *
DateTimeAtCreation + * DateTimeAtCreation *   *   * X *   *   *
DateTimeAtProcessing + * + * DateTimeAtProcessing *   *   * X *   *   *
JobImpressionsCompleted + * + * JobImpressionsCompleted *   *   * X *   *   *
JobKOctetsProcessed + * + * JobKOctetsProcessed *   *   * X *   *   *
JobMediaSheetsCompleted + * + * JobMediaSheetsCompleted *   *   * X *   *   *
JobMessageFromOperator + * + * JobMessageFromOperator *   *   * X *   *   *
JobOriginatingUserName + * + * JobOriginatingUserName *   *   * X *   *   *
JobState + * JobState *   *   * X *   *   *
JobStateReasons
- * Contains zero or more -- + *
JobStateReasons + *
+ * Contains zero or more -- *
  *   * X *   *   *
-- JobStateReason + * -- JobStateReason *   *   *   *   *   *
NumberOfDocuments + * NumberOfDocuments *   *   * X *   *   *
NumberOfInterveningJobs + * + * NumberOfInterveningJobs *   *   * X *   *   *
OutputDeviceAssigned + * + * OutputDeviceAssigned *   *   * X *   *   *
ColorSupported + * ColorSupported *   *   *   * X *   *
PagesPerMinute + * PagesPerMinute *   *   *   * X *   *
PagesPerMinuteColor + * + * PagesPerMinuteColor *   *   *   * X *   *
PDLOverrideSupported + * + * PDLOverrideSupported *   *   *   * X *   *
PrinterIsAcceptingJobs + * + * PrinterIsAcceptingJobs *   *   *   * X *   *
PrinterInfo + * PrinterInfo *   *   *   * X *   *
PrinterLocation + * PrinterLocation *   *   *   * X *   *
- * PrinterMessageFromOperator + * + * PrinterMessageFromOperator *   *   *   * X *   *
PrinterMakeAndModel + * + * PrinterMakeAndModel *   *   *   * X *   *
PrinterMoreInfo + * PrinterMoreInfo *   *   *   * X *   *
- * PrinterMoreInfoManufacturer + * + * PrinterMoreInfoManufacturer *   *   *   * X *   *
PrinterName + * PrinterName *   *   *   * X *   *
PrinterState + * PrinterState *   *   *   * X *   *
PrinterStateReasons
- * Contains zero or more -- + *
+ * PrinterStateReasons + *
+ * Contains zero or more -- *
  *   *   * X *   *
-- PrinterStateReason + * -- + * PrinterStateReason *   *   *   *   *   *
-- Severity + * -- Severity *   *   *   *   *   *
QueuedJobCount + * QueuedJobCount *   *   *   * X *   *
- * ReferenceUriSchemesSupported + * + * ReferenceUriSchemesSupported *   *   *   *   *   + *
*

* Please note: In the {@code javax.print} APIs, a {@code null} reference diff --git a/src/java.desktop/share/classes/javax/sound/midi/MidiFileFormat.java b/src/java.desktop/share/classes/javax/sound/midi/MidiFileFormat.java index f64f2260da6..1230171fae5 100644 --- a/src/java.desktop/share/classes/javax/sound/midi/MidiFileFormat.java +++ b/src/java.desktop/share/classes/javax/sound/midi/MidiFileFormat.java @@ -43,32 +43,36 @@ import java.util.Map; * The following table lists some common properties that should be used in * implementations: * - * + *
* + * * - * + * * - * - * - * - * - * *
MIDI File Format Properties
Property key - * Value type - * Description + * Property key + * Value type + * Description + *
"author" + * "author" * {@link String String} * name of the author of this file *
"title" + * "title" * {@link String String} * title of this file *
"copyright" + * "copyright" * {@link String String} * copyright message *
"date" + * "date" * {@link java.util.Date Date} * date of the recording or release *
"comment" + * "comment" * {@link String String} * an arbitrary text + *
* * @author Kara Kytle diff --git a/src/java.desktop/share/classes/javax/sound/midi/MidiSystem.java b/src/java.desktop/share/classes/javax/sound/midi/MidiSystem.java index 686840ff8a4..9a928dcbdc0 100644 --- a/src/java.desktop/share/classes/javax/sound/midi/MidiSystem.java +++ b/src/java.desktop/share/classes/javax/sound/midi/MidiSystem.java @@ -78,32 +78,32 @@ import com.sun.media.sound.ReferenceCountingDevice; *

MIDI System Property Keys
Property Key - * Interface - * Affected Method + * Property Key + * Interface + * Affected Method *
{@code javax.sound.midi.Receiver} + * {@code javax.sound.midi.Receiver} * {@link Receiver} * {@link #getReceiver} *
{@code javax.sound.midi.Sequencer} + * {@code javax.sound.midi.Sequencer} * {@link Sequencer} * {@link #getSequencer} *
{@code javax.sound.midi.Synthesizer} + * {@code javax.sound.midi.Synthesizer} * {@link Synthesizer} * {@link #getSynthesizer} *
{@code javax.sound.midi.Transmitter} + * {@code javax.sound.midi.Transmitter} * {@link Transmitter} * {@link #getTransmitter} *
* * The property value consists of the provider class name and the device name, - * separated by the hash mark ("#"). The provider class name is the + * separated by the hash mark ("#"). The provider class name is the * fully-qualified name of a concrete * {@link MidiDeviceProvider MIDI device provider} class. The device name is * matched against the {@code String} returned by the {@code getName} method of diff --git a/src/java.desktop/share/classes/javax/sound/sampled/AudioFileFormat.java b/src/java.desktop/share/classes/javax/sound/sampled/AudioFileFormat.java index 64dc76d0a3a..38046059727 100644 --- a/src/java.desktop/share/classes/javax/sound/sampled/AudioFileFormat.java +++ b/src/java.desktop/share/classes/javax/sound/sampled/AudioFileFormat.java @@ -50,36 +50,40 @@ import java.util.Objects; * The following table lists some common properties that should be used in * implementations: * - * + *
* + * * - * + * * - * - * - * - * - * - * *
Audio File Format Properties
Property key - * Value type - * Description + * Property key + * Value type + * Description + *
"duration" + * "duration" * {@link Long Long} * playback duration of the file in microseconds *
"author" + * "author" * {@link String String} * name of the author of this file *
"title" + * "title" * {@link String String} * title of this file *
"copyright" + * "copyright" * {@link String String} * copyright message *
"date" + * "date" * {@link java.util.Date Date} * date of the recording or release *
"comment" + * "comment" * {@link String String} * an arbitrary text + *
* * @author David Rivas diff --git a/src/java.desktop/share/classes/javax/sound/sampled/AudioFormat.java b/src/java.desktop/share/classes/javax/sound/sampled/AudioFormat.java index f5d561f70fd..6f1e21ad7f7 100644 --- a/src/java.desktop/share/classes/javax/sound/sampled/AudioFormat.java +++ b/src/java.desktop/share/classes/javax/sound/sampled/AudioFormat.java @@ -94,21 +94,21 @@ import java.util.Objects; * Audio Format Properties * * - * Property key - * Value type - * Description + * Property key + * Value type + * Description * * * - * "bitrate" + * "bitrate" * {@link java.lang.Integer Integer} * average bit rate in bits per second * - * "vbr" + * "vbr" * {@link java.lang.Boolean Boolean} * {@code true}, if the file is encoded in variable bit rate (VBR) * - * "quality" + * "quality" * {@link java.lang.Integer Integer} * encoding/conversion quality, 1..100 * diff --git a/src/java.desktop/share/classes/javax/sound/sampled/AudioPermission.java b/src/java.desktop/share/classes/javax/sound/sampled/AudioPermission.java index d2dfa04edf1..00cea5bfd94 100644 --- a/src/java.desktop/share/classes/javax/sound/sampled/AudioPermission.java +++ b/src/java.desktop/share/classes/javax/sound/sampled/AudioPermission.java @@ -46,13 +46,13 @@ import java.security.BasicPermission; * risks * * - * Permission Target Name - * What the Permission Allows - * Risks of Allowing this Permission + * Permission Target Name + * What the Permission Allows + * Risks of Allowing this Permission * * * - * play + * play * Audio playback through the audio device or devices on the system. * Allows the application to obtain and manipulate lines and mixers for * audio playback (rendering). @@ -61,7 +61,7 @@ import java.security.BasicPermission; * audio being played on the system, or because manipulation of a mixer * affects the audio for all lines using that mixer. * - * record + * record * Audio recording through the audio device or devices on the system. * Allows the application to obtain and manipulate lines and mixers for * audio recording (capture). diff --git a/src/java.desktop/share/classes/javax/sound/sampled/AudioSystem.java b/src/java.desktop/share/classes/javax/sound/sampled/AudioSystem.java index 203c57bad5f..87936aeb155 100644 --- a/src/java.desktop/share/classes/javax/sound/sampled/AudioSystem.java +++ b/src/java.desktop/share/classes/javax/sound/sampled/AudioSystem.java @@ -75,32 +75,32 @@ import com.sun.media.sound.JDK13Services; * Audio System Property Keys * * - * Property Key - * Interface - * Affected Method(s) + * Property Key + * Interface + * Affected Method(s) * * * - * {@code javax.sound.sampled.Clip} + * {@code javax.sound.sampled.Clip} * {@link Clip} * {@link #getLine}, {@link #getClip} * - * {@code javax.sound.sampled.Port} + * {@code javax.sound.sampled.Port} * {@link Port} * {@link #getLine} * - * {@code javax.sound.sampled.SourceDataLine} + * {@code javax.sound.sampled.SourceDataLine} * {@link SourceDataLine} * {@link #getLine}, {@link #getSourceDataLine} * - * {@code javax.sound.sampled.TargetDataLine} + * {@code javax.sound.sampled.TargetDataLine} * {@link TargetDataLine} * {@link #getLine}, {@link #getTargetDataLine} * * * * The property value consists of the provider class name and the mixer name, - * separated by the hash mark ("#"). The provider class name is the + * separated by the hash mark ("#"). The provider class name is the * fully-qualified name of a concrete {@link MixerProvider mixer provider} * class. The mixer name is matched against the {@code String} returned by the * {@code getName} method of {@code Mixer.Info}. Either the class name, or the diff --git a/src/java.desktop/share/classes/javax/sound/sampled/ReverbType.java b/src/java.desktop/share/classes/javax/sound/sampled/ReverbType.java index cae8f052209..24cf21c90a3 100644 --- a/src/java.desktop/share/classes/javax/sound/sampled/ReverbType.java +++ b/src/java.desktop/share/classes/javax/sound/sampled/ReverbType.java @@ -75,44 +75,44 @@ package javax.sound.sampled; * early intensity, and early delay * * - * Type - * Decay Time (ms) - * Late Intensity (dB) - * Late Delay (ms) - * Early Intensity (dB) - * Early Delay(ms) + * Type + * Decay Time (ms) + * Late Intensity (dB) + * Late Delay (ms) + * Early Intensity (dB) + * Early Delay(ms) * * * - * Cavern + * Cavern * 2250 * -2.0 * 41.3 * -1.4 * 10.3 * - * Dungeon + * Dungeon * 1600 * -1.0 * 10.3 * -0.7 * 2.6 * - * Garage + * Garage * 900 * -6.0 * 14.7 * -4.0 * 3.9 * - * Acoustic Lab + * Acoustic Lab * 280 * -3.0 * 8.0 * -2.0 * 2.0 * - * Closet + * Closet * 150 * -10.0 * 2.5 diff --git a/src/java.desktop/share/classes/javax/swing/Action.java b/src/java.desktop/share/classes/javax/swing/Action.java index 05f8c667be3..4456218fbac 100644 --- a/src/java.desktop/share/classes/javax/swing/Action.java +++ b/src/java.desktop/share/classes/javax/swing/Action.java @@ -98,102 +98,88 @@ import java.beans.*; * Supported Action properties * * - * Component Property - * Components - * Action Key - * Notes + * Component Property + * Components + * Action Key + * Notes * * - * - * enabled - * All - * The isEnabled method - *   - * - * toolTipText - * All - * SHORT_DESCRIPTION - *   - * - * actionCommand - * All - * ACTION_COMMAND_KEY - *   - * - * mnemonic - * All buttons - * MNEMONIC_KEY - * A null value or Action results in the - * button's mnemonic property being set to - * '\0'. - * - * text - * All buttons - * NAME - * If you do not want the text of the button to mirror that - * of the Action, set the property - * hideActionText to true. If - * hideActionText is true, setting the - * Action changes the text of the button to - * null and any changes to NAME - * are ignored. hideActionText is useful for - * tool bar buttons that typically only show an Icon. - * JToolBar.add(Action) sets the property to - * true if the Action has a - * non-null value for LARGE_ICON_KEY or - * SMALL_ICON. - * - * displayedMnemonicIndex - * All buttons - * DISPLAYED_MNEMONIC_INDEX_KEY - * If the value of DISPLAYED_MNEMONIC_INDEX_KEY is - * beyond the bounds of the text, it is ignored. When - * setAction is called, if the value from the - * Action is null, the displayed - * mnemonic index is not updated. In any subsequent changes to - * DISPLAYED_MNEMONIC_INDEX_KEY, null - * is treated as -1. - * - * icon - * All buttons except of JCheckBox, - * JToggleButton and JRadioButton. - * either LARGE_ICON_KEY or - * SMALL_ICON - * The JMenuItem subclasses only use - * SMALL_ICON. All other buttons will use - * LARGE_ICON_KEY; if the value is null they - * use SMALL_ICON. - * - * accelerator - * All JMenuItem subclasses, with the exception of - * JMenu. - * ACCELERATOR_KEY - *   - * - * selected - * JToggleButton, JCheckBox, - * JRadioButton, JCheckBoxMenuItem and - * JRadioButtonMenuItem - * SELECTED_KEY - * Components that honor this property only use - * the value if it is {@code non-null}. For example, if - * you set an {@code Action} that has a {@code null} - * value for {@code SELECTED_KEY} on a {@code JToggleButton}, the - * {@code JToggleButton} will not update it's selected state in - * any way. Similarly, any time the {@code JToggleButton}'s - * selected state changes it will only set the value back on - * the {@code Action} if the {@code Action} has a {@code non-null} - * value for {@code SELECTED_KEY}. - *
- * Components that honor this property keep their selected state - * in sync with this property. When the same {@code Action} is used - * with multiple components, all the components keep their selected - * state in sync with this property. Mutually exclusive - * buttons, such as {@code JToggleButton}s in a {@code ButtonGroup}, - * force only one of the buttons to be selected. As such, do not - * use the same {@code Action} that defines a value for the - * {@code SELECTED_KEY} property with multiple mutually - * exclusive buttons. + * + * {@code enabled} + * All + * The {@code isEnabled} method + *   + * + * {@code toolTipText} + * All + * {@code SHORT_DESCRIPTION} + *   + * + * {@code actionCommand} + * All + * {@code ACTION_COMMAND_KEY} + *   + * + * {@code mnemonic} + * All buttons + * {@code MNEMONIC_KEY} + * A {@code null} value or {@code Action} results in the button's + * {@code mnemonic} property being set to {@code '\0'}. + * + * {@code text} + * All buttons + * {@code NAME} + * If you do not want the text of the button to mirror that of the + * {@code Action}, set the property {@code hideActionText} to {@code true}. + * If {@code hideActionText} is {@code true}, setting the {@code Action} + * changes the text of the button to {@code null} and any changes to + * {@code NAME} are ignored. {@code hideActionText} is useful for tool bar + * buttons that typically only show an {@code Icon}. + * {@code JToolBar.add(Action)} sets the property to {@code true} if the + * {@code Action} has a non-{@code null} value for {@code LARGE_ICON_KEY} or + * {@code SMALL_ICON}. + * + * {@code displayedMnemonicIndex} + * All buttons + * {@code DISPLAYED_MNEMONIC_INDEX_KEY} + * If the value of {@code DISPLAYED_MNEMONIC_INDEX_KEY} is beyond the + * bounds of the text, it is ignored. When {@code setAction} is called, if + * the value from the {@code Action} is {@code null}, the displayed mnemonic + * index is not updated. In any subsequent changes to + * {@code DISPLAYED_MNEMONIC_INDEX_KEY}, {@code null} is treated as -1. + * + * {@code icon} + * All buttons except of {@code JCheckBox}, {@code JToggleButton} and + * {@code JRadioButton}. + * either {@code LARGE_ICON_KEY} or {@code SMALL_ICON} + * The {@code JMenuItem} subclasses only use {@code SMALL_ICON}. All + * other buttons will use {@code LARGE_ICON_KEY}; if the value is + * {@code null} they use {@code SMALL_ICON}. + * + * {@code accelerator} + * All {@code JMenuItem} subclasses, with the exception of {@code JMenu}. + * {@code ACCELERATOR_KEY} + *   + * + * {@code selected} + * {@code JToggleButton}, {@code JCheckBox}, {@code JRadioButton}, + * {@code JCheckBoxMenuItem} and {@code JRadioButtonMenuItem} + * {@code SELECTED_KEY} + * Components that honor this property only use the value if it is + * {@code non-null}. For example, if you set an {@code Action} that has a + * {@code null} value for {@code SELECTED_KEY} on a {@code JToggleButton}, + * the {@code JToggleButton} will not update it's selected state in any way. + * Similarly, any time the {@code JToggleButton}'s selected state changes it + * will only set the value back on the {@code Action} if the {@code Action} + * has a {@code non-null} value for {@code SELECTED_KEY}. + *
+ * Components that honor this property keep their selected state in sync with + * this property. When the same {@code Action} is used with multiple + * components, all the components keep their selected state in sync with this + * property. Mutually exclusive buttons, such as {@code JToggleButton}s in a + * {@code ButtonGroup}, force only one of the buttons to be selected. As + * such, do not use the same {@code Action} that defines a value for the + * {@code SELECTED_KEY} property with multiple mutually exclusive buttons. * * *

diff --git a/src/java.desktop/share/classes/javax/swing/JFormattedTextField.java b/src/java.desktop/share/classes/javax/swing/JFormattedTextField.java index 41706345cd9..e511fb16630 100644 --- a/src/java.desktop/share/classes/javax/swing/JFormattedTextField.java +++ b/src/java.desktop/share/classes/javax/swing/JFormattedTextField.java @@ -59,27 +59,32 @@ import javax.swing.text.*; * Possible JFormattedTextField configurations and their descriptions * * - * Value - * Description + * + * Value + * Description * * - * JFormattedTextField.REVERT - * Revert the display to match that of getValue, - * possibly losing the current edit. - * JFormattedTextField.COMMIT - * Commits the current value. If the value being edited - * isn't considered a legal value by the - * AbstractFormatter that is, a - * ParseException is thrown, then the value - * will not change, and then edited value will persist. - * JFormattedTextField.COMMIT_OR_REVERT - * Similar to COMMIT, but if the value isn't - * legal, behave like REVERT. - * JFormattedTextField.PERSIST - * Do nothing, don't obtain a new - * AbstractFormatter, and don't update the value. + * + * JFormattedTextField.REVERT + * Revert the display to match that of {@code getValue}, possibly losing + * the current edit. + * + * JFormattedTextField.COMMIT + * Commits the current value. If the value being edited isn't considered + * a legal value by the {@code AbstractFormatter} that is, a + * {@code ParseException} is thrown, then the value will not change, and + * then edited value will persist. + * + * JFormattedTextField.COMMIT_OR_REVERT + * Similar to {@code COMMIT}, but if the value isn't legal, behave like + * {@code REVERT}. + * + * JFormattedTextField.PERSIST + * Do nothing, don't obtain a new {@code AbstractFormatter}, and don't + * update the value. * * + * * The default is JFormattedTextField.COMMIT_OR_REVERT, * refer to {@link #setFocusLostBehavior} for more information on this. *

diff --git a/src/java.desktop/share/classes/javax/swing/JList.java b/src/java.desktop/share/classes/javax/swing/JList.java index 73eb7789fca..85a6caa8aad 100644 --- a/src/java.desktop/share/classes/javax/swing/JList.java +++ b/src/java.desktop/share/classes/javax/swing/JList.java @@ -968,25 +968,30 @@ public class JList extends JComponent implements Scrollable, Accessible * Describes layouts VERTICAL,HORIZONTAL_WRAP, and VERTICAL_WRAP * * - * ValueDescription + * + * Value + * Description * * - * VERTICAL - * Cells are layed out vertically in a single column. - * HORIZONTAL_WRAP - * Cells are layed out horizontally, wrapping to a new row as - * necessary. If the {@code visibleRowCount} property is less than - * or equal to zero, wrapping is determined by the width of the - * list; otherwise wrapping is done in such a way as to ensure - * {@code visibleRowCount} rows in the list. - * VERTICAL_WRAP - * Cells are layed out vertically, wrapping to a new column as - * necessary. If the {@code visibleRowCount} property is less than - * or equal to zero, wrapping is determined by the height of the - * list; otherwise wrapping is done at {@code visibleRowCount} rows. + * + * {@code VERTICAL} + * Cells are layed out vertically in a single column. + * + * {@code HORIZONTAL_WRAP} + * Cells are layed out horizontally, wrapping to a new row as + * necessary. If the {@code visibleRowCount} property is less than or + * equal to zero, wrapping is determined by the width of the list; + * otherwise wrapping is done in such a way as to ensure + * {@code visibleRowCount} rows in the list. + * + * {@code VERTICAL_WRAP} + * Cells are layed out vertically, wrapping to a new column as + * necessary. If the {@code visibleRowCount} property is less than or + * equal to zero, wrapping is determined by the height of the list; + * otherwise wrapping is done at {@code visibleRowCount} rows. * * - *

+ * * The default value of this property is VERTICAL. * * @param layoutOrientation the new layout orientation, one of: diff --git a/src/java.desktop/share/classes/javax/swing/JOptionPane.java b/src/java.desktop/share/classes/javax/swing/JOptionPane.java index ad5a5061649..795720ca913 100644 --- a/src/java.desktop/share/classes/javax/swing/JOptionPane.java +++ b/src/java.desktop/share/classes/javax/swing/JOptionPane.java @@ -71,37 +71,30 @@ import sun.awt.AWTAccessor; * class may appear complex because of the large number of methods, almost * all uses of this class are one-line calls to one of the static * showXxxDialog methods shown below: - *

* * * * - * - * - * - * + * + * * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * + * + * + * + * + * + * *
Common JOptionPane method names and their descriptions
Method NameDescription
Method Name + * Description *
showConfirmDialogAsks a confirming question, like yes/no/cancel.
showInputDialogPrompt for some input.
showMessageDialogTell the user about something that has happened.
showOptionDialogThe Grand Unification of the above three.
showConfirmDialog + * Asks a confirming question, like yes/no/cancel.
showInputDialog + * Prompt for some input. + *
showMessageDialog + * Tell the user about something that has happened. + *
showOptionDialog + * The Grand Unification of the above three. *
* - *
* Each of these methods also comes in a showInternalXXX * flavor, which uses an internal frame to hold the dialog box (see * {@link JInternalFrame}). diff --git a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicListUI.java b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicListUI.java index 2e43229aee8..c175cd02f23 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicListUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/basic/BasicListUI.java @@ -588,52 +588,53 @@ public class BasicListUI extends ListUI * Describes the preferred size for each layout orientation * * - * Layout OrientationPreferred Size + * + * Layout Orientation + * Preferred Size * * - * - * JList.VERTICAL - * The preferredSize of the list is total height of the rows - * and the maximum width of the cells. If JList.fixedCellHeight - * is specified then the total height of the rows is just - * (cellVerticalMargins + fixedCellHeight) * model.getSize() where - * rowVerticalMargins is the space we allocate for drawing - * the yellow focus outline. Similarly if fixedCellWidth is - * specified then we just use that. - * - * - * JList.VERTICAL_WRAP - * If the visible row count is greater than zero, the preferredHeight - * is the maximum cell height * visibleRowCount. If the visible row - * count is <= 0, the preferred height is either the current height - * of the list, or the maximum cell height, whichever is - * bigger. The preferred width is than the maximum cell width * - * number of columns needed. Where the number of columns needs is - * list.height / max cell height. Max cell height is either the fixed - * cell height, or is determined by iterating through all the cells - * to find the maximum height from the ListCellRenderer. - * - * JList.HORIZONTAL_WRAP - * If the visible row count is greater than zero, the preferredHeight - * is the maximum cell height * adjustedRowCount. Where - * visibleRowCount is used to determine the number of columns. - * Because this lays out horizontally the number of rows is - * then determined from the column count. For example, lets say - * you have a model with 10 items and the visible row count is 8. - * The number of columns needed to display this is 2, but you no - * longer need 8 rows to display this, you only need 5, thus - * the adjustedRowCount is 5. - *

If the visible row - * count is <= 0, the preferred height is dictated by the - * number of columns, which will be as many as can fit in the width - * of the JList (width / max cell width), with at - * least one column. The preferred height then becomes the - * model size / number of columns * maximum cell height. - * Max cell height is either the fixed - * cell height, or is determined by iterating through all the cells - * to find the maximum height from the ListCellRenderer. + * + * JList.VERTICAL + * The preferredSize of the list is total height of the rows + * and the maximum width of the cells. If JList.fixedCellHeight + * is specified then the total height of the rows is just + * (cellVerticalMargins + fixedCellHeight) * model.getSize() where + * rowVerticalMargins is the space we allocate for drawing + * the yellow focus outline. Similarly if fixedCellWidth is + * specified then we just use that. + * + * JList.VERTICAL_WRAP + * If the visible row count is greater than zero, the preferredHeight + * is the maximum cell height * visibleRowCount. If the visible row + * count is <= 0, the preferred height is either the current height + * of the list, or the maximum cell height, whichever is + * bigger. The preferred width is than the maximum cell width * + * number of columns needed. Where the number of columns needs is + * list.height / max cell height. Max cell height is either the fixed + * cell height, or is determined by iterating through all the cells + * to find the maximum height from the ListCellRenderer. + * + * JList.HORIZONTAL_WRAP + * If the visible row count is greater than zero, the preferredHeight + * is the maximum cell height * adjustedRowCount. Where + * visibleRowCount is used to determine the number of columns. + * Because this lays out horizontally the number of rows is + * then determined from the column count. For example, lets say + * you have a model with 10 items and the visible row count is 8. + * The number of columns needed to display this is 2, but you no + * longer need 8 rows to display this, you only need 5, thus + * the adjustedRowCount is 5. + *

+ * If the visible row count is <= 0, the preferred height is dictated + * by the number of columns, which will be as many as can fit in the + * width of the {@code JList} (width / max cell width), with at least + * one column. The preferred height then becomes the model size / number + * of columns * maximum cell height. Max cell height is either the fixed + * cell height, or is determined by iterating through all the cells to + * find the maximum height from the ListCellRenderer. * * + * * The above specifies the raw preferred width and height. The resulting * preferred width is the above width + insets.left + insets.right and * the resulting preferred height is the above height + insets.top + diff --git a/src/java.desktop/share/classes/javax/swing/plaf/metal/MetalLookAndFeel.java b/src/java.desktop/share/classes/javax/swing/plaf/metal/MetalLookAndFeel.java index f0552b158f7..5b589596937 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/metal/MetalLookAndFeel.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/metal/MetalLookAndFeel.java @@ -295,87 +295,87 @@ public class MetalLookAndFeel extends BasicLookAndFeel * Metal's system color mapping * * - * Key - * Value + * Key + * Value * * - * - * "desktop" + * + * "desktop" * {@code theme.getDesktopColor()} - * - * "activeCaption" + * + * "activeCaption" * {@code theme.getWindowTitleBackground()} - * - * "activeCaptionText" + * + * "activeCaptionText" * {@code theme.getWindowTitleForeground()} - * - * "activeCaptionBorder" + * + * "activeCaptionBorder" * {@code theme.getPrimaryControlShadow()} - * - * "inactiveCaption" + * + * "inactiveCaption" * {@code theme.getWindowTitleInactiveBackground()} - * - * "inactiveCaptionText" + * + * "inactiveCaptionText" * {@code theme.getWindowTitleInactiveForeground()} - * - * "inactiveCaptionBorder" + * + * "inactiveCaptionBorder" * {@code theme.getControlShadow()} - * - * "window" + * + * "window" * {@code theme.getWindowBackground()} - * - * "windowBorder" + * + * "windowBorder" * {@code theme.getControl()} - * - * "windowText" + * + * "windowText" * {@code theme.getUserTextColor()} - * - * "menu" + * + * "menu" * {@code theme.getMenuBackground()} - * - * "menuText" + * + * "menuText" * {@code theme.getMenuForeground()} - * - * "text" + * + * "text" * {@code theme.getWindowBackground()} - * - * "textText" + * + * "textText" * {@code theme.getUserTextColor()} - * - * "textHighlight" + * + * "textHighlight" * {@code theme.getTextHighlightColor()} - * - * "textHighlightText" + * + * "textHighlightText" * {@code theme.getHighlightedTextColor()} - * - * "textInactiveText" + * + * "textInactiveText" * {@code theme.getInactiveSystemTextColor()} - * - * "control" + * + * "control" * {@code theme.getControl()} - * - * "controlText" + * + * "controlText" * {@code theme.getControlTextColor()} - * - * "controlHighlight" + * + * "controlHighlight" * {@code theme.getControlHighlight()} - * - * "controlLtHighlight" + * + * "controlLtHighlight" * {@code theme.getControlHighlight()} - * - * "controlShadow" + * + * "controlShadow" * {@code theme.getControlShadow()} - * - * "controlDkShadow" + * + * "controlDkShadow" * {@code theme.getControlDarkShadow()} - * - * "scrollbar" + * + * "scrollbar" * {@code theme.getControl()} - * - * "info" + * + * "info" * {@code theme.getPrimaryControl()} - * - * "infoText" + * + * "infoText" * {@code theme.getPrimaryControlInfo()} * * diff --git a/src/java.desktop/share/classes/javax/swing/plaf/metal/MetalTreeUI.java b/src/java.desktop/share/classes/javax/swing/plaf/metal/MetalTreeUI.java index 6781762c817..c5603c36ef6 100644 --- a/src/java.desktop/share/classes/javax/swing/plaf/metal/MetalTreeUI.java +++ b/src/java.desktop/share/classes/javax/swing/plaf/metal/MetalTreeUI.java @@ -47,24 +47,25 @@ import javax.swing.plaf.basic.*; * * - * - * - * - * - * - * - * - * - * - * - * - * + * + * + * + * + * + * + * + * *
Descriptions of supported hints: Angled, Horizontal, and None *
AngledA line is drawn connecting the child to the parent. For handling - * of the root node refer to - * {@link javax.swing.JTree#setRootVisible} and - * {@link javax.swing.JTree#setShowsRootHandles}. - *
HorizontalA horizontal line is drawn dividing the children of the root node.
NoneDo not draw any visual indication between nodes.
Hint + * Description + *
Angled + * A line is drawn connecting the child to the parent. For handling of + * the root node refer to {@link JTree#setRootVisible} and + * {@link JTree#setShowsRootHandles}. + *
Horizontal + * A horizontal line is drawn dividing the children of the root node. + *
None + * Do not draw any visual indication between nodes. + *
- * *

* As it is typically impractical to obtain the TreeUI from * the JTree and cast to an instance of MetalTreeUI diff --git a/src/java.desktop/share/classes/javax/swing/text/JTextComponent.java b/src/java.desktop/share/classes/javax/swing/text/JTextComponent.java index 6ea7ea75a0a..df6011d1f94 100644 --- a/src/java.desktop/share/classes/javax/swing/text/JTextComponent.java +++ b/src/java.desktop/share/classes/javax/swing/text/JTextComponent.java @@ -160,34 +160,39 @@ import sun.swing.SwingAccessor; * * * - * - * - * - * + * + * * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * + * + * + * + * + * + * + * + * *
Stages of keyboard and input method event handling
StageKeyEventInputMethodEvent
Stage + * KeyEvent + * InputMethodEvent *
1. input methods (generated here)
2. focus manager
3. registered key listenersregistered input method listeners
4. input method handling in JTextComponent
5. keymap handling using the current keymap
6. keyboard handling in JComponent (e.g. accelerators, component navigation, etc.)
1. + * input methods + * (generated here) + *
2. + * focus manager + * + *
3. + * registered key listeners + * registered input method listeners + *
4. + * + * input method handling in JTextComponent + *
5. + * keymap handling using the current keymap + *
6. + * keyboard handling in JComponent (e.g. accelerators, component + * navigation, etc.) + * *
- * *

* To maintain compatibility with applications that listen to key * events but are not aware of input method events, the input diff --git a/src/java.desktop/share/classes/javax/swing/text/MaskFormatter.java b/src/java.desktop/share/classes/javax/swing/text/MaskFormatter.java index 6f5ea467a89..8924858caf1 100644 --- a/src/java.desktop/share/classes/javax/swing/text/MaskFormatter.java +++ b/src/java.desktop/share/classes/javax/swing/text/MaskFormatter.java @@ -40,36 +40,39 @@ import javax.swing.*; * * * - * - * - * - * + * + * * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * + * + * + * + * + * + * + * + * + * *
Valid characters and their descriptions
Character Description
Character + * Description *
#Any valid number, uses Character.isDigit.
'Escape character, used to escape any of the - * special formatting characters.
UAny character (Character.isLetter). All - * lowercase letters are mapped to upper case.
LAny character (Character.isLetter). All - * upper case letters are mapped to lower case.
AAny character or number (Character.isLetter - * or Character.isDigit)
?Any character - * (Character.isLetter).
*Anything.
HAny hex character (0-9, a-f or A-F).
# + * Any valid number, uses {@code Character.isDigit}. + *
' + * Escape character, used to escape any of the special formatting + * characters. + *
U + * Any character ({@code Character.isLetter}). All lowercase letters are + * mapped to upper case. + *
L + * Any character ({@code Character.isLetter}). All upper case letters + * are mapped to lower case. + *
A + * Any character or number ({@code Character.isLetter} or + * {@code Character.isDigit}). + *
? + * Any character ({@code Character.isLetter}). + *
* + * Anything. + *
H + * Any hex character (0-9, a-f or A-F). *
* diff --git a/src/java.desktop/share/classes/javax/swing/text/html/FormView.java b/src/java.desktop/share/classes/javax/swing/text/html/FormView.java index b36edc8c8fe..b9ba06dc1f4 100644 --- a/src/java.desktop/share/classes/javax/swing/text/html/FormView.java +++ b/src/java.desktop/share/classes/javax/swing/text/html/FormView.java @@ -50,60 +50,47 @@ import javax.swing.text.*; * * * - * - * - * - * + * + * * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * - * + * + * + * + * + * + * + * + * + * + * + * + * + * *
Shows what components get built by this view
Element TypeComponent built
Element Type + * Component built *
input, type buttonJButton
input, type checkboxJCheckBox
input, type imageJButton
input, type passwordJPasswordField
input, type radioJRadioButton
input, type resetJButton
input, type submitJButton
input, type textJTextField
select, size > 1 or multiple attribute definedJList in a JScrollPane
select, size unspecified or 1JComboBox
textareaJTextArea in a JScrollPane
input, type fileJTextField
input, type button + * JButton + *
input, type checkbox + * JCheckBox + *
input, type image + * JButton + *
input, type password + * JPasswordField + *
input, type radio + * JRadioButton + *
input, type reset + * JButton + *
input, type submit + * JButton + *
input, type text + * JTextField + *
select, size > 1 or multiple attribute defined + * JList in a JScrollPane + *
select, size unspecified or 1 + * JComboBox + *
textarea + * JTextArea in a JScrollPane + *
input, type file + * JTextField *
* diff --git a/src/java.desktop/share/classes/javax/swing/text/html/HTMLDocument.java b/src/java.desktop/share/classes/javax/swing/text/html/HTMLDocument.java index f1f3be6eee4..0fec6a9ced1 100644 --- a/src/java.desktop/share/classes/javax/swing/text/html/HTMLDocument.java +++ b/src/java.desktop/share/classes/javax/swing/text/html/HTMLDocument.java @@ -2134,81 +2134,227 @@ public class HTMLDocument extends DefaultStyledDocument { * * * - * + * + * * - * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * + * *
HTML tags and assigned actions
TagAction
Tag + * Action *
HTML.Tag.A CharacterAction - *
HTML.Tag.ADDRESS CharacterAction - *
HTML.Tag.APPLET HiddenAction - *
HTML.Tag.AREA AreaAction - *
HTML.Tag.B CharacterAction - *
HTML.Tag.BASE BaseAction - *
HTML.Tag.BASEFONT CharacterAction - *
HTML.Tag.BIG CharacterAction - *
HTML.Tag.BLOCKQUOTEBlockAction - *
HTML.Tag.BODY BlockAction - *
HTML.Tag.BR SpecialAction - *
HTML.Tag.CAPTION BlockAction - *
HTML.Tag.CENTER BlockAction - *
HTML.Tag.CITE CharacterAction - *
HTML.Tag.CODE CharacterAction - *
HTML.Tag.DD BlockAction - *
HTML.Tag.DFN CharacterAction - *
HTML.Tag.DIR BlockAction - *
HTML.Tag.DIV BlockAction - *
HTML.Tag.DL BlockAction - *
HTML.Tag.DT ParagraphAction - *
HTML.Tag.EM CharacterAction - *
HTML.Tag.FONT CharacterAction - *
HTML.Tag.FORM As of 1.4 a BlockAction - *
HTML.Tag.FRAME SpecialAction - *
HTML.Tag.FRAMESET BlockAction - *
HTML.Tag.H1 ParagraphAction - *
HTML.Tag.H2 ParagraphAction - *
HTML.Tag.H3 ParagraphAction - *
HTML.Tag.H4 ParagraphAction - *
HTML.Tag.H5 ParagraphAction - *
HTML.Tag.H6 ParagraphAction - *
HTML.Tag.HEAD HeadAction - *
HTML.Tag.HR SpecialAction - *
HTML.Tag.HTML BlockAction - *
HTML.Tag.I CharacterAction - *
HTML.Tag.IMG SpecialAction - *
HTML.Tag.INPUT FormAction - *
HTML.Tag.ISINDEX IsndexAction - *
HTML.Tag.KBD CharacterAction - *
HTML.Tag.LI BlockAction - *
HTML.Tag.LINK LinkAction - *
HTML.Tag.MAP MapAction - *
HTML.Tag.MENU BlockAction - *
HTML.Tag.META MetaAction - *
HTML.Tag.NOFRAMES BlockAction - *
HTML.Tag.OBJECT SpecialAction - *
HTML.Tag.OL BlockAction - *
HTML.Tag.OPTION FormAction - *
HTML.Tag.P ParagraphAction - *
HTML.Tag.PARAM HiddenAction - *
HTML.Tag.PRE PreAction - *
HTML.Tag.SAMP CharacterAction - *
HTML.Tag.SCRIPT HiddenAction - *
HTML.Tag.SELECT FormAction - *
HTML.Tag.SMALL CharacterAction - *
HTML.Tag.STRIKE CharacterAction - *
HTML.Tag.S CharacterAction - *
HTML.Tag.STRONG CharacterAction - *
HTML.Tag.STYLE StyleAction - *
HTML.Tag.SUB CharacterAction - *
HTML.Tag.SUP CharacterAction - *
HTML.Tag.TABLE BlockAction - *
HTML.Tag.TD BlockAction - *
HTML.Tag.TEXTAREA FormAction - *
HTML.Tag.TH BlockAction - *
HTML.Tag.TITLE TitleAction - *
HTML.Tag.TR BlockAction - *
HTML.Tag.TT CharacterAction - *
HTML.Tag.U CharacterAction - *
HTML.Tag.UL BlockAction - *
HTML.Tag.VAR CharacterAction + *
{@code HTML.Tag.A} + * CharacterAction + *
{@code HTML.Tag.ADDRESS} + * CharacterAction + *
{@code HTML.Tag.APPLET} + * HiddenAction + *
{@code HTML.Tag.AREA} + * AreaAction + *
{@code HTML.Tag.B} + * CharacterAction + *
{@code HTML.Tag.BASE} + * BaseAction + *
{@code HTML.Tag.BASEFONT} + * CharacterAction + *
{@code HTML.Tag.BIG} + * CharacterAction + *
{@code HTML.Tag.BLOCKQUOTE} + * BlockAction + *
{@code HTML.Tag.BODY} + * BlockAction + *
{@code HTML.Tag.BR} + * SpecialAction + *
{@code HTML.Tag.CAPTION} + * BlockAction + *
{@code HTML.Tag.CENTER} + * BlockAction + *
{@code HTML.Tag.CITE} + * CharacterAction + *
{@code HTML.Tag.CODE} + * CharacterAction + *
{@code HTML.Tag.DD} + * BlockAction + *
{@code HTML.Tag.DFN} + * CharacterAction + *
{@code HTML.Tag.DIR} + * BlockAction + *
{@code HTML.Tag.DIV} + * BlockAction + *
{@code HTML.Tag.DL} + * BlockAction + *
{@code HTML.Tag.DT} + * ParagraphAction + *
{@code HTML.Tag.EM} + * CharacterAction + *
{@code HTML.Tag.FONT} + * CharacterAction + *
{@code HTML.Tag.FORM} + * As of 1.4 a BlockAction + *
{@code HTML.Tag.FRAME} + * SpecialAction + *
{@code HTML.Tag.FRAMESET} + * BlockAction + *
{@code HTML.Tag.H1} + * ParagraphAction + *
{@code HTML.Tag.H2} + * ParagraphAction + *
{@code HTML.Tag.H3} + * ParagraphAction + *
{@code HTML.Tag.H4} + * ParagraphAction + *
{@code HTML.Tag.H5} + * ParagraphAction + *
{@code HTML.Tag.H6} + * ParagraphAction + *
{@code HTML.Tag.HEAD} + * HeadAction + *
{@code HTML.Tag.HR} + * SpecialAction + *
{@code HTML.Tag.HTML} + * BlockAction + *
{@code HTML.Tag.I} + * CharacterAction + *
{@code HTML.Tag.IMG} + * SpecialAction + *
{@code HTML.Tag.INPUT} + * FormAction + *
{@code HTML.Tag.ISINDEX} + * IsndexAction + *
{@code HTML.Tag.KBD} + * CharacterAction + *
{@code HTML.Tag.LI} + * BlockAction + *
{@code HTML.Tag.LINK} + * LinkAction + *
{@code HTML.Tag.MAP} + * MapAction + *
{@code HTML.Tag.MENU} + * BlockAction + *
{@code HTML.Tag.META} + * MetaAction + *
{@code HTML.Tag.NOFRAMES} + * BlockAction + *
{@code HTML.Tag.OBJECT} + * SpecialAction + *
{@code HTML.Tag.OL} + * BlockAction + *
{@code HTML.Tag.OPTION} + * FormAction + *
{@code HTML.Tag.P} + * ParagraphAction + *
{@code HTML.Tag.PARAM} + * HiddenAction + *
{@code HTML.Tag.PRE} + * PreAction + *
{@code HTML.Tag.SAMP} + * CharacterAction + *
{@code HTML.Tag.SCRIPT} + * HiddenAction + *
{@code HTML.Tag.SELECT} + * FormAction + *
{@code HTML.Tag.SMALL} + * CharacterAction + *
{@code HTML.Tag.STRIKE} + * CharacterAction + *
{@code HTML.Tag.S} + * CharacterAction + *
{@code HTML.Tag.STRONG} + * CharacterAction + *
{@code HTML.Tag.STYLE} + * StyleAction + *
{@code HTML.Tag.SUB} + * CharacterAction + *
{@code HTML.Tag.SUP} + * CharacterAction + *
{@code HTML.Tag.TABLE} + * BlockAction + *
{@code HTML.Tag.TD} + * BlockAction + *
{@code HTML.Tag.TEXTAREA} + * FormAction + *
{@code HTML.Tag.TH} + * BlockAction + *
{@code HTML.Tag.TITLE} + * TitleAction + *
{@code HTML.Tag.TR} + * BlockAction + *
{@code HTML.Tag.TT} + * CharacterAction + *
{@code HTML.Tag.U} + * CharacterAction + *
{@code HTML.Tag.UL} + * BlockAction + *
{@code HTML.Tag.VAR} + * CharacterAction *
*

@@ -3397,45 +3543,44 @@ public class HTMLDocument extends DefaultStyledDocument { * Model assignments for the various types of form elements * * - * - * Element Type - * Model Type - * + * + * Element Type + * Model Type * * - * - * input, type button - * {@link DefaultButtonModel} - * - * input, type checkbox - * {@link javax.swing.JToggleButton.ToggleButtonModel} - * - * input, type image - * {@link DefaultButtonModel} - * - * input, type password - * {@link PlainDocument} - * - * input, type radio - * {@link javax.swing.JToggleButton.ToggleButtonModel} - * - * input, type reset - * {@link DefaultButtonModel} - * - * input, type submit - * {@link DefaultButtonModel} - * - * input, type text or type is null. - * {@link PlainDocument} - * - * select - * {@link DefaultComboBoxModel} or an {@link DefaultListModel}, with an item type of Option - * - * textarea - * {@link PlainDocument} + * + * input, type button + * {@link DefaultButtonModel} + * + * input, type checkbox + * {@link JToggleButton.ToggleButtonModel} + * + * input, type image + * {@link DefaultButtonModel} + * + * input, type password + * {@link PlainDocument} + * + * input, type radio + * {@link JToggleButton.ToggleButtonModel} + * + * input, type reset + * {@link DefaultButtonModel} + * + * input, type submit + * {@link DefaultButtonModel} + * + * input, type text or type is null. + * {@link PlainDocument} + * + * select + * {@link DefaultComboBoxModel} or an {@link DefaultListModel}, + * with an item type of Option + * + * textarea + * {@link PlainDocument} * * - * */ public class FormAction extends SpecialAction { diff --git a/src/java.desktop/share/classes/javax/swing/text/html/HTMLEditorKit.java b/src/java.desktop/share/classes/javax/swing/text/html/HTMLEditorKit.java index 230bd2f6b99..e2f1966eefc 100644 --- a/src/java.desktop/share/classes/javax/swing/text/html/HTMLEditorKit.java +++ b/src/java.desktop/share/classes/javax/swing/text/html/HTMLEditorKit.java @@ -1122,83 +1122,116 @@ public class HTMLEditorKit extends StyledEditorKit implements Accessible { * Describes the tag and view created by this factory by default * * - * - * Tag - * View created - * + * + * Tag + * View created * * - * - * HTML.Tag.CONTENTInlineView - * - * HTML.Tag.IMPLIEDjavax.swing.text.html.ParagraphView - * - * HTML.Tag.Pjavax.swing.text.html.ParagraphView - * - * HTML.Tag.H1javax.swing.text.html.ParagraphView - * - * HTML.Tag.H2javax.swing.text.html.ParagraphView - * - * HTML.Tag.H3javax.swing.text.html.ParagraphView - * - * HTML.Tag.H4javax.swing.text.html.ParagraphView - * - * HTML.Tag.H5javax.swing.text.html.ParagraphView - * - * HTML.Tag.H6javax.swing.text.html.ParagraphView - * - * HTML.Tag.DTjavax.swing.text.html.ParagraphView - * - * HTML.Tag.MENUListView - * - * HTML.Tag.DIRListView - * - * HTML.Tag.ULListView - * - * HTML.Tag.OLListView - * - * HTML.Tag.LIBlockView - * - * HTML.Tag.DLBlockView - * - * HTML.Tag.DDBlockView - * - * HTML.Tag.BODYBlockView - * - * HTML.Tag.HTMLBlockView - * - * HTML.Tag.CENTERBlockView - * - * HTML.Tag.DIVBlockView - * - * HTML.Tag.BLOCKQUOTEBlockView - * - * HTML.Tag.PREBlockView - * - * HTML.Tag.BLOCKQUOTEBlockView - * - * HTML.Tag.PREBlockView - * - * HTML.Tag.IMGImageView - * - * HTML.Tag.HRHRuleView - * - * HTML.Tag.BRBRView - * - * HTML.Tag.TABLEjavax.swing.text.html.TableView - * - * HTML.Tag.INPUTFormView - * - * HTML.Tag.SELECTFormView - * - * HTML.Tag.TEXTAREAFormView - * - * HTML.Tag.OBJECTObjectView - * - * HTML.Tag.FRAMESETFrameSetView - * - * HTML.Tag.FRAMEFrameView - * + * + * HTML.Tag.CONTENT + * InlineView + * + * HTML.Tag.IMPLIED + * javax.swing.text.html.ParagraphView + * + * HTML.Tag.P + * javax.swing.text.html.ParagraphView + * + * HTML.Tag.H1 + * javax.swing.text.html.ParagraphView + * + * HTML.Tag.H2 + * javax.swing.text.html.ParagraphView + * + * HTML.Tag.H3 + * javax.swing.text.html.ParagraphView + * + * HTML.Tag.H4 + * javax.swing.text.html.ParagraphView + * + * HTML.Tag.H5 + * javax.swing.text.html.ParagraphView + * + * HTML.Tag.H6 + * javax.swing.text.html.ParagraphView + * + * HTML.Tag.DT + * javax.swing.text.html.ParagraphView + * + * HTML.Tag.MENU + * ListView + * + * HTML.Tag.DIR + * ListView + * + * HTML.Tag.UL + * ListView + * + * HTML.Tag.OL + * ListView + * + * HTML.Tag.LI + * BlockView + * + * HTML.Tag.DL + * BlockView + * + * HTML.Tag.DD + * BlockView + * + * HTML.Tag.BODY + * BlockView + * + * HTML.Tag.HTML + * BlockView + * + * HTML.Tag.CENTER + * BlockView + * + * HTML.Tag.DIV + * BlockView + * + * HTML.Tag.BLOCKQUOTE + * BlockView + * + * HTML.Tag.PRE + * BlockView + * + * HTML.Tag.BLOCKQUOTE + * BlockView + * + * HTML.Tag.PRE + * BlockView + * + * HTML.Tag.IMG + * ImageView + * + * HTML.Tag.HR + * HRuleView + * + * HTML.Tag.BR + * BRView + * + * HTML.Tag.TABLE + * javax.swing.text.html.TableView + * + * HTML.Tag.INPUT + * FormView + * + * HTML.Tag.SELECT + * FormView + * + * HTML.Tag.TEXTAREA + * FormView + * + * HTML.Tag.OBJECT + * ObjectView + * + * HTML.Tag.FRAMESET + * FrameSetView + * + * HTML.Tag.FRAME + * FrameView * * */ diff --git a/src/java.desktop/share/classes/javax/swing/tree/DefaultTreeCellRenderer.java b/src/java.desktop/share/classes/javax/swing/tree/DefaultTreeCellRenderer.java index 73fc667c185..59e6427aae1 100644 --- a/src/java.desktop/share/classes/javax/swing/tree/DefaultTreeCellRenderer.java +++ b/src/java.desktop/share/classes/javax/swing/tree/DefaultTreeCellRenderer.java @@ -65,19 +65,35 @@ import sun.swing.DefaultLookup; * Properties * * - * Property: - * Key: + * Property + * Key * * * - * "leafIcon""Tree.leafIcon" - * "closedIcon""Tree.closedIcon" - * "openIcon""Tree.openIcon" - * "textSelectionColor""Tree.selectionForeground" - * "textNonSelectionColor""Tree.textForeground" - * "backgroundSelectionColor""Tree.selectionBackground" - * "backgroundNonSelectionColor""Tree.textBackground" - * "borderSelectionColor""Tree.selectionBorderColor" + * + * "leafIcon" + * "Tree.leafIcon" + * + * "closedIcon" + * "Tree.closedIcon" + * + * "openIcon" + * "Tree.openIcon" + * + * "textSelectionColor" + * "Tree.selectionForeground" + * + * "textNonSelectionColor" + * "Tree.textForeground" + * + * "backgroundSelectionColor" + * "Tree.selectionBackground" + * + * "backgroundNonSelectionColor" + * "Tree.textBackground" + * + * "borderSelectionColor" + * "Tree.selectionBorderColor" * * *

From 19fbc4c08caa1517903e067501823471d9988907 Mon Sep 17 00:00:00 2001 From: Robert Field Date: Fri, 20 Oct 2017 19:08:25 -0700 Subject: [PATCH 04/39] 8187359: JShell: Give comprehensible error when user method name matches Object method Reviewed-by: jlahoda --- .../share/classes/jdk/jshell/Eval.java | 72 +++++++++++++++++-- .../jdk/jshell/resources/l10n.properties | 3 +- test/langtools/jdk/jshell/MethodsTest.java | 22 +++++- 3 files changed, 90 insertions(+), 7 deletions(-) diff --git a/src/jdk.jshell/share/classes/jdk/jshell/Eval.java b/src/jdk.jshell/share/classes/jdk/jshell/Eval.java index 769d741908c..8cdc1f03f84 100644 --- a/src/jdk.jshell/share/classes/jdk/jshell/Eval.java +++ b/src/jdk.jshell/share/classes/jdk/jshell/Eval.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2014, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2014, 2017, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -48,6 +48,7 @@ import com.sun.tools.javac.tree.Pretty; import java.io.IOException; import java.io.StringWriter; import java.io.Writer; +import java.util.Arrays; import java.util.LinkedHashSet; import java.util.Set; import jdk.jshell.ExpressionToTypeInfo.ExpressionInfo; @@ -100,6 +101,12 @@ class Eval { private final JShell state; + // The set of names of methods on Object + private final Set objectMethods = Arrays + .stream(Object.class.getMethods()) + .map(m -> m.getName()) + .collect(toSet()); + Eval(JShell state) { this.state = state; } @@ -528,10 +535,26 @@ class Eval { private List processMethod(String userSource, Tree unitTree, String compileSource, ParseTask pt) { TreeDependencyScanner tds = new TreeDependencyScanner(); tds.scan(unitTree); - TreeDissector dis = TreeDissector.createByFirstClass(pt); + final TreeDissector dis = TreeDissector.createByFirstClass(pt); - MethodTree mt = (MethodTree) unitTree; - String name = mt.getName().toString(); + final MethodTree mt = (MethodTree) unitTree; + final String name = mt.getName().toString(); + if (objectMethods.contains(name)) { + // The name matches a method on Object, short of an overhaul, this + // fails, see 8187137. Generate a descriptive error message + + // The error position will be the position of the name, find it + long possibleStart = dis.getEndPosition(mt.getReturnType()); + Range possibleRange = new Range((int) possibleStart, + dis.getStartPosition(mt.getBody())); + String possibleNameSection = possibleRange.part(compileSource); + int offset = possibleNameSection.indexOf(name); + long start = offset < 0 + ? possibleStart // something wrong, punt + : possibleStart + offset; + + return compileFailResult(new DiagList(objectMethodNameDiag(name, start)), userSource, Kind.METHOD); + } String parameterTypes = mt.getParameters() .stream() @@ -900,6 +923,47 @@ class Eval { return PREFIX_PATTERN.matcher(ste.getClassName()).find(); } + /** + * Construct a diagnostic for a method name matching an Object method name + * @param name the method name + * @param nameStart the position within the source of the method name + * @return the generated diagnostic + */ + private Diag objectMethodNameDiag(String name, long nameStart) { + return new Diag() { + @Override + public boolean isError() { + return true; + } + + @Override + public long getPosition() { + return nameStart; + } + + @Override + public long getStartPosition() { + return nameStart; + } + + @Override + public long getEndPosition() { + return nameStart + name.length(); + } + + @Override + public String getCode() { + return "jdk.eval.error.object.method"; + } + + @Override + public String getMessage(Locale locale) { + return state.messageFormat("jshell.diag.object.method.fatal", + String.join(" ", objectMethods)); + } + }; + } + private DiagList modifierDiagnostics(ModifiersTree modtree, final TreeDissector dis, boolean isAbstractProhibited) { diff --git a/src/jdk.jshell/share/classes/jdk/jshell/resources/l10n.properties b/src/jdk.jshell/share/classes/jdk/jshell/resources/l10n.properties index 5f85a6bae29..4c1abd2b173 100644 --- a/src/jdk.jshell/share/classes/jdk/jshell/resources/l10n.properties +++ b/src/jdk.jshell/share/classes/jdk/jshell/resources/l10n.properties @@ -1,5 +1,5 @@ # -# Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. +# Copyright (c) 2016, 2017, Oracle and/or its affiliates. All rights reserved. # 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,6 +27,7 @@ jshell.diag.modifier.plural.fatal = Modifiers {0} not permitted in top-level dec jshell.diag.modifier.plural.ignore = Modifiers {0} not permitted in top-level declarations, ignored jshell.diag.modifier.single.fatal = Modifier {0} not permitted in top-level declarations jshell.diag.modifier.single.ignore = Modifier {0} not permitted in top-level declarations, ignored +jshell.diag.object.method.fatal = JShell method names must not match Object methods: {0} jshell.exc.null = Snippet must not be null jshell.exc.alien = Snippet not from this JShell: {0} diff --git a/test/langtools/jdk/jshell/MethodsTest.java b/test/langtools/jdk/jshell/MethodsTest.java index ad5b4ac590d..29af41a0a3f 100644 --- a/test/langtools/jdk/jshell/MethodsTest.java +++ b/test/langtools/jdk/jshell/MethodsTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 2017, Oracle and/or its affiliates. All rights reserved. * 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 8080357 8167643 + * @bug 8080357 8167643 8187359 * @summary Tests for EvaluationState.methods * @build KullaTesting TestingInputStream ExpectedDiagnostic * @run testng MethodsTest @@ -230,6 +230,24 @@ public class MethodsTest extends KullaTesting { assertActiveKeys(); } + public void objectMethodNamedMethodsErrors() { + assertDeclareFail("boolean equals(double d1, double d2) { return d1 == d2; }", + new ExpectedDiagnostic("jdk.eval.error.object.method", 8, 14, 8, -1, -1, Diagnostic.Kind.ERROR)); + assertNumberOfActiveMethods(0); + assertActiveKeys(); + + assertDeclareFail("void wait() { }", + new ExpectedDiagnostic("jdk.eval.error.object.method", 14, 18, 14, -1, -1, Diagnostic.Kind.ERROR)); + assertNumberOfActiveMethods(0); + assertActiveKeys(); + + assertDeclareFail(" String toString() throws NullPointerException{ }", + new ExpectedDiagnostic("jdk.eval.error.object.method", 11, 19, 11, -1, -1, Diagnostic.Kind.ERROR)); + assertNumberOfActiveMethods(0); + assertActiveKeys(); + + } + public void methodsAccessModifierIgnored() { Snippet f = methodKey(assertEval("public String f() {return null;}", From c852879b03b7adfa887d496e3a0efe1658711de0 Mon Sep 17 00:00:00 2001 From: Sergey Bylokhov Date: Fri, 20 Oct 2017 20:08:09 -0700 Subject: [PATCH 05/39] 8186559: [macos] the screen location is wrong when using AWT/SWT bridge with dual monitors Reviewed-by: dmarkov, ssadetsky --- .../macosx/native/libawt_lwawt/awt/AWTView.m | 322 +++++++++--------- .../native/libawt_lwawt/awt/CTrayIcon.m | 13 +- 2 files changed, 167 insertions(+), 168 deletions(-) diff --git a/src/java.desktop/macosx/native/libawt_lwawt/awt/AWTView.m b/src/java.desktop/macosx/native/libawt_lwawt/awt/AWTView.m index 3c33c09c558..72d7aebc26a 100644 --- a/src/java.desktop/macosx/native/libawt_lwawt/awt/AWTView.m +++ b/src/java.desktop/macosx/native/libawt_lwawt/awt/AWTView.m @@ -74,20 +74,20 @@ static BOOL shouldUsePressAndHold() { // Initialize ourselves self = [super initWithFrame: rect]; if (self == nil) return self; - + m_cPlatformView = cPlatformView; fInputMethodLOCKABLE = NULL; fKeyEventsNeeded = NO; fProcessingKeystroke = NO; - + fEnablePressAndHold = shouldUsePressAndHold(); fInPressAndHold = NO; fPAHNeedsToSelect = NO; - + mouseIsOver = NO; [self resetTrackingArea]; [self setAutoresizesSubviews:NO]; - + if (windowLayer != nil) { self.cglLayer = windowLayer; //Layer hosting view @@ -98,7 +98,7 @@ static BOOL shouldUsePressAndHold() { //[self setLayerContentsRedrawPolicy: NSViewLayerContentsRedrawDuringViewResize]; //[self setLayerContentsPlacement: NSViewLayerContentsPlacementTopLeft]; //[self setAutoresizingMask: NSViewHeightSizable | NSViewWidthSizable]; - + #ifdef REMOTELAYER CGLLayer *parentLayer = (CGLLayer*)self.cglLayer; parentLayer.parentLayer = NULL; @@ -120,36 +120,36 @@ static BOOL shouldUsePressAndHold() { } #endif /* REMOTELAYER */ } - + return self; } - (void) dealloc { AWT_ASSERT_APPKIT_THREAD; - + self.cglLayer = nil; - + JNIEnv *env = [ThreadUtilities getJNIEnvUncached]; (*env)->DeleteWeakGlobalRef(env, m_cPlatformView); m_cPlatformView = NULL; - + if (fInputMethodLOCKABLE != NULL) { JNIEnv *env = [ThreadUtilities getJNIEnvUncached]; - + JNFDeleteGlobalRef(env, fInputMethodLOCKABLE); fInputMethodLOCKABLE = NULL; } - - + + [super dealloc]; } - (void) viewDidMoveToWindow { AWT_ASSERT_APPKIT_THREAD; - + [AWTToolkit eventCountPlusPlus]; - + [JNFRunLoop performOnMainThreadWaiting:NO withBlock:^() { [[self window] makeFirstResponder: self]; }]; @@ -230,10 +230,10 @@ static BOOL shouldUsePressAndHold() { - (void) mouseMoved: (NSEvent *)event { // TODO: better way to redirect move events to the "under" view - + NSPoint eventLocation = [event locationInWindow]; NSPoint localPoint = [self convertPoint: eventLocation fromView: nil]; - + if ([self mouse: localPoint inRect: [self bounds]]) { [self deliverJavaMouseEvent: event]; } else { @@ -277,10 +277,10 @@ static BOOL shouldUsePressAndHold() { - (void) keyDown: (NSEvent *)event { fProcessingKeystroke = YES; fKeyEventsNeeded = YES; - + // Allow TSM to look at the event and potentially send back NSTextInputClient messages. [self interpretKeyEvents:[NSArray arrayWithObject:event]]; - + if (fEnablePressAndHold && [event willBeHandledByComplexInputMethod] && fInputMethodLOCKABLE) { fProcessingKeystroke = NO; if (!fInPressAndHold) { @@ -289,14 +289,14 @@ static BOOL shouldUsePressAndHold() { } return; } - + NSString *eventCharacters = [event characters]; BOOL isDeadKey = (eventCharacters != nil && [eventCharacters length] == 0); - + if ((![self hasMarkedText] && fKeyEventsNeeded) || isDeadKey) { [self deliverJavaKeyEventHelper: event]; } - + fProcessingKeystroke = NO; } @@ -313,7 +313,7 @@ static BOOL shouldUsePressAndHold() { if (![self hasMarkedText] && !fInPressAndHold) { [self deliverJavaKeyEventHelper: event]; } - + // Workaround for 8020209: special case for "Cmd =" and "Cmd ." // because Cocoa calls performKeyEquivalent twice for these keystrokes NSUInteger modFlags = [event modifierFlags] & @@ -327,9 +327,9 @@ static BOOL shouldUsePressAndHold() { return YES; } } - + } - + return NO; } @@ -343,36 +343,36 @@ static BOOL shouldUsePressAndHold() { if ([window isKindOfClass: [AWTWindow_Panel class]] || [window isKindOfClass: [AWTWindow_Normal class]]) { isEnabled = [(AWTWindow*)[window delegate] isEnabled]; } - + if (!isEnabled) { return; } - + NSEventType type = [event type]; - + // check synthesized mouse entered/exited events if ((type == NSMouseEntered && mouseIsOver) || (type == NSMouseExited && !mouseIsOver)) { return; }else if ((type == NSMouseEntered && !mouseIsOver) || (type == NSMouseExited && mouseIsOver)) { mouseIsOver = !mouseIsOver; } - + [AWTToolkit eventCountPlusPlus]; - + JNIEnv *env = [ThreadUtilities getJNIEnv]; - + NSPoint eventLocation = [event locationInWindow]; NSPoint localPoint = [self convertPoint: eventLocation fromView: nil]; NSPoint absP = [NSEvent mouseLocation]; - + // Convert global numbers between Cocoa's coordinate system and Java. // TODO: need consitent way for doing that both with global as well as with local coordinates. // The reason to do it here is one more native method for getting screen dimension otherwise. - + NSRect screenRect = [[[NSScreen screens] objectAtIndex:0] frame]; absP.y = screenRect.size.height - absP.y; jint clickCount; - + if (type == NSMouseEntered || type == NSMouseExited || type == NSScrollWheel || @@ -388,7 +388,7 @@ static BOOL shouldUsePressAndHold() { deltaX = [event scrollingDeltaX] * 0.1; deltaY = [event scrollingDeltaY] * 0.1; } - + static JNF_CLASS_CACHE(jc_NSEvent, "sun/lwawt/macosx/NSEvent"); static JNF_CTOR_CACHE(jctor_NSEvent, jc_NSEvent, "(IIIIIIIIDDI)V"); jobject jEvent = JNFNewObject(env, jctor_NSEvent, @@ -402,7 +402,7 @@ static BOOL shouldUsePressAndHold() { deltaX, [AWTToolkit scrollStateWithEvent: event]); CHECK_NULL(jEvent); - + static JNF_CLASS_CACHE(jc_PlatformView, "sun/lwawt/macosx/CPlatformView"); static JNF_MEMBER_CACHE(jm_deliverMouseEvent, jc_PlatformView, "deliverMouseEvent", "(Lsun/lwawt/macosx/NSEvent;)V"); jobject jlocal = (*env)->NewLocalRef(env, m_cPlatformView); @@ -418,10 +418,10 @@ static BOOL shouldUsePressAndHold() { [self removeTrackingArea:rolloverTrackingArea]; [rolloverTrackingArea release]; } - + int options = (NSTrackingActiveAlways | NSTrackingMouseEnteredAndExited | NSTrackingMouseMoved | NSTrackingEnabledDuringMouseDrag); - + rolloverTrackingArea = [[NSTrackingArea alloc] initWithRect:[self visibleRect] options: options owner:self @@ -448,17 +448,17 @@ static BOOL shouldUsePressAndHold() { } [sLastKeyEvent release]; sLastKeyEvent = [event retain]; - + [AWTToolkit eventCountPlusPlus]; JNIEnv *env = [ThreadUtilities getJNIEnv]; - + jstring characters = NULL; jstring charactersIgnoringModifiers = NULL; if ([event type] != NSFlagsChanged) { characters = JNFNSToJavaString(env, [event characters]); charactersIgnoringModifiers = JNFNSToJavaString(env, [event charactersIgnoringModifiers]); } - + static JNF_CLASS_CACHE(jc_NSEvent, "sun/lwawt/macosx/NSEvent"); static JNF_CTOR_CACHE(jctor_NSEvent, jc_NSEvent, "(IISLjava/lang/String;Ljava/lang/String;)V"); jobject jEvent = JNFNewObject(env, jctor_NSEvent, @@ -468,7 +468,7 @@ static BOOL shouldUsePressAndHold() { characters, charactersIgnoringModifiers); CHECK_NULL(jEvent); - + static JNF_CLASS_CACHE(jc_PlatformView, "sun/lwawt/macosx/CPlatformView"); static JNF_MEMBER_CACHE(jm_deliverKeyEvent, jc_PlatformView, "deliverKeyEvent", "(Lsun/lwawt/macosx/NSEvent;)V"); @@ -502,7 +502,7 @@ static BOOL shouldUsePressAndHold() { - (void) drawRect:(NSRect)dirtyRect { AWT_ASSERT_APPKIT_THREAD; - + [super drawRect:dirtyRect]; JNIEnv *env = [ThreadUtilities getJNIEnv]; if (env != NULL) { @@ -615,17 +615,17 @@ static BOOL shouldUsePressAndHold() { - (id)accessibilityAttributeValue:(NSString *)attribute { AWT_ASSERT_APPKIT_THREAD; - + if ([attribute isEqualToString:NSAccessibilityChildrenAttribute]) { JNIEnv *env = [ThreadUtilities getJNIEnv]; - + (*env)->PushLocalFrame(env, 4); - + id result = NSAccessibilityUnignoredChildrenForOnlyChild([self getAxData:env]); - + (*env)->PopLocalFrame(env, NULL); - + return result; } else @@ -642,28 +642,28 @@ static BOOL shouldUsePressAndHold() { { AWT_ASSERT_APPKIT_THREAD; JNIEnv *env = [ThreadUtilities getJNIEnv]; - + (*env)->PushLocalFrame(env, 4); - + id result = [[self getAxData:env] accessibilityHitTest:point withEnv:env]; - + (*env)->PopLocalFrame(env, NULL); - + return result; } - (id)accessibilityFocusedUIElement { AWT_ASSERT_APPKIT_THREAD; - + JNIEnv *env = [ThreadUtilities getJNIEnv]; - + (*env)->PushLocalFrame(env, 4); - + id result = [[self getAxData:env] accessibilityFocusedUIElement]; - + (*env)->PopLocalFrame(env, NULL); - + return result; } @@ -702,12 +702,12 @@ static BOOL shouldUsePressAndHold() { - (id)validRequestorForSendType:(NSString *)sendType returnType:(NSString *)returnType { if ([[self window] firstResponder] != self) return nil; // let AWT components handle themselves - + if ([sendType isEqual:NSStringPboardType] || [returnType isEqual:NSStringPboardType]) { NSString *selectedText = [self accessibleSelectedText]; if (selectedText) return self; } - + return nil; } @@ -719,13 +719,13 @@ static BOOL shouldUsePressAndHold() { [pboard declareTypes:[NSArray arrayWithObject:NSStringPboardType] owner:nil]; return [pboard setString:[self accessibleSelectedText] forType:NSStringPboardType]; } - + if ([types containsObject:NSRTFDPboardType]) { [pboard declareTypes:[NSArray arrayWithObject:NSRTFDPboardType] owner:nil]; return [pboard setData:[self accessibleSelectedTextAsRTFD] forType:NSRTFDPboardType]; } - + return NO; } @@ -737,17 +737,17 @@ static BOOL shouldUsePressAndHold() { NSString *text = [pboard stringForType:NSStringPboardType]; return [self replaceAccessibleTextSelection:text]; } - + if ([[pboard types] containsObject:NSRTFDPboardType]) { NSData *rtfdData = [pboard dataForType:NSRTFDPboardType]; NSAttributedString *styledText = [[NSAttributedString alloc] initWithRTFD:rtfdData documentAttributes:NULL]; NSString *text = [styledText string]; [styledText release]; - + return [self replaceAccessibleTextSelection:text]; } - + return NO; } @@ -769,7 +769,7 @@ static BOOL shouldUsePressAndHold() { // If draggingSource is nil route the message to the superclass (if responding to the selector): CDragSource *dragSource = self._dragSource; NSDragOperation dragOp = NSDragOperationNone; - + if (dragSource != nil) { dragOp = [dragSource draggingSourceOperationMaskForLocal:flag]; } @@ -781,7 +781,7 @@ static BOOL shouldUsePressAndHold() { // If draggingSource is nil route the message to the superclass (if responding to the selector): CDragSource *dragSource = self._dragSource; NSArray* array = nil; - + if (dragSource != nil) { array = [dragSource namesOfPromisedFilesDroppedAtDestination:dropDestination]; } @@ -792,7 +792,7 @@ static BOOL shouldUsePressAndHold() { { // If draggingSource is nil route the message to the superclass (if responding to the selector): CDragSource *dragSource = self._dragSource; - + if (dragSource != nil) { [dragSource draggedImage:image beganAt:screenPoint]; } @@ -802,7 +802,7 @@ static BOOL shouldUsePressAndHold() { { // If draggingSource is nil route the message to the superclass (if responding to the selector): CDragSource *dragSource = self._dragSource; - + if (dragSource != nil) { [dragSource draggedImage:image endedAt:screenPoint operation:operation]; } @@ -812,7 +812,7 @@ static BOOL shouldUsePressAndHold() { { // If draggingSource is nil route the message to the superclass (if responding to the selector): CDragSource *dragSource = self._dragSource; - + if (dragSource != nil) { [dragSource draggedImage:image movedTo:screenPoint]; } @@ -823,7 +823,7 @@ static BOOL shouldUsePressAndHold() { // If draggingSource is nil route the message to the superclass (if responding to the selector): CDragSource *dragSource = self._dragSource; BOOL result = FALSE; - + if (dragSource != nil) { result = [dragSource ignoreModifierKeysWhileDragging]; } @@ -839,7 +839,7 @@ static BOOL shouldUsePressAndHold() { // If draggingDestination is nil route the message to the superclass: CDropTarget *dropTarget = self._dropTarget; NSDragOperation dragOp = NSDragOperationNone; - + if (dropTarget != nil) { dragOp = [dropTarget draggingEntered:sender]; } @@ -851,7 +851,7 @@ static BOOL shouldUsePressAndHold() { // If draggingDestination is nil route the message to the superclass: CDropTarget *dropTarget = self._dropTarget; NSDragOperation dragOp = NSDragOperationNone; - + if (dropTarget != nil) { dragOp = [dropTarget draggingUpdated:sender]; } @@ -862,7 +862,7 @@ static BOOL shouldUsePressAndHold() { { // If draggingDestination is nil route the message to the superclass: CDropTarget *dropTarget = self._dropTarget; - + if (dropTarget != nil) { [dropTarget draggingExited:sender]; } @@ -873,7 +873,7 @@ static BOOL shouldUsePressAndHold() { // If draggingDestination is nil route the message to the superclass: CDropTarget *dropTarget = self._dropTarget; BOOL result = FALSE; - + if (dropTarget != nil) { result = [dropTarget prepareForDragOperation:sender]; } @@ -885,7 +885,7 @@ static BOOL shouldUsePressAndHold() { // If draggingDestination is nil route the message to the superclass: CDropTarget *dropTarget = self._dropTarget; BOOL result = FALSE; - + if (dropTarget != nil) { result = [dropTarget performDragOperation:sender]; } @@ -896,7 +896,7 @@ static BOOL shouldUsePressAndHold() { { // If draggingDestination is nil route the message to the superclass: CDropTarget *dropTarget = self._dropTarget; - + if (dropTarget != nil) { [dropTarget concludeDragOperation:sender]; } @@ -906,7 +906,7 @@ static BOOL shouldUsePressAndHold() { { // If draggingDestination is nil route the message to the superclass: CDropTarget *dropTarget = self._dropTarget; - + if (dropTarget != nil) { [dropTarget draggingEnded:sender]; } @@ -924,20 +924,20 @@ JNF_CLASS_CACHE(jc_CInputMethod, "sun/lwawt/macosx/CInputMethod"); #ifdef IM_DEBUG fprintf(stderr, "AWTView InputMethod Selector Called : [insertText]: %s\n", [aString UTF8String]); #endif // IM_DEBUG - + if (fInputMethodLOCKABLE == NULL) { return; } - + // Insert happens at the end of PAH fInPressAndHold = NO; - + // insertText gets called when the user commits text generated from an input method. It also gets // called during ordinary input as well. We only need to send an input method event when we have marked // text, or 'text in progress'. We also need to send the event if we get an insert text out of the blue! // (i.e., when the user uses the Character palette or Inkwell), or when the string to insert is a complex // Unicode value. - + NSMutableString * useString = [self parseString:aString]; NSUInteger utf16Length = [useString lengthOfBytesUsingEncoding:NSUTF16StringEncoding]; NSUInteger utf8Length = [useString lengthOfBytesUsingEncoding:NSUTF8StringEncoding]; @@ -946,22 +946,22 @@ JNF_CLASS_CACHE(jc_CInputMethod, "sun/lwawt/macosx/CInputMethod"); ((utf8Length > 1) && [self isCodePointInUnicodeBlockNeedingIMEvent:[useString characterAtIndex:0]])) { aStringIsComplex = YES; } - + if ([self hasMarkedText] || !fProcessingKeystroke || aStringIsComplex) { JNIEnv *env = [ThreadUtilities getJNIEnv]; - + static JNF_MEMBER_CACHE(jm_selectPreviousGlyph, jc_CInputMethod, "selectPreviousGlyph", "()V"); // We need to select the previous glyph so that it is overwritten. if (fPAHNeedsToSelect) { JNFCallVoidMethod(env, fInputMethodLOCKABLE, jm_selectPreviousGlyph); fPAHNeedsToSelect = NO; } - + static JNF_MEMBER_CACHE(jm_insertText, jc_CInputMethod, "insertText", "(Ljava/lang/String;)V"); jstring insertedText = JNFNSToJavaString(env, useString); JNFCallVoidMethod(env, fInputMethodLOCKABLE, jm_insertText, insertedText); // AWT_THREADING Safe (AWTRunLoopMode) (*env)->DeleteLocalRef(env, insertedText); - + // The input method event will create psuedo-key events for each character in the committed string. // We also don't want to send the character that triggered the insertText, usually a return. [3337563] fKeyEventsNeeded = NO; @@ -993,7 +993,7 @@ JNF_CLASS_CACHE(jc_CInputMethod, "sun/lwawt/macosx/CInputMethod"); { if (!fInputMethodLOCKABLE) return; - + BOOL isAttributedString = [aString isKindOfClass:[NSAttributedString class]]; NSAttributedString *attrString = (isAttributedString ? (NSAttributedString *)aString : nil); NSString *incomingString = (isAttributedString ? [aString string] : aString); @@ -1004,14 +1004,14 @@ JNF_CLASS_CACHE(jc_CInputMethod, "sun/lwawt/macosx/CInputMethod"); static JNF_MEMBER_CACHE(jm_addAttribute, jc_CInputMethod, "addAttribute", "(ZZII)V"); static JNF_MEMBER_CACHE(jm_dispatchText, jc_CInputMethod, "dispatchText", "(IIZ)V"); JNIEnv *env = [ThreadUtilities getJNIEnv]; - + // NSInputContext already did the analysis of the TSM event and created attributes indicating // the underlining and color that should be done to the string. We need to look at the underline // style and color to determine what kind of Java hilighting needs to be done. jstring inProcessText = JNFNSToJavaString(env, incomingString); JNFCallVoidMethod(env, fInputMethodLOCKABLE, jm_startIMUpdate, inProcessText); // AWT_THREADING Safe (AWTRunLoopMode) (*env)->DeleteLocalRef(env, inProcessText); - + if (isAttributedString) { NSUInteger length; NSRange effectiveRange; @@ -1027,25 +1027,25 @@ JNF_CLASS_CACHE(jc_CInputMethod, "sun/lwawt/macosx/CInputMethod"); (NSNumber *)[attributes objectForKey:NSUnderlineStyleAttributeName]; NSInteger underlineSize = [underlineSizeObj integerValue]; isThickUnderline = (underlineSize > 1); - + NSColor *underlineColorObj = (NSColor *)[attributes objectForKey:NSUnderlineColorAttributeName]; isGray = !([underlineColorObj isEqual:[NSColor blackColor]]); - + JNFCallVoidMethod(env, fInputMethodLOCKABLE, jm_addAttribute, isThickUnderline, isGray, effectiveRange.location, effectiveRange.length); // AWT_THREADING Safe (AWTRunLoopMode) } } } - + static JNF_MEMBER_CACHE(jm_selectPreviousGlyph, jc_CInputMethod, "selectPreviousGlyph", "()V"); // We need to select the previous glyph so that it is overwritten. if (fPAHNeedsToSelect) { JNFCallVoidMethod(env, fInputMethodLOCKABLE, jm_selectPreviousGlyph); fPAHNeedsToSelect = NO; } - + JNFCallVoidMethod(env, fInputMethodLOCKABLE, jm_dispatchText, selectionRange.location, selectionRange.length, JNI_FALSE); // AWT_THREADING Safe (AWTRunLoopMode) - + // If the marked text is being cleared (zero-length string) don't handle the key event. if ([incomingString length] == 0) { fKeyEventsNeeded = NO; @@ -1057,16 +1057,16 @@ JNF_CLASS_CACHE(jc_CInputMethod, "sun/lwawt/macosx/CInputMethod"); #ifdef IM_DEBUG fprintf(stderr, "AWTView InputMethod Selector Called : [unmarkText]\n"); #endif // IM_DEBUG - + if (!fInputMethodLOCKABLE) { return; } - + // unmarkText cancels any input in progress and commits it to the text field. static JNF_MEMBER_CACHE(jm_unmarkText, jc_CInputMethod, "unmarkText", "()V"); JNIEnv *env = [ThreadUtilities getJNIEnv]; JNFCallVoidMethod(env, fInputMethodLOCKABLE, jm_unmarkText); // AWT_THREADING Safe (AWTRunLoopMode) - + } - (BOOL) hasMarkedText @@ -1074,24 +1074,24 @@ JNF_CLASS_CACHE(jc_CInputMethod, "sun/lwawt/macosx/CInputMethod"); #ifdef IM_DEBUG fprintf(stderr, "AWTView InputMethod Selector Called : [hasMarkedText]\n"); #endif // IM_DEBUG - + if (!fInputMethodLOCKABLE) { return NO; } - + static JNF_MEMBER_CACHE(jf_fCurrentText, jc_CInputMethod, "fCurrentText", "Ljava/text/AttributedString;"); static JNF_MEMBER_CACHE(jf_fCurrentTextLength, jc_CInputMethod, "fCurrentTextLength", "I"); JNIEnv *env = [ThreadUtilities getJNIEnv]; jobject currentText = JNFGetObjectField(env, fInputMethodLOCKABLE, jf_fCurrentText); - + jint currentTextLength = JNFGetIntField(env, fInputMethodLOCKABLE, jf_fCurrentTextLength); - + BOOL hasMarkedText = (currentText != NULL && currentTextLength > 0); - + if (currentText != NULL) { (*env)->DeleteLocalRef(env, currentText); } - + return hasMarkedText; } @@ -1100,7 +1100,7 @@ JNF_CLASS_CACHE(jc_CInputMethod, "sun/lwawt/macosx/CInputMethod"); #ifdef IM_DEBUG fprintf(stderr, "AWTView InputMethod Selector Called : [conversationIdentifier]\n"); #endif // IM_DEBUG - + return (NSInteger) self; } @@ -1112,16 +1112,16 @@ JNF_CLASS_CACHE(jc_CInputMethod, "sun/lwawt/macosx/CInputMethod"); #ifdef IM_DEBUG fprintf(stderr, "AWTView InputMethod Selector Called : [attributedSubstringFromRange] location=%lu, length=%lu\n", (unsigned long)theRange.location, (unsigned long)theRange.length); #endif // IM_DEBUG - + static JNF_MEMBER_CACHE(jm_substringFromRange, jc_CInputMethod, "attributedSubstringFromRange", "(II)Ljava/lang/String;"); JNIEnv *env = [ThreadUtilities getJNIEnv]; jobject theString = JNFCallObjectMethod(env, fInputMethodLOCKABLE, jm_substringFromRange, theRange.location, theRange.length); // AWT_THREADING Safe (AWTRunLoopMode) - + id result = [[[NSAttributedString alloc] initWithString:JNFJavaToNSString(env, theString)] autorelease]; #ifdef IM_DEBUG NSLog(@"attributedSubstringFromRange returning \"%@\"", result); #endif // IM_DEBUG - + (*env)->DeleteLocalRef(env, theString); return result; } @@ -1131,24 +1131,24 @@ JNF_CLASS_CACHE(jc_CInputMethod, "sun/lwawt/macosx/CInputMethod"); */ - (NSRange) markedRange { - + #ifdef IM_DEBUG fprintf(stderr, "AWTView InputMethod Selector Called : [markedRange]\n"); #endif // IM_DEBUG - + if (!fInputMethodLOCKABLE) { return NSMakeRange(NSNotFound, 0); } - + static JNF_MEMBER_CACHE(jm_markedRange, jc_CInputMethod, "markedRange", "()[I"); JNIEnv *env = [ThreadUtilities getJNIEnv]; jarray array; jboolean isCopy; jint *_array; NSRange range = NSMakeRange(NSNotFound, 0); - + array = JNFCallObjectMethod(env, fInputMethodLOCKABLE, jm_markedRange); // AWT_THREADING Safe (AWTRunLoopMode) - + if (array) { _array = (*env)->GetIntArrayElements(env, array, &isCopy); if (_array != NULL) { @@ -1162,7 +1162,7 @@ JNF_CLASS_CACHE(jc_CInputMethod, "sun/lwawt/macosx/CInputMethod"); } (*env)->DeleteLocalRef(env, array); } - + return range; } @@ -1174,18 +1174,18 @@ JNF_CLASS_CACHE(jc_CInputMethod, "sun/lwawt/macosx/CInputMethod"); if (!fInputMethodLOCKABLE) { return NSMakeRange(NSNotFound, 0); } - + static JNF_MEMBER_CACHE(jm_selectedRange, jc_CInputMethod, "selectedRange", "()[I"); JNIEnv *env = [ThreadUtilities getJNIEnv]; jarray array; jboolean isCopy; jint *_array; NSRange range = NSMakeRange(NSNotFound, 0); - + #ifdef IM_DEBUG fprintf(stderr, "AWTView InputMethod Selector Called : [selectedRange]\n"); #endif // IM_DEBUG - + array = JNFCallObjectMethod(env, fInputMethodLOCKABLE, jm_selectedRange); // AWT_THREADING Safe (AWTRunLoopMode) if (array) { _array = (*env)->GetIntArrayElements(env, array, &isCopy); @@ -1196,7 +1196,7 @@ JNF_CLASS_CACHE(jc_CInputMethod, "sun/lwawt/macosx/CInputMethod"); } (*env)->DeleteLocalRef(env, array); } - + return range; } @@ -1207,7 +1207,7 @@ JNF_CLASS_CACHE(jc_CInputMethod, "sun/lwawt/macosx/CInputMethod"); if (!fInputMethodLOCKABLE) { return NSZeroRect; } - + static JNF_MEMBER_CACHE(jm_firstRectForCharacterRange, jc_CInputMethod, "firstRectForCharacterRange", "(I)[I"); JNIEnv *env = [ThreadUtilities getJNIEnv]; @@ -1215,16 +1215,16 @@ JNF_CLASS_CACHE(jc_CInputMethod, "sun/lwawt/macosx/CInputMethod"); jboolean isCopy; jint *_array; NSRect rect; - + #ifdef IM_DEBUG fprintf(stderr, "AWTView InputMethod Selector Called : [firstRectForCharacterRange:] location=%lu, length=%lu\n", (unsigned long)theRange.location, (unsigned long)theRange.length); #endif // IM_DEBUG - + array = JNFCallObjectMethod(env, fInputMethodLOCKABLE, jm_firstRectForCharacterRange, theRange.location); // AWT_THREADING Safe (AWTRunLoopMode) - + _array = (*env)->GetIntArrayElements(env, array, &isCopy); if (_array) { rect = ConvertNSScreenRect(env, NSMakeRect(_array[0], _array[1], _array[2], _array[3])); @@ -1233,7 +1233,7 @@ JNF_CLASS_CACHE(jc_CInputMethod, "sun/lwawt/macosx/CInputMethod"); rect = NSZeroRect; } (*env)->DeleteLocalRef(env, array); - + #ifdef IM_DEBUG fprintf(stderr, "firstRectForCharacterRange returning x=%f, y=%f, width=%f, height=%f\n", @@ -1250,23 +1250,23 @@ JNF_CLASS_CACHE(jc_CInputMethod, "sun/lwawt/macosx/CInputMethod"); if (!fInputMethodLOCKABLE) { return NSNotFound; } - + static JNF_MEMBER_CACHE(jm_characterIndexForPoint, jc_CInputMethod, "characterIndexForPoint", "(II)I"); JNIEnv *env = [ThreadUtilities getJNIEnv]; - + NSPoint flippedLocation = ConvertNSScreenPoint(env, thePoint); - + #ifdef IM_DEBUG fprintf(stderr, "AWTView InputMethod Selector Called : [characterIndexForPoint:(NSPoint)thePoint] x=%f, y=%f\n", flippedLocation.x, flippedLocation.y); #endif // IM_DEBUG - + jint index = JNFCallIntMethod(env, fInputMethodLOCKABLE, jm_characterIndexForPoint, (jint)flippedLocation.x, (jint)flippedLocation.y); // AWT_THREADING Safe (AWTRunLoopMode) - + #ifdef IM_DEBUG fprintf(stderr, "characterIndexForPoint returning %ld\n", index); #endif // IM_DEBUG - + if (index == -1) { return NSNotFound; } else { @@ -1279,7 +1279,7 @@ JNF_CLASS_CACHE(jc_CInputMethod, "sun/lwawt/macosx/CInputMethod"); #ifdef IM_DEBUG fprintf(stderr, "AWTView InputMethod Selector Called : [validAttributesForMarkedText]\n"); #endif // IM_DEBUG - + return [NSArray array]; } @@ -1288,14 +1288,14 @@ JNF_CLASS_CACHE(jc_CInputMethod, "sun/lwawt/macosx/CInputMethod"); #ifdef IM_DEBUG fprintf(stderr, "AWTView InputMethod Selector Called : [setInputMethod]\n"); #endif // IM_DEBUG - + JNIEnv *env = [ThreadUtilities getJNIEnv]; - + // Get rid of the old one if (fInputMethodLOCKABLE) { JNFDeleteGlobalRef(env, fInputMethodLOCKABLE); } - + // Save a global ref to the new input method. if (inputMethod != NULL) fInputMethodLOCKABLE = JNFNewGlobalRef(env, inputMethod); @@ -1308,7 +1308,7 @@ JNF_CLASS_CACHE(jc_CInputMethod, "sun/lwawt/macosx/CInputMethod"); #ifdef IM_DEBUG fprintf(stderr, "AWTView InputMethod Selector Called : [abandonInput]\n"); #endif // IM_DEBUG - + [ThreadUtilities performOnMainThread:@selector(markedTextAbandoned:) on:[NSInputManager currentInputManager] withObject:self waitUntilDone:YES]; [self unmarkText]; } @@ -1330,22 +1330,22 @@ Java_sun_lwawt_macosx_CPlatformView_nativeCreateView (JNIEnv *env, jobject obj, jint originX, jint originY, jint width, jint height, jlong windowLayerPtr) { __block AWTView *newView = nil; - + JNF_COCOA_ENTER(env); - + NSRect rect = NSMakeRect(originX, originY, width, height); jobject cPlatformView = (*env)->NewWeakGlobalRef(env, obj); - + [ThreadUtilities performOnMainThreadWaiting:YES block:^(){ - + CALayer *windowLayer = jlong_to_ptr(windowLayerPtr); newView = [[AWTView alloc] initWithRect:rect platformView:cPlatformView windowLayer:windowLayer]; }]; - + JNF_COCOA_EXIT(env); - + return ptr_to_jlong(newView); } @@ -1360,21 +1360,21 @@ Java_sun_lwawt_macosx_CPlatformView_nativeSetAutoResizable (JNIEnv *env, jclass cls, jlong viewPtr, jboolean toResize) { JNF_COCOA_ENTER(env); - + NSView *view = (NSView *)jlong_to_ptr(viewPtr); - + [ThreadUtilities performOnMainThreadWaiting:NO block:^(){ - + if (toResize) { [view setAutoresizingMask: NSViewHeightSizable | NSViewWidthSizable]; } else { [view setAutoresizingMask: NSViewMinYMargin | NSViewMaxXMargin]; } - + if ([view superview] != nil) { [[view superview] setAutoresizesSubviews:(BOOL)toResize]; } - + }]; JNF_COCOA_EXIT(env); } @@ -1390,19 +1390,19 @@ Java_sun_lwawt_macosx_CPlatformView_nativeGetNSViewDisplayID (JNIEnv *env, jclass cls, jlong viewPtr) { __block jint ret; //CGDirectDisplayID - + JNF_COCOA_ENTER(env); - + NSView *view = (NSView *)jlong_to_ptr(viewPtr); NSWindow *window = [view window]; - + [ThreadUtilities performOnMainThreadWaiting:YES block:^(){ - + ret = (jint)[[AWTWindow getNSWindowDisplayID_AppKitThread: window] intValue]; }]; - + JNF_COCOA_EXIT(env); - + return ret; } @@ -1417,25 +1417,25 @@ Java_sun_lwawt_macosx_CPlatformView_nativeGetLocationOnScreen (JNIEnv *env, jclass cls, jlong viewPtr) { jobject jRect = NULL; - + JNF_COCOA_ENTER(env); - + __block NSRect rect = NSZeroRect; - + NSView *view = (NSView *)jlong_to_ptr(viewPtr); [ThreadUtilities performOnMainThreadWaiting:YES block:^(){ - + NSRect viewBounds = [view bounds]; NSRect frameInWindow = [view convertRect:viewBounds toView:nil]; rect = [[view window] convertRectToScreen:frameInWindow]; - NSRect screenRect = [[NSScreen mainScreen] frame]; //Convert coordinates to top-left corner origin - rect.origin.y = screenRect.size.height - rect.origin.y - viewBounds.size.height; + rect = ConvertNSScreenRect(NULL, rect); + }]; jRect = NSToJavaRect(env, rect); - + JNF_COCOA_EXIT(env); - + return jRect; } @@ -1449,17 +1449,17 @@ JNIEXPORT jboolean JNICALL Java_sun_lwawt_macosx_CPlatformView_nativeIsViewUnder (JNIEnv *env, jclass clazz, jlong viewPtr) { __block jboolean underMouse = JNI_FALSE; - + JNF_COCOA_ENTER(env); - + NSView *nsView = OBJC(viewPtr); - [ThreadUtilities performOnMainThreadWaiting:YES block:^(){ + [ThreadUtilities performOnMainThreadWaiting:YES block:^(){ NSPoint ptWindowCoords = [[nsView window] mouseLocationOutsideOfEventStream]; NSPoint ptViewCoords = [nsView convertPoint:ptWindowCoords fromView:nil]; underMouse = [nsView hitTest:ptViewCoords] != nil; }]; - + JNF_COCOA_EXIT(env); - + return underMouse; } diff --git a/src/java.desktop/macosx/native/libawt_lwawt/awt/CTrayIcon.m b/src/java.desktop/macosx/native/libawt_lwawt/awt/CTrayIcon.m index bfce2fde5c7..aa9abdba104 100644 --- a/src/java.desktop/macosx/native/libawt_lwawt/awt/CTrayIcon.m +++ b/src/java.desktop/macosx/native/libawt_lwawt/awt/CTrayIcon.m @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, 2017, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -134,8 +134,7 @@ static NSSize ScaledImageSizeForStatusBar(NSSize imageSize, BOOL autosize) { NSPoint absP = [NSEvent mouseLocation]; NSEventType type = [event type]; - NSRect screenRect = [[NSScreen mainScreen] frame]; - absP.y = screenRect.size.height - absP.y; + absP = ConvertNSScreenPoint(NULL, absP); jint clickCount; clickCount = [event clickCount]; @@ -179,15 +178,15 @@ static NSSize ScaledImageSizeForStatusBar(NSSize imageSize, BOOL autosize) { isHighlighted = NO; image = nil; trackingArea = nil; - + [self addTrackingArea]; - + return self; } - (void)addTrackingArea { - NSTrackingAreaOptions options = NSTrackingMouseMoved | - NSTrackingInVisibleRect | + NSTrackingAreaOptions options = NSTrackingMouseMoved | + NSTrackingInVisibleRect | NSTrackingActiveAlways; trackingArea = [[NSTrackingArea alloc] initWithRect: CGRectZero options: options From 6e6996cd6cd0d48a7bfeed9bca0dba787fc0187e Mon Sep 17 00:00:00 2001 From: Pankaj Bansal Date: Mon, 23 Oct 2017 16:55:52 +0530 Subject: [PATCH 06/39] 8145795: [PIT] java/awt/Window/ScreenLocation/ScreenLocationTest.java fails (can assign Integer.MAX_VALUE to Window dimensions) Reviewed-by: serb, pkbalakr --- .../sun/awt/X11/XDragSourceContextPeer.java | 5 ++-- .../unix/classes/sun/awt/X11/XlibUtil.java | 4 +++- .../classes/sun/awt/X11GraphicsConfig.java | 5 ++-- .../windows/awt_Win32GraphicsDevice.cpp | 23 +++++++++++++++---- .../libawt/windows/awt_Win32GraphicsDevice.h | 1 + .../ScreenLocation/ScreenLocationTest.java | 4 ++-- 6 files changed, 31 insertions(+), 11 deletions(-) diff --git a/src/java.desktop/unix/classes/sun/awt/X11/XDragSourceContextPeer.java b/src/java.desktop/unix/classes/sun/awt/X11/XDragSourceContextPeer.java index 5dcf06c59bf..53073057cb6 100644 --- a/src/java.desktop/unix/classes/sun/awt/X11/XDragSourceContextPeer.java +++ b/src/java.desktop/unix/classes/sun/awt/X11/XDragSourceContextPeer.java @@ -38,6 +38,7 @@ import java.awt.dnd.InvalidDnDOperationException; import java.util.*; +import sun.java2d.pipe.Region; import sun.util.logging.PlatformLogger; import sun.awt.dnd.SunDragSourceContextPeer; @@ -811,10 +812,10 @@ public final class XDragSourceContextPeer } public int scaleUp(int x) { - return x * windowScale; + return Region.clipRound(x * (double)windowScale); } public int scaleDown(int x) { - return x / windowScale; + return Region.clipRound(x / (double)windowScale); } } diff --git a/src/java.desktop/unix/classes/sun/awt/X11/XlibUtil.java b/src/java.desktop/unix/classes/sun/awt/X11/XlibUtil.java index 27d6eef57d7..ce9c0269671 100644 --- a/src/java.desktop/unix/classes/sun/awt/X11/XlibUtil.java +++ b/src/java.desktop/unix/classes/sun/awt/X11/XlibUtil.java @@ -38,6 +38,8 @@ import sun.awt.X11GraphicsConfig; import sun.awt.X11GraphicsDevice; import sun.awt.X11GraphicsEnvironment; +import sun.java2d.pipe.Region; + /* * This class is a collection of utility methods that operate * with native windows. @@ -414,6 +416,6 @@ public class XlibUtil } static int scaleDown(int x, int scale) { - return x / scale; + return Region.clipRound(x / (double)scale); } } diff --git a/src/java.desktop/unix/classes/sun/awt/X11GraphicsConfig.java b/src/java.desktop/unix/classes/sun/awt/X11GraphicsConfig.java index 27b97818dee..42ece1749be 100644 --- a/src/java.desktop/unix/classes/sun/awt/X11GraphicsConfig.java +++ b/src/java.desktop/unix/classes/sun/awt/X11GraphicsConfig.java @@ -49,6 +49,7 @@ import sun.java2d.SurfaceData; import sun.java2d.loops.RenderLoops; import sun.java2d.loops.SurfaceType; import sun.java2d.loops.CompositeType; +import sun.java2d.pipe.Region; import sun.java2d.x11.X11SurfaceData; import sun.awt.image.OffScreenImage; import sun.awt.image.SunVolatileImage; @@ -265,11 +266,11 @@ public class X11GraphicsConfig extends GraphicsConfiguration } public int scaleUp(int x) { - return x * getScale(); + return Region.clipRound(x * (double)getScale()); } public int scaleDown(int x) { - return x / getScale(); + return Region.clipRound(x / (double)getScale()); } /** diff --git a/src/java.desktop/windows/native/libawt/windows/awt_Win32GraphicsDevice.cpp b/src/java.desktop/windows/native/libawt/windows/awt_Win32GraphicsDevice.cpp index b0e593adba2..186c7f99a92 100644 --- a/src/java.desktop/windows/native/libawt/windows/awt_Win32GraphicsDevice.cpp +++ b/src/java.desktop/windows/native/libawt/windows/awt_Win32GraphicsDevice.cpp @@ -632,22 +632,37 @@ void AwtWin32GraphicsDevice::SetScale(float sx, float sy) int AwtWin32GraphicsDevice::ScaleUpX(int x) { - return (int)ceil(x * scaleX); + return CheckIntLimits(x * scaleX); } int AwtWin32GraphicsDevice::ScaleUpY(int y) { - return (int)ceil(y * scaleY); + return CheckIntLimits(y * scaleY); } int AwtWin32GraphicsDevice::ScaleDownX(int x) { - return (int)ceil(x / scaleX); + return CheckIntLimits(x / scaleX); } int AwtWin32GraphicsDevice::ScaleDownY(int y) { - return (int)ceil(y / scaleY); + return CheckIntLimits(y / scaleY); +} + +int AwtWin32GraphicsDevice::CheckIntLimits(double value) +{ + if (value < INT_MIN) + { + return INT_MIN; + } + + if (value > INT_MAX) + { + return INT_MAX; + } + + return (int)ceil(value); } void AwtWin32GraphicsDevice::InitDesktopScales() diff --git a/src/java.desktop/windows/native/libawt/windows/awt_Win32GraphicsDevice.h b/src/java.desktop/windows/native/libawt/windows/awt_Win32GraphicsDevice.h index 250df7af727..699d3b415ec 100644 --- a/src/java.desktop/windows/native/libawt/windows/awt_Win32GraphicsDevice.h +++ b/src/java.desktop/windows/native/libawt/windows/awt_Win32GraphicsDevice.h @@ -119,6 +119,7 @@ private: float scaleY; static HDC MakeDCFromMonitor(HMONITOR); + static int CheckIntLimits(double value); }; #endif AWT_WIN32GRAPHICSDEVICE_H diff --git a/test/jdk/java/awt/Window/ScreenLocation/ScreenLocationTest.java b/test/jdk/java/awt/Window/ScreenLocation/ScreenLocationTest.java index ab0baa7f4d5..c014864302d 100644 --- a/test/jdk/java/awt/Window/ScreenLocation/ScreenLocationTest.java +++ b/test/jdk/java/awt/Window/ScreenLocation/ScreenLocationTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -24,7 +24,7 @@ /* * @test * @key headful - * @bug 8011616 + * @bug 8011616 8145795 * @summary JWindow.getLocation and JWindow.getLocationOnScreen return different * values on Unity * @author Semyon Sadetsky From 00fcd16ee700a96009890be0eae199ed9dca1c5b Mon Sep 17 00:00:00 2001 From: Semyon Sadetsky Date: Tue, 24 Oct 2017 08:37:11 -0700 Subject: [PATCH 07/39] 8188081: Text selection does not clear after focus is lost Reviewed-by: serb, psadhukhan --- .../javax/swing/text/DefaultCaret.java | 20 +-- .../jdk/javax/swing/JTextPane/bug8025082.java | 109 ------------- .../HidingSelection/HidingSelectionTest.java | 152 ++++++++++++++++++ 3 files changed, 157 insertions(+), 124 deletions(-) delete mode 100644 test/jdk/javax/swing/JTextPane/bug8025082.java create mode 100644 test/jdk/javax/swing/text/DefaultCaret/HidingSelection/HidingSelectionTest.java diff --git a/src/java.desktop/share/classes/javax/swing/text/DefaultCaret.java b/src/java.desktop/share/classes/javax/swing/text/DefaultCaret.java index 8d973e63b65..6deb037861d 100644 --- a/src/java.desktop/share/classes/javax/swing/text/DefaultCaret.java +++ b/src/java.desktop/share/classes/javax/swing/text/DefaultCaret.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2017, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -352,6 +352,7 @@ public class DefaultCaret extends Rectangle implements Caret, FocusListener, Mou setVisible(true); } setSelectionVisible(true); + updateSystemSelection(); } } @@ -365,7 +366,9 @@ public class DefaultCaret extends Rectangle implements Caret, FocusListener, Mou */ public void focusLost(FocusEvent e) { setVisible(false); - setSelectionVisible(ownsSelection || e.isTemporary()); + setSelectionVisible((e.getCause() == FocusEvent.Cause.ACTIVATION || + e.getOppositeComponent() instanceof JRootPane) && + (ownsSelection || e.isTemporary())); } @@ -866,7 +869,6 @@ public class DefaultCaret extends Rectangle implements Caret, FocusListener, Mou Highlighter.HighlightPainter p = getSelectionPainter(); try { selectionTag = h.addHighlight(p0, p1, p); - updateOwnsSelection(); } catch (BadLocationException bl) { selectionTag = null; } @@ -877,7 +879,6 @@ public class DefaultCaret extends Rectangle implements Caret, FocusListener, Mou Highlighter h = component.getHighlighter(); h.removeHighlight(selectionTag); selectionTag = null; - updateOwnsSelection(); } } } @@ -1119,7 +1120,6 @@ public class DefaultCaret extends Rectangle implements Caret, FocusListener, Mou if (selectionTag != null) { h.removeHighlight(selectionTag); selectionTag = null; - updateOwnsSelection(); } // otherwise, change or add the highlight } else { @@ -1130,7 +1130,6 @@ public class DefaultCaret extends Rectangle implements Caret, FocusListener, Mou Highlighter.HighlightPainter p = getSelectionPainter(); selectionTag = h.addHighlight(p0, p1, p); } - updateOwnsSelection(); } catch (BadLocationException e) { throw new StateInvariantError("Bad caret position"); } @@ -1181,7 +1180,6 @@ public class DefaultCaret extends Rectangle implements Caret, FocusListener, Mou if (this.dot != dot || this.dotBias != dotBias || selectionTag != null || forceCaretPositionChange) { changeCaretPosition(dot, dotBias); - updateOwnsSelection(); } this.markBias = this.dotBias; this.markLTR = dotLTR; @@ -1189,7 +1187,6 @@ public class DefaultCaret extends Rectangle implements Caret, FocusListener, Mou if ((h != null) && (selectionTag != null)) { h.removeHighlight(selectionTag); selectionTag = null; - updateOwnsSelection(); } } @@ -1940,13 +1937,6 @@ public class DefaultCaret extends Rectangle implements Caret, FocusListener, Mou } } - /** - * Updates ownsSelection based on text selection in the caret. - */ - private void updateOwnsSelection() { - ownsSelection = (selectionTag != null) - && SwingUtilities2.canAccessSystemClipboard(); - } private class DefaultFilterBypass extends NavigationFilter.FilterBypass { public Caret getCaret() { diff --git a/test/jdk/javax/swing/JTextPane/bug8025082.java b/test/jdk/javax/swing/JTextPane/bug8025082.java deleted file mode 100644 index aeedbb43146..00000000000 --- a/test/jdk/javax/swing/JTextPane/bug8025082.java +++ /dev/null @@ -1,109 +0,0 @@ -/* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. - * 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 - * @key headful - * @bug 8025082 - * @summary The behaviour of the highlight will be lost after clicking the set - * button. - * @run main bug8025082 - */ -import java.awt.*; -import java.awt.event.ActionEvent; -import java.awt.event.ActionListener; -import java.awt.event.InputEvent; -import javax.swing.*; - -public class bug8025082 { - - private static JButton button; - private static JFrame frame; - - public static void main(String[] args) throws Exception { - Robot robo = new Robot(); - robo.delay(500); - - SwingUtilities.invokeAndWait(new Runnable() { - public void run() { - createUI(); - } - }); - - robo.waitForIdle(); - Point point = getButtonLocationOnScreen(); - robo.mouseMove(point.x, point.y); - robo.mousePress(InputEvent.BUTTON1_MASK); - robo.mouseRelease(InputEvent.BUTTON1_MASK); - robo.waitForIdle(); - - SwingUtilities.invokeAndWait(new Runnable() { - public void run() { - frame.dispose(); - } - }); - } - - private static void createUI() { - frame = new JFrame(); - frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); - frame.setSize(500, 500); - JTextPane textpane = new JTextPane(); - textpane.setText("Select Me"); - textpane.selectAll(); - - JPanel panel = new JPanel(new BorderLayout()); - panel.add(textpane, BorderLayout.CENTER); - button = new JButton("Press Me"); - panel.add(button, BorderLayout.SOUTH); - - button.addActionListener(new ActionListener() { - @Override - public void actionPerformed(ActionEvent e) { - if (!textpane.getCaret().isSelectionVisible()) { - throw new RuntimeException("Highlight removed after " - + "button click"); - } - } - }); - - frame.getContentPane().add(panel); - frame.setLocationRelativeTo(null); - frame.setVisible(true); - } - - private static Point getButtonLocationOnScreen() throws Exception { - final Point[] result = new Point[1]; - - SwingUtilities.invokeAndWait(new Runnable() { - @Override - public void run() { - Point point = button.getLocationOnScreen(); - point.x += button.getWidth() / 2; - point.y += button.getHeight() / 2; - result[0] = point; - } - }); - return result[0]; - } -} diff --git a/test/jdk/javax/swing/text/DefaultCaret/HidingSelection/HidingSelectionTest.java b/test/jdk/javax/swing/text/DefaultCaret/HidingSelection/HidingSelectionTest.java new file mode 100644 index 00000000000..a422eed798b --- /dev/null +++ b/test/jdk/javax/swing/text/DefaultCaret/HidingSelection/HidingSelectionTest.java @@ -0,0 +1,152 @@ +/* + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * 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 javax.swing.*; +import java.awt.*; +import java.awt.event.InputEvent; +import java.awt.image.BufferedImage; + +/** + * @test + * @bug 8188081 + * @summary Text selection does not clear after focus is lost + * @run main HidingSelectionTest + */ + +public class HidingSelectionTest { + + private static JTextField field1; + private static JTextField field2; + private static JFrame frame; + private static Rectangle bounds; + private static JMenu menu; + private static JTextField anotherWindow; + private static Point menuLoc; + private static JFrame frame2; + + public static void main(String[] args) throws Exception { + SwingUtilities.invokeAndWait(() -> { + frame = new JFrame(); + field1 = new JTextField("field1 "); + field2 = new JTextField("field2 "); + field1.setEditable(false); + field2.setEditable(false); + frame.getContentPane().setLayout(new FlowLayout()); + frame.getContentPane().add(field1); + frame.getContentPane().add(field2); + JMenuBar menuBar = new JMenuBar(); + menu = new JMenu("menu"); + menu.add(new JMenuItem("item")); + menuBar.add(menu); + frame.setJMenuBar(menuBar); + frame.pack(); + frame.setVisible(true); + }); + + Robot robot = new Robot(); + robot.waitForIdle(); + robot.delay(200); + SwingUtilities.invokeAndWait(() -> { + bounds = field2.getBounds(); + bounds.setLocation(field2.getLocationOnScreen()); + }); + BufferedImage nosel = robot.createScreenCapture(bounds); + + SwingUtilities.invokeAndWait(field2::requestFocus); + SwingUtilities.invokeAndWait(field2::selectAll); + robot.waitForIdle(); + robot.delay(200); + BufferedImage sel = robot.createScreenCapture(bounds); + + SwingUtilities.invokeAndWait(() -> { + menuLoc = menu.getLocationOnScreen(); + menuLoc.translate(10, 10); + }); + robot.mouseMove(menuLoc.x, menuLoc.y); + robot.mousePress(InputEvent.BUTTON1_DOWN_MASK); + robot.delay(50); + robot.mouseRelease(InputEvent.BUTTON1_DOWN_MASK); + robot.waitForIdle(); + robot.delay(200); + if (!biEqual(robot.createScreenCapture(bounds), sel)) { + throw new RuntimeException("Test fails: menu hides selection"); + } + + SwingUtilities.invokeAndWait( + MenuSelectionManager.defaultManager()::clearSelectedPath); + SwingUtilities.invokeAndWait(field1::requestFocus); + robot.waitForIdle(); + robot.delay(200); + if (!biEqual(robot.createScreenCapture(bounds), nosel)) { + throw new RuntimeException( + "Test fails: focus lost doesn't hide selection"); + } + + SwingUtilities.invokeAndWait(field2::requestFocus); + robot.waitForIdle(); + SwingUtilities.invokeAndWait(() ->{ + frame2 = new JFrame(); + Point loc = frame.getLocationOnScreen(); + loc.translate(0, frame.getHeight()); + frame2.setLocation(loc); + anotherWindow = new JTextField("textField3"); + frame2.add(anotherWindow); + frame2.pack(); + frame2.setVisible(true); + }); + robot.waitForIdle(); + SwingUtilities.invokeAndWait(anotherWindow::requestFocus); + robot.waitForIdle(); + robot.delay(200); + if (biEqual(robot.createScreenCapture(bounds), nosel)) { + throw new RuntimeException( + "Test fails: switch window hides selection"); + } + + SwingUtilities.invokeAndWait(anotherWindow::selectAll); + robot.waitForIdle(); + robot.delay(200); + if (biEqual(robot.createScreenCapture(bounds), sel)) { + throw new RuntimeException( + "Test fails: selection ownership is lost selection is shown"); + } + + SwingUtilities.invokeLater(frame2::dispose); + SwingUtilities.invokeLater(frame::dispose); + } + + static boolean biEqual(BufferedImage i1, BufferedImage i2) { + if (i1.getWidth() == i2.getWidth() && + i1.getHeight() == i2.getHeight()) { + for (int x = 0; x < i1.getWidth(); x++) { + for (int y = 0; y < i1.getHeight(); y++) { + if (i1.getRGB(x, y) != i2.getRGB(x, y)) { + return false; + } + } + } + return true; + } + return false; + } +} From 7ce7347fd2f35af032a65a587bc1107800c75ee9 Mon Sep 17 00:00:00 2001 From: Robert Field Date: Tue, 24 Oct 2017 20:33:36 -0700 Subject: [PATCH 08/39] 8179856: jshell tool: not suitable for pipeline use 8186708: jshell tool: bad load file garbles message and does not abort Reviewed-by: jlahoda --- .../jdk/internal/jshell/tool/JShellTool.java | 114 ++++++++---------- .../jshell/tool/resources/l10n.properties | 13 +- .../langtools/jdk/jshell/StartOptionTest.java | 36 +++++- test/langtools/jdk/jshell/ToolBasicTest.java | 5 - .../jdk/jshell/ToolProviderTest.java | 22 +++- 5 files changed, 114 insertions(+), 76 deletions(-) diff --git a/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/JShellTool.java b/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/JShellTool.java index 1388e5e7480..1d031b5f5b4 100644 --- a/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/JShellTool.java +++ b/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/JShellTool.java @@ -184,6 +184,7 @@ public class JShellTool implements MessageHandler { private IOContext input = null; private boolean regenerateOnDeath = true; private boolean live = false; + private boolean interactiveModeBegun = false; private Options options; SourceCodeAnalysis analysis; @@ -499,9 +500,13 @@ public class JShellTool implements MessageHandler { @Override void msg(String key, Object... args) { - startmsg(key, args); + errormsg(key, args); } + /** + * Parse the command line options. + * @return the options as an Options object, or null if error + */ @Override Options parse(OptionSet options) { if (options.has(argHelp)) { @@ -541,7 +546,7 @@ public class JShellTool implements MessageHandler { if (options.has(argStart)) { List sts = options.valuesOf(argStart); if (options.has("no-startup")) { - startmsg("jshell.err.opt.startup.conflict"); + msg("jshell.err.opt.startup.conflict"); return null; } initialStartup = Startup.fromFileList(sts, "--startup", new InitMessageHandler()); @@ -648,16 +653,6 @@ public class JShellTool implements MessageHandler { } } - /** - * Base output for command output -- no pre- or post-fix - * - * @param printf format - * @param printf args - */ - void rawout(String format, Object... args) { - cmdout.printf(format, args); - } - /** * Must show command output * @@ -666,17 +661,17 @@ public class JShellTool implements MessageHandler { */ @Override public void hard(String format, Object... args) { - rawout(prefix(format), args); + cmdout.printf(prefix(format), args); } - /** + /** * Error command output * * @param format printf format * @param args printf args */ void error(String format, Object... args) { - rawout(prefixError(format), args); + (interactiveModeBegun? cmdout : cmderr).printf(prefixError(format), args); } /** @@ -749,7 +744,8 @@ public class JShellTool implements MessageHandler { /** * Add prefixing/postfixing to embedded newlines in a string, - * bracketing with prefix/postfix + * bracketing with prefix/postfix. No prefixing when non-interactive. + * Result is expected to be the format for a printf. * * @param s the string to prefix * @param pre the string to prepend to each line @@ -760,6 +756,10 @@ public class JShellTool implements MessageHandler { if (s == null) { return ""; } + if (!interactiveModeBegun) { + // messages expect to be new-line terminated (even when not prefixed) + return s + "%n"; + } String pp = s.replaceAll("\\R", post + pre); if (pp.endsWith(post + pre)) { // prevent an extra prefix char and blank line when the string @@ -810,21 +810,7 @@ public class JShellTool implements MessageHandler { */ @Override public void errormsg(String key, Object... args) { - if (isRunningInteractive()) { - rawout(prefixError(messageFormat(key, args))); - } else { - startmsg(key, args); - } - } - - /** - * Print command-line error using resource bundle look-up, MessageFormat - * - * @param key the resource key - * @param args - */ - void startmsg(String key, Object... args) { - cmderr.println(messageFormat(key, args)); + error(messageFormat(key, args)); } /** @@ -847,7 +833,7 @@ public class JShellTool implements MessageHandler { LinkedHashMap::new)); for (Entry e : a2b.entrySet()) { hard("%s", e.getKey()); - rawout(prefix(e.getValue(), feedback.getPre() + "\t", feedback.getPost())); + cmdout.printf(prefix(e.getValue(), feedback.getPre() + "\t", feedback.getPost())); } } @@ -899,7 +885,10 @@ public class JShellTool implements MessageHandler { replayableHistoryPrevious = ReplayableHistory.fromPrevious(prefs); // load snippet/command files given on command-line for (String loadFile : commandLineArgs.nonOptions()) { - runFile(loadFile, "jshell"); + if (!runFile(loadFile, "jshell")) { + // Load file failed -- abort + return; + } } // if we survived that... if (regenerateOnDeath) { @@ -909,6 +898,7 @@ public class JShellTool implements MessageHandler { // check again, as feedback setting could have failed if (regenerateOnDeath) { // if we haven't died, and the feedback mode wants fluff, print welcome + interactiveModeBegun = true; if (feedback.shouldDisplayCommandFluff()) { hardmsg("jshell.msg.welcome", version()); } @@ -994,7 +984,7 @@ public class JShellTool implements MessageHandler { @Override public void errormsg(String messageKey, Object... args) { - startmsg(messageKey, args); + JShellTool.this.errormsg(messageKey, args); } @Override @@ -1034,6 +1024,7 @@ public class JShellTool implements MessageHandler { shutdownSubscription = state.onShutdown((JShell deadState) -> { if (deadState == state) { hardmsg("jshell.msg.terminated"); + fluffmsg("jshell.msg.terminated.restore"); live = false; } }); @@ -1056,10 +1047,6 @@ public class JShellTool implements MessageHandler { currentNameSpace = mainNamespace; } - private boolean isRunningInteractive() { - return currentNameSpace != null && currentNameSpace == mainNamespace; - } - //where -- one-time per run initialization of feedback modes private void initFeedback(String initMode) { // No fluff, no prefix, for init failures @@ -1096,8 +1083,8 @@ public class JShellTool implements MessageHandler { try (IOContext suin = new ScannerIOContext(new StringReader(start))) { run(suin); } catch (Exception ex) { - hardmsg("jshell.err.startup.unexpected.exception", ex); - ex.printStackTrace(cmdout); + errormsg("jshell.err.startup.unexpected.exception", ex); + ex.printStackTrace(cmderr); } } @@ -1123,7 +1110,7 @@ public class JShellTool implements MessageHandler { String incomplete = ""; while (live) { String prompt; - if (isRunningInteractive()) { + if (interactive()) { prompt = testPrompt ? incomplete.isEmpty() ? "\u0005" //ENQ @@ -1171,7 +1158,7 @@ public class JShellTool implements MessageHandler { } private void addToReplayHistory(String s) { - if (isRunningInteractive()) { + if (!isCurrentlyRunningStartup) { replayableHistory.add(s); } } @@ -2127,7 +2114,7 @@ public class JShellTool implements MessageHandler { fluff("Wrap debugging on"); break; default: - hard("Unknown debugging option: %c", ch); + error("Unknown debugging option: %c", ch); fluff("Use: 0 r g f c d e w"); return false; } @@ -2697,7 +2684,7 @@ public class JShellTool implements MessageHandler { } currSrcs = nextSrcs; } catch (IllegalStateException ex) { - hardmsg("jshell.msg.resetting"); + errormsg("jshell.msg.resetting"); resetState(); currSrcs = new LinkedHashSet<>(); // re-process everything } @@ -2746,16 +2733,21 @@ public class JShellTool implements MessageHandler { private boolean runFile(String filename, String context) { if (!filename.isEmpty()) { try { - Path path = toPathResolvingUserHome(filename); - Reader reader; - String resource; - if (!Files.exists(path) && (resource = getResource(filename)) != null) { - // Not found as file, but found as resource - reader = new StringReader(resource); + Scanner scanner; + if (!interactiveModeBegun && filename.equals("-")) { + // - on command line: no interactive later, read from input + regenerateOnDeath = false; + scanner = new Scanner(cmdin); } else { - reader = new FileReader(path.toString()); + Path path = toPathResolvingUserHome(filename); + String resource; + scanner = new Scanner( + (!Files.exists(path) && (resource = getResource(filename)) != null) + ? new StringReader(resource) // Not found as file, but found as resource + : new FileReader(path.toString()) + ); } - run(new ScannerIOContext(reader)); + run(new ScannerIOContext(scanner)); return true; } catch (FileNotFoundException e) { errormsg("jshell.err.file.not.found", context, filename, e.getMessage()); @@ -2841,7 +2833,7 @@ public class JShellTool implements MessageHandler { sb.append(a); } if (sb.length() > 0) { - rawout(prefix(sb.toString())); + hard(sb.toString()); } return false; } @@ -3175,11 +3167,11 @@ public class JShellTool implements MessageHandler { if (ste.causeSnippet() == null) { // main event for (Diag d : diagnostics) { - hardmsg(d.isError()? "jshell.msg.error" : "jshell.msg.warning"); + errormsg(d.isError()? "jshell.msg.error" : "jshell.msg.warning"); List disp = new ArrayList<>(); displayDiagnostics(source, d, disp); disp.stream() - .forEach(l -> hard("%s", l)); + .forEach(l -> error("%s", l)); } if (ste.status() != Status.REJECTED) { @@ -3190,7 +3182,7 @@ public class JShellTool implements MessageHandler { } else if (ste.exception() instanceof UnresolvedReferenceException) { printUnresolvedException((UnresolvedReferenceException) ste.exception()); } else { - hard("Unexpected execution exception: %s", ste.exception()); + error("Unexpected execution exception: %s", ste.exception()); return true; } } else { @@ -3242,7 +3234,7 @@ public class JShellTool implements MessageHandler { : lineNumber >= 0 ? fileName + ":" + lineNumber : fileName; - hard(" at %s(%s)", sb, loc); + error(" at %s(%s)", sb, loc); } } @@ -3253,9 +3245,9 @@ public class JShellTool implements MessageHandler { //where void printEvalException(EvalException ex) { if (ex.getMessage() == null) { - hard("%s thrown", ex.getExceptionClassName()); + error("%s thrown", ex.getExceptionClassName()); } else { - hard("%s thrown: %s", ex.getExceptionClassName(), ex.getMessage()); + error("%s thrown: %s", ex.getExceptionClassName(), ex.getMessage()); } printStackTrace(ex.getStackTrace()); } @@ -3394,7 +3386,7 @@ public class JShellTool implements MessageHandler { resolution, unrcnt, errcnt, name, type, value, unresolved, errorLines); if (!resolutionErrors.trim().isEmpty()) { - hard(" %s", resolutionErrors); + error(" %s", resolutionErrors); } } else if (interactive()) { String display = feedback.format(fcase, action, update, @@ -3625,7 +3617,6 @@ class ScannerIOContext extends NonInteractiveIOContext { scannerIn.close(); } - @Override public int readUserInput() { return -1; } @@ -3657,7 +3648,6 @@ class ReloadIOContext extends NonInteractiveIOContext { public void close() { } - @Override public int readUserInput() { return -1; } diff --git a/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/resources/l10n.properties b/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/resources/l10n.properties index 5ad429ad15d..dce8e5c6900 100644 --- a/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/resources/l10n.properties +++ b/src/jdk.jshell/share/classes/jdk/internal/jshell/tool/resources/l10n.properties @@ -33,9 +33,8 @@ jshell.err.opt.startup.conflict = Conflicting options: both --startup and --no-s jshell.err.opt.feedback.one = Only one feedback option (--feedback, -q, -s, or -v) may be used. jshell.err.opt.unknown = Unknown option: {0} -jshell.msg.terminated =\ -State engine terminated.\n\ -Restore definitions with: /reload -restore +jshell.msg.terminated = State engine terminated. +jshell.msg.terminated.restore = Restore definitions with: /reload -restore jshell.msg.use.one.of = Use one of: {0} jshell.msg.see.classes.etc = See /types, /methods, /vars, or /list @@ -189,7 +188,7 @@ For more information see:\n\ /help shortcuts help.usage = \ -Usage: jshell \n\ +Usage: jshell

-
-Copyright 2001,2003 Keith Packard
-
-Permission to use, copy, modify, distribute, and sell this software and its
-documentation for any purpose is hereby granted without fee, provided that the
-above copyright notice appear in all copies and that both that copyright
-notice and this permission notice appear in supporting documentation, and that
-the name of Keith Packard not be used in advertising or publicity pertaining
-to distribution of the software without specific, written prior permission.
-Keith Packard makes no representations about the suitability of this software
-for any purpose.  It is provided "as is" without express or implied warranty.
-
-KEITH PACKARD DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING
-ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL KEITH
-PACKARD BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY
-DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
-ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN
-CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
-
-
diff --git a/src/java.desktop/unix/native/common/awt/fontconfig.h b/src/java.desktop/unix/native/common/awt/fontconfig.h deleted file mode 100644 index d6e49d88b76..00000000000 --- a/src/java.desktop/unix/native/common/awt/fontconfig.h +++ /dev/null @@ -1,941 +0,0 @@ -/* - * $RCSId: xc/lib/fontconfig/fontconfig/fontconfig.h,v 1.30 2002/09/26 00:17:27 keithp Exp $ - * - * Copyright © 2001 Keith Packard - * - * Permission to use, copy, modify, distribute, and sell this software and its - * documentation for any purpose is hereby granted without fee, provided that - * the above copyright notice appear in all copies and that both that - * copyright notice and this permission notice appear in supporting - * documentation, and that the name of Keith Packard not be used in - * advertising or publicity pertaining to distribution of the software without - * specific, written prior permission. Keith Packard makes no - * representations about the suitability of this software for any purpose. It - * is provided "as is" without express or implied warranty. - * - * KEITH PACKARD DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, - * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO - * EVENT SHALL KEITH PACKARD BE LIABLE FOR ANY SPECIAL, INDIRECT OR - * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, - * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER - * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR - * PERFORMANCE OF THIS SOFTWARE. - */ - -#ifndef _FONTCONFIG_H_ -#define _FONTCONFIG_H_ - -#include -#include -#include -#include - -#if defined(__GNUC__) && (__GNUC__ >= 4) -#define FC_ATTRIBUTE_SENTINEL(x) __attribute__((__sentinel__(0))) -#else -#define FC_ATTRIBUTE_SENTINEL(x) -#endif - -#ifndef FcPublic -#define FcPublic -#endif - -typedef unsigned char FcChar8; -typedef unsigned short FcChar16; -typedef unsigned int FcChar32; -typedef int FcBool; - -/* - * Current Fontconfig version number. This same number - * must appear in the fontconfig configure.in file. Yes, - * it'a a pain to synchronize version numbers like this. - */ - -#define FC_MAJOR 2 -#define FC_MINOR 5 -#define FC_REVISION 0 - -#define FC_VERSION ((FC_MAJOR * 10000) + (FC_MINOR * 100) + (FC_REVISION)) - -/* - * Current font cache file format version - * This is appended to the cache files so that multiple - * versions of the library will peacefully coexist - * - * Change this value whenever the disk format for the cache file - * changes in any non-compatible way. Try to avoid such changes as - * it means multiple copies of the font information. - */ - -#define FC_CACHE_VERSION "2" - -#define FcTrue 1 -#define FcFalse 0 - -#define FC_FAMILY "family" /* String */ -#define FC_STYLE "style" /* String */ -#define FC_SLANT "slant" /* Int */ -#define FC_WEIGHT "weight" /* Int */ -#define FC_SIZE "size" /* Double */ -#define FC_ASPECT "aspect" /* Double */ -#define FC_PIXEL_SIZE "pixelsize" /* Double */ -#define FC_SPACING "spacing" /* Int */ -#define FC_FOUNDRY "foundry" /* String */ -#define FC_ANTIALIAS "antialias" /* Bool (depends) */ -#define FC_HINTING "hinting" /* Bool (true) */ -#define FC_HINT_STYLE "hintstyle" /* Int */ -#define FC_VERTICAL_LAYOUT "verticallayout" /* Bool (false) */ -#define FC_AUTOHINT "autohint" /* Bool (false) */ -#define FC_GLOBAL_ADVANCE "globaladvance" /* Bool (true) */ -#define FC_WIDTH "width" /* Int */ -#define FC_FILE "file" /* String */ -#define FC_INDEX "index" /* Int */ -#define FC_FT_FACE "ftface" /* FT_Face */ -#define FC_RASTERIZER "rasterizer" /* String */ -#define FC_OUTLINE "outline" /* Bool */ -#define FC_SCALABLE "scalable" /* Bool */ -#define FC_SCALE "scale" /* double */ -#define FC_DPI "dpi" /* double */ -#define FC_RGBA "rgba" /* Int */ -#define FC_MINSPACE "minspace" /* Bool use minimum line spacing */ -#define FC_SOURCE "source" /* String (deprecated) */ -#define FC_CHARSET "charset" /* CharSet */ -#define FC_LANG "lang" /* String RFC 3066 langs */ -#define FC_FONTVERSION "fontversion" /* Int from 'head' table */ -#define FC_FULLNAME "fullname" /* String */ -#define FC_FAMILYLANG "familylang" /* String RFC 3066 langs */ -#define FC_STYLELANG "stylelang" /* String RFC 3066 langs */ -#define FC_FULLNAMELANG "fullnamelang" /* String RFC 3066 langs */ -#define FC_CAPABILITY "capability" /* String */ -#define FC_FONTFORMAT "fontformat" /* String */ -#define FC_EMBOLDEN "embolden" /* Bool - true if emboldening needed*/ -#define FC_EMBEDDED_BITMAP "embeddedbitmap" /* Bool - true to enable embedded bitmaps */ -#define FC_DECORATIVE "decorative" /* Bool - true if style is a decorative variant */ - -#define FC_CACHE_SUFFIX ".cache-"FC_CACHE_VERSION -#define FC_DIR_CACHE_FILE "fonts.cache-"FC_CACHE_VERSION -#define FC_USER_CACHE_FILE ".fonts.cache-"FC_CACHE_VERSION - -/* Adjust outline rasterizer */ -#define FC_CHAR_WIDTH "charwidth" /* Int */ -#define FC_CHAR_HEIGHT "charheight"/* Int */ -#define FC_MATRIX "matrix" /* FcMatrix */ - -#define FC_WEIGHT_THIN 0 -#define FC_WEIGHT_EXTRALIGHT 40 -#define FC_WEIGHT_ULTRALIGHT FC_WEIGHT_EXTRALIGHT -#define FC_WEIGHT_LIGHT 50 -#define FC_WEIGHT_BOOK 75 -#define FC_WEIGHT_REGULAR 80 -#define FC_WEIGHT_NORMAL FC_WEIGHT_REGULAR -#define FC_WEIGHT_MEDIUM 100 -#define FC_WEIGHT_DEMIBOLD 180 -#define FC_WEIGHT_SEMIBOLD FC_WEIGHT_DEMIBOLD -#define FC_WEIGHT_BOLD 200 -#define FC_WEIGHT_EXTRABOLD 205 -#define FC_WEIGHT_ULTRABOLD FC_WEIGHT_EXTRABOLD -#define FC_WEIGHT_BLACK 210 -#define FC_WEIGHT_HEAVY FC_WEIGHT_BLACK -#define FC_WEIGHT_EXTRABLACK 215 -#define FC_WEIGHT_ULTRABLACK FC_WEIGHT_EXTRABLACK - -#define FC_SLANT_ROMAN 0 -#define FC_SLANT_ITALIC 100 -#define FC_SLANT_OBLIQUE 110 - -#define FC_WIDTH_ULTRACONDENSED 50 -#define FC_WIDTH_EXTRACONDENSED 63 -#define FC_WIDTH_CONDENSED 75 -#define FC_WIDTH_SEMICONDENSED 87 -#define FC_WIDTH_NORMAL 100 -#define FC_WIDTH_SEMIEXPANDED 113 -#define FC_WIDTH_EXPANDED 125 -#define FC_WIDTH_EXTRAEXPANDED 150 -#define FC_WIDTH_ULTRAEXPANDED 200 - -#define FC_PROPORTIONAL 0 -#define FC_DUAL 90 -#define FC_MONO 100 -#define FC_CHARCELL 110 - -/* sub-pixel order */ -#define FC_RGBA_UNKNOWN 0 -#define FC_RGBA_RGB 1 -#define FC_RGBA_BGR 2 -#define FC_RGBA_VRGB 3 -#define FC_RGBA_VBGR 4 -#define FC_RGBA_NONE 5 - -/* hinting style */ -#define FC_HINT_NONE 0 -#define FC_HINT_SLIGHT 1 -#define FC_HINT_MEDIUM 2 -#define FC_HINT_FULL 3 - -typedef enum _FcType { - FcTypeVoid, - FcTypeInteger, - FcTypeDouble, - FcTypeString, - FcTypeBool, - FcTypeMatrix, - FcTypeCharSet, - FcTypeFTFace, - FcTypeLangSet -} FcType; - -typedef struct _FcMatrix { - double xx, xy, yx, yy; -} FcMatrix; - -#define FcMatrixInit(m) ((m)->xx = (m)->yy = 1, \ - (m)->xy = (m)->yx = 0) - -/* - * A data structure to represent the available glyphs in a font. - * This is represented as a sparse boolean btree. - */ - -typedef struct _FcCharSet FcCharSet; - -typedef struct _FcObjectType { - const char *object; - FcType type; -} FcObjectType; - -typedef struct _FcConstant { - const FcChar8 *name; - const char *object; - int value; -} FcConstant; - -typedef enum _FcResult { - FcResultMatch, FcResultNoMatch, FcResultTypeMismatch, FcResultNoId, - FcResultOutOfMemory -} FcResult; - -typedef struct _FcPattern FcPattern; - -typedef struct _FcLangSet FcLangSet; - -typedef struct _FcValue { - FcType type; - union { - const FcChar8 *s; - int i; - FcBool b; - double d; - const FcMatrix *m; - const FcCharSet *c; - void *f; - const FcLangSet *l; - } u; -} FcValue; - -typedef struct _FcFontSet { - int nfont; - int sfont; - FcPattern **fonts; -} FcFontSet; - -typedef struct _FcObjectSet { - int nobject; - int sobject; - const char **objects; -} FcObjectSet; - -typedef enum _FcMatchKind { - FcMatchPattern, FcMatchFont, FcMatchScan -} FcMatchKind; - -typedef enum _FcLangResult { - FcLangEqual = 0, - FcLangDifferentCountry = 1, - FcLangDifferentTerritory = 1, - FcLangDifferentLang = 2 -} FcLangResult; - -typedef enum _FcSetName { - FcSetSystem = 0, - FcSetApplication = 1 -} FcSetName; - -typedef struct _FcAtomic FcAtomic; - -#if defined(__cplusplus) || defined(c_plusplus) /* for C++ V2.0 */ -#define _FCFUNCPROTOBEGIN extern "C" { /* do not leave open across includes */ -#define _FCFUNCPROTOEND } -#else -#define _FCFUNCPROTOBEGIN -#define _FCFUNCPROTOEND -#endif - -typedef enum { FcEndianBig, FcEndianLittle } FcEndian; - -typedef struct _FcConfig FcConfig; - -typedef struct _FcGlobalCache FcFileCache; - -typedef struct _FcBlanks FcBlanks; - -typedef struct _FcStrList FcStrList; - -typedef struct _FcStrSet FcStrSet; - -typedef struct _FcCache FcCache; - -_FCFUNCPROTOBEGIN - -/* fcblanks.c */ -FcPublic FcBlanks * -FcBlanksCreate (void); - -FcPublic void -FcBlanksDestroy (FcBlanks *b); - -FcPublic FcBool -FcBlanksAdd (FcBlanks *b, FcChar32 ucs4); - -FcPublic FcBool -FcBlanksIsMember (FcBlanks *b, FcChar32 ucs4); - -/* fccache.c */ - -FcPublic const FcChar8 * -FcCacheDir(const FcCache *c); - -FcPublic FcFontSet * -FcCacheCopySet(const FcCache *c); - -FcPublic const FcChar8 * -FcCacheSubdir (const FcCache *c, int i); - -FcPublic int -FcCacheNumSubdir (const FcCache *c); - -FcPublic int -FcCacheNumFont (const FcCache *c); - -FcPublic FcBool -FcDirCacheUnlink (const FcChar8 *dir, FcConfig *config); - -FcPublic FcBool -FcDirCacheValid (const FcChar8 *cache_file); - -/* fccfg.c */ -FcPublic FcChar8 * -FcConfigHome (void); - -FcPublic FcBool -FcConfigEnableHome (FcBool enable); - -FcPublic FcChar8 * -FcConfigFilename (const FcChar8 *url); - -FcPublic FcConfig * -FcConfigCreate (void); - -FcPublic void -FcConfigDestroy (FcConfig *config); - -FcPublic FcBool -FcConfigSetCurrent (FcConfig *config); - -FcPublic FcConfig * -FcConfigGetCurrent (void); - -FcPublic FcBool -FcConfigUptoDate (FcConfig *config); - -FcPublic FcBool -FcConfigBuildFonts (FcConfig *config); - -FcPublic FcStrList * -FcConfigGetFontDirs (FcConfig *config); - -FcPublic FcStrList * -FcConfigGetConfigDirs (FcConfig *config); - -FcPublic FcStrList * -FcConfigGetConfigFiles (FcConfig *config); - -FcPublic FcChar8 * -FcConfigGetCache (FcConfig *config); - -FcPublic FcBlanks * -FcConfigGetBlanks (FcConfig *config); - -FcPublic FcStrList * -FcConfigGetCacheDirs (FcConfig *config); - -FcPublic int -FcConfigGetRescanInterval (FcConfig *config); - -FcPublic FcBool -FcConfigSetRescanInterval (FcConfig *config, int rescanInterval); - -FcPublic FcFontSet * -FcConfigGetFonts (FcConfig *config, - FcSetName set); - -FcPublic FcBool -FcConfigAppFontAddFile (FcConfig *config, - const FcChar8 *file); - -FcPublic FcBool -FcConfigAppFontAddDir (FcConfig *config, - const FcChar8 *dir); - -FcPublic void -FcConfigAppFontClear (FcConfig *config); - -FcPublic FcBool -FcConfigSubstituteWithPat (FcConfig *config, - FcPattern *p, - FcPattern *p_pat, - FcMatchKind kind); - -FcPublic FcBool -FcConfigSubstitute (FcConfig *config, - FcPattern *p, - FcMatchKind kind); - -/* fccharset.c */ -FcPublic FcCharSet* -FcCharSetCreate (void); - -/* deprecated alias for FcCharSetCreate */ -FcPublic FcCharSet * -FcCharSetNew (void); - -FcPublic void -FcCharSetDestroy (FcCharSet *fcs); - -FcPublic FcBool -FcCharSetAddChar (FcCharSet *fcs, FcChar32 ucs4); - -FcPublic FcCharSet* -FcCharSetCopy (FcCharSet *src); - -FcPublic FcBool -FcCharSetEqual (const FcCharSet *a, const FcCharSet *b); - -FcPublic FcCharSet* -FcCharSetIntersect (const FcCharSet *a, const FcCharSet *b); - -FcPublic FcCharSet* -FcCharSetUnion (const FcCharSet *a, const FcCharSet *b); - -FcPublic FcCharSet* -FcCharSetSubtract (const FcCharSet *a, const FcCharSet *b); - -FcPublic FcBool -FcCharSetHasChar (const FcCharSet *fcs, FcChar32 ucs4); - -FcPublic FcChar32 -FcCharSetCount (const FcCharSet *a); - -FcPublic FcChar32 -FcCharSetIntersectCount (const FcCharSet *a, const FcCharSet *b); - -FcPublic FcChar32 -FcCharSetSubtractCount (const FcCharSet *a, const FcCharSet *b); - -FcPublic FcBool -FcCharSetIsSubset (const FcCharSet *a, const FcCharSet *b); - -#define FC_CHARSET_MAP_SIZE (256/32) -#define FC_CHARSET_DONE ((FcChar32) -1) - -FcPublic FcChar32 -FcCharSetFirstPage (const FcCharSet *a, - FcChar32 map[FC_CHARSET_MAP_SIZE], - FcChar32 *next); - -FcPublic FcChar32 -FcCharSetNextPage (const FcCharSet *a, - FcChar32 map[FC_CHARSET_MAP_SIZE], - FcChar32 *next); - -/* - * old coverage API, rather hard to use correctly - */ - -FcPublic FcChar32 -FcCharSetCoverage (const FcCharSet *a, FcChar32 page, FcChar32 *result); - -/* fcdbg.c */ -FcPublic void -FcValuePrint (const FcValue v); - -FcPublic void -FcPatternPrint (const FcPattern *p); - -FcPublic void -FcFontSetPrint (const FcFontSet *s); - -/* fcdefault.c */ -FcPublic void -FcDefaultSubstitute (FcPattern *pattern); - -/* fcdir.c */ -FcPublic FcBool -FcFileIsDir (const FcChar8 *file); - -FcPublic FcBool -FcFileScan (FcFontSet *set, - FcStrSet *dirs, - FcFileCache *cache, - FcBlanks *blanks, - const FcChar8 *file, - FcBool force); - -FcPublic FcBool -FcDirScan (FcFontSet *set, - FcStrSet *dirs, - FcFileCache *cache, - FcBlanks *blanks, - const FcChar8 *dir, - FcBool force); - -FcPublic FcBool -FcDirSave (FcFontSet *set, FcStrSet *dirs, const FcChar8 *dir); - -FcPublic FcCache * -FcDirCacheLoad (const FcChar8 *dir, FcConfig *config, FcChar8 **cache_file); - -FcPublic FcCache * -FcDirCacheRead (const FcChar8 *dir, FcBool force, FcConfig *config); - -FcPublic FcCache * -FcDirCacheLoadFile (const FcChar8 *cache_file, struct stat *file_stat); - -FcPublic void -FcDirCacheUnload (FcCache *cache); - -/* fcfreetype.c */ -FcPublic FcPattern * -FcFreeTypeQuery (const FcChar8 *file, int id, FcBlanks *blanks, int *count); - -/* fcfs.c */ - -FcPublic FcFontSet * -FcFontSetCreate (void); - -FcPublic void -FcFontSetDestroy (FcFontSet *s); - -FcPublic FcBool -FcFontSetAdd (FcFontSet *s, FcPattern *font); - -/* fcinit.c */ -FcPublic FcConfig * -FcInitLoadConfig (void); - -FcPublic FcConfig * -FcInitLoadConfigAndFonts (void); - -FcPublic FcBool -FcInit (void); - -FcPublic void -FcFini (void); - -FcPublic int -FcGetVersion (void); - -FcPublic FcBool -FcInitReinitialize (void); - -FcPublic FcBool -FcInitBringUptoDate (void); - -/* fclang.c */ -FcPublic FcStrSet * -FcGetLangs (void); - -FcPublic const FcCharSet * -FcLangGetCharSet (const FcChar8 *lang); - -FcPublic FcLangSet* -FcLangSetCreate (void); - -FcPublic void -FcLangSetDestroy (FcLangSet *ls); - -FcPublic FcLangSet* -FcLangSetCopy (const FcLangSet *ls); - -FcPublic FcBool -FcLangSetAdd (FcLangSet *ls, const FcChar8 *lang); - -FcPublic FcLangResult -FcLangSetHasLang (const FcLangSet *ls, const FcChar8 *lang); - -FcPublic FcLangResult -FcLangSetCompare (const FcLangSet *lsa, const FcLangSet *lsb); - -FcPublic FcBool -FcLangSetContains (const FcLangSet *lsa, const FcLangSet *lsb); - -FcPublic FcBool -FcLangSetEqual (const FcLangSet *lsa, const FcLangSet *lsb); - -FcPublic FcChar32 -FcLangSetHash (const FcLangSet *ls); - -/* fclist.c */ -FcPublic FcObjectSet * -FcObjectSetCreate (void); - -FcPublic FcBool -FcObjectSetAdd (FcObjectSet *os, const char *object); - -FcPublic void -FcObjectSetDestroy (FcObjectSet *os); - -FcPublic FcObjectSet * -FcObjectSetVaBuild (const char *first, va_list va); - -FcPublic FcObjectSet * -FcObjectSetBuild (const char *first, ...) FC_ATTRIBUTE_SENTINEL(0); - -FcPublic FcFontSet * -FcFontSetList (FcConfig *config, - FcFontSet **sets, - int nsets, - FcPattern *p, - FcObjectSet *os); - -FcPublic FcFontSet * -FcFontList (FcConfig *config, - FcPattern *p, - FcObjectSet *os); - -/* fcatomic.c */ - -FcPublic FcAtomic * -FcAtomicCreate (const FcChar8 *file); - -FcPublic FcBool -FcAtomicLock (FcAtomic *atomic); - -FcPublic FcChar8 * -FcAtomicNewFile (FcAtomic *atomic); - -FcPublic FcChar8 * -FcAtomicOrigFile (FcAtomic *atomic); - -FcPublic FcBool -FcAtomicReplaceOrig (FcAtomic *atomic); - -FcPublic void -FcAtomicDeleteNew (FcAtomic *atomic); - -FcPublic void -FcAtomicUnlock (FcAtomic *atomic); - -FcPublic void -FcAtomicDestroy (FcAtomic *atomic); - -/* fcmatch.c */ -FcPublic FcPattern * -FcFontSetMatch (FcConfig *config, - FcFontSet **sets, - int nsets, - FcPattern *p, - FcResult *result); - -FcPublic FcPattern * -FcFontMatch (FcConfig *config, - FcPattern *p, - FcResult *result); - -FcPublic FcPattern * -FcFontRenderPrepare (FcConfig *config, - FcPattern *pat, - FcPattern *font); - -FcPublic FcFontSet * -FcFontSetSort (FcConfig *config, - FcFontSet **sets, - int nsets, - FcPattern *p, - FcBool trim, - FcCharSet **csp, - FcResult *result); - -FcPublic FcFontSet * -FcFontSort (FcConfig *config, - FcPattern *p, - FcBool trim, - FcCharSet **csp, - FcResult *result); - -FcPublic void -FcFontSetSortDestroy (FcFontSet *fs); - -/* fcmatrix.c */ -FcPublic FcMatrix * -FcMatrixCopy (const FcMatrix *mat); - -FcPublic FcBool -FcMatrixEqual (const FcMatrix *mat1, const FcMatrix *mat2); - -FcPublic void -FcMatrixMultiply (FcMatrix *result, const FcMatrix *a, const FcMatrix *b); - -FcPublic void -FcMatrixRotate (FcMatrix *m, double c, double s); - -FcPublic void -FcMatrixScale (FcMatrix *m, double sx, double sy); - -FcPublic void -FcMatrixShear (FcMatrix *m, double sh, double sv); - -/* fcname.c */ - -FcPublic FcBool -FcNameRegisterObjectTypes (const FcObjectType *types, int ntype); - -FcPublic FcBool -FcNameUnregisterObjectTypes (const FcObjectType *types, int ntype); - -FcPublic const FcObjectType * -FcNameGetObjectType (const char *object); - -FcPublic FcBool -FcNameRegisterConstants (const FcConstant *consts, int nconsts); - -FcPublic FcBool -FcNameUnregisterConstants (const FcConstant *consts, int nconsts); - -FcPublic const FcConstant * -FcNameGetConstant (FcChar8 *string); - -FcPublic FcBool -FcNameConstant (FcChar8 *string, int *result); - -FcPublic FcPattern * -FcNameParse (const FcChar8 *name); - -FcPublic FcChar8 * -FcNameUnparse (FcPattern *pat); - -/* fcpat.c */ -FcPublic FcPattern * -FcPatternCreate (void); - -FcPublic FcPattern * -FcPatternDuplicate (const FcPattern *p); - -FcPublic void -FcPatternReference (FcPattern *p); - -FcPublic void -FcValueDestroy (FcValue v); - -FcPublic FcBool -FcValueEqual (FcValue va, FcValue vb); - -FcPublic FcValue -FcValueSave (FcValue v); - -FcPublic void -FcPatternDestroy (FcPattern *p); - -FcPublic FcBool -FcPatternEqual (const FcPattern *pa, const FcPattern *pb); - -FcPublic FcBool -FcPatternEqualSubset (const FcPattern *pa, const FcPattern *pb, const FcObjectSet *os); - -FcPublic FcChar32 -FcPatternHash (const FcPattern *p); - -FcPublic FcBool -FcPatternAdd (FcPattern *p, const char *object, FcValue value, FcBool append); - -FcPublic FcBool -FcPatternAddWeak (FcPattern *p, const char *object, FcValue value, FcBool append); - -FcPublic FcResult -FcPatternGet (const FcPattern *p, const char *object, int id, FcValue *v); - -FcPublic FcBool -FcPatternDel (FcPattern *p, const char *object); - -FcPublic FcBool -FcPatternRemove (FcPattern *p, const char *object, int id); - -FcPublic FcBool -FcPatternAddInteger (FcPattern *p, const char *object, int i); - -FcPublic FcBool -FcPatternAddDouble (FcPattern *p, const char *object, double d); - -FcPublic FcBool -FcPatternAddString (FcPattern *p, const char *object, const FcChar8 *s); - -FcPublic FcBool -FcPatternAddMatrix (FcPattern *p, const char *object, const FcMatrix *s); - -FcPublic FcBool -FcPatternAddCharSet (FcPattern *p, const char *object, const FcCharSet *c); - -FcPublic FcBool -FcPatternAddBool (FcPattern *p, const char *object, FcBool b); - -FcPublic FcBool -FcPatternAddLangSet (FcPattern *p, const char *object, const FcLangSet *ls); - -FcPublic FcResult -FcPatternGetInteger (const FcPattern *p, const char *object, int n, int *i); - -FcPublic FcResult -FcPatternGetDouble (const FcPattern *p, const char *object, int n, double *d); - -FcPublic FcResult -FcPatternGetString (const FcPattern *p, const char *object, int n, FcChar8 ** s); - -FcPublic FcResult -FcPatternGetMatrix (const FcPattern *p, const char *object, int n, FcMatrix **s); - -FcPublic FcResult -FcPatternGetCharSet (const FcPattern *p, const char *object, int n, FcCharSet **c); - -FcPublic FcResult -FcPatternGetBool (const FcPattern *p, const char *object, int n, FcBool *b); - -FcPublic FcResult -FcPatternGetLangSet (const FcPattern *p, const char *object, int n, FcLangSet **ls); - -FcPublic FcPattern * -FcPatternVaBuild (FcPattern *orig, va_list va); - -FcPublic FcPattern * -FcPatternBuild (FcPattern *orig, ...) FC_ATTRIBUTE_SENTINEL(0); - -/* fcstr.c */ - -FcPublic FcChar8 * -FcStrCopy (const FcChar8 *s); - -FcPublic FcChar8 * -FcStrCopyFilename (const FcChar8 *s); - -FcPublic FcChar8 * -FcStrPlus (const FcChar8 *s1, const FcChar8 *s2); - -FcPublic void -FcStrFree (FcChar8 *s); - -/* These are ASCII only, suitable only for pattern element names */ -#define FcIsUpper(c) ((0101 <= (c) && (c) <= 0132)) -#define FcIsLower(c) ((0141 <= (c) && (c) <= 0172)) -#define FcToLower(c) (FcIsUpper(c) ? (c) - 0101 + 0141 : (c)) - -FcPublic FcChar8 * -FcStrDowncase (const FcChar8 *s); - -FcPublic int -FcStrCmpIgnoreCase (const FcChar8 *s1, const FcChar8 *s2); - -FcPublic int -FcStrCmp (const FcChar8 *s1, const FcChar8 *s2); - -FcPublic const FcChar8 * -FcStrStrIgnoreCase (const FcChar8 *s1, const FcChar8 *s2); - -FcPublic const FcChar8 * -FcStrStr (const FcChar8 *s1, const FcChar8 *s2); - -FcPublic int -FcUtf8ToUcs4 (const FcChar8 *src_orig, - FcChar32 *dst, - int len); - -FcPublic FcBool -FcUtf8Len (const FcChar8 *string, - int len, - int *nchar, - int *wchar); - -#define FC_UTF8_MAX_LEN 6 - -FcPublic int -FcUcs4ToUtf8 (FcChar32 ucs4, - FcChar8 dest[FC_UTF8_MAX_LEN]); - -FcPublic int -FcUtf16ToUcs4 (const FcChar8 *src_orig, - FcEndian endian, - FcChar32 *dst, - int len); /* in bytes */ - -FcPublic FcBool -FcUtf16Len (const FcChar8 *string, - FcEndian endian, - int len, /* in bytes */ - int *nchar, - int *wchar); - -FcPublic FcChar8 * -FcStrDirname (const FcChar8 *file); - -FcPublic FcChar8 * -FcStrBasename (const FcChar8 *file); - -FcPublic FcStrSet * -FcStrSetCreate (void); - -FcPublic FcBool -FcStrSetMember (FcStrSet *set, const FcChar8 *s); - -FcPublic FcBool -FcStrSetEqual (FcStrSet *sa, FcStrSet *sb); - -FcPublic FcBool -FcStrSetAdd (FcStrSet *set, const FcChar8 *s); - -FcPublic FcBool -FcStrSetAddFilename (FcStrSet *set, const FcChar8 *s); - -FcPublic FcBool -FcStrSetDel (FcStrSet *set, const FcChar8 *s); - -FcPublic void -FcStrSetDestroy (FcStrSet *set); - -FcPublic FcStrList * -FcStrListCreate (FcStrSet *set); - -FcPublic FcChar8 * -FcStrListNext (FcStrList *list); - -FcPublic void -FcStrListDone (FcStrList *list); - -/* fcxml.c */ -FcPublic FcBool -FcConfigParseAndLoad (FcConfig *config, const FcChar8 *file, FcBool complain); - -_FCFUNCPROTOEND - -#undef FC_ATTRIBUTE_SENTINEL - - -#ifndef _FCINT_H_ - -/* - * Deprecated functions are placed here to help users fix their code without - * digging through documentation - */ - -#define FcConfigGetRescanInverval FcConfigGetRescanInverval_REPLACE_BY_FcConfigGetRescanInterval -#define FcConfigSetRescanInverval FcConfigSetRescanInverval_REPLACE_BY_FcConfigSetRescanInterval - -#endif - -#endif /* _FONTCONFIG_H_ */ diff --git a/src/java.desktop/unix/native/common/awt/fontpath.c b/src/java.desktop/unix/native/common/awt/fontpath.c index 4362da5c436..6d264a36ab5 100644 --- a/src/java.desktop/unix/native/common/awt/fontpath.c +++ b/src/java.desktop/unix/native/common/awt/fontpath.c @@ -578,7 +578,7 @@ JNIEXPORT jstring JNICALL Java_sun_awt_FcFontManager_getFontPathNative #include -#include "fontconfig.h" +#include static void* openFontConfig() { From 837250ab0ec6919de7f811f4cfd0e2732be7d631 Mon Sep 17 00:00:00 2001 From: Sergey Bylokhov Date: Thu, 26 Oct 2017 19:45:37 -0700 Subject: [PATCH 11/39] 8187639: TrayIcon is not properly supported on macOS in multi-screen environment Reviewed-by: prr, ssadetsky --- .../classes/sun/lwawt/macosx/CTrayIcon.java | 269 +++--------------- .../native/libawt_lwawt/awt/CTrayIcon.m | 25 ++ .../native/libosxapp/NSApplicationAWT.h | 4 +- .../native/libosxapp/NSApplicationAWT.m | 10 + 4 files changed, 79 insertions(+), 229 deletions(-) diff --git a/src/java.desktop/macosx/classes/sun/lwawt/macosx/CTrayIcon.java b/src/java.desktop/macosx/classes/sun/lwawt/macosx/CTrayIcon.java index dc168a4ab1f..08ea316a25f 100644 --- a/src/java.desktop/macosx/classes/sun/lwawt/macosx/CTrayIcon.java +++ b/src/java.desktop/macosx/classes/sun/lwawt/macosx/CTrayIcon.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, 2017, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -25,26 +25,37 @@ package sun.lwawt.macosx; -import sun.awt.AWTAccessor; -import sun.awt.SunToolkit; - -import javax.swing.*; -import java.awt.*; -import java.awt.event.*; +import java.awt.AWTEvent; +import java.awt.Button; +import java.awt.Frame; +import java.awt.Graphics2D; +import java.awt.GraphicsConfiguration; +import java.awt.GraphicsDevice; +import java.awt.GraphicsEnvironment; +import java.awt.Image; +import java.awt.MediaTracker; +import java.awt.PopupMenu; +import java.awt.RenderingHints; +import java.awt.Toolkit; +import java.awt.Transparency; +import java.awt.TrayIcon; +import java.awt.event.ActionEvent; +import java.awt.event.MouseEvent; import java.awt.geom.Point2D; import java.awt.image.BufferedImage; import java.awt.peer.TrayIconPeer; -import java.beans.PropertyChangeEvent; -import java.beans.PropertyChangeListener; -import java.util.concurrent.atomic.AtomicReference; -import static sun.awt.AWTAccessor.*; +import javax.swing.Icon; +import javax.swing.UIManager; + +import sun.awt.SunToolkit; + +import static sun.awt.AWTAccessor.MenuComponentAccessor; +import static sun.awt.AWTAccessor.getMenuComponentAccessor; public class CTrayIcon extends CFRetainedResource implements TrayIconPeer { private TrayIcon target; private PopupMenu popup; - private JDialog messageDialog; - private DialogEventHandler handler; // In order to construct MouseEvent object, we need to specify a // Component target. Because TrayIcon isn't Component's subclass, @@ -59,8 +70,6 @@ public class CTrayIcon extends CFRetainedResource implements TrayIconPeer { CTrayIcon(TrayIcon target) { super(0, true); - this.messageDialog = null; - this.handler = null; this.target = target; this.popup = target.getPopupMenu(); this.dummyFrame = new Frame(); @@ -129,28 +138,25 @@ public class CTrayIcon extends CFRetainedResource implements TrayIconPeer { */ public void displayMessage(final String caption, final String text, final String messageType) { - - if (SwingUtilities.isEventDispatchThread()) { - displayMessageOnEDT(caption, text, messageType); + // obtain icon to show along the message + Icon icon = getIconForMessageType(messageType); + CImage cimage = null; + if (icon != null) { + BufferedImage image = scaleIcon(icon, 0.75); + cimage = CImage.getCreator().createFromImage(image); + } + if (cimage != null) { + cimage.execute(imagePtr -> { + execute(ptr -> nativeShowNotification(ptr, caption, text, + imagePtr)); + }); } else { - try { - SwingUtilities.invokeAndWait(new Runnable() { - public void run() { - displayMessageOnEDT(caption, text, messageType); - } - }); - } catch (Exception e) { - throw new AssertionError(e); - } + execute(ptr -> nativeShowNotification(ptr, caption, text, 0)); } } @Override public void dispose() { - if (messageDialog != null) { - disposeMessageDialog(); - } - dummyFrame.dispose(); if (popup != null) { @@ -276,154 +282,14 @@ public class CTrayIcon extends CFRetainedResource implements TrayIconPeer { } } - private native Point2D nativeGetIconLocation(long trayIconModel); - - public void displayMessageOnEDT(String caption, String text, - String messageType) { - if (messageDialog != null) { - disposeMessageDialog(); - } - - // obtain icon to show along the message - Icon icon = getIconForMessageType(messageType); - if (icon != null) { - icon = new ImageIcon(scaleIcon(icon, 0.75)); - } - - // We want the message dialog text area to be about 1/8 of the screen - // size. There is nothing special about this value, it's just makes the - // message dialog to look nice - Dimension screenSize = java.awt.Toolkit.getDefaultToolkit().getScreenSize(); - int textWidth = screenSize.width / 8; - - // create dialog to show - messageDialog = createMessageDialog(caption, text, textWidth, icon); - - // finally, show the dialog to user - showMessageDialog(); - } + private native void nativeShowNotification(long trayIconModel, + String caption, String text, + long nsimage); /** - * Creates dialog window used to display the message + * Used by the automated tests. */ - private JDialog createMessageDialog(String caption, String text, - int textWidth, Icon icon) { - JDialog dialog; - handler = new DialogEventHandler(); - - JTextArea captionArea = null; - if (caption != null) { - captionArea = createTextArea(caption, textWidth, false, true); - } - - JTextArea textArea = null; - if (text != null){ - textArea = createTextArea(text, textWidth, true, false); - } - - Object[] panels = null; - if (captionArea != null) { - if (textArea != null) { - panels = new Object[] {captionArea, new JLabel(), textArea}; - } else { - panels = new Object[] {captionArea}; - } - } else { - if (textArea != null) { - panels = new Object[] {textArea}; - } - } - - // We want message dialog with small title bar. There is a client - // property property that does it, however, it must be set before - // dialog's native window is created. This is why we create option - // pane and dialog separately - final JOptionPane op = new JOptionPane(panels); - op.setIcon(icon); - op.addPropertyChangeListener(handler); - - // Make Ok button small. Most likely won't work for L&F other then Aqua - try { - JPanel buttonPanel = (JPanel)op.getComponent(1); - JButton ok = (JButton)buttonPanel.getComponent(0); - ok.putClientProperty("JComponent.sizeVariant", "small"); - } catch (Throwable t) { - // do nothing, we tried and failed, no big deal - } - - dialog = new JDialog((Dialog) null); - JRootPane rp = dialog.getRootPane(); - - // gives us dialog window with small title bar and not zoomable - rp.putClientProperty(CPlatformWindow.WINDOW_STYLE, "small"); - rp.putClientProperty(CPlatformWindow.WINDOW_ZOOMABLE, "false"); - - dialog.setDefaultCloseOperation(JDialog.DO_NOTHING_ON_CLOSE); - dialog.setModal(false); - dialog.setModalExclusionType(Dialog.ModalExclusionType.TOOLKIT_EXCLUDE); - dialog.setAlwaysOnTop(true); - dialog.setAutoRequestFocus(false); - dialog.setResizable(false); - dialog.setContentPane(op); - - dialog.addWindowListener(handler); - - // suppress security warning for untrusted windows - AWTAccessor.getWindowAccessor().setTrayIconWindow(dialog, true); - - dialog.pack(); - - return dialog; - } - - private void showMessageDialog() { - - Dimension screenSize = java.awt.Toolkit.getDefaultToolkit().getScreenSize(); - AtomicReference ref = new AtomicReference<>(); - execute(ptr -> { - ref.set(nativeGetIconLocation(ptr)); - }); - Point2D iconLoc = ref.get(); - if (iconLoc == null) { - return; - } - - int dialogY = (int)iconLoc.getY(); - int dialogX = (int)iconLoc.getX(); - if (dialogX + messageDialog.getWidth() > screenSize.width) { - dialogX = screenSize.width - messageDialog.getWidth(); - } - - messageDialog.setLocation(dialogX, dialogY); - messageDialog.setVisible(true); - } - - private void disposeMessageDialog() { - if (SwingUtilities.isEventDispatchThread()) { - disposeMessageDialogOnEDT(); - } else { - try { - SwingUtilities.invokeAndWait(new Runnable() { - public void run() { - disposeMessageDialogOnEDT(); - } - }); - } catch (Exception e) { - throw new AssertionError(e); - } - } - } - - private void disposeMessageDialogOnEDT() { - if (messageDialog != null) { - messageDialog.removeWindowListener(handler); - messageDialog.removePropertyChangeListener(handler); - messageDialog.dispose(); - - messageDialog = null; - handler = null; - } - } + private native Point2D nativeGetIconLocation(long trayIconModel); /** * Scales an icon using specified scale factor @@ -480,56 +346,5 @@ public class CTrayIcon extends CFRetainedResource implements TrayIconPeer { return UIManager.getIcon("OptionPane.informationIcon"); } } - - private static JTextArea createTextArea(String text, int width, - boolean isSmall, boolean isBold) { - JTextArea textArea = new JTextArea(text); - - textArea.setLineWrap(true); - textArea.setWrapStyleWord(true); - textArea.setEditable(false); - textArea.setFocusable(false); - textArea.setBorder(null); - textArea.setBackground(new JLabel().getBackground()); - - if (isSmall) { - textArea.putClientProperty("JComponent.sizeVariant", "small"); - } - - if (isBold) { - Font font = textArea.getFont(); - Font boldFont = new Font(font.getName(), Font.BOLD, font.getSize()); - textArea.setFont(boldFont); - } - - textArea.setSize(width, 1); - - return textArea; - } - - /** - * Implements all the Listeners needed by message dialog - */ - private final class DialogEventHandler extends WindowAdapter - implements PropertyChangeListener { - - public void windowClosing(WindowEvent we) { - disposeMessageDialog(); - } - - public void propertyChange(PropertyChangeEvent e) { - if (messageDialog == null) { - return; - } - - String prop = e.getPropertyName(); - Container cp = messageDialog.getContentPane(); - - if (messageDialog.isVisible() && e.getSource() == cp && - (prop.equals(JOptionPane.VALUE_PROPERTY))) { - disposeMessageDialog(); - } - } - } } diff --git a/src/java.desktop/macosx/native/libawt_lwawt/awt/CTrayIcon.m b/src/java.desktop/macosx/native/libawt_lwawt/awt/CTrayIcon.m index aa9abdba104..23e17fb7b14 100644 --- a/src/java.desktop/macosx/native/libawt_lwawt/awt/CTrayIcon.m +++ b/src/java.desktop/macosx/native/libawt_lwawt/awt/CTrayIcon.m @@ -409,3 +409,28 @@ JNF_COCOA_EXIT(env); return jpt; } + +JNIEXPORT void JNICALL +Java_sun_lwawt_macosx_CTrayIcon_nativeShowNotification +(JNIEnv *env, jobject self, jlong model, jobject jcaption, jobject jtext, + long nsimage) { +JNF_COCOA_ENTER(env); + + AWTTrayIcon *icon = jlong_to_ptr(model); + NSString *caption = JNFJavaToNSString(env, jcaption); + NSString *text = JNFJavaToNSString(env, jtext); + NSImage * contentImage = jlong_to_ptr(nsimage); + + [ThreadUtilities performOnMainThreadWaiting:NO block:^(){ + NSUserNotification *notification = [[NSUserNotification alloc] init]; + notification.title = caption; + notification.informativeText = text; + notification.contentImage = contentImage; + notification.soundName = NSUserNotificationDefaultSoundName; + + [[NSUserNotificationCenter defaultUserNotificationCenter] + deliverNotification:notification]; + }]; + +JNF_COCOA_EXIT(env); +} diff --git a/src/java.desktop/macosx/native/libosxapp/NSApplicationAWT.h b/src/java.desktop/macosx/native/libosxapp/NSApplicationAWT.h index c84ad06f9b5..dfb04b581ff 100644 --- a/src/java.desktop/macosx/native/libosxapp/NSApplicationAWT.h +++ b/src/java.desktop/macosx/native/libosxapp/NSApplicationAWT.h @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, 2017, Oracle and/or its affiliates. All rights reserved. * 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 #import -@interface NSApplicationAWT : NSApplication { +@interface NSApplicationAWT : NSApplication { NSString *fApplicationName; NSWindow *eventTransparentWindow; NSTimeInterval dummyEventTimestamp; diff --git a/src/java.desktop/macosx/native/libosxapp/NSApplicationAWT.m b/src/java.desktop/macosx/native/libosxapp/NSApplicationAWT.m index c3dcd20a092..49b26a4eb52 100644 --- a/src/java.desktop/macosx/native/libosxapp/NSApplicationAWT.m +++ b/src/java.desktop/macosx/native/libosxapp/NSApplicationAWT.m @@ -77,6 +77,8 @@ AWT_ASSERT_APPKIT_THREAD; - (void)dealloc { + [[NSUserNotificationCenter defaultUserNotificationCenter] setDelegate:nil]; + [fApplicationName release]; fApplicationName = nil; @@ -138,10 +140,18 @@ AWT_ASSERT_APPKIT_THREAD; [super finishLaunching]; + [[NSUserNotificationCenter defaultUserNotificationCenter] setDelegate:self]; + // inform any interested parties that the AWT has arrived and is pumping [[NSNotificationCenter defaultCenter] postNotificationName:JNFRunLoopDidStartNotification object:self]; } +- (BOOL)userNotificationCenter:(NSUserNotificationCenter *)center + shouldPresentNotification:(NSUserNotification *)notification +{ + return YES; // We always show notifications to the user +} + - (void) registerWithProcessManager { // Headless: NO From a569f5293b3b626e69a0472820fe2c6f67f030d0 Mon Sep 17 00:00:00 2001 From: Phil Race Date: Fri, 27 Oct 2017 11:29:50 -0700 Subject: [PATCH 12/39] 8180501: RescaleOp.filter does not document IllegalArgumentException if sizes differ Reviewed-by: bpb, pnarayanan --- .../classes/java/awt/image/RescaleOp.java | 6 +- .../RescaleOp/RescaleOpExceptionTest.java | 69 +++++++++++++++++++ 2 files changed, 73 insertions(+), 2 deletions(-) create mode 100644 test/jdk/java/awt/image/RescaleOp/RescaleOpExceptionTest.java diff --git a/src/java.desktop/share/classes/java/awt/image/RescaleOp.java b/src/java.desktop/share/classes/java/awt/image/RescaleOp.java index bfd7eb0958b..fb6ccf0b735 100644 --- a/src/java.desktop/share/classes/java/awt/image/RescaleOp.java +++ b/src/java.desktop/share/classes/java/awt/image/RescaleOp.java @@ -360,7 +360,8 @@ public class RescaleOp implements BufferedImageOp, RasterOp { * of {@code src} is an {@code IndexColorModel}, * or if the number of scaling factors and offsets in this * {@code RescaleOp} do not meet the requirements - * stated in the class comments. + * stated in the class comments, or if the source and + * destination images differ in size. */ public final BufferedImage filter (BufferedImage src, BufferedImage dst) { ColorModel srcCM = src.getColorModel(); @@ -473,7 +474,8 @@ public class RescaleOp implements BufferedImageOp, RasterOp { * {@code dst} do not have the same number of bands, * or if the number of scaling factors and offsets in this * {@code RescaleOp} do not meet the requirements - * stated in the class comments. + * stated in the class comments, or if the source and + * destination rasters differ in size. */ public final WritableRaster filter (Raster src, WritableRaster dst) { return filterRasterImpl(src, dst, length, true); diff --git a/test/jdk/java/awt/image/RescaleOp/RescaleOpExceptionTest.java b/test/jdk/java/awt/image/RescaleOp/RescaleOpExceptionTest.java new file mode 100644 index 00000000000..84ac71c559e --- /dev/null +++ b/test/jdk/java/awt/image/RescaleOp/RescaleOpExceptionTest.java @@ -0,0 +1,69 @@ +/* + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * 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 8180501 + * @summary Verify RescaleOp.filter() throws exception for different sized + source and destination. + * @run main RescaleOpExceptionTest + */ + +import java.awt.image.BufferedImage; +import static java.awt.image.BufferedImage.TYPE_INT_RGB; +import java.awt.image.RescaleOp; +import java.awt.image.WritableRaster; + +public class RescaleOpExceptionTest { + + public static void main(String[] args) throws Exception { + + RescaleOp op = new RescaleOp(1.0f, 0.0f, null); + + BufferedImage srcI = new BufferedImage(1, 1, TYPE_INT_RGB); + BufferedImage dstI = new BufferedImage(1, 2, TYPE_INT_RGB); + + boolean caughtIAE = false; + try { + op.filter(srcI, dstI); + } catch (IllegalArgumentException e) { + caughtIAE = true; + } + if (!caughtIAE) { + throw new RuntimeException("Expected IllegalArgumentException"); + } + + WritableRaster srcR = srcI.getRaster(); + WritableRaster dstR = dstI.getRaster(); + + caughtIAE = false; + try { + op.filter(srcR, dstR); + } catch (IllegalArgumentException e) { + caughtIAE = true; + } + if (!caughtIAE) { + throw new RuntimeException("Expected IllegalArgumentException"); + } + } +} From 66812b5f48baef6a00d7c73f465163fc80252b9e Mon Sep 17 00:00:00 2001 From: Sergey Bylokhov Date: Fri, 27 Oct 2017 14:15:02 -0700 Subject: [PATCH 13/39] 8186617: The "com.sun.awt.AWTUtilities" class can be dropped in favour of public API Reviewed-by: azvegint, prr --- .../com/apple/eawt/FullScreenUtilities.java | 9 +- .../apple/eawt/event/GestureUtilities.java | 9 +- .../sun/lwawt/macosx/CPlatformWindow.java | 44 +- .../classes/com/sun/awt/AWTUtilities.java | 52 +- .../share/classes/java/awt/Component.java | 4 - .../classes/java/awt/GraphicsDevice.java | 4 +- .../share/classes/java/awt/Window.java | 40 +- .../javax/swing/DefaultDesktopManager.java | 20 +- .../share/classes/sun/awt/AWTAccessor.java | 22 +- .../unix/classes/sun/awt/X11/XToolkit.java | 126 ++++- .../unix/classes/sun/awt/X11/XWindowPeer.java | 44 +- .../classes/sun/awt/windows/WWindowPeer.java | 51 +- .../sun/awt/Translucency/WindowOpacity.java | 467 ------------------ .../WindowOpacity.java | 139 ++++++ .../swing/JComponent/6683775/bug6683775.java | 48 +- .../JInternalFrame/6726866/bug6726866.java | 33 +- .../swing/JPopupMenu/7156657/bug7156657.java | 47 +- 17 files changed, 507 insertions(+), 652 deletions(-) delete mode 100644 test/jdk/com/sun/awt/Translucency/WindowOpacity.java create mode 100644 test/jdk/java/awt/Window/ShapedAndTranslucentWindows/WindowOpacity.java diff --git a/src/java.desktop/macosx/classes/com/apple/eawt/FullScreenUtilities.java b/src/java.desktop/macosx/classes/com/apple/eawt/FullScreenUtilities.java index 38472121b8b..f70e93b7963 100644 --- a/src/java.desktop/macosx/classes/com/apple/eawt/FullScreenUtilities.java +++ b/src/java.desktop/macosx/classes/com/apple/eawt/FullScreenUtilities.java @@ -25,19 +25,19 @@ package com.apple.eawt; -import java.awt.*; +import java.awt.Component; +import java.awt.Window; import javax.swing.RootPaneContainer; -import sun.lwawt.macosx.*; - import com.apple.eawt.event.GestureUtilities; +import sun.lwawt.macosx.CPlatformWindow; /** * Utility class perform animated full screen actions to top-level {@link Window}s. * * This class manages the relationship between {@link Window}s and the {@link FullScreenListener}s - * attached to them. It's design is similar to the Java SE 6u10 {@link com.sun.awt.AWTUtilities} + * attached to them. It's design is similar to the Java SE 6u10 {@code com.sun.awt.AWTUtilities} * class which adds additional functionality to AWT Windows, without adding new API to the * {@link java.awt.Window} class. * @@ -45,7 +45,6 @@ import com.apple.eawt.event.GestureUtilities; * * @see FullScreenAdapter * @see GestureUtilities - * @see com.sun.awt.AWTUtilities * * @since Java for Mac OS X 10.7 Update 1 */ diff --git a/src/java.desktop/macosx/classes/com/apple/eawt/event/GestureUtilities.java b/src/java.desktop/macosx/classes/com/apple/eawt/event/GestureUtilities.java index 8b70a0c1c38..bb8922ee7c9 100644 --- a/src/java.desktop/macosx/classes/com/apple/eawt/event/GestureUtilities.java +++ b/src/java.desktop/macosx/classes/com/apple/eawt/event/GestureUtilities.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011, 2012, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, 2017, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -25,13 +25,15 @@ package com.apple.eawt.event; -import javax.swing.*; +import javax.swing.JComponent; +import javax.swing.JFrame; +import javax.swing.JRootPane; /** * Registration utility class to add {@link GestureListener}s to Swing components. * * This class manages the relationship between {@link JComponent}s and the {@link GestureListener}s - * attached to them. It's design is similar to the Java SE 6u10 {@link com.sun.awt.AWTUtilities} + * attached to them. It's design is similar to the Java SE 6u10 {@code com.sun.awt.AWTUtilities} * class which adds additional functionality to AWT Windows, without adding new API to the * {@link java.awt.Window} class. * @@ -40,7 +42,6 @@ import javax.swing.*; * * @see GestureAdapter * @see JFrame#getRootPane() - * @see com.sun.awt.AWTUtilities * * @since Java for Mac OS X 10.5 Update 7, Java for Mac OS X 10.6 Update 2 */ diff --git a/src/java.desktop/macosx/classes/sun/lwawt/macosx/CPlatformWindow.java b/src/java.desktop/macosx/classes/sun/lwawt/macosx/CPlatformWindow.java index 297be1372d9..bc12d4887f4 100644 --- a/src/java.desktop/macosx/classes/sun/lwawt/macosx/CPlatformWindow.java +++ b/src/java.desktop/macosx/classes/sun/lwawt/macosx/CPlatformWindow.java @@ -25,13 +25,25 @@ package sun.lwawt.macosx; -import com.apple.eawt.FullScreenAdapter; -import com.apple.eawt.FullScreenUtilities; -import com.apple.eawt.event.FullScreenEvent; -import java.awt.*; +import java.awt.Color; +import java.awt.Component; +import java.awt.DefaultKeyboardFocusManager; +import java.awt.Dialog; import java.awt.Dialog.ModalityType; -import java.awt.event.*; -import java.beans.*; +import java.awt.Font; +import java.awt.FontMetrics; +import java.awt.Frame; +import java.awt.GraphicsDevice; +import java.awt.Insets; +import java.awt.MenuBar; +import java.awt.Point; +import java.awt.Rectangle; +import java.awt.Toolkit; +import java.awt.Window; +import java.awt.event.FocusEvent; +import java.awt.event.WindowEvent; +import java.beans.PropertyChangeEvent; +import java.beans.PropertyChangeListener; import java.lang.reflect.InvocationTargetException; import java.util.ArrayList; import java.util.Arrays; @@ -39,20 +51,22 @@ import java.util.concurrent.atomic.AtomicBoolean; import java.util.concurrent.atomic.AtomicLong; import java.util.concurrent.atomic.AtomicReference; -import javax.swing.*; +import javax.swing.JRootPane; +import javax.swing.RootPaneContainer; +import javax.swing.SwingUtilities; -import sun.awt.*; +import com.apple.laf.ClientPropertyApplicator; +import com.apple.laf.ClientPropertyApplicator.Property; +import sun.awt.AWTAccessor; import sun.awt.AWTAccessor.ComponentAccessor; import sun.awt.AWTAccessor.WindowAccessor; import sun.java2d.SurfaceData; import sun.java2d.opengl.CGLSurfaceData; -import sun.lwawt.*; -import sun.util.logging.PlatformLogger; - -import com.apple.laf.*; -import com.apple.laf.ClientPropertyApplicator.Property; -import com.sun.awt.AWTUtilities; +import sun.lwawt.LWToolkit; +import sun.lwawt.LWWindowPeer; import sun.lwawt.LWWindowPeer.PeerType; +import sun.lwawt.PlatformWindow; +import sun.util.logging.PlatformLogger; public class CPlatformWindow extends CFRetainedResource implements PlatformWindow { private native long nativeCreateNSWindow(long nsViewPtr,long ownerPtr, long styleBits, double x, double y, double w, double h); @@ -172,7 +186,7 @@ public class CPlatformWindow extends CFRetainedResource implements PlatformWindo c.setStyleBits(TEXTURED, Boolean.parseBoolean(value.toString())); }}, new Property(WINDOW_ALPHA) { public void applyProperty(final CPlatformWindow c, final Object value) { - AWTUtilities.setWindowOpacity(c.target, value == null ? 1.0f : Float.parseFloat(value.toString())); + c.target.setOpacity(value == null ? 1.0f : Float.parseFloat(value.toString())); }}, new Property(WINDOW_SHADOW) { public void applyProperty(final CPlatformWindow c, final Object value) { c.setStyleBits(HAS_SHADOW, value == null ? true : Boolean.parseBoolean(value.toString())); diff --git a/src/java.desktop/share/classes/com/sun/awt/AWTUtilities.java b/src/java.desktop/share/classes/com/sun/awt/AWTUtilities.java index e699937bd7f..1d16510d267 100644 --- a/src/java.desktop/share/classes/com/sun/awt/AWTUtilities.java +++ b/src/java.desktop/share/classes/com/sun/awt/AWTUtilities.java @@ -25,7 +25,16 @@ package com.sun.awt; -import java.awt.*; +import java.awt.Color; +import java.awt.Component; +import java.awt.Dialog; +import java.awt.Frame; +import java.awt.GraphicsConfiguration; +import java.awt.GraphicsDevice; +import java.awt.GraphicsEnvironment; +import java.awt.Shape; +import java.awt.Toolkit; +import java.awt.Window; import javax.swing.JRootPane; @@ -64,6 +73,7 @@ import sun.awt.SunToolkit; * drastically between update release, and it may even be * removed or be moved in some other package(s)/class(es). */ +@Deprecated(forRemoval = true, since = "10") public final class AWTUtilities { /** @@ -114,7 +124,10 @@ public final class AWTUtilities { * (either PERPIXEL_TRANSPARENT, * TRANSLUCENT, or PERPIXEL_TRANSLUCENT) * @return whether the given translucency kind is supported + * @deprecated use {@link GraphicsDevice#isWindowTranslucencySupported} + * instead */ + @Deprecated(forRemoval = true, since = "10") public static boolean isTranslucencySupported(Translucency translucencyKind) { switch (translucencyKind) { case PERPIXEL_TRANSPARENT: @@ -166,14 +179,15 @@ public final class AWTUtilities { * and the opacity is less than 1.0f * @throws UnsupportedOperationException if the TRANSLUCENT translucency * kind is not supported + * @deprecated use {@link Window#setOpacity} instead */ + @Deprecated(forRemoval = true, since = "10") public static void setWindowOpacity(Window window, float opacity) { if (window == null) { throw new NullPointerException( "The window argument should not be null."); } - - AWTAccessor.getWindowAccessor().setOpacity(window, opacity); + window.setOpacity(opacity); } /** @@ -182,14 +196,16 @@ public final class AWTUtilities { * * @param window the window to get the opacity level from * @throws NullPointerException if the window argument is null + * @deprecated use {@link Window#getOpacity} instead */ + @Deprecated(forRemoval = true, since = "10") public static float getWindowOpacity(Window window) { if (window == null) { throw new NullPointerException( "The window argument should not be null."); } - return AWTAccessor.getWindowAccessor().getOpacity(window); + return window.getOpacity(); } /** @@ -198,7 +214,10 @@ public final class AWTUtilities { * Note that this method may sometimes return true, but the native * windowing system may still not support the concept of * shaping (due to the bugs in the windowing system). + * @deprecated use {@link GraphicsDevice#isWindowTranslucencySupported} + * instead */ + @Deprecated(forRemoval = true, since = "10") public static boolean isWindowShapingSupported() { Toolkit curToolkit = Toolkit.getDefaultToolkit(); if (!(curToolkit instanceof SunToolkit)) { @@ -216,13 +235,15 @@ public final class AWTUtilities { * @param window the window to get the shape from * @return the current shape of the window * @throws NullPointerException if the window argument is null + * @deprecated use {@link Window#getShape} instead */ + @Deprecated(forRemoval = true, since = "10") public static Shape getWindowShape(Window window) { if (window == null) { throw new NullPointerException( "The window argument should not be null."); } - return AWTAccessor.getWindowAccessor().getShape(window); + return window.getShape(); } /** @@ -247,13 +268,15 @@ public final class AWTUtilities { * and the shape is not null * @throws UnsupportedOperationException if the PERPIXEL_TRANSPARENT * translucency kind is not supported + * @deprecated use {@link Window#setShape} instead */ + @Deprecated(forRemoval = true, since = "10") public static void setWindowShape(Window window, Shape shape) { if (window == null) { throw new NullPointerException( "The window argument should not be null."); } - AWTAccessor.getWindowAccessor().setShape(window, shape); + window.setShape(shape); } private static boolean isWindowTranslucencySupported() { @@ -349,7 +372,9 @@ public final class AWTUtilities { * isOpaque argument is {@code false}. * @throws UnsupportedOperationException if the PERPIXEL_TRANSLUCENT * translucency kind is not supported + * @deprecated use {@link Window#setBackground} instead */ + @Deprecated(forRemoval = true, since = "10") public static void setWindowOpaque(Window window, boolean isOpaque) { if (window == null) { throw new NullPointerException( @@ -359,7 +384,12 @@ public final class AWTUtilities { throw new UnsupportedOperationException( "The PERPIXEL_TRANSLUCENT translucency kind is not supported"); } - AWTAccessor.getWindowAccessor().setOpaque(window, isOpaque); + Color bg = window.getBackground(); + if (bg == null) { + bg = new Color(0, 0, 0, 0); + } + window.setBackground(new Color(bg.getRed(), bg.getGreen(), bg.getBlue(), + isOpaque ? 255 : 0)); } /** @@ -369,7 +399,9 @@ public final class AWTUtilities { * @return whether the window is currently opaque (true) * or translucent (false) * @throws NullPointerException if the window argument is null + * @deprecated use {@link Window#isOpaque} instead */ + @Deprecated(forRemoval = true, since = "10") public static boolean isWindowOpaque(Window window) { if (window == null) { throw new NullPointerException( @@ -395,7 +427,10 @@ public final class AWTUtilities { * @throws NullPointerException if the gc argument is null * @return whether the given GraphicsConfiguration supports * the translucency effects. + * @deprecated use {@link GraphicsConfiguration#isTranslucencyCapable} + * instead */ + @Deprecated(forRemoval = true, since = "10") public static boolean isTranslucencyCapable(GraphicsConfiguration gc) { if (gc == null) { throw new NullPointerException("The gc argument should not be null"); @@ -448,8 +483,9 @@ public final class AWTUtilities { * 'mixing-cutout' shape * @param shape the new 'mixing-cutout' shape * @throws NullPointerException if the component argument is {@code null} + * @deprecated use {@link Component#setMixingCutoutShape} instead */ - @Deprecated(since = "9") + @Deprecated(forRemoval = true, since = "9") public static void setComponentMixingCutoutShape(Component component, Shape shape) { diff --git a/src/java.desktop/share/classes/java/awt/Component.java b/src/java.desktop/share/classes/java/awt/Component.java index 6461f9bc24d..01db08c44c5 100644 --- a/src/java.desktop/share/classes/java/awt/Component.java +++ b/src/java.desktop/share/classes/java/awt/Component.java @@ -843,10 +843,6 @@ public abstract class Component implements ImageObserver, MenuContainer, public Rectangle getBounds(Component comp) { return new Rectangle(comp.x, comp.y, comp.width, comp.height); } - public void setMixingCutoutShape(Component comp, Shape shape) { - comp.setMixingCutoutShape(shape); - } - public void setGraphicsConfiguration(Component comp, GraphicsConfiguration gc) { diff --git a/src/java.desktop/share/classes/java/awt/GraphicsDevice.java b/src/java.desktop/share/classes/java/awt/GraphicsDevice.java index b8947148a7e..10cbd805899 100644 --- a/src/java.desktop/share/classes/java/awt/GraphicsDevice.java +++ b/src/java.desktop/share/classes/java/awt/GraphicsDevice.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2017, Oracle and/or its affiliates. All rights reserved. * 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,12 +23,10 @@ * questions. */ - package java.awt; import java.awt.image.ColorModel; -import sun.awt.AWTAccessor; import sun.awt.AppContext; import sun.awt.SunToolkit; diff --git a/src/java.desktop/share/classes/java/awt/Window.java b/src/java.desktop/share/classes/java/awt/Window.java index 8d122be3522..df4bbf27023 100644 --- a/src/java.desktop/share/classes/java/awt/Window.java +++ b/src/java.desktop/share/classes/java/awt/Window.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1995, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1995, 2017, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -22,9 +22,17 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package java.awt; -import java.awt.event.*; +import java.awt.event.ComponentEvent; +import java.awt.event.FocusEvent; +import java.awt.event.KeyEvent; +import java.awt.event.MouseWheelEvent; +import java.awt.event.WindowEvent; +import java.awt.event.WindowFocusListener; +import java.awt.event.WindowListener; +import java.awt.event.WindowStateListener; import java.awt.geom.Path2D; import java.awt.geom.Point2D; import java.awt.im.InputContext; @@ -48,7 +56,13 @@ import java.util.ResourceBundle; import java.util.Set; import java.util.Vector; import java.util.concurrent.atomic.AtomicBoolean; -import javax.accessibility.*; + +import javax.accessibility.Accessible; +import javax.accessibility.AccessibleContext; +import javax.accessibility.AccessibleRole; +import javax.accessibility.AccessibleState; +import javax.accessibility.AccessibleStateSet; + import sun.awt.AWTAccessor; import sun.awt.AWTPermissions; import sun.awt.AppContext; @@ -4050,26 +4064,6 @@ public class Window extends Container implements Accessible { static { AWTAccessor.setWindowAccessor(new AWTAccessor.WindowAccessor() { - public float getOpacity(Window window) { - return window.opacity; - } - public void setOpacity(Window window, float opacity) { - window.setOpacity(opacity); - } - public Shape getShape(Window window) { - return window.getShape(); - } - public void setShape(Window window, Shape shape) { - window.setShape(shape); - } - public void setOpaque(Window window, boolean opaque) { - Color bg = window.getBackground(); - if (bg == null) { - bg = new Color(0, 0, 0, 0); - } - window.setBackground(new Color(bg.getRed(), bg.getGreen(), bg.getBlue(), - opaque ? 255 : 0)); - } public void updateWindow(Window window) { window.updateWindow(); } diff --git a/src/java.desktop/share/classes/javax/swing/DefaultDesktopManager.java b/src/java.desktop/share/classes/javax/swing/DefaultDesktopManager.java index 8046037e471..bc666504c7e 100644 --- a/src/java.desktop/share/classes/javax/swing/DefaultDesktopManager.java +++ b/src/java.desktop/share/classes/javax/swing/DefaultDesktopManager.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2014, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2017, Oracle and/or its affiliates. All rights reserved. * 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,16 +23,22 @@ * questions. */ - package javax.swing; -import com.sun.awt.AWTUtilities; +import java.awt.Color; +import java.awt.Component; +import java.awt.Container; +import java.awt.Dimension; +import java.awt.Graphics; +import java.awt.Point; +import java.awt.Rectangle; +import java.awt.Toolkit; +import java.awt.Window; +import java.beans.PropertyVetoException; + import sun.awt.AWTAccessor; import sun.awt.SunToolkit; -import java.awt.*; -import java.beans.PropertyVetoException; - /** This is an implementation of the DesktopManager. * It currently implements the basic behaviors for managing * JInternalFrames in an arbitrary parent. @@ -315,7 +321,7 @@ public class DefaultDesktopManager implements DesktopManager, java.io.Serializab if (p != null) { String mode = (String)p.getClientProperty("JDesktopPane.dragMode"); Window window = SwingUtilities.getWindowAncestor(f); - if (window != null && !AWTUtilities.isWindowOpaque(window)) { + if (window != null && !window.isOpaque()) { dragMode = DEFAULT_DRAG_MODE; } else if (mode != null && mode.equals("outline")) { dragMode = OUTLINE_DRAG_MODE; diff --git a/src/java.desktop/share/classes/sun/awt/AWTAccessor.java b/src/java.desktop/share/classes/sun/awt/AWTAccessor.java index a23cfee8125..4ee449b8636 100644 --- a/src/java.desktop/share/classes/sun/awt/AWTAccessor.java +++ b/src/java.desktop/share/classes/sun/awt/AWTAccessor.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2008, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2008, 2017, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -290,26 +290,6 @@ public final class AWTAccessor { * An interface of accessor for java.awt.Window class. */ public interface WindowAccessor { - /* - * Get opacity level of the given window. - */ - float getOpacity(Window window); - /* - * Set opacity level to the given window. - */ - void setOpacity(Window window, float opacity); - /* - * Get a shape assigned to the given window. - */ - Shape getShape(Window window); - /* - * Set a shape to the given window. - */ - void setShape(Window window, Shape shape); - /* - * Set the opaque preoperty to the given window. - */ - void setOpaque(Window window, boolean isOpaque); /* * Update the image of a non-opaque (translucent) window. */ diff --git a/src/java.desktop/unix/classes/sun/awt/X11/XToolkit.java b/src/java.desktop/unix/classes/sun/awt/X11/XToolkit.java index 38a07057849..8f7834c14c2 100644 --- a/src/java.desktop/unix/classes/sun/awt/X11/XToolkit.java +++ b/src/java.desktop/unix/classes/sun/awt/X11/XToolkit.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2002, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2002, 2017, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -22,41 +22,135 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package sun.awt.X11; -import java.awt.peer.TaskbarPeer; -import java.awt.*; -import java.awt.event.InputEvent; -import java.awt.event.MouseEvent; -import java.awt.event.KeyEvent; +import java.awt.AWTError; +import java.awt.AWTException; +import java.awt.Button; +import java.awt.Canvas; +import java.awt.Checkbox; +import java.awt.CheckboxMenuItem; +import java.awt.Choice; +import java.awt.Color; +import java.awt.Component; +import java.awt.Cursor; +import java.awt.Desktop; +import java.awt.Dialog; +import java.awt.Dimension; +import java.awt.EventQueue; +import java.awt.FileDialog; +import java.awt.Frame; +import java.awt.GraphicsConfiguration; +import java.awt.GraphicsDevice; +import java.awt.GraphicsEnvironment; +import java.awt.HeadlessException; +import java.awt.Image; +import java.awt.Insets; +import java.awt.JobAttributes; +import java.awt.Label; +import java.awt.Menu; +import java.awt.MenuBar; +import java.awt.MenuItem; +import java.awt.PageAttributes; +import java.awt.Panel; +import java.awt.Point; +import java.awt.PopupMenu; +import java.awt.PrintJob; +import java.awt.Rectangle; +import java.awt.Robot; +import java.awt.ScrollPane; +import java.awt.Scrollbar; +import java.awt.SystemColor; +import java.awt.SystemTray; +import java.awt.Taskbar; +import java.awt.TextArea; +import java.awt.TextField; +import java.awt.Toolkit; +import java.awt.TrayIcon; +import java.awt.Window; import java.awt.datatransfer.Clipboard; -import java.awt.dnd.DragSource; -import java.awt.dnd.DragGestureListener; import java.awt.dnd.DragGestureEvent; +import java.awt.dnd.DragGestureListener; import java.awt.dnd.DragGestureRecognizer; -import java.awt.dnd.MouseDragGestureRecognizer; +import java.awt.dnd.DragSource; import java.awt.dnd.InvalidDnDOperationException; +import java.awt.dnd.MouseDragGestureRecognizer; import java.awt.dnd.peer.DragSourceContextPeer; +import java.awt.event.InputEvent; +import java.awt.event.KeyEvent; +import java.awt.event.MouseEvent; import java.awt.font.TextAttribute; import java.awt.im.InputMethodHighlight; import java.awt.im.spi.InputMethodDescriptor; -import java.awt.peer.*; +import java.awt.peer.ButtonPeer; +import java.awt.peer.CanvasPeer; +import java.awt.peer.CheckboxMenuItemPeer; +import java.awt.peer.CheckboxPeer; +import java.awt.peer.ChoicePeer; +import java.awt.peer.DesktopPeer; +import java.awt.peer.DialogPeer; +import java.awt.peer.FileDialogPeer; +import java.awt.peer.FontPeer; +import java.awt.peer.FramePeer; +import java.awt.peer.KeyboardFocusManagerPeer; +import java.awt.peer.LabelPeer; +import java.awt.peer.ListPeer; +import java.awt.peer.MenuBarPeer; +import java.awt.peer.MenuItemPeer; +import java.awt.peer.MenuPeer; +import java.awt.peer.MouseInfoPeer; +import java.awt.peer.PanelPeer; +import java.awt.peer.PopupMenuPeer; +import java.awt.peer.RobotPeer; +import java.awt.peer.ScrollPanePeer; +import java.awt.peer.ScrollbarPeer; +import java.awt.peer.SystemTrayPeer; +import java.awt.peer.TaskbarPeer; +import java.awt.peer.TextAreaPeer; +import java.awt.peer.TextFieldPeer; +import java.awt.peer.TrayIconPeer; +import java.awt.peer.WindowPeer; import java.beans.PropertyChangeListener; import java.security.AccessController; import java.security.PrivilegedAction; -import java.util.*; +import java.util.ArrayList; +import java.util.Collection; +import java.util.HashMap; +import java.util.Iterator; +import java.util.LinkedList; +import java.util.Map; +import java.util.NoSuchElementException; +import java.util.Properties; +import java.util.Set; +import java.util.SortedMap; +import java.util.TreeMap; +import java.util.Vector; + import javax.swing.LookAndFeel; import javax.swing.UIDefaults; -import sun.awt.*; + +import sun.awt.AWTAccessor; +import sun.awt.AWTPermissions; +import sun.awt.AppContext; +import sun.awt.DisplayChangedListener; +import sun.awt.LightweightFrame; +import sun.awt.SunToolkit; +import sun.awt.UNIXToolkit; +import sun.awt.X11GraphicsConfig; +import sun.awt.X11GraphicsDevice; +import sun.awt.X11GraphicsEnvironment; +import sun.awt.XSettings; import sun.awt.datatransfer.DataTransferer; -import sun.font.FontConfigManager; -import sun.java2d.SunGraphicsEnvironment; import sun.awt.util.PerformanceLogger; import sun.awt.util.ThreadGroupUtils; +import sun.font.FontConfigManager; +import sun.java2d.SunGraphicsEnvironment; import sun.print.PrintJob2D; -import sun.security.action.GetPropertyAction; import sun.security.action.GetBooleanAction; +import sun.security.action.GetPropertyAction; import sun.util.logging.PlatformLogger; + import static sun.awt.X11.XlibUtil.scaleDown; public final class XToolkit extends UNIXToolkit implements Runnable { @@ -2587,7 +2681,7 @@ public final class XToolkit extends UNIXToolkit implements Runnable { @Override public boolean isWindowTranslucencySupported() { //NOTE: it may not be supported. The actual check is being performed - // at com.sun.awt.AWTUtilities(). In X11 we need to check + // at java.awt.GraphicsDevice. In X11 we need to check // whether there's any translucency-capable GC available. return true; } diff --git a/src/java.desktop/unix/classes/sun/awt/X11/XWindowPeer.java b/src/java.desktop/unix/classes/sun/awt/X11/XWindowPeer.java index 05fe8163e93..92cc7ba10b9 100644 --- a/src/java.desktop/unix/classes/sun/awt/X11/XWindowPeer.java +++ b/src/java.desktop/unix/classes/sun/awt/X11/XWindowPeer.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2002, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2002, 2017, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -22,42 +22,50 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package sun.awt.X11; -import java.awt.*; - +import java.awt.AWTEvent; +import java.awt.Component; +import java.awt.Dialog; +import java.awt.Dimension; +import java.awt.EventQueue; +import java.awt.Frame; +import java.awt.Graphics; +import java.awt.GraphicsConfiguration; +import java.awt.GraphicsDevice; +import java.awt.GraphicsEnvironment; +import java.awt.Image; +import java.awt.Insets; +import java.awt.Point; +import java.awt.Rectangle; +import java.awt.Shape; +import java.awt.SystemColor; +import java.awt.Window; import java.awt.event.ComponentEvent; import java.awt.event.FocusEvent; import java.awt.event.WindowEvent; -import java.awt.geom.AffineTransform; - import java.awt.peer.ComponentPeer; import java.awt.peer.WindowPeer; - import java.io.UnsupportedEncodingException; - import java.security.AccessController; import java.security.PrivilegedAction; - import java.util.ArrayList; import java.util.HashSet; import java.util.Iterator; import java.util.Set; import java.util.Vector; - import java.util.concurrent.atomic.AtomicBoolean; -import sun.awt.AWTAccessor.ComponentAccessor; -import sun.util.logging.PlatformLogger; - import sun.awt.AWTAccessor; +import sun.awt.AWTAccessor.ComponentAccessor; import sun.awt.DisplayChangedListener; +import sun.awt.IconInfo; import sun.awt.SunToolkit; import sun.awt.X11GraphicsDevice; import sun.awt.X11GraphicsEnvironment; -import sun.awt.IconInfo; - import sun.java2d.pipe.Region; +import sun.util.logging.PlatformLogger; class XWindowPeer extends XPanelPeer implements WindowPeer, DisplayChangedListener { @@ -446,16 +454,14 @@ class XWindowPeer extends XPanelPeer implements WindowPeer, } private void updateShape() { - // Shape shape = ((Window)target).getShape(); - Shape shape = AWTAccessor.getWindowAccessor().getShape((Window)target); + Shape shape = ((Window)target).getShape(); if (shape != null) { applyShape(Region.getInstance(shape, null)); } } private void updateOpacity() { - // float opacity = ((Window)target).getOpacity(); - float opacity = AWTAccessor.getWindowAccessor().getOpacity((Window)target); + float opacity = ((Window)target).getOpacity(); if (opacity < 1.0f) { setOpacity(opacity); } @@ -2375,7 +2381,7 @@ class XWindowPeer extends XPanelPeer implements WindowPeer, public void print(Graphics g) { // We assume we print the whole frame, // so we expect no clip was set previously - Shape shape = AWTAccessor.getWindowAccessor().getShape((Window)target); + Shape shape = ((Window)target).getShape(); if (shape != null) { g.setClip(shape); } diff --git a/src/java.desktop/windows/classes/sun/awt/windows/WWindowPeer.java b/src/java.desktop/windows/classes/sun/awt/windows/WWindowPeer.java index d1a296495f5..9de3d9baf97 100644 --- a/src/java.desktop/windows/classes/sun/awt/windows/WWindowPeer.java +++ b/src/java.desktop/windows/classes/sun/awt/windows/WWindowPeer.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2017, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -22,23 +22,48 @@ * or visit www.oracle.com if you need additional information or have any * questions. */ + package sun.awt.windows; -import java.awt.*; -import java.awt.event.*; -import java.awt.image.*; -import java.awt.peer.*; - -import java.beans.*; - -import java.util.*; -import java.util.List; -import sun.util.logging.PlatformLogger; +import java.awt.AWTEvent; +import java.awt.AWTEventMulticaster; +import java.awt.Color; +import java.awt.Component; +import java.awt.Container; +import java.awt.Dialog; +import java.awt.Dimension; +import java.awt.Graphics; +import java.awt.GraphicsConfiguration; +import java.awt.GraphicsDevice; +import java.awt.GraphicsEnvironment; +import java.awt.Image; +import java.awt.Insets; +import java.awt.KeyboardFocusManager; +import java.awt.Rectangle; +import java.awt.Shape; +import java.awt.SystemColor; +import java.awt.Window; +import java.awt.event.FocusEvent; +import java.awt.event.WindowEvent; +import java.awt.event.WindowListener; import java.awt.geom.AffineTransform; -import sun.awt.*; +import java.awt.image.DataBufferInt; +import java.awt.peer.WindowPeer; +import java.beans.PropertyChangeEvent; +import java.beans.PropertyChangeListener; +import java.util.LinkedList; +import java.util.List; +import sun.awt.AWTAccessor; +import sun.awt.AppContext; +import sun.awt.DisplayChangedListener; +import sun.awt.SunToolkit; +import sun.awt.Win32GraphicsConfig; +import sun.awt.Win32GraphicsDevice; +import sun.awt.Win32GraphicsEnvironment; import sun.java2d.pipe.Region; import sun.swing.SwingUtilities2; +import sun.util.logging.PlatformLogger; public class WWindowPeer extends WPanelPeer implements WindowPeer, DisplayChangedListener @@ -671,7 +696,7 @@ public class WWindowPeer extends WPanelPeer implements WindowPeer, public void print(Graphics g) { // We assume we print the whole frame, // so we expect no clip was set previously - Shape shape = AWTAccessor.getWindowAccessor().getShape((Window)target); + Shape shape = ((Window)target).getShape(); if (shape != null) { g.setClip(shape); } diff --git a/test/jdk/com/sun/awt/Translucency/WindowOpacity.java b/test/jdk/com/sun/awt/Translucency/WindowOpacity.java deleted file mode 100644 index 634c1a045b9..00000000000 --- a/test/jdk/com/sun/awt/Translucency/WindowOpacity.java +++ /dev/null @@ -1,467 +0,0 @@ -/* - * Copyright (c) 2008, 2016, Oracle and/or its affiliates. All rights reserved. - * 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 %W% %E% - @key headful - @bug 6594131 - @summary Tests the AWTUtilities.get/setWindowOpacity() methods - @author anthony.petrov@...: area=awt.toplevel - @modules java.desktop/com.sun.awt - @run main WindowOpacity -*/ - -import java.awt.*; -import java.awt.event.*; - -import com.sun.awt.AWTUtilities; - -public class WindowOpacity -{ - //*** test-writer defined static variables go here *** - - private static Robot robot; - - - private static void init() - { - //*** Create instructions for the user here *** - String[] instructions = - { - "This is an AUTOMATIC test, simply wait until it is done.", - "The result (passed or failed) will be shown in the", - "message window below." - }; - Sysout.createDialog( ); - Sysout.printInstructions( instructions ); - - if (!AWTUtilities.isTranslucencySupported(AWTUtilities.Translucency.TRANSLUCENT)) { - System.out.println("Either the Toolkit or the native system does not support controlling the window opacity level."); - pass(); - } - try { - robot = new Robot(); - }catch(Exception ex) { - ex.printStackTrace(); - throw new RuntimeException ("Unexpected failure"); - } - - boolean passed; - - Frame f = new Frame("Opacity test"); - f.setUndecorated(true); - - passed = false; - try { - AWTUtilities.getWindowOpacity(null); - } catch (NullPointerException e) { - passed = true; - } - if (!passed) { - fail("getWindowOpacity() allows passing null."); - } - - - passed = false; - try { - AWTUtilities.setWindowOpacity(null, 0.5f); - } catch (NullPointerException e) { - passed = true; - } - if (!passed) { - fail("setWindowOpacity() allows passing null."); - } - - - float curOpacity = AWTUtilities.getWindowOpacity(f); - if (curOpacity < 1.0f || curOpacity > 1.0f) { - fail("getWindowOpacity() reports the initial opacity level other than 1.0: " + curOpacity); - } - - - - passed = false; - try { - AWTUtilities.setWindowOpacity(f, -0.5f); - } catch (IllegalArgumentException e) { - passed = true; - } - if (!passed) { - fail("setWindowOpacity() allows passing negative opacity level."); - } - - - - passed = false; - try { - AWTUtilities.setWindowOpacity(f, 1.5f); - } catch (IllegalArgumentException e) { - passed = true; - } - if (!passed) { - fail("setWindowOpacity() allows passing opacity level greater than 1.0."); - } - - - AWTUtilities.setWindowOpacity(f, 0.5f); - - curOpacity = AWTUtilities.getWindowOpacity(f); - if (curOpacity < 0.5f || curOpacity > 0.5f) { - fail("getWindowOpacity() reports the opacity level that differs from the value set with setWindowOpacity: " + curOpacity); - } - - - AWTUtilities.setWindowOpacity(f, 0.75f); - - curOpacity = AWTUtilities.getWindowOpacity(f); - if (curOpacity < 0.75f || curOpacity > 0.75f) { - fail("getWindowOpacity() reports the opacity level that differs from the value set with setWindowOpacity the second time: " + curOpacity); - } - - - f.setBounds(100, 100, 300, 200); - f.setVisible(true); - - robot.waitForIdle(); - - curOpacity = AWTUtilities.getWindowOpacity(f); - if (curOpacity < 0.75f || curOpacity > 0.75f) { - fail("getWindowOpacity() reports the opacity level that differs from the value set with setWindowOpacity before showing the frame: " + curOpacity); - } - - - - AWTUtilities.setWindowOpacity(f, 0.5f); - robot.waitForIdle(); - - curOpacity = AWTUtilities.getWindowOpacity(f); - if (curOpacity < 0.5f || curOpacity > 0.5f) { - fail("getWindowOpacity() reports the opacity level that differs from the value set with setWindowOpacity after showing the frame: " + curOpacity); - } - - WindowOpacity.pass(); - - }//End init() - - - - /***************************************************** - * Standard Test Machinery Section - * DO NOT modify anything in this section -- it's a - * standard chunk of code which has all of the - * synchronisation necessary for the test harness. - * By keeping it the same in all tests, it is easier - * to read and understand someone else's test, as - * well as insuring that all tests behave correctly - * with the test harness. - * There is a section following this for test- - * classes - ******************************************************/ - private static boolean theTestPassed = false; - private static boolean testGeneratedInterrupt = false; - private static String failureMessage = ""; - - private static Thread mainThread = null; - - private static int sleepTime = 300000; - - // Not sure about what happens if multiple of this test are - // instantiated in the same VM. Being static (and using - // static vars), it aint gonna work. Not worrying about - // it for now. - public static void main( String args[] ) throws InterruptedException - { - mainThread = Thread.currentThread(); - try - { - init(); - } - catch( TestPassedException e ) - { - //The test passed, so just return from main and harness will - // interepret this return as a pass - return; - } - //At this point, neither test pass nor test fail has been - // called -- either would have thrown an exception and ended the - // test, so we know we have multiple threads. - - //Test involves other threads, so sleep and wait for them to - // called pass() or fail() - try - { - Thread.sleep( sleepTime ); - //Timed out, so fail the test - throw new RuntimeException( "Timed out after " + sleepTime/1000 + " seconds" ); - } - catch (InterruptedException e) - { - //The test harness may have interrupted the test. If so, rethrow the exception - // so that the harness gets it and deals with it. - if( ! testGeneratedInterrupt ) throw e; - - //reset flag in case hit this code more than once for some reason (just safety) - testGeneratedInterrupt = false; - - if ( theTestPassed == false ) - { - throw new RuntimeException( failureMessage ); - } - } - - }//main - - public static synchronized void setTimeoutTo( int seconds ) - { - sleepTime = seconds * 1000; - } - - public static synchronized void pass() - { - Sysout.println( "The test passed." ); - Sysout.println( "The test is over, hit Ctl-C to stop Java VM" ); - //first check if this is executing in main thread - if ( mainThread == Thread.currentThread() ) - { - //Still in the main thread, so set the flag just for kicks, - // and throw a test passed exception which will be caught - // and end the test. - theTestPassed = true; - throw new TestPassedException(); - } - theTestPassed = true; - testGeneratedInterrupt = true; - mainThread.interrupt(); - }//pass() - - public static synchronized void fail() - { - //test writer didn't specify why test failed, so give generic - fail( "it just plain failed! :-)" ); - } - - public static synchronized void fail( String whyFailed ) - { - Sysout.println( "The test failed: " + whyFailed ); - Sysout.println( "The test is over, hit Ctl-C to stop Java VM" ); - //check if this called from main thread - if ( mainThread == Thread.currentThread() ) - { - //If main thread, fail now 'cause not sleeping - throw new RuntimeException( whyFailed ); - } - theTestPassed = false; - testGeneratedInterrupt = true; - failureMessage = whyFailed; - mainThread.interrupt(); - }//fail() - -}// class WindowOpacity - -//This exception is used to exit from any level of call nesting -// when it's determined that the test has passed, and immediately -// end the test. -class TestPassedException extends RuntimeException -{ -} - -//*********** End Standard Test Machinery Section ********** - - -//************ Begin classes defined for the test **************** - -// if want to make listeners, here is the recommended place for them, then instantiate -// them in init() - -/* Example of a class which may be written as part of a test -class NewClass implements anInterface - { - static int newVar = 0; - - public void eventDispatched(AWTEvent e) - { - //Counting events to see if we get enough - eventCount++; - - if( eventCount == 20 ) - { - //got enough events, so pass - - WindowOpacity.pass(); - } - else if( tries == 20 ) - { - //tried too many times without getting enough events so fail - - WindowOpacity.fail(); - } - - }// eventDispatched() - - }// NewClass class - -*/ - - -//************** End classes defined for the test ******************* - - - - -/**************************************************** - Standard Test Machinery - DO NOT modify anything below -- it's a standard - chunk of code whose purpose is to make user - interaction uniform, and thereby make it simpler - to read and understand someone else's test. - ****************************************************/ - -/** - This is part of the standard test machinery. - It creates a dialog (with the instructions), and is the interface - for sending text messages to the user. - To print the instructions, send an array of strings to Sysout.createDialog - WithInstructions method. Put one line of instructions per array entry. - To display a message for the tester to see, simply call Sysout.println - with the string to be displayed. - This mimics System.out.println but works within the test harness as well - as standalone. - */ - -class Sysout -{ - private static TestDialog dialog; - - public static void createDialogWithInstructions( String[] instructions ) - { - dialog = new TestDialog( new Frame(), "Instructions" ); - dialog.printInstructions( instructions ); - dialog.setVisible(true); - println( "Any messages for the tester will display here." ); - } - - public static void createDialog( ) - { - dialog = new TestDialog( new Frame(), "Instructions" ); - String[] defInstr = { "Instructions will appear here. ", "" } ; - dialog.printInstructions( defInstr ); - dialog.setVisible(true); - println( "Any messages for the tester will display here." ); - } - - - public static void printInstructions( String[] instructions ) - { - dialog.printInstructions( instructions ); - } - - - public static void println( String messageIn ) - { - dialog.displayMessage( messageIn ); - System.out.println(messageIn); - } - -}// Sysout class - -/** - This is part of the standard test machinery. It provides a place for the - test instructions to be displayed, and a place for interactive messages - to the user to be displayed. - To have the test instructions displayed, see Sysout. - To have a message to the user be displayed, see Sysout. - Do not call anything in this dialog directly. - */ -class TestDialog extends Dialog -{ - - TextArea instructionsText; - TextArea messageText; - int maxStringLength = 80; - - //DO NOT call this directly, go through Sysout - public TestDialog( Frame frame, String name ) - { - super( frame, name ); - int scrollBoth = TextArea.SCROLLBARS_BOTH; - instructionsText = new TextArea( "", 15, maxStringLength, scrollBoth ); - add( "North", instructionsText ); - - messageText = new TextArea( "", 5, maxStringLength, scrollBoth ); - add("Center", messageText); - - pack(); - - setVisible(true); - }// TestDialog() - - //DO NOT call this directly, go through Sysout - public void printInstructions( String[] instructions ) - { - //Clear out any current instructions - instructionsText.setText( "" ); - - //Go down array of instruction strings - - String printStr, remainingStr; - for( int i=0; i < instructions.length; i++ ) - { - //chop up each into pieces maxSringLength long - remainingStr = instructions[ i ]; - while( remainingStr.length() > 0 ) - { - //if longer than max then chop off first max chars to print - if( remainingStr.length() >= maxStringLength ) - { - //Try to chop on a word boundary - int posOfSpace = remainingStr. - lastIndexOf( ' ', maxStringLength - 1 ); - - if( posOfSpace <= 0 ) posOfSpace = maxStringLength - 1; - - printStr = remainingStr.substring( 0, posOfSpace + 1 ); - remainingStr = remainingStr.substring( posOfSpace + 1 ); - } - //else just print - else - { - printStr = remainingStr; - remainingStr = ""; - } - - instructionsText.append( printStr + "\n" ); - - }// while - - }// for - - }//printInstructions() - - //DO NOT call this directly, go through Sysout - public void displayMessage( String messageIn ) - { - messageText.append( messageIn + "\n" ); - System.out.println(messageIn); - } - -}// TestDialog class diff --git a/test/jdk/java/awt/Window/ShapedAndTranslucentWindows/WindowOpacity.java b/test/jdk/java/awt/Window/ShapedAndTranslucentWindows/WindowOpacity.java new file mode 100644 index 00000000000..5ac9cb92c2a --- /dev/null +++ b/test/jdk/java/awt/Window/ShapedAndTranslucentWindows/WindowOpacity.java @@ -0,0 +1,139 @@ +/* + * Copyright (c) 2008, 2017, Oracle and/or its affiliates. All rights reserved. + * 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 + @key headful + @bug 6594131 8186617 + @summary Tests the Window.get/setOpacity() methods +*/ + +import java.awt.AWTException; +import java.awt.Frame; +import java.awt.GraphicsDevice; +import java.awt.GraphicsEnvironment; +import java.awt.Robot; + +public class WindowOpacity { + + public static void main(String[] args) throws Exception { + GraphicsDevice gd = + GraphicsEnvironment.getLocalGraphicsEnvironment() + .getDefaultScreenDevice(); + if (!gd.isWindowTranslucencySupported( + GraphicsDevice.WindowTranslucency.TRANSLUCENT)) { + System.out.println( + "Either the Toolkit or the native system does not support" + + " controlling the window opacity level."); + return; + } + Frame f = new Frame("Opacity test"); + try { + test(f); + } finally { + f.dispose(); + } + } + + private static void test(final Frame f) throws AWTException { + boolean passed; + + f.setUndecorated(true); + float curOpacity = f.getOpacity(); + if (curOpacity < 1.0f || curOpacity > 1.0f) { + throw new RuntimeException( + "getOpacity() reports the initial opacity level " + + "other than 1.0: " + curOpacity); + } + + + passed = false; + try { + f.setOpacity(-0.5f); + } catch (IllegalArgumentException e) { + passed = true; + } + if (!passed) { + throw new RuntimeException( + "setOpacity() allows passing negative opacity level."); + } + + + passed = false; + try { + f.setOpacity(1.5f); + } catch (IllegalArgumentException e) { + passed = true; + } + if (!passed) { + throw new RuntimeException( + "setOpacity() allows passing opacity level greater than 1.0."); + } + + + f.setOpacity(0.5f); + curOpacity = f.getOpacity(); + if (curOpacity < 0.5f || curOpacity > 0.5f) { + throw new RuntimeException( + "setOpacity() reports the opacity level that " + + "differs from the value set with " + + "setWindowOpacity: " + curOpacity); + } + + + f.setOpacity(0.75f); + curOpacity = f.getOpacity(); + if (curOpacity < 0.75f || curOpacity > 0.75f) { + throw new RuntimeException( + "getOpacity() reports the opacity level that " + + "differs from the value set with " + + "setWindowOpacity the second time: " + + curOpacity); + } + + + f.setBounds(100, 100, 300, 200); + f.setVisible(true); + Robot robot = new Robot(); + robot.waitForIdle(); + + curOpacity = f.getOpacity(); + if (curOpacity < 0.75f || curOpacity > 0.75f) { + throw new RuntimeException( + "getOpacity() reports the opacity level that " + + "differs from the value set with " + + "setWindowOpacity before showing the frame: " + + curOpacity); + } + f.setOpacity(0.5f); + robot.waitForIdle(); + curOpacity = f.getOpacity(); + if (curOpacity < 0.5f || curOpacity > 0.5f) { + throw new RuntimeException( + "getOpacity() reports the opacity level that " + + "differs from the value set with " + + "setWindowOpacity after showing the frame: " + + curOpacity); + } + } +} diff --git a/test/jdk/javax/swing/JComponent/6683775/bug6683775.java b/test/jdk/javax/swing/JComponent/6683775/bug6683775.java index d069a281fb1..c5572e83919 100644 --- a/test/jdk/javax/swing/JComponent/6683775/bug6683775.java +++ b/test/jdk/javax/swing/JComponent/6683775/bug6683775.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2009, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2009, 2017, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -24,29 +24,32 @@ /* * @test * @key headful - * @bug 6683775 6794764 - * @summary Painting artifacts is seen when panel is made setOpaque(false) for a translucent window - * @author Alexander Potochkin - * @modules java.desktop/com.sun.awt - * java.desktop/sun.awt - * @run main bug6683775 + * @bug 6683775 6794764 8186617 + * @summary Painting artifacts is seen when panel is made setOpaque(false) for a + * translucent window */ -import com.sun.awt.AWTUtilities; - -import javax.swing.*; -import java.awt.*; +import java.awt.Color; +import java.awt.GraphicsConfiguration; +import java.awt.GraphicsDevice; +import java.awt.GraphicsEnvironment; +import java.awt.Rectangle; +import java.awt.Robot; +import java.awt.Window; import java.awt.image.BufferedImage; +import javax.swing.JFrame; +import javax.swing.JPanel; +import javax.swing.SwingUtilities; + public class bug6683775 { static final int LOC = 100, SIZE = 200; public static void main(String[] args) throws Exception { GraphicsConfiguration gc = getGC(); - if (!AWTUtilities.isTranslucencySupported( - AWTUtilities.Translucency.PERPIXEL_TRANSLUCENT) - || gc == null) { + if (gc == null || !gc.getDevice().isWindowTranslucencySupported( + GraphicsDevice.WindowTranslucency.PERPIXEL_TRANSLUCENT)) { return; } Robot robot = new Robot(); @@ -65,7 +68,7 @@ public class bug6683775 { JPanel p = new JPanel(); p.setOpaque(false); testFrame.add(p); - AWTUtilities.setWindowOpaque(testFrame, false); + setOpaque(testFrame, false); testFrame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); testFrame.setBounds(LOC, LOC, SIZE, SIZE); testFrame.setVisible(true); @@ -78,17 +81,28 @@ public class bug6683775 { BufferedImage capture = robot.createScreenCapture(new Rectangle(LOC, LOC, SIZE, SIZE)); + SwingUtilities.invokeAndWait(testFrame::dispose); + int redRGB = Color.RED.getRGB(); if (redRGB != capture.getRGB(SIZE/2, SIZE/2)) { throw new RuntimeException("Transparent frame is not transparent!"); } } + public static void setOpaque(Window window, boolean opaque) { + Color bg = window.getBackground(); + if (bg == null) { + bg = new Color(0, 0, 0, 0); + } + window.setBackground(new Color(bg.getRed(), bg.getGreen(), bg.getBlue(), + opaque ? 255 : 0)); + } + private static GraphicsConfiguration getGC() { GraphicsConfiguration transparencyCapableGC = GraphicsEnvironment.getLocalGraphicsEnvironment() .getDefaultScreenDevice().getDefaultConfiguration(); - if (!AWTUtilities.isTranslucencyCapable(transparencyCapableGC)) { + if (!transparencyCapableGC.isTranslucencyCapable()) { transparencyCapableGC = null; GraphicsEnvironment env = @@ -98,7 +112,7 @@ public class bug6683775 { for (int i = 0; i < devices.length && transparencyCapableGC == null; i++) { GraphicsConfiguration[] configs = devices[i].getConfigurations(); for (int j = 0; j < configs.length && transparencyCapableGC == null; j++) { - if (AWTUtilities.isTranslucencyCapable(configs[j])) { + if (configs[j].isTranslucencyCapable()) { transparencyCapableGC = configs[j]; } } diff --git a/test/jdk/javax/swing/JInternalFrame/6726866/bug6726866.java b/test/jdk/javax/swing/JInternalFrame/6726866/bug6726866.java index 4d107cc28ac..d56f10d39ef 100644 --- a/test/jdk/javax/swing/JInternalFrame/6726866/bug6726866.java +++ b/test/jdk/javax/swing/JInternalFrame/6726866/bug6726866.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2009, 2013, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2009, 2017, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -22,15 +22,20 @@ */ /* @test - @bug 6726866 - @summary Repainting artifacts when resizing or dragging JInternalFrames in non-opaque toplevel - @author Alexander Potochkin + @bug 6726866 8186617 + @summary Repainting artifacts when resizing or dragging JInternalFrames in + non-opaque toplevel @run applet/manual=yesno bug6726866.html */ -import javax.swing.*; -import java.awt.*; -import java.lang.reflect.Method; +import java.awt.Color; +import java.awt.Window; + +import javax.swing.JApplet; +import javax.swing.JDesktopPane; +import javax.swing.JFrame; +import javax.swing.JInternalFrame; +import javax.swing.JLabel; public class bug6726866 extends JApplet { @@ -54,14 +59,12 @@ public class bug6726866 extends JApplet { frame.toFront(); } - private void setWindowNonOpaque(Window w) { - try { - Class c = Class.forName("com.sun.awt.AWTUtilities"); - Method m = c.getMethod("setWindowOpaque", Window.class, boolean.class); - m.invoke(null, w, false); - } - catch (Exception e) { - e.printStackTrace(); + public static void setWindowNonOpaque(Window window) { + Color bg = window.getBackground(); + if (bg == null) { + bg = new Color(0, 0, 0, 0); } + window.setBackground( + new Color(bg.getRed(), bg.getGreen(), bg.getBlue(), 0)); } } diff --git a/test/jdk/javax/swing/JPopupMenu/7156657/bug7156657.java b/test/jdk/javax/swing/JPopupMenu/7156657/bug7156657.java index 8851eabd5f5..1aef52c1f4d 100644 --- a/test/jdk/javax/swing/JPopupMenu/7156657/bug7156657.java +++ b/test/jdk/javax/swing/JPopupMenu/7156657/bug7156657.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 2017, Oracle and/or its affiliates. All rights reserved. * 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,23 +21,33 @@ * questions. */ -import com.sun.awt.AWTUtilities; -import sun.awt.SunToolkit; - -import javax.swing.*; -import java.awt.*; +import java.awt.AlphaComposite; +import java.awt.Color; +import java.awt.Graphics; +import java.awt.Graphics2D; +import java.awt.Rectangle; +import java.awt.Robot; +import java.awt.Toolkit; +import java.awt.Window; import java.awt.image.BufferedImage; import java.util.concurrent.Callable; +import javax.swing.JFrame; +import javax.swing.JMenuItem; +import javax.swing.JPanel; +import javax.swing.JPopupMenu; +import javax.swing.SwingUtilities; + +import sun.awt.SunToolkit; + /* @test - @key headful - @bug 7156657 - @summary Version 7 doesn't support translucent popup menus against a translucent window + @key headful + @bug 7156657 8186617 + @summary Version 7 doesn't support translucent popup menus against a + translucent window @library ../../regtesthelpers - @author Pavel Porvatov - @modules java.desktop/com.sun.awt - java.desktop/sun.awt + @modules java.desktop/sun.awt */ public class bug7156657 { private static JFrame lowerFrame; @@ -54,8 +64,7 @@ public class bug7156657 { @Override public Boolean call() throws Exception { frame = createFrame(); - - if (!AWTUtilities.isTranslucencyCapable(frame.getGraphicsConfiguration())) { + if (!frame.getGraphicsConfiguration().isTranslucencyCapable()) { System.out.println("Translucency is not supported, the test skipped"); return true; @@ -71,7 +80,7 @@ public class bug7156657 { popupMenu.add(new TransparentMenuItem("2222")); popupMenu.add(new TransparentMenuItem("3333")); - AWTUtilities.setWindowOpaque(frame, false); + setOpaque(frame, false); JPanel pnContent = new JPanel(); pnContent.setBackground(new Color(255, 255, 255, 128)); frame.add(pnContent); @@ -132,6 +141,14 @@ public class bug7156657 { System.out.println("The test passed"); } + public static void setOpaque(Window window, boolean opaque) { + Color bg = window.getBackground(); + if (bg == null) { + bg = new Color(0, 0, 0, 0); + } + window.setBackground(new Color(bg.getRed(), bg.getGreen(), bg.getBlue(), + opaque ? 255 : 0)); + } private static JFrame createFrame() { JFrame result = new JFrame(); From e3c6e350c8ffb3600d4cf45037142bbef8c4e871 Mon Sep 17 00:00:00 2001 From: Jayathirth D V Date: Mon, 30 Oct 2017 12:16:56 +0530 Subject: [PATCH 14/39] 8177455: TIFFCompressor has a reference to non-existent method Reviewed-by: prr, bpb --- .../com/sun/imageio/plugins/tiff/TIFFCompressor.java | 7 +------ 1 file changed, 1 insertion(+), 6 deletions(-) diff --git a/src/java.desktop/share/classes/com/sun/imageio/plugins/tiff/TIFFCompressor.java b/src/java.desktop/share/classes/com/sun/imageio/plugins/tiff/TIFFCompressor.java index ce1b2a58fa1..4610ca7fbf4 100644 --- a/src/java.desktop/share/classes/com/sun/imageio/plugins/tiff/TIFFCompressor.java +++ b/src/java.desktop/share/classes/com/sun/imageio/plugins/tiff/TIFFCompressor.java @@ -68,12 +68,7 @@ public abstract class TIFFCompressor { protected ImageOutputStream stream; /** - * Creates a compressor object for use in compressing TIFF data. This - * object may be passed to the - * {@link TIFFImageWriteParam#setTIFFCompressor(TIFFCompressor)} - * method to override the compressor of a supported compression type or - * to provide the implementation of the compression algorithm of an - * unsupported compression type. + * Creates a compressor object for use in compressing TIFF data. * *

The parameters {@code compressionTagValue} and * {@code isCompressionLossless} are provided to accomodate From fab3dea7117c0161aa3a07c99789d0e5e6cabbb0 Mon Sep 17 00:00:00 2001 From: Pankaj Bansal Date: Mon, 30 Oct 2017 15:45:55 +0530 Subject: [PATCH 15/39] 8159062: [hidpi] DnD on Windows while scaling is non-integer Reviewed-by: serb, pkbalakr --- .../windows/awt_Win32GraphicsDevice.cpp | 11 +- .../libawt/windows/awt_Win32GraphicsDevice.h | 2 +- .../DnDTestWithHIDPI/DragTestWithHIDPI.java | 209 ++++++++++++++++++ 3 files changed, 216 insertions(+), 6 deletions(-) create mode 100644 test/jdk/java/awt/dnd/DnDTestWithHIDPI/DragTestWithHIDPI.java diff --git a/src/java.desktop/windows/native/libawt/windows/awt_Win32GraphicsDevice.cpp b/src/java.desktop/windows/native/libawt/windows/awt_Win32GraphicsDevice.cpp index 186c7f99a92..dcc5ee99335 100644 --- a/src/java.desktop/windows/native/libawt/windows/awt_Win32GraphicsDevice.cpp +++ b/src/java.desktop/windows/native/libawt/windows/awt_Win32GraphicsDevice.cpp @@ -632,26 +632,27 @@ void AwtWin32GraphicsDevice::SetScale(float sx, float sy) int AwtWin32GraphicsDevice::ScaleUpX(int x) { - return CheckIntLimits(x * scaleX); + return ClipRound(x * scaleX); } int AwtWin32GraphicsDevice::ScaleUpY(int y) { - return CheckIntLimits(y * scaleY); + return ClipRound(y * scaleY); } int AwtWin32GraphicsDevice::ScaleDownX(int x) { - return CheckIntLimits(x / scaleX); + return ClipRound(x / scaleX); } int AwtWin32GraphicsDevice::ScaleDownY(int y) { - return CheckIntLimits(y / scaleY); + return ClipRound(y / scaleY); } -int AwtWin32GraphicsDevice::CheckIntLimits(double value) +int AwtWin32GraphicsDevice::ClipRound(double value) { + value -= 0.5; if (value < INT_MIN) { return INT_MIN; diff --git a/src/java.desktop/windows/native/libawt/windows/awt_Win32GraphicsDevice.h b/src/java.desktop/windows/native/libawt/windows/awt_Win32GraphicsDevice.h index 699d3b415ec..d5fc0d57150 100644 --- a/src/java.desktop/windows/native/libawt/windows/awt_Win32GraphicsDevice.h +++ b/src/java.desktop/windows/native/libawt/windows/awt_Win32GraphicsDevice.h @@ -119,7 +119,7 @@ private: float scaleY; static HDC MakeDCFromMonitor(HMONITOR); - static int CheckIntLimits(double value); + static int ClipRound(double value); }; #endif AWT_WIN32GRAPHICSDEVICE_H diff --git a/test/jdk/java/awt/dnd/DnDTestWithHIDPI/DragTestWithHIDPI.java b/test/jdk/java/awt/dnd/DnDTestWithHIDPI/DragTestWithHIDPI.java new file mode 100644 index 00000000000..2f315c17e03 --- /dev/null +++ b/test/jdk/java/awt/dnd/DnDTestWithHIDPI/DragTestWithHIDPI.java @@ -0,0 +1,209 @@ +/* + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * 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 + * @key headful + * @bug 8159062 + * @summary Tests DnD property with HIDPI scale set to non-interger value 2.5 + * @run main/othervm -Dsun.java2d.uiScale=2.5 DragTestWithHIDPI + */ + +import javax.swing.JList; +import javax.swing.TransferHandler; +import javax.swing.JFrame; +import javax.swing.JComponent; +import javax.swing.SwingUtilities; + +import java.awt.Robot; +import java.awt.BorderLayout; +import java.awt.Point; +import java.awt.Dimension; +import java.awt.MouseInfo; +import java.awt.event.InputEvent; + +public class DragTestWithHIDPI extends TransferHandler { + + private static boolean didDrag = false; + private static int threshold = 10; + private static int DEFAULT_DELAY = 550; + + private Robot robot = null; + private static JList list = null; + private static Point listLocation = null; + private static Dimension listSize = null; + private static JFrame f = null; + + private enum Direction { + RIGHT, LEFT, BOTTOM, TOP + } + + public static void main(String[] args) throws Exception { + DragTestWithHIDPI test = new DragTestWithHIDPI(); + + // set the mouse move drag threshold + System.setProperty("awt.dnd.drag.threshold", String.valueOf(threshold)); + + test.createGUI(); + test.doTest(); + System.out.println("Test Passed"); + test.disposeGUI(); + } + + public void exportAsDrag(JComponent comp, InputEvent e, int action) { + didDrag = true; + } + + public DragTestWithHIDPI() { + super("foreground"); + } + + private void createGUI() throws Exception{ + SwingUtilities.invokeAndWait(() -> { + String[] listData = + new String[]{"Pacific Ocean", "Atlantic Ocean", "Indian Ocean", + "Arctic Ocean"}; + list = new JList(listData); + list.setDragEnabled(true); + list.setTransferHandler(new DragTestWithHIDPI()); + + f = new JFrame("DragTestWithHIDPI"); + f.getContentPane().add(list, BorderLayout.CENTER); + f.pack(); + f.toFront(); + f.setVisible(true); + + listLocation = list.getLocationOnScreen(); + listSize = list.getSize(); + }); + } + + private void disposeGUI () throws Exception { + SwingUtilities.invokeAndWait(() -> { + f.dispose(); + }); + } + + private void doTest() throws Exception { + + robot = new Robot(); + robot.waitForIdle(); + + for (Direction direction : Direction.values()) { + //Drag should not start only by moving (threshold - 1) pixels + didDrag = false; + test(threshold - 1, direction); + if (didDrag) { + disposeGUI(); + throw new RuntimeException( + "Shouldn't start drag until > " + threshold + + " pixels " + " while moving " + direction); + } + + // Drag should not start only by moving threshold pixels + didDrag = false; + test(threshold, direction); + if (didDrag) { + disposeGUI(); + throw new RuntimeException( + "Shouldn't start drag until > " + threshold + + " pixels" + " while moving " + direction); + } + + // Drag should start after moving threshold + 1 pixel + didDrag = false; + test(threshold + 1, direction); + if (!didDrag) { + disposeGUI(); + throw new RuntimeException( + "Should start drag after > " + threshold + " pixels" + + " while moving " + direction); + } + } + } + + private void test(int threshold, Direction direction) { + clickMouseOnList(InputEvent.BUTTON1_DOWN_MASK); + Point p = MouseInfo.getPointerInfo().getLocation(); + robot.mousePress(InputEvent.BUTTON1_DOWN_MASK); + robot.delay(DEFAULT_DELAY); + glide(p, direction, threshold); + robot.mouseRelease(InputEvent.BUTTON1_DOWN_MASK); + } + + private void glide(Point p, Direction direction, int toAdd) { + switch (direction) { + case RIGHT: + // move towards right + glide(p.x, p.y, p.x + toAdd, p.y); + break; + case LEFT: + // move towards left + glide(p.x, p.y, p.x - toAdd, p.y); + break; + case BOTTOM: + // move towards bottom + glide(p.x, p.y, p.x, p.y + toAdd); + break; + case TOP: + // move towards top + glide(p.x, p.y, p.x, p.y - toAdd); + break; + + } + } + + /* + Some utilities functions from JRobot class. + */ + private void moveMouseToList() { + int x = listLocation.x + listSize.width/2; + int y = listLocation.y + listSize.height/2; + robot.mouseMove(x, y); + robot.delay(DEFAULT_DELAY); + } + + private void clickMouse(int buttons) { + robot.mousePress(buttons); + robot.mouseRelease(buttons); + robot.delay(DEFAULT_DELAY); + } + + private void clickMouseOnList(int buttons) { + moveMouseToList(); + clickMouse(buttons); + } + + private void glide(int x0, int y0, int x1, int y1) { + float dmax = (float)Math.max(Math.abs(x1 - x0), Math.abs(y1 - y0)); + float dx = (x1 - x0) / dmax; + float dy = (y1 - y0) / dmax; + + robot.mouseMove(x0, y0); + for (int i=1; i<=dmax; i++) { + robot.mouseMove((int)(x0 + dx*i), (int)(y0 + dy*i)); + } + robot.delay(DEFAULT_DELAY); + } +} + From 8ecf308d8ffcca73b79eac33ac86ec7f6313af87 Mon Sep 17 00:00:00 2001 From: Mario Torre Date: Mon, 30 Oct 2017 13:15:08 +0100 Subject: [PATCH 16/39] 8188030: AWT java apps fail to start when some minimal fonts are present Allow using CFF fonts as valid fonts when they are returned by fontconfig during font initialisation. Reviewed-by: prr, serb --- src/java.desktop/unix/native/common/awt/fontpath.c | 1 + 1 file changed, 1 insertion(+) diff --git a/src/java.desktop/unix/native/common/awt/fontpath.c b/src/java.desktop/unix/native/common/awt/fontpath.c index 6d264a36ab5..9ae443e26a0 100644 --- a/src/java.desktop/unix/native/common/awt/fontpath.c +++ b/src/java.desktop/unix/native/common/awt/fontpath.c @@ -1254,6 +1254,7 @@ Java_sun_font_FontConfigManager_getFontConfig && (strcmp((char*)fontformat, "TrueType") != 0) #if defined(__linux__) || defined(_AIX) && (strcmp((char*)fontformat, "Type 1") != 0) + && (strcmp((char*)fontformat, "CFF") != 0) #endif ) { continue; From 56eea6422542104832a3224d2398e7e97e85840c Mon Sep 17 00:00:00 2001 From: Kumar Srinivasan Date: Mon, 30 Oct 2017 07:06:49 -0700 Subject: [PATCH 17/39] 8129077: Unfix JDK-8087205 Reviewed-by: jlahoda, mcimadamore, vromero --- .../share/classes/javax/lang/model/SourceVersion.java | 1 - 1 file changed, 1 deletion(-) diff --git a/src/java.compiler/share/classes/javax/lang/model/SourceVersion.java b/src/java.compiler/share/classes/javax/lang/model/SourceVersion.java index a15950e9caa..2e962a2f4ab 100644 --- a/src/java.compiler/share/classes/javax/lang/model/SourceVersion.java +++ b/src/java.compiler/share/classes/javax/lang/model/SourceVersion.java @@ -183,7 +183,6 @@ public enum SourceVersion { case "10": return RELEASE_10; case "9": - case "1.9": return RELEASE_9; case "1.8": return RELEASE_8; From f32470d85f01afd74479a130504f7fe8b2638191 Mon Sep 17 00:00:00 2001 From: Brent Christian Date: Mon, 30 Oct 2017 16:16:01 -0700 Subject: [PATCH 18/39] 8189319: Add a java.util.Properties constructor that takes an initial capacity Reviewed-by: martin, mchung, rriggs --- .../share/classes/java/lang/System.java | 2 +- .../share/classes/java/util/Properties.java | 34 ++++++++++++++-- .../java/util/Properties/InitialCapacity.java | 40 +++++++++++++++++++ 3 files changed, 72 insertions(+), 4 deletions(-) create mode 100644 test/jdk/java/util/Properties/InitialCapacity.java diff --git a/src/java.base/share/classes/java/lang/System.java b/src/java.base/share/classes/java/lang/System.java index 8388dce7562..86ec3c5cad3 100644 --- a/src/java.base/share/classes/java/lang/System.java +++ b/src/java.base/share/classes/java/lang/System.java @@ -1937,7 +1937,7 @@ public final class System { // initialization. So make sure the "props" is available at the // very beginning of the initialization and all system properties to // be put into it directly. - props = new Properties(); + props = new Properties(84); initProperties(props); // initialized by the VM // There are certain system configurations that may be controlled by diff --git a/src/java.base/share/classes/java/util/Properties.java b/src/java.base/share/classes/java/util/Properties.java index fd7ee9ce6b3..1ae9a49a028 100644 --- a/src/java.base/share/classes/java/util/Properties.java +++ b/src/java.base/share/classes/java/util/Properties.java @@ -122,6 +122,10 @@ import jdk.internal.util.xml.PropertiesDefaultHandler; *

This class is thread-safe: multiple threads can share a single * {@code Properties} object without the need for external synchronization. * + * @apiNote + * The {@code Properties} class does not inherit the concept of a load factor + * from its superclass, {@code Hashtable}. + * * @author Arthur van Hoff * @author Michael McCloskey * @author Xueming Shen @@ -148,25 +152,49 @@ class Properties extends Hashtable { * simple read operations. Writes and bulk operations remain synchronized, * as in Hashtable. */ - private transient ConcurrentHashMap map = - new ConcurrentHashMap<>(8); + private transient ConcurrentHashMap map; /** * Creates an empty property list with no default values. + * + * @implNote The initial capacity of a {@code Properties} object created + * with this constructor is unspecified. */ public Properties() { - this(null); + this(null, 8); + } + + /** + * Creates an empty property list with no default values, and with an + * initial size accommodating the specified number of elements without the + * need to dynamically resize. + * + * @param initialCapacity the {@code Properties} will be sized to + * accommodate this many elements + * @throws IllegalArgumentException if the initial capacity is less than + * zero. + */ + public Properties(int initialCapacity) { + this(null, initialCapacity); } /** * Creates an empty property list with the specified defaults. * + * @implNote The initial capacity of a {@code Properties} object created + * with this constructor is unspecified. + * * @param defaults the defaults. */ public Properties(Properties defaults) { + this(defaults, 8); + } + + private Properties(Properties defaults, int initialCapacity) { // use package-private constructor to // initialize unused fields with dummy values super((Void) null); + map = new ConcurrentHashMap<>(initialCapacity); this.defaults = defaults; } diff --git a/test/jdk/java/util/Properties/InitialCapacity.java b/test/jdk/java/util/Properties/InitialCapacity.java new file mode 100644 index 00000000000..81e5421bbef --- /dev/null +++ b/test/jdk/java/util/Properties/InitialCapacity.java @@ -0,0 +1,40 @@ +/* + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * 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.Properties; +import org.testng.annotations.Test; + +/* + * @test + * @bug 8189319 + * @summary Test that Properties(int initialCapacity) throws exceptions (or + doesn't) as expected + * @run testng InitialCapacity + */ +public class InitialCapacity { + @Test(expectedExceptions = IllegalArgumentException.class) + public void negativeInitCap() { Properties p = new Properties(-1); } + + @Test + public void positiveInitCap() { Properties p = new Properties(10); } +} From b366f4f3493418565cc9ffab2014b212a6d5fde5 Mon Sep 17 00:00:00 2001 From: Joe Wang Date: Mon, 30 Oct 2017 17:32:38 -0700 Subject: [PATCH 19/39] 8181155: Fix lint warnings in JAXP repo: fallthrough and static Reviewed-by: lancea, rriggs --- .../org/apache/bcel/internal/classfile/Utility.java | 5 +++-- .../org/apache/bcel/internal/util/BCELFactory.java | 5 +++-- .../xalan/internal/xsltc/compiler/Message.java | 5 +++-- .../apache/xalan/internal/xsltc/compiler/Step.java | 1 + .../xalan/internal/xsltc/compiler/Whitespace.java | 1 + .../xalan/internal/xsltc/compiler/XPathLexer.java | 3 +++ .../xalan/internal/xsltc/compiler/XPathParser.java | 12 ++++++------ .../org/apache/xalan/internal/xsltc/dom/SAXImpl.java | 3 +++ .../runtime/output/TransletOutputHandlerFactory.java | 5 +++-- .../internal/dom/DeferredDocumentTypeImpl.java | 6 +++--- .../impl/xs/traversers/XSDElementTraverser.java | 6 +++--- .../internal/impl/xs/traversers/XSDHandler.java | 1 + .../xerces/internal/parsers/AbstractDOMParser.java | 4 ++++ .../apache/xml/internal/dtm/ref/DTMDocumentImpl.java | 5 +++-- .../apache/xml/internal/dtm/ref/dom2dtm/DOM2DTM.java | 1 + .../xml/internal/serialize/BaseMarkupSerializer.java | 1 + .../apache/xpath/internal/axes/FilterExprWalker.java | 1 + .../xpath/internal/axes/MatchPatternIterator.java | 6 +++--- .../apache/xpath/internal/axes/WalkerFactory.java | 8 +++++--- .../org/apache/xpath/internal/compiler/Lexer.java | 1 + .../internal/patterns/ContextMatchStepPattern.java | 6 +++--- .../apache/xpath/internal/patterns/StepPattern.java | 2 +- .../classes/org/xml/sax/helpers/ParserAdapter.java | 2 +- 23 files changed, 57 insertions(+), 33 deletions(-) diff --git a/src/java.xml/share/classes/com/sun/org/apache/bcel/internal/classfile/Utility.java b/src/java.xml/share/classes/com/sun/org/apache/bcel/internal/classfile/Utility.java index fffa6cae984..7da4bc88510 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/bcel/internal/classfile/Utility.java +++ b/src/java.xml/share/classes/com/sun/org/apache/bcel/internal/classfile/Utility.java @@ -1,6 +1,6 @@ /* - * reserved comment block - * DO NOT REMOVE OR ALTER! + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * @LastModified: Oct 2017 */ /* * Licensed to the Apache Software Foundation (ASF) under one or more @@ -181,6 +181,7 @@ public abstract class Utility { * @throws IOException if a failure from reading from the bytes argument * occurs */ + @SuppressWarnings("fallthrough") // by design for case Const.INSTANCEOF public static String codeToString(final ByteSequence bytes, final ConstantPool constant_pool, final boolean verbose) throws IOException { final short opcode = (short) bytes.readUnsignedByte(); diff --git a/src/java.xml/share/classes/com/sun/org/apache/bcel/internal/util/BCELFactory.java b/src/java.xml/share/classes/com/sun/org/apache/bcel/internal/util/BCELFactory.java index 929d2832a34..7149cd29503 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/bcel/internal/util/BCELFactory.java +++ b/src/java.xml/share/classes/com/sun/org/apache/bcel/internal/util/BCELFactory.java @@ -1,6 +1,6 @@ /* - * reserved comment block - * DO NOT REMOVE OR ALTER! + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * @LastModified: Oct 2017 */ /* * Licensed to the Apache Software Foundation (ASF) under one or more @@ -175,6 +175,7 @@ class BCELFactory extends EmptyVisitor { @Override + @SuppressWarnings("fallthrough") // by design for case Const.ANEWARRAY public void visitAllocationInstruction( final AllocationInstruction i ) { Type type; if (i instanceof CPInstruction) { diff --git a/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/Message.java b/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/Message.java index cda255f0fca..71dc212dc40 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/Message.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/Message.java @@ -1,6 +1,6 @@ /* - * reserved comment block - * DO NOT REMOVE OR ALTER! + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * @LastModified: Oct 2017 */ /* * Licensed to the Apache Software Foundation (ASF) under one or more @@ -54,6 +54,7 @@ final class Message extends Instruction { return Type.Void; } + @SuppressWarnings("fallthrough") // at default public void translate(ClassGenerator classGen, MethodGenerator methodGen) { final ConstantPoolGen cpg = classGen.getConstantPool(); final InstructionList il = methodGen.getInstructionList(); diff --git a/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/Step.java b/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/Step.java index 7ce3fa72eb0..35819b4fc97 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/Step.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/Step.java @@ -232,6 +232,7 @@ final class Step extends RelativeLocationPath { translateStep(classGen, methodGen, hasPredicates() ? _predicates.size() - 1 : -1); } + @SuppressWarnings("fallthrough") // at case NodeTest.ANODE and NodeTest.ELEMENT private void translateStep(ClassGenerator classGen, MethodGenerator methodGen, int predicateIndex) { diff --git a/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/Whitespace.java b/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/Whitespace.java index d6cd37c0e61..f33d8fd343d 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/Whitespace.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/Whitespace.java @@ -191,6 +191,7 @@ final class Whitespace extends TopLevelElement { * Scans through the rules vector and looks for a rule of higher * priority that contradicts the current rule. */ + @SuppressWarnings("fallthrough") // case RULE_NAMESPACE private static WhitespaceRule findContradictingRule(List rules, WhitespaceRule rule) { for (WhitespaceRule currentRule : rules) { diff --git a/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/XPathLexer.java b/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/XPathLexer.java index 623b3f81417..6cb022649af 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/XPathLexer.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/XPathLexer.java @@ -1,5 +1,6 @@ /* * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * @LastModified: Oct 2017 */ /* * Licensed to the Apache Software Foundation (ASF) under one or more @@ -73,6 +74,7 @@ class XPathLexer implements com.sun.java_cup.internal.runtime.Scanner { * name instead of a keyword (Jira-1912). Look two tokens behind * to desambiguate expressions like "* and *" or "and * and". */ + @SuppressWarnings("fallthrough") Symbol disambiguateOperator(int ss) throws Exception { switch (last) { case sym.STAR: @@ -745,6 +747,7 @@ class XPathLexer implements com.sun.java_cup.internal.runtime.Scanner { ":13,-1:2,184:10,-1:3,76,184,76:3,-1:4,184:6,64,-1:2,76,-1:6,184:5,-1:3,184:" + "4,232,184:8,-1:2,184:10,-1:3,76,184,76:3"); + @SuppressWarnings("fallthrough") // at case 18 and -1 public com.sun.java_cup.internal.runtime.Symbol next_token () throws java.io.IOException, Exception diff --git a/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/XPathParser.java b/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/XPathParser.java index c1554f3c0af..0e5c7aa44ca 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/XPathParser.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/compiler/XPathParser.java @@ -1591,13 +1591,13 @@ class parser_actions { RESULT = new CurrentCall(fname); } else if (fname == parser.getQNameIgnoreDefaultNs("number")) { - RESULT = new NumberCall(fname, parser.EmptyArgs); + RESULT = new NumberCall(fname, XPathParser.EmptyArgs); } else if (fname == parser.getQNameIgnoreDefaultNs("string")) { - RESULT = new StringCall(fname, parser.EmptyArgs); + RESULT = new StringCall(fname, XPathParser.EmptyArgs); } else if (fname == parser.getQNameIgnoreDefaultNs("concat")) { - RESULT = new ConcatCall(fname, parser.EmptyArgs); + RESULT = new ConcatCall(fname, XPathParser.EmptyArgs); } else if (fname == parser.getQNameIgnoreDefaultNs("true")) { RESULT = new BooleanExpr(true); @@ -1609,10 +1609,10 @@ class parser_actions { RESULT = new NameCall(fname); } else if (fname == parser.getQNameIgnoreDefaultNs("generate-id")) { - RESULT = new GenerateIdCall(fname, parser.EmptyArgs); + RESULT = new GenerateIdCall(fname, XPathParser.EmptyArgs); } else if (fname == parser.getQNameIgnoreDefaultNs("string-length")) { - RESULT = new StringLengthCall(fname, parser.EmptyArgs); + RESULT = new StringLengthCall(fname, XPathParser.EmptyArgs); } else if (fname == parser.getQNameIgnoreDefaultNs("position")) { RESULT = new PositionCall(fname); @@ -1627,7 +1627,7 @@ class parser_actions { RESULT = new NamespaceUriCall(fname); } else { - RESULT = new FunctionCall(fname, parser.EmptyArgs); + RESULT = new FunctionCall(fname, XPathParser.EmptyArgs); } parser_result = new Symbol(16/*FunctionCall*/, (parser_stack.get(parser_top-2)).left, (parser_stack.get(parser_top-0)).right, RESULT); diff --git a/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/dom/SAXImpl.java b/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/dom/SAXImpl.java index a78e1f8458b..623bfe389af 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/dom/SAXImpl.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/dom/SAXImpl.java @@ -1,5 +1,6 @@ /* * Copyright (c) 2015, 2017, Oracle and/or its affiliates. All rights reserved. + * @LastModified: Oct 2017 */ /* * Licensed to the Apache Software Foundation (ASF) under one or more @@ -1278,11 +1279,13 @@ public final class SAXImpl extends SAX2DTM2 // For "attribute::p:*", the principal node kind is // attribute m_baseIterator = getAxisIterator(axis); + break; } case Axis.NAMESPACE: { // This covers "namespace::p:*". It is syntactically // correct, though it doesn't make much sense. m_baseIterator = getAxisIterator(axis); + break; } default: { // In all other cases, the principal node kind is diff --git a/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/runtime/output/TransletOutputHandlerFactory.java b/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/runtime/output/TransletOutputHandlerFactory.java index 6ebdc780edb..985d6080578 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/runtime/output/TransletOutputHandlerFactory.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xalan/internal/xsltc/runtime/output/TransletOutputHandlerFactory.java @@ -1,6 +1,6 @@ /* - * reserved comment block - * DO NOT REMOVE OR ALTER! + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * @LastModified: Oct 2017 */ /* * Licensed to the Apache Software Foundation (ASF) under one or more @@ -145,6 +145,7 @@ public class TransletOutputHandlerFactory { _indentNumber = value; } + @SuppressWarnings("fallthrough") // intentional at case STAX, SAX public SerializationHandler getSerializationHandler() throws IOException, ParserConfigurationException { diff --git a/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/dom/DeferredDocumentTypeImpl.java b/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/dom/DeferredDocumentTypeImpl.java index abdc94054a3..be164613472 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/dom/DeferredDocumentTypeImpl.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/dom/DeferredDocumentTypeImpl.java @@ -1,6 +1,6 @@ /* - * reserved comment block - * DO NOT REMOVE OR ALTER! + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * @LastModified: Oct 2017 */ /* * Licensed to the Apache Software Foundation (ASF) under one or more @@ -161,8 +161,8 @@ public class DeferredDocumentTypeImpl if (((DocumentImpl)getOwnerDocument()).allowGrammarAccess){ insertBefore(node, last); last = node; - break; } + break; } // NOTE: Should never get here! -Ac diff --git a/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/impl/xs/traversers/XSDElementTraverser.java b/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/impl/xs/traversers/XSDElementTraverser.java index 9ee9159cbb9..136daad8dcf 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/impl/xs/traversers/XSDElementTraverser.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/impl/xs/traversers/XSDElementTraverser.java @@ -1,6 +1,6 @@ /* - * reserved comment block - * DO NOT REMOVE OR ALTER! + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * @LastModified: Oct 2017 */ /* * Licensed to the Apache Software Foundation (ASF) under one or more @@ -439,7 +439,7 @@ class XSDElementTraverser extends XSDAbstractTraverser { fSchemaHandler.checkForDuplicateNames( (schemaDoc.fTargetNamespace == null) ? ","+DOMUtil.getAttrValue(child, SchemaSymbols.ATT_NAME) : schemaDoc.fTargetNamespace+","+ DOMUtil.getAttrValue(child, SchemaSymbols.ATT_NAME), - fSchemaHandler.ATTRIBUTE_TYPE, fSchemaHandler.getIDRegistry(), fSchemaHandler.getIDRegistry_sub(), + XSDHandler.ATTRIBUTE_TYPE, fSchemaHandler.getIDRegistry(), fSchemaHandler.getIDRegistry_sub(), child, schemaDoc); } } else if (childName.equals(SchemaSymbols.ELT_KEYREF)) { diff --git a/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/impl/xs/traversers/XSDHandler.java b/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/impl/xs/traversers/XSDHandler.java index a3cbdc7055b..1b5c5074647 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/impl/xs/traversers/XSDHandler.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/impl/xs/traversers/XSDHandler.java @@ -3025,6 +3025,7 @@ public class XSDHandler { return newComponents; } + @SuppressWarnings("fallthrough") private void expandRelatedComponents(XSObject component,ListcomponentList, Map> dependencies) { short componentType = component.getType(); switch (componentType) { diff --git a/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/parsers/AbstractDOMParser.java b/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/parsers/AbstractDOMParser.java index 980faf76d71..3bad4eec47f 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/parsers/AbstractDOMParser.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/parsers/AbstractDOMParser.java @@ -600,6 +600,7 @@ public class AbstractDOMParser extends AbstractXMLDocumentParser { * * @throws XNIException Thrown by application to signal an error. */ + @SuppressWarnings("fallthrough") // by design at case LSParserFilter.FILTER_SKIP public void comment (XMLString text, Augmentations augs) throws XNIException { if (fInDTD) { if (fInternalSubset != null && !fInDTDExternalSubset) { @@ -673,6 +674,7 @@ public class AbstractDOMParser extends AbstractXMLDocumentParser { * * @throws XNIException Thrown by handler to signal an error. */ + @SuppressWarnings("fallthrough") // by design at case LSParserFilter.FILTER_REJECT public void processingInstruction (String target, XMLString data, Augmentations augs) throws XNIException { @@ -1416,6 +1418,7 @@ public class AbstractDOMParser extends AbstractXMLDocumentParser { * * @throws XNIException Thrown by handler to signal an error. */ + @SuppressWarnings("fallthrough") // by design at case LSParserFilter.FILTER_REJECT public void endCDATA (Augmentations augs) throws XNIException { fInCDATASection = false; @@ -2596,6 +2599,7 @@ public class AbstractDOMParser extends AbstractXMLDocumentParser { * or removed fFistChunk must be set to true, otherwise some data can be lost. * */ + @SuppressWarnings("fallthrough") // by design at case LSParserFilter.FILTER_REJECT protected void setCharacterData (boolean sawChars){ // handle character data diff --git a/src/java.xml/share/classes/com/sun/org/apache/xml/internal/dtm/ref/DTMDocumentImpl.java b/src/java.xml/share/classes/com/sun/org/apache/xml/internal/dtm/ref/DTMDocumentImpl.java index 999c3fc01b3..ea8fed859ef 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xml/internal/dtm/ref/DTMDocumentImpl.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xml/internal/dtm/ref/DTMDocumentImpl.java @@ -1,6 +1,6 @@ /* - * reserved comment block - * DO NOT REMOVE OR ALTER! + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * @LastModified: Oct 2017 */ /* * Licensed to the Apache Software Foundation (ASF) under one or more @@ -1697,6 +1697,7 @@ implements DTM, org.xml.sax.ContentHandler, org.xml.sax.ext.LexicalHandler * @return String Value of this node, or null if not * meaningful for this node type. */ + @SuppressWarnings("fallthrough") public String getNodeValue(int nodeHandle) { nodes.readSlot(nodeHandle, gotslot); diff --git a/src/java.xml/share/classes/com/sun/org/apache/xml/internal/dtm/ref/dom2dtm/DOM2DTM.java b/src/java.xml/share/classes/com/sun/org/apache/xml/internal/dtm/ref/dom2dtm/DOM2DTM.java index 1f11bba000c..af5155d9c1c 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xml/internal/dtm/ref/dom2dtm/DOM2DTM.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xml/internal/dtm/ref/dom2dtm/DOM2DTM.java @@ -1651,6 +1651,7 @@ public class DOM2DTM extends DTMDefaultBaseIterators * @param node Node whose subtree is to be walked, gathering the * contents of all Text or CDATASection nodes. */ + @SuppressWarnings("fallthrough") protected static void dispatchNodeData(Node node, org.xml.sax.ContentHandler ch, int depth) diff --git a/src/java.xml/share/classes/com/sun/org/apache/xml/internal/serialize/BaseMarkupSerializer.java b/src/java.xml/share/classes/com/sun/org/apache/xml/internal/serialize/BaseMarkupSerializer.java index ce088660144..8b65f445dcd 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xml/internal/serialize/BaseMarkupSerializer.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xml/internal/serialize/BaseMarkupSerializer.java @@ -1020,6 +1020,7 @@ public abstract class BaseMarkupSerializer * @throws IOException An I/O exception occured while * serializing */ + @SuppressWarnings("fallthrough") // by design at case Node.DOCUMENT_FRAGMENT_NODE protected void serializeNode( Node node ) throws IOException { diff --git a/src/java.xml/share/classes/com/sun/org/apache/xpath/internal/axes/FilterExprWalker.java b/src/java.xml/share/classes/com/sun/org/apache/xpath/internal/axes/FilterExprWalker.java index d4f1c42ef83..8c9eabcd20a 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xpath/internal/axes/FilterExprWalker.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xpath/internal/axes/FilterExprWalker.java @@ -62,6 +62,7 @@ public class FilterExprWalker extends AxesWalker * * @throws javax.xml.transform.TransformerException */ + @SuppressWarnings("fallthrough") public void init(Compiler compiler, int opPos, int stepType) throws javax.xml.transform.TransformerException { diff --git a/src/java.xml/share/classes/com/sun/org/apache/xpath/internal/axes/MatchPatternIterator.java b/src/java.xml/share/classes/com/sun/org/apache/xpath/internal/axes/MatchPatternIterator.java index 7a4a5934ee5..881893c66c8 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xpath/internal/axes/MatchPatternIterator.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xpath/internal/axes/MatchPatternIterator.java @@ -1,6 +1,6 @@ /* - * reserved comment block - * DO NOT REMOVE OR ALTER! + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * @LastModified: Oct 2017 */ /* * Licensed to the Apache Software Foundation (ASF) under one or more @@ -299,7 +299,7 @@ public class MatchPatternIterator extends LocPathIterator System.out.println(", "+m_cdtm.getNodeName(n)); // if(m_cdtm.getNodeName(n).equals("near-east")) System.out.println("pattern: "+m_pattern.toString()); - m_pattern.debugWhatToShow(m_pattern.getWhatToShow()); + NodeTest.debugWhatToShow(m_pattern.getWhatToShow()); } XObject score = m_pattern.execute(xctxt); diff --git a/src/java.xml/share/classes/com/sun/org/apache/xpath/internal/axes/WalkerFactory.java b/src/java.xml/share/classes/com/sun/org/apache/xpath/internal/axes/WalkerFactory.java index 2f20645a847..e02c19efff5 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xpath/internal/axes/WalkerFactory.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xpath/internal/axes/WalkerFactory.java @@ -1,6 +1,6 @@ /* - * reserved comment block - * DO NOT REMOVE OR ALTER! + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * @LastModified: Oct 2017 */ /* * Licensed to the Apache Software Foundation (ASF) under one or more @@ -554,6 +554,7 @@ public class WalkerFactory * * @throws javax.xml.transform.TransformerException */ + @SuppressWarnings("fallthrough") // by design at case OpCodes.FROM_DESCENDANTS private static boolean isOptimizableForDescendantIterator( Compiler compiler, int stepOpCodePos, int stepIndex) throws javax.xml.transform.TransformerException @@ -1102,7 +1103,7 @@ public class WalkerFactory System.out.print(", predAxis: " + Axis.getNames(ai.getAxis())); System.out.print(", what: "); System.out.print(" "); - ai.debugWhatToShow(ai.getWhatToShow()); + NodeTest.debugWhatToShow(ai.getWhatToShow()); } int argLen = compiler.getFirstPredicateOpPos(opPos); @@ -1621,6 +1622,7 @@ public class WalkerFactory * * @throws javax.xml.transform.TransformerException */ + @SuppressWarnings("fallthrough") // by design at case OpCodes.FROM_ROOT private static boolean isNaturalDocOrder( Compiler compiler, int stepOpCodePos, int stepIndex, int analysis) throws javax.xml.transform.TransformerException diff --git a/src/java.xml/share/classes/com/sun/org/apache/xpath/internal/compiler/Lexer.java b/src/java.xml/share/classes/com/sun/org/apache/xpath/internal/compiler/Lexer.java index ec790fca565..449c453cf11 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xpath/internal/compiler/Lexer.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xpath/internal/compiler/Lexer.java @@ -106,6 +106,7 @@ class Lexer * * @throws javax.xml.transform.TransformerException */ + @SuppressWarnings("fallthrough") // on purpose at case '-', '(' and default void tokenize(String pat, List targetStrings) throws javax.xml.transform.TransformerException { diff --git a/src/java.xml/share/classes/com/sun/org/apache/xpath/internal/patterns/ContextMatchStepPattern.java b/src/java.xml/share/classes/com/sun/org/apache/xpath/internal/patterns/ContextMatchStepPattern.java index 19976d1c3a5..7a4ceb41778 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xpath/internal/patterns/ContextMatchStepPattern.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xpath/internal/patterns/ContextMatchStepPattern.java @@ -1,6 +1,6 @@ /* - * reserved comment block - * DO NOT REMOVE OR ALTER! + * Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved. + * @LastModified: Oct 2017 */ /* * Licensed to the Apache Software Foundation (ASF) under one or more @@ -65,7 +65,7 @@ public class ContextMatchStepPattern extends StepPattern if (xctxt.getIteratorRoot() == xctxt.getCurrentNode()) return getStaticScore(); else - return this.SCORE_NONE; + return NodeTest.SCORE_NONE; } /** diff --git a/src/java.xml/share/classes/com/sun/org/apache/xpath/internal/patterns/StepPattern.java b/src/java.xml/share/classes/com/sun/org/apache/xpath/internal/patterns/StepPattern.java index 4c7293d32d3..7f6bd66f86c 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xpath/internal/patterns/StepPattern.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xpath/internal/patterns/StepPattern.java @@ -116,7 +116,7 @@ public class StepPattern extends NodeTest implements SubContextList, ExpressionO m_targetString = PsuedoNames.PSEUDONAME_ROOT; break; case DTMFilter.SHOW_ELEMENT : - if (this.WILD == m_name) + if (WILD.equals(m_name)) m_targetString = PsuedoNames.PSEUDONAME_ANY; else m_targetString = m_name; diff --git a/src/java.xml/share/classes/org/xml/sax/helpers/ParserAdapter.java b/src/java.xml/share/classes/org/xml/sax/helpers/ParserAdapter.java index ad38d4fe830..45f3c181ff9 100644 --- a/src/java.xml/share/classes/org/xml/sax/helpers/ParserAdapter.java +++ b/src/java.xml/share/classes/org/xml/sax/helpers/ParserAdapter.java @@ -586,7 +586,7 @@ public class ParserAdapter implements XMLReader, DocumentHandler // note funky case: localname can be null // when declaring the default prefix, and // yet the uri isn't null. - atts.addAttribute (nsSupport.XMLNS, prefix, + atts.addAttribute (NamespaceSupport.XMLNS, prefix, attQName.intern(), type, value); else atts.addAttribute ("", "", From 7f79fffba682596d58007d45a9b6b9b0db0e2b01 Mon Sep 17 00:00:00 2001 From: Christoph Dreis Date: Mon, 30 Oct 2017 17:49:33 -0700 Subject: [PATCH 20/39] 8190382: fix small typographic errors in comments Reviewed-by: martin --- .../share/classes/java/io/FilePermission.java | 4 ++-- .../share/classes/java/lang/invoke/MethodHandle.java | 2 +- .../classes/java/lang/invoke/StringConcatFactory.java | 2 +- .../share/classes/java/lang/invoke/VarHandle.java | 4 ++-- .../share/classes/java/net/DatagramSocket.java | 2 +- src/java.base/share/classes/java/net/Inet4Address.java | 2 +- src/java.base/share/classes/java/net/SocketImpl.java | 2 +- .../share/classes/java/net/SocksSocketImpl.java | 2 +- .../share/classes/java/net/URLConnection.java | 2 +- .../java/nio/channels/AsynchronousFileChannel.java | 2 +- .../share/classes/java/nio/channels/FileChannel.java | 2 +- src/java.base/share/classes/java/nio/file/Files.java | 2 +- .../share/classes/java/security/KeyPairGenerator.java | 2 +- .../java/time/format/DateTimeFormatterBuilder.java | 2 +- .../share/classes/java/time/temporal/WeekFields.java | 2 +- src/java.base/share/classes/java/util/Base64.java | 2 +- src/java.base/share/classes/java/util/EventObject.java | 10 +++++----- .../share/classes/java/util/FormattableFlags.java | 2 +- .../share/classes/java/util/ResourceBundle.java | 2 +- .../classes/jdk/internal/logger/BootstrapLogger.java | 2 +- .../sun/net/www/protocol/http/HttpURLConnection.java | 2 +- .../reflectiveObjects/ParameterizedTypeImpl.java | 2 +- .../classes/sun/security/provider/AuthPolicyFile.java | 2 +- .../classes/sun/security/provider/PolicyFile.java | 2 +- .../sun/security/provider/SubjectCodeSource.java | 2 +- .../classes/sun/security/ssl/DTLSInputRecord.java | 2 +- .../share/classes/sun/security/x509/X509CertImpl.java | 2 +- .../share/classes/sun/util/logging/PlatformLogger.java | 2 +- 28 files changed, 34 insertions(+), 34 deletions(-) diff --git a/src/java.base/share/classes/java/io/FilePermission.java b/src/java.base/share/classes/java/io/FilePermission.java index 39cded53b27..0cdb660145f 100644 --- a/src/java.base/share/classes/java/io/FilePermission.java +++ b/src/java.base/share/classes/java/io/FilePermission.java @@ -698,7 +698,7 @@ public final class FilePermission extends Permission implements Serializable { if (p2.equals(EMPTY_PATH)) { return 0; } else if (p2.getName(0).equals(DOTDOT_PATH)) { - // "." contains p2 iif p2 has no "..". Since a + // "." contains p2 iff p2 has no "..". Since // a normalized path can only have 0 or more // ".." at the beginning. We only need to look // at the head. @@ -711,7 +711,7 @@ public final class FilePermission extends Permission implements Serializable { } else if (p2.equals(EMPTY_PATH)) { int c1 = p1.getNameCount(); if (!p1.getName(c1 - 1).equals(DOTDOT_PATH)) { - // "." is inside p1 iif p1 is 1 or more "..". + // "." is inside p1 iff p1 is 1 or more "..". // For the same reason above, we only need to // look at the tail. return -1; diff --git a/src/java.base/share/classes/java/lang/invoke/MethodHandle.java b/src/java.base/share/classes/java/lang/invoke/MethodHandle.java index 60092d33d73..8b9c0ec9cc2 100644 --- a/src/java.base/share/classes/java/lang/invoke/MethodHandle.java +++ b/src/java.base/share/classes/java/lang/invoke/MethodHandle.java @@ -765,7 +765,7 @@ public abstract class MethodHandle { * In every other case, all conversions are applied pairwise, * which means that each argument or return value is converted to * exactly one argument or return value (or no return value). - * The applied conversions are defined by consulting the + * The applied conversions are defined by consulting * the corresponding component types of the old and new * method handle types. *

diff --git a/src/java.base/share/classes/java/lang/invoke/StringConcatFactory.java b/src/java.base/share/classes/java/lang/invoke/StringConcatFactory.java index 4bc58803c90..72feb9f1ca0 100644 --- a/src/java.base/share/classes/java/lang/invoke/StringConcatFactory.java +++ b/src/java.base/share/classes/java/lang/invoke/StringConcatFactory.java @@ -194,7 +194,7 @@ public final class StringConcatFactory { static { // In case we need to double-back onto the StringConcatFactory during this // static initialization, make sure we have the reasonable defaults to complete - // the static initialization properly. After that, actual users would use the + // the static initialization properly. After that, actual users would use // the proper values we have read from the properties. STRATEGY = DEFAULT_STRATEGY; // CACHE_ENABLE = false; // implied diff --git a/src/java.base/share/classes/java/lang/invoke/VarHandle.java b/src/java.base/share/classes/java/lang/invoke/VarHandle.java index 9f24c2907a4..5194d6ee981 100644 --- a/src/java.base/share/classes/java/lang/invoke/VarHandle.java +++ b/src/java.base/share/classes/java/lang/invoke/VarHandle.java @@ -205,7 +205,7 @@ import static java.lang.invoke.MethodHandleStatics.newInternalError; * and {@code double} on 32-bit platforms. * *

Access modes will override any memory ordering effects specified at - * the declaration site of a variable. For example, a VarHandle accessing a + * the declaration site of a variable. For example, a VarHandle accessing * a field using the {@code get} access mode will access the field as * specified by its access mode even if that field is declared * {@code volatile}. When mixed access is performed extreme care should be @@ -423,7 +423,7 @@ import static java.lang.invoke.MethodHandleStatics.newInternalError; * {@link java.lang.invoke.MethodHandles#varHandleInvoker}. * *

Interoperation between VarHandles and Java generics

- * A VarHandle can be obtained for a variable, such as a a field, which is + * A VarHandle can be obtained for a variable, such as a field, which is * declared with Java generic types. As with the Core Reflection API, the * VarHandle's variable type will be constructed from the erasure of the * source-level type. When a VarHandle access mode method is invoked, the diff --git a/src/java.base/share/classes/java/net/DatagramSocket.java b/src/java.base/share/classes/java/net/DatagramSocket.java index 7a447cb0acd..43e42e38042 100644 --- a/src/java.base/share/classes/java/net/DatagramSocket.java +++ b/src/java.base/share/classes/java/net/DatagramSocket.java @@ -988,7 +988,7 @@ class DatagramSocket implements java.io.Closeable { /** * Sets the SO_RCVBUF option to the specified value for this - * {@code DatagramSocket}. The SO_RCVBUF option is used by the + * {@code DatagramSocket}. The SO_RCVBUF option is used by * the network implementation as a hint to size the underlying * network I/O buffers. The SO_RCVBUF setting may also be used * by the network implementation to determine the maximum size diff --git a/src/java.base/share/classes/java/net/Inet4Address.java b/src/java.base/share/classes/java/net/Inet4Address.java index 25c5ab41224..daf7d86bc05 100644 --- a/src/java.base/share/classes/java/net/Inet4Address.java +++ b/src/java.base/share/classes/java/net/Inet4Address.java @@ -143,7 +143,7 @@ class Inet4Address extends InetAddress { /** * Prior to 1.4 an InetAddress was created with a family * based on the platform AF_INET value (usually 2). - * For compatibility reasons we must therefore write the + * For compatibility reasons we must therefore write * the InetAddress with this family. */ inet.holder().family = 2; diff --git a/src/java.base/share/classes/java/net/SocketImpl.java b/src/java.base/share/classes/java/net/SocketImpl.java index 60fe083445a..1c2060c7f15 100644 --- a/src/java.base/share/classes/java/net/SocketImpl.java +++ b/src/java.base/share/classes/java/net/SocketImpl.java @@ -333,7 +333,7 @@ public abstract class SocketImpl implements SocketOptions { * latency, and low latency above short connection time, then it could * invoke this method with the values {@code (0, 1, 2)}. * - * By default, this method does nothing, unless it is overridden in a + * By default, this method does nothing, unless it is overridden in * a sub-class. * * @param connectionTime diff --git a/src/java.base/share/classes/java/net/SocksSocketImpl.java b/src/java.base/share/classes/java/net/SocksSocketImpl.java index f8ea9ce6c16..3fe64a9c849 100644 --- a/src/java.base/share/classes/java/net/SocksSocketImpl.java +++ b/src/java.base/share/classes/java/net/SocksSocketImpl.java @@ -657,7 +657,7 @@ class SocksSocketImpl extends PlainSocketImpl implements SocksConsts { /** * Sends the Bind request to the SOCKS proxy. In the SOCKS protocol, bind - * means "accept incoming connection from", so the SocketAddress is the + * means "accept incoming connection from", so the SocketAddress is * the one of the host we do accept connection from. * * @param saddr the Socket address of the remote host. diff --git a/src/java.base/share/classes/java/net/URLConnection.java b/src/java.base/share/classes/java/net/URLConnection.java index a5c30df3d4b..2b52e07e921 100644 --- a/src/java.base/share/classes/java/net/URLConnection.java +++ b/src/java.base/share/classes/java/net/URLConnection.java @@ -785,7 +785,7 @@ public abstract class URLConnection { * required to make the connection. By default, this method * returns {@code java.security.AllPermission}. Subclasses * should override this method and return the permission - * that best represents the permission required to make a + * that best represents the permission required to make * a connection to the URL. For example, a {@code URLConnection} * representing a {@code file:} URL would return a * {@code java.io.FilePermission} object. diff --git a/src/java.base/share/classes/java/nio/channels/AsynchronousFileChannel.java b/src/java.base/share/classes/java/nio/channels/AsynchronousFileChannel.java index 0c0d0e6d3b5..26d2313f5f8 100644 --- a/src/java.base/share/classes/java/nio/channels/AsynchronousFileChannel.java +++ b/src/java.base/share/classes/java/nio/channels/AsynchronousFileChannel.java @@ -165,7 +165,7 @@ public abstract class AsynchronousFileChannel * * {@link StandardOpenOption#DELETE_ON_CLOSE DELETE_ON_CLOSE} * When this option is present then the implementation makes a - * best effort attempt to delete the file when closed by the + * best effort attempt to delete the file when closed by * the {@link #close close} method. If the {@code close} method is not * invoked then a best effort attempt is made to delete the file * when the Java virtual machine terminates. diff --git a/src/java.base/share/classes/java/nio/channels/FileChannel.java b/src/java.base/share/classes/java/nio/channels/FileChannel.java index 9ee447dbaf6..4463e5a5d82 100644 --- a/src/java.base/share/classes/java/nio/channels/FileChannel.java +++ b/src/java.base/share/classes/java/nio/channels/FileChannel.java @@ -216,7 +216,7 @@ public abstract class FileChannel * * {@link StandardOpenOption#DELETE_ON_CLOSE DELETE_ON_CLOSE} * When this option is present then the implementation makes a - * best effort attempt to delete the file when closed by the + * best effort attempt to delete the file when closed by * the {@link #close close} method. If the {@code close} method is not * invoked then a best effort attempt is made to delete the file * when the Java virtual machine terminates. diff --git a/src/java.base/share/classes/java/nio/file/Files.java b/src/java.base/share/classes/java/nio/file/Files.java index f5dbba9c358..5c0e3712524 100644 --- a/src/java.base/share/classes/java/nio/file/Files.java +++ b/src/java.base/share/classes/java/nio/file/Files.java @@ -3301,7 +3301,7 @@ public final class Files { } /** - * Writes bytes to a file. The {@code options} parameter specifies how the + * Writes bytes to a file. The {@code options} parameter specifies how * the file is created or opened. If no options are present then this method * works as if the {@link StandardOpenOption#CREATE CREATE}, {@link * StandardOpenOption#TRUNCATE_EXISTING TRUNCATE_EXISTING}, and {@link diff --git a/src/java.base/share/classes/java/security/KeyPairGenerator.java b/src/java.base/share/classes/java/security/KeyPairGenerator.java index cd9a0a51263..eee081ae51e 100644 --- a/src/java.base/share/classes/java/security/KeyPairGenerator.java +++ b/src/java.base/share/classes/java/security/KeyPairGenerator.java @@ -84,7 +84,7 @@ import sun.security.util.Debug; * exists (e.g., so-called community parameters in DSA), there are two * {@link #initialize(java.security.spec.AlgorithmParameterSpec) * initialize} methods that have an {@code AlgorithmParameterSpec} - * argument. One also has a {@code SecureRandom} argument, while the + * argument. One also has a {@code SecureRandom} argument, while * 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 diff --git a/src/java.base/share/classes/java/time/format/DateTimeFormatterBuilder.java b/src/java.base/share/classes/java/time/format/DateTimeFormatterBuilder.java index f734fdd9d02..ebf044919a4 100644 --- a/src/java.base/share/classes/java/time/format/DateTimeFormatterBuilder.java +++ b/src/java.base/share/classes/java/time/format/DateTimeFormatterBuilder.java @@ -4775,7 +4775,7 @@ public final class DateTimeFormatterBuilder { //----------------------------------------------------------------------- /** * Prints or parses a localized pattern from a localized field. - * The specific formatter and parameters is not selected until the + * The specific formatter and parameters is not selected until * the field is to be printed or parsed. * The locale is needed to select the proper WeekFields from which * the field for day-of-week, week-of-month, or week-of-year is selected. diff --git a/src/java.base/share/classes/java/time/temporal/WeekFields.java b/src/java.base/share/classes/java/time/temporal/WeekFields.java index 60478772d9f..0046bef9b68 100644 --- a/src/java.base/share/classes/java/time/temporal/WeekFields.java +++ b/src/java.base/share/classes/java/time/temporal/WeekFields.java @@ -311,7 +311,7 @@ public final class WeekFields implements Serializable { * the new month or year. *

* WeekFields instances are singletons; for each unique combination - * of {@code firstDayOfWeek} and {@code minimalDaysInFirstWeek} the + * of {@code firstDayOfWeek} and {@code minimalDaysInFirstWeek} * the same instance will be returned. * * @param firstDayOfWeek the first day of the week, not null diff --git a/src/java.base/share/classes/java/util/Base64.java b/src/java.base/share/classes/java/util/Base64.java index 43e3d0690cd..0973a63844c 100644 --- a/src/java.base/share/classes/java/util/Base64.java +++ b/src/java.base/share/classes/java/util/Base64.java @@ -56,7 +56,7 @@ import java.nio.charset.StandardCharsets; * base64 alphabet.

* *
  • MIME - *

    Uses the "The Base64 Alphabet" as specified in Table 1 of + *

    Uses "The Base64 Alphabet" as specified in Table 1 of * RFC 2045 for encoding and decoding operation. The encoded output * must be represented in lines of no more than 76 characters each * and uses a carriage return {@code '\r'} followed immediately by diff --git a/src/java.base/share/classes/java/util/EventObject.java b/src/java.base/share/classes/java/util/EventObject.java index 99f58eb434e..ff89754a185 100644 --- a/src/java.base/share/classes/java/util/EventObject.java +++ b/src/java.base/share/classes/java/util/EventObject.java @@ -43,13 +43,13 @@ public class EventObject implements java.io.Serializable { /** * The object on which the Event initially occurred. */ - protected transient Object source; + protected transient Object source; /** * Constructs a prototypical Event. * - * @param source The object on which the Event initially occurred. - * @exception IllegalArgumentException if source is null. + * @param source the object on which the Event initially occurred + * @throws IllegalArgumentException if source is null */ public EventObject(Object source) { if (source == null) @@ -61,7 +61,7 @@ public class EventObject implements java.io.Serializable { /** * The object on which the Event initially occurred. * - * @return The object on which the Event initially occurred. + * @return the object on which the Event initially occurred */ public Object getSource() { return source; @@ -70,7 +70,7 @@ public class EventObject implements java.io.Serializable { /** * Returns a String representation of this EventObject. * - * @return A a String representation of this EventObject. + * @return a String representation of this EventObject */ public String toString() { return getClass().getName() + "[source=" + source + "]"; diff --git a/src/java.base/share/classes/java/util/FormattableFlags.java b/src/java.base/share/classes/java/util/FormattableFlags.java index 6c9962c3dba..92c020f9991 100644 --- a/src/java.base/share/classes/java/util/FormattableFlags.java +++ b/src/java.base/share/classes/java/util/FormattableFlags.java @@ -26,7 +26,7 @@ package java.util; /** - * FomattableFlags are passed to the {@link Formattable#formatTo + * FormattableFlags are passed to the {@link Formattable#formatTo * Formattable.formatTo()} method and modify the output format for {@linkplain * Formattable Formattables}. Implementations of {@link Formattable} are * responsible for interpreting and validating any flags. diff --git a/src/java.base/share/classes/java/util/ResourceBundle.java b/src/java.base/share/classes/java/util/ResourceBundle.java index 1e8141fe14b..b361ceefff4 100644 --- a/src/java.base/share/classes/java/util/ResourceBundle.java +++ b/src/java.base/share/classes/java/util/ResourceBundle.java @@ -2743,7 +2743,7 @@ public abstract class ResourceBundle { * of multiple subtags separated by underscore, generate candidate * Locales by omitting the variant subtags one by one, then * insert them after every occurrence of Locales with the - * full variant value in the original list. For example, if the + * full variant value in the original list. For example, if * the variant consists of two subtags V1 and V2: * *