Package org.mozilla.javascript.tools.debugger

Source Code of org.mozilla.javascript.tools.debugger.TreeTableModelAdapter

/*************************************************************************
*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* Copyright 2008 by Sun Microsystems, Inc.
*
* OpenOffice.org - a multi-platform office productivity suite
*
* $RCSfile: AppletExecutionContext.java,v $
*
* $Revision: 1.8 $
*
* This file is part of OpenOffice.org.
*
* OpenOffice.org is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License version 3
* only, as published by the Free Software Foundation.
*
* OpenOffice.org 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 Lesser General Public License version 3 for more details
* (a copy is included in the LICENSE file that accompanied this code).
*
* You should have received a copy of the GNU Lesser General Public License
* version 3 along with OpenOffice.org.  If not, see
* <http://www.openoffice.org/license.html>
* for a copy of the LGPLv3 License.
*
************************************************************************/

package org.mozilla.javascript.tools.debugger;

import javax.swing.JTree;
import javax.swing.SwingUtilities;
import javax.swing.table.AbstractTableModel;
import javax.swing.tree.TreePath;
import javax.swing.event.TreeExpansionEvent;
import javax.swing.event.TreeExpansionListener;
import javax.swing.event.TreeModelEvent;
import javax.swing.event.TreeModelListener;

/**
* This is a wrapper class takes a TreeTableModel and implements
* the table model interface. The implementation is trivial, with
* all of the event dispatching support provided by the superclass:
* the AbstractTableModel.
*
* @version 1.2 10/27/98
*
* @author Philip Milne
* @author Scott Violet
*/
public class TreeTableModelAdapter extends AbstractTableModel
{
    JTree tree;
    TreeTableModel treeTableModel;

    public TreeTableModelAdapter(TreeTableModel treeTableModel, JTree tree) {
        this.tree = tree;
        this.treeTableModel = treeTableModel;

  tree.addTreeExpansionListener(new TreeExpansionListener() {
      // Don't use fireTableRowsInserted() here; the selection model
      // would get updated twice.
      public void treeExpanded(TreeExpansionEvent event) { 
        fireTableDataChanged();
      }
            public void treeCollapsed(TreeExpansionEvent event) { 
        fireTableDataChanged();
      }
  });

  // Install a TreeModelListener that can update the table when
  // tree changes. We use delayedFireTableDataChanged as we can
  // not be guaranteed the tree will have finished processing
  // the event before us.
  treeTableModel.addTreeModelListener(new TreeModelListener() {
      public void treeNodesChanged(TreeModelEvent e) {
    delayedFireTableDataChanged();
      }

      public void treeNodesInserted(TreeModelEvent e) {
    delayedFireTableDataChanged();
      }

      public void treeNodesRemoved(TreeModelEvent e) {
    delayedFireTableDataChanged();
      }

      public void treeStructureChanged(TreeModelEvent e) {
    delayedFireTableDataChanged();
      }
  });
    }

    // Wrappers, implementing TableModel interface.

    public int getColumnCount() {
  return treeTableModel.getColumnCount();
    }

    public String getColumnName(int column) {
  return treeTableModel.getColumnName(column);
    }

    public Class getColumnClass(int column) {
  return treeTableModel.getColumnClass(column);
    }

    public int getRowCount() {
  return tree.getRowCount();
    }

    protected Object nodeForRow(int row) {
  TreePath treePath = tree.getPathForRow(row);
  return treePath.getLastPathComponent();        
    }

    public Object getValueAt(int row, int column) {
  return treeTableModel.getValueAt(nodeForRow(row), column);
    }

    public boolean isCellEditable(int row, int column) {
         return treeTableModel.isCellEditable(nodeForRow(row), column);
    }

    public void setValueAt(Object value, int row, int column) {
  treeTableModel.setValueAt(value, nodeForRow(row), column);
    }

    /**
     * Invokes fireTableDataChanged after all the pending events have been
     * processed. SwingUtilities.invokeLater is used to handle this.
     */
    protected void delayedFireTableDataChanged() {
  SwingUtilities.invokeLater(new Runnable() {
      public void run() {
    fireTableDataChanged();
      }
  });
    }
}
TOP

Related Classes of org.mozilla.javascript.tools.debugger.TreeTableModelAdapter

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.