misc changes
[phpeclipse.git] / net.sourceforge.phpeclipse.launching / src / net / sourceforge / phpdt / internal / launching / DebuggerRunner.java
index 203a5b4..01e4f6c 100644 (file)
@@ -8,6 +8,7 @@ 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;
 
@@ -27,19 +28,46 @@ public class DebuggerRunner extends InterpreterRunner {
 
        public IProcess run(InterpreterRunnerConfiguration configuration, ILaunch launch) {
                String[] env;
-               PHPDBGProxy newPHPDBGProxy= new PHPDBGProxy();
-               newPHPDBGProxy.start();
-               env= setEnvironmentVariables(newPHPDBGProxy.getPort(), configuration.getAbsoluteFileName());
-               
-               IProcess process = super.run(configuration, launch, env);
+               String name, value;
+               PHPDBGProxy newPHPDBGProxy= new PHPDBGProxy(configuration.useRemoteDebugger(),
+                                                           configuration.getRemoteSourcePath());
+               int pos;
+
+
+               IProcess process =null;
                PHPDebugTarget debugTarget = new PHPDebugTarget(launch, process);
-               newPHPDBGProxy.setDebugTarget(debugTarget);
+               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);
+                       }
+                       // 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);
+                       debugTarget.setProcess(process);
+               }       
                launch.addDebugTarget(debugTarget);
 
                return process;
        }
-
-       protected String[] setEnvironmentVariables(int listenPort, String AbsoluteFileName) {
+       
+       protected String[] setEnvironmentVariables(int listenPort, String AbsoluteFileName, String interpreter) {
                IPath FilePath= new Path(AbsoluteFileName);
                String OSFilePath= FilePath.toOSString();
                String DBGSessID;
@@ -56,7 +84,7 @@ public class DebuggerRunner extends InterpreterRunner {
                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=c:\\php\\php.exe";
+               env[9]= "SCRIPT_FILENAME=" + interpreter;
                env[10]= "GATEWAY_INTERFACE=CGI / 1.1";
                env[11]= "SERVER_PROTOCOL=HTTP / 1.1";
                env[12]= "REQUEST_METHOD=GET";