PhpExecutableFinder.php 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. <?php
  2. /*
  3. * This file is part of the Symfony package.
  4. *
  5. * (c) Fabien Potencier <fabien@symfony.com>
  6. *
  7. * For the full copyright and license information, please view the LICENSE
  8. * file that was distributed with this source code.
  9. */
  10. namespace Symfony\Component\Process;
  11. /**
  12. * An executable finder specifically designed for the PHP executable.
  13. *
  14. * @author Fabien Potencier <fabien@symfony.com>
  15. * @author Johannes M. Schmitt <schmittjoh@gmail.com>
  16. */
  17. class PhpExecutableFinder
  18. {
  19. private $executableFinder;
  20. public function __construct()
  21. {
  22. $this->executableFinder = new ExecutableFinder();
  23. }
  24. /**
  25. * Finds The PHP executable.
  26. *
  27. * @param bool $includeArgs Whether or not include command arguments
  28. *
  29. * @return string|false The PHP executable path or false if it cannot be found
  30. */
  31. public function find($includeArgs = true)
  32. {
  33. $args = $this->findArguments();
  34. $args = $includeArgs && $args ? ' '.implode(' ', $args) : '';
  35. // PHP_BINARY return the current sapi executable
  36. if (PHP_BINARY && \in_array(\PHP_SAPI, array('cli', 'cli-server', 'phpdbg'), true)) {
  37. return PHP_BINARY.$args;
  38. }
  39. if ($php = getenv('PHP_PATH')) {
  40. if (!@is_executable($php)) {
  41. return false;
  42. }
  43. return $php;
  44. }
  45. if ($php = getenv('PHP_PEAR_PHP_BIN')) {
  46. if (@is_executable($php)) {
  47. return $php;
  48. }
  49. }
  50. if (@is_executable($php = PHP_BINDIR.('\\' === \DIRECTORY_SEPARATOR ? '\\php.exe' : '/php'))) {
  51. return $php;
  52. }
  53. $dirs = array(PHP_BINDIR);
  54. if ('\\' === \DIRECTORY_SEPARATOR) {
  55. $dirs[] = 'C:\xampp\php\\';
  56. }
  57. return $this->executableFinder->find('php', false, $dirs);
  58. }
  59. /**
  60. * Finds the PHP executable arguments.
  61. *
  62. * @return array The PHP executable arguments
  63. */
  64. public function findArguments()
  65. {
  66. $arguments = array();
  67. if ('phpdbg' === \PHP_SAPI) {
  68. $arguments[] = '-qrr';
  69. }
  70. return $arguments;
  71. }
  72. }