X-Git-Url: http://secure.phpeclipse.com diff --git a/net.sourceforge.phpeclipse.launching/src/net/sourceforge/phpdt/internal/launching/DebuggerRunner.java b/net.sourceforge.phpeclipse.launching/src/net/sourceforge/phpdt/internal/launching/DebuggerRunner.java index 6003721..95938af 100644 --- a/net.sourceforge.phpeclipse.launching/src/net/sourceforge/phpdt/internal/launching/DebuggerRunner.java +++ b/net.sourceforge.phpeclipse.launching/src/net/sourceforge/phpdt/internal/launching/DebuggerRunner.java @@ -1,102 +1,114 @@ -/********************************************************************** -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 - Vicente Fernando - www.alfersoft.com.ar - Christian Perkonig - remote Debug -**********************************************************************/ +/*********************************************************************************************************************************** + * 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 Vicente Fernando - www.alfersoft.com.ar Christian Perkonig - remote Debug + **********************************************************************************************************************************/ package net.sourceforge.phpdt.internal.launching; import java.util.Iterator; import net.sourceforge.phpdt.internal.core.JavaProject; -import net.sourceforge.phpdt.internal.debug.core.Environment; import net.sourceforge.phpdt.internal.debug.core.PHPDBGProxy; import net.sourceforge.phpdt.internal.debug.core.model.PHPDebugTarget; +import net.sourceforge.phpeclipse.ui.editor.BrowserUtil; +import org.eclipse.core.resources.IFile; import org.eclipse.core.resources.IProject; -import org.eclipse.core.runtime.IPath; -import org.eclipse.core.runtime.Path; import org.eclipse.debug.core.ILaunch; import org.eclipse.debug.core.model.IProcess; -//import net.sourceforge.phpeclipse.resourcesview.PHPProject; +import org.eclipse.swt.widgets.Display; -public class DebuggerRunner extends InterpreterRunner { +// import net.sourceforge.phpeclipse.resourcesview.PHPProject; - public IProcess run(InterpreterRunnerConfiguration configuration, ILaunch launch) { - String[] env; - String name, value; - PHPDBGProxy newPHPDBGProxy= new PHPDBGProxy(configuration.useRemoteDebugger(), - configuration.getRemoteSourcePath()); - int pos; +public class DebuggerRunner extends InterpreterRunner { + public IProcess run(InterpreterRunnerConfiguration configuration, + ILaunch launch) { + //String[] env; + //String name, value; + PHPDBGProxy newPHPDBGProxy = new PHPDBGProxy(configuration + .useRemoteDebugger(), configuration.getRemoteSourcePath(), + configuration.usePathTranslation(), configuration.getPathMap()); + //int pos; - IProcess process =null; + IProcess process = null; PHPDebugTarget debugTarget = new PHPDebugTarget(launch, process); - newPHPDBGProxy.setDebugTarget(debugTarget); - newPHPDBGProxy.start(); - if (configuration.useRemoteDebugger()) - { - // listener for remote debuger is started - } - else - { - - env= setEnvironmentVariables(newPHPDBGProxy.getPort(), configuration.getAbsoluteFileName(), configuration.getInterpreter().getCommand()); - for(int i= 0; i < env.length; i++) { - pos= env[i].indexOf("="); - if(pos > -1) { - name= env[i].substring(0, pos); - value= env[i].substring(pos + 1); - } else { - name= env[i]; - value= ""; - } - Environment.setenv(name, value); + newPHPDBGProxy.setDebugTarget(debugTarget); + newPHPDBGProxy.start(); + if (configuration.useRemoteDebugger()) { + // listener for remote debuger is started + if (configuration.useDBGSessionInBrowser()) { + activateDBGSESSIDPreview(configuration, newPHPDBGProxy + .getPort()); } - // now enviroment settings is made with Environment class - // because if new parameters are passed by array, doesn't inherit system vars - process = super.run(configuration, launch, null); + } else { + setEnvironmentVariables(configuration, newPHPDBGProxy.getPort()); + // env=configuration.getEnvironment(); + process = super.run(configuration, launch); debugTarget.setProcess(process); - } + } launch.addDebugTarget(debugTarget); return process; } - - protected String[] setEnvironmentVariables(int listenPort, String AbsoluteFileName, String interpreter) { - IPath FilePath= new Path(AbsoluteFileName); - String OSFilePath= FilePath.toOSString(); + + /** + * Open the browser in the UI thread with the current debugger URL + * + * @param configuration + * @param port + */ + protected static void activateDBGSESSIDPreview( + final InterpreterRunnerConfiguration configuration, final int port) { + Display.getDefault().asyncExec(new Runnable() { + public void run() { + String fileName = configuration.getFileName(); + JavaProject jproject = configuration.getProject(); + IProject project = jproject.getProject(); + IFile file = project.getFile(fileName); + if (configuration.useDBGSessionInExternalBrowser()) { + BrowserUtil.showBrowserAsExternal(file, + "?DBGSESSID=1@clienthost:" + port); + } else { + BrowserUtil.showPreview(file, true, + "?DBGSESSID=1@clienthost:" + port); + } + } + }); + } + + protected void setEnvironmentVariables( + InterpreterRunnerConfiguration configuration, int listenPort) { String DBGSessID; - String env[]= new String[18]; - - DBGSessID = "DBGSESSID=0753972710000018@clienthost:" + listenPort; - - env[0]= "HTTP_COOKIE=" + DBGSessID; - env[1]= "REDIRECT_QUERY_STRING="; - env[2]= "REDIRECT_STATUS=200"; - env[3]= "REDIRECT_URL=" + OSFilePath; - env[4]= "SERVER_SOFTWARE=DBG / 2.1"; - env[5]= "SERVER_NAME=localhost"; - env[6]= "SERVER_ADDR=127.0.0.1"; - env[7]= "SERVER_PORT=80"; - env[8]= "REMOTE_ADDR=127.0.0.1"; - env[9]= "SCRIPT_FILENAME=" + interpreter; - env[10]= "GATEWAY_INTERFACE=CGI / 1.1"; - env[11]= "SERVER_PROTOCOL=HTTP / 1.1"; - env[12]= "REQUEST_METHOD=GET"; - env[13]= "QUERY_STRING="; - env[14]= "REQUEST_URI=" + OSFilePath; - env[15]= "PATH_INFO=" + OSFilePath; - env[16]= "PATH_TRANSLATED=" + OSFilePath; - env[17]= "SystemRoot=" + Environment.getenv("SystemRoot"); - - return env; + //String env[] = new String[18]; + long id = Math.round(Math.random() * 100000); + + DBGSessID = "DBGSESSID=" + id + "@clienthost:" + listenPort; + configuration.addEnvironmentValue("HTTP_COOKIE", DBGSessID, false); + /* + * configuration.addEnvironmentValue("REDIRECT_URL",OSFilePath,true); + * configuration.addEnvironmentValue("REQUEST_URI",OSFilePath,true); + * configuration.addEnvironmentValue("PATH_INFO",OSFilePath,true); + * configuration.addEnvironmentValue("PATH_TRANSLATED",OSFilePath,true); + * configuration.addEnvironmentValue("SCRIPT_FILENAME",interpreter,true); + * configuration.addEnvironmentValue("SERVER_PROTOCOL","HTTP / + * 1.1",true); + */ + /* + * env[0]= "HTTP_COOKIE=" + DBGSessID; env[1]= "REDIRECT_QUERY_STRING="; + * env[2]= "REDIRECT_STATUS=200"; env[3]= "REDIRECT_URL=" + OSFilePath; + * env[4]= "SERVER_SOFTWARE=DBG / 2.1"; env[5]= "SERVER_NAME=localhost"; + * env[6]= "SERVER_ADDR=127.0.0.1"; env[7]= "SERVER_PORT=80"; env[8]= + * "REMOTE_ADDR=127.0.0.1"; env[9]= "SCRIPT_FILENAME=" + interpreter; + * env[10]= "GATEWAY_INTERFACE=CGI / 1.1"; env[11]= + * "SERVER_PROTOCOL=HTTP / 1.1"; env[12]= "REQUEST_METHOD=GET"; env[13]= + * "QUERY_STRING=test=1"; env[14]= "REQUEST_URI=" + OSFilePath; env[15]= + * "PATH_INFO=" + OSFilePath; env[16]= "PATH_TRANSLATED=" + OSFilePath; + * env[17]= "SystemRoot=" + Environment.getenv("SystemRoot"); + */ + // return env; } protected String getDebugCommandLineArgument() { @@ -109,10 +121,11 @@ public class DebuggerRunner extends InterpreterRunner { JavaProject project = configuration.getProject(); addToLoadPath(loadPath, project.getProject()); - Iterator referencedProjects = project.getReferencedProjects().iterator(); + Iterator referencedProjects = project.getReferencedProjects() + .iterator(); while (referencedProjects.hasNext()) addToLoadPath(loadPath, (IProject) referencedProjects.next()); return loadPath.toString(); } -} +} \ No newline at end of file