X-Git-Url: http://git.phpeclipse.com diff --git a/net.sourceforge.phpeclipse/src/net/sourceforge/phpeclipse/actions/PHPEclipseShowAction.java b/net.sourceforge.phpeclipse/src/net/sourceforge/phpeclipse/actions/PHPEclipseShowAction.java index 0d3b56f..6a9430d 100644 --- a/net.sourceforge.phpeclipse/src/net/sourceforge/phpeclipse/actions/PHPEclipseShowAction.java +++ b/net.sourceforge.phpeclipse/src/net/sourceforge/phpeclipse/actions/PHPEclipseShowAction.java @@ -1,15 +1,12 @@ -/********************************************************************** - Copyright (c) 2000, 2002 IBM Corp. and others. - All rights reserved. This program and the accompanying materials - 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 Corporation - Initial implementation - Klaus Hartlage - www.eclipseproject.de - **********************************************************************/ +/*********************************************************************************************************************************** + * Copyright (c) 2000, 2002 IBM Corp. and others. All rights reserved. This program and the accompanying materials 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 Corporation - Initial implementation Klaus Hartlage - www.eclipseproject.de + **********************************************************************************************************************************/ package net.sourceforge.phpeclipse.actions; + import java.io.IOException; import java.net.MalformedURLException; import java.net.URL; @@ -17,8 +14,12 @@ import java.text.MessageFormat; import java.util.Iterator; import net.sourceforge.phpeclipse.PHPeclipsePlugin; +import net.sourceforge.phpeclipse.ui.IPreferenceConstants; import net.sourceforge.phpeclipse.ui.editor.ShowExternalPreviewAction; -import net.sourceforge.phpeclipse.views.PHPConsole; +import net.sourceforge.phpeclipse.ui.overlaypages.Util; +import net.sourceforge.phpeclipse.webbrowser.IWebBrowser; +import net.sourceforge.phpeclipse.webbrowser.internal.BrowserManager; +import net.sourceforge.phpeclipse.webbrowser.internal.WebBrowserUtil; import net.sourceforge.phpeclipse.webbrowser.views.BrowserView; import org.eclipse.core.resources.IFile; @@ -35,28 +36,31 @@ import org.eclipse.ui.IObjectActionDelegate; import org.eclipse.ui.IViewPart; import org.eclipse.ui.IWorkbenchPage; import org.eclipse.ui.IWorkbenchPart; -//import org.eclipse.update.internal.ui.UpdatePerspective; -//import org.eclipse.update.internal.ui.views.IEmbeddedWebBrowser; + + public class PHPEclipseShowAction implements IObjectActionDelegate { private IWorkbenchPart workbenchPart; + /** * Constructor for Action1. */ public PHPEclipseShowAction() { super(); } + /** * @see IObjectActionDelegate#setActivePart(IAction, IWorkbenchPart) */ public void setActivePart(IAction action, IWorkbenchPart targetPart) { workbenchPart = targetPart; } + public void run(IAction action) { ISelectionProvider selectionProvider = null; selectionProvider = workbenchPart.getSite().getSelectionProvider(); StructuredSelection selection = null; selection = (StructuredSelection) selectionProvider.getSelection(); - PHPConsole console = PHPConsole.getInstance(); + // PHPConsole console = PHPConsole.getInstance(); IPreferenceStore store = PHPeclipsePlugin.getDefault().getPreferenceStore(); Shell shell = null; Iterator iterator = null; @@ -69,87 +73,69 @@ public class PHPEclipseShowAction implements IObjectActionDelegate { IResource resource = (IResource) obj; // check if it's a file resource switch (resource.getType()) { - case IResource.FILE : - // single file: - IFile file = (IFile) resource; - String localhostURL; - if ((localhostURL = ShowExternalPreviewAction.getLocalhostURL(store, (IFile) resource)) == null) { - MessageDialog.openInformation(shell, - "Couldn't create localhost URL", - "Please configure your localhost and documentRoot"); - return; - } - try { - if (store.getBoolean(PHPeclipsePlugin.USE_EXTERNAL_BROWSER_PREF)) { - String[] arguments = {localhostURL}; - MessageFormat form = new MessageFormat(store - .getString(PHPeclipsePlugin.EXTERNAL_BROWSER_PREF)); - Runtime runtime = Runtime.getRuntime(); - String command = form.format(arguments); - console.write("External Browser command: " + command + "\n"); - runtime.exec(command); - // runtime.exec(store.getString(PHPeclipsePlugin.EXTERNAL_BROWSER_PREF) - // + " " + fileName); - // runtime.exec("command.com /c start iexplore " + fileName); - } else { - // MessageDialog.openInformation(shell, "localhostURL", - // "localhostURL: " + localhostURL); - // this doesn't work under win98 ? - // Program.launch(localhostURL); - console.write("Internal Browser URL: " + localhostURL + "\n"); - open(new URL(localhostURL), shell, localhostURL); - } - } catch (MalformedURLException e) { - MessageDialog.openInformation(shell, "MalformedURLException: ", e - .toString()); - } catch (IOException e) { - MessageDialog.openInformation(shell, "IOException", - "Cannot show: " + localhostURL); - } + case IResource.FILE: + // single file: + IFile previewFile = (IFile) resource; + String extension = previewFile.getFileExtension().toLowerCase(); + boolean bringToTopPreview = Util.getPreviewBooleanValue(previewFile, IPreferenceConstants.PHP_BRING_TO_TOP_PREVIEW_DEFAULT); + boolean showHTMLFilesLocal = Util.getPreviewBooleanValue(previewFile, IPreferenceConstants.PHP_SHOW_HTML_FILES_LOCAL); + boolean showXMLFilesLocal = Util.getPreviewBooleanValue(previewFile, IPreferenceConstants.PHP_SHOW_XML_FILES_LOCAL); + boolean isHTMLFileName = "html".equals(extension) || "htm".equals(extension) || "xhtml".equals(extension); + boolean isXMLFileName = "xml".equals(extension) || "xsd".equals(extension) || "dtd".equals(extension); + + String localhostURL; + if (showHTMLFilesLocal && isHTMLFileName) { + localhostURL = "file://"+previewFile.getLocation().toString(); + } else if (showXMLFilesLocal && isXMLFileName) { + localhostURL = "file://"+previewFile.getLocation().toString(); + } else if ((localhostURL = ShowExternalPreviewAction.getLocalhostURL(store, previewFile)) == null) { + MessageDialog.openInformation(shell, "Couldn't create localhost URL", + "Please configure your localhost and documentRoot"); + return; + } + + try { +// if (store.getBoolean(PHPeclipsePlugin.USE_EXTERNAL_BROWSER_PREF)) { +// String[] arguments = { localhostURL }; +// MessageFormat form = new MessageFormat(store.getString(PHPeclipsePlugin.EXTERNAL_BROWSER_PREF)); +// Runtime runtime = Runtime.getRuntime(); +// String command = form.format(arguments); +// // console.write("External Browser command: " + command + "\n"); +// runtime.exec(command); +// } else { + open(new URL(localhostURL), shell, localhostURL); +// } + } catch (MalformedURLException e) { + MessageDialog.openInformation(shell, "MalformedURLException: ", e.toString()); + } } } } } + /** * @see IActionDelegate#selectionChanged(IAction, ISelection) */ public void selectionChanged(IAction action, ISelection selection) { } -// public static String getLocalhostURL(IPreferenceStore store, IFile file) { -// if (store == null) { -// store = PHPeclipsePlugin.getDefault().getPreferenceStore(); -// } -// // IPath path = file.getFullPath(); -// String localhostURL = file.getLocation().toString(); -// String lowerCaseFileName = localhostURL.toLowerCase(); -// // String documentRoot = store.getString(PHPeclipsePlugin.DOCUMENTROOT_PREF); -// String documentRoot = Util.getMiscProjectsPreferenceValue( -// file.getProject(), IPreferenceConstants.PHP_DOCUMENTROOT_PREF); -// -// documentRoot = documentRoot.replace('\\', '/'); -// documentRoot = documentRoot.toLowerCase(); -// -// if (lowerCaseFileName.startsWith(documentRoot)) { -// localhostURL = localhostURL.substring(documentRoot.length()); + + public static void open(final URL url, final Shell shell, final String dialogTitle) { +// if (WebBrowserUtil.canUseInternalWebBrowser()) { +// IWorkbenchPage page = PHPeclipsePlugin.getActivePage(); +// try { +// IViewPart part = page.findView(BrowserView.ID_BROWSER); +// if (part == null) { +// part = page.showView(BrowserView.ID_BROWSER); +// } else { +// page.bringToTop(part); +// } +// ((BrowserView) part).setUrl(url.toExternalForm()); +// } catch (Exception e) { +// } // } else { -// return null; + BrowserManager manager = BrowserManager.getInstance(); + IWebBrowser browser = manager.getCurrentWebBrowser(); + browser.openURL(url); // } -//// return store.getString(PHPeclipsePlugin.LOCALHOST_PREF) + localhostURL; -// return Util.getMiscProjectsPreferenceValue(file.getProject(), IPreferenceConstants.PHP_LOCALHOST_PREF) + localhostURL; -// } - - public static void open(final URL url, final Shell shell, - final String dialogTitle) { - IWorkbenchPage page = PHPeclipsePlugin.getActivePage(); - try { - IViewPart part = page.findView(BrowserView.ID_BROWSER); - if (part == null) { - part = page.showView(BrowserView.ID_BROWSER); - } else { - page.bringToTop(part); - } - ((BrowserView) part).setUrl(url.toExternalForm()); - } catch (Exception e) { - } } -} +} \ No newline at end of file