The 
JTextArea component provides a multi-line area for displaying
 and editing plain text.  The component is designed to act as a lightweight
 replacement for the heavyweight 
java.awt.TextArea component,
 which provides similar functionality using native widgets.
 
 This component has additional functionality to the AWT class.  It follows
 the same design pattern as seen in other text components, such as
 
JTextField, 
JTextPane and 
JEditorPane,
 and embodied in 
JTextComponent.  These classes separate the text
 (the model) from its appearance within the onscreen component (the view).  The
 text is held within a 
javax.swing.text.Document object, which can
 also maintain relevant style information where necessary.  As a result, it is the
 document that should be monitored for textual changes, via
 
DocumentEvents delivered to registered
 
DocumentListeners, rather than this component.
 
 Unlike 
java.awt.TextArea, 
JTextArea does not
 handle scrolling.  Instead, this functionality is delegated to a
 
JScrollPane, which can contain the text area and handle
 scrolling when required.  Likewise, the word wrapping functionality
 of the AWT component is converted to a property of this component
 and the 
rows and 
columns properties
 are used in calculating the preferred size of the scroll pane's
 view port.
JTextArea
public JTextArea()
 Creates a new JTextArea object.
JTextArea
public JTextArea(int rows,
                 int columns) Creates a new JTextArea object.
- rows- the number of rows
- columns- the number of cols
JTextArea
public JTextArea(String text,
                 int rows,
                 int columns) Creates a new JTextArea object.
- text- the initial text
- rows- the number of rows
- columns- the number of cols
JTextArea
public JTextArea(Document doc)
 Creates a new JTextArea object.
- doc- the document model to use
JTextArea
public JTextArea(Document doc,
                 String text,
                 int rows,
                 int columns) Creates a new JTextArea object.
- doc- the document model to use
- text- the initial text
- rows- the number of rows
- columns- the number of cols
append
public void append(String toAppend)
 Appends the supplied text to the current contents
 of the document model.
- toAppend- the text to append
getColumns
public int getColumns()
 Returns the current number of columns.
getLineWrap
public boolean getLineWrap()
 Checks whether line wrapping is enabled.
- trueif line wrapping is enabled,- falseotherwise
getRows
public int getRows()
 Returns the current number of rows.
getTabSize
public int getTabSize()
 Returns the number of characters used for a tab.
 This defaults to 8.
- the current number of spaces used for a tab.
getWrapStyleWord
public boolean getWrapStyleWord()
 Checks whether word style wrapping is enabled.
- trueif word style wrapping is enabled,- falseotherwise
insert
public void insert(String string,
                   int position) Inserts the supplied text at the specified position.  Nothing
 happens in the case that the model or the supplied string is null
 or of zero length.
- string- The string of text to insert.
- position- The position at which to insert the supplied text.
setColumns
public void setColumns(int columns)
 Sets the number of rows.
- columns- number of columns
setLineWrap
public void setLineWrap(boolean flag)
 Enables/disables line wrapping.
- flag-- trueto enable line wrapping,- falseotherwise
setRows
public void setRows(int rows)
 Sets the number of rows.
setTabSize
public void setTabSize(int newSize)
 Sets the number of characters used for a tab to the
 supplied value.  If a change to the tab size property
 occurs (i.e. newSize != tabSize), a property change event
 is fired.
- newSize- The new number of characters to use for a tab.
setWrapStyleWord
public void setWrapStyleWord(boolean flag)
 Enables/Disables word style wrapping.
- flag-- trueto enable word style wrapping,- falseotherwise
JTextArea.java --
   Copyright (C) 2004, 2005  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., 51 Franklin Street, Fifth Floor, Boston, MA
02110-1301 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.