merged branch jfsimon/issue-7481 (PR #7489)
This PR was merged into the master branch.
Discussion
----------
Fixes bytes convertion method, last episode
This definitely fixes the bytes convertion method.
@lazyhammer thanks for your support & indulgence
@fabpot sorry for the running gag
@vicb I opened a ticket: https://bugs.php.net/bug.php?id=64530
| Q | A
| ------------- | ---
| Bug fix? | yes
| New feature? | no
| BC breaks? | no
| Deprecations? | no
| Tests pass? | yes
| Fixed tickets | #7481
Commits
-------
233b945
fixed bytes convertion method, again
This commit is contained in:
commit
ea79360fba
@ -29,11 +29,11 @@ class ServerParams
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (preg_match('#^\+?(0X?)?([^KMG]*)([KMG]?)#', $iniMax, $match)) {
|
if (preg_match('#^\+?(0X?)?(.*?)([KMG]?)$#', $iniMax, $match)) {
|
||||||
$shifts = array('' => 0, 'K' => 10, 'M' => 20, 'G' => 30);
|
$shifts = array('' => 0, 'K' => 10, 'M' => 20, 'G' => 30);
|
||||||
$bases = array('' => 10, '0' => 8, '0X' => 16);
|
$bases = array('' => 10, '0' => 8, '0X' => 16);
|
||||||
|
|
||||||
return (intval($match[2], $bases[$match[1]]) * (1 << $shifts[$match[3]]));
|
return intval($match[2], $bases[$match[1]]) << $shifts[$match[3]];
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -30,6 +30,7 @@ class ServerParamsTest extends \PHPUnit_Framework_TestCase
|
|||||||
return array(
|
return array(
|
||||||
array('2k', 2048),
|
array('2k', 2048),
|
||||||
array('2 k', 2048),
|
array('2 k', 2048),
|
||||||
|
array('8m', 8 * 1024 * 1024),
|
||||||
array('+2 k', 2048),
|
array('+2 k', 2048),
|
||||||
array('+2???k', 2048),
|
array('+2???k', 2048),
|
||||||
array('0x10', 16),
|
array('0x10', 16),
|
||||||
@ -37,6 +38,9 @@ class ServerParamsTest extends \PHPUnit_Framework_TestCase
|
|||||||
array('010', 8),
|
array('010', 8),
|
||||||
array('+0x10 k', 16 * 1024),
|
array('+0x10 k', 16 * 1024),
|
||||||
array('1g', 1024 * 1024 * 1024),
|
array('1g', 1024 * 1024 * 1024),
|
||||||
|
array('-1', -1),
|
||||||
|
array('0', 0),
|
||||||
|
array('2mk', 2048), // the unit must be the last char, so in this case 'k', not 'm'
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -237,11 +237,11 @@ class UploadedFile extends File
|
|||||||
return PHP_INT_MAX;
|
return PHP_INT_MAX;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (preg_match('#^\+?(0x?)?([^kmg]*)([kmg]?)#', $max, $match)) {
|
if (preg_match('#^\+?(0x?)?(.*?)([kmg]?)$#', $max, $match)) {
|
||||||
$shifts = array('' => 0, 'k' => 10, 'm' => 20, 'g' => 30);
|
$shifts = array('' => 0, 'k' => 10, 'm' => 20, 'g' => 30);
|
||||||
$bases = array('' => 10, '0' => 8, '0x' => 16);
|
$bases = array('' => 10, '0' => 8, '0x' => 16);
|
||||||
|
|
||||||
return (intval($match[2], $bases[$match[1]]) * (1 << $shifts[$match[3]]));
|
return intval($match[2], $bases[$match[1]]) << $shifts[$match[3]];
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -79,11 +79,11 @@ class MemoryDataCollector extends DataCollector
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (preg_match('#^\+?(0x?)?([^kmg]*)([kmg]?)#', $memoryLimit, $match)) {
|
if (preg_match('#^\+?(0x?)?(.*?)([kmg]?)$#', $memoryLimit, $match)) {
|
||||||
$shifts = array('' => 0, 'k' => 10, 'm' => 20, 'g' => 30);
|
$shifts = array('' => 0, 'k' => 10, 'm' => 20, 'g' => 30);
|
||||||
$bases = array('' => 10, '0' => 8, '0x' => 16);
|
$bases = array('' => 10, '0' => 8, '0x' => 16);
|
||||||
|
|
||||||
return (intval($match[2], $bases[$match[1]]) * (1 << $shifts[$match[3]]));
|
return intval($match[2], $bases[$match[1]]) << $shifts[$match[3]];
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -48,6 +48,7 @@ class MemoryDataCollectorTest extends \PHPUnit_Framework_TestCase
|
|||||||
return array(
|
return array(
|
||||||
array('2k', 2048),
|
array('2k', 2048),
|
||||||
array('2 k', 2048),
|
array('2 k', 2048),
|
||||||
|
array('8m', 8 * 1024 * 1024),
|
||||||
array('+2 k', 2048),
|
array('+2 k', 2048),
|
||||||
array('+2???k', 2048),
|
array('+2???k', 2048),
|
||||||
array('0x10', 16),
|
array('0x10', 16),
|
||||||
@ -55,6 +56,9 @@ class MemoryDataCollectorTest extends \PHPUnit_Framework_TestCase
|
|||||||
array('010', 8),
|
array('010', 8),
|
||||||
array('+0x10 k', 16 * 1024),
|
array('+0x10 k', 16 * 1024),
|
||||||
array('1g', 1024 * 1024 * 1024),
|
array('1g', 1024 * 1024 * 1024),
|
||||||
|
array('-1', -1),
|
||||||
|
array('0', 0),
|
||||||
|
array('2mk', 2048), // the unit must be the last char, so in this case 'k', not 'm'
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user