home *** CD-ROM | disk | FTP | other *** search
/ Programming Languages Suite / JBuilder8.iso / Solaris / resource / jre / demo / jfc / TableExample / src / TableMap.java < prev    next >
Encoding:
Java Source  |  2002-09-06  |  3.7 KB  |  108 lines

  1. /*
  2.  * Copyright (c) 2002 Sun Microsystems, Inc. All  Rights Reserved.
  3.  * 
  4.  * Redistribution and use in source and binary forms, with or without
  5.  * modification, are permitted provided that the following conditions
  6.  * are met:
  7.  * 
  8.  * -Redistributions of source code must retain the above copyright
  9.  *  notice, this list of conditions and the following disclaimer.
  10.  * 
  11.  * -Redistribution in binary form must reproduct the above copyright
  12.  *  notice, this list of conditions and the following disclaimer in
  13.  *  the documentation and/or other materials provided with the distribution.
  14.  * 
  15.  * Neither the name of Sun Microsystems, Inc. or the names of contributors
  16.  * may be used to endorse or promote products derived from this software
  17.  * without specific prior written permission.
  18.  * 
  19.  * This software is provided "AS IS," without a warranty of any kind. ALL
  20.  * EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES, INCLUDING
  21.  * ANY IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE
  22.  * OR NON-INFRINGEMENT, ARE HEREBY EXCLUDED. SUN AND ITS LICENSORS SHALL NOT
  23.  * BE LIABLE FOR ANY DAMAGES OR LIABILITIES SUFFERED BY LICENSEE AS A RESULT
  24.  * OF OR RELATING TO USE, MODIFICATION OR DISTRIBUTION OF THE SOFTWARE OR ITS
  25.  * DERIVATIVES. IN NO EVENT WILL SUN OR ITS LICENSORS BE LIABLE FOR ANY LOST
  26.  * REVENUE, PROFIT OR DATA, OR FOR DIRECT, INDIRECT, SPECIAL, CONSEQUENTIAL,
  27.  * INCIDENTAL OR PUNITIVE DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY
  28.  * OF LIABILITY, ARISING OUT OF THE USE OF OR INABILITY TO USE SOFTWARE, EVEN
  29.  * IF SUN HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
  30.  * 
  31.  * You acknowledge that Software is not designed, licensed or intended for
  32.  * use in the design, construction, operation or maintenance of any nuclear
  33.  * facility.
  34.  */
  35.  
  36. /*
  37.  * @(#)TableMap.java    1.10 02/06/13
  38.  */
  39.  
  40. /** 
  41.  * In a chain of data manipulators some behaviour is common. TableMap
  42.  * provides most of this behavour and can be subclassed by filters
  43.  * that only need to override a handful of specific methods. TableMap 
  44.  * implements TableModel by routing all requests to its model, and
  45.  * TableModelListener by routing all events to its listeners. Inserting 
  46.  * a TableMap which has not been subclassed into a chain of table filters 
  47.  * should have no effect.
  48.  *
  49.  * @version 1.10 06/13/02
  50.  * @author Philip Milne */
  51.  
  52. import javax.swing.table.*; 
  53. import javax.swing.event.TableModelListener; 
  54. import javax.swing.event.TableModelEvent; 
  55.  
  56. public class TableMap extends AbstractTableModel implements TableModelListener
  57. {
  58.     protected TableModel model; 
  59.  
  60.     public TableModel  getModel() {
  61.         return model;
  62.     }
  63.  
  64.     public void  setModel(TableModel model) {
  65.         this.model = model; 
  66.         model.addTableModelListener(this); 
  67.     }
  68.  
  69.     // By default, Implement TableModel by forwarding all messages 
  70.     // to the model. 
  71.  
  72.     public Object getValueAt(int aRow, int aColumn) {
  73.         return model.getValueAt(aRow, aColumn); 
  74.     }
  75.     
  76.     public void setValueAt(Object aValue, int aRow, int aColumn) {
  77.         model.setValueAt(aValue, aRow, aColumn); 
  78.     }
  79.  
  80.     public int getRowCount() {
  81.         return (model == null) ? 0 : model.getRowCount(); 
  82.     }
  83.  
  84.     public int getColumnCount() {
  85.         return (model == null) ? 0 : model.getColumnCount(); 
  86.     }
  87.     
  88.     public String getColumnName(int aColumn) {
  89.         return model.getColumnName(aColumn); 
  90.     }
  91.  
  92.     public Class getColumnClass(int aColumn) {
  93.         return model.getColumnClass(aColumn); 
  94.     }
  95.     
  96.     public boolean isCellEditable(int row, int column) { 
  97.          return model.isCellEditable(row, column); 
  98.     }
  99. //
  100. // Implementation of the TableModelListener interface, 
  101. //
  102.  
  103.     // By default forward all events to all the listeners. 
  104.     public void tableChanged(TableModelEvent e) {
  105.         fireTableChanged(e);
  106.     }
  107. }
  108.