Fix bugs #725 and releted #744
[phpeclipse.git] / net.sourceforge.phpeclipse.webbrowser / src / net / sourceforge / phpeclipse / webbrowser / WebBrowserEditorInput.java
index aeec7e4..1f4681f 100644 (file)
@@ -4,7 +4,7 @@
  * are made available under the terms of the Common Public License v1.0
  * which accompanies this distribution, and is available at
  * http://www.eclipse.org/legal/cpl-v10.html
- *
+ �*
  * Contributors:
  *    IBM - Initial API and implementation
  */
@@ -22,10 +22,12 @@ import org.eclipse.jface.resource.ImageDescriptor;
 import org.eclipse.ui.IElementFactory;
 import org.eclipse.ui.IMemento;
 import org.eclipse.ui.IPersistableElement;
+
 /**
  * The editor input for the integrated web browser.
  */
-public class WebBrowserEditorInput implements IWebBrowserEditorInput, IPersistableElement, IElementFactory {
+public class WebBrowserEditorInput implements IWebBrowserEditorInput,
+               IPersistableElement, IElementFactory {
        // --- constants to pass into constructor ---
 
        // if used, the toolbar will be available
@@ -42,7 +44,7 @@ public class WebBrowserEditorInput implements IWebBrowserEditorInput, IPersistab
        // the page can reopen to the same URL after
        // shutting down
        public static final int SAVE_URL = 1 << 5;
-       
+
        // if used, the browser will be transient and will not appear
        // in the most recently used file list, nor will it reopen after
        // restarting Eclipse
@@ -51,12 +53,17 @@ public class WebBrowserEditorInput implements IWebBrowserEditorInput, IPersistab
        public static final int SHOW_ALL = SHOW_TOOLBAR | SHOW_STATUSBAR;
 
        private static final String ELEMENT_FACTORY_ID = "net.sourceforge.phpeclipse.webbrowser.elementFactory";
+
        private static final String MEMENTO_URL = "url";
+
        private static final String MEMENTO_STYLE = "style";
+
        private static final String MEMENTO_ID = "id";
 
        private URL url;
+
        private int style;
+
        private String id = null;
 
        /**
@@ -98,13 +105,13 @@ public class WebBrowserEditorInput implements IWebBrowserEditorInput, IPersistab
        public WebBrowserEditorInput(URL url, boolean b) {
                this(url);
        }
-       
+
        /**
-        * Returns true if this page can reuse the browser that the
-        * given input is being displayed in, or false if it should
-        * open up in a new page.
-        *
-        * @param input net.sourceforge.phpeclipse.webbrowser.IWebBrowserEditorInput
+        * Returns true if this page can reuse the browser that the given input is
+        * being displayed in, or false if it should open up in a new page.
+        * 
+        * @param input
+        *            net.sourceforge.phpeclipse.webbrowser.IWebBrowserEditorInput
         * @return boolean
         */
        public boolean canReplaceInput(IWebBrowserEditorInput input) {
@@ -123,13 +130,15 @@ public class WebBrowserEditorInput implements IWebBrowserEditorInput, IPersistab
                } else
                        return false;
        }
-       
+
        /**
-        * Creates an <code>IElement</code> from the state captured within 
-        * an <code>IMemento</code>.
-        *
-        * @param memento a memento containing the state for an element
-        * @return an element, or <code>null</code> if the element could not be created
+        * Creates an <code>IElement</code> from the state captured within an
+        * <code>IMemento</code>.
+        * 
+        * @param memento
+        *            a memento containing the state for an element
+        * @return an element, or <code>null</code> if the element could not be
+        *         created
         */
        public IAdaptable createElement(IMemento memento) {
                URL url2 = null;
@@ -142,26 +151,27 @@ public class WebBrowserEditorInput implements IWebBrowserEditorInput, IPersistab
                int newStyle = SHOW_TOOLBAR | SHOW_STATUSBAR;
                try {
                        newStyle = memento.getInteger(MEMENTO_STYLE).intValue();
-       
+
                        if ((newStyle & SAVE_URL) != 0)
                                url = new URL(memento.getString(MEMENTO_URL));
                } catch (Exception e) {
                        // could not determine the style
                }
-               
+
                String id2 = null;
                try {
                        id2 = memento.getString(MEMENTO_ID);
                        if (id2 != null && id2.length() < 1)
                                id2 = null;
-               } catch (Exception e) { }
-               
+               } catch (Exception e) {
+               }
+
                return new WebBrowserEditorInput(url2, newStyle, id2);
        }
-       
+
        /**
-        * Indicates whether some other object is "equal to" this one.
-        * In this case it means that the underlying IFolders are equal.
+        * Indicates whether some other object is "equal to" this one. In this case
+        * it means that the underlying IFolders are equal.
         */
        public boolean equals(Object obj) {
                if (this == obj)
@@ -169,23 +179,23 @@ public class WebBrowserEditorInput implements IWebBrowserEditorInput, IPersistab
                if (!(obj instanceof WebBrowserEditorInput))
                        return false;
                WebBrowserEditorInput other = (WebBrowserEditorInput) obj;
-       
+
                if (url != null && !url.equals(obj))
                        return false;
-       
+
                return canReplaceInput(other);
        }
