This commit is contained in:
Lana Steuck 2011-07-27 22:42:19 -07:00
commit 6960817595
50 changed files with 1115 additions and 447 deletions

View File

@ -49,11 +49,11 @@ public class MotifFileChooserUI extends BasicFileChooserUI {
private FilterComboBoxModel filterComboBoxModel; private FilterComboBoxModel filterComboBoxModel;
protected JList directoryList = null; protected JList<File> directoryList = null;
protected JList fileList = null; protected JList<File> fileList = null;
protected JTextField pathField = null; protected JTextField pathField = null;
protected JComboBox filterComboBox = null; protected JComboBox<FileFilter> filterComboBox = null;
protected JTextField filenameTextField = null; protected JTextField filenameTextField = null;
private static final Dimension hstrut10 = new Dimension(10, 1); private static final Dimension hstrut10 = new Dimension(10, 1);
@ -337,7 +337,7 @@ public class MotifFileChooserUI extends BasicFileChooserUI {
align(l); align(l);
leftPanel.add(l); leftPanel.add(l);
filterComboBox = new JComboBox() { filterComboBox = new JComboBox<FileFilter>() {
public Dimension getMaximumSize() { public Dimension getMaximumSize() {
Dimension d = super.getMaximumSize(); Dimension d = super.getMaximumSize();
d.height = getPreferredSize().height; d.height = getPreferredSize().height;
@ -557,7 +557,7 @@ public class MotifFileChooserUI extends BasicFileChooserUI {
} }
protected JScrollPane createFilesList() { protected JScrollPane createFilesList() {
fileList = new JList(); fileList = new JList<File>();
if(getFileChooser().isMultiSelectionEnabled()) { if(getFileChooser().isMultiSelectionEnabled()) {
fileList.setSelectionMode(ListSelectionModel.MULTIPLE_INTERVAL_SELECTION); fileList.setSelectionMode(ListSelectionModel.MULTIPLE_INTERVAL_SELECTION);
@ -576,7 +576,7 @@ public class MotifFileChooserUI extends BasicFileChooserUI {
if (SwingUtilities.isLeftMouseButton(e) && !chooser.isMultiSelectionEnabled()) { if (SwingUtilities.isLeftMouseButton(e) && !chooser.isMultiSelectionEnabled()) {
int index = SwingUtilities2.loc2IndexFileList(fileList, e.getPoint()); int index = SwingUtilities2.loc2IndexFileList(fileList, e.getPoint());
if (index >= 0) { if (index >= 0) {
File file = (File) fileList.getModel().getElementAt(index); File file = fileList.getModel().getElementAt(index);
setFileName(chooser.getName(file)); setFileName(chooser.getName(file));
} }
} }
@ -593,7 +593,7 @@ public class MotifFileChooserUI extends BasicFileChooserUI {
} }
protected JScrollPane createDirectoryList() { protected JScrollPane createDirectoryList() {
directoryList = new JList(); directoryList = new JList<File>();
align(directoryList); align(directoryList);
directoryList.setCellRenderer(new DirectoryCellRenderer()); directoryList.setCellRenderer(new DirectoryCellRenderer());
@ -658,7 +658,7 @@ public class MotifFileChooserUI extends BasicFileChooserUI {
} }
} }
protected class MotifDirectoryListModel extends AbstractListModel implements ListDataListener { protected class MotifDirectoryListModel extends AbstractListModel<File> implements ListDataListener {
public MotifDirectoryListModel() { public MotifDirectoryListModel() {
getModel().addListDataListener(this); getModel().addListDataListener(this);
} }
@ -667,7 +667,7 @@ public class MotifFileChooserUI extends BasicFileChooserUI {
return getModel().getDirectories().size(); return getModel().getDirectories().size();
} }
public Object getElementAt(int index) { public File getElementAt(int index) {
return getModel().getDirectories().elementAt(index); return getModel().getDirectories().elementAt(index);
} }
@ -694,7 +694,7 @@ public class MotifFileChooserUI extends BasicFileChooserUI {
} }
protected class MotifFileListModel extends AbstractListModel implements ListDataListener { protected class MotifFileListModel extends AbstractListModel<File> implements ListDataListener {
public MotifFileListModel() { public MotifFileListModel() {
getModel().addListDataListener(this); getModel().addListDataListener(this);
} }
@ -711,7 +711,7 @@ public class MotifFileChooserUI extends BasicFileChooserUI {
return getModel().getFiles().indexOf(o); return getModel().getFiles().indexOf(o);
} }
public Object getElementAt(int index) { public File getElementAt(int index) {
return getModel().getFiles().elementAt(index); return getModel().getFiles().elementAt(index);
} }
@ -773,7 +773,8 @@ public class MotifFileChooserUI extends BasicFileChooserUI {
/** /**
* Data model for a type-face selection combo-box. * Data model for a type-face selection combo-box.
*/ */
protected class FilterComboBoxModel extends AbstractListModel implements ComboBoxModel, PropertyChangeListener { protected class FilterComboBoxModel extends AbstractListModel<FileFilter> implements ComboBoxModel<FileFilter>,
PropertyChangeListener {
protected FileFilter[] filters; protected FileFilter[] filters;
protected FilterComboBoxModel() { protected FilterComboBoxModel() {
super(); super();
@ -826,7 +827,7 @@ public class MotifFileChooserUI extends BasicFileChooserUI {
} }
} }
public Object getElementAt(int index) { public FileFilter getElementAt(int index) {
if(index > getSize() - 1) { if(index > getSize() - 1) {
// This shouldn't happen. Try to recover gracefully. // This shouldn't happen. Try to recover gracefully.
return getFileChooser().getFileFilter(); return getFileChooser().getFileFilter();

View File

@ -60,7 +60,7 @@ public class WindowsFileChooserUI extends BasicFileChooserUI {
private JPanel centerPanel; private JPanel centerPanel;
private JLabel lookInLabel; private JLabel lookInLabel;
private JComboBox directoryComboBox; private JComboBox<File> directoryComboBox;
private DirectoryComboBoxModel directoryComboBoxModel; private DirectoryComboBoxModel directoryComboBoxModel;
private ActionListener directoryComboBoxAction = new DirectoryComboBoxAction(); private ActionListener directoryComboBoxAction = new DirectoryComboBoxAction();
@ -76,7 +76,7 @@ public class WindowsFileChooserUI extends BasicFileChooserUI {
private JPanel buttonPanel; private JPanel buttonPanel;
private JPanel bottomPanel; private JPanel bottomPanel;
private JComboBox filterComboBox; private JComboBox<FileFilter> filterComboBox;
private static final Dimension hstrut10 = new Dimension(10, 1); private static final Dimension hstrut10 = new Dimension(10, 1);
@ -245,7 +245,7 @@ public class WindowsFileChooserUI extends BasicFileChooserUI {
topPanel.add(Box.createRigidArea(new Dimension(8,0))); topPanel.add(Box.createRigidArea(new Dimension(8,0)));
// CurrentDir ComboBox // CurrentDir ComboBox
directoryComboBox = new JComboBox() { directoryComboBox = new JComboBox<File>() {
public Dimension getMinimumSize() { public Dimension getMinimumSize() {
Dimension d = super.getMinimumSize(); Dimension d = super.getMinimumSize();
d.width = 60; d.width = 60;
@ -445,7 +445,7 @@ public class WindowsFileChooserUI extends BasicFileChooserUI {
filterComboBoxModel = createFilterComboBoxModel(); filterComboBoxModel = createFilterComboBoxModel();
fc.addPropertyChangeListener(filterComboBoxModel); fc.addPropertyChangeListener(filterComboBoxModel);
filterComboBox = new JComboBox(filterComboBoxModel); filterComboBox = new JComboBox<FileFilter>(filterComboBoxModel);
ftl.setLabelFor(filterComboBox); ftl.setLabelFor(filterComboBox);
filterComboBox.setRenderer(createFilterComboBoxRenderer()); filterComboBox.setRenderer(createFilterComboBoxRenderer());
fileAndFilterPanel.add(filterComboBox); fileAndFilterPanel.add(filterComboBox);
@ -1032,7 +1032,7 @@ public class WindowsFileChooserUI extends BasicFileChooserUI {
/** /**
* Data model for a type-face selection combo-box. * Data model for a type-face selection combo-box.
*/ */
protected class DirectoryComboBoxModel extends AbstractListModel implements ComboBoxModel { protected class DirectoryComboBoxModel extends AbstractListModel<File> implements ComboBoxModel<File> {
Vector<File> directories = new Vector<File>(); Vector<File> directories = new Vector<File>();
int[] depths = null; int[] depths = null;
File selectedDirectory = null; File selectedDirectory = null;
@ -1149,7 +1149,7 @@ public class WindowsFileChooserUI extends BasicFileChooserUI {
return directories.size(); return directories.size();
} }
public Object getElementAt(int index) { public File getElementAt(int index) {
return directories.elementAt(index); return directories.elementAt(index);
} }
} }
@ -1189,7 +1189,8 @@ public class WindowsFileChooserUI extends BasicFileChooserUI {
/** /**
* Data model for a type-face selection combo-box. * Data model for a type-face selection combo-box.
*/ */
protected class FilterComboBoxModel extends AbstractListModel implements ComboBoxModel, PropertyChangeListener { protected class FilterComboBoxModel extends AbstractListModel<FileFilter> implements ComboBoxModel<FileFilter>,
PropertyChangeListener {
protected FileFilter[] filters; protected FileFilter[] filters;
protected FilterComboBoxModel() { protected FilterComboBoxModel() {
super(); super();
@ -1242,7 +1243,7 @@ public class WindowsFileChooserUI extends BasicFileChooserUI {
} }
} }
public Object getElementAt(int index) { public FileFilter getElementAt(int index) {
if(index > getSize() - 1) { if(index > getSize() - 1) {
// This shouldn't happen. Try to recover gracefully. // This shouldn't happen. Try to recover gracefully.
return getFileChooser().getFileFilter(); return getFileChooser().getFileFilter();

View File

@ -81,6 +81,7 @@ public class WindowsTreeUI extends BasicTreeUI {
else { else {
Rectangle beginRect = getPathBounds(tree, getPathForRow Rectangle beginRect = getPathBounds(tree, getPathForRow
(tree, beginRow)); (tree, beginRow));
if (beginRect != null) {
Rectangle testRect = beginRect; Rectangle testRect = beginRect;
int beginY = beginRect.y; int beginY = beginRect.y;
int maxY = beginY + visRect.height; int maxY = beginY + visRect.height;
@ -88,15 +89,17 @@ public class WindowsTreeUI extends BasicTreeUI {
for(int counter = beginRow + 1; counter <= endRow; counter++) { for(int counter = beginRow + 1; counter <= endRow; counter++) {
testRect = getPathBounds(tree, testRect = getPathBounds(tree,
getPathForRow(tree, counter)); getPathForRow(tree, counter));
if((testRect.y + testRect.height) > maxY) if(testRect != null && (testRect.y + testRect.height) > maxY) {
counter = endRow; counter = endRow;
} }
}
tree.scrollRectToVisible(new Rectangle(visRect.x, beginY, 1, tree.scrollRectToVisible(new Rectangle(visRect.x, beginY, 1,
testRect.y + testRect.height- testRect.y + testRect.height-
beginY)); beginY));
} }
} }
} }
}
static protected final int HALF_SIZE = 4; static protected final int HALF_SIZE = 4;
static protected final int SIZE = 9; static protected final int SIZE = 9;

View File

@ -24,6 +24,8 @@
*/ */
package java.awt; package java.awt;
import sun.awt.AWTAccessor;
import java.awt.event.AdjustmentEvent; import java.awt.event.AdjustmentEvent;
import java.awt.event.AdjustmentListener; import java.awt.event.AdjustmentListener;
import java.awt.peer.ScrollPanePeer; import java.awt.peer.ScrollPanePeer;
@ -156,6 +158,12 @@ public class ScrollPaneAdjustable implements Adjustable, Serializable {
if (!GraphicsEnvironment.isHeadless()) { if (!GraphicsEnvironment.isHeadless()) {
initIDs(); initIDs();
} }
AWTAccessor.setScrollPaneAdjustableAccessor(new AWTAccessor.ScrollPaneAdjustableAccessor() {
public void setTypedValue(final ScrollPaneAdjustable adj,
final int v, final int type) {
adj.setTypedValue(v, type);
}
});
} }
/** /**

View File

@ -63,8 +63,7 @@ import java.io.Serializable;
public class BasicComboPopup extends JPopupMenu implements ComboPopup { public class BasicComboPopup extends JPopupMenu implements ComboPopup {
// An empty ListMode, this is used when the UI changes to allow // An empty ListMode, this is used when the UI changes to allow
// the JList to be gc'ed. // the JList to be gc'ed.
private static class EmptyListModelClass implements ListModel, private static class EmptyListModelClass implements ListModel<Object>, Serializable {
Serializable {
public int getSize() { return 0; } public int getSize() { return 0; }
public Object getElementAt(int index) { return null; } public Object getElementAt(int index) { return null; }
public void addListDataListener(ListDataListener l) {} public void addListDataListener(ListDataListener l) {}

View File

@ -810,12 +810,9 @@ public class BasicFileChooserUI extends FileChooserUI {
putValue(Action.ACTION_COMMAND_KEY, FilePane.ACTION_CHANGE_TO_PARENT_DIRECTORY); putValue(Action.ACTION_COMMAND_KEY, FilePane.ACTION_CHANGE_TO_PARENT_DIRECTORY);
} }
public void actionPerformed(ActionEvent e) { public void actionPerformed(ActionEvent e) {
Component focusOwner = KeyboardFocusManager.getCurrentKeyboardFocusManager().getFocusOwner();
if (focusOwner == null || !(focusOwner instanceof javax.swing.text.JTextComponent)) {
getFileChooser().changeToParentDirectory(); getFileChooser().changeToParentDirectory();
} }
} }
}
/** /**
* Responds to an Open or Save request * Responds to an Open or Save request

View File

@ -444,7 +444,7 @@ public class SynthComboBoxUI extends BasicComboBoxUI implements
* renderer installed on a Synth combo box is a JLabel. If this is changed, * renderer installed on a Synth combo box is a JLabel. If this is changed,
* then an assert will fail in SynthFileChooserUIImpl * then an assert will fail in SynthFileChooserUIImpl
*/ */
private class SynthComboBoxRenderer extends JLabel implements ListCellRenderer, UIResource { private class SynthComboBoxRenderer extends JLabel implements ListCellRenderer<Object>, UIResource {
public SynthComboBoxRenderer() { public SynthComboBoxRenderer() {
super(); super();
setName("ComboBox.renderer"); setName("ComboBox.renderer");
@ -452,7 +452,7 @@ public class SynthComboBoxUI extends BasicComboBoxUI implements
} }
@Override @Override
public Component getListCellRendererComponent(JList list, Object value, public Component getListCellRendererComponent(JList<?> list, Object value,
int index, boolean isSelected, boolean cellHasFocus) { int index, boolean isSelected, boolean cellHasFocus) {
setName("ComboBox.listRenderer"); setName("ComboBox.listRenderer");
SynthLookAndFeel.resetSelectedUI(); SynthLookAndFeel.resetSelectedUI();

View File

@ -725,11 +725,11 @@ public class FormView extends ComponentView implements ActionListener {
} }
Object m = attr.getAttribute(StyleConstants.ModelAttribute); Object m = attr.getAttribute(StyleConstants.ModelAttribute);
if (m instanceof OptionListModel) { if (m instanceof OptionListModel) {
OptionListModel model = (OptionListModel)m; OptionListModel<Option> model = (OptionListModel<Option>) m;
for (int i = 0; i < model.getSize(); i++) { for (int i = 0; i < model.getSize(); i++) {
if (model.isSelectedIndex(i)) { if (model.isSelectedIndex(i)) {
Option option = (Option) model.getElementAt(i); Option option = model.getElementAt(i);
appendBuffer(buffer, name, option.getValue()); appendBuffer(buffer, name, option.getValue());
} }
} }

View File

@ -3358,13 +3358,13 @@ public class HTMLDocument extends DefaultStyledDocument {
1); 1);
boolean multiple = attr.getAttribute(HTML.Attribute.MULTIPLE) != null; boolean multiple = attr.getAttribute(HTML.Attribute.MULTIPLE) != null;
if ((size > 1) || multiple) { if ((size > 1) || multiple) {
OptionListModel m = new OptionListModel(); OptionListModel<Option> m = new OptionListModel<Option>();
if (multiple) { if (multiple) {
m.setSelectionMode(ListSelectionModel.MULTIPLE_INTERVAL_SELECTION); m.setSelectionMode(ListSelectionModel.MULTIPLE_INTERVAL_SELECTION);
} }
selectModel = m; selectModel = m;
} else { } else {
selectModel = new OptionComboBoxModel(); selectModel = new OptionComboBoxModel<Option>();
} }
attr.addAttribute(StyleConstants.ModelAttribute, attr.addAttribute(StyleConstants.ModelAttribute,
selectModel); selectModel);
@ -3376,14 +3376,14 @@ public class HTMLDocument extends DefaultStyledDocument {
option = new Option(attr); option = new Option(attr);
if (selectModel instanceof OptionListModel) { if (selectModel instanceof OptionListModel) {
OptionListModel m = (OptionListModel)selectModel; OptionListModel<Option> m = (OptionListModel<Option>) selectModel;
m.addElement(option); m.addElement(option);
if (option.isSelected()) { if (option.isSelected()) {
m.addSelectionInterval(optionCount, optionCount); m.addSelectionInterval(optionCount, optionCount);
m.setInitialSelection(optionCount); m.setInitialSelection(optionCount);
} }
} else if (selectModel instanceof OptionComboBoxModel) { } else if (selectModel instanceof OptionComboBoxModel) {
OptionComboBoxModel m = (OptionComboBoxModel)selectModel; OptionComboBoxModel<Option> m = (OptionComboBoxModel<Option>) selectModel;
m.addElement(option); m.addElement(option);
if (option.isSelected()) { if (option.isSelected()) {
m.setSelectedItem(option); m.setSelectedItem(option);

View File

@ -527,17 +527,17 @@ public class HTMLWriter extends AbstractWriter {
Object model = attr.getAttribute(StyleConstants.ModelAttribute); Object model = attr.getAttribute(StyleConstants.ModelAttribute);
incrIndent(); incrIndent();
if (model instanceof OptionListModel) { if (model instanceof OptionListModel) {
OptionListModel listModel = (OptionListModel)model; OptionListModel<Option> listModel = (OptionListModel<Option>) model;
int size = listModel.getSize(); int size = listModel.getSize();
for (int i = 0; i < size; i++) { for (int i = 0; i < size; i++) {
Option option = (Option)listModel.getElementAt(i); Option option = listModel.getElementAt(i);
writeOption(option); writeOption(option);
} }
} else if (model instanceof OptionComboBoxModel) { } else if (model instanceof OptionComboBoxModel) {
OptionComboBoxModel comboBoxModel = (OptionComboBoxModel)model; OptionComboBoxModel<Option> comboBoxModel = (OptionComboBoxModel<Option>) model;
int size = comboBoxModel.getSize(); int size = comboBoxModel.getSize();
for (int i = 0; i < size; i++) { for (int i = 0; i < size; i++) {
Option option = (Option)comboBoxModel.getElementAt(i); Option option = comboBoxModel.getElementAt(i);
writeOption(option); writeOption(option);
} }
} }

View File

@ -25,7 +25,6 @@
package javax.swing.text.html; package javax.swing.text.html;
import javax.swing.*; import javax.swing.*;
import javax.swing.event.*;
import java.io.Serializable; import java.io.Serializable;
@ -41,7 +40,7 @@ import java.io.Serializable;
@author Sunita Mani @author Sunita Mani
*/ */
class OptionComboBoxModel extends DefaultComboBoxModel implements Serializable { class OptionComboBoxModel<E> extends DefaultComboBoxModel<E> implements Serializable {
private Option selectedOption = null; private Option selectedOption = null;

View File

@ -26,7 +26,6 @@ package javax.swing.text.html;
import javax.swing.*; import javax.swing.*;
import javax.swing.event.*; import javax.swing.event.*;
import java.util.EventListener;
import java.util.BitSet; import java.util.BitSet;
import java.io.Serializable; import java.io.Serializable;
@ -44,7 +43,7 @@ import java.io.Serializable;
@author Sunita Mani @author Sunita Mani
*/ */
class OptionListModel extends DefaultListModel implements ListSelectionModel, Serializable { class OptionListModel<E> extends DefaultListModel<E> implements ListSelectionModel, Serializable {
private static final int MIN = -1; private static final int MIN = -1;

View File

@ -25,15 +25,12 @@
package sun.awt; package sun.awt;
import sun.misc.Unsafe;
import java.awt.*; import java.awt.*;
import java.awt.event.InputEvent; import java.awt.event.InputEvent;
import java.awt.geom.Point2D; import java.awt.geom.Point2D;
import java.awt.image.BufferedImage;
import sun.misc.Unsafe;
import java.awt.peer.ComponentPeer; import java.awt.peer.ComponentPeer;
import java.security.AccessController;
import java.security.AccessControlContext; import java.security.AccessControlContext;
/** /**
@ -470,6 +467,17 @@ public final class AWTAccessor {
boolean isMultipleMode(FileDialog fileDialog); boolean isMultipleMode(FileDialog fileDialog);
} }
/*
* An accessor for the ScrollPaneAdjustable class.
*/
public interface ScrollPaneAdjustableAccessor {
/*
* Sets the value of this scrollbar to the specified value.
*/
void setTypedValue(final ScrollPaneAdjustable adj, final int v,
final int type);
}
/* /*
* Accessor instances are initialized in the static initializers of * Accessor instances are initialized in the static initializers of
* corresponding AWT classes by using setters defined below. * corresponding AWT classes by using setters defined below.
@ -485,6 +493,7 @@ public final class AWTAccessor {
private static EventQueueAccessor eventQueueAccessor; private static EventQueueAccessor eventQueueAccessor;
private static PopupMenuAccessor popupMenuAccessor; private static PopupMenuAccessor popupMenuAccessor;
private static FileDialogAccessor fileDialogAccessor; private static FileDialogAccessor fileDialogAccessor;
private static ScrollPaneAdjustableAccessor scrollPaneAdjustableAccessor;
/* /*
* Set an accessor object for the java.awt.Component class. * Set an accessor object for the java.awt.Component class.
@ -675,4 +684,21 @@ public final class AWTAccessor {
return fileDialogAccessor; return fileDialogAccessor;
} }
/*
* Set an accessor object for the java.awt.ScrollPaneAdjustable class.
*/
public static void setScrollPaneAdjustableAccessor(ScrollPaneAdjustableAccessor adj) {
scrollPaneAdjustableAccessor = adj;
}
/*
* Retrieve the accessor object for the java.awt.ScrollPaneAdjustable
* class.
*/
public static ScrollPaneAdjustableAccessor getScrollPaneAdjustableAccessor() {
if (scrollPaneAdjustableAccessor == null) {
unsafe.ensureClassInitialized(ScrollPaneAdjustable.class);
}
return scrollPaneAdjustableAccessor;
}
} }

View File

@ -570,7 +570,7 @@ public class FilePane extends JPanel implements PropertyChangeListener {
public JPanel createList() { public JPanel createList() {
JPanel p = new JPanel(new BorderLayout()); JPanel p = new JPanel(new BorderLayout());
final JFileChooser fileChooser = getFileChooser(); final JFileChooser fileChooser = getFileChooser();
final JList list = new JList() { final JList<Object> list = new JList<Object>() {
public int getNextMatch(String prefix, int startIndex, Position.Bias bias) { public int getNextMatch(String prefix, int startIndex, Position.Bias bias) {
ListModel model = getModel(); ListModel model = getModel();
int max = model.getSize(); int max = model.getSize();
@ -641,7 +641,7 @@ public class FilePane extends JPanel implements PropertyChangeListener {
/** /**
* This model allows for sorting JList * This model allows for sorting JList
*/ */
private class SortableListModel extends AbstractListModel private class SortableListModel extends AbstractListModel<Object>
implements TableModelListener, RowSorterListener { implements TableModelListener, RowSorterListener {
public SortableListModel() { public SortableListModel() {

View File

@ -60,7 +60,7 @@ import sun.swing.*;
*/ */
public class SynthFileChooserUIImpl extends SynthFileChooserUI { public class SynthFileChooserUIImpl extends SynthFileChooserUI {
private JLabel lookInLabel; private JLabel lookInLabel;
private JComboBox directoryComboBox; private JComboBox<File> directoryComboBox;
private DirectoryComboBoxModel directoryComboBoxModel; private DirectoryComboBoxModel directoryComboBoxModel;
private Action directoryComboBoxAction = new DirectoryComboBoxAction(); private Action directoryComboBoxAction = new DirectoryComboBoxAction();
@ -77,10 +77,9 @@ public class SynthFileChooserUIImpl extends SynthFileChooserUI {
private JPanel buttonPanel; private JPanel buttonPanel;
private JPanel bottomPanel; private JPanel bottomPanel;
private JComboBox filterComboBox; private JComboBox<FileFilter> filterComboBox;
private static final Dimension hstrut5 = new Dimension(5, 1); private static final Dimension hstrut5 = new Dimension(5, 1);
private static final Dimension vstrut5 = new Dimension(1, 5);
private static final Insets shrinkwrap = new Insets(0,0,0,0); private static final Insets shrinkwrap = new Insets(0,0,0,0);
@ -217,7 +216,7 @@ public class SynthFileChooserUIImpl extends SynthFileChooserUI {
topPanel.add(lookInLabel, BorderLayout.BEFORE_LINE_BEGINS); topPanel.add(lookInLabel, BorderLayout.BEFORE_LINE_BEGINS);
// CurrentDir ComboBox // CurrentDir ComboBox
directoryComboBox = new JComboBox(); directoryComboBox = new JComboBox<File>();
directoryComboBox.getAccessibleContext().setAccessibleDescription(lookInLabelText); directoryComboBox.getAccessibleContext().setAccessibleDescription(lookInLabelText);
directoryComboBox.putClientProperty( "JComboBox.isTableCellEditor", Boolean.TRUE ); directoryComboBox.putClientProperty( "JComboBox.isTableCellEditor", Boolean.TRUE );
lookInLabel.setLabelFor(directoryComboBox); lookInLabel.setLabelFor(directoryComboBox);
@ -394,7 +393,7 @@ public class SynthFileChooserUIImpl extends SynthFileChooserUI {
filterComboBoxModel = createFilterComboBoxModel(); filterComboBoxModel = createFilterComboBoxModel();
fc.addPropertyChangeListener(filterComboBoxModel); fc.addPropertyChangeListener(filterComboBoxModel);
filterComboBox = new JComboBox(filterComboBoxModel); filterComboBox = new JComboBox<FileFilter>(filterComboBoxModel);
filterComboBox.getAccessibleContext().setAccessibleDescription(filesOfTypeLabelText); filterComboBox.getAccessibleContext().setAccessibleDescription(filesOfTypeLabelText);
filesOfTypeLabel.setLabelFor(filterComboBox); filesOfTypeLabel.setLabelFor(filterComboBox);
filterComboBox.setRenderer(createFilterComboBoxRenderer()); filterComboBox.setRenderer(createFilterComboBoxRenderer());
@ -671,16 +670,16 @@ public class SynthFileChooserUIImpl extends SynthFileChooserUI {
// looking combo boxes. // looking combo boxes.
// So what we do here is delegate most jobs to the "real" or original renderer, // So what we do here is delegate most jobs to the "real" or original renderer,
// and simply monkey with the icon and text of the renderer. // and simply monkey with the icon and text of the renderer.
private class DirectoryComboBoxRenderer implements ListCellRenderer { private class DirectoryComboBoxRenderer implements ListCellRenderer<File> {
private ListCellRenderer delegate; private ListCellRenderer<? super File> delegate;
IndentIcon ii = new IndentIcon(); IndentIcon ii = new IndentIcon();
private DirectoryComboBoxRenderer(ListCellRenderer delegate) { private DirectoryComboBoxRenderer(ListCellRenderer<? super File> delegate) {
this.delegate = delegate; this.delegate = delegate;
} }
@Override @Override
public Component getListCellRendererComponent(JList list, Object value, int index, boolean isSelected, boolean cellHasFocus) { public Component getListCellRendererComponent(JList<? extends File> list, File value, int index, boolean isSelected, boolean cellHasFocus) {
Component c = delegate.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus); Component c = delegate.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus);
assert c instanceof JLabel; assert c instanceof JLabel;
@ -689,9 +688,8 @@ public class SynthFileChooserUIImpl extends SynthFileChooserUI {
label.setText(""); label.setText("");
return label; return label;
} }
File directory = (File) value; label.setText(getFileChooser().getName(value));
label.setText(getFileChooser().getName(directory)); Icon icon = getFileChooser().getIcon(value);
Icon icon = getFileChooser().getIcon(directory);
ii.icon = icon; ii.icon = icon;
ii.depth = directoryComboBoxModel.getDepth(index); ii.depth = directoryComboBoxModel.getDepth(index);
label.setIcon(ii); label.setIcon(ii);
@ -736,7 +734,7 @@ public class SynthFileChooserUIImpl extends SynthFileChooserUI {
/** /**
* Data model for a type-face selection combo-box. * Data model for a type-face selection combo-box.
*/ */
protected class DirectoryComboBoxModel extends AbstractListModel implements ComboBoxModel { protected class DirectoryComboBoxModel extends AbstractListModel<File> implements ComboBoxModel<File> {
Vector<File> directories = new Vector<File>(); Vector<File> directories = new Vector<File>();
int[] depths = null; int[] depths = null;
File selectedDirectory = null; File selectedDirectory = null;
@ -857,7 +855,7 @@ public class SynthFileChooserUIImpl extends SynthFileChooserUI {
return directories.size(); return directories.size();
} }
public Object getElementAt(int index) { public File getElementAt(int index) {
return directories.elementAt(index); return directories.elementAt(index);
} }
} }
@ -890,18 +888,19 @@ public class SynthFileChooserUIImpl extends SynthFileChooserUI {
/** /**
* Render different type sizes and styles. * Render different type sizes and styles.
*/ */
public class FilterComboBoxRenderer implements ListCellRenderer { public class FilterComboBoxRenderer implements ListCellRenderer<FileFilter> {
private ListCellRenderer delegate; private ListCellRenderer<? super FileFilter> delegate;
private FilterComboBoxRenderer(ListCellRenderer delegate) { private FilterComboBoxRenderer(ListCellRenderer<? super FileFilter> delegate) {
this.delegate = delegate; this.delegate = delegate;
} }
public Component getListCellRendererComponent(JList list, Object value, int index, boolean isSelected, boolean cellHasFocus) { public Component getListCellRendererComponent(JList<? extends FileFilter> list, FileFilter value, int index,
boolean isSelected, boolean cellHasFocus) {
Component c = delegate.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus); Component c = delegate.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus);
String text = null; String text = null;
if (value != null && value instanceof FileFilter) { if (value != null) {
text = ((FileFilter) value).getDescription(); text = value.getDescription();
} }
//this should always be true, since SynthComboBoxUI's SynthComboBoxRenderer //this should always be true, since SynthComboBoxUI's SynthComboBoxRenderer
@ -924,7 +923,8 @@ public class SynthFileChooserUIImpl extends SynthFileChooserUI {
/** /**
* Data model for a type-face selection combo-box. * Data model for a type-face selection combo-box.
*/ */
protected class FilterComboBoxModel extends AbstractListModel implements ComboBoxModel, PropertyChangeListener { protected class FilterComboBoxModel extends AbstractListModel<FileFilter> implements ComboBoxModel<FileFilter>,
PropertyChangeListener {
protected FileFilter[] filters; protected FileFilter[] filters;
protected FilterComboBoxModel() { protected FilterComboBoxModel() {
super(); super();
@ -977,7 +977,7 @@ public class SynthFileChooserUIImpl extends SynthFileChooserUI {
} }
} }
public Object getElementAt(int index) { public FileFilter getElementAt(int index) {
if(index > getSize() - 1) { if(index > getSize() - 1) {
// This shouldn't happen. Try to recover gracefully. // This shouldn't happen. Try to recover gracefully.
return getFileChooser().getFileFilter(); return getFileChooser().getFileFilter();

View File

@ -47,15 +47,7 @@ import java.util.concurrent.ExecutionException;
import java.util.concurrent.FutureTask; import java.util.concurrent.FutureTask;
import java.util.concurrent.atomic.AtomicReference; import java.util.concurrent.atomic.AtomicReference;
import javax.swing.BorderFactory; import javax.swing.*;
import javax.swing.CellRendererPane;
import javax.swing.JTextField;
import javax.swing.JTextArea;
import javax.swing.JEditorPane;
import javax.swing.JViewport;
import javax.swing.JScrollPane;
import javax.swing.JTextPane;
import javax.swing.SwingUtilities;
import javax.swing.border.Border; import javax.swing.border.Border;
import javax.swing.border.TitledBorder; import javax.swing.border.TitledBorder;
import javax.swing.text.BadLocationException; import javax.swing.text.BadLocationException;
@ -336,7 +328,22 @@ public class TextComponentPrintable implements CountingPrintable {
assert SwingUtilities.isEventDispatchThread(); assert SwingUtilities.isEventDispatchThread();
JTextComponent ret = null; JTextComponent ret = null;
if (textComponent instanceof JTextField) { if (textComponent instanceof JPasswordField) {
ret =
new JPasswordField() {
{
setEchoChar(((JPasswordField) textComponent).getEchoChar());
setHorizontalAlignment(
((JTextField) textComponent).getHorizontalAlignment());
}
@Override
public FontMetrics getFontMetrics(Font font) {
return (frc.get() == null)
? super.getFontMetrics(font)
: FontDesignMetrics.getMetrics(font, frc.get());
}
};
} else if (textComponent instanceof JTextField) {
ret = ret =
new JTextField() { new JTextField() {
{ {

View File

@ -2690,6 +2690,7 @@ public class BidiBase {
public void setPara(AttributedCharacterIterator paragraph) public void setPara(AttributedCharacterIterator paragraph)
{ {
byte paraLvl; byte paraLvl;
char ch = paragraph.first();
Boolean runDirection = Boolean runDirection =
(Boolean) paragraph.getAttribute(TextAttributeConstants.RUN_DIRECTION); (Boolean) paragraph.getAttribute(TextAttributeConstants.RUN_DIRECTION);
Object shaper = paragraph.getAttribute(TextAttributeConstants.NUMERIC_SHAPING); Object shaper = paragraph.getAttribute(TextAttributeConstants.NUMERIC_SHAPING);
@ -2705,7 +2706,6 @@ public class BidiBase {
byte[] embeddingLevels = new byte[len]; byte[] embeddingLevels = new byte[len];
char[] txt = new char[len]; char[] txt = new char[len];
int i = 0; int i = 0;
char ch = paragraph.first();
while (ch != AttributedCharacterIterator.DONE) { while (ch != AttributedCharacterIterator.DONE) {
txt[i] = ch; txt[i] = ch;
Integer embedding = Integer embedding =
@ -3411,18 +3411,21 @@ public class BidiBase {
* Display the bidi internal state, used in debugging. * Display the bidi internal state, used in debugging.
*/ */
public String toString() { public String toString() {
StringBuffer buf = new StringBuffer(super.toString()); StringBuilder buf = new StringBuilder(getClass().getName());
buf.append("[dir: " + direction); buf.append("[dir: ");
buf.append(" baselevel: " + paraLevel); buf.append(direction);
buf.append(" length: " + length); buf.append(" baselevel: ");
buf.append(paraLevel);
buf.append(" length: ");
buf.append(length);
buf.append(" runs: "); buf.append(" runs: ");
if (levels == null) { if (levels == null) {
buf.append("null"); buf.append("none");
} else { } else {
buf.append('['); buf.append('[');
buf.append(levels[0]); buf.append(levels[0]);
for (int i = 0; i < levels.length; i++) { for (int i = 1; i < levels.length; i++) {
buf.append(' '); buf.append(' ');
buf.append(levels[i]); buf.append(levels[i]);
} }
@ -3430,12 +3433,11 @@ public class BidiBase {
} }
buf.append(" text: [0x"); buf.append(" text: [0x");
buf.append(Integer.toHexString(text[0])); buf.append(Integer.toHexString(text[0]));
for (int i = 0; i < text.length; i++) { for (int i = 1; i < text.length; i++) {
buf.append(" 0x"); buf.append(" 0x");
buf.append(Integer.toHexString(text[i])); buf.append(Integer.toHexString(text[i]));
} }
buf.append(']'); buf.append("]]");
buf.append(']');
return buf.toString(); return buf.toString();
} }

View File

@ -33,12 +33,9 @@ import java.awt.event.ActionEvent;
import javax.swing.plaf.basic.*; import javax.swing.plaf.basic.*;
import javax.swing.SwingUtilities; import javax.swing.SwingUtilities;
import javax.swing.SwingConstants; import javax.swing.SwingConstants;
public class XButtonPeer extends XComponentPeer implements ButtonPeer { public class XButtonPeer extends XComponentPeer implements ButtonPeer {
private boolean pressed;
boolean pressed; private boolean armed;
boolean armed;
private Insets focusInsets; private Insets focusInsets;
private Insets borderInsets; private Insets borderInsets;
private Insets contentAreaInsets; private Insets contentAreaInsets;
@ -86,11 +83,6 @@ public class XButtonPeer extends XComponentPeer implements ButtonPeer {
this.label = label; this.label = label;
repaint(); repaint();
} }
public void paint(Graphics g) {
paint(g,target);
}
public void setBackground(Color c) { public void setBackground(Color c) {
updateMotifColors(c); updateMotifColors(c);
super.setBackground(c); super.setBackground(c);
@ -133,16 +125,10 @@ public class XButtonPeer extends XComponentPeer implements ButtonPeer {
case MouseEvent.MOUSE_ENTERED: case MouseEvent.MOUSE_ENTERED:
if (pressed) if (pressed)
armed = true; armed = true;
// repaint();
break; break;
case MouseEvent.MOUSE_EXITED: case MouseEvent.MOUSE_EXITED:
armed = false; armed = false;
// repaint();
break; break;
} }
} }
@ -209,18 +195,14 @@ public class XButtonPeer extends XComponentPeer implements ButtonPeer {
public Dimension minimumSize() { public Dimension minimumSize() {
return getMinimumSize(); return getMinimumSize();
} }
/**
* This method is called from Toolkit Thread and so it should not call any
/* * client code.
This method is called from Toolkit Thread and so it should not call any client code
*/ */
public void paint(Graphics g, Component c) @Override
{ void paintPeer(final Graphics g) {
if (!disposed && (g != null)) if (!disposed) {
{
Dimension size = getPeerSize(); Dimension size = getPeerSize();
g.setColor( getPeerBackground() ); /* erase the existing button remains */ g.setColor( getPeerBackground() ); /* erase the existing button remains */
g.fillRect(0,0, size.width , size.height); g.fillRect(0,0, size.width , size.height);
paintBorder(g,borderInsets.left, paintBorder(g,borderInsets.left,
@ -239,11 +221,9 @@ public class XButtonPeer extends XComponentPeer implements ButtonPeer {
viewRect.width = size.width - (contentAreaInsets.left+contentAreaInsets.right); viewRect.width = size.width - (contentAreaInsets.left+contentAreaInsets.right);
viewRect.height = size.height - (contentAreaInsets.top+contentAreaInsets.bottom); viewRect.height = size.height - (contentAreaInsets.top+contentAreaInsets.bottom);
viewRect.x = contentAreaInsets.left; viewRect.x = contentAreaInsets.left;
viewRect.y = contentAreaInsets.right; viewRect.y = contentAreaInsets.top;
String llabel = (label != null) ? label : ""; String llabel = (label != null) ? label : "";
// layout the text and icon // layout the text and icon
String text = SwingUtilities.layoutCompoundLabel( String text = SwingUtilities.layoutCompoundLabel(
fm, llabel, null, fm, llabel, null,
@ -309,10 +289,9 @@ public class XButtonPeer extends XComponentPeer implements ButtonPeer {
else { else {
/*** paint the text disabled ***/ /*** paint the text disabled ***/
g.setColor(getPeerBackground().brighter()); g.setColor(getPeerBackground().brighter());
BasicGraphicsUtils.drawStringUnderlineCharAt(g,text, mnemonicIndex, BasicGraphicsUtils.drawStringUnderlineCharAt(g,text, mnemonicIndex,
textRect.x, textRect.y + fm.getAscent()); textRect.x, textRect.y + fm.getAscent());
g.setColor(c.getBackground().darker()); g.setColor(getPeerBackground().darker());
BasicGraphicsUtils.drawStringUnderlineCharAt(g,text, mnemonicIndex, BasicGraphicsUtils.drawStringUnderlineCharAt(g,text, mnemonicIndex,
textRect.x - 1, textRect.y + fm.getAscent() - 1); textRect.x - 1, textRect.y + fm.getAscent() - 1);
} }

View File

@ -297,19 +297,15 @@ class XCheckboxPeer extends XComponentPeer implements CheckboxPeer {
double fsize = (double) checkBoxSize; double fsize = (double) checkBoxSize;
myCheckMark = AffineTransform.getScaleInstance(fsize / MASTER_SIZE, fsize / MASTER_SIZE).createTransformedShape(MASTER_CHECKMARK); myCheckMark = AffineTransform.getScaleInstance(fsize / MASTER_SIZE, fsize / MASTER_SIZE).createTransformedShape(MASTER_CHECKMARK);
} }
@Override
public void paint(Graphics g) { void paintPeer(final Graphics g) {
if (g != null) {
//layout(); //layout();
Dimension size = getPeerSize(); Dimension size = getPeerSize();
Font f = getPeerFont(); Font f = getPeerFont();
flush(); flush();
g.setColor(getPeerBackground()); // erase the existing button g.setColor(getPeerBackground()); // erase the existing button
g.fillRect(0,0, size.width, size.height); g.fillRect(0,0, size.width, size.height);
if (label != null) { if (label != null) {
g.setFont(f); g.setFont(f);
paintText(g, textRect, label); paintText(g, textRect, label);
@ -322,7 +318,6 @@ class XCheckboxPeer extends XComponentPeer implements CheckboxPeer {
focusRect.width, focusRect.width,
focusRect.height); focusRect.height);
} }
// Paint the checkbox or radio button // Paint the checkbox or radio button
if (checkBoxGroup == null) { if (checkBoxGroup == null) {
paintCheckbox(g, cbX, cbY, checkBoxSize, checkBoxSize); paintCheckbox(g, cbX, cbY, checkBoxSize, checkBoxSize);
@ -330,8 +325,6 @@ class XCheckboxPeer extends XComponentPeer implements CheckboxPeer {
else { else {
paintRadioButton(g, cbX, cbY, checkBoxSize, checkBoxSize); paintRadioButton(g, cbX, cbY, checkBoxSize, checkBoxSize);
} }
}
flush(); flush();
} }

View File

@ -550,10 +550,10 @@ public class XChoicePeer extends XComponentPeer implements ChoicePeer, ToplevelS
/** /**
* Paint the choice * Paint the choice
*/ */
public void paint(Graphics g) { @Override
void paintPeer(final Graphics g) {
flush(); flush();
Dimension size = getPeerSize(); Dimension size = getPeerSize();
// TODO: when mouse is down over button, widget should be drawn depressed // TODO: when mouse is down over button, widget should be drawn depressed
g.setColor(getPeerBackground()); g.setColor(getPeerBackground());
g.fillRect(0, 0, width, height); g.fillRect(0, 0, width, height);
@ -912,16 +912,22 @@ public class XChoicePeer extends XComponentPeer implements ChoicePeer, ToplevelS
/* /*
* fillRect with current Background color on the whole dropdown list. * fillRect with current Background color on the whole dropdown list.
*/ */
public void paintBackground(){ public void paintBackground() {
Graphics g = getGraphics(); final Graphics g = getGraphics();
if (g != null) {
try {
g.setColor(getPeerBackground()); g.setColor(getPeerBackground());
g.fillRect(0, 0, width, height); g.fillRect(0, 0, width, height);
} finally {
g.dispose();
}
}
} }
/* /*
* 6405689. In some cases we should erase background to eliminate painting * 6405689. In some cases we should erase background to eliminate painting
* artefacts. * artefacts.
*/ */
@Override
public void repaint() { public void repaint() {
if (!isVisible()) { if (!isVisible()) {
return; return;
@ -931,8 +937,8 @@ public class XChoicePeer extends XComponentPeer implements ChoicePeer, ToplevelS
} }
super.repaint(); super.repaint();
} }
@Override
public void paint(Graphics g) { public void paintPeer(Graphics g) {
//System.out.println("UC.paint()"); //System.out.println("UC.paint()");
Choice choice = (Choice)target; Choice choice = (Choice)target;
Color colors[] = XChoicePeer.this.getGUIcolors(); Color colors[] = XChoicePeer.this.getGUIcolors();

View File

@ -38,7 +38,6 @@ import java.awt.Graphics;
import java.awt.GraphicsConfiguration; import java.awt.GraphicsConfiguration;
import java.awt.Image; import java.awt.Image;
import java.awt.Insets; import java.awt.Insets;
import java.awt.KeyboardFocusManager;
import java.awt.Rectangle; import java.awt.Rectangle;
import java.awt.SystemColor; import java.awt.SystemColor;
import java.awt.Toolkit; import java.awt.Toolkit;
@ -59,15 +58,11 @@ import java.awt.image.ImageProducer;
import java.awt.image.VolatileImage; import java.awt.image.VolatileImage;
import java.awt.peer.ComponentPeer; import java.awt.peer.ComponentPeer;
import java.awt.peer.ContainerPeer; import java.awt.peer.ContainerPeer;
import java.awt.peer.LightweightPeer;
import java.lang.reflect.*; import java.lang.reflect.*;
import java.security.*; import java.security.*;
import java.util.Collection; import java.util.Collection;
import java.util.HashSet;
import java.util.Set; import java.util.Set;
import java.util.Vector;
import sun.util.logging.PlatformLogger; import sun.util.logging.PlatformLogger;
import sun.awt.*; import sun.awt.*;
import sun.awt.event.IgnorePaintEvent; import sun.awt.event.IgnorePaintEvent;
import sun.awt.image.SunVolatileImage; import sun.awt.image.SunVolatileImage;
@ -428,27 +423,23 @@ public class XComponentPeer extends XWindow implements ComponentPeer, DropTarget
public void disable() { public void disable() {
setEnabled(false); setEnabled(false);
} }
@Override
public void paint(Graphics g) { public void paint(final Graphics g) {
super.paint(g);
// allow target to change the picture
target.paint(g);
} }
public void repaint(long tm, int x, int y, int width, int height) {
repaint();
}
public Graphics getGraphics() { public Graphics getGraphics() {
return getGraphics(surfaceData, getPeerForeground(), getPeerBackground(), getPeerFont()); return getGraphics(surfaceData, getPeerForeground(), getPeerBackground(), getPeerFont());
} }
public void print(Graphics g) { public void print(Graphics g) {
// clear rect here to emulate X clears rect before Expose // clear rect here to emulate X clears rect before Expose
g.setColor(target.getBackground()); g.setColor(target.getBackground());
g.fillRect(0, 0, target.getWidth(), target.getHeight()); g.fillRect(0, 0, target.getWidth(), target.getHeight());
g.setColor(target.getForeground()); g.setColor(target.getForeground());
// paint peer // paint peer
paint(g); paintPeer(g);
// allow target to change the picture // allow target to change the picture
target.print(g); target.print(g);
} }

View File

@ -85,7 +85,8 @@ class XLabelPeer extends XComponentPeer implements LabelPeer {
*/ */
// NOTE: This method is called by privileged threads. // NOTE: This method is called by privileged threads.
// DO NOT INVOKE CLIENT CODE ON THIS THREAD! // DO NOT INVOKE CLIENT CODE ON THIS THREAD!
public void paint(Graphics g) { @Override
void paintPeer(final Graphics g) {
int textX = 0; int textX = 0;
int textY = 0; int textY = 0;
g.setColor(getPeerBackground()); g.setColor(getPeerBackground());

View File

@ -363,9 +363,7 @@ class XListPeer extends XComponentPeer implements ListPeer, XScrollbarClient {
return Math.min(items.size()-1, itemsInWindow()-1); return Math.min(items.size()-1, itemsInWindow()-1);
} }
} }
public void repaintScrollbarRequest(XScrollbar scrollbar) { public void repaintScrollbarRequest(XScrollbar scrollbar) {
Graphics g = getGraphics();
if (scrollbar == hsb) { if (scrollbar == hsb) {
repaint(PAINT_HSCROLL); repaint(PAINT_HSCROLL);
} }
@ -373,9 +371,6 @@ class XListPeer extends XComponentPeer implements ListPeer, XScrollbarClient {
repaint(PAINT_VSCROLL); repaint(PAINT_VSCROLL);
} }
} }
/** /**
* Overridden for performance * Overridden for performance
*/ */
@ -410,18 +405,20 @@ class XListPeer extends XComponentPeer implements ListPeer, XScrollbarClient {
* @param distance the distance to copy the source area * @param distance the distance to copy the source area
*/ */
private void repaint(int firstItem, int lastItem, int options, Rectangle source, Point distance) { private void repaint(int firstItem, int lastItem, int options, Rectangle source, Point distance) {
Graphics g = getGraphics(); final Graphics g = getGraphics();
if (g != null) {
try { try {
painter.paint(g, firstItem, lastItem, options, source, distance); painter.paint(g, firstItem, lastItem, options, source, distance);
target.paint(g);
} finally { } finally {
g.dispose(); g.dispose();
} }
} }
}
public void paint(Graphics g) { @Override
void paintPeer(final Graphics g) {
painter.paint(g, getFirstVisibleItem(), getLastVisibleItem(), PAINT_ALL); painter.paint(g, getFirstVisibleItem(), getLastVisibleItem(), PAINT_ALL);
} }
public boolean isFocusable() { return true; } public boolean isFocusable() { return true; }
// TODO: share/promote the Focus methods? // TODO: share/promote the Focus methods?

View File

@ -415,7 +415,7 @@ public class XMenuBarPeer extends XBaseMenuWindow implements MenuBarPeer {
* Overriden XWindow painting & printing * Overriden XWindow painting & printing
* *
************************************************/ ************************************************/
public void paint(Graphics g) { public void paintPeer(Graphics g) {
resetColors(); resetColors();
/* Calculate menubar dimension. */ /* Calculate menubar dimension. */
int width = getWidth(); int width = getWidth();

View File

@ -432,9 +432,9 @@ public class XMenuWindow extends XBaseMenuWindow {
/** /**
* Paints menu window * Paints menu window
*/ */
public void paint(Graphics g) { @Override
public void paintPeer(Graphics g) {
resetColors(); resetColors();
int width = getWidth(); int width = getWidth();
int height = getHeight(); int height = getHeight();

View File

@ -60,14 +60,13 @@ public class XPanelPeer extends XCanvasPeer implements PanelPeer {
public Insets getInsets() { public Insets getInsets() {
return new Insets(0, 0, 0, 0); return new Insets(0, 0, 0, 0);
} }
public void paint(Graphics g) { public void paint(Graphics g) {
super.paint(g); super.paint(g);
/* SunGraphicsCallback.PaintHeavyweightComponentsCallback.getInstance(). SunGraphicsCallback.PaintHeavyweightComponentsCallback.getInstance().
runComponents(((Container)target).getComponents(), g, runComponents(((Container)target).getComponents(), g,
SunGraphicsCallback.LIGHTWEIGHTS | SunGraphicsCallback.LIGHTWEIGHTS |
SunGraphicsCallback.HEAVYWEIGHTS); SunGraphicsCallback.HEAVYWEIGHTS);
*/ } }
public void print(Graphics g) { public void print(Graphics g) {
super.print(g); super.print(g);
SunGraphicsCallback.PrintHeavyweightComponentsCallback.getInstance(). SunGraphicsCallback.PrintHeavyweightComponentsCallback.getInstance().

View File

@ -53,9 +53,9 @@ class XRepaintArea extends RepaintArea {
*/ */
protected void updateComponent(Component comp, Graphics g) { protected void updateComponent(Component comp, Graphics g) {
if (comp != null) { if (comp != null) {
ComponentPeer peer = comp.getPeer(); final XComponentPeer peer = (XComponentPeer) comp.getPeer();
if (peer != null) { if (peer != null) {
peer.paint(g); peer.paintPeer(g);
} }
super.updateComponent(comp, g); super.updateComponent(comp, g);
} }
@ -66,9 +66,9 @@ class XRepaintArea extends RepaintArea {
*/ */
protected void paintComponent(Component comp, Graphics g) { protected void paintComponent(Component comp, Graphics g) {
if (comp != null) { if (comp != null) {
ComponentPeer peer = comp.getPeer(); final XComponentPeer peer = (XComponentPeer) comp.getPeer();
if (peer != null) { if (peer != null) {
peer.paint(g); peer.paintPeer(g);
} }
super.paintComponent(comp, g); super.paintComponent(comp, g);
} }

View File

@ -29,6 +29,8 @@ import java.awt.*;
import java.awt.event.*; import java.awt.event.*;
import java.awt.peer.*; import java.awt.peer.*;
import java.lang.reflect.*; import java.lang.reflect.*;
import sun.awt.AWTAccessor;
import sun.awt.SunToolkit; import sun.awt.SunToolkit;
class XScrollPanePeer extends XComponentPeer implements ScrollPanePeer, XScrollbarClient { class XScrollPanePeer extends XComponentPeer implements ScrollPanePeer, XScrollbarClient {
@ -41,9 +43,7 @@ class XScrollPanePeer extends XComponentPeer implements ScrollPanePeer, XScrollb
public final static int VERTICAL = 1 << 0; public final static int VERTICAL = 1 << 0;
public final static int HORIZONTAL = 1 << 1; public final static int HORIZONTAL = 1 << 1;
private static Method m_setValue;
static { static {
m_setValue = SunToolkit.getMethod(ScrollPaneAdjustable.class, "setTypedValue", new Class[] {Integer.TYPE, Integer.TYPE});
SCROLLBAR = XToolkit.getUIDefaults().getInt("ScrollBar.defaultWidth"); SCROLLBAR = XToolkit.getUIDefaults().getInt("ScrollBar.defaultWidth");
} }
@ -293,18 +293,21 @@ class XScrollPanePeer extends XComponentPeer implements ScrollPanePeer, XScrollb
setAdjustableValue(hadj, hsb.getValue(), type); setAdjustableValue(hadj, hsb.getValue(), type);
sx = -(hsb.getValue()); sx = -(hsb.getValue());
Graphics g = getGraphics(); Graphics g = getGraphics();
if (g != null) {
try { try {
paintHorScrollbar(g, colors, true); paintHorScrollbar(g, colors, true);
} finally { } finally {
g.dispose(); g.dispose();
} }
} }
}
if ((flag & VERTICAL) != 0) { if ((flag & VERTICAL) != 0) {
vsb.setValue(Math.min(y, vsb.getMaximum() - vsb.getVisibleAmount())); vsb.setValue(Math.min(y, vsb.getMaximum() - vsb.getVisibleAmount()));
ScrollPaneAdjustable vadj = (ScrollPaneAdjustable)sp.getVAdjustable(); ScrollPaneAdjustable vadj = (ScrollPaneAdjustable)sp.getVAdjustable();
setAdjustableValue(vadj, vsb.getValue(), type); setAdjustableValue(vadj, vsb.getValue(), type);
sy = -(vsb.getValue()); sy = -(vsb.getValue());
Graphics g = getGraphics(); Graphics g = getGraphics();
if (g != null) {
try { try {
paintVerScrollbar(g, colors, true); paintVerScrollbar(g, colors, true);
} finally { } finally {
@ -312,29 +315,30 @@ class XScrollPanePeer extends XComponentPeer implements ScrollPanePeer, XScrollb
} }
} }
} }
}
c.move(sx, sy); c.move(sx, sy);
} }
void setAdjustableValue(ScrollPaneAdjustable adj, int value, int type) { private void setAdjustableValue(final ScrollPaneAdjustable adj, final int value,
try { final int type) {
m_setValue.invoke(adj, new Object[] {Integer.valueOf(value), Integer.valueOf(type)}); AWTAccessor.getScrollPaneAdjustableAccessor().setTypedValue(adj, value,
} catch (IllegalAccessException iae) { type);
adj.setValue(value);
} catch (IllegalArgumentException iae2) {
adj.setValue(value);
} catch (InvocationTargetException ite) {
adj.setValue(value);
ite.getCause().printStackTrace();
} }
@Override
void paintPeer(final Graphics g) {
final Color[] colors = getGUIcolors();
g.setColor(colors[BACKGROUND_COLOR]);
final int h = height - hsbSpace;
final int w = width - vsbSpace;
g.fillRect(0, 0, w, h);
// paint rectangular region between scrollbars
g.fillRect(w, h, vsbSpace, hsbSpace);
if (MARGIN > 0) {
draw3DRect(g, colors, 0, 0, w - 1, h - 1, false);
} }
paintScrollBars(g, colors);
public void paint(Graphics g) {
paintComponent(g);
} }
private void paintScrollBars(Graphics g, Color[] colors) {
void paintScrollBars(Graphics g, Color[] colors) {
if (vsbSpace > 0) { if (vsbSpace > 0) {
paintVerScrollbar(g, colors, true); paintVerScrollbar(g, colors, true);
// paint the whole scrollbar // paint the whole scrollbar
@ -345,51 +349,32 @@ class XScrollPanePeer extends XComponentPeer implements ScrollPanePeer, XScrollb
// paint the whole scrollbar // paint the whole scrollbar
} }
} }
void repaintScrollBars() { void repaintScrollBars() {
Graphics g = getGraphics(); Graphics g = getGraphics();
Color colors[] = getGUIcolors(); Color colors[] = getGUIcolors();
if (g != null) { if (g != null) {
paintScrollBars(g,colors); try {
} paintScrollBars(g, colors);
} finally {
g.dispose(); g.dispose();
} }
}
}
public void repaintScrollbarRequest(XScrollbar sb) { public void repaintScrollbarRequest(XScrollbar sb) {
Graphics g = getGraphics(); Graphics g = getGraphics();
Color colors[] = getGUIcolors(); Color colors[] = getGUIcolors();
if (g != null) { if (g != null) {
try {
if (sb == vsb) { if (sb == vsb) {
paintVerScrollbar(g,colors,true); paintVerScrollbar(g, colors, true);
} else if (sb == hsb) {
paintHorScrollbar(g, colors, true);
} }
else if (sb == hsb) { } finally {
paintHorScrollbar(g,colors,true); g.dispose();
} }
} }
} }
/**
* Paint the scrollpane.
*/
public void paintComponent(Graphics g) {
Color colors[] = getGUIcolors();
g.setColor(colors[BACKGROUND_COLOR]);
int h = height - hsbSpace;
int w = width - vsbSpace;
g.fillRect(0, 0, w, h);
// paint rectangular region between scrollbars
g.fillRect(w, h, vsbSpace, hsbSpace);
if (MARGIN > 0) {
draw3DRect(g, colors, 0, 0, w - 1, h - 1, false);
}
paintScrollBars(g,colors);
}
public void handleEvent(java.awt.AWTEvent e) { public void handleEvent(java.awt.AWTEvent e) {
super.handleEvent(e); super.handleEvent(e);

View File

@ -90,18 +90,12 @@ class XScrollbarPeer extends XComponentPeer implements ScrollbarPeer, XScrollbar
? new Dimension(getDefaultDimension(), DEFAULT_LENGTH) ? new Dimension(getDefaultDimension(), DEFAULT_LENGTH)
: new Dimension(DEFAULT_LENGTH, getDefaultDimension()); : new Dimension(DEFAULT_LENGTH, getDefaultDimension());
} }
public void repaint() {
Graphics g = getGraphics();
if (g != null) paint(g);
}
/** /**
* Paint the scrollbar. * Paint the scrollbar.
*/ */
public void paint(Graphics g) { @Override
Scrollbar sb = (Scrollbar)target; void paintPeer(final Graphics g) {
Color colors[] = getGUIcolors(); final Color[] colors = getGUIcolors();
g.setColor(colors[BACKGROUND_COLOR]); g.setColor(colors[BACKGROUND_COLOR]);
tsb.paint(g, colors, true); tsb.paint(g, colors, true);
// paint the whole scrollbar // paint the whole scrollbar

View File

@ -185,11 +185,8 @@ class XTextAreaPeer extends XComponentPeer implements TextAreaPeer {
*/ */
@Override @Override
public void pSetCursor(Cursor cursor, boolean ignoreSubComponents) { public void pSetCursor(Cursor cursor, boolean ignoreSubComponents) {
Point onScreen = getLocationOnScreen();
if (ignoreSubComponents || if (ignoreSubComponents ||
javaMouseEventHandler == null || javaMouseEventHandler == null) {
onScreen == null)
{
super.pSetCursor(cursor, true); super.pSetCursor(cursor, true);
return; return;
} }
@ -197,6 +194,7 @@ class XTextAreaPeer extends XComponentPeer implements TextAreaPeer {
Point cursorPos = new Point(); Point cursorPos = new Point();
((XGlobalCursorManager)XGlobalCursorManager.getCursorManager()).getCursorPos(cursorPos); ((XGlobalCursorManager)XGlobalCursorManager.getCursorManager()).getCursorPos(cursorPos);
final Point onScreen = getLocationOnScreen();
Point localPoint = new Point(cursorPos.x - onScreen.x, cursorPos.y - onScreen.y ); Point localPoint = new Point(cursorPos.x - onScreen.x, cursorPos.y - onScreen.y );
javaMouseEventHandler.setPointerToUnderPoint(localPoint); javaMouseEventHandler.setPointerToUnderPoint(localPoint);
@ -300,15 +298,14 @@ class XTextAreaPeer extends XComponentPeer implements TextAreaPeer {
* Paint the component * Paint the component
* this method is called when the repaint instruction has been used * this method is called when the repaint instruction has been used
*/ */
public void repaint() { public void repaint() {
if (textPane != null) { if (textPane != null) {
//textPane.validate(); //textPane.validate();
textPane.repaint(); textPane.repaint();
} }
} }
@Override
public void paint(Graphics g) { void paintPeer(final Graphics g) {
if (textPane != null) { if (textPane != null) {
textPane.paint(g); textPane.paint(g);
} }

View File

@ -370,12 +370,11 @@ public class XTextFieldPeer extends XComponentPeer implements TextFieldPeer {
public void repaint() { public void repaint() {
if (xtext != null) xtext.repaint(); if (xtext != null) xtext.repaint();
} }
@Override
public void paint(Graphics g) { void paintPeer(final Graphics g) {
if (xtext != null) xtext.paint(g); if (xtext != null) xtext.paint(g);
} }
public void print(Graphics g) { public void print(Graphics g) {
if (xtext != null) { if (xtext != null) {
xtext.print(g); xtext.print(g);

View File

@ -241,16 +241,19 @@ class XWarningWindow extends XWindow {
Font getFont () { Font getFont () {
return ownerWindow.getFont(); return ownerWindow.getFont();
} }
@Override
public void repaint() { public void repaint() {
Rectangle bounds = getBounds(); final Rectangle bounds = getBounds();
Graphics g = getGraphics(); final Graphics g = getGraphics();
if (g != null) {
try { try {
paint(g, 0, 0, bounds.width, bounds.height); paint(g, 0, 0, bounds.width, bounds.height);
} finally { } finally {
g.dispose(); g.dispose();
} }
} }
}
@Override @Override
public void handleExposeEvent(XEvent xev) { public void handleExposeEvent(XEvent xev) {
super.handleExposeEvent(xev); super.handleExposeEvent(xev);
@ -263,13 +266,15 @@ class XWarningWindow extends XWindow {
SunToolkit.executeOnEventHandlerThread(target, SunToolkit.executeOnEventHandlerThread(target,
new Runnable() { new Runnable() {
public void run() { public void run() {
Graphics g = getGraphics(); final Graphics g = getGraphics();
if (g != null) {
try { try {
paint(g, x, y, width, height); paint(g, x, y, width, height);
} finally { } finally {
g.dispose(); g.dispose();
} }
} }
}
}); });
} }

View File

@ -502,9 +502,8 @@ public class XWindow extends XBaseWindow implements X11ComponentPeer {
public boolean isEmbedded() { public boolean isEmbedded() {
return embedded; return embedded;
} }
public void repaint(int x,int y, int width, int height) { public void repaint(int x,int y, int width, int height) {
if (!isVisible()) { if (!isVisible() || getWidth() == 0 || getHeight() == 0) {
return; return;
} }
Graphics g = getGraphics(); Graphics g = getGraphics();
@ -517,12 +516,11 @@ public class XWindow extends XBaseWindow implements X11ComponentPeer {
} }
} }
} }
void repaint() {
public void repaint() { if (!isVisible() || getWidth() == 0 || getHeight() == 0) {
if (!isVisible()) {
return; return;
} }
Graphics g = getGraphics(); final Graphics g = getGraphics();
if (g != null) { if (g != null) {
try { try {
paint(g); paint(g);
@ -531,10 +529,13 @@ public class XWindow extends XBaseWindow implements X11ComponentPeer {
} }
} }
} }
public void paint(final Graphics g) {
void paint(Graphics g) { // paint peer
paintPeer(g);
} }
void paintPeer(final Graphics g) {
}
//used by Peers to avoid flickering withing paint() //used by Peers to avoid flickering withing paint()
protected void flush(){ protected void flush(){
XToolkit.awtLock(); XToolkit.awtLock();

View File

@ -183,7 +183,9 @@ class WMenuItemPeer extends WObjectPeer implements MenuItemPeer {
*/ */
private static native void initIDs(); private static native void initIDs();
// Needed for MenuComponentPeer. private native void _setFont(Font f);
public void setFont(Font f) {
public void setFont(final Font f) {
_setFont(f);
} }
} }

View File

@ -27,6 +27,8 @@ package sun.awt.windows;
import java.awt.*; import java.awt.*;
import java.awt.event.AdjustmentEvent; import java.awt.event.AdjustmentEvent;
import java.awt.peer.ScrollPanePeer; import java.awt.peer.ScrollPanePeer;
import sun.awt.AWTAccessor;
import sun.awt.PeerEvent; import sun.awt.PeerEvent;
import sun.util.logging.PlatformLogger; import sun.util.logging.PlatformLogger;
@ -169,8 +171,6 @@ class WScrollPanePeer extends WPanelPeer implements ScrollPanePeer {
} }
} }
native void setTypedValue(ScrollPaneAdjustable adjustable, int newpos, int type);
/* /*
* Runnable for the ScrollEvent that performs the adjustment. * Runnable for the ScrollEvent that performs the adjustment.
*/ */
@ -247,8 +247,9 @@ class WScrollPanePeer extends WPanelPeer implements ScrollPanePeer {
// Fix for 4075484 - consider type information when creating AdjustmentEvent // Fix for 4075484 - consider type information when creating AdjustmentEvent
// We can't just call adj.setValue() because it creates AdjustmentEvent with type=TRACK // We can't just call adj.setValue() because it creates AdjustmentEvent with type=TRACK
// Instead, we call private method setTypedValue of ScrollPaneAdjustable. // Instead, we call private method setTypedValue of ScrollPaneAdjustable.
// Because ScrollPaneAdjustable is in another package we should call it through native code. AWTAccessor.getScrollPaneAdjustableAccessor().setTypedValue(adj,
setTypedValue(adj, newpos, type); newpos,
type);
// Paint the exposed area right away. To do this - find // Paint the exposed area right away. To do this - find
// the heavyweight ancestor of the scroll child. // the heavyweight ancestor of the scroll child.

View File

@ -396,12 +396,6 @@ LRESULT CALLBACK AwtChoice::ListWindowProc(HWND hwnd, UINT message,
DASSERT(::IsWindow(hwnd)); DASSERT(::IsWindow(hwnd));
// This branch is required for the proper work of AwtComponent::GetComponent() method
// while hovering drop-down list
if (message == WmAwtIsComponent) {
return (LRESULT)TRUE;
}
switch (message) { switch (message) {
case WM_LBUTTONDOWN: { case WM_LBUTTONDOWN: {
DWORD curPos = ::GetMessagePos(); DWORD curPos = ::GetMessagePos();

View File

@ -364,6 +364,7 @@ AwtComponent* AwtComponent::GetComponentImpl(HWND hWnd) {
AwtComponent *component = AwtComponent *component =
(AwtComponent *)::GetWindowLongPtr(hWnd, GWLP_USERDATA); (AwtComponent *)::GetWindowLongPtr(hWnd, GWLP_USERDATA);
DASSERT(!component || !IsBadReadPtr(component, sizeof(AwtComponent)) ); DASSERT(!component || !IsBadReadPtr(component, sizeof(AwtComponent)) );
DASSERT(!component || component->GetHWnd() == hWnd );
return component; return component;
} }

View File

@ -119,6 +119,41 @@ done:
return menu; return menu;
} }
void AwtMenu::UpdateLayout()
{
UpdateLayout(GetHMenu());
RedrawMenuBar();
}
void AwtMenu::UpdateLayout(const HMENU hmenu)
{
const int nMenuItemCount = ::GetMenuItemCount(hmenu);
static MENUITEMINFO mii;
for (int idx = 0; idx < nMenuItemCount; ++idx) {
memset(&mii, 0, sizeof(mii));
mii.cbSize = sizeof(mii);
mii.fMask = MIIM_CHECKMARKS | MIIM_DATA | MIIM_ID
| MIIM_STATE | MIIM_SUBMENU | MIIM_TYPE;
if (::GetMenuItemInfo(hmenu, idx, TRUE, &mii)) {
VERIFY(::RemoveMenu(hmenu, idx, MF_BYPOSITION));
VERIFY(::InsertMenuItem(hmenu, idx, TRUE, &mii));
if (mii.hSubMenu != NULL) {
UpdateLayout(mii.hSubMenu);
}
}
}
}
void AwtMenu::UpdateContainerLayout()
{
AwtMenu* menu = GetMenuContainer();
if (menu != NULL) {
menu->UpdateLayout();
} else {
UpdateLayout();
}
}
AwtMenuBar* AwtMenu::GetMenuBar() { AwtMenuBar* AwtMenu::GetMenuBar() {
return (GetMenuContainer() == NULL) ? NULL : GetMenuContainer()->GetMenuBar(); return (GetMenuContainer() == NULL) ? NULL : GetMenuContainer()->GetMenuBar();
} }

View File

@ -72,6 +72,8 @@ public:
virtual AwtMenuBar* GetMenuBar(); virtual AwtMenuBar* GetMenuBar();
void AddSeparator(); void AddSeparator();
virtual void UpdateContainerLayout();
void UpdateLayout();
virtual void AddItem(AwtMenuItem *item); virtual void AddItem(AwtMenuItem *item);
virtual void DeleteItem(UINT index); virtual void DeleteItem(UINT index);
@ -103,6 +105,7 @@ protected:
virtual void RemoveCmdID() { /* do nothing */ } virtual void RemoveCmdID() { /* do nothing */ }
private: private:
void UpdateLayout(const HMENU hmenu);
HMENU m_hMenu; HMENU m_hMenu;
}; };

View File

@ -198,7 +198,15 @@ void AwtMenuBar::DeleteItem(UINT index)
if (hOwnerWnd != NULL) { if (hOwnerWnd != NULL) {
VERIFY(::InvalidateRect(hOwnerWnd,0,TRUE)); VERIFY(::InvalidateRect(hOwnerWnd,0,TRUE));
} }
::DrawMenuBar(GetOwnerHWnd()); RedrawMenuBar();
}
/**
* If the menu changes after the system has created the window,
* this function must be called to draw the changed menu bar.
*/
void AwtMenuBar::RedrawMenuBar() {
VERIFY(::DrawMenuBar(GetOwnerHWnd()));
} }
LRESULT AwtMenuBar::WinThreadExecProc(ExecuteArgs * args) LRESULT AwtMenuBar::WinThreadExecProc(ExecuteArgs * args)
@ -232,7 +240,7 @@ void AwtMenuBar::_AddMenu(void *param)
if (::IsWindow(m->GetOwnerHWnd())) if (::IsWindow(m->GetOwnerHWnd()))
{ {
/* The menu was already created and added during peer creation -- redraw */ /* The menu was already created and added during peer creation -- redraw */
::DrawMenuBar(m->GetOwnerHWnd()); m->RedrawMenuBar();
} }
ret: ret:
env->DeleteGlobalRef(self); env->DeleteGlobalRef(self);

View File

@ -65,6 +65,7 @@ public:
INLINE AwtFrame* GetFrame() { return m_frame; } INLINE AwtFrame* GetFrame() { return m_frame; }
virtual HWND GetOwnerHWnd(); virtual HWND GetOwnerHWnd();
virtual void RedrawMenuBar();
AwtMenuItem* GetItem(jobject target, long index); AwtMenuItem* GetItem(jobject target, long index);
int CountItem(jobject menuBar); int CountItem(jobject menuBar);

View File

@ -626,7 +626,7 @@ void AwtMenuItem::SetLabel(LPCTSTR sb)
mii.dwTypeData = (LPTSTR)(*sb); mii.dwTypeData = (LPTSTR)(*sb);
// find index by menu item id // find index by menu item id
int nMenuItemCount = ::GetMenuItemCount(hMenu);; int nMenuItemCount = ::GetMenuItemCount(hMenu);
int idx; int idx;
for (idx = 0; (idx < nMenuItemCount); idx++) { for (idx = 0; (idx < nMenuItemCount); idx++) {
memset(&mii1, 0, sizeof(MENUITEMINFO)); memset(&mii1, 0, sizeof(MENUITEMINFO));
@ -639,10 +639,7 @@ void AwtMenuItem::SetLabel(LPCTSTR sb)
::RemoveMenu(hMenu, idx, MF_BYPOSITION); ::RemoveMenu(hMenu, idx, MF_BYPOSITION);
::InsertMenuItem(hMenu, idx, TRUE, &mii); ::InsertMenuItem(hMenu, idx, TRUE, &mii);
// Redraw menu bar if it was affected. RedrawMenuBar();
if (menu->GetMenuBar() == menu) {
::DrawMenuBar(menu->GetOwnerHWnd());
}
} }
void AwtMenuItem::Enable(BOOL isEnabled) void AwtMenuItem::Enable(BOOL isEnabled)
@ -658,10 +655,7 @@ void AwtMenuItem::Enable(BOOL isEnabled)
MF_BYCOMMAND | (isEnabled ? MF_ENABLED : MF_GRAYED)) MF_BYCOMMAND | (isEnabled ? MF_ENABLED : MF_GRAYED))
!= 0xFFFFFFFF); != 0xFFFFFFFF);
// Redraw menu bar if it was affected. RedrawMenuBar();
if (menu->GetMenuBar() == menu) {
::DrawMenuBar(menu->GetOwnerHWnd());
}
} }
void AwtMenuItem::SetState(BOOL isChecked) void AwtMenuItem::SetState(BOOL isChecked)
@ -676,23 +670,31 @@ void AwtMenuItem::SetState(BOOL isChecked)
MF_BYCOMMAND | (isChecked ? MF_CHECKED : MF_UNCHECKED)) MF_BYCOMMAND | (isChecked ? MF_CHECKED : MF_UNCHECKED))
!= 0xFFFFFFFF); != 0xFFFFFFFF);
// Redraw menu bar if it was affected. RedrawMenuBar();
if (menu->GetMenuBar() == menu) { }
::DrawMenuBar(menu->GetOwnerHWnd());
/**
* If the menu changes after the system has created the window,
* this function must be called to draw the changed menu bar.
*/
void AwtMenuItem::RedrawMenuBar() {
AwtMenu* menu = GetMenuContainer();
if (menu != NULL && menu->GetMenuBar() == menu){
menu->RedrawMenuBar();
}
}
void AwtMenuItem::UpdateContainerLayout() {
AwtMenu* menu = GetMenuContainer();
if (menu != NULL) {
DASSERT(menu != NULL && GetID() >= 0);
menu->UpdateLayout();
} }
} }
LRESULT AwtMenuItem::WinThreadExecProc(ExecuteArgs * args) LRESULT AwtMenuItem::WinThreadExecProc(ExecuteArgs * args)
{ {
switch( args->cmdId ) { switch( args->cmdId ) {
case MENUITEM_SETLABEL:
{
LPCTSTR sb = (LPCTSTR)args->param1;
DASSERT(!IsBadStringPtr(sb, 20));
this->SetLabel(sb);
}
break;
case MENUITEM_ENABLE: case MENUITEM_ENABLE:
{ {
BOOL isEnabled = (BOOL)args->param1; BOOL isEnabled = (BOOL)args->param1;
@ -714,8 +716,8 @@ LRESULT AwtMenuItem::WinThreadExecProc(ExecuteArgs * args)
return 0L; return 0L;
} }
void AwtMenuItem::_SetLabel(void *param) void AwtMenuItem::_SetLabel(void *param) {
{ if (AwtToolkit::IsMainThread()) {
JNIEnv *env = (JNIEnv *)JNU_GetEnv(jvm, JNI_VERSION_1_2); JNIEnv *env = (JNIEnv *)JNU_GetEnv(jvm, JNI_VERSION_1_2);
SetLabelStruct *sls = (SetLabelStruct *)param; SetLabelStruct *sls = (SetLabelStruct *)param;
@ -752,10 +754,8 @@ void AwtMenuItem::_SetLabel(void *param)
} }
else else
{ {
ExecuteArgs args; DASSERT(!IsBadStringPtr(labelPtr, 20));
args.cmdId = MENUITEM_SETLABEL; m->SetLabel(labelPtr);
args.param1 = (LPARAM)labelPtr;
m->WinThreadExecProc(&args);
if (empty != NULL) if (empty != NULL)
{ {
JNU_ReleaseStringPlatformChars(env, empty, labelPtr); JNU_ReleaseStringPlatformChars(env, empty, labelPtr);
@ -784,6 +784,31 @@ ret:
{ {
throw std::bad_alloc(); throw std::bad_alloc();
} }
} else {
AwtToolkit::GetInstance().InvokeFunction(AwtMenuItem::_SetLabel, param);
}
}
void AwtMenuItem::_UpdateLayout(void *param)
{
if (AwtToolkit::IsMainThread()) {
JNIEnv *env = (JNIEnv *)JNU_GetEnv(jvm, JNI_VERSION_1_2);
jobject self = (jobject)param;
AwtMenuItem *m = NULL;
PDATA pData;
JNI_CHECK_PEER_GOTO(self, ret);
m = (AwtMenuItem *)pData;
m->UpdateContainerLayout();
ret:
env->DeleteGlobalRef(self);
} else {
AwtToolkit::GetInstance().InvokeFunction(AwtMenuItem::_UpdateLayout, param);
}
} }
BOOL AwtMenuItem::IsSeparator() { BOOL AwtMenuItem::IsSeparator() {
@ -883,8 +908,8 @@ extern "C" {
/* /*
* Class: sun_awt_windows_WMenuItemPeer * Class: sun_awt_windows_WMenuItemPeer
* Method: _setLabel * Method: initIDs
* Signature: (Ljava/lang/String;)V * Signature: ()V
*/ */
JNIEXPORT void JNICALL JNIEXPORT void JNICALL
Java_sun_awt_windows_WMenuItemPeer_initIDs(JNIEnv *env, jclass cls) Java_sun_awt_windows_WMenuItemPeer_initIDs(JNIEnv *env, jclass cls)
@ -925,6 +950,26 @@ Java_sun_awt_windows_WMenuItemPeer__1setLabel(JNIEnv *env, jobject self,
CATCH_BAD_ALLOC; CATCH_BAD_ALLOC;
} }
/*
* Class: sun_awt_windows_WMenuItemPeer
* Method: _setFont
* Signature: (Ljava/awt/Font;)V
*/
JNIEXPORT void JNICALL
Java_sun_awt_windows_WMenuItemPeer__1setFont(JNIEnv *env, jobject self, jobject)
{
TRY;
jobject selfGlobalRef = env->NewGlobalRef(self);
// Current implementation of AwtMenuItem get font attribute from the peer
// directly, so we ignore it here, but update current menu layout.
AwtToolkit::GetInstance().SyncCall(AwtMenuItem::_UpdateLayout, selfGlobalRef);
// selfGlobalRef is deleted in _UpdateLayout
CATCH_BAD_ALLOC;
}
/* /*
* Class: sun_awt_windows_WMenuItemPeer * Class: sun_awt_windows_WMenuItemPeer
* Method: create * Method: create

View File

@ -48,7 +48,6 @@ class AwtMenuItem : public AwtObject {
public: public:
// id's for methods executed on toolkit thread // id's for methods executed on toolkit thread
enum { enum {
MENUITEM_SETLABEL,
MENUITEM_ENABLE, MENUITEM_ENABLE,
MENUITEM_SETSTATE, MENUITEM_SETSTATE,
MENUITEM_LAST MENUITEM_LAST
@ -78,7 +77,6 @@ public:
virtual LPCTSTR GetClassName(); virtual LPCTSTR GetClassName();
void AwtMenuItem::LinkObjects(jobject peer);
static AwtMenuItem* Create(jobject self, jobject menu); static AwtMenuItem* Create(jobject self, jobject menu);
INLINE AwtMenu* GetMenuContainer() { return m_menuContainer; } INLINE AwtMenu* GetMenuContainer() { return m_menuContainer; }
@ -148,6 +146,8 @@ public:
void SetLabel(LPCTSTR sb); void SetLabel(LPCTSTR sb);
virtual void Enable(BOOL isEnabled); virtual void Enable(BOOL isEnabled);
virtual void UpdateContainerLayout();
virtual void RedrawMenuBar();
void SetState(BOOL isChecked); void SetState(BOOL isChecked);
/* /*
@ -163,6 +163,7 @@ public:
// invoked on Toolkit thread // invoked on Toolkit thread
static void _SetLabel(void *param); static void _SetLabel(void *param);
static void _UpdateLayout(void *param);
protected: protected:
AwtMenu* m_menuContainer; /* The menu object containing this item */ AwtMenu* m_menuContainer; /* The menu object containing this item */

View File

@ -4137,7 +4137,7 @@ Java_sun_awt_windows_WPrinterJob_initIDs(JNIEnv *env, jclass cls)
AwtPrintDialog::controlID = AwtPrintDialog::controlID =
env->GetFieldID(cls, "pjob", "Ljava/awt/print/PrinterJob;"); env->GetFieldID(cls, "pjob", "Ljava/awt/print/PrinterJob;");
jclass printDialogPeerClass = env->FindClass("Lsun/awt/windows/WPrintDialogPeer;"); jclass printDialogPeerClass = env->FindClass("sun/awt/windows/WPrintDialogPeer");
AwtPrintDialog::setHWndMID = AwtPrintDialog::setHWndMID =
env->GetMethodID(printDialogPeerClass, "setHWnd", "(J)V"); env->GetMethodID(printDialogPeerClass, "setHWnd", "(J)V");

View File

@ -808,29 +808,4 @@ Java_sun_awt_windows_WScrollPanePeer_setSpans(JNIEnv *env, jobject self,
CATCH_BAD_ALLOC; CATCH_BAD_ALLOC;
} }
/*
* Class: sun_awt_windows_WScrollPanePeer
* Method: setTypedValue
* Signature: (Ljava/awt/ScrollPaneAdjustable;II)V
*/
JNIEXPORT void JNICALL
Java_sun_awt_windows_WScrollPanePeer_setTypedValue(JNIEnv *env, jobject peer, jobject adjustable, jint value, jint type)
{
// need this global ref to make the class unloadable (see 6500204)
static jclass scrollPaneAdj;
static jmethodID setTypedValueMID = 0;
if (setTypedValueMID == NULL) {
jclass clazz = env->FindClass("java/awt/ScrollPaneAdjustable");
if (safe_ExceptionOccurred(env)) {
env->ExceptionDescribe();
env->ExceptionClear();
}
setTypedValueMID = env->GetMethodID(clazz, "setTypedValue", "(II)V");
scrollPaneAdj = (jclass) env->NewGlobalRef(clazz);
env->DeleteLocalRef(clazz);
DASSERT(setTypedValueMID != NULL);
}
env->CallVoidMethod(adjustable, setTypedValueMID, value, type);
}
} /* extern "C" */ } /* extern "C" */

View File

@ -1444,7 +1444,6 @@ BOOL AwtToolkit::PreProcessMouseMsg(AwtComponent* p, MSG& msg)
AwtComponent* mouseComp = AwtComponent* mouseComp =
AwtComponent::GetComponent(hWndFromPoint); AwtComponent::GetComponent(hWndFromPoint);
// Need extra copies for non-client area issues // Need extra copies for non-client area issues
AwtComponent* mouseWheelComp = mouseComp;
HWND hWndForWheel = hWndFromPoint; HWND hWndForWheel = hWndFromPoint;
// If the point under the mouse isn't in the client area, // If the point under the mouse isn't in the client area,
@ -1510,8 +1509,8 @@ BOOL AwtToolkit::PreProcessMouseMsg(AwtComponent* p, MSG& msg)
*/ */
if (msg.message == WM_MOUSEWHEEL && if (msg.message == WM_MOUSEWHEEL &&
mouseWheelComp != NULL) { //i.e. mouse is over client area for this AwtToolkit::MainThread() == ::GetWindowThreadProcessId(hWndForWheel, NULL)) {
//window //i.e. mouse is over client area for this window
msg.hwnd = hWndForWheel; msg.hwnd = hWndForWheel;
} }

View File

@ -0,0 +1,149 @@
/*
* Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
* 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 7050935
@summary closed/java/awt/Choice/WheelEventsConsumed/WheelEventsConsumed.html fails on win32
@author Oleg Pekhovskiy: area=awt-choice
@run main ChoiceMouseWheelTest
*/
import test.java.awt.regtesthelpers.Util;
import java.awt.*;
import java.awt.event.*;
public class ChoiceMouseWheelTest extends Frame {
private volatile boolean itemChanged = false;
private volatile boolean wheelMoved = false;
private volatile boolean frameExited = false;
public static void main(String[] args) {
new ChoiceMouseWheelTest();
}
ChoiceMouseWheelTest() {
super("ChoiceMouseWheelTest");
setLayout(new FlowLayout());
Choice choice = new Choice();
addWindowListener(new WindowAdapter() {
@Override
public void windowClosing(WindowEvent e) {
System.exit(0);
}
});
for(Integer i = 0; i < 50; i++) {
choice.add(i.toString());
}
choice.addItemListener(new ItemListener() {
public void itemStateChanged(ItemEvent e) {
itemChanged = true;
}
});
choice.addMouseWheelListener(new MouseWheelListener() {
public void mouseWheelMoved(MouseWheelEvent e) {
wheelMoved = true;
}
});
addMouseListener(new MouseAdapter() {
@Override
public void mouseExited(MouseEvent e) {
frameExited = true;
}
});
add(choice);
setSize(200, 300);
setVisible(true);
toFront();
try {
Robot robot = new Robot();
robot.setAutoDelay(20);
Util.waitForIdle(robot);
Point pt = choice.getLocationOnScreen();
Dimension size = choice.getSize();
int x = pt.x + size.width / 3;
robot.mouseMove(x, pt.y + size.height / 2);
// Test mouse wheel over the choice
String name = Toolkit.getDefaultToolkit().getClass().getName();
if(!name.equals("sun.awt.X11.XToolkit")) { // mouse wheel doesn't work for the choice on X11, so skip it
robot.mouseWheel(1);
Util.waitForIdle(robot);
if(!wheelMoved || !itemChanged) {
throw new RuntimeException("Mouse Wheel over the choice failed!");
}
}
// Test mouse wheel over the drop-down list
robot.mousePress(InputEvent.BUTTON1_DOWN_MASK);
Util.waitForIdle(robot);
robot.mouseRelease(InputEvent.BUTTON1_DOWN_MASK);
Util.waitForIdle(robot);
int y = getLocationOnScreen().y + getSize().height;
while(!frameExited && y >= 0) { // move to the bottom of drop-down list
robot.mouseMove(x, --y);
Util.waitForIdle(robot);
}
if(x < 0) {
throw new RuntimeException("Could not enter drop-down list!");
}
y -= choice.getHeight() / 2;
robot.mouseMove(x, y); // move to the last visible item in the drop-down list
Util.waitForIdle(robot);
robot.mouseWheel(choice.getItemCount()); // wheel to the last item
Util.waitForIdle(robot);
// click the last item
itemChanged = false;
robot.mousePress(InputEvent.BUTTON1_DOWN_MASK);
Util.waitForIdle(robot);
robot.mouseRelease(InputEvent.BUTTON1_DOWN_MASK);
Util.waitForIdle(robot);
if(!itemChanged || choice.getSelectedIndex() != choice.getItemCount() - 1) {
throw new RuntimeException("Mouse Wheel scroll position error!");
}
System.exit(0);
} catch (AWTException e) {
throw new RuntimeException("AWTException occurred - problem creating robot!");
}
}
}

View File

@ -0,0 +1,301 @@
/*
* Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
import sun.awt.SunToolkit;
import java.awt.Button;
import java.awt.Canvas;
import java.awt.Checkbox;
import java.awt.Choice;
import java.awt.Component;
import java.awt.Container;
import java.awt.Dimension;
import java.awt.Frame;
import java.awt.Graphics;
import java.awt.GridLayout;
import java.awt.Label;
import java.awt.List;
import java.awt.Panel;
import java.awt.ScrollPane;
import java.awt.Scrollbar;
import java.awt.TextArea;
import java.awt.TextField;
import java.awt.Toolkit;
import java.awt.image.BufferedImage;
/*
@test
@bug 6596915
@summary Test Component.paintAll() method
@author sergey.bylokhov@oracle.com: area=awt.component
@run main PaintAll
*/
public class PaintAll {
private static volatile boolean lwPainted;
private static volatile boolean buttonPainted;
private static volatile boolean canvasPainted;
private static volatile boolean checkboxPainted;
private static volatile boolean choicePainted;
private static volatile boolean containerPainted;
private static volatile boolean framePainted;
private static volatile boolean labelPainted;
private static volatile boolean listPainted;
private static volatile boolean panelPainted;
private static volatile boolean scrollbarPainted;
private static volatile boolean scrollPanePainted;
private static volatile boolean textAreaPainted;
private static volatile boolean textFieldPainted;
private static final Button buttonStub = new Button() {
@Override
public void paint(final Graphics g) {
buttonPainted = true;
}
};
private static final Canvas canvasStub = new Canvas() {
@Override
public void paint(final Graphics g) {
canvasPainted = true;
}
};
private static final Checkbox checkboxStub = new Checkbox() {
@Override
public void paint(final Graphics g) {
checkboxPainted = true;
}
};
private static final Choice choiceStub = new Choice() {
@Override
public void paint(final Graphics g) {
choicePainted = true;
}
};
private static final Component lwComponentStub = new Component() {
@Override
public void paint(final Graphics g) {
lwPainted = true;
}
};
private static final Container containerStub = new Container() {
@Override
public void paint(final Graphics g) {
containerPainted = true;
}
};
private static final Frame frame = new Frame() {
@Override
public void paint(final Graphics g) {
super.paint(g);
framePainted = true;
}
};
private static final Label labelStub = new Label() {
@Override
public void paint(final Graphics g) {
labelPainted = true;
}
};
private static final List listStub = new List() {
@Override
public void paint(final Graphics g) {
listPainted = true;
}
};
private static final Panel panelStub = new Panel() {
@Override
public void paint(final Graphics g) {
panelPainted = true;
}
};
private static final Scrollbar scrollbarStub = new Scrollbar() {
@Override
public void paint(final Graphics g) {
scrollbarPainted = true;
}
};
private static final ScrollPane scrollPaneStub = new ScrollPane() {
@Override
public void paint(final Graphics g) {
scrollPanePainted = true;
}
};
private static final TextArea textAreaStub = new TextArea() {
@Override
public void paint(final Graphics g) {
textAreaPainted = true;
}
};
private static final TextField textFieldStub = new TextField() {
@Override
public void paint(final Graphics g) {
textFieldPainted = true;
}
};
public static void main(final String[] args) throws Exception {
//Frame initialisation
final BufferedImage graphicsProducer =
new BufferedImage(BufferedImage.TYPE_INT_ARGB, 1, 1);
final Graphics g = graphicsProducer.getGraphics();
frame.setLayout(new GridLayout());
frame.add(buttonStub);
frame.add(canvasStub);
frame.add(checkboxStub);
frame.add(choiceStub);
frame.add(lwComponentStub);
frame.add(containerStub);
frame.add(labelStub);
frame.add(listStub);
frame.add(panelStub);
frame.add(scrollbarStub);
frame.add(scrollPaneStub);
frame.add(textAreaStub);
frame.add(textFieldStub);
frame.setSize(new Dimension(500, 500));
frame.setLocationRelativeTo(null);
frame.setVisible(true);
sleep();
//Check results.
validation();
//Reset all flags to 'false'.
initPaintedFlags();
//Tested method.
frame.paintAll(g);
sleep();
//Check results.
validation();
cleanup();
}
private static void initPaintedFlags() {
lwPainted = false;
buttonPainted = false;
canvasPainted = false;
checkboxPainted = false;
choicePainted = false;
containerPainted = false;
framePainted = false;
labelPainted = false;
listPainted = false;
panelPainted = false;
scrollbarPainted = false;
scrollPanePainted = false;
textAreaPainted = false;
textFieldPainted = false;
}
private static void validation() {
if (!buttonPainted) {
fail("Paint is not called a Button "
+ "when paintAll() invoked on a parent");
}
if (!canvasPainted) {
fail("Paint is not called a Canvas "
+ "when paintAll() invoked on a parent");
}
if (!checkboxPainted) {
fail("Paint is not called a Checkbox "
+ "when paintAll() invoked on a parent");
}
if (!choicePainted) {
fail("Paint is not called a Choice "
+ "when paintAll() invoked on a parent");
}
if (!lwPainted) {
fail("Paint is not called on a lightweight"
+ " subcomponent when paintAll() invoked on a parent");
}
if (!containerPainted) {
fail("Paint is not called on a Container"
+ " subcomponent when paintAll() invoked on a parent");
}
if (!labelPainted) {
fail("Paint is not called on a Label"
+ " subcomponent when paintAll() invoked on a parent");
}
if (!listPainted) {
fail("Paint is not called on a List"
+ " subcomponent when paintAll() invoked on a parent");
}
if (!panelPainted) {
fail("Paint is not called on a Panel"
+ " subcomponent when paintAll() invoked on a parent");
}
if (!scrollbarPainted) {
fail("Paint is not called on a Scrollbar"
+ " subcomponent when paintAll() invoked on a parent");
}
if (!scrollPanePainted) {
fail("Paint is not called on a ScrollPane"
+ " subcomponent when paintAll() invoked on a parent");
}
if (!textAreaPainted) {
fail("Paint is not called on a TextArea"
+ " subcomponent when paintAll() invoked on a parent");
}
if (!textFieldPainted) {
fail("Paint is not called on a TextField"
+ " subcomponent when paintAll() invoked on a parent");
}
if (!framePainted) {
fail("Paint is not called on a Frame when paintAll()");
}
}
private static void sleep() {
((SunToolkit) Toolkit.getDefaultToolkit()).realSync();
try {
Thread.sleep(500L);
} catch (InterruptedException ignored) {
}
}
private static void fail(final String message) {
cleanup();
throw new RuntimeException(message);
}
private static void cleanup() {
frame.dispose();
}
}

View File

@ -0,0 +1,92 @@
/*
* Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
* 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 7042148
* @summary verify that Bidi.baseIsLeftToRight() returns the correct value even if an incorrect position is set in the given AttributedCharacterIterator.
*/
import java.awt.font.*;
import java.text.*;
import java.util.*;
public class Bug7042148 {
private static boolean err = false;
public static void main(String[] args) {
testDirection();
if (err) {
throw new RuntimeException("Failed");
} else {
System.out.println("Passed.");
}
}
private static void testDirection() {
Map attrLTR = new HashMap();
attrLTR.put(TextAttribute.RUN_DIRECTION,
TextAttribute.RUN_DIRECTION_LTR);
Map attrRTL = new HashMap();
attrRTL.put(TextAttribute.RUN_DIRECTION,
TextAttribute.RUN_DIRECTION_RTL);
String str1 = "A\u05e0";
String str2 = "\u05e0B";
test(str1, attrLTR, Bidi.DIRECTION_LEFT_TO_RIGHT);
test(str1, attrRTL, Bidi.DIRECTION_RIGHT_TO_LEFT);
test(str2, attrLTR, Bidi.DIRECTION_LEFT_TO_RIGHT);
test(str2, attrRTL, Bidi.DIRECTION_RIGHT_TO_LEFT);
}
private static void test(String text, Map attr, int dirFlag) {
boolean expected = (dirFlag == Bidi.DIRECTION_LEFT_TO_RIGHT);
Bidi bidi = new Bidi(text, dirFlag);
boolean got = bidi.baseIsLeftToRight();
if (got != expected) {
err = true;
System.err.println("wrong Bidi(String, int).baseIsLeftToRight() value: " +
"\n\ttext=" + text +
"\n\tExpected=" + expected +
"\n\tGot=" + got);
}
AttributedString as = new AttributedString(text, attr);
AttributedCharacterIterator itr = as.getIterator();
itr.last();
itr.next();
bidi = new Bidi(itr);
got = bidi.baseIsLeftToRight();
if (got != expected) {
err = true;
System.err.println("Wrong Bidi(AttributedCharacterIterator).baseIsLeftToRight() value: " +
"\n\ttext=" + text +
"\n\tExpected=" + expected +
"\n\tGot=" + got);
}
}
}

View File

@ -0,0 +1,72 @@
/*
* Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
* 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 7051769
* @summary verify that Bidi.toString() returns the corect result.
*/
import java.awt.font.*;
import java.text.*;
import java.util.*;
public class Bug7051769 {
private static boolean err = false;
public static void main(String[] args) {
testNumericShaping();
if (err) {
throw new RuntimeException("Failed");
} else {
System.out.println("Passed.");
}
}
private static void testNumericShaping() {
Map attrNS = new HashMap();
attrNS.put(TextAttribute.NUMERIC_SHAPING,
NumericShaper.getContextualShaper(NumericShaper.ARABIC));
attrNS.put(TextAttribute.RUN_DIRECTION,
TextAttribute.RUN_DIRECTION_RTL);
String text = "\u0623\u0643\u062a\u0648\u0628\u0631 10";
String expected = "sun.text.bidi.BidiBase[dir: 2 baselevel: 1 length: 9 runs: [1 1 1 1 1 1 1 2 2] text: [0x623 0x643 0x62a 0x648 0x628 0x631 0x20 0x661 0x660]]";
AttributedString as = new AttributedString(text, attrNS);
AttributedCharacterIterator itr = as.getIterator();
itr.last();
itr.next();
Bidi bidi = new Bidi(itr);
String got = bidi.toString();
if (!got.equals(expected)) {
err = true;
System.err.println("Wrong toString() output: " +
"\n\tExpected=" + expected +
"\n\tGot=" + got);
}
}
}