/******************************************************************************* * Copyright (c) 2000, 2005 IBM Corporation and others. All rights reserved. This program and the * accompanying materials are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html Contributors: IBM Corporation - initial API and * implementation *******************************************************************************/ package org.eclipse.wst.common.ui.internal.search; import com.google.dart.tools.search.ui.text.AbstractTextSearchResult; import org.eclipse.jface.viewers.IStructuredContentProvider; import org.eclipse.jface.viewers.TableViewer; import org.eclipse.jface.viewers.Viewer; import org.eclipse.wst.common.ui.internal.search.basecode.IFileSearchContentProvider; public class SearchResultTableContentProvider implements IStructuredContentProvider, IFileSearchContentProvider { private final Object[] EMPTY_ARR = new Object[0]; private SearchResultPage fPage; private AbstractTextSearchResult fResult; public SearchResultTableContentProvider(SearchResultPage page) { fPage = page; } public void dispose() { // nothing to do } public Object[] getElements(Object inputElement) { if (inputElement instanceof SearchResult) { Object[] elements = ((SearchResult) inputElement).getElements(); // cs : I've comment this code out for now. We need to review the changes to the base class and react accordingly. // Even more importantly we need to discuss with the base guys to get API lined up for this (see bug 163177). /* * int tableLimit= SearchPreferencePage.getTableLimit(); if * (SearchPreferencePage.isTableLimited() && elements.length > tableLimit) { Object[] * shownElements= new Object[tableLimit]; System.arraycopy(elements, 0, shownElements, 0, * tableLimit); return shownElements; } */ return elements; } return EMPTY_ARR; } public void inputChanged(Viewer viewer, Object oldInput, Object newInput) { if (newInput instanceof SearchResult) { fResult = (SearchResult) newInput; } } public void elementsChanged(Object[] updatedElements) { TableViewer viewer = getViewer(); // cs : I've comment 'tableLimited' related code out for now. We need to review the changes to the base class and react accordingly. // Even more importantly we need to discuss with the base guys to get API lined up for this (see bug 163177). //boolean tableLimited= SearchPreferencePage.isTableLimited(); for (int i = 0; i < updatedElements.length; i++) { if (fResult.getMatchCount(updatedElements[i]) > 0) { if (viewer.testFindItem(updatedElements[i]) != null) viewer.update(updatedElements[i], null); else { //if (!tableLimited || viewer.getTable().getItemCount() < SearchPreferencePage.getTableLimit()) viewer.add(updatedElements[i]); } } else viewer.remove(updatedElements[i]); } } private TableViewer getViewer() { return (TableViewer) fPage.getViewer(); } public void clear() { getViewer().refresh(); } }