annotate dwtx/jface/action/SubMenuManager.d @ 104:04b47443bb01

Reworked the collection uses to make use of a wrapper collection that is compatible to the Java Collections. These new wrappers now use the tango.util.containers instead of the tango.util.collections.
author Frank Benoit <benoit@tionex.de>
date Thu, 07 Aug 2008 15:01:33 +0200
parents 46a6e0e6ccd4
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
28
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
1 /*******************************************************************************
70
46a6e0e6ccd4 Merge with d-fied sources of 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 43
diff changeset
2 * Copyright (c) 2000, 2007 IBM Corporation and others.
28
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
3 * All rights reserved. This program and the accompanying materials
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
4 * are made available under the terms of the Eclipse Public License v1.0
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
5 * which accompanies this distribution, and is available at
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
6 * http://www.eclipse.org/legal/epl-v10.html
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
7 *
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
8 * Contributors:
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
9 * IBM Corporation - initial API and implementation
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
10 * Port to the D programming language:
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
11 * Frank Benoit <benoit@tionex.de>
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
12 *******************************************************************************/
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
13 module dwtx.jface.action.SubMenuManager;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
14
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
15 import dwtx.jface.action.SubContributionManager;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
16 import dwtx.jface.action.IMenuManager;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
17 import dwtx.jface.action.IMenuListener;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
18 import dwtx.jface.action.IContributionItem;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
19 import dwtx.jface.action.IContributionManager;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
20 import dwtx.jface.action.SubContributionItem;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
21
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
22
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
23 import dwt.widgets.Composite;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
24 import dwt.widgets.CoolBar;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
25 import dwt.widgets.Menu;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
26 import dwt.widgets.ToolBar;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
27 import dwtx.core.runtime.Assert;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
28 import dwtx.core.runtime.ListenerList;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
29
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
30 import dwt.dwthelper.utils;
104
04b47443bb01 Reworked the collection uses to make use of a wrapper collection that is compatible to the Java Collections.
Frank Benoit <benoit@tionex.de>
parents: 70
diff changeset
31 import dwtx.dwtxhelper.Collection;
28
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
32
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
33 /**
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
34 * A <code>SubMenuManager</code> is used to define a set of contribution
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
35 * items within a parent manager. Once defined, the visibility of the entire set can
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
36 * be changed as a unit.
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
37 * <p>
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
38 * A client may ask for and make additions to a submenu. The visibility of these items
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
39 * is also controlled by the visibility of the <code>SubMenuManager</code>.
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
40 * </p>
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
41 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
42 public class SubMenuManager : SubContributionManager,
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
43 IMenuManager {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
44
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
45 public bool isDirty() {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
46 return super.isDirty();
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
47 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
48 public bool isVisible() {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
49 return super.isVisible();
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
50 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
51
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
52 /**
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
53 * Maps each submenu in the manager to a wrapper. The wrapper is used to
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
54 * monitor additions and removals. If the visibility of the manager is modified
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
55 * the visibility of the submenus is also modified.
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
56 */
104
04b47443bb01 Reworked the collection uses to make use of a wrapper collection that is compatible to the Java Collections.
Frank Benoit <benoit@tionex.de>
parents: 70
diff changeset
57 private Map mapMenuToWrapper;
28
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
58
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
59 /**
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
60 * List of registered menu listeners (element type: <code>IMenuListener</code>).
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
61 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
62 private ListenerList menuListeners;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
63
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
64 /**
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
65 * The menu listener added to the parent. Lazily initialized
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
66 * in addMenuListener.
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
67 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
68 private IMenuListener menuListener;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
69
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
70 /**
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
71 * Constructs a new manager.
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
72 *
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
73 * @param mgr the parent manager. All contributions made to the
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
74 * <code>SubMenuManager</code> are forwarded and appear in the
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
75 * parent manager.
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
76 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
77 public this(IMenuManager mgr) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
78 menuListeners = new ListenerList();
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
79 super(mgr);
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
80 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
81
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
82 /* (non-Javadoc)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
83 * @see dwtx.jface.action.IMenuManager#addMenuListener(dwtx.jface.action.IMenuListener)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
84 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
85 public void addMenuListener(IMenuListener listener) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
86 menuListeners.add(cast(Object)listener);
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
87 if (menuListener is null) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
88 menuListener = new class IMenuListener {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
89 public void menuAboutToShow(IMenuManager manager) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
90 Object[] listeners = menuListeners.getListeners();
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
91 for (int i = 0; i < listeners.length; ++i) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
92 (cast(IMenuListener) listeners[i])
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
93 .menuAboutToShow(this.outer);
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
94 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
95 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
96 };
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
97 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
98 getParentMenuManager().addMenuListener(menuListener);
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
99 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
100
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
101 /**
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
102 * The default implementation of this <code>IContributionItem</code>
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
103 * method does nothing. Subclasses may override.
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
104 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
105 public void dispose() {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
106 // do nothing
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
107 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
108
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
109 /* (non-Javadoc)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
110 * @see dwtx.jface.action.SubContributionManager#disposeManager()
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
111 */
43
ea8ff534f622 Fix override and super aliases
Frank Benoit <benoit@tionex.de>
parents: 28
diff changeset
112 public override void disposeManager() {
28
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
113 if (menuListener !is null) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
114 getParentMenuManager().removeMenuListener(menuListener);
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
115 menuListener = null;
70
46a6e0e6ccd4 Merge with d-fied sources of 3.4M7
Frank Benoit <benoit@tionex.de>
parents: 43
diff changeset
116 menuListeners.clear();
28
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
117 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
118 // Dispose wrapped menus in addition to removing them.
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
119 // See bugs 64024 and 73715 for details.
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
120 // important to dispose menu wrappers before call to super,
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
121 // otherwise super's call to removeAll will remove them
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
122 // before they can be disposed
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
123 if (mapMenuToWrapper !is null) {
104
04b47443bb01 Reworked the collection uses to make use of a wrapper collection that is compatible to the Java Collections.
Frank Benoit <benoit@tionex.de>
parents: 70
diff changeset
124 Iterator iter = mapMenuToWrapper.values().iterator();
04b47443bb01 Reworked the collection uses to make use of a wrapper collection that is compatible to the Java Collections.
Frank Benoit <benoit@tionex.de>
parents: 70
diff changeset
125 while (iter.hasNext()) {
04b47443bb01 Reworked the collection uses to make use of a wrapper collection that is compatible to the Java Collections.
Frank Benoit <benoit@tionex.de>
parents: 70
diff changeset
126 SubMenuManager wrapper = cast(SubMenuManager) iter.next();
28
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
127 wrapper.disposeManager();
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
128 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
129 mapMenuToWrapper.clear();
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
130 mapMenuToWrapper = null;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
131 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
132 super.disposeManager();
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
133 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
134
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
135 /* (non-Javadoc)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
136 * @see dwtx.jface.action.IContributionItem#fill(dwt.widgets.Composite)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
137 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
138 public void fill(Composite parent) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
139 if (isVisible()) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
140 getParentMenuManager().fill(parent);
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
141 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
142 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
143
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
144 /* (non-Javadoc)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
145 * @see dwtx.jface.action.IContributionItem#fill(dwt.widgets.CoolBar, int)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
146 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
147 public void fill(CoolBar parent, int index) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
148 // do nothing
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
149 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
150
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
151 /* (non-Javadoc)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
152 * @see dwtx.jface.action.IContributionItem#fill(dwt.widgets.Menu, int)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
153 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
154 public void fill(Menu parent, int index) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
155 if (isVisible()) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
156 getParentMenuManager().fill(parent, index);
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
157 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
158 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
159
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
160 /* (non-Javadoc)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
161 * @see dwtx.jface.action.IContributionItem#fill(dwt.widgets.ToolBar, int)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
162 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
163 public void fill(ToolBar parent, int index) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
164 if (isVisible()) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
165 getParentMenuManager().fill(parent, index);
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
166 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
167 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
168
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
169 /* (non-Javadoc)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
170 * Method declared on IContributionManager.
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
171 *
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
172 * Returns the item passed to us, not the wrapper.
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
173 * In the case of menu's not added by this manager,
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
174 * ensure that we return a wrapper for the menu.
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
175 */
43
ea8ff534f622 Fix override and super aliases
Frank Benoit <benoit@tionex.de>
parents: 28
diff changeset
176 public override IContributionItem find(String id) {
28
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
177 IContributionItem item = getParentMenuManager().find(id);
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
178 if (cast(SubContributionItem)item ) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
179 // Return the item passed to us, not the wrapper.
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
180 item = unwrap(item);
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
181 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
182
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
183 if (cast(IMenuManager)item ) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
184 // if it is a menu manager wrap it before returning
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
185 IMenuManager menu = cast(IMenuManager) item;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
186 item = getWrapper(menu);
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
187 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
188
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
189 return item;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
190 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
191
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
192 /**
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
193 * <p>
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
194 * The menu returned is wrapped within a <code>SubMenuManager</code> to
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
195 * monitor additions and removals. If the visibility of this menu is modified
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
196 * the visibility of the submenus is also modified.
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
197 * </p>
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
198 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
199 public IMenuManager findMenuUsingPath(String path) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
200 IContributionItem item = findUsingPath(path);
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
201 if (cast(IMenuManager)item ) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
202 return cast(IMenuManager) item;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
203 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
204 return null;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
205 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
206
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
207 /* (non-Javadoc)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
208 * Method declared on IMenuManager.
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
209 *
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
210 * Returns the item passed to us, not the wrapper.
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
211 *
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
212 * We use use the same algorithm as MenuManager.findUsingPath, but unwrap
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
213 * submenus along so that SubMenuManagers are visible.
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
214 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
215 public IContributionItem findUsingPath(String path) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
216 String id = path;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
217 String rest = null;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
218 int separator = path.indexOf('/');
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
219 if (separator !is -1) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
220 id = path.substring(0, separator);
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
221 rest = path.substring(separator + 1);
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
222 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
223 IContributionItem item = find(id); // unwraps item
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
224 if (rest !is null && cast(IMenuManager)item ) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
225 IMenuManager menu = cast(IMenuManager) item;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
226 item = menu.findUsingPath(rest);
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
227 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
228 return item;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
229 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
230
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
231 /* (non-Javadoc)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
232 * @see dwtx.jface.action.IContributionItem#getId()
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
233 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
234 public String getId() {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
235 return getParentMenuManager().getId();
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
236 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
237
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
238 /**
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
239 * @return the parent menu manager that this sub-manager contributes to.
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
240 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
241 protected final IMenuManager getParentMenuManager() {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
242 // Cast is ok because that's the only
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
243 // thing we accept in the construtor.
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
244 return cast(IMenuManager) getParent();
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
245 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
246
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
247 /* (non-Javadoc)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
248 * @see dwtx.jface.action.IMenuManager#getRemoveAllWhenShown()
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
249 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
250 public bool getRemoveAllWhenShown() {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
251 return false;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
252 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
253
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
254 /**
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
255 * Returns the menu wrapper for a menu manager.
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
256 * <p>
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
257 * The sub menus within this menu are wrapped within a <code>SubMenuManager</code> to
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
258 * monitor additions and removals. If the visibility of this menu is modified
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
259 * the visibility of the sub menus is also modified.
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
260 * <p>
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
261 * @param mgr the menu manager to be wrapped
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
262 *
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
263 * @return the menu wrapper
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
264 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
265 protected IMenuManager getWrapper(IMenuManager mgr) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
266 if (mapMenuToWrapper is null) {
104
04b47443bb01 Reworked the collection uses to make use of a wrapper collection that is compatible to the Java Collections.
Frank Benoit <benoit@tionex.de>
parents: 70
diff changeset
267 mapMenuToWrapper = new HashMap(4);
28
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
268 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
269 SubMenuManager wrapper = cast(SubMenuManager) mapMenuToWrapper.get(cast(Object)mgr);
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
270 if (wrapper is null) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
271 wrapper = wrapMenu(mgr);
104
04b47443bb01 Reworked the collection uses to make use of a wrapper collection that is compatible to the Java Collections.
Frank Benoit <benoit@tionex.de>
parents: 70
diff changeset
272 mapMenuToWrapper.put(cast(Object)mgr, wrapper);
28
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
273 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
274 return wrapper;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
275 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
276
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
277 /* (non-Javadoc)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
278 * @see dwtx.jface.action.IContributionItem#isDynamic()
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
279 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
280 public bool isDynamic() {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
281 return getParentMenuManager().isDynamic();
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
282 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
283
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
284 /* (non-Javadoc)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
285 * @see dwtx.jface.action.IContributionItem#isEnabled()
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
286 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
287 public bool isEnabled() {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
288 return isVisible() && getParentMenuManager().isEnabled();
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
289 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
290
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
291 /* (non-Javadoc)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
292 * @see dwtx.jface.action.IContributionItem#isGroupMarker()
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
293 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
294 public bool isGroupMarker() {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
295 return getParentMenuManager().isGroupMarker();
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
296 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
297
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
298 /* (non-Javadoc)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
299 * @see dwtx.jface.action.IContributionItem#isSeparator()
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
300 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
301 public bool isSeparator() {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
302 return getParentMenuManager().isSeparator();
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
303 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
304
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
305 /**
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
306 * Remove all contribution items.
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
307 */
43
ea8ff534f622 Fix override and super aliases
Frank Benoit <benoit@tionex.de>
parents: 28
diff changeset
308 public override void removeAll() {
28
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
309 super.removeAll();
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
310 if (mapMenuToWrapper !is null) {
104
04b47443bb01 Reworked the collection uses to make use of a wrapper collection that is compatible to the Java Collections.
Frank Benoit <benoit@tionex.de>
parents: 70
diff changeset
311 Iterator iter = mapMenuToWrapper.values().iterator();
04b47443bb01 Reworked the collection uses to make use of a wrapper collection that is compatible to the Java Collections.
Frank Benoit <benoit@tionex.de>
parents: 70
diff changeset
312 while (iter.hasNext()) {
04b47443bb01 Reworked the collection uses to make use of a wrapper collection that is compatible to the Java Collections.
Frank Benoit <benoit@tionex.de>
parents: 70
diff changeset
313 SubMenuManager wrapper = cast(SubMenuManager) iter.next();
28
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
314 wrapper.removeAll();
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
315 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
316 mapMenuToWrapper.clear();
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
317 mapMenuToWrapper = null;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
318 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
319 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
320
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
321 /* (non-Javadoc)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
322 * @see dwtx.jface.action.IMenuManager#removeMenuListener(dwtx.jface.action.IMenuListener)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
323 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
324 public void removeMenuListener(IMenuListener listener) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
325 menuListeners.remove(cast(Object)listener);
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
326 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
327
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
328 /* (non-Javadoc)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
329 * @see dwtx.jface.action.IContributionItem#saveWidgetState()
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
330 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
331 public void saveWidgetState() {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
332 // do nothing
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
333 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
334
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
335 /* (non-Javadoc)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
336 * @see dwtx.jface.action.IContributionItem#setParent(dwtx.jface.action.IContributionManager)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
337 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
338 public void setParent(IContributionManager parent) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
339 // do nothing, our "parent manager's" parent
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
340 // is set when it is added to a manager
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
341 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
342
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
343 /* (non-Javadoc)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
344 * @see dwtx.jface.action.IMenuManager#setRemoveAllWhenShown(bool)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
345 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
346 public void setRemoveAllWhenShown(bool removeAll) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
347 Assert.isTrue(false, "Should not be called on submenu manager"); //$NON-NLS-1$
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
348 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
349
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
350 /* (non-Javadoc)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
351 * @see dwtx.jface.action.SubContributionManager#setVisible(bool)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
352 */
43
ea8ff534f622 Fix override and super aliases
Frank Benoit <benoit@tionex.de>
parents: 28
diff changeset
353 public override void setVisible(bool visible) {
28
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
354 super.setVisible(visible);
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
355 if (mapMenuToWrapper !is null) {
104
04b47443bb01 Reworked the collection uses to make use of a wrapper collection that is compatible to the Java Collections.
Frank Benoit <benoit@tionex.de>
parents: 70
diff changeset
356 Iterator iter = mapMenuToWrapper.values().iterator();
04b47443bb01 Reworked the collection uses to make use of a wrapper collection that is compatible to the Java Collections.
Frank Benoit <benoit@tionex.de>
parents: 70
diff changeset
357 while (iter.hasNext()) {
04b47443bb01 Reworked the collection uses to make use of a wrapper collection that is compatible to the Java Collections.
Frank Benoit <benoit@tionex.de>
parents: 70
diff changeset
358 SubMenuManager wrapper = cast(SubMenuManager) iter.next();
28
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
359 wrapper.setVisible(visible);
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
360 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
361 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
362 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
363
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
364 /* (non-Javadoc)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
365 * @see dwtx.jface.action.IContributionItem#update()
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
366 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
367 public void update() {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
368 // This method is not governed by visibility. The client may
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
369 // call <code>setVisible</code> and then force an update. At that
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
370 // point we need to update the parent.
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
371 getParentMenuManager().update();
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
372 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
373
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
374 /* (non-Javadoc)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
375 * @see dwtx.jface.action.IContributionManager#update(bool)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
376 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
377 public void update(bool force) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
378 // This method is not governed by visibility. The client may
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
379 // call <code>setVisible</code> and then force an update. At that
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
380 // point we need to update the parent.
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
381 getParentMenuManager().update(force);
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
382 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
383
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
384 /* (non-Javadoc)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
385 * @see dwtx.jface.action.IContributionItem#update(java.lang.String)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
386 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
387 public void update(String id) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
388 getParentMenuManager().update(id);
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
389 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
390
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
391 /* (non-Javadoc)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
392 * @see dwtx.jface.action.IMenuManager#updateAll(bool)
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
393 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
394 public void updateAll(bool force) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
395 // This method is not governed by visibility. The client may
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
396 // call <code>setVisible</code> and then force an update. At that
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
397 // point we need to update the parent.
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
398 getParentMenuManager().updateAll(force);
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
399 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
400
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
401 /**
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
402 * Wraps a menu manager in a sub menu manager, and returns the new wrapper.
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
403 * @param menu the menu manager to wrap
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
404 * @return the new wrapped menu manager
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
405 */
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
406 protected SubMenuManager wrapMenu(IMenuManager menu) {
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
407 SubMenuManager mgr = new SubMenuManager(menu);
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
408 mgr.setVisible(isVisible());
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
409 return mgr;
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
410 }
Frank Benoit <benoit@tionex.de>
parents:
diff changeset
411 }