Skip to main content
summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorspingel2010-07-15 21:45:52 +0000
committerspingel2010-07-15 21:45:52 +0000
commit7a21205ec2cfc454880f9b5d612c4917c4fd801a (patch)
treef8de7cf3c1cbecff82bcd79794317f7810030c26 /org.eclipse.mylyn.tasks.search
parentaea9a1d145fd49ceedce67a75592e448ff5bf035 (diff)
downloadorg.eclipse.mylyn.tasks-7a21205ec2cfc454880f9b5d612c4917c4fd801a.tar.gz
org.eclipse.mylyn.tasks-7a21205ec2cfc454880f9b5d612c4917c4fd801a.tar.xz
org.eclipse.mylyn.tasks-7a21205ec2cfc454880f9b5d612c4917c4fd801a.zip
NEW - bug 319469: [patch] Highlight filter matches in Task Search view
https://bugs.eclipse.org/bugs/show_bug.cgi?id=319469
Diffstat (limited to 'org.eclipse.mylyn.tasks.search')
-rw-r--r--org.eclipse.mylyn.tasks.search/src/org/eclipse/mylyn/internal/tasks/ui/search/RepositorySearchResultView.java21
-rw-r--r--org.eclipse.mylyn.tasks.search/src/org/eclipse/mylyn/internal/tasks/ui/search/RepositorySearchStyledLabelProvider.java241
2 files changed, 257 insertions, 5 deletions
diff --git a/org.eclipse.mylyn.tasks.search/src/org/eclipse/mylyn/internal/tasks/ui/search/RepositorySearchResultView.java b/org.eclipse.mylyn.tasks.search/src/org/eclipse/mylyn/internal/tasks/ui/search/RepositorySearchResultView.java
index 1e0f5f2fa..10308e32d 100644
--- a/org.eclipse.mylyn.tasks.search/src/org/eclipse/mylyn/internal/tasks/ui/search/RepositorySearchResultView.java
+++ b/org.eclipse.mylyn.tasks.search/src/org/eclipse/mylyn/internal/tasks/ui/search/RepositorySearchResultView.java
@@ -8,6 +8,7 @@
* Contributors:
* Tasktop Technologies - initial API and implementation
* Frank Becker - improvements
+ * Perforce - enhancements for bug 319469
*******************************************************************************/
package org.eclipse.mylyn.internal.tasks.ui.search;
@@ -25,7 +26,6 @@ import org.eclipse.jface.action.IMenuManager;
import org.eclipse.jface.action.MenuManager;
import org.eclipse.jface.action.Separator;
import org.eclipse.jface.util.LocalSelectionTransfer;
-import org.eclipse.jface.viewers.DecoratingLabelProvider;
import org.eclipse.jface.viewers.StructuredSelection;
import org.eclipse.jface.viewers.StructuredViewer;
import org.eclipse.jface.viewers.TableViewer;
@@ -151,6 +151,8 @@ public class RepositorySearchResultView extends AbstractTextSearchViewPage imple
private SearchResultSortAction sortByDialogAction;
+ private RepositorySearchStyledLabelProvider styledLabelProvider;
+
private static final IShowInTargetList SHOW_IN_TARGET_LIST = new IShowInTargetList() {
public String[] getShowInTargetIds() {
return SHOW_IN_TARGETS;
@@ -219,9 +221,10 @@ public class RepositorySearchResultView extends AbstractTextSearchViewPage imple
searchResultProvider = new SearchResultTreeContentProvider();
viewer.setContentProvider(searchResultProvider);
- DecoratingLabelProvider labelProvider = new DecoratingLabelProvider(new SearchResultsLabelProvider(
- searchResultProvider, viewer), PlatformUI.getWorkbench().getDecoratorManager().getLabelDecorator());
- viewer.setLabelProvider(labelProvider);
+ styledLabelProvider = new RepositorySearchStyledLabelProvider(new SearchResultsLabelProvider(
+ searchResultProvider, viewer), PlatformUI.getWorkbench().getDecoratorManager().getLabelDecorator(),
+ null);
+ viewer.setLabelProvider(styledLabelProvider);
viewer.setSorter(searchResultSorter);
Transfer[] dragTypes = new Transfer[] { LocalSelectionTransfer.getTransfer(), FileTransfer.getInstance() };
@@ -248,7 +251,15 @@ public class RepositorySearchResultView extends AbstractTextSearchViewPage imple
}
FilteredTree searchTree = new EnhancedFilteredTree(treeComposite, SWT.MULTI | SWT.H_SCROLL | SWT.V_SCROLL,
- new SubstringPatternFilter(), true);
+ new SubstringPatternFilter() {
+
+ @Override
+ public void setPattern(String patternString) {
+ styledLabelProvider.setPattern(patternString);
+ super.setPattern(patternString);
+ }
+
+ }, true);
return searchTree.getViewer();
}
diff --git a/org.eclipse.mylyn.tasks.search/src/org/eclipse/mylyn/internal/tasks/ui/search/RepositorySearchStyledLabelProvider.java b/org.eclipse.mylyn.tasks.search/src/org/eclipse/mylyn/internal/tasks/ui/search/RepositorySearchStyledLabelProvider.java
new file mode 100644
index 000000000..6179cc4e3
--- /dev/null
+++ b/org.eclipse.mylyn.tasks.search/src/org/eclipse/mylyn/internal/tasks/ui/search/RepositorySearchStyledLabelProvider.java
@@ -0,0 +1,241 @@
+/*******************************************************************************
+ * Copyright (c) 2000, 2008 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
+ * Perforce - enhancements for bug 319469
+ *******************************************************************************/
+
+package org.eclipse.mylyn.internal.tasks.ui.search;
+
+import org.eclipse.jface.resource.JFaceResources;
+import org.eclipse.jface.util.IPropertyChangeListener;
+import org.eclipse.jface.util.PropertyChangeEvent;
+import org.eclipse.jface.viewers.ColumnViewer;
+import org.eclipse.jface.viewers.DecoratingStyledCellLabelProvider;
+import org.eclipse.jface.viewers.IColorProvider;
+import org.eclipse.jface.viewers.IDecorationContext;
+import org.eclipse.jface.viewers.IFontProvider;
+import org.eclipse.jface.viewers.ILabelDecorator;
+import org.eclipse.jface.viewers.ILabelProvider;
+import org.eclipse.jface.viewers.StyledCellLabelProvider;
+import org.eclipse.jface.viewers.StyledString;
+import org.eclipse.jface.viewers.ViewerColumn;
+import org.eclipse.search.internal.ui.text.DecoratingFileSearchLabelProvider;
+import org.eclipse.swt.SWT;
+import org.eclipse.swt.custom.StyleRange;
+import org.eclipse.swt.graphics.Color;
+import org.eclipse.swt.graphics.Font;
+import org.eclipse.swt.graphics.Image;
+import org.eclipse.ui.IWorkbenchPreferenceConstants;
+import org.eclipse.ui.PlatformUI;
+import org.eclipse.ui.internal.misc.StringMatcher;
+import org.eclipse.ui.internal.misc.StringMatcher.Position;
+
+/**
+ * Repository search styled label provider. Based on {@link DecoratingFileSearchLabelProvider}.
+ *
+ * @author Kevin Sawicki
+ * @see DecoratingFileSearchLabelProvider
+ */
+public class RepositorySearchStyledLabelProvider extends DecoratingStyledCellLabelProvider implements
+ IPropertyChangeListener, ILabelProvider {
+
+ /**
+ * Color to use to decorate matches.
+ */
+ public static final String HIGHLIGHT_BG_COLOR_NAME = "org.eclipse.jdt.ui.ColoredLabels.match_highlight"; //$NON-NLS-1$
+
+ private static class PatternStyledLabelProvider extends StyledCellLabelProvider implements IStyledLabelProvider,
+ IColorProvider, IFontProvider {
+
+ private final SearchResultsLabelProvider labelProvider;
+
+ private StringMatcher matcher = null;
+
+ public PatternStyledLabelProvider(SearchResultsLabelProvider provider) {
+ this.labelProvider = provider;
+ }
+
+ /**
+ * Set the pattern to highlight
+ *
+ * @param pattern
+ */
+ public void setPattern(String pattern) {
+ if (pattern != null && pattern.length() > 0) {
+ this.matcher = new StringMatcher(pattern, true, false);
+ } else {
+ this.matcher = null;
+ }
+ }
+
+ public StyledString getStyledText(Object element) {
+ StyledString styled = null;
+ String label = this.labelProvider.getText(element);
+ if (matcher == null || label.length() == 0) {
+ styled = new StyledString(label);
+ } else {
+ styled = new StyledString();
+ int start = 0;
+ int end = 0;
+ int length = label.length();
+ Position position = matcher.find(label, start, length);
+ while (position != null) {
+ end = position.getStart();
+ styled.append(label.substring(start, end));
+ start = position.getEnd();
+ styled.append(label.substring(end, start), DecoratingFileSearchLabelProvider.HIGHLIGHT_STYLE);
+ position = matcher.find(label, start, length);
+ }
+ if (start > 0 && start < length) {
+ styled.append(label.substring(start));
+ }
+ }
+ return styled;
+ }
+
+ public Image getImage(Object element) {
+ return this.labelProvider.getImage(element);
+ }
+
+ public Font getFont(Object element) {
+ return this.labelProvider.getFont(element);
+ }
+
+ public Color getForeground(Object element) {
+ return this.labelProvider.getForeground(element);
+ }
+
+ public Color getBackground(Object element) {
+ return this.labelProvider.getBackground(element);
+ }
+
+ }
+
+ private final ILabelProvider labelProvider;
+
+ /**
+ * Create a new repository search styled label provider that wraps an {@link ILabelProvider}
+ *
+ * @param labelProvider
+ * @param decorator
+ * @param decorationContext
+ */
+ public RepositorySearchStyledLabelProvider(SearchResultsLabelProvider labelProvider, ILabelDecorator decorator,
+ IDecorationContext decorationContext) {
+ super(new PatternStyledLabelProvider(labelProvider), decorator, decorationContext);
+ this.labelProvider = labelProvider;
+ }
+
+ /**
+ * @see org.eclipse.jface.viewers.StyledCellLabelProvider#initialize(org.eclipse.jface.viewers.ColumnViewer,
+ * org.eclipse.jface.viewers.ViewerColumn)
+ */
+ @Override
+ public void initialize(ColumnViewer viewer, ViewerColumn column) {
+ PlatformUI.getPreferenceStore().addPropertyChangeListener(this);
+ JFaceResources.getColorRegistry().addListener(this);
+
+ setOwnerDrawEnabled(PlatformUI.getPreferenceStore()
+ .getBoolean(IWorkbenchPreferenceConstants.USE_COLORED_LABELS));
+
+ super.initialize(viewer, column);
+ }
+
+ /**
+ * Get underyling label provider
+ *
+ * @return label provider
+ */
+ public ILabelProvider getLabelProvider() {
+ return this.labelProvider;
+ }
+
+ /**
+ * @see org.eclipse.jface.viewers.DecoratingStyledCellLabelProvider#dispose()
+ */
+ @Override
+ public void dispose() {
+ PlatformUI.getPreferenceStore().removePropertyChangeListener(this);
+ JFaceResources.getColorRegistry().removeListener(this);
+ this.labelProvider.dispose();
+ super.dispose();
+ }
+
+ /**
+ * Set the pattern to highlight
+ *
+ * @param pattern
+ */
+ public void setPattern(String pattern) {
+ ((PatternStyledLabelProvider) getStyledStringProvider()).setPattern(pattern);
+ }
+
+ /**
+ * Refresh the labels on viewer associated with this label provider. This method must be called on the UI-thread.
+ */
+ protected void refresh() {
+ ColumnViewer viewer = getViewer();
+ if (viewer != null) {
+ boolean coloredLabels = PlatformUI.getPreferenceStore().getBoolean(
+ IWorkbenchPreferenceConstants.USE_COLORED_LABELS);
+ if (coloredLabels || coloredLabels != isOwnerDrawEnabled()) {
+ setOwnerDrawEnabled(coloredLabels);
+ viewer.refresh();
+ }
+ }
+ }
+
+ /**
+ * Schedule a refresh of this label provider. This method can be called from any thread.
+ */
+ protected void scheduleRefresh() {
+ PlatformUI.getWorkbench().getDisplay().asyncExec(new Runnable() {
+ public void run() {
+ refresh();
+ }
+ });
+ }
+
+ /**
+ * @param event
+ */
+ public void propertyChange(PropertyChangeEvent event) {
+ String property = event.getProperty();
+ if (IWorkbenchPreferenceConstants.USE_COLORED_LABELS.equals(property)
+ || HIGHLIGHT_BG_COLOR_NAME.equals(property)) {
+ scheduleRefresh();
+ }
+ }
+
+ /**
+ * Get text of element from underyling label provider
+ *
+ * @see org.eclipse.jface.viewers.ILabelProvider#getText(java.lang.Object)
+ */
+ public String getText(Object element) {
+ return this.labelProvider.getText(element);
+ }
+
+ /**
+ * Override preparation of style range to add border dot about highlight regions that don't have colors applied
+ *
+ * @see org.eclipse.jface.viewers.StyledCellLabelProvider#prepareStyleRange(org.eclipse.swt.custom.StyleRange,
+ * boolean)
+ */
+ @Override
+ protected StyleRange prepareStyleRange(StyleRange styleRange, boolean applyColors) {
+ boolean addBorder = !applyColors && styleRange.background != null;
+ styleRange = super.prepareStyleRange(styleRange, applyColors);
+ if (addBorder) {
+ styleRange.borderStyle = SWT.BORDER_DOT;
+ }
+ return styleRange;
+ }
+
+}

Back to the top