mirror of git://gcc.gnu.org/git/gcc.git
				
				
				
			
		
			
				
	
	
		
			550 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			Java
		
	
	
	
			
		
		
	
	
			550 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			Java
		
	
	
	
| /* TextArea.java -- A multi-line text entry widget
 | |
|    Copyright (C) 1999 Free Software Foundation, Inc.
 | |
| 
 | |
| This file is part of GNU Classpath.
 | |
| 
 | |
| GNU Classpath is free software; you can redistribute it and/or modify
 | |
| it under the terms of the GNU General Public License as published by
 | |
| the Free Software Foundation; either version 2, or (at your option)
 | |
| any later version.
 | |
| 
 | |
| GNU Classpath 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 for more details.
 | |
| 
 | |
| You should have received a copy of the GNU General Public License
 | |
| along with GNU Classpath; see the file COPYING.  If not, write to the
 | |
| Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
 | |
| 02111-1307 USA.
 | |
| 
 | |
| Linking this library statically or dynamically with other modules is
 | |
| making a combined work based on this library.  Thus, the terms and
 | |
| conditions of the GNU General Public License cover the whole
 | |
| combination.
 | |
| 
 | |
| As a special exception, the copyright holders of this library give you
 | |
| permission to link this library with independent modules to produce an
 | |
| executable, regardless of the license terms of these independent
 | |
| modules, and to copy and distribute the resulting executable under
 | |
| terms of your choice, provided that you also meet, for each linked
 | |
| independent module, the terms and conditions of the license of that
 | |
| module.  An independent module is a module which is not derived from
 | |
| or based on this library.  If you modify this library, you may extend
 | |
| this exception to your version of the library, but you are not
 | |
| obligated to do so.  If you do not wish to do so, delete this
 | |
| exception statement from your version. */
 | |
| 
 | |
| 
 | |
| package java.awt;
 | |
| 
 | |
| import java.awt.peer.TextAreaPeer;
 | |
| import java.awt.peer.TextComponentPeer;
 | |
| import java.awt.peer.ComponentPeer;
 | |
| 
 | |
| /**
 | |
|   * This implements a multi-line text entry widget.
 | |
|   *
 | |
|   * @author Aaron M. Renn (arenn@urbanophile.com)
 | |
|   */
 | |
| public class TextArea extends TextComponent implements java.io.Serializable
 | |
