Regex.php 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. <?php
  2. declare(strict_types=1);
  3. namespace Dotenv\Util;
  4. use GrahamCampbell\ResultType\Error;
  5. use GrahamCampbell\ResultType\Success;
  6. /**
  7. * @internal
  8. */
  9. final class Regex
  10. {
  11. /**
  12. * This class is a singleton.
  13. *
  14. * @codeCoverageIgnore
  15. *
  16. * @return void
  17. */
  18. private function __construct()
  19. {
  20. //
  21. }
  22. /**
  23. * Perform a preg match, wrapping up the result.
  24. *
  25. * @param string $pattern
  26. * @param string $subject
  27. *
  28. * @return \GrahamCampbell\ResultType\Result<bool,string>
  29. */
  30. public static function matches(string $pattern, string $subject)
  31. {
  32. return self::pregAndWrap(static function (string $subject) use ($pattern) {
  33. return @\preg_match($pattern, $subject) === 1;
  34. }, $subject);
  35. }
  36. /**
  37. * Perform a preg match all, wrapping up the result.
  38. *
  39. * @param string $pattern
  40. * @param string $subject
  41. *
  42. * @return \GrahamCampbell\ResultType\Result<int,string>
  43. */
  44. public static function occurrences(string $pattern, string $subject)
  45. {
  46. return self::pregAndWrap(static function (string $subject) use ($pattern) {
  47. return (int) @\preg_match_all($pattern, $subject);
  48. }, $subject);
  49. }
  50. /**
  51. * Perform a preg replace callback, wrapping up the result.
  52. *
  53. * @param string $pattern
  54. * @param callable $callback
  55. * @param string $subject
  56. * @param int|null $limit
  57. *
  58. * @return \GrahamCampbell\ResultType\Result<string,string>
  59. */
  60. public static function replaceCallback(string $pattern, callable $callback, string $subject, int $limit = null)
  61. {
  62. return self::pregAndWrap(static function (string $subject) use ($pattern, $callback, $limit) {
  63. return (string) @\preg_replace_callback($pattern, $callback, $subject, $limit ?? -1);
  64. }, $subject);
  65. }
  66. /**
  67. * Perform a preg split, wrapping up the result.
  68. *
  69. * @param string $pattern
  70. * @param string $subject
  71. *
  72. * @return \GrahamCampbell\ResultType\Result<string[],string>
  73. */
  74. public static function split(string $pattern, string $subject)
  75. {
  76. return self::pregAndWrap(static function (string $subject) use ($pattern) {
  77. /** @var string[] */
  78. return (array) @\preg_split($pattern, $subject);
  79. }, $subject);
  80. }
  81. /**
  82. * Perform a preg operation, wrapping up the result.
  83. *
  84. * @template V
  85. *
  86. * @param callable(string):V $operation
  87. * @param string $subject
  88. *
  89. * @return \GrahamCampbell\ResultType\Result<V,string>
  90. */
  91. private static function pregAndWrap(callable $operation, string $subject)
  92. {
  93. $result = $operation($subject);
  94. if (\preg_last_error() !== \PREG_NO_ERROR) {
  95. /** @var \GrahamCampbell\ResultType\Result<V,string> */
  96. return Error::create(\preg_last_error_msg());
  97. }
  98. /** @var \GrahamCampbell\ResultType\Result<V,string> */
  99. return Success::create($result);
  100. }
  101. }