/** @see prefuse.data.util.Index#index() */ public void index() { m_index.clear(); // iterate over all valid values, adding them to the index int idx = getColumnIndex(); m_colidx = idx; IntIterator rows = m_rows.rows(); if (m_index instanceof IntIntSortedMap) { IntIntSortedMap map = (IntIntSortedMap) m_index; while (rows.hasNext()) { int r = rows.nextInt(); map.put(m_col.getInt(m_table.getColumnRow(r, idx)), r); } } else if (m_index instanceof LongIntSortedMap) { LongIntSortedMap map = (LongIntSortedMap) m_index; while (rows.hasNext()) { int r = rows.nextInt(); map.put(m_col.getLong(m_table.getColumnRow(r, idx)), r); } } else if (m_index instanceof FloatIntSortedMap) { FloatIntSortedMap map = (FloatIntSortedMap) m_index; while (rows.hasNext()) { int r = rows.nextInt(); map.put(m_col.getFloat(m_table.getColumnRow(r, idx)), r); } } else if (m_index instanceof DoubleIntSortedMap) { DoubleIntSortedMap map = (DoubleIntSortedMap) m_index; while (rows.hasNext()) { int r = rows.nextInt(); map.put(m_col.getDouble(m_table.getColumnRow(r, idx)), r); } } else if (m_index instanceof BooleanIntSortedMap) { BooleanIntSortedMap map = (BooleanIntSortedMap) m_index; while (rows.hasNext()) { int r = rows.nextInt(); map.put(m_col.getBoolean(m_table.getColumnRow(r, idx)), r); } } else if (m_index instanceof ObjectIntSortedMap) { ObjectIntSortedMap map = (ObjectIntSortedMap) m_index; while (rows.hasNext()) { int r = rows.nextInt(); map.put(m_col.get(m_table.getColumnRow(r, idx)), r); } } else { throw new IllegalStateException(); } m_reindex = false; }
/** * Release a row and mark it as free. * * @param row the row index of the released row * @return true if the row was successfully released, false if it was already free or if the input * is not a valid row index */ public boolean releaseRow(int row) { if (row < 0) { return false; } else if (m_openRows != null && m_openRows.containsKey(row)) { return false; } else if (row == m_curId) { --m_curId; } else if (row == m_firstId) { ++m_firstId; } else { if (m_openRows == null) m_openRows = new IntIntTreeMap(false); m_openRows.put(row, row); } return true; }
private void rowChanged(int row, boolean insert) { // make sure we access the right column value int crow = m_rows.getColumnRow(row, getColumnIndex()); if (m_index instanceof IntIntSortedMap) { IntIntSortedMap map = (IntIntSortedMap) m_index; int key = m_col.getInt(row); if (insert) map.put(key, row); else map.remove(key, row); } else if (m_index instanceof LongIntSortedMap) { LongIntSortedMap map = (LongIntSortedMap) m_index; long key = m_col.getLong(crow); if (insert) map.put(key, row); else map.remove(key, row); } else if (m_index instanceof FloatIntSortedMap) { FloatIntSortedMap map = (FloatIntSortedMap) m_index; float key = m_col.getFloat(crow); if (insert) map.put(key, row); else map.remove(key, row); } else if (m_index instanceof DoubleIntSortedMap) { DoubleIntSortedMap map = (DoubleIntSortedMap) m_index; double key = m_col.getDouble(crow); if (insert) map.put(key, row); else map.remove(key, row); } else if (m_index instanceof BooleanIntSortedMap) { BooleanIntSortedMap map = (BooleanIntSortedMap) m_index; boolean key = m_col.getBoolean(crow); if (insert) map.put(key, row); else map.remove(key, row); } else if (m_index instanceof ObjectIntSortedMap) { ObjectIntSortedMap map = (ObjectIntSortedMap) m_index; Object key = m_col.get(crow); if (insert) map.put(key, row); else map.remove(key, row); } else { throw new IllegalStateException(); } }
/** @see prefuse.data.event.ColumnListener#columnChanged(prefuse.data.column.Column, int, int) */ public void columnChanged(Column src, int idx, int prev) { int row = m_rows.getTableRow(idx, getColumnIndex()); if (row < 0) return; // invalid row value ((IntIntSortedMap) m_index).remove(prev, row); ((IntIntSortedMap) m_index).put(src.getInt(idx), row); }