Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(469)

Unified Diff: editor/tools/plugins/com.xored.glance.ui/src/com/xored/glance/internal/ui/sources/TextSourceListener.java

Issue 17431004: New UI for Find command: find-as-you-type. (Closed) Base URL: http://dart.googlecode.com/svn/branches/bleeding_edge/dart/
Patch Set: Created 7 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: editor/tools/plugins/com.xored.glance.ui/src/com/xored/glance/internal/ui/sources/TextSourceListener.java
===================================================================
--- editor/tools/plugins/com.xored.glance.ui/src/com/xored/glance/internal/ui/sources/TextSourceListener.java (revision 0)
+++ editor/tools/plugins/com.xored.glance.ui/src/com/xored/glance/internal/ui/sources/TextSourceListener.java (revision 0)
@@ -0,0 +1,79 @@
+/**
+ *
+ */
+package com.xored.glance.internal.ui.sources;
+
+import org.eclipse.core.runtime.ListenerList;
+import org.eclipse.swt.SWT;
+import org.eclipse.swt.widgets.Control;
+import org.eclipse.swt.widgets.Display;
+import org.eclipse.swt.widgets.Event;
+import org.eclipse.swt.widgets.Listener;
+import org.eclipse.ui.PlatformUI;
+
+import com.xored.glance.ui.sources.ITextSourceDescriptor;
+
+/**
+ * @author Yuri Strot
+ */
+public class TextSourceListener implements Listener {
+
+ public TextSourceListener(ITextSourceDescriptor[] descriptors) {
+ this.descriptors = descriptors;
+ }
+
+ public void addSourceProviderListener(ISourceProviderListener listener) {
+ if (listeners.size() == 0) {
+ getDisplay().addFilter(SWT.FocusIn, this);
+ }
+ listeners.add(listener);
+ }
+
+ public void removeSourceProviderListener(ISourceProviderListener listener) {
+ listeners.remove(listener);
+ if (listeners.size() == 0) {
+ getDisplay().removeFilter(SWT.FocusIn, this);
+ selection = null;
+ }
+ }
+
+ public void handleEvent(Event event) {
+ TextSourceMaker creator = getCreator(getDisplay().getFocusControl());
+ if (!creator.equals(selection)) {
+ selection = creator;
+ Object[] objects = listeners.getListeners();
+ for (Object object : objects) {
+ ISourceProviderListener listener = (ISourceProviderListener) object;
+ listener.sourceChanged(selection);
+ }
+ }
+ }
+
+ public TextSourceMaker getSelection() {
+ return getCreator(getDisplay().getFocusControl());
+ }
+
+ private TextSourceMaker getCreator(Control control) {
+ return new TextSourceMaker(getDescriptor(control), control);
+ }
+
+ private ITextSourceDescriptor getDescriptor(Control control) {
+ if (control != null) {
+ for (ITextSourceDescriptor descriptor : descriptors) {
+ if (descriptor.isValid(control)) {
+ return descriptor;
+ }
+ }
+ }
+ return null;
+ }
+
+ private Display getDisplay() {
+ return PlatformUI.getWorkbench().getDisplay();
+ }
+
+ private TextSourceMaker selection;
+ private ListenerList listeners = new ListenerList();
+ private ITextSourceDescriptor[] descriptors;
+
+}

Powered by Google App Engine
This is Rietveld 408576698