blob: a4a6de871b3f44d41652a24284ee435199b85cd0 [file] [log] [blame]
<HTML><HEAD><META CONTENT="text/html; charset=UTF-8" HTTP-EQUIV="Content-Type"/><TITLE>EMMA Coverage Report</TITLE><STYLE TYPE="text/css"> TABLE,TD,TH {border-style:solid; border-color:black;} TD,TH {background:white;margin:0;line-height:100%;padding-left:0.5em;padding-right:0.5em;} TD {border-width:0 1px 0 0;} TH {border-width:1px 1px 1px 0;} TR TD.h {color:red;} TABLE {border-spacing:0; border-collapse:collapse;border-width:0 0 1px 1px;} P,H1,H2,H3,TH {font-family:verdana,arial,sans-serif;font-size:10pt;} TD {font-family:courier,monospace;font-size:10pt;} TABLE.hdft {border-spacing:0;border-collapse:collapse;border-style:none;} TABLE.hdft TH,TABLE.hdft TD {border-style:none;line-height:normal;} TABLE.hdft TH.tl,TABLE.hdft TD.tl {background:#6699CC;color:white;} TABLE.hdft TD.nv {background:#6633DD;color:white;} .nv A:link {color:white;} .nv A:visited {color:white;} .nv A:active {color:yellow;} TABLE.hdft A:link {color:white;} TABLE.hdft A:visited {color:white;} TABLE.hdft A:active {color:yellow;} .in {color:#356085;} TABLE.s TD {padding-left:0.25em;padding-right:0.25em;} TABLE.s TD.l {padding-left:0.25em;padding-right:0.25em;text-align:right;background:#F0F0F0;} TABLE.s TR.z TD {background:#FF9999;} TABLE.s TR.p TD {background:#FFFF88;} TABLE.s TR.c TD {background:#CCFFCC;} A:link {color:#0000EE;text-decoration:none;} A:visited {color:#0000EE;text-decoration:none;} A:hover {color:#0000EE;text-decoration:underline;} TABLE.cn {border-width:0 0 1px 0;} TABLE.s {border-width:1px 0 1px 1px;} TD.h {color:red;border-width:0 1px 0 0;} TD.f {border-width:0 1px 0 1px;} TD.hf {color:red;border-width:0 1px 0 1px;} TH.f {border-width:1px 1px 1px 1px;} TR.cis TD {background:#F0F0F0;} TR.cis TD {border-width:1px 1px 1px 0;} TR.cis TD.h {color:red;border-width:1px 1px 1px 0;} TR.cis TD.f {border-width:1px 1px 1px 1px;} TR.cis TD.hf {color:red;border-width:1px 1px 1px 1px;} TD.b {border-style:none;background:transparent;line-height:50%;} TD.bt {border-width:1px 0 0 0;background:transparent;line-height:50%;} TR.o TD {background:#F0F0F0;}TABLE.it {border-style:none;}TABLE.it TD,TABLE.it TH {border-style:none;}</STYLE></HEAD><BODY><TABLE CLASS="hdft" CELLSPACING="0" WIDTH="100%"><TR><TH CLASS="tl"><A HREF="http://www.eclemma.org/">EMMA</A> Coverage Report (generated Fri Feb 20 18:44:54 GMT 2009)</TH></TR><TR><TD CLASS="nv">[<A HREF="../xslUnitTestCoverage.html">all classes</A>][<A HREF="7e.html">org.eclipse.wst.sse.ui.internal</A>]</TD></TR></TABLE><H2>COVERAGE SUMMARY FOR SOURCE FILE [<SPAN CLASS="in">ExtendedEditorActionBuilder.java</SPAN>]</H2><TABLE CELLSPACING="0" WIDTH="100%"><TR><TH>name</TH><TH>class, %</TH><TH>method, %</TH><TH>block, %</TH><TH>line, %</TH></TR><TR><TD>ExtendedEditorActionBuilder.java</TD><TD CLASS="h">0%   (0/3)</TD><TD CLASS="h">0%   (0/28)</TD><TD CLASS="h">0%   (0/1581)</TD><TD CLASS="h">0%   (0/362)</TD></TR></TABLE><H3>COVERAGE BREAKDOWN BY CLASS AND METHOD</H3><TABLE CLASS="cn" CELLSPACING="0" WIDTH="100%"><TR><TH CLASS="f">name</TH><TH>class, %</TH><TH>method, %</TH><TH>block, %</TH><TH>line, %</TH></TR><TR><TD CLASS="b"> </TD><TD CLASS="b"> </TD><TD CLASS="b"> </TD><TD CLASS="b"> </TD><TD CLASS="b"> </TD></TR><TR CLASS="cis"><TD CLASS="f">class <A HREF="#0">ExtendedEditorActionBuilder</A></TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/12)</TD><TD CLASS="h">0%   (0/704)</TD><TD CLASS="h">0%   (0/174)</TD></TR><TR><TD CLASS="f"><A HREF="#0">&lt;static initializer&gt;</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/26)</TD><TD CLASS="h">0%   (0/6)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#2">ExtendedEditorActionBuilder (): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/3)</TD><TD CLASS="h">0%   (0/2)</TD></TR><TR><TD CLASS="f"><A HREF="#3">contributeMenu (IConfigurationElement, IMenuManager, boolean): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/141)</TD><TD CLASS="h">0%   (0/38)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#4">contributeMenuAction (ActionDescriptor, IMenuManager, boolean, boolean): IMen...</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/143)</TD><TD CLASS="h">0%   (0/34)</TD></TR><TR><TD CLASS="f"><A HREF="#5">contributeSeparator (IMenuManager, IConfigurationElement): boolean</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/27)</TD><TD CLASS="h">0%   (0/8)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#6">contributeToolbarAction (ActionDescriptor, IToolBarManager, boolean): boolean</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/96)</TD><TD CLASS="h">0%   (0/24)</TD></TR><TR><TD CLASS="f"><A HREF="#7">createActionDescriptor (IConfigurationElement): ActionDescriptor</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/23)</TD><TD CLASS="h">0%   (0/8)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#8">getTargetID (IConfigurationElement): String</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/10)</TD><TD CLASS="h">0%   (0/2)</TD></TR><TR><TD CLASS="f"><A HREF="#9">readActionExtensions (String []): IExtendedContributor</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/98)</TD><TD CLASS="h">0%   (0/15)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#a">readActionExtensions (String): IExtendedContributor</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/9)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR><TD CLASS="f"><A HREF="#b">readContributions (String [], String, String): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/18)</TD><TD CLASS="h">0%   (0/6)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#c">readElement (IConfigurationElement): boolean</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/110)</TD><TD CLASS="h">0%   (0/30)</TD></TR><TR><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD></TR><TR CLASS="cis"><TD CLASS="f">class <A HREF="#d">ExtendedEditorActionBuilder$1</A></TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/5)</TD><TD CLASS="h">0%   (0/36)</TD><TD CLASS="h">0%   (0/7)</TD></TR><TR><TD CLASS="f"><A HREF="#d">ExtendedEditorActionBuilder$1 (ExtendedEditorActionBuilder$ExtendedContributo...</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/9)</TD><TD CLASS="h">0%   (0/2)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#f">getCaretPosition (): int</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/4)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR><TD CLASS="f"><A HREF="#10">getDocument (): IDocument</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/4)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#11">getEditorPart (): IEditorPart</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/4)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR><TD CLASS="f"><A HREF="#12">getSelectionRange (): Point</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/15)</TD><TD CLASS="h">0%   (0/2)</TD></TR><TR><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD><TD CLASS="bt"> </TD></TR><TR CLASS="cis"><TD CLASS="f">class <A HREF="#13">ExtendedEditorActionBuilder$ExtendedContributor</A></TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/11)</TD><TD CLASS="h">0%   (0/841)</TD><TD CLASS="h">0%   (0/182)</TD></TR><TR><TD CLASS="f"><A HREF="#13">ExtendedEditorActionBuilder$ExtendedContributor (ExtendedEditorActionBuilder,...</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/25)</TD><TD CLASS="h">0%   (0/7)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#15">computeExtendedEditor (IEditorPart): IExtendedSimpleEditor</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/41)</TD><TD CLASS="h">0%   (0/8)</TD></TR><TR><TD CLASS="f"><A HREF="#16">contributeToMenu (IMenuManager): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/129)</TD><TD CLASS="h">0%   (0/24)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#17">contributeToPopupMenu (IMenuManager): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/155)</TD><TD CLASS="h">0%   (0/30)</TD></TR><TR><TD CLASS="f"><A HREF="#18">contributeToStatusLine (IStatusLineManager): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#19">contributeToToolBar (IToolBarManager): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/149)</TD><TD CLASS="h">0%   (0/26)</TD></TR><TR><TD CLASS="f"><A HREF="#1a">dispose (): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/19)</TD><TD CLASS="h">0%   (0/6)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#1b">init (IActionBars, IWorkbenchPage): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/1)</TD></TR><TR><TD CLASS="f"><A HREF="#1c">menuAboutToShow (IMenuManager): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/192)</TD><TD CLASS="h">0%   (0/47)</TD></TR><TR CLASS="o"><TD CLASS="f"><A HREF="#1d">setActiveEditor (IEditorPart): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/91)</TD><TD CLASS="h">0%   (0/21)</TD></TR><TR><TD CLASS="f"><A HREF="#1e">updateToolbarActions (): void</A></TD><TD> </TD><TD CLASS="h">0%   (0/1)</TD><TD CLASS="h">0%   (0/38)</TD><TD CLASS="h">0%   (0/11)</TD></TR></TABLE><P></P><TABLE CLASS="s" CELLSPACING="0" WIDTH="100%"><TR CLASS="z"><TD CLASS="l">1</TD><TD>/*******************************************************************************</TD></TR><TR><TD CLASS="l">2</TD><TD> * Copyright (c) 2001, 2007 IBM Corporation and others.</TD></TR><TR><TD CLASS="l">3</TD><TD> * All rights reserved. This program and the accompanying materials</TD></TR><TR><TD CLASS="l">4</TD><TD> * are made available under the terms of the Eclipse Public License v1.0</TD></TR><TR><TD CLASS="l">5</TD><TD> * which accompanies this distribution, and is available at</TD></TR><TR><TD CLASS="l">6</TD><TD> * http://www.eclipse.org/legal/epl-v10.html</TD></TR><TR><TD CLASS="l">7</TD><TD> *</TD></TR><TR><TD CLASS="l">8</TD><TD> * Contributors:</TD></TR><TR><TD CLASS="l">9</TD><TD> *     IBM Corporation - initial API and implementation</TD></TR><TR><TD CLASS="l">10</TD><TD> *     Jens Lukowski/Innoopract - initial renaming/restructuring</TD></TR><TR><TD CLASS="l">11</TD><TD> *     </TD></TR><TR><TD CLASS="l">12</TD><TD> *******************************************************************************/</TD></TR><TR><TD CLASS="l">13</TD><TD>package org.eclipse.wst.sse.ui.internal;</TD></TR><TR><TD CLASS="l">14</TD><TD> </TD></TR><TR><TD CLASS="l">15</TD><TD>import java.util.ArrayList;</TD></TR><TR><TD CLASS="l">16</TD><TD>import java.util.Arrays;</TD></TR><TR><TD CLASS="l">17</TD><TD>import java.util.HashMap;</TD></TR><TR><TD CLASS="l">18</TD><TD>import java.util.HashSet;</TD></TR><TR><TD CLASS="l">19</TD><TD>import java.util.Iterator;</TD></TR><TR><TD CLASS="l">20</TD><TD>import java.util.List;</TD></TR><TR><TD CLASS="l">21</TD><TD>import java.util.Map;</TD></TR><TR><TD CLASS="l">22</TD><TD>import java.util.Set;</TD></TR><TR><TD CLASS="l">23</TD><TD> </TD></TR><TR><TD CLASS="l">24</TD><TD>import org.eclipse.core.runtime.IConfigurationElement;</TD></TR><TR><TD CLASS="l">25</TD><TD>import org.eclipse.core.runtime.IExtensionRegistry;</TD></TR><TR><TD CLASS="l">26</TD><TD>import org.eclipse.core.runtime.Platform;</TD></TR><TR><TD CLASS="l">27</TD><TD>import org.eclipse.jface.action.ActionContributionItem;</TD></TR><TR><TD CLASS="l">28</TD><TD>import org.eclipse.jface.action.IAction;</TD></TR><TR><TD CLASS="l">29</TD><TD>import org.eclipse.jface.action.IContributionItem;</TD></TR><TR><TD CLASS="l">30</TD><TD>import org.eclipse.jface.action.IMenuListener;</TD></TR><TR><TD CLASS="l">31</TD><TD>import org.eclipse.jface.action.IMenuManager;</TD></TR><TR><TD CLASS="l">32</TD><TD>import org.eclipse.jface.action.IStatusLineManager;</TD></TR><TR><TD CLASS="l">33</TD><TD>import org.eclipse.jface.action.IToolBarManager;</TD></TR><TR><TD CLASS="l">34</TD><TD>import org.eclipse.jface.action.MenuManager;</TD></TR><TR><TD CLASS="l">35</TD><TD>import org.eclipse.jface.action.Separator;</TD></TR><TR><TD CLASS="l">36</TD><TD>import org.eclipse.jface.text.IDocument;</TD></TR><TR><TD CLASS="l">37</TD><TD>import org.eclipse.jface.text.ITextSelection;</TD></TR><TR><TD CLASS="l">38</TD><TD>import org.eclipse.swt.graphics.Point;</TD></TR><TR><TD CLASS="l">39</TD><TD>import org.eclipse.ui.IActionBars;</TD></TR><TR><TD CLASS="l">40</TD><TD>import org.eclipse.ui.IEditorPart;</TD></TR><TR><TD CLASS="l">41</TD><TD>import org.eclipse.ui.IEditorSite;</TD></TR><TR><TD CLASS="l">42</TD><TD>import org.eclipse.ui.IKeyBindingService;</TD></TR><TR><TD CLASS="l">43</TD><TD>import org.eclipse.ui.IWorkbenchActionConstants;</TD></TR><TR><TD CLASS="l">44</TD><TD>import org.eclipse.ui.IWorkbenchPage;</TD></TR><TR><TD CLASS="l">45</TD><TD>import org.eclipse.ui.part.MultiPageEditorSite;</TD></TR><TR><TD CLASS="l">46</TD><TD>import org.eclipse.ui.texteditor.IUpdate;</TD></TR><TR><TD CLASS="l">47</TD><TD>import org.eclipse.wst.sse.ui.internal.extension.ActionDescriptor;</TD></TR><TR><TD CLASS="l">48</TD><TD>import org.eclipse.wst.sse.ui.internal.extension.IExtendedEditorActionProxyForDelayLoading;</TD></TR><TR><TD CLASS="l">49</TD><TD>import org.eclipse.wst.sse.ui.internal.extension.RegistryReader;</TD></TR><TR><TD CLASS="l">50</TD><TD>import org.eclipse.wst.sse.ui.internal.provisional.extensions.ISourceEditingTextTools;</TD></TR><TR><TD CLASS="l">51</TD><TD> </TD></TR><TR><TD CLASS="l">52</TD><TD> </TD></TR><TR><TD CLASS="l">53</TD><TD>/**</TD></TR><TR><TD CLASS="l">54</TD><TD> * This class reads the registry for extensions that plug into 'editorActions'</TD></TR><TR><TD CLASS="l">55</TD><TD> * extension point.</TD></TR><TR><TD CLASS="l">56</TD><TD> */</TD></TR><TR><TD CLASS="l">57</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">58</TD><TD>public class ExtendedEditorActionBuilder extends RegistryReader {</TD></TR><TR><TD CLASS="l">59</TD><TD> </TD></TR><TR><TD CLASS="l">60</TD><TD>        public class ExtendedContributor implements IExtendedContributor, IMenuListener {</TD></TR><TR CLASS="z"><TD CLASS="l">61</TD><TD>                private IExtendedSimpleEditor activeExtendedEditor = null;</TD></TR><TR><TD CLASS="l">62</TD><TD> </TD></TR><TR><TD CLASS="l">63</TD><TD>                private List cache;</TD></TR><TR CLASS="z"><TD CLASS="l">64</TD><TD>                private Map map = new HashMap();</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="13">65</A></TD><TD>                private IMenuManager menuBar = null;</TD></TR><TR><TD CLASS="l">66</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">67</TD><TD>                private Set menus = new HashSet();</TD></TR><TR><TD CLASS="l">68</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">69</TD><TD>                public ExtendedContributor(List cache) {</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="15">70</A></TD><TD>                        this.cache = cache;</TD></TR><TR CLASS="z"><TD CLASS="l">71</TD><TD>                }</TD></TR><TR><TD CLASS="l">72</TD><TD> </TD></TR><TR><TD CLASS="l">73</TD><TD>                private IExtendedSimpleEditor computeExtendedEditor(final IEditorPart editor) {</TD></TR><TR CLASS="z"><TD CLASS="l">74</TD><TD>                        IExtendedSimpleEditor simpleEditor = null;</TD></TR><TR CLASS="z"><TD CLASS="l">75</TD><TD>                        if (editor instanceof IExtendedSimpleEditor) {</TD></TR><TR CLASS="z"><TD CLASS="l">76</TD><TD>                                simpleEditor = (IExtendedSimpleEditor) editor;</TD></TR><TR><TD CLASS="l"><A NAME="d">77</A></TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">78</TD><TD>                        if (editor != null &amp;&amp; simpleEditor == null) {</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="f">79</A></TD><TD>                                final ISourceEditingTextTools tools = (ISourceEditingTextTools) editor.getAdapter(ISourceEditingTextTools.class);</TD></TR><TR CLASS="z"><TD CLASS="l">80</TD><TD>                                if (tools != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">81</TD><TD>                                        simpleEditor = new IExtendedSimpleEditor() {</TD></TR><TR><TD CLASS="l">82</TD><TD>                                                public int getCaretPosition() {</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="10">83</A></TD><TD>                                                        return tools.getCaretOffset();</TD></TR><TR><TD CLASS="l">84</TD><TD>                                                }</TD></TR><TR><TD CLASS="l">85</TD><TD> </TD></TR><TR><TD CLASS="l">86</TD><TD>                                                public IDocument getDocument() {</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="11">87</A></TD><TD>                                                        return tools.getDocument();</TD></TR><TR><TD CLASS="l">88</TD><TD>                                                }</TD></TR><TR><TD CLASS="l">89</TD><TD> </TD></TR><TR><TD CLASS="l">90</TD><TD>                                                public IEditorPart getEditorPart() {</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="12">91</A></TD><TD>                                                        return tools.getEditorPart();</TD></TR><TR><TD CLASS="l">92</TD><TD>                                                }</TD></TR><TR><TD CLASS="l">93</TD><TD> </TD></TR><TR><TD CLASS="l">94</TD><TD>                                                public Point getSelectionRange() {</TD></TR><TR CLASS="z"><TD CLASS="l">95</TD><TD>                                                        ITextSelection selection = tools.getSelection();</TD></TR><TR CLASS="z"><TD CLASS="l">96</TD><TD>                                                        return new Point(selection.getOffset(), selection.getOffset() + selection.getLength());</TD></TR><TR><TD CLASS="l">97</TD><TD>                                                }</TD></TR><TR><TD CLASS="l">98</TD><TD> </TD></TR><TR><TD CLASS="l">99</TD><TD>                                        };</TD></TR><TR><TD CLASS="l">100</TD><TD>                                }</TD></TR><TR><TD CLASS="l">101</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="16">102</A></TD><TD>                        return simpleEditor;</TD></TR><TR><TD CLASS="l">103</TD><TD>                }</TD></TR><TR><TD CLASS="l">104</TD><TD> </TD></TR><TR><TD CLASS="l">105</TD><TD>                public void contributeToMenu(IMenuManager menu) {</TD></TR><TR CLASS="z"><TD CLASS="l">106</TD><TD>                        menuBar = menu;</TD></TR><TR CLASS="z"><TD CLASS="l">107</TD><TD>                        long time0 = System.currentTimeMillis();</TD></TR><TR CLASS="z"><TD CLASS="l">108</TD><TD>                        for (int i = 0; i &lt; cache.size(); i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">109</TD><TD>                                Object obj = cache.get(i);</TD></TR><TR CLASS="z"><TD CLASS="l">110</TD><TD>                                if (obj instanceof IConfigurationElement) {</TD></TR><TR CLASS="z"><TD CLASS="l">111</TD><TD>                                        IConfigurationElement menuElement = (IConfigurationElement) obj;</TD></TR><TR CLASS="z"><TD CLASS="l">112</TD><TD>                                        if ((menuElement.getName()).equals(TAG_MENU)) {</TD></TR><TR CLASS="z"><TD CLASS="l">113</TD><TD>                                                contributeMenu(menuElement, menu, true);</TD></TR><TR CLASS="z"><TD CLASS="l">114</TD><TD>                                                if (debugMenu)</TD></TR><TR CLASS="z"><TD CLASS="l">115</TD><TD>                                                        System.out.println(getClass().getName() + &#34;#contributeToMenu() added: &#34; + menuElement.getAttribute(ATT_ID)); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">116</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">117</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">118</TD><TD>                                else if (obj instanceof ActionDescriptor) {</TD></TR><TR><TD CLASS="l">119</TD><TD>                                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">120</TD><TD>                                                ActionDescriptor ad = (ActionDescriptor) obj;</TD></TR><TR CLASS="z"><TD CLASS="l">121</TD><TD>                                                IMenuManager mm = contributeMenuAction(ad, menu, true, false);</TD></TR><TR CLASS="z"><TD CLASS="l">122</TD><TD>                                                if (mm != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">123</TD><TD>                                                        map.put(ad.getContributionItem(), mm);</TD></TR><TR CLASS="z"><TD CLASS="l">124</TD><TD>                                                        mm.addMenuListener(this);</TD></TR><TR CLASS="z"><TD CLASS="l">125</TD><TD>                                                        menus.add(mm);</TD></TR><TR CLASS="z"><TD CLASS="l">126</TD><TD>                                                        if (debugMenu)</TD></TR><TR CLASS="z"><TD CLASS="l">127</TD><TD>                                                                System.out.println(getClass().getName() + &#34;#contributeToMenu() added: &#34; + ad.getId()); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">128</TD><TD>                                                }</TD></TR><TR><TD CLASS="l">129</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">130</TD><TD>                                        catch (Exception e) {</TD></TR><TR CLASS="z"><TD CLASS="l">131</TD><TD>                                                Logger.logException(&#34;contributing to menu&#34;, e); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">132</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">133</TD><TD>                                }</TD></TR><TR><TD CLASS="l">134</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">135</TD><TD>                        if (debugContributeTime)</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="17">136</A></TD><TD>                                System.out.println(getClass().getName() + &#34;#contributeToMenu(): ran in &#34; + (System.currentTimeMillis() - time0) + &#34;ms&#34;); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR CLASS="z"><TD CLASS="l">137</TD><TD>                }</TD></TR><TR><TD CLASS="l">138</TD><TD> </TD></TR><TR><TD CLASS="l">139</TD><TD>                public void contributeToPopupMenu(IMenuManager menu) {</TD></TR><TR CLASS="z"><TD CLASS="l">140</TD><TD>                        long time0 = System.currentTimeMillis();</TD></TR><TR CLASS="z"><TD CLASS="l">141</TD><TD>                        for (int i = 0; i &lt; cache.size(); i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">142</TD><TD>                                Object obj = cache.get(i);</TD></TR><TR CLASS="z"><TD CLASS="l">143</TD><TD>                                if (obj instanceof IConfigurationElement) {</TD></TR><TR CLASS="z"><TD CLASS="l">144</TD><TD>                                        IConfigurationElement menuElement = (IConfigurationElement) obj;</TD></TR><TR CLASS="z"><TD CLASS="l">145</TD><TD>                                        if ((menuElement.getName()).equals(TAG_POPUPMENU)) {</TD></TR><TR CLASS="z"><TD CLASS="l">146</TD><TD>                                                contributeMenu(menuElement, menu, true);</TD></TR><TR><TD CLASS="l">147</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">148</TD><TD>                                }</TD></TR><TR CLASS="z"><TD CLASS="l">149</TD><TD>                                else if (obj instanceof ActionDescriptor) {</TD></TR><TR><TD CLASS="l">150</TD><TD>                                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">151</TD><TD>                                                ActionDescriptor ad = (ActionDescriptor) obj;</TD></TR><TR CLASS="z"><TD CLASS="l">152</TD><TD>                                                IAction a = ad.getAction();</TD></TR><TR CLASS="z"><TD CLASS="l">153</TD><TD>                                                if (a instanceof IExtendedEditorAction) {</TD></TR><TR><TD CLASS="l">154</TD><TD>                                                        // uncaught exceptions could cause the menu to not</TD></TR><TR><TD CLASS="l">155</TD><TD>                                                        // be shown</TD></TR><TR><TD CLASS="l">156</TD><TD>                                                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">157</TD><TD>                                                                if (((ad.getPopupMenuPath() != null) || (ad.getPopupMenuGroup() != null)) &amp;&amp; (a instanceof IExtendedEditorActionProxyForDelayLoading)) {</TD></TR><TR CLASS="z"><TD CLASS="l">158</TD><TD>                                                                    ((IExtendedEditorActionProxyForDelayLoading)a).realize();</TD></TR><TR><TD CLASS="l">159</TD><TD>                                                                }</TD></TR><TR><TD CLASS="l">160</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">161</TD><TD>                                                                IExtendedEditorAction eea = (IExtendedEditorAction) a;</TD></TR><TR CLASS="z"><TD CLASS="l">162</TD><TD>                                                                eea.setActiveExtendedEditor(activeExtendedEditor);</TD></TR><TR CLASS="z"><TD CLASS="l">163</TD><TD>                                                                eea.update();</TD></TR><TR CLASS="z"><TD CLASS="l">164</TD><TD>                                                                if (eea.isVisible()) {</TD></TR><TR CLASS="z"><TD CLASS="l">165</TD><TD>                                                                        IMenuManager parent = contributeMenuAction(ad, menu, true, true);</TD></TR><TR CLASS="z"><TD CLASS="l">166</TD><TD>                                                                        if (debugPopup &amp;&amp; parent != null)</TD></TR><TR CLASS="z"><TD CLASS="l">167</TD><TD>                                                                                System.out.println(getClass().getName() + &#34;#contributeToPopupMenu() added: &#34; + ad.getId()); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">168</TD><TD>                                                                }</TD></TR><TR><TD CLASS="l">169</TD><TD>                                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">170</TD><TD>                                                        catch (Exception e) {</TD></TR><TR CLASS="z"><TD CLASS="l">171</TD><TD>                                                                Logger.logException(e);</TD></TR><TR><TD CLASS="l">172</TD><TD>                                                        }</TD></TR><TR><TD CLASS="l">173</TD><TD> </TD></TR><TR><TD CLASS="l">174</TD><TD>                                                }</TD></TR><TR><TD CLASS="l">175</TD><TD>                                                else {</TD></TR><TR CLASS="z"><TD CLASS="l">176</TD><TD>                                                        IMenuManager parent = contributeMenuAction(ad, menu, true, true);</TD></TR><TR CLASS="z"><TD CLASS="l">177</TD><TD>                                                        if (debugPopup &amp;&amp; parent != null)</TD></TR><TR CLASS="z"><TD CLASS="l">178</TD><TD>                                                                System.out.println(getClass().getName() + &#34;#contributeToPopupMenu() added: &#34; + ad.getId()); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">179</TD><TD>                                                }</TD></TR><TR><TD CLASS="l">180</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">181</TD><TD>                                        catch (Exception e) {</TD></TR><TR CLASS="z"><TD CLASS="l">182</TD><TD>                                                Logger.logException(&#34;contributing to popup&#34;, e); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">183</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">184</TD><TD>                                }</TD></TR><TR><TD CLASS="l">185</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">186</TD><TD>                        if (debugContributeTime)</TD></TR><TR CLASS="z"><TD CLASS="l">187</TD><TD>                                System.out.println(getClass().getName() + &#34;#contributeToPopupMenu(): ran in &#34; + (System.currentTimeMillis() - time0) + &#34;ms&#34;); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="18">188</A></TD><TD>                }</TD></TR><TR><TD CLASS="l">189</TD><TD> </TD></TR><TR><TD CLASS="l">190</TD><TD>                public void contributeToStatusLine(IStatusLineManager manager) {</TD></TR><TR><TD CLASS="l"><A NAME="19">191</A></TD><TD>                        // nothing from here</TD></TR><TR CLASS="z"><TD CLASS="l">192</TD><TD>                }</TD></TR><TR><TD CLASS="l">193</TD><TD> </TD></TR><TR><TD CLASS="l">194</TD><TD>                public void contributeToToolBar(IToolBarManager manager) {</TD></TR><TR CLASS="z"><TD CLASS="l">195</TD><TD>                        long time0 = System.currentTimeMillis();</TD></TR><TR CLASS="z"><TD CLASS="l">196</TD><TD>                        for (int i = 0; i &lt; cache.size(); i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">197</TD><TD>                                Object obj = cache.get(i);</TD></TR><TR CLASS="z"><TD CLASS="l">198</TD><TD>                                if (obj instanceof ActionDescriptor) {</TD></TR><TR><TD CLASS="l">199</TD><TD>                                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">200</TD><TD>                                                ActionDescriptor ad = (ActionDescriptor) obj;</TD></TR><TR CLASS="z"><TD CLASS="l">201</TD><TD>                                                IAction a = ad.getAction();</TD></TR><TR CLASS="z"><TD CLASS="l">202</TD><TD>                                                if (a instanceof IExtendedEditorAction) {</TD></TR><TR CLASS="z"><TD CLASS="l">203</TD><TD>                                                        if (((ad.getToolbarPath() != null) || (ad.getToolbarGroup() != null)) &amp;&amp; (a instanceof IExtendedEditorActionProxyForDelayLoading)) {</TD></TR><TR CLASS="z"><TD CLASS="l">204</TD><TD>                                                            ((IExtendedEditorActionProxyForDelayLoading)a).realize();</TD></TR><TR><TD CLASS="l">205</TD><TD>                                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">206</TD><TD>                                                        IExtendedEditorAction eea = (IExtendedEditorAction) a;</TD></TR><TR CLASS="z"><TD CLASS="l">207</TD><TD>                                                        eea.setActiveExtendedEditor(activeExtendedEditor);</TD></TR><TR CLASS="z"><TD CLASS="l">208</TD><TD>                                                        eea.update();</TD></TR><TR CLASS="z"><TD CLASS="l">209</TD><TD>                                                        if (eea.isVisible()) {</TD></TR><TR CLASS="z"><TD CLASS="l">210</TD><TD>                                                                boolean contributed = contributeToolbarAction(ad, manager, true);</TD></TR><TR CLASS="z"><TD CLASS="l">211</TD><TD>                                                                if (debugToolbar &amp;&amp; contributed)</TD></TR><TR CLASS="z"><TD CLASS="l">212</TD><TD>                                                                        System.out.println(getClass().getName() + &#34;#contributeToToolBar() added: &#34; + ad.getId()); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">213</TD><TD>                                                        }</TD></TR><TR><TD CLASS="l">214</TD><TD>                                                        else {</TD></TR><TR CLASS="z"><TD CLASS="l">215</TD><TD>                                                                if (debugToolbar)</TD></TR><TR CLASS="z"><TD CLASS="l">216</TD><TD>                                                                        System.out.println(getClass().getName() + &#34;#contributeToToolBar(): [skipped] &#34; + ad.getId()); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">217</TD><TD>                                                        }</TD></TR><TR><TD CLASS="l">218</TD><TD>                                                }</TD></TR><TR><TD CLASS="l">219</TD><TD>                                                else {</TD></TR><TR CLASS="z"><TD CLASS="l">220</TD><TD>                                                        boolean contributed = contributeToolbarAction(ad, manager, true);</TD></TR><TR CLASS="z"><TD CLASS="l">221</TD><TD>                                                        if (debugToolbar &amp;&amp; contributed)</TD></TR><TR CLASS="z"><TD CLASS="l">222</TD><TD>                                                                System.out.println(getClass().getName() + &#34;#contributeToToolBar() added: &#34; + ad.getId()); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">223</TD><TD>                                                }</TD></TR><TR><TD CLASS="l">224</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">225</TD><TD>                                        catch (Exception e) {</TD></TR><TR CLASS="z"><TD CLASS="l">226</TD><TD>                                                Logger.logException(&#34;contributing to toolbar&#34;, e); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">227</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">228</TD><TD>                                }</TD></TR><TR><TD CLASS="l">229</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">230</TD><TD>                        if (debugContributeTime)</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="1a">231</A></TD><TD>                                System.out.println(getClass().getName() + &#34;#contributeToToolBar(): ran in &#34; + (System.currentTimeMillis() - time0) + &#34;ms&#34;); //$NON-NLS-1$ //$NON-NLS-2$</TD></TR><TR CLASS="z"><TD CLASS="l">232</TD><TD>                }</TD></TR><TR><TD CLASS="l">233</TD><TD> </TD></TR><TR><TD CLASS="l">234</TD><TD>                public void dispose() {</TD></TR><TR CLASS="z"><TD CLASS="l">235</TD><TD>                        Iterator it = menus.iterator();</TD></TR><TR CLASS="z"><TD CLASS="l">236</TD><TD>                        while (it.hasNext()) {</TD></TR><TR CLASS="z"><TD CLASS="l">237</TD><TD>                                Object o = it.next();</TD></TR><TR CLASS="z"><TD CLASS="l">238</TD><TD>                                if (o instanceof IMenuManager) {</TD></TR><TR CLASS="z"><TD CLASS="l">239</TD><TD>                                        ((IMenuManager) o).removeMenuListener(this);</TD></TR><TR><TD CLASS="l">240</TD><TD>                                }</TD></TR><TR><TD CLASS="l">241</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="1b">242</A></TD><TD>                }</TD></TR><TR><TD CLASS="l">243</TD><TD> </TD></TR><TR><TD CLASS="l">244</TD><TD>                public void init(IActionBars bars, IWorkbenchPage page) {</TD></TR><TR><TD CLASS="l">245</TD><TD>                        // nothing from here</TD></TR><TR CLASS="z"><TD CLASS="l">246</TD><TD>                }</TD></TR><TR><TD CLASS="l"><A NAME="1c">247</A></TD><TD> </TD></TR><TR><TD CLASS="l">248</TD><TD>                public void menuAboutToShow(IMenuManager menu) {</TD></TR><TR><TD CLASS="l">249</TD><TD>                        // slows down the menu and interferes with it for other editors;</TD></TR><TR><TD CLASS="l">250</TD><TD>                        // optimize on visibility</TD></TR><TR CLASS="z"><TD CLASS="l">251</TD><TD>                        IEditorSite site = null;</TD></TR><TR CLASS="z"><TD CLASS="l">252</TD><TD>                        boolean activeEditorIsVisible = false;</TD></TR><TR><TD CLASS="l">253</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">254</TD><TD>                        if (activeExtendedEditor != null &amp;&amp; activeExtendedEditor.getEditorPart() != null)</TD></TR><TR CLASS="z"><TD CLASS="l">255</TD><TD>                                site = activeExtendedEditor.getEditorPart().getEditorSite();</TD></TR><TR CLASS="z"><TD CLASS="l">256</TD><TD>                        if (site == null)</TD></TR><TR CLASS="z"><TD CLASS="l">257</TD><TD>                                return;</TD></TR><TR><TD CLASS="l">258</TD><TD> </TD></TR><TR><TD CLASS="l">259</TD><TD>                        // Eclipse bug 48784 - [MPE] ClassCast exception Workbench page</TD></TR><TR><TD CLASS="l">260</TD><TD>                        // isPartVisiable for MultiPageSite</TD></TR><TR CLASS="z"><TD CLASS="l">261</TD><TD>                        if (site instanceof MultiPageEditorSite) {</TD></TR><TR CLASS="z"><TD CLASS="l">262</TD><TD>                                Object multiPageEditor = ((MultiPageEditorSite) site).getMultiPageEditor();</TD></TR><TR CLASS="z"><TD CLASS="l">263</TD><TD>                                activeEditorIsVisible = multiPageEditor.equals(site.getPage().getActiveEditor()) || multiPageEditor.equals(site.getPage().getActivePart());</TD></TR><TR><TD CLASS="l">264</TD><TD>                        }</TD></TR><TR><TD CLASS="l">265</TD><TD>                        else {</TD></TR><TR CLASS="z"><TD CLASS="l">266</TD><TD>                                activeEditorIsVisible = site.getWorkbenchWindow().getPartService().getActivePart().equals(activeExtendedEditor.getEditorPart());</TD></TR><TR><TD CLASS="l">267</TD><TD>                        }</TD></TR><TR><TD CLASS="l">268</TD><TD>                        // due to a delay class loading, don't return now</TD></TR><TR><TD CLASS="l">269</TD><TD>//                        if (!activeEditorIsVisible)</TD></TR><TR><TD CLASS="l">270</TD><TD>//                                return;</TD></TR><TR><TD CLASS="l">271</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">272</TD><TD>                        IContributionItem[] items = menu.getItems();</TD></TR><TR CLASS="z"><TD CLASS="l">273</TD><TD>                        if (items == null || items.length == 0)</TD></TR><TR CLASS="z"><TD CLASS="l">274</TD><TD>                                return;</TD></TR><TR><TD CLASS="l">275</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">276</TD><TD>                        for (int i = 0; i &lt; items.length; ++i) {</TD></TR><TR><TD CLASS="l">277</TD><TD>                                // add menu listener to submenu</TD></TR><TR CLASS="z"><TD CLASS="l">278</TD><TD>                                if (items[i] instanceof IMenuManager) {</TD></TR><TR CLASS="z"><TD CLASS="l">279</TD><TD>                                        ((IMenuManager) items[i]).addMenuListener(this);</TD></TR><TR CLASS="z"><TD CLASS="l">280</TD><TD>                                        menus.add(items[i]);</TD></TR><TR><TD CLASS="l">281</TD><TD>                                }</TD></TR><TR><TD CLASS="l">282</TD><TD>                        }</TD></TR><TR><TD CLASS="l">283</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">284</TD><TD>                        Set keys = map.keySet();</TD></TR><TR CLASS="z"><TD CLASS="l">285</TD><TD>                        Iterator it = keys.iterator();</TD></TR><TR CLASS="z"><TD CLASS="l">286</TD><TD>                        boolean needActionContributionItemUpdate = false;</TD></TR><TR CLASS="z"><TD CLASS="l">287</TD><TD>                        while (it.hasNext()) {</TD></TR><TR CLASS="z"><TD CLASS="l">288</TD><TD>                                IContributionItem item = (IContributionItem) it.next();</TD></TR><TR CLASS="z"><TD CLASS="l">289</TD><TD>                                IMenuManager mm = (IMenuManager) map.get(item);</TD></TR><TR CLASS="z"><TD CLASS="l">290</TD><TD>                                if (menu.getId() != null &amp;&amp; menu.getId().equals(mm.getId()) &amp;&amp; item instanceof ActionContributionItem) {</TD></TR><TR><TD CLASS="l">291</TD><TD>                                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">292</TD><TD>                                                IAction action = ((ActionContributionItem) item).getAction();</TD></TR><TR><TD CLASS="l">293</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">294</TD><TD>                                                if (action instanceof IExtendedEditorActionProxyForDelayLoading) {</TD></TR><TR CLASS="z"><TD CLASS="l">295</TD><TD>                                                    IExtendedEditorActionProxyForDelayLoading eea = (IExtendedEditorActionProxyForDelayLoading)action;</TD></TR><TR CLASS="z"><TD CLASS="l">296</TD><TD>                                                    if (eea.isBundleActive() == true &amp;&amp; eea.isRealized() == false) {</TD></TR><TR CLASS="z"><TD CLASS="l">297</TD><TD>                                                        eea.realize();</TD></TR><TR CLASS="z"><TD CLASS="l">298</TD><TD>                                                        needActionContributionItemUpdate = true;</TD></TR><TR><TD CLASS="l">299</TD><TD>                                                    }</TD></TR><TR><TD CLASS="l">300</TD><TD>                                                }</TD></TR><TR><TD CLASS="l">301</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">302</TD><TD>                                                if (activeEditorIsVisible || needActionContributionItemUpdate) {</TD></TR><TR CLASS="z"><TD CLASS="l">303</TD><TD>                                                        if (action instanceof IUpdate) {</TD></TR><TR CLASS="z"><TD CLASS="l">304</TD><TD>                                                                ((IUpdate) action).update();</TD></TR><TR><TD CLASS="l">305</TD><TD>                                                        }</TD></TR><TR><TD CLASS="l">306</TD><TD>                                                }</TD></TR><TR><TD CLASS="l">307</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">308</TD><TD>                                                if (activeEditorIsVisible || needActionContributionItemUpdate) {</TD></TR><TR CLASS="z"><TD CLASS="l">309</TD><TD>                                                        boolean visible = true;</TD></TR><TR CLASS="z"><TD CLASS="l">310</TD><TD>                                                        if (action instanceof IExtendedEditorAction) {</TD></TR><TR CLASS="z"><TD CLASS="l">311</TD><TD>                                                                visible = ((IExtendedEditorAction) action).isVisible();</TD></TR><TR><TD CLASS="l">312</TD><TD>                                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">313</TD><TD>                                                        item.setVisible(visible);</TD></TR><TR><TD CLASS="l">314</TD><TD>                                                }</TD></TR><TR><TD CLASS="l">315</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">316</TD><TD>                                                if (needActionContributionItemUpdate) {</TD></TR><TR CLASS="z"><TD CLASS="l">317</TD><TD>                                                    ((ActionContributionItem)item).update();</TD></TR><TR><TD CLASS="l">318</TD><TD>                                                }</TD></TR><TR><TD CLASS="l">319</TD><TD> </TD></TR><TR><TD CLASS="l">320</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">321</TD><TD>                                        catch (Exception e) {</TD></TR><TR CLASS="z"><TD CLASS="l">322</TD><TD>                                                Logger.logException(&#34;updating actions&#34;, e); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">323</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">324</TD><TD>                                }</TD></TR><TR><TD CLASS="l">325</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">326</TD><TD>                        if (activeEditorIsVisible || needActionContributionItemUpdate) {</TD></TR><TR CLASS="z"><TD CLASS="l">327</TD><TD>                            if (needActionContributionItemUpdate) {</TD></TR><TR><TD CLASS="l">328</TD><TD>                                // the action is realized so that need to update the menu w/</TD></TR><TR><TD CLASS="l">329</TD><TD>                                // force set to true</TD></TR><TR CLASS="z"><TD CLASS="l">330</TD><TD>                                menu.update(true);</TD></TR><TR><TD CLASS="l">331</TD><TD>                            } else {</TD></TR><TR CLASS="z"><TD CLASS="l">332</TD><TD>                                menu.update(false);</TD></TR><TR><TD CLASS="l">333</TD><TD>                            }</TD></TR><TR><TD CLASS="l"><A NAME="1d">334</A></TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">335</TD><TD>                }</TD></TR><TR><TD CLASS="l">336</TD><TD> </TD></TR><TR><TD CLASS="l">337</TD><TD>                public void setActiveEditor(IEditorPart editor) {</TD></TR><TR CLASS="z"><TD CLASS="l">338</TD><TD>                        activeExtendedEditor = computeExtendedEditor(editor);</TD></TR><TR CLASS="z"><TD CLASS="l">339</TD><TD>                        IKeyBindingService svc = (editor != null) ? editor.getEditorSite().getKeyBindingService() : null;</TD></TR><TR CLASS="z"><TD CLASS="l">340</TD><TD>                        for (int i = 0; i &lt; cache.size(); i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">341</TD><TD>                                Object obj = cache.get(i);</TD></TR><TR CLASS="z"><TD CLASS="l">342</TD><TD>                                if (obj instanceof ActionDescriptor) {</TD></TR><TR CLASS="z"><TD CLASS="l">343</TD><TD>                                        ActionDescriptor ad = (ActionDescriptor) obj;</TD></TR><TR><TD CLASS="l">344</TD><TD>                                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">345</TD><TD>                                                IAction action = ad.getAction();</TD></TR><TR CLASS="z"><TD CLASS="l">346</TD><TD>                                                if (action instanceof IExtendedEditorAction) {</TD></TR><TR CLASS="z"><TD CLASS="l">347</TD><TD>                                                        ((IExtendedEditorAction) action).setActiveExtendedEditor(activeExtendedEditor);</TD></TR><TR CLASS="z"><TD CLASS="l">348</TD><TD>                                                        ((IExtendedEditorAction) action).update();</TD></TR><TR><TD CLASS="l">349</TD><TD>                                                        // update visibility right now so that the menu</TD></TR><TR><TD CLASS="l">350</TD><TD>                                                        // will show/hide properly</TD></TR><TR CLASS="z"><TD CLASS="l">351</TD><TD>                                                        if (!((IExtendedEditorAction) action).isVisible() &amp;&amp; ad.getContributionItem() != null)</TD></TR><TR CLASS="z"><TD CLASS="l">352</TD><TD>                                                                ad.getContributionItem().setVisible(false);</TD></TR><TR CLASS="z"><TD CLASS="l">353</TD><TD>                                                        if (svc != null &amp;&amp; action.getActionDefinitionId() != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">354</TD><TD>                                                                svc.registerAction(action);</TD></TR><TR><TD CLASS="l">355</TD><TD>                                                        }</TD></TR><TR><TD CLASS="l">356</TD><TD>                                                }</TD></TR><TR><TD CLASS="l">357</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">358</TD><TD>                                        catch (Exception e) {</TD></TR><TR CLASS="z"><TD CLASS="l">359</TD><TD>                                                Logger.logException(&#34;setting active editor on actions&#34;, e); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">360</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">361</TD><TD>                                }</TD></TR><TR><TD CLASS="l">362</TD><TD>                        }</TD></TR><TR><TD CLASS="l">363</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">364</TD><TD>                        if (menuBar != null &amp;&amp; editor != null) {</TD></TR><TR><TD CLASS="l">365</TD><TD>                                // Class clz = editor.getClass();</TD></TR><TR><TD CLASS="l">366</TD><TD>                                // while (clz != null) {</TD></TR><TR><TD CLASS="l">367</TD><TD>                                // if (clz.getName().equals(targetID)) {</TD></TR><TR><TD CLASS="l">368</TD><TD>                                // contributeToMenu(menuBar);</TD></TR><TR><TD CLASS="l">369</TD><TD>                                // break;</TD></TR><TR><TD CLASS="l">370</TD><TD>                                // }</TD></TR><TR><TD CLASS="l">371</TD><TD>                                // clz = clz.getSuperclass();</TD></TR><TR><TD CLASS="l">372</TD><TD>                                // }</TD></TR><TR CLASS="z"><TD CLASS="l">373</TD><TD>                                if (targetIDs.contains(editor.getEditorSite().getId())) {</TD></TR><TR CLASS="z"><TD CLASS="l">374</TD><TD>                                        contributeToMenu(menuBar);</TD></TR><TR><TD CLASS="l">375</TD><TD>                                }</TD></TR><TR><TD CLASS="l">376</TD><TD>                        }</TD></TR><TR><TD CLASS="l">377</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l"><A NAME="1e">378</A></TD><TD>                        updateToolbarActions();</TD></TR><TR CLASS="z"><TD CLASS="l">379</TD><TD>                }</TD></TR><TR><TD CLASS="l">380</TD><TD> </TD></TR><TR><TD CLASS="l">381</TD><TD>                public void updateToolbarActions() {</TD></TR><TR CLASS="z"><TD CLASS="l">382</TD><TD>                        for (int i = 0; i &lt; cache.size(); i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">383</TD><TD>                                Object obj = cache.get(i);</TD></TR><TR CLASS="z"><TD CLASS="l">384</TD><TD>                                if (obj instanceof ActionDescriptor) {</TD></TR><TR><TD CLASS="l">385</TD><TD>                                        try {</TD></TR><TR CLASS="z"><TD CLASS="l">386</TD><TD>                                                ActionDescriptor ad = (ActionDescriptor) obj;</TD></TR><TR CLASS="z"><TD CLASS="l">387</TD><TD>                                                if (ad.getToolbarPath() != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">388</TD><TD>                                                        IAction action = ad.getAction();</TD></TR><TR CLASS="z"><TD CLASS="l">389</TD><TD>                                                        if (action instanceof IUpdate) {</TD></TR><TR CLASS="z"><TD CLASS="l">390</TD><TD>                                                                ((IUpdate) action).update();</TD></TR><TR><TD CLASS="l">391</TD><TD>                                                        }</TD></TR><TR><TD CLASS="l">392</TD><TD>                                                }</TD></TR><TR><TD CLASS="l">393</TD><TD>                                        }</TD></TR><TR CLASS="z"><TD CLASS="l">394</TD><TD>                                        catch (Exception e) {</TD></TR><TR CLASS="z"><TD CLASS="l">395</TD><TD>                                                Logger.logException(&#34;updating toolbar actions&#34;, e); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">396</TD><TD>                                        }</TD></TR><TR><TD CLASS="l">397</TD><TD>                                }</TD></TR><TR><TD CLASS="l">398</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">399</TD><TD>                }</TD></TR><TR><TD CLASS="l">400</TD><TD>        }</TD></TR><TR><TD CLASS="l">401</TD><TD> </TD></TR><TR><TD CLASS="l">402</TD><TD>        public static final String ATT_ID = &#34;id&#34;; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">403</TD><TD>        public static final String ATT_LABEL = &#34;label&#34;; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l"><A NAME="0">404</A></TD><TD>        public static final String ATT_NAME = &#34;name&#34;; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">405</TD><TD>        public static final String ATT_PATH = &#34;path&#34;; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">406</TD><TD> </TD></TR><TR><TD CLASS="l">407</TD><TD>        public static final String ATT_TARGET_ID = &#34;targetID&#34;; //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">408</TD><TD>        protected final static boolean debugContributeTime = &#34;true&#34;.equalsIgnoreCase(Platform.getDebugOption(&#34;org.eclipse.wst.sse.ui/extendededitoractionbuilder/contributetime&#34;)); //$NON-NLS-1$  //$NON-NLS-2$</TD></TR><TR><TD CLASS="l">409</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">410</TD><TD>        protected final static boolean debugMenu = &#34;true&#34;.equalsIgnoreCase(Platform.getDebugOption(&#34;org.eclipse.wst.sse.ui/extendededitoractionbuilder/debugmenu&#34;)); //$NON-NLS-1$  //$NON-NLS-2$;</TD></TR><TR CLASS="z"><TD CLASS="l">411</TD><TD>        protected final static boolean debugPopup = &#34;true&#34;.equalsIgnoreCase(Platform.getDebugOption(&#34;org.eclipse.wst.sse.ui/extendededitoractionbuilder/debugpopup&#34;)); //$NON-NLS-1$  //$NON-NLS-2$;</TD></TR><TR CLASS="z"><TD CLASS="l">412</TD><TD>        protected final static boolean debugReadTime = &#34;true&#34;.equalsIgnoreCase(Platform.getDebugOption(&#34;org.eclipse.wst.sse.ui/extendededitoractionbuilder/readtime&#34;)); //$NON-NLS-1$  //$NON-NLS-2$</TD></TR><TR CLASS="z"><TD CLASS="l">413</TD><TD>        protected final static boolean debugToolbar = &#34;true&#34;.equalsIgnoreCase(Platform.getDebugOption(&#34;org.eclipse.wst.sse.ui/extendededitoractionbuilder/debugtoolbar&#34;)); //$NON-NLS-1$  //$NON-NLS-2$;</TD></TR><TR><TD CLASS="l">414</TD><TD> </TD></TR><TR><TD CLASS="l">415</TD><TD>        private static final String EXTENDED_EDITOR = &#34;extendedEditor&#34;; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">416</TD><TD> </TD></TR><TR><TD CLASS="l">417</TD><TD>        public static final String PL_EXTENDED_EDITOR_ACTIONS = &#34;extendedEditorActions&#34;; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">418</TD><TD> </TD></TR><TR><TD CLASS="l">419</TD><TD>        public static final String PLUGIN_ID = &#34;org.eclipse.wst.sse.ui&#34;; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">420</TD><TD>        public static final String TAG_ACTION = &#34;action&#34;; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">421</TD><TD> </TD></TR><TR><TD CLASS="l">422</TD><TD>        public static final String TAG_CONTRIBUTION_TYPE = &#34;editorContribution&#34;; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">423</TD><TD> </TD></TR><TR><TD CLASS="l">424</TD><TD>        public static final String TAG_MENU = &#34;menu&#34;; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">425</TD><TD>        public static final String TAG_POPUPMENU = &#34;popupmenu&#34;; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">426</TD><TD>        public static final String TAG_RULERMENU = &#34;rulermenu&#34;; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">427</TD><TD>        public static final String TAG_SEPARATOR = &#34;separator&#34;; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">428</TD><TD> </TD></TR><TR><TD CLASS="l">429</TD><TD>        protected List readingCache;</TD></TR><TR><TD CLASS="l">430</TD><TD> </TD></TR><TR><TD CLASS="l">431</TD><TD>        protected String targetContributionTag;</TD></TR><TR><TD CLASS="l">432</TD><TD>        protected List targetIDs;</TD></TR><TR><TD CLASS="l">433</TD><TD> </TD></TR><TR><TD CLASS="l"><A NAME="2">434</A></TD><TD>        /**</TD></TR><TR><TD CLASS="l">435</TD><TD>         * The constructor.</TD></TR><TR><TD CLASS="l">436</TD><TD>         */</TD></TR><TR><TD CLASS="l">437</TD><TD>        public ExtendedEditorActionBuilder() {</TD></TR><TR CLASS="z"><TD CLASS="l">438</TD><TD>                super();</TD></TR><TR CLASS="z"><TD CLASS="l">439</TD><TD>        }</TD></TR><TR><TD CLASS="l">440</TD><TD> </TD></TR><TR><TD CLASS="l">441</TD><TD>        /**</TD></TR><TR><TD CLASS="l">442</TD><TD>         * Creates a menu from the information in the menu configuration element</TD></TR><TR><TD CLASS="l">443</TD><TD>         * and adds it into the provided menu manager. If 'appendIfMissing' is</TD></TR><TR><TD CLASS="l">444</TD><TD>         * true, and menu path slot is not found, it will be created and menu will</TD></TR><TR><TD CLASS="l"><A NAME="3">445</A></TD><TD>         * be added into it. Otherwise, add operation will fail.</TD></TR><TR><TD CLASS="l">446</TD><TD>         */</TD></TR><TR><TD CLASS="l">447</TD><TD>        protected void contributeMenu(IConfigurationElement menuElement, IMenuManager mng, boolean appendIfMissing) {</TD></TR><TR><TD CLASS="l">448</TD><TD>                // Get config data.</TD></TR><TR CLASS="z"><TD CLASS="l">449</TD><TD>                String id = menuElement.getAttribute(ATT_ID);</TD></TR><TR CLASS="z"><TD CLASS="l">450</TD><TD>                String label = menuElement.getAttribute(ATT_LABEL);</TD></TR><TR CLASS="z"><TD CLASS="l">451</TD><TD>                String path = menuElement.getAttribute(ATT_PATH);</TD></TR><TR CLASS="z"><TD CLASS="l">452</TD><TD>                if (label == null) {</TD></TR><TR CLASS="z"><TD CLASS="l">453</TD><TD>                        Logger.log(Logger.ERROR, &#34;Invalid Menu Extension (label == null): &#34; + id); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">454</TD><TD>                        return;</TD></TR><TR><TD CLASS="l">455</TD><TD>                }</TD></TR><TR><TD CLASS="l">456</TD><TD> </TD></TR><TR><TD CLASS="l">457</TD><TD>                // Calculate menu path and group.</TD></TR><TR CLASS="z"><TD CLASS="l">458</TD><TD>                String group = null;</TD></TR><TR CLASS="z"><TD CLASS="l">459</TD><TD>                if (path != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">460</TD><TD>                        int loc = path.lastIndexOf('/');</TD></TR><TR CLASS="z"><TD CLASS="l">461</TD><TD>                        if (loc != -1) {</TD></TR><TR CLASS="z"><TD CLASS="l">462</TD><TD>                                group = path.substring(loc + 1);</TD></TR><TR CLASS="z"><TD CLASS="l">463</TD><TD>                                path = path.substring(0, loc);</TD></TR><TR><TD CLASS="l">464</TD><TD>                        }</TD></TR><TR><TD CLASS="l">465</TD><TD>                        else {</TD></TR><TR><TD CLASS="l">466</TD><TD>                                // assume that path represents a slot</TD></TR><TR><TD CLASS="l">467</TD><TD>                                // so actual path portion should be null</TD></TR><TR CLASS="z"><TD CLASS="l">468</TD><TD>                                group = path;</TD></TR><TR CLASS="z"><TD CLASS="l">469</TD><TD>                                path = null;</TD></TR><TR><TD CLASS="l">470</TD><TD>                        }</TD></TR><TR><TD CLASS="l">471</TD><TD>                }</TD></TR><TR><TD CLASS="l">472</TD><TD> </TD></TR><TR><TD CLASS="l">473</TD><TD>                // Find parent menu.</TD></TR><TR CLASS="z"><TD CLASS="l">474</TD><TD>                IMenuManager parent = mng;</TD></TR><TR CLASS="z"><TD CLASS="l">475</TD><TD>                if (path != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">476</TD><TD>                        parent = mng.findMenuUsingPath(path);</TD></TR><TR CLASS="z"><TD CLASS="l">477</TD><TD>                        if (parent == null) {</TD></TR><TR><TD CLASS="l">478</TD><TD>                                // Logger.log(&#34;Invalid Menu Extension (Path is invalid): &#34; +</TD></TR><TR><TD CLASS="l">479</TD><TD>                                // id);//$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">480</TD><TD>                                return;</TD></TR><TR><TD CLASS="l">481</TD><TD>                        }</TD></TR><TR><TD CLASS="l">482</TD><TD>                        // IMenuManager.findMenuUsingPath() returns invisible menu item if</TD></TR><TR><TD CLASS="l">483</TD><TD>                        // the manager can't find</TD></TR><TR><TD CLASS="l">484</TD><TD>                        // the specified path and create new MenuManager for it.</TD></TR><TR><TD CLASS="l">485</TD><TD>                        // I don't know this is a specification or bug.</TD></TR><TR><TD CLASS="l">486</TD><TD>                        // Anyway, to ensure the menu can be visible, setVisible(true)</TD></TR><TR><TD CLASS="l">487</TD><TD>                        // needs to be called.</TD></TR><TR CLASS="z"><TD CLASS="l">488</TD><TD>                        parent.setVisible(true);</TD></TR><TR><TD CLASS="l">489</TD><TD>                }</TD></TR><TR><TD CLASS="l">490</TD><TD> </TD></TR><TR><TD CLASS="l">491</TD><TD>                // Find reference group.</TD></TR><TR CLASS="z"><TD CLASS="l">492</TD><TD>                if (group == null)</TD></TR><TR CLASS="z"><TD CLASS="l">493</TD><TD>                        group = IWorkbenchActionConstants.MB_ADDITIONS;</TD></TR><TR CLASS="z"><TD CLASS="l">494</TD><TD>                IContributionItem sep = parent.find(group);</TD></TR><TR CLASS="z"><TD CLASS="l">495</TD><TD>                if (sep == null) {</TD></TR><TR CLASS="z"><TD CLASS="l">496</TD><TD>                        if (appendIfMissing)</TD></TR><TR CLASS="z"><TD CLASS="l">497</TD><TD>                                parent.add(new Separator(group));</TD></TR><TR><TD CLASS="l">498</TD><TD>                        else {</TD></TR><TR CLASS="z"><TD CLASS="l">499</TD><TD>                                Logger.log(Logger.ERROR, &#34;Invalid Menu Extension (Group is invalid): &#34; + id); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">500</TD><TD>                                return;</TD></TR><TR><TD CLASS="l">501</TD><TD>                        }</TD></TR><TR><TD CLASS="l">502</TD><TD>                }</TD></TR><TR><TD CLASS="l">503</TD><TD> </TD></TR><TR><TD CLASS="l">504</TD><TD>                // If the menu does not exist create it.</TD></TR><TR CLASS="z"><TD CLASS="l">505</TD><TD>                IMenuManager newMenu = parent.findMenuUsingPath(id);</TD></TR><TR CLASS="z"><TD CLASS="l">506</TD><TD>                if (newMenu == null)</TD></TR><TR CLASS="z"><TD CLASS="l">507</TD><TD>                        newMenu = new MenuManager(label, id);</TD></TR><TR><TD CLASS="l">508</TD><TD> </TD></TR><TR><TD CLASS="l">509</TD><TD>                // Create separators.</TD></TR><TR CLASS="z"><TD CLASS="l">510</TD><TD>                IConfigurationElement[] children = menuElement.getChildren(TAG_SEPARATOR);</TD></TR><TR CLASS="z"><TD CLASS="l">511</TD><TD>                for (int i = 0; i &lt; children.length; i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">512</TD><TD>                        contributeSeparator(newMenu, children[i]);</TD></TR><TR><TD CLASS="l">513</TD><TD>                }</TD></TR><TR><TD CLASS="l">514</TD><TD> </TD></TR><TR><TD CLASS="l">515</TD><TD>                // Add new menu</TD></TR><TR><TD CLASS="l">516</TD><TD>                try {</TD></TR><TR CLASS="z"><TD CLASS="l">517</TD><TD>                        parent.insertAfter(group, newMenu);</TD></TR><TR><TD CLASS="l">518</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">519</TD><TD>                catch (IllegalArgumentException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">520</TD><TD>                        Logger.log(Logger.ERROR, &#34;Invalid Menu Extension (Group is missing): &#34; + id); //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">521</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">522</TD><TD>        }</TD></TR><TR><TD CLASS="l">523</TD><TD> </TD></TR><TR><TD CLASS="l">524</TD><TD>        /**</TD></TR><TR><TD CLASS="l"><A NAME="4">525</A></TD><TD>         * Contributes action from action descriptor into the provided menu</TD></TR><TR><TD CLASS="l">526</TD><TD>         * manager.</TD></TR><TR><TD CLASS="l">527</TD><TD>         */</TD></TR><TR><TD CLASS="l">528</TD><TD>        protected IMenuManager contributeMenuAction(ActionDescriptor ad, IMenuManager menu, boolean appendIfMissing, boolean popupmenu) {</TD></TR><TR CLASS="z"><TD CLASS="l">529</TD><TD>                if (ad.getContributionItem() == null || ad.getAction() == null)</TD></TR><TR CLASS="z"><TD CLASS="l">530</TD><TD>                        return null;</TD></TR><TR><TD CLASS="l">531</TD><TD> </TD></TR><TR><TD CLASS="l">532</TD><TD>                // Get config data.</TD></TR><TR CLASS="z"><TD CLASS="l">533</TD><TD>                String mpath = popupmenu ? ad.getPopupMenuPath() : ad.getMenuPath();</TD></TR><TR CLASS="z"><TD CLASS="l">534</TD><TD>                String mgroup = popupmenu ? ad.getPopupMenuGroup() : ad.getMenuGroup();</TD></TR><TR CLASS="z"><TD CLASS="l">535</TD><TD>                if (mpath == null &amp;&amp; mgroup == null)</TD></TR><TR CLASS="z"><TD CLASS="l">536</TD><TD>                        return null;</TD></TR><TR><TD CLASS="l">537</TD><TD> </TD></TR><TR><TD CLASS="l">538</TD><TD>                // Find parent menu.</TD></TR><TR CLASS="z"><TD CLASS="l">539</TD><TD>                IMenuManager parent = menu;</TD></TR><TR CLASS="z"><TD CLASS="l">540</TD><TD>                if (mpath != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">541</TD><TD>                        parent = parent.findMenuUsingPath(mpath);</TD></TR><TR CLASS="z"><TD CLASS="l">542</TD><TD>                        if (parent == null) {</TD></TR><TR><TD CLASS="l">543</TD><TD>                                // Logger.log(&#34;Invalid Menu Extension (Path is invalid): &#34; +</TD></TR><TR><TD CLASS="l">544</TD><TD>                                // ad.getId()); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">545</TD><TD>                                return null;</TD></TR><TR><TD CLASS="l">546</TD><TD>                        }</TD></TR><TR><TD CLASS="l">547</TD><TD>                        // IMenuManager.findMenuUsingPath() returns invisible menu item if</TD></TR><TR><TD CLASS="l">548</TD><TD>                        // the manager can't find</TD></TR><TR><TD CLASS="l">549</TD><TD>                        // the specified path and create new MenuManager for it.</TD></TR><TR><TD CLASS="l">550</TD><TD>                        // I don't know this is a specification or bug.</TD></TR><TR><TD CLASS="l">551</TD><TD>                        // Anyway, to ensure the menu can be visible, setVisible(true)</TD></TR><TR><TD CLASS="l">552</TD><TD>                        // needs to be called.</TD></TR><TR CLASS="z"><TD CLASS="l">553</TD><TD>                        parent.setVisible(true);</TD></TR><TR><TD CLASS="l">554</TD><TD>                }</TD></TR><TR><TD CLASS="l">555</TD><TD> </TD></TR><TR><TD CLASS="l">556</TD><TD>                // First remove existing menu item</TD></TR><TR CLASS="z"><TD CLASS="l">557</TD><TD>                IContributionItem item = parent.find(ad.getId());</TD></TR><TR CLASS="z"><TD CLASS="l">558</TD><TD>                if (item != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">559</TD><TD>                        parent.remove(ad.getId());</TD></TR><TR><TD CLASS="l">560</TD><TD>                }</TD></TR><TR><TD CLASS="l">561</TD><TD> </TD></TR><TR><TD CLASS="l">562</TD><TD>                // Find reference group.</TD></TR><TR CLASS="z"><TD CLASS="l">563</TD><TD>                if (mgroup == null)</TD></TR><TR CLASS="z"><TD CLASS="l">564</TD><TD>                        mgroup = IWorkbenchActionConstants.MB_ADDITIONS;</TD></TR><TR CLASS="z"><TD CLASS="l">565</TD><TD>                IContributionItem sep = parent.find(mgroup);</TD></TR><TR CLASS="z"><TD CLASS="l">566</TD><TD>                if (sep == null) {</TD></TR><TR CLASS="z"><TD CLASS="l">567</TD><TD>                        if (appendIfMissing)</TD></TR><TR CLASS="z"><TD CLASS="l">568</TD><TD>                                parent.add(sep = new Separator(mgroup));</TD></TR><TR><TD CLASS="l">569</TD><TD>                        else {</TD></TR><TR CLASS="z"><TD CLASS="l">570</TD><TD>                                Logger.log(Logger.ERROR, &#34;Invalid Menu Extension (Group is invalid): &#34; + ad.getId()); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">571</TD><TD>                                return null;</TD></TR><TR><TD CLASS="l">572</TD><TD>                        }</TD></TR><TR><TD CLASS="l">573</TD><TD>                }</TD></TR><TR><TD CLASS="l">574</TD><TD> </TD></TR><TR><TD CLASS="l">575</TD><TD>                // Add action.</TD></TR><TR><TD CLASS="l">576</TD><TD>                try {</TD></TR><TR CLASS="z"><TD CLASS="l">577</TD><TD>                        if (popupmenu) {</TD></TR><TR><TD CLASS="l">578</TD><TD>                                // Context menu need a newly created contribution item</TD></TR><TR CLASS="z"><TD CLASS="l">579</TD><TD>                                if (sep != null &amp;&amp; sep.isGroupMarker())</TD></TR><TR CLASS="z"><TD CLASS="l">580</TD><TD>                                        parent.appendToGroup(sep.getId(), ad.getAction());</TD></TR><TR><TD CLASS="l">581</TD><TD>                                else</TD></TR><TR CLASS="z"><TD CLASS="l">582</TD><TD>                                        parent.insertAfter(mgroup, ad.getAction());</TD></TR><TR><TD CLASS="l">583</TD><TD>                        }</TD></TR><TR><TD CLASS="l">584</TD><TD>                        else {</TD></TR><TR><TD CLASS="l">585</TD><TD>                                // Normal menu need to add existing contribution item to</TD></TR><TR><TD CLASS="l">586</TD><TD>                                // remove it from menu listener</TD></TR><TR CLASS="z"><TD CLASS="l">587</TD><TD>                                if (sep != null &amp;&amp; sep.isGroupMarker())</TD></TR><TR CLASS="z"><TD CLASS="l">588</TD><TD>                                        parent.appendToGroup(sep.getId(), ad.getContributionItem());</TD></TR><TR><TD CLASS="l">589</TD><TD>                                else</TD></TR><TR CLASS="z"><TD CLASS="l">590</TD><TD>                                        parent.insertAfter(mgroup, ad.getContributionItem());</TD></TR><TR><TD CLASS="l">591</TD><TD>                        }</TD></TR><TR><TD CLASS="l">592</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">593</TD><TD>                catch (IllegalArgumentException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">594</TD><TD>                        Logger.log(Logger.ERROR, &#34;Invalid Menu Extension (Group is missing): &#34; + ad.getId()); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">595</TD><TD>                        parent = null;</TD></TR><TR><TD CLASS="l">596</TD><TD>                }</TD></TR><TR><TD CLASS="l">597</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">598</TD><TD>                return parent;</TD></TR><TR><TD CLASS="l">599</TD><TD>        }</TD></TR><TR><TD CLASS="l">600</TD><TD> </TD></TR><TR><TD CLASS="l">601</TD><TD>        /**</TD></TR><TR><TD CLASS="l">602</TD><TD>         * Creates a named menu separator from the information in the</TD></TR><TR><TD CLASS="l"><A NAME="5">603</A></TD><TD>         * configuration element. If the separator already exists do not create a</TD></TR><TR><TD CLASS="l">604</TD><TD>         * second.</TD></TR><TR><TD CLASS="l">605</TD><TD>         */</TD></TR><TR><TD CLASS="l">606</TD><TD>        protected boolean contributeSeparator(IMenuManager menu, IConfigurationElement element) {</TD></TR><TR CLASS="z"><TD CLASS="l">607</TD><TD>                String id = element.getAttribute(ATT_NAME);</TD></TR><TR CLASS="z"><TD CLASS="l">608</TD><TD>                if (id == null || id.length() &lt;= 0)</TD></TR><TR CLASS="z"><TD CLASS="l">609</TD><TD>                        return false;</TD></TR><TR CLASS="z"><TD CLASS="l">610</TD><TD>                IContributionItem sep = menu.find(id);</TD></TR><TR CLASS="z"><TD CLASS="l">611</TD><TD>                if (sep != null)</TD></TR><TR CLASS="z"><TD CLASS="l">612</TD><TD>                        return false;</TD></TR><TR CLASS="z"><TD CLASS="l">613</TD><TD>                menu.add(new Separator(id));</TD></TR><TR CLASS="z"><TD CLASS="l">614</TD><TD>                return true;</TD></TR><TR><TD CLASS="l">615</TD><TD>        }</TD></TR><TR><TD CLASS="l">616</TD><TD> </TD></TR><TR><TD CLASS="l">617</TD><TD>        /**</TD></TR><TR><TD CLASS="l"><A NAME="6">618</A></TD><TD>         * Contributes action from the action descriptor into the provided tool</TD></TR><TR><TD CLASS="l">619</TD><TD>         * bar manager.</TD></TR><TR><TD CLASS="l">620</TD><TD>         */</TD></TR><TR><TD CLASS="l">621</TD><TD>        protected boolean contributeToolbarAction(ActionDescriptor ad, IToolBarManager toolbar, boolean appendIfMissing) {</TD></TR><TR CLASS="z"><TD CLASS="l">622</TD><TD>                if (ad.getContributionItem() == null || ad.getAction() == null)</TD></TR><TR CLASS="z"><TD CLASS="l">623</TD><TD>                        return false;</TD></TR><TR><TD CLASS="l">624</TD><TD> </TD></TR><TR><TD CLASS="l">625</TD><TD>                // Get config data.</TD></TR><TR CLASS="z"><TD CLASS="l">626</TD><TD>                String tpath = ad.getToolbarPath();</TD></TR><TR CLASS="z"><TD CLASS="l">627</TD><TD>                String tgroup = ad.getToolbarGroup();</TD></TR><TR CLASS="z"><TD CLASS="l">628</TD><TD>                if (tpath == null &amp;&amp; tgroup == null)</TD></TR><TR CLASS="z"><TD CLASS="l">629</TD><TD>                        return false;</TD></TR><TR><TD CLASS="l">630</TD><TD> </TD></TR><TR><TD CLASS="l">631</TD><TD>                // First remove existing toolbar item</TD></TR><TR CLASS="z"><TD CLASS="l">632</TD><TD>                IContributionItem item = toolbar.find(ad.getId());</TD></TR><TR CLASS="z"><TD CLASS="l">633</TD><TD>                if (item != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">634</TD><TD>                        toolbar.remove(ad.getId());</TD></TR><TR><TD CLASS="l">635</TD><TD>                }</TD></TR><TR><TD CLASS="l">636</TD><TD> </TD></TR><TR><TD CLASS="l">637</TD><TD>                // Find reference group.</TD></TR><TR CLASS="z"><TD CLASS="l">638</TD><TD>                if (tgroup == null)</TD></TR><TR CLASS="z"><TD CLASS="l">639</TD><TD>                        tgroup = IWorkbenchActionConstants.MB_ADDITIONS;</TD></TR><TR CLASS="z"><TD CLASS="l">640</TD><TD>                IContributionItem sep = toolbar.find(tgroup);</TD></TR><TR CLASS="z"><TD CLASS="l">641</TD><TD>                if (sep == null) {</TD></TR><TR CLASS="z"><TD CLASS="l">642</TD><TD>                        if (appendIfMissing)</TD></TR><TR CLASS="z"><TD CLASS="l">643</TD><TD>                                toolbar.add(new Separator(tgroup));</TD></TR><TR><TD CLASS="l">644</TD><TD>                        else {</TD></TR><TR CLASS="z"><TD CLASS="l">645</TD><TD>                                Logger.log(Logger.ERROR, &#34;Invalid Toolbar Extension (Group is invalid): &#34; + ad.getId()); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">646</TD><TD>                                return false;</TD></TR><TR><TD CLASS="l">647</TD><TD>                        }</TD></TR><TR><TD CLASS="l">648</TD><TD>                }</TD></TR><TR><TD CLASS="l">649</TD><TD> </TD></TR><TR><TD CLASS="l">650</TD><TD>                // Add action to tool bar.</TD></TR><TR><TD CLASS="l">651</TD><TD>                try {</TD></TR><TR CLASS="z"><TD CLASS="l">652</TD><TD>                        if (sep != null &amp;&amp; sep.isGroupMarker())</TD></TR><TR CLASS="z"><TD CLASS="l">653</TD><TD>                                toolbar.appendToGroup(sep.getId(), ad.getAction());</TD></TR><TR><TD CLASS="l">654</TD><TD>                        else</TD></TR><TR CLASS="z"><TD CLASS="l">655</TD><TD>                                toolbar.insertAfter(tgroup, ad.getAction());</TD></TR><TR><TD CLASS="l">656</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">657</TD><TD>                catch (IllegalArgumentException e) {</TD></TR><TR CLASS="z"><TD CLASS="l">658</TD><TD>                        Logger.log(Logger.ERROR, &#34;Invalid Toolbar Extension (Group is missing): &#34; + ad.getId()); //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">659</TD><TD>                        return false;</TD></TR><TR><TD CLASS="l">660</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">661</TD><TD>                return true;</TD></TR><TR><TD CLASS="l">662</TD><TD>        }</TD></TR><TR><TD CLASS="l">663</TD><TD> </TD></TR><TR><TD CLASS="l">664</TD><TD>        /**</TD></TR><TR><TD CLASS="l"><A NAME="7">665</A></TD><TD>         * This factory method returns a new ActionDescriptor for the</TD></TR><TR><TD CLASS="l">666</TD><TD>         * configuration element. It should be implemented by subclasses.</TD></TR><TR><TD CLASS="l">667</TD><TD>         */</TD></TR><TR><TD CLASS="l">668</TD><TD>        protected ActionDescriptor createActionDescriptor(IConfigurationElement element) {</TD></TR><TR CLASS="z"><TD CLASS="l">669</TD><TD>                ActionDescriptor ad = null;</TD></TR><TR><TD CLASS="l">670</TD><TD>                try {</TD></TR><TR CLASS="z"><TD CLASS="l">671</TD><TD>                        ad = new ActionDescriptor(element);</TD></TR><TR><TD CLASS="l">672</TD><TD>                        // these cases like &#34;class not found&#34; are handled</TD></TR><TR><TD CLASS="l">673</TD><TD>                        // at lower level, so no action if formed. In that</TD></TR><TR><TD CLASS="l">674</TD><TD>                        // case, we also don't want to form an action descriptor.</TD></TR><TR CLASS="z"><TD CLASS="l">675</TD><TD>                        if ((ad != null) &amp;&amp; (ad.getAction() == null)) {</TD></TR><TR CLASS="z"><TD CLASS="l">676</TD><TD>                                ad = null;</TD></TR><TR><TD CLASS="l">677</TD><TD>                        }</TD></TR><TR><TD CLASS="l">678</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">679</TD><TD>                catch (Exception e) {</TD></TR><TR CLASS="z"><TD CLASS="l">680</TD><TD>                        Logger.traceException(EXTENDED_EDITOR, e);</TD></TR><TR CLASS="z"><TD CLASS="l">681</TD><TD>                        ad = null;</TD></TR><TR><TD CLASS="l">682</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">683</TD><TD>                return ad;</TD></TR><TR><TD CLASS="l">684</TD><TD>        }</TD></TR><TR><TD CLASS="l">685</TD><TD> </TD></TR><TR><TD CLASS="l">686</TD><TD>        /**</TD></TR><TR><TD CLASS="l"><A NAME="8">687</A></TD><TD>         * Returns the name of the part ID attribute that is expected in the</TD></TR><TR><TD CLASS="l">688</TD><TD>         * target extension.</TD></TR><TR><TD CLASS="l">689</TD><TD>         */</TD></TR><TR><TD CLASS="l">690</TD><TD>        protected String getTargetID(IConfigurationElement element) {</TD></TR><TR CLASS="z"><TD CLASS="l">691</TD><TD>                String value = element.getAttribute(ATT_TARGET_ID);</TD></TR><TR CLASS="z"><TD CLASS="l">692</TD><TD>                return value != null ? value : &#34;???&#34;; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">693</TD><TD>        }</TD></TR><TR><TD CLASS="l">694</TD><TD> </TD></TR><TR><TD CLASS="l">695</TD><TD>        /**</TD></TR><TR><TD CLASS="l">696</TD><TD>         * Reads editor contributor if specified directly in the 'editor'</TD></TR><TR><TD CLASS="l"><A NAME="a">697</A></TD><TD>         * extension point, and all external contributions for this editor's ID</TD></TR><TR><TD CLASS="l">698</TD><TD>         * registered in 'editorActions' extension point.</TD></TR><TR><TD CLASS="l">699</TD><TD>         */</TD></TR><TR><TD CLASS="l">700</TD><TD>        public IExtendedContributor readActionExtensions(String editorId) {</TD></TR><TR CLASS="z"><TD CLASS="l">701</TD><TD>                return readActionExtensions(new String[]{editorId});</TD></TR><TR><TD CLASS="l">702</TD><TD>        }</TD></TR><TR><TD CLASS="l">703</TD><TD> </TD></TR><TR><TD CLASS="l">704</TD><TD>        /**</TD></TR><TR><TD CLASS="l">705</TD><TD>         * Reads editor contributor if specified directly in the 'editor'</TD></TR><TR><TD CLASS="l"><A NAME="9">706</A></TD><TD>         * extension point, and all external contributions for this editor's ID</TD></TR><TR><TD CLASS="l">707</TD><TD>         * registered in 'editorActions' extension point.</TD></TR><TR><TD CLASS="l">708</TD><TD>         */</TD></TR><TR><TD CLASS="l">709</TD><TD>        public IExtendedContributor readActionExtensions(String[] ids) {</TD></TR><TR CLASS="z"><TD CLASS="l">710</TD><TD>                long time0 = System.currentTimeMillis();</TD></TR><TR CLASS="z"><TD CLASS="l">711</TD><TD>                ExtendedContributor ext = null;</TD></TR><TR CLASS="z"><TD CLASS="l">712</TD><TD>                readContributions(ids, TAG_CONTRIBUTION_TYPE, PL_EXTENDED_EDITOR_ACTIONS);</TD></TR><TR CLASS="z"><TD CLASS="l">713</TD><TD>                if (debugReadTime) {</TD></TR><TR CLASS="z"><TD CLASS="l">714</TD><TD>                        String idlist = &#34;&#34;; //$NON-NLS-1$</TD></TR><TR CLASS="z"><TD CLASS="l">715</TD><TD>                        if (ids.length &gt; 0) {</TD></TR><TR CLASS="z"><TD CLASS="l">716</TD><TD>                                for (int i = 0; i &lt; ids.length; i++) {</TD></TR><TR CLASS="z"><TD CLASS="l">717</TD><TD>                                        idlist += ids[i];</TD></TR><TR CLASS="z"><TD CLASS="l">718</TD><TD>                                        if (i &lt; ids.length - 1)</TD></TR><TR CLASS="z"><TD CLASS="l">719</TD><TD>                                                idlist += &#34;,&#34;; //$NON-NLS-1$</TD></TR><TR><TD CLASS="l">720</TD><TD>                                }</TD></TR><TR><TD CLASS="l">721</TD><TD>                        }</TD></TR><TR CLASS="z"><TD CLASS="l">722</TD><TD>                        System.out.println(getClass().getName() + &#34;#readActionExtensions(&#34; + idlist + &#34;): read in &#34; + (System.currentTimeMillis() - time0) + &#34;ms [&#34; + (readingCache != null ? readingCache.size() : 0) + &#34; contributions]&#34;); //$NON-NLS-1$ //$NON-NLS-2$ //$NON-NLS-3$ //$NON-NLS-4$</TD></TR><TR><TD CLASS="l">723</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">724</TD><TD>                if (readingCache != null) {</TD></TR><TR CLASS="z"><TD CLASS="l">725</TD><TD>                        ext = new ExtendedContributor(readingCache);</TD></TR><TR CLASS="z"><TD CLASS="l">726</TD><TD>                        readingCache = null;</TD></TR><TR><TD CLASS="l">727</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">728</TD><TD>                return ext;</TD></TR><TR><TD CLASS="l">729</TD><TD>        }</TD></TR><TR><TD CLASS="l">730</TD><TD> </TD></TR><TR><TD CLASS="l">731</TD><TD>        /**</TD></TR><TR><TD CLASS="l"><A NAME="b">732</A></TD><TD>         * Reads the contributions from the registry for the provided workbench</TD></TR><TR><TD CLASS="l">733</TD><TD>         * part and the provided extension point IDs.</TD></TR><TR><TD CLASS="l">734</TD><TD>         */</TD></TR><TR><TD CLASS="l">735</TD><TD>        protected void readContributions(String[] ids, String tag, String extensionPoint) {</TD></TR><TR CLASS="z"><TD CLASS="l">736</TD><TD>                readingCache = null;</TD></TR><TR CLASS="z"><TD CLASS="l">737</TD><TD>                targetIDs = Arrays.asList(ids);</TD></TR><TR CLASS="z"><TD CLASS="l">738</TD><TD>                targetContributionTag = tag;</TD></TR><TR CLASS="z"><TD CLASS="l">739</TD><TD>                IExtensionRegistry registry = Platform.getExtensionRegistry();</TD></TR><TR CLASS="z"><TD CLASS="l">740</TD><TD>                readRegistry(registry, PLUGIN_ID, extensionPoint);</TD></TR><TR CLASS="z"><TD CLASS="l">741</TD><TD>        }</TD></TR><TR><TD CLASS="l">742</TD><TD> </TD></TR><TR><TD CLASS="l">743</TD><TD>        /**</TD></TR><TR><TD CLASS="l"><A NAME="c">744</A></TD><TD>         * Implements abstract method to handle the provided XML element in the</TD></TR><TR><TD CLASS="l">745</TD><TD>         * registry.</TD></TR><TR><TD CLASS="l">746</TD><TD>         */</TD></TR><TR><TD CLASS="l">747</TD><TD>        protected boolean readElement(IConfigurationElement element) {</TD></TR><TR CLASS="z"><TD CLASS="l">748</TD><TD>                String tag = element.getName();</TD></TR><TR CLASS="z"><TD CLASS="l">749</TD><TD>                if (tag.equals(targetContributionTag)) {</TD></TR><TR CLASS="z"><TD CLASS="l">750</TD><TD>                        String id = getTargetID(element);</TD></TR><TR CLASS="z"><TD CLASS="l">751</TD><TD>                        if (id == null || !targetIDs.contains(id)) {</TD></TR><TR><TD CLASS="l">752</TD><TD>                                // This is not of interest to us - don't go deeper</TD></TR><TR CLASS="z"><TD CLASS="l">753</TD><TD>                                return true;</TD></TR><TR><TD CLASS="l">754</TD><TD>                        }</TD></TR><TR><TD CLASS="l">755</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">756</TD><TD>                else if (tag.equals(TAG_MENU)) {</TD></TR><TR CLASS="z"><TD CLASS="l">757</TD><TD>                        if (readingCache == null)</TD></TR><TR CLASS="z"><TD CLASS="l">758</TD><TD>                                readingCache = new ArrayList();</TD></TR><TR CLASS="z"><TD CLASS="l">759</TD><TD>                        readingCache.add(element);</TD></TR><TR CLASS="z"><TD CLASS="l">760</TD><TD>                        return true; // just cache the element - don't go into it</TD></TR><TR><TD CLASS="l">761</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">762</TD><TD>                else if (tag.equals(TAG_POPUPMENU)) {</TD></TR><TR CLASS="z"><TD CLASS="l">763</TD><TD>                        if (readingCache == null)</TD></TR><TR CLASS="z"><TD CLASS="l">764</TD><TD>                                readingCache = new ArrayList();</TD></TR><TR CLASS="z"><TD CLASS="l">765</TD><TD>                        readingCache.add(element);</TD></TR><TR CLASS="z"><TD CLASS="l">766</TD><TD>                        return true; // just cache the element - don't go into it</TD></TR><TR><TD CLASS="l">767</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">768</TD><TD>                else if (tag.equals(TAG_RULERMENU)) {</TD></TR><TR CLASS="z"><TD CLASS="l">769</TD><TD>                        if (readingCache == null)</TD></TR><TR CLASS="z"><TD CLASS="l">770</TD><TD>                                readingCache = new ArrayList();</TD></TR><TR CLASS="z"><TD CLASS="l">771</TD><TD>                        readingCache.add(element);</TD></TR><TR CLASS="z"><TD CLASS="l">772</TD><TD>                        return true; // just cache the element - don't go into it</TD></TR><TR><TD CLASS="l">773</TD><TD>                }</TD></TR><TR CLASS="z"><TD CLASS="l">774</TD><TD>                else if (tag.equals(TAG_ACTION)) {</TD></TR><TR CLASS="z"><TD CLASS="l">775</TD><TD>                        if (readingCache == null)</TD></TR><TR CLASS="z"><TD CLASS="l">776</TD><TD>                                readingCache = new ArrayList();</TD></TR><TR CLASS="z"><TD CLASS="l">777</TD><TD>                        ActionDescriptor ad = createActionDescriptor(element);</TD></TR><TR CLASS="z"><TD CLASS="l">778</TD><TD>                        if (ad != null)</TD></TR><TR CLASS="z"><TD CLASS="l">779</TD><TD>                                readingCache.add(ad);</TD></TR><TR CLASS="z"><TD CLASS="l">780</TD><TD>                        return true; // just cache the action - don't go into</TD></TR><TR><TD CLASS="l">781</TD><TD>                }</TD></TR><TR><TD CLASS="l">782</TD><TD>                else {</TD></TR><TR CLASS="z"><TD CLASS="l">783</TD><TD>                        return false;</TD></TR><TR><TD CLASS="l">784</TD><TD>                }</TD></TR><TR><TD CLASS="l">785</TD><TD> </TD></TR><TR CLASS="z"><TD CLASS="l">786</TD><TD>                readElementChildren(element);</TD></TR><TR CLASS="z"><TD CLASS="l">787</TD><TD>                return true;</TD></TR><TR><TD CLASS="l">788</TD><TD>        }</TD></TR><TR><TD CLASS="l">789</TD><TD>}</TD></TR></TABLE><P></P><TABLE CLASS="hdft" CELLSPACING="0" WIDTH="100%"><TR><TD CLASS="nv">[<A HREF="../xslUnitTestCoverage.html">all classes</A>][<A HREF="7e.html">org.eclipse.wst.sse.ui.internal</A>]</TD></TR><TR><TD CLASS="tl"><A HREF="http://www.eclemma.org/support.html">EMMA 2.0.5312 EclEmma Fix 1</A> (C) Vladimir Roubtsov</TD></TR></TABLE></BODY></HTML>