Merge pull request #58 from sc0Vu/specify-package-version

Specify package version
This commit is contained in:
Kuan-Cheng,Lai 2018-03-31 10:34:15 +08:00 committed by GitHub
commit 4df0835f2b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 23 additions and 4 deletions

View File

@ -9,12 +9,11 @@
"email": "alk03073135@gmail.com" "email": "alk03073135@gmail.com"
} }
], ],
"minimum-stability": "dev",
"require": { "require": {
"guzzlehttp/guzzle": "~6.0", "guzzlehttp/guzzle": "~6.0",
"PHP": "^7.1", "PHP": "^7.1",
"kornrunner/keccak": "dev-master", "kornrunner/keccak": "~1.0",
"phpseclib/phpseclib": "dev-master" "phpseclib/phpseclib": "~2.0"
}, },
"require-dev": { "require-dev": {
"phpunit/phpunit": "~6.0" "phpunit/phpunit": "~6.0"

View File

@ -292,7 +292,27 @@ class Utils
throw new InvalidArgumentException('toWei fraction part is out of limit.'); throw new InvalidArgumentException('toWei fraction part is out of limit.');
} }
$whole = $whole->multiply($bnt); $whole = $whole->multiply($bnt);
$base = (new BigNumber(10))->pow(new BigNumber($fractionLength));
// There is no pow function in phpseclib 2.0, only can see in dev-master
// Maybe implement own biginteger in the future
// See 2.0 BigInteger: https://github.com/phpseclib/phpseclib/blob/2.0/phpseclib/Math/BigInteger.php
// See dev-master BigInteger: https://github.com/phpseclib/phpseclib/blob/master/phpseclib/Math/BigInteger.php#L700
// $base = (new BigNumber(10))->pow(new BigNumber($fractionLength));
// So we switch phpseclib special global param, change in the future
switch (MATH_BIGINTEGER_MODE) {
case $whole::MODE_GMP:
static $two;
$powerBase = gmp_pow(gmp_init(10), (int) $fractionLength);
break;
case $whole::MODE_BCMATH:
$powerBase = bcpow('10', (string) $fractionLength, 0);
break;
default:
$powerBase = pow(10, (int) $fractionLength);
break;
}
$base = new BigNumber($powerBase);
$fraction = $fraction->multiply($bnt)->divide($base)[0]; $fraction = $fraction->multiply($bnt)->divide($base)[0];
if ($negative1 !== false) { if ($negative1 !== false) {