Skip to content

Commit

Permalink
Merge pull request #95 from SamarRizvi/master
Browse files Browse the repository at this point in the history
Fix Bug: % symbol stripped from ffmpeg command
  • Loading branch information
buggedcom authored Oct 18, 2016
2 parents 827629f + 9749bb6 commit 7f7c784
Show file tree
Hide file tree
Showing 2 changed files with 71 additions and 1 deletion.
2 changes: 1 addition & 1 deletion src/PHPVideoToolkit/ProcessBuilder.php
Original file line number Diff line number Diff line change
Expand Up @@ -151,7 +151,7 @@ protected function _combineArgumentList($commands)
foreach ($commands as $argument)
{
// the array ois a flag for a raw argument
$command_string .= (is_array($argument) === true ? $argument : escapeshellarg($argument)).' ';
$command_string .= (is_array($argument) === true ? $argument : ProcessUtils::escapeArgument($argument)).' ';
}
}

Expand Down
70 changes: 70 additions & 0 deletions src/PHPVideoToolkit/ProcessUtils.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
<?php

namespace PHPVideoToolkit;

/**
* ProcessUtils is a bunch of utility methods taken from Symphony.
*
* This class contains static methods only and is not meant to be instantiated.
*
* @author Martin Hasoň <martin.hason@gmail.com>
*/
class ProcessUtils
{
/**
* This class should not be instantiated.
*/
private function __construct()
{
}

/**
* Escapes a string to be used as a shell argument.
*
* @param string $argument The argument that will be escaped
*
* @return string The escaped argument
*/
public static function escapeArgument($argument)
{
//Fix for PHP bug #43784 escapeshellarg removes % from given string
//Fix for PHP bug #49446 escapeshellarg doesn't work on Windows
//@see https://bugs.php.net/bug.php?id=43784
//@see https://bugs.php.net/bug.php?id=49446
if ('\\' === DIRECTORY_SEPARATOR) {
if ('' === $argument) {
return escapeshellarg($argument);
}

$escapedArgument = '';
$quote = false;
foreach (preg_split('/(")/', $argument, -1, PREG_SPLIT_NO_EMPTY | PREG_SPLIT_DELIM_CAPTURE) as $part) {
if ('"' === $part) {
$escapedArgument .= '\\"';
} elseif (self::isSurroundedBy($part, '%')) {
// Avoid environment variable expansion
$escapedArgument .= '^%"'.substr($part, 1, -1).'"^%';
} else {
// escape trailing backslash
if ('\\' === substr($part, -1)) {
$part .= '\\';
}
$quote = true;
$escapedArgument .= $part;
}
}
if ($quote) {
$escapedArgument = '"'.$escapedArgument.'"';
}

return $escapedArgument;
}

return escapeshellarg($argument);
}

private static function isSurroundedBy($arg, $char)
{
return 2 < strlen($arg) && $char === $arg[0] && $char === $arg[strlen($arg) - 1];
}
}

0 comments on commit 7f7c784

Please # to comment.