| {
 | |
| 
 | |
| /*
 | |
|  * Static Variables
 | |
|  */
 | |
| 
 | |
| /**
 | |
|   * Use both horiztonal and vertical scroll bars.
 | |
|   */
 | |
| public static final int SCROLLBARS_BOTH = 0;
 | |
| 
 | |
| /**
 | |
|   * Use vertical scroll bars only.
 | |
|   */
 | |
| public static final int SCROLLBARS_VERTICAL_ONLY = 1;
 | |
| 
 | |
| /**
 | |
|   * Use horizatonal scroll bars only.
 | |
|   */
 | |
| public static final int SCROLLBARS_HORIZONTAL_ONLY = 2;
 | |
| 
 | |
| /**
 | |
|   * Use no scrollbars.
 | |
|   */
 | |
| public static final int SCROLLBARS_NONE = 3;
 | |
| 
 | |
| // Serialization constant
 | |
| private static final long serialVersionUID = 3692302836626095722L;
 | |
| 
 | |
| /*************************************************************************/
 | |
| 
 | |
| /*
 | |
|  * Instance Variables
 | |
|  */
 | |
| 
 | |
| /**
 | |
|   * @serial The number of columns in this text area.
 | |
|   */
 | |
| private int columns;
 | |
| 
 | |
| /**
 | |
|   * @serial The number of rows in this text area.
 | |
|   */
 | |
| private int rows;
 | |
| 
 | |
| /**
 | |
|   * @serial The type of scrollbars to display, which will be one of
 | |
|   * the contstants from this class.
 | |
|   */
 | |
| private int scrollbarVisibility;
 | |
| 
 | |
| /*************************************************************************/
 | |
| 
 | |
| /*
 | |
|  * Constructors
 | |
|  */
 | |
| 
 | |
| /**
 | |
|   * Initialize a new instance of <code>TextArea</code> that is empty
 | |
|   * and is one row and one column.  Both horizontal and vertical
 | |
|   * scrollbars will be used.
 | |
|   */
 | |
| public
 | |
| TextArea()
 | |
| {
 | |
|   this("", 1, 1, SCROLLBARS_BOTH);
 | |
| }
 | |
| 
 | |
| /*************************************************************************/
 | |
| 
 | |
| /**
 | |
|   * Initializes a new instance of <code>TextArea</code> that 
 | |
|   * contains the specified string.  Both horizontal and veritcal
 | |
|   * scrollbars will be used.
 | |
|   *
 | |
|   * @param text The text to display in this text area.
 | |
|   */
 | |
| public
 | |
| TextArea(String text)
 | |
| {
 | |
|   this(text, 1, text.length(), SCROLLBARS_BOTH);
 | |
| }
 | |
| 
 | |
| /*************************************************************************/
 | |
| 
 | |
| /**
 | |
|   * Initializes a new instance of <code>TextArea</code> that is empty
 | |
|   * and has the specified number of rows and columns.  Both
 | |
|   * horizontal and vertical scrollbars will be used.
 | |
|   *
 | |
|   * @param rows The number of rows in this text area.
 | |
|   * @param columns The number of columns in this text area.
 | |
|   */
 | |
| public
 | |
| TextArea(int rows, int columns)
 | |
| {
 | |
|   this("", rows, columns, SCROLLBARS_BOTH);
 | |
| }
 | |
| 
 | |
| /*************************************************************************/
 | |
| 
 | |
| /**
 | |
|   * Initializes a new instance of <code>TextArea</code> that is the
 | |
|   * specified size and has the specified text.
 | |
|   *
 | |
|   * @param text The text to display in this text area.
 | |
|   * @param rows The number of rows in this text area.
 | |
|   * @param columns The number of columns in this text area.
 | |
|   */
 | |
| public
 | |
| TextArea(String text, int rows, int columns)
 | |
| {
 | |
|   this(text, rows, columns, SCROLLBARS_BOTH);
 | |
| }
 | |
| 
 | |
| /*************************************************************************/
 | |
| 
 | |
| /** 
 | |
|   * Initializes a new instance of <code>TextArea</code> with the
 | |
|   * specified values.  The scrollbar visibility value must be one
 | |
|   * of the constants in this class.
 | |
|   *
 | |
|   * @param text The text to display in this text area.
 | |
|   * @param rows The number of rows in this text area.
 | |
|   * @param columns The number of columns in this text area.
 | |
|   * @param scrollbarVisibility Which scrollbars to display.
 | |
|   */
 | |
| public
 | |
| TextArea(String text, int rows, int columns, int scrollbarVisibility)
 | |
| {
 | |
|   super(text);
 | |
| 
 | |
|   if ((rows < 1) || (columns < 0))
 | |
|     throw new IllegalArgumentException("Bad row or column value");
 | |
| 
 | |
|   if ((scrollbarVisibility != SCROLLBARS_BOTH) &&
 | |
|       (scrollbarVisibility != SCROLLBARS_VERTICAL_ONLY) &&
 | |
|       (scrollbarVisibility != SCROLLBARS_HORIZONTAL_ONLY) &&
 | |
|       (scrollbarVisibility != SCROLLBARS_NONE))
 | |
|     throw new IllegalArgumentException("Bad scrollbar visibility value");
 | |
| 
 | |
|   this.rows = rows;
 | |
|   this.columns = columns;
 | |
|   this.scrollbarVisibility = scrollbarVisibility;
 | |
| }
 | |
| 
 | |
| /*************************************************************************/
 | |
| 
 | |
| /*
 | |
|  * Instance Variables
 | |
|  */
 | |
| 
 | |
| /**
 | |
|   * Returns the number of columns in the field.
 | |
|   *
 | |
|   * @return The number of columns in the field.
 | |
|   */
 | |
| public int
 | |
| getColumns()
 | |
| {
 | |
|   return(columns);
 | |
| }
 | |
| 
 | |
| /*************************************************************************/
 | |
| 
 | |
| /**
 | |
|   * Sets the number of columns in this field to the specified value.
 | |
|   *
 | |
|   * @param columns The new number of columns in the field.
 | |
|   *
 | |
|   * @exception IllegalArgumentException If columns is less than zero.
 | |
|   */
 | |
| public synchronized void
 | |
| setColumns(int columns)
 | |
| {
 | |
|   if (columns < 0)
 | |
|     throw new IllegalArgumentException("Value is less than zero: " +
 | |
|                                        columns);
 | |
| 
 | |
|   this.columns = columns;
 | |
|   // FIXME: How to we communicate this to our peer?
 | |
| }
 | |
| 
 | |
| /*************************************************************************/
 | |
| 
 | |
| /**
 | |
|   * Returns the number of rows in the field.
 | |
|   *
 | |
|   * @return The number of rows in the field.
 | |
|   */
 | |
| public int
 | |
| getRows()
 | |
| {
 | |
|   return(rows);
 | |
| }
 | |
| 
 | |
| /*************************************************************************/
 | |
| 
 | |
| /**
 | |
|   * Sets the number of rows in this field to the specified value.
 | |
|   *
 | |
|   * @param rows The new number of rows in the field.
 | |
|   *
 | |
|   * @exception IllegalArgumentException If rows is less than zero.
 | |
|   */
 | |
| public synchronized void
 | |
| setRows(int rows)
 | |
| {
 | |
|   if (rows < 1)
 | |
|     throw new IllegalArgumentException("Value is less than one: " +
 | |
|                                        rows);
 | |
| 
 | |
|   this.rows = rows;
 | |
|   // FIXME: How to we communicate this to our peer?
 | |
| }
 | |
| 
 | |
| /*************************************************************************/
 | |
| 
 | |
| /**
 | |
|   * Returns the minimum size for this text field.
 | |
|   *
 | |
|   * @return The minimum size for this text field.
 | |
|   */
 | |
| public Dimension
 | |
| getMinimumSize()
 | |
| {
 | |
|   return(getMinimumSize(getRows(), getColumns()));
 | |
| }
 | |
| 
 | |
| /*************************************************************************/
 | |
| 
 | |
| /**
 | |
|   * Returns the minimum size of a text field with the specified number
 | |
|   * of rows and columns.
 | |
|   *
 | |
|   * @param rows The number of rows to get the minimum size for.
 | |
|   * @param columns The number of columns to get the minimum size for.
 | |
|   */
 | |
| public Dimension
 | |
| getMinimumSize(int rows, int columns)
 | |
| {
 | |
|   TextAreaPeer tap = (TextAreaPeer)getPeer();
 | |
|   if (tap == null)
 | |
|     return(null); // FIXME: What do we do if there is no peer?
 | |
| 
 | |
|   return(tap.getMinimumSize(rows, columns));
 | |
| }
 | |
| 
 | |
| /*************************************************************************/
 | |
| 
 | |
| /**
 | |
|   * Returns the minimum size for this text field.
 | |
|   *
 | |
|   * @return The minimum size for this text field.
 | |
|   *
 | |
|   * @deprecated This method is depcreated in favor of
 | |
|   * <code>getMinimumSize()</code>.
 | |
|   */
 | |
| public Dimension
 | |
| minimumSize()
 | |
| {
 | |
|   return(getMinimumSize(getRows(), getColumns()));
 | |
| }
 | |
| 
 | |
| /*************************************************************************/
 | |
| 
 | |
| /**
 | |
|   * Returns the minimum size of a text field with the specified number
 | |
|   * of rows and columns.
 | |
|   *
 | |
|   * @param rows The number of rows to get the minimum size for.
 | |
|   * @param columns The number of columns to get the minimum size for.
 | |
|   *
 | |
|   * @deprecated This method is deprecated in favor of 
 | |
|   * <code>getMinimumSize(int)</code>.
 | |
|   */
 | |
| public Dimension
 | |
| minimumSize(int rows, int columns)
 | |
| {
 | |
|   return(getMinimumSize(rows, columns));
 | |
| }
 | |
| 
 | |
| /*************************************************************************/
 | |
| 
 | |
| /**
 | |
|   * Returns the preferred size for this text field.
 | |
|   *
 | |
|   * @return The preferred size for this text field.
 | |
|   */
 | |
| public Dimension
 | |
| getPreferredSize()
 | |
| {
 | |
|   return(getPreferredSize(getRows(), getColumns()));
 | |
| }
 | |
| 
 | |
| /*************************************************************************/
 | |
| 
 | |
| /**
 | |
|   * Returns the preferred size of a text field with the specified number
 | |
|   * of rows and columns.
 | |
|   *
 | |
|   * @param rows The number of rows to get the preferred size for.
 | |
|   * @param columns The number of columns to get the preferred size for.
 | |
|   */
 | |
| public Dimension
 | |
| getPreferredSize(int rows, int columns)
 | |
| {
 | |
|   TextAreaPeer tap = (TextAreaPeer)getPeer();
 | |
|   if (tap == null)
 | |
|     return(null); // FIXME: What do we do if there is no peer?
 | |
| 
 | |
|   return(tap.getPreferredSize(rows, columns));
 | |
| }
 | |
| 
 | |
| /*************************************************************************/
 | |
| 
 | |
| /**
 | |
|   * Returns the preferred size for this text field.
 | |
|   *
 | |
|   * @return The preferred size for this text field.
 | |
|   *
 | |
|   * @deprecated This method is deprecated in favor of 
 | |
|   * <code>getPreferredSize()</code>.
 | |
|   */
 | |
| public Dimension
 | |
| preferredSize()
 | |
| {
 | |
|   return(getPreferredSize(getRows(), getColumns()));
 | |
| }
 | |
| 
 | |
| /*************************************************************************/
 | |
| 
 | |
| /**
 | |
|   * Returns the preferred size of a text field with the specified number
 | |
|   * of rows and columns.
 | |
|   *
 | |
|   * @param rows The number of rows to get the preferred size for.
 | |
|   * @param columns The number of columns to get the preferred size for.
 | |
|   *
 | |
|   * @deprecated This method is deprecated in favor of 
 | |
|   * <code>getPreferredSize(int)</code>.
 | |
|   */
 | |
| public Dimension
 | |
| preferredSize(int columns)
 | |
| {
 | |
|   return(getPreferredSize(rows, columns));
 | |
| }
 | |
| 
 | |
| /*************************************************************************/
 | |
| 
 | |
| /**
 | |
|   * Returns one of the constants from this class indicating which
 | |
|   * types of scrollbars this object uses, if any.
 | |
|   *
 | |
|   * @return The scrollbar type constant for this object.
 | |
|   */
 | |
| public int
 | |
| getScrollbarVisibility()
 | |
| {
 | |
|   return(scrollbarVisibility);
 | |
| }
 | |
| 
 | |
| /*************************************************************************/
 | |
| 
 | |
| /**
 | |
|   * Notify this object that it should create its native peer.
 | |
|   */
 | |
| public void
 | |
| addNotify()
 | |
| {
 | |
|   if (getPeer() != null)
 | |
|     return;
 | |
| 
 | |
|   setPeer((ComponentPeer)getToolkit().createTextArea(this));
 | |
| }
 | |
| 
 | |
| /*************************************************************************/
 | |
| 
 | |
| /**
 | |
|   * Appends the specified text to the end of the current text.
 | |
|   *
 | |
|   * @param text The text to append.
 | |
|   */
 | |
| public void
 | |
| append(String str)
 | |
| {
 | |
|   TextAreaPeer tap = (TextAreaPeer)getPeer();
 | |
|   if (tap == null) 
 | |
|     return;
 | |
| 
 | |
|   tap.insert(str, tap.getText().length());
 | |
| }
 | |
| 
 | |
| /*************************************************************************/
 | |
| 
 | |
| /**
 | |
|   * Appends the specified text to the end of the current text.
 | |
|   *
 | |
|   * @param text The text to append.
 | |
|   *
 | |
|   * @deprecated This method is deprecated in favor of 
 | |
|   * <code>append()</code>.
 | |
|   */
 | |
| public void
 | |
| appendText(String text)
 | |
| {
 | |
|   append(text);
 | |
| }
 | |
|  
 | |
| /*************************************************************************/
 | |
| 
 | |
| /**
 | |
|   * Inserts the specified text at the specified location.
 | |
|   *
 | |
|   * @param text The text to insert.
 | |
|   * @param pos The insert position.
 | |
|   */
 | |
| public void
 | |
| insert(String text, int pos)
 | |
| {
 | |
|   TextAreaPeer tap = (TextAreaPeer)getPeer();
 | |
|   if (tap == null)
 | |
|     return;
 | |
| 
 | |
|   tap.insert(text, pos);
 | |
| }
 | |
| 
 | |
| /*************************************************************************/
 | |
| 
 | |
| /**
 | |
|   * Inserts the specified text at the specified location.
 | |
|   *
 | |
|   * @param text The text to insert.
 | |
|   * @param pos The insert position.
 | |
|   *
 | |
|   * @deprecated This method is depcreated in favor of <code>insert()</code>.
 | |
|   */
 | |
| public void
 | |
| insertText(String text, int pos)
 | |
| {
 | |
|   insert(text, pos);
 | |
| }
 | |
| 
 | |
| /*************************************************************************/
 | |
| 
 | |
| /**
 | |
|   * Replaces the text bounded by the specified start and end positions
 | |
|   * with the specified text.
 | |
|   *
 | |
|   * @param text The new text for the range.
 | |
|   * @param start The start position of the replacement range.
 | |
|   * @param end The end position of the replacement range.
 | |
|   */
 | |
| public void
 | |
| replaceRange(String text, int start, int end)
 | |
| {
 | |
|   TextAreaPeer tap = (TextAreaPeer)getPeer();
 | |
|   if (tap == null)
 | |
|     return;
 | |
| 
 | |
|   tap.replaceRange(text, start, end);
 | |
| }
 | |
| 
 | |
| /*************************************************************************/
 | |
| 
 | |
| /**
 | |
|   * Replaces the text bounded by the specified start and end positions
 | |
|   * with the specified text.
 | |
|   *
 | |
|   * @param text The new text for the range.
 | |
|   * @param start The start position of the replacement range.
 | |
|   * @param end The end position of the replacement range.
 | |
|   *
 | |
|   * @deprecated This method is deprecated in favor of
 | |
|   * <code>replaceRange()</code>.
 | |
|   */
 | |
| public void
 | |
| replaceText(String text, int start, int end)
 | |
| {
 | |
|   replaceRange(text, start, end);
 | |
| }
 | |
| 
 | |
| /*************************************************************************/
 | |
| 
 | |
| /**
 | |
|   * Returns a debugging string for this text area.
 | |
|   *
 | |
|   * @return A debugging string for this text area.
 | |
|   */
 | |
| protected String
 | |
| paramString()
 | |
| {
 | |
|   return(getClass().getName() + "(rows=" + getRows() + ",columns=" +
 | |
|          getColumns() + ",scrollbars=" + getScrollbarVisibility() +
 | |
|          ")");
 | |
| }
 | |
| 
 | |
| } // class TextArea 
 | |
| 
 |