You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

124 line
2.2 KiB

  1. <?php
  2. /*
  3. * This file is part of Hashids.
  4. *
  5. * (c) Ivan Akimov <ivan@barreleye.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 Hashids\Math;
  11. /**
  12. * This is the Gmp math class.
  13. *
  14. * @author Vincent Klaiber <hello@doubledip.se>
  15. * @author Jakub Kramarz <lenwe@lenwe.net>
  16. * @author Johnson Page <jwpage@gmail.com>
  17. */
  18. class Gmp implements MathInterface
  19. {
  20. /**
  21. * Add two arbitrary-length integers.
  22. *
  23. * @param string $a
  24. * @param string $b
  25. *
  26. * @return string
  27. */
  28. public function add($a, $b)
  29. {
  30. return gmp_add($a, $b);
  31. }
  32. /**
  33. * Multiply two arbitrary-length integers.
  34. *
  35. * @param string $a
  36. * @param string $b
  37. *
  38. * @return string
  39. */
  40. public function multiply($a, $b)
  41. {
  42. return gmp_mul($a, $b);
  43. }
  44. /**
  45. * Divide two arbitrary-length integers.
  46. *
  47. * @param string $a
  48. * @param string $b
  49. *
  50. * @return string
  51. */
  52. public function divide($a, $b)
  53. {
  54. return gmp_div_q($a, $b);
  55. }
  56. /**
  57. * Compute arbitrary-length integer modulo.
  58. *
  59. * @param string $n
  60. * @param string $d
  61. *
  62. * @return string
  63. */
  64. public function mod($n, $d)
  65. {
  66. return gmp_mod($n, $d);
  67. }
  68. /**
  69. * Compares two arbitrary-length integers.
  70. *
  71. * @param string $a
  72. * @param string $b
  73. *
  74. * @return bool
  75. */
  76. public function greaterThan($a, $b)
  77. {
  78. return gmp_cmp($a, $b) > 0;
  79. }
  80. /**
  81. * Converts arbitrary-length integer to PHP integer.
  82. *
  83. * @param string $a
  84. *
  85. * @return int
  86. */
  87. public function intval($a)
  88. {
  89. return gmp_intval($a);
  90. }
  91. /**
  92. * Converts arbitrary-length integer to PHP string.
  93. *
  94. * @param string $a
  95. *
  96. * @return string
  97. */
  98. public function strval($a)
  99. {
  100. return gmp_strval($a);
  101. }
  102. /**
  103. * Converts PHP integer to arbitrary-length integer.
  104. *
  105. * @param int $a
  106. *
  107. * @return string
  108. */
  109. public function get($a)
  110. {
  111. return gmp_init($a);
  112. }
  113. }