-       
+
        /**
-        * Returns whether the editor input exists.  
+        * Returns whether the editor input exists.
         * <p>
-        * This method is primarily used to determine if an editor input should 
-        * appear in the "File Most Recently Used" menu.  An editor input will appear 
-        * in the list until the return value of <code>exists</code> becomes 
+        * This method is primarily used to determine if an editor input should
+        * appear in the "File Most Recently Used" menu. An editor input will appear
+        * in the list until the return value of <code>exists</code> becomes
         * <code>false</code> or it drops off the bottom of the list.
-        *
-        * @return <code>true</code> if the editor input exists; <code>false</code>
-        *              otherwise
+        * 
+        * @return <code>true</code> if the editor input exists;
+        *         <code>false</code> otherwise
         */
        public boolean exists() {
                if ((style & TRANSIENT) != 0)
@@ -193,54 +203,55 @@ public class WebBrowserEditorInput implements IWebBrowserEditorInput, IPersistab
                else
                        return true;
        }
-       
+
        /**
-        * Returns an object which is an instance of the given class
-        * associated with this object. Returns <code>null</code> if
-        * no such object can be found.
-        *
-        * @param adapter the adapter class to look up
-        * @return a object castable to the given class, 
-        *    or <code>null</code> if this object does not
-        *    have an adapter for the given class
+        * Returns an object which is an instance of the given class associated with
+        * this object. Returns <code>null</code> if no such object can be found.
+        * 
+        * @param adapter
+        *            the adapter class to look up
+        * @return a object castable to the given class, or <code>null</code> if
+        *         this object does not have an adapter for the given class
         */
        public Object getAdapter(Class adapter) {
                return null;
        }
-       
+
        /**
-        * Returns the ID of an element factory which can be used to recreate 
-        * this object.  An element factory extension with this ID must exist
-        * within the workbench registry.
+        * Returns the ID of an element factory which can be used to recreate this
+        * object. An element factory extension with this ID must exist within the
+        * workbench registry.
         * 
         * @return the element factory ID
         */
        public String getFactoryId() {
                return ELEMENT_FACTORY_ID;
        }
-       
+
        public ImageDescriptor getImageDescriptor() {
-               return ImageResource.getImageDescriptor(ImageResource.IMG_INTERNAL_BROWSER);
+               return ImageResource
+                               .getImageDescriptor(ImageResource.IMG_INTERNAL_BROWSER);
        }
-       
+
        /**
         * Returns the name of this editor input for display purposes.
         * <p>
         * For instance, if the fully qualified input name is
         * <code>"a\b\MyFile.gif"</code>, the return value would be just
         * <code>"MyFile.gif"</code>.
-        *
+        * 
         * @return the file name string
         */
        public String getName() {
                return WebBrowserUIPlugin.getResource("%viewWebBrowserTitle");
        }
-       
+
        /*
-        * Returns an object that can be used to save the state of this editor input.
-        *
-        * @return the persistable element, or <code>null</code> if this editor input
-        *   cannot be persisted
+        * Returns an object that can be used to save the state of this editor
+        * input.
+        * 
+        * @return the persistable element, or <code>null</code> if this editor
+        * input cannot be persisted
         */
        public IPersistableElement getPersistable() {
                if ((style & TRANSIENT) != 0)
@@ -248,23 +259,23 @@ public class WebBrowserEditorInput implements IWebBrowserEditorInput, IPersistab
                else
                        return this;
        }
-       
+
        public String getToolTipText() {
                if (url != null)
                        return url.toExternalForm();
                else
                        return WebBrowserUIPlugin.getResource("%viewWebBrowserTitle");
        }
-       
+
        /**
         * Returns the url.
-        *
+        * 
         * @return java.net.URL
         */
        public URL getURL() {
                return url;
        }
-       
+
        /**
         * Returns the browser id. Browsers with a set id will always & only be
         * replaced by browsers with the same id.
@@ -274,43 +285,44 @@ public class WebBrowserEditorInput implements IWebBrowserEditorInput, IPersistab
        public String getBrowserId() {
                return id;
        }
-       
+
        /**
         * Returns true if the status bar should be shown.
-        *
+        * 
         * @return boolean
         */
        public boolean isStatusbarVisible() {
                return (style & SHOW_STATUSBAR) != 0;
        }
-       
+
        /**
         * Returns true if the toolbar should be shown.
-        *
+        * 
         * @return boolean
         */
        public boolean isToolbarVisible() {
                return (style & SHOW_TOOLBAR) != 0;
        }
-       
+
        /**
         * Saves the state of an element within a memento.
-        *
-        * @param memento the storage area for element state
+        * 
+        * @param memento
+        *            the storage area for element state
         */
        public void saveState(IMemento memento) {
                if ((style & SAVE_URL) != 0 && url != null)
                        memento.putString(MEMENTO_URL, url.toExternalForm());
 
                memento.putInteger(MEMENTO_STYLE, style);
-               
+
                if (id != null)
                        memento.putString(MEMENTO_ID, id);
        }
 
        /**
         * Converts this object to a string.
-        *
+        * 
         * @return java.lang.String
         */
        public String toString() {