All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.snmp4j.agent.mo.DefaultMOMutableTableModel Maven / Gradle / Ivy

There is a newer version: 3.8.1
Show newest version
/*_############################################################################
  _## 
  _##  SNMP4J-Agent 3 - DefaultMOMutableTableModel.java  
  _## 
  _##  Copyright (C) 2005-2018  Frank Fock (SNMP4J.org)
  _##  
  _##  Licensed under the Apache License, Version 2.0 (the "License");
  _##  you may not use this file except in compliance with the License.
  _##  You may obtain a copy of the License at
  _##  
  _##      http://www.apache.org/licenses/LICENSE-2.0
  _##  
  _##  Unless required by applicable law or agreed to in writing, software
  _##  distributed under the License is distributed on an "AS IS" BASIS,
  _##  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  _##  See the License for the specific language governing permissions and
  _##  limitations under the License.
  _##  
  _##########################################################################*/


package org.snmp4j.agent.mo;

import org.snmp4j.smi.OID;
import org.snmp4j.smi.Variable;

import java.util.*;

public class DefaultMOMutableTableModel extends DefaultMOTableModel
        implements MOMutableTableModel {

    protected MOTableRowFactory rowFactory;
    private transient List moTableModelListeners;

    public MOTableRowFactory getRowFactory() {
        return rowFactory;
    }

    /**
     * Returns a lexicographic ordered list of the rows in the specified index range.
     *
     * @param lowerBound
     *         the lower bound index (inclusive) for the rows in the returned list.
     * @param upperBoundEx
     *         the upper bound index (exclusive) for the rows in the returned list.
     *
     * @return the possibly empty lexicographically ordered List of rows of this table model in the
     * specified index range. Modifications to the list will not affect the underlying table model, although
     * modifications to the row elements will.
     */
    public synchronized List getRows(OID lowerBound, OID upperBoundEx) {
        return new ArrayList<>(getView(lowerBound, upperBoundEx).values());
    }

    /**
     * Returns a lexicographic ordered list of the rows in the specified index range that match the supplied filter.
     *
     * @param lowerBound
     *         the lower bound index (inclusive) for the rows in the returned list.
     * @param upperBoundEx
     *         the upper bound index (exclusive) for the rows in the returned list.
     * @param filter
     *         the filter to exclude rows in the range from the returned
     *
     * @return the possibly empty lexicographically ordered List of rows of this table model in the
     * specified index range. Modifications to the list will not affect the underlying table model, although
     * modifications to the row elements will.
     */
    public synchronized List getRows(OID lowerBound, OID upperBoundEx,
                                        MOTableRowFilter filter) {
        LinkedList result = new LinkedList();
        SortedMap view = getView(lowerBound, upperBoundEx);
        for (R row : view.values()) {
            if (filter.passesFilter(row)) {
                result.add(row);
            }
        }
        return result;
    }

    private SortedMap getView(OID lowerBound, OID upperBoundEx) {
        SortedMap view;
        if ((lowerBound == null) && (upperBoundEx == null)) {
            view = rows;
        } else if (lowerBound == null) {
            view = rows.headMap(upperBoundEx);
        } else if (upperBoundEx == null) {
            view = rows.tailMap(lowerBound);
        } else {
            view = rows.subMap(lowerBound, upperBoundEx);
        }
        return view;
    }

    public synchronized R removeRow(OID index) {
        R row = rows.remove(index);
        if ((row != null) && (moTableModelListeners != null)) {
            MOTableModelEvent event =
                    new MOTableModelEvent(this, MOTableModelEvent.ROW_REMOVED, row);
            fireTableModelChanged(event);
        }
        return row;
    }

    public synchronized void removeRows(OID lowerBoundIncl,
                                        OID upperBoundExcl) {
        Map m = (lowerBoundIncl == null) ? rows : rows.tailMap(lowerBoundIncl);
        for (Iterator> it = m.entrySet().iterator(); it.hasNext(); ) {
            Map.Entry item = it.next();
            if ((upperBoundExcl == null) ||
                    (upperBoundExcl.compareTo(item.getKey()) > 0)) {
                if (moTableModelListeners != null) {
                    MOTableModelEvent event =
                            new MOTableModelEvent(this, MOTableModelEvent.ROW_REMOVED,
                                    item.getValue());
                    fireTableModelChanged(event);
                }
                it.remove();
            } else {
                break;
            }
        }
    }

    public synchronized void clear() {
        fireTableModelChanged(new MOTableModelEvent(this,
                MOTableModelEvent.TABLE_CLEAR));
        rows.clear();
    }

    /**
     * Remove all rows that do not match the given filter criteria from the model.
     *
     * @param filter
     *         the {@code MOTableRowFilter} that filters out the rows to delete.
     *
     * @return the number of removed rows.
     */
    public synchronized List clear(MOTableRowFilter filter) {
        List removedRows = new ArrayList<>();
        for (Iterator it = rows.values().iterator(); it.hasNext(); ) {
            R row = it.next();
            if (!filter.passesFilter(row)) {
                if (moTableModelListeners != null) {
                    MOTableModelEvent event =
                            new MOTableModelEvent(this, MOTableModelEvent.ROW_REMOVED, row);
                    fireTableModelChanged(event);
                }
                it.remove();
                removedRows.add(row);
            }
        }
        return removedRows;
    }

    /**
     * Returns an iterator over all rows in this table that pass the given filter. If the table might be modified while
     * the iterator is used, it is recommended to synchronize on this model while iterating.
     *
     * @param filter
     *         a MOTableRowFilter instance that defines the rows to return.
     *
     * @return an Iterator.
     */
    public synchronized Iterator iterator(MOTableRowFilter filter) {
        return new FilteredRowIterator(filter);
    }

    /**
     * Create a new row and return it. The new row will not be added to the table. To add it to the model use the {@link
     * #addRow} method. If this mutable table does not support row creation, it should throw an {@link
     * UnsupportedOperationException}.
     *
     * @param index
     *         the index OID for the new row.
     * @param values
     *         the values to be contained in the new row.
     *
     * @return the created MOTableRow.
     * @throws java.lang.UnsupportedOperationException
     *         if the specified row cannot be created.
     */
    public R createRow(OID index, Variable[] values)
            throws UnsupportedOperationException {
        if (rowFactory == null) {
            throw new UnsupportedOperationException("No row factory");
        }
        return rowFactory.createRow(index, values);
    }

    @Override
    public void setRowFactory(MOTableRowFactory rowFactory) {
        this.rowFactory = rowFactory;
    }

    public void setColumnCount(int columnCount) {
        this.columnCount = columnCount;
    }

    public void freeRow(R row) {
        if (rowFactory != null) {
            rowFactory.freeRow(row);
        }
    }

    public synchronized void addMOTableModelListener(MOTableModelListener l) {
        if (moTableModelListeners == null) {
            moTableModelListeners = new ArrayList<>(2);
        }
        moTableModelListeners.add(l);
    }

    public synchronized void removeMOTableModelListener(MOTableModelListener l) {
        if (moTableModelListeners != null) {
            moTableModelListeners.remove(l);
        }
    }

    protected void fireTableModelChanged(MOTableModelEvent event) {
        final List listeners = moTableModelListeners;
        if (listeners != null) {
            synchronized (listeners) {
                for (MOTableModelListener listener : listeners) {
                    listener.tableModelChanged(event);
                }
            }
        }
    }

    public class FilteredRowIterator implements Iterator {

        private Iterator iterator;
        private MOTableRowFilter filter;
        private R next;

        FilteredRowIterator(MOTableRowFilter filter) {
            this.filter = filter;
            this.iterator = iterator();
        }

        public void remove() {
            iterator.remove();
        }

        public boolean hasNext() {
            if (next != null) {
                return true;
            }
            findNext();
            return (next != null);
        }

        private void findNext() {
            while (iterator.hasNext()) {
                next = iterator.next();
                if (filter.passesFilter(next)) {
                    break;
                } else {
                    next = null;
                }
            }
        }

        public R next() {
            if (next == null) {
                findNext();
            }
            if (next != null) {
                R retval = next;
                next = null;
                return retval;
            }
            throw new NoSuchElementException();
        }

    }

    public R addRow(R row) {
        R replacedRow = super.addRow(row);
        if (moTableModelListeners != null) {
            MOTableModelEvent event = new MOTableModelEvent(this, MOTableModelEvent.ROW_ADDED, row);
            fireTableModelChanged(event);
        }
        return replacedRow;
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy