X-Git-Url: http://secure.phpeclipse.com diff --git a/net.sourceforge.phpeclipse.launching/src/net/sourceforge/phpdt/internal/launching/InterpreterRunner.java b/net.sourceforge.phpeclipse.launching/src/net/sourceforge/phpdt/internal/launching/InterpreterRunner.java index a3be7fa..a333027 100644 --- a/net.sourceforge.phpeclipse.launching/src/net/sourceforge/phpdt/internal/launching/InterpreterRunner.java +++ b/net.sourceforge.phpeclipse.launching/src/net/sourceforge/phpdt/internal/launching/InterpreterRunner.java @@ -2,10 +2,10 @@ package net.sourceforge.phpdt.internal.launching; import java.io.File; import java.io.IOException; -import java.util.Iterator; +//import java.util.Iterator; import java.util.Map; -import net.sourceforge.phpdt.internal.core.JavaProject; +//import net.sourceforge.phpdt.internal.core.JavaProject; import org.eclipse.core.resources.IProject; import org.eclipse.core.runtime.IPath; @@ -20,23 +20,31 @@ public class InterpreterRunner { public InterpreterRunner() { } - public IProcess run(InterpreterRunnerConfiguration configuration, ILaunch launch) { - String commandLine = renderCommandLine(configuration); + public IProcess run(InterpreterRunnerConfiguration configuration, + ILaunch launch) { + String commandLine = renderCommandLine(configuration); File workingDirectory = configuration.getAbsoluteWorkingDirectory(); - + setEnvironmentVariables(configuration); String[] env = configuration.getEnvironment(); Process nativePHPProcess = null; try { - nativePHPProcess = configuration.getInterpreter().exec(commandLine, workingDirectory, env); + nativePHPProcess = configuration.getInterpreter().exec(commandLine, + workingDirectory, env); } catch (IOException e) { - throw new RuntimeException("Unable to execute interpreter: " + commandLine + workingDirectory); + throw new RuntimeException("Unable to execute interpreter: " + + commandLine + workingDirectory); } - IProcess process = DebugPlugin.newProcess(launch, nativePHPProcess, renderLabel(configuration)); - process.setAttribute(PHPLaunchingPlugin.PLUGIN_ID + ".launcher.cmdline", commandLine); + IProcess process = DebugPlugin.newProcess(launch, nativePHPProcess, + renderLabel(configuration)); + process + .setAttribute(PHPLaunchingPlugin.PLUGIN_ID + + ".launcher.cmdline", commandLine); + process.setAttribute(IProcess.ATTR_PROCESS_TYPE, + PHPLaunchConfigurationAttribute.PHP_LAUNCH_PROCESS_TYPE); - return process ; + return process; } protected String renderLabel(InterpreterRunnerConfiguration configuration) { @@ -51,62 +59,72 @@ public class InterpreterRunner { return buffer.toString(); } - protected String renderCommandLine(InterpreterRunnerConfiguration configuration) { - PHPInterpreter interpreter = configuration.getInterpreter(); + protected String renderCommandLine( + InterpreterRunnerConfiguration configuration) { + //PHPInterpreter interpreter = configuration.getInterpreter(); StringBuffer buffer = new StringBuffer(); buffer.append(this.getDebugCommandLineArgument()); - // buffer.append(renderLoadPath(configuration)); + // buffer.append(renderLoadPath(configuration)); buffer.append(" " + configuration.getInterpreterArguments()); - // buffer.append(interpreter.endOfOptionsDelimeter); - buffer.append(" " + osDependentPath(configuration.getAbsoluteFileName())); + // buffer.append(interpreter.endOfOptionsDelimeter); + buffer.append(" " + + osDependentPath(configuration.getAbsoluteFileName())); buffer.append(" " + configuration.getProgramArguments()); return buffer.toString(); } - - protected void setEnvironmentVariables(InterpreterRunnerConfiguration configuration) { - IPath FilePath= new Path(configuration.getAbsoluteFileName()); - String OSFilePath= FilePath.toOSString(); - 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",configuration.getInterpreter().getCommand(),true); - configuration.addEnvironmentValue("SERVER_PROTOCOL","HTTP / 1.1",true); - - configuration.addEnvironmentValue("REDIRECT_QUERY_STRING","",true); - configuration.addEnvironmentValue("REDIRECT_STATUS","200",true); - configuration.addEnvironmentValue("SERVER_SOFTWARE","DBG / 2.1",true); - configuration.addEnvironmentValue("SERVER_NAME","localhost",true); - configuration.addEnvironmentValue("SERVER_ADDR","127.0.0.1",true); - configuration.addEnvironmentValue("SERVER_PORT","80",true); - configuration.addEnvironmentValue("REMOTE_ADDR","127.0.0.1",true); - - configuration.addEnvironmentValue("GATEWAY_INTERFACE","CGI / 1.1",true); - configuration.addEnvironmentValue("REQUEST_METHOD","GET",true); - - Map stringVars = DebugPlugin.getDefault().getLaunchManager().getNativeEnvironment(); - if (stringVars.containsKey("SYSTEMROOT")) - configuration.addEnvironmentValue("SYSTEMROOT",(String) stringVars.get("SYSTEMROOT"),true); - - } - - protected String renderLoadPath(InterpreterRunnerConfiguration configuration) { - StringBuffer loadPath = new StringBuffer(); - JavaProject project = configuration.getProject(); - addToLoadPath(loadPath, project.getProject()); - - Iterator referencedProjects = project.getReferencedProjects().iterator(); - while (referencedProjects.hasNext()) - addToLoadPath(loadPath, (IProject) referencedProjects.next()); + protected void setEnvironmentVariables( + InterpreterRunnerConfiguration configuration) { + IPath FilePath = new Path(configuration.getAbsoluteFileName()); + String OSFilePath = FilePath.toOSString(); + 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", configuration + .getInterpreter().getCommand(), true); + configuration + .addEnvironmentValue("SERVER_PROTOCOL", "HTTP / 1.1", true); + + configuration.addEnvironmentValue("REDIRECT_QUERY_STRING", "", true); + configuration.addEnvironmentValue("REDIRECT_STATUS", "200", true); + configuration.addEnvironmentValue("SERVER_SOFTWARE", "DBG / 2.1", true); + configuration.addEnvironmentValue("SERVER_NAME", "localhost", true); + configuration.addEnvironmentValue("SERVER_ADDR", "127.0.0.1", true); + configuration.addEnvironmentValue("SERVER_PORT", "80", true); + configuration.addEnvironmentValue("REMOTE_ADDR", "127.0.0.1", true); + + configuration.addEnvironmentValue("GATEWAY_INTERFACE", "CGI / 1.1", + true); + configuration.addEnvironmentValue("REQUEST_METHOD", "GET", true); + + Map stringVars = DebugPlugin.getDefault().getLaunchManager() + .getNativeEnvironment(); + if (stringVars.containsKey("SYSTEMROOT")) + configuration.addEnvironmentValue("SYSTEMROOT", (String) stringVars + .get("SYSTEMROOT"), true); - return loadPath.toString(); } +// protected String renderLoadPath(InterpreterRunnerConfiguration configuration) { +// StringBuffer loadPath = new StringBuffer(); +// +// JavaProject project = configuration.getProject(); +// addToLoadPath(loadPath, project.getProject()); +// +// Iterator referencedProjects = project.getReferencedProjects() +// .iterator(); +// while (referencedProjects.hasNext()) +// addToLoadPath(loadPath, (IProject) referencedProjects.next()); +// +// return loadPath.toString(); +// } + protected void addToLoadPath(StringBuffer loadPath, IProject project) { - loadPath.append(" -I " + osDependentPath(project.getLocation().toOSString())); + loadPath.append(" -I " + + osDependentPath(project.getFullPath().toOSString())); } protected String osDependentPath(String aPath) { @@ -115,8 +133,8 @@ public class InterpreterRunner { return aPath; } - + protected String getDebugCommandLineArgument() { - return "" ; - } + return ""; + } }