@@ -183,7 +183,7 @@ discard block |
||
183 | 183 | $len = $str instanceof UtfString ? $str->length() : strlen($str); |
184 | 184 | |
185 | 185 | // For multi-byte strings, a new instance of `UtfString` is initialized. |
186 | - if (! $str instanceof UtfString && $len !== mb_strlen($str, 'UTF-8')) { |
|
186 | + if (!$str instanceof UtfString && $len !== mb_strlen($str, 'UTF-8')) { |
|
187 | 187 | $str = new UtfString($str); |
188 | 188 | } |
189 | 189 | |
@@ -193,7 +193,7 @@ discard block |
||
193 | 193 | $this->strict = $strict; |
194 | 194 | |
195 | 195 | // Setting the delimiter. |
196 | - $this->setDelimiter(! empty($delimiter) ? $delimiter : static::$defaultDelimiter); |
|
196 | + $this->setDelimiter(!empty($delimiter) ? $delimiter : static::$defaultDelimiter); |
|
197 | 197 | |
198 | 198 | $this->lex(); |
199 | 199 | } |
@@ -321,7 +321,7 @@ discard block |
||
321 | 321 | $delimiterLen = 0; |
322 | 322 | while ( |
323 | 323 | ++$this->last < $this->len |
324 | - && ! Context::isWhitespace($this->str[$this->last]) |
|
324 | + && !Context::isWhitespace($this->str[$this->last]) |
|
325 | 325 | && $delimiterLen < 15 |
326 | 326 | ) { |
327 | 327 | $this->delimiter .= $this->str[$this->last]; |
@@ -380,8 +380,8 @@ discard block |
||
380 | 380 | } |
381 | 381 | |
382 | 382 | if ( |
383 | - ($next->type !== Token::TYPE_KEYWORD || ! in_array($next->value, ['FROM', 'USING'], true)) |
|
384 | - && ($next->type !== Token::TYPE_OPERATOR || ! in_array($next->value, [',', ')'], true)) |
|
383 | + ($next->type !== Token::TYPE_KEYWORD || !in_array($next->value, ['FROM', 'USING'], true)) |
|
384 | + && ($next->type !== Token::TYPE_OPERATOR || !in_array($next->value, [',', ')'], true)) |
|
385 | 385 | ) { |
386 | 386 | continue; |
387 | 387 | } |
@@ -419,10 +419,10 @@ discard block |
||
419 | 419 | $next = $this->list->getNext(); |
420 | 420 | if ( |
421 | 421 | ($next->type !== Token::TYPE_KEYWORD |
422 | - || ! in_array($next->value, $this->keywordNameIndicators, true) |
|
422 | + || !in_array($next->value, $this->keywordNameIndicators, true) |
|
423 | 423 | ) |
424 | 424 | && ($next->type !== Token::TYPE_OPERATOR |
425 | - || ! in_array($next->value, $this->operatorNameIndicators, true) |
|
425 | + || !in_array($next->value, $this->operatorNameIndicators, true) |
|
426 | 426 | ) |
427 | 427 | && ($next->value !== null) |
428 | 428 | ) { |
@@ -505,7 +505,7 @@ discard block |
||
505 | 505 | $token .= $this->str[$this->last]; |
506 | 506 | $flags = Context::isKeyword($token); |
507 | 507 | |
508 | - if (($this->last + 1 !== $this->len && ! Context::isSeparator($this->str[$this->last + 1])) || ! $flags) { |
|
508 | + if (($this->last + 1 !== $this->len && !Context::isSeparator($this->str[$this->last + 1])) || !$flags) { |
|
509 | 509 | continue; |
510 | 510 | } |
511 | 511 | |
@@ -593,7 +593,7 @@ discard block |
||
593 | 593 | $token .= $this->str[$this->last]; |
594 | 594 | $flags = Context::isOperator($token); |
595 | 595 | |
596 | - if (! $flags) { |
|
596 | + if (!$flags) { |
|
597 | 597 | continue; |
598 | 598 | } |
599 | 599 | |
@@ -615,7 +615,7 @@ discard block |
||
615 | 615 | { |
616 | 616 | $token = $this->str[$this->last]; |
617 | 617 | |
618 | - if (! Context::isWhitespace($token)) { |
|
618 | + if (!Context::isWhitespace($token)) { |
|
619 | 619 | return null; |
620 | 620 | } |
621 | 621 | |
@@ -855,7 +855,7 @@ discard block |
||
855 | 855 | } elseif ($state === 2) { |
856 | 856 | $flags |= Token::FLAG_NUMBER_HEX; |
857 | 857 | if ( |
858 | - ! ( |
|
858 | + !( |
|
859 | 859 | ($this->str[$this->last] >= '0' && $this->str[$this->last] <= '9') |
860 | 860 | || ($this->str[$this->last] >= 'A' && $this->str[$this->last] <= 'F') |
861 | 861 | || ($this->str[$this->last] >= 'a' && $this->str[$this->last] <= 'f') |
@@ -958,7 +958,7 @@ discard block |
||
958 | 958 | $token = $this->str[$this->last]; |
959 | 959 | $flags = Context::isString($token); |
960 | 960 | |
961 | - if (! $flags && $token !== $quote) { |
|
961 | + if (!$flags && $token !== $quote) { |
|
962 | 962 | return null; |
963 | 963 | } |
964 | 964 | |
@@ -1010,7 +1010,7 @@ discard block |
||
1010 | 1010 | $token = $this->str[$this->last]; |
1011 | 1011 | $flags = Context::isSymbol($token); |
1012 | 1012 | |
1013 | - if (! $flags) { |
|
1013 | + if (!$flags) { |
|
1014 | 1014 | return null; |
1015 | 1015 | } |
1016 | 1016 | |
@@ -1061,7 +1061,7 @@ discard block |
||
1061 | 1061 | return null; |
1062 | 1062 | } |
1063 | 1063 | |
1064 | - while (++$this->last < $this->len && ! Context::isSeparator($this->str[$this->last])) { |
|
1064 | + while (++$this->last < $this->len && !Context::isSeparator($this->str[$this->last])) { |
|
1065 | 1065 | $token .= $this->str[$this->last]; |
1066 | 1066 | |
1067 | 1067 | // Test if end of token equals the current delimiter. If so, remove it from the token. |
@@ -496,7 +496,7 @@ discard block |
||
496 | 496 | $list->idx = $lastIdx; |
497 | 497 | } elseif (empty(static::$statementParsers[$token->keyword])) { |
498 | 498 | // Checking if it is a known statement that can be parsed. |
499 | - if (! isset(static::$statementParsers[$token->keyword])) { |
|
499 | + if (!isset(static::$statementParsers[$token->keyword])) { |
|
500 | 500 | // A statement is considered recognized if the parser |
501 | 501 | // is aware that it is a statement, but it does not have |
502 | 502 | // a parser for it yet. |
@@ -536,7 +536,7 @@ discard block |
||
536 | 536 | |
537 | 537 | // Handles unions. |
538 | 538 | if ( |
539 | - ! empty($unionType) |
|
539 | + !empty($unionType) |
|
540 | 540 | && ($lastStatement instanceof SelectStatement) |
541 | 541 | && ($statement instanceof SelectStatement) |
542 | 542 | ) { |
@@ -623,7 +623,7 @@ discard block |
||
623 | 623 | * |
624 | 624 | * @throws ParserException throws the exception, if strict mode is enabled. |
625 | 625 | */ |
626 | - public function error($msg, Token|null $token = null, $code = 0): void |
|
626 | + public function error($msg, Token | null $token = null, $code = 0): void |
|
627 | 627 | { |
628 | 628 | $error = new ParserException( |
629 | 629 | Translator::gettext($msg), |
@@ -436,7 +436,7 @@ discard block |
||
436 | 436 | // The options of a clause should stay on the same line and everything that follows. |
437 | 437 | if ( |
438 | 438 | $this->options['parts_newline'] |
439 | - && ! $formattedOptions |
|
439 | + && !$formattedOptions |
|
440 | 440 | && empty(self::$inlineClauses[$lastClause]) |
441 | 441 | && ( |
442 | 442 | $curr->type !== Token::TYPE_KEYWORD |
@@ -496,7 +496,7 @@ discard block |
||
496 | 496 | end($blocksLineEndings) === true |
497 | 497 | || ( |
498 | 498 | empty(self::$inlineClauses[$lastClause]) |
499 | - && ! $shortGroup |
|
499 | + && !$shortGroup |
|
500 | 500 | && $this->options['parts_newline'] |
501 | 501 | ) |
502 | 502 | ) { |
@@ -532,7 +532,7 @@ discard block |
||
532 | 532 | $lineEnded = false; |
533 | 533 | } elseif ( |
534 | 534 | $prev->keyword === 'DELIMITER' |
535 | - || ! ( |
|
535 | + || !( |
|
536 | 536 | ($prev->type === Token::TYPE_OPERATOR && ($prev->value === '.' || $prev->value === '(')) |
537 | 537 | // No space after . ( |
538 | 538 | || ($curr->type === Token::TYPE_OPERATOR |
@@ -648,12 +648,12 @@ discard block |
||
648 | 648 | static $prev; |
649 | 649 | |
650 | 650 | foreach ($this->options['formats'] as $format) { |
651 | - if ($token->type !== $format['type'] || ! (($token->flags & $format['flags']) === $format['flags'])) { |
|
651 | + if ($token->type !== $format['type'] || !(($token->flags & $format['flags']) === $format['flags'])) { |
|
652 | 652 | continue; |
653 | 653 | } |
654 | 654 | |
655 | 655 | // Running transformation function. |
656 | - if (! empty($format['function'])) { |
|
656 | + if (!empty($format['function'])) { |
|
657 | 657 | $func = $format['function']; |
658 | 658 | $text = $func($text); |
659 | 659 | } |
@@ -764,7 +764,7 @@ discard block |
||
764 | 764 | * |
765 | 765 | * @psalm-return 1|2|false |
766 | 766 | */ |
767 | - public static function isClause($token): int|false |
|
767 | + public static function isClause($token): int | false |
|
768 | 768 | { |
769 | 769 | if ( |
770 | 770 | ($token->type === Token::TYPE_KEYWORD && isset(Parser::$statementParsers[$token->keyword])) |
@@ -300,23 +300,23 @@ discard block |
||
300 | 300 | $flags['distinct'] = true; |
301 | 301 | } |
302 | 302 | |
303 | - if (! empty($statement->group) || ! empty($statement->having)) { |
|
303 | + if (!empty($statement->group) || !empty($statement->having)) { |
|
304 | 304 | $flags['is_group'] = true; |
305 | 305 | } |
306 | 306 | |
307 | - if (! empty($statement->into) && ($statement->into->type === 'OUTFILE')) { |
|
307 | + if (!empty($statement->into) && ($statement->into->type === 'OUTFILE')) { |
|
308 | 308 | $flags['is_export'] = true; |
309 | 309 | } |
310 | 310 | |
311 | 311 | $expressions = $statement->expr; |
312 | - if (! empty($statement->join)) { |
|
312 | + if (!empty($statement->join)) { |
|
313 | 313 | foreach ($statement->join as $join) { |
314 | 314 | $expressions[] = $join->expr; |
315 | 315 | } |
316 | 316 | } |
317 | 317 | |
318 | 318 | foreach ($expressions as $expr) { |
319 | - if (! empty($expr->function)) { |
|
319 | + if (!empty($expr->function)) { |
|
320 | 320 | if ($expr->function === 'COUNT') { |
321 | 321 | $flags['is_count'] = true; |
322 | 322 | } elseif (in_array($expr->function, static::$functions)) { |
@@ -331,15 +331,15 @@ discard block |
||
331 | 331 | $flags['is_subquery'] = true; |
332 | 332 | } |
333 | 333 | |
334 | - if (! empty($statement->procedure) && ($statement->procedure->name === 'ANALYSE')) { |
|
334 | + if (!empty($statement->procedure) && ($statement->procedure->name === 'ANALYSE')) { |
|
335 | 335 | $flags['is_analyse'] = true; |
336 | 336 | } |
337 | 337 | |
338 | - if (! empty($statement->group)) { |
|
338 | + if (!empty($statement->group)) { |
|
339 | 339 | $flags['group'] = true; |
340 | 340 | } |
341 | 341 | |
342 | - if (! empty($statement->having)) { |
|
342 | + if (!empty($statement->having)) { |
|
343 | 343 | $flags['having'] = true; |
344 | 344 | } |
345 | 345 | |
@@ -347,7 +347,7 @@ discard block |
||
347 | 347 | $flags['union'] = true; |
348 | 348 | } |
349 | 349 | |
350 | - if (! empty($statement->join)) { |
|
350 | + if (!empty($statement->join)) { |
|
351 | 351 | $flags['join'] = true; |
352 | 352 | } |
353 | 353 | |
@@ -438,11 +438,11 @@ discard block |
||
438 | 438 | || ($statement instanceof UpdateStatement) |
439 | 439 | || ($statement instanceof DeleteStatement) |
440 | 440 | ) { |
441 | - if (! empty($statement->limit)) { |
|
441 | + if (!empty($statement->limit)) { |
|
442 | 442 | $flags['limit'] = true; |
443 | 443 | } |
444 | 444 | |
445 | - if (! empty($statement->order)) { |
|
445 | + if (!empty($statement->order)) { |
|
446 | 446 | $flags['order'] = true; |
447 | 447 | } |
448 | 448 | } |
@@ -492,7 +492,7 @@ discard block |
||
492 | 492 | // Finding tables' aliases and their associated real names. |
493 | 493 | $tableAliases = []; |
494 | 494 | foreach ($statement->from as $expr) { |
495 | - if (! isset($expr->table, $expr->alias) || ($expr->table === '') || ($expr->alias === '')) { |
|
495 | + if (!isset($expr->table, $expr->alias) || ($expr->table === '') || ($expr->alias === '')) { |
|
496 | 496 | continue; |
497 | 497 | } |
498 | 498 | |
@@ -517,7 +517,7 @@ discard block |
||
517 | 517 | ]; |
518 | 518 | } |
519 | 519 | |
520 | - if (! in_array($arr, $ret['select_tables'])) { |
|
520 | + if (!in_array($arr, $ret['select_tables'])) { |
|
521 | 521 | $ret['select_tables'][] = $arr; |
522 | 522 | } |
523 | 523 | } else { |
@@ -530,7 +530,7 @@ discard block |
||
530 | 530 | // extracted from the FROM clause. |
531 | 531 | if ($ret['select_tables'] === []) { |
532 | 532 | foreach ($statement->from as $expr) { |
533 | - if (! isset($expr->table) || ($expr->table === '')) { |
|
533 | + if (!isset($expr->table) || ($expr->table === '')) { |
|
534 | 534 | continue; |
535 | 535 | } |
536 | 536 | |
@@ -571,7 +571,7 @@ discard block |
||
571 | 571 | } elseif (($statement instanceof AlterStatement) || ($statement instanceof TruncateStatement)) { |
572 | 572 | $expressions = [$statement->table]; |
573 | 573 | } elseif ($statement instanceof DropStatement) { |
574 | - if (! $statement->options->has('TABLE')) { |
|
574 | + if (!$statement->options->has('TABLE')) { |
|
575 | 575 | // No tables are dropped. |
576 | 576 | return []; |
577 | 577 | } |
@@ -847,7 +847,7 @@ discard block |
||
847 | 847 | |
848 | 848 | $statement .= $token->token; |
849 | 849 | |
850 | - if (($token->type === Token::TYPE_DELIMITER) && ! empty($token->token)) { |
|
850 | + if (($token->type === Token::TYPE_DELIMITER) && !empty($token->token)) { |
|
851 | 851 | $delimiter = $token->token; |
852 | 852 | $fullStatement = true; |
853 | 853 | break; |
@@ -856,7 +856,7 @@ discard block |
||
856 | 856 | |
857 | 857 | // No statement was found so we return the entire query as being the |
858 | 858 | // remaining part. |
859 | - if (! $fullStatement) { |
|
859 | + if (!$fullStatement) { |
|
860 | 860 | return [ |
861 | 861 | null, |
862 | 862 | $query, |
@@ -357,13 +357,13 @@ discard block |
||
357 | 357 | * |
358 | 358 | * @param bool $isReserved checks if the keyword is reserved |
359 | 359 | */ |
360 | - public static function isKeyword(string $string, bool $isReserved = false): int|null |
|
360 | + public static function isKeyword(string $string, bool $isReserved = false): int | null |
|
361 | 361 | { |
362 | 362 | $upperString = strtoupper($string); |
363 | 363 | |
364 | 364 | if ( |
365 | - ! isset(static::$keywords[$upperString]) |
|
366 | - || ($isReserved && ! (static::$keywords[$upperString] & Token::FLAG_KEYWORD_RESERVED)) |
|
365 | + !isset(static::$keywords[$upperString]) |
|
366 | + || ($isReserved && !(static::$keywords[$upperString] & Token::FLAG_KEYWORD_RESERVED)) |
|
367 | 367 | ) { |
368 | 368 | return null; |
369 | 369 | } |
@@ -374,7 +374,7 @@ discard block |
||
374 | 374 | /** |
375 | 375 | * Checks if the given string is an operator and returns the appropriate flag for the operator. |
376 | 376 | */ |
377 | - public static function isOperator(string $string): int|null |
|
377 | + public static function isOperator(string $string): int | null |
|
378 | 378 | { |
379 | 379 | return static::$operators[$string] ?? null; |
380 | 380 | } |
@@ -392,7 +392,7 @@ discard block |
||
392 | 392 | * |
393 | 393 | * @return int|null the appropriate flag for the comment type |
394 | 394 | */ |
395 | - public static function isComment(string $string, bool $end = false): int|null |
|
395 | + public static function isComment(string $string, bool $end = false): int | null |
|
396 | 396 | { |
397 | 397 | if ($string === '') { |
398 | 398 | return null; |
@@ -455,7 +455,7 @@ discard block |
||
455 | 455 | * |
456 | 456 | * @return int|null the appropriate flag for the symbol type |
457 | 457 | */ |
458 | - public static function isSymbol(string $string): int|null |
|
458 | + public static function isSymbol(string $string): int | null |
|
459 | 459 | { |
460 | 460 | if ($string === '') { |
461 | 461 | return null; |
@@ -483,7 +483,7 @@ discard block |
||
483 | 483 | * |
484 | 484 | * @return int|null the appropriate flag for the string type |
485 | 485 | */ |
486 | - public static function isString(string $string): int|null |
|
486 | + public static function isString(string $string): int | null |
|
487 | 487 | { |
488 | 488 | if ($string === '') { |
489 | 489 | return null; |
@@ -537,7 +537,7 @@ discard block |
||
537 | 537 | $context = self::$contextPrefix . $context; |
538 | 538 | } |
539 | 539 | |
540 | - if (! class_exists($context)) { |
|
540 | + if (!class_exists($context)) { |
|
541 | 541 | return false; |
542 | 542 | } |
543 | 543 | |
@@ -559,7 +559,7 @@ discard block |
||
559 | 559 | * |
560 | 560 | * @return string|null The loaded context. `null` if no context was loaded. |
561 | 561 | */ |
562 | - public static function loadClosest(string $context = ''): string|null |
|
562 | + public static function loadClosest(string $context = ''): string | null |
|
563 | 563 | { |
564 | 564 | $length = strlen($context); |
565 | 565 | for ($i = $length; $i > 0;) { |
@@ -573,7 +573,7 @@ discard block |
||
573 | 573 | $i -= 2; |
574 | 574 | $part = substr($context, $i, 2); |
575 | 575 | /* No more numeric parts to strip */ |
576 | - if (! is_numeric($part)) { |
|
576 | + if (!is_numeric($part)) { |
|
577 | 577 | break 2; |
578 | 578 | } |
579 | 579 | } while (intval($part) === 0 && $i > 0); |
@@ -675,7 +675,7 @@ discard block |
||
675 | 675 | */ |
676 | 676 | public static function escape(string $str, string $quote = '`') |
677 | 677 | { |
678 | - if ((static::$mode & self::SQL_MODE_NO_ENCLOSING_QUOTES) && (! static::isKeyword($str, true))) { |
|
678 | + if ((static::$mode & self::SQL_MODE_NO_ENCLOSING_QUOTES) && (!static::isKeyword($str, true))) { |
|
679 | 679 | return $str; |
680 | 680 | } |
681 | 681 | |
@@ -719,7 +719,7 @@ discard block |
||
719 | 719 | * |
720 | 720 | * @return bool false on empty param, true/false on given constant/int value |
721 | 721 | */ |
722 | - public static function hasMode(int|null $flag = null): bool |
|
722 | + public static function hasMode(int | null $flag = null): bool |
|
723 | 723 | { |
724 | 724 | if (empty($flag)) { |
725 | 725 | return false; |
@@ -63,7 +63,7 @@ discard block |
||
63 | 63 | * |
64 | 64 | * @var ArrayObj[]|null |
65 | 65 | */ |
66 | - public array|null $values = null; |
|
66 | + public array | null $values = null; |
|
67 | 67 | |
68 | 68 | /** |
69 | 69 | * If SET clause is present |
@@ -71,7 +71,7 @@ discard block |
||
71 | 71 | * |
72 | 72 | * @var SetOperation[]|null |
73 | 73 | */ |
74 | - public array|null $set = null; |
|
74 | + public array | null $set = null; |
|
75 | 75 | |
76 | 76 | /** |
77 | 77 | * If SELECT clause is present |
@@ -424,7 +424,7 @@ discard block |
||
424 | 424 | } elseif (($token->value === ',') && ($brackets === 0)) { |
425 | 425 | break; |
426 | 426 | } |
427 | - } elseif (! self::checkIfTokenQuotedSymbol($token)) { |
|
427 | + } elseif (!self::checkIfTokenQuotedSymbol($token)) { |
|
428 | 428 | // If the current token is "SET" or "ENUM", we want to avoid the token between their parenthesis in |
429 | 429 | // the unknown tokens. |
430 | 430 | if (in_array($token->value, ['SET', 'ENUM'], true)) { |
@@ -443,7 +443,7 @@ discard block |
||
443 | 443 | ); |
444 | 444 | break; |
445 | 445 | } |
446 | - } elseif (! empty(Parser::$statementParsers[$token->value])) { |
|
446 | + } elseif (!empty(Parser::$statementParsers[$token->value])) { |
|
447 | 447 | // We have reached the end of ALTER operation and suddenly found |
448 | 448 | // a start to new statement, but have not found a delimiter between them |
449 | 449 | $parser->error( |
@@ -454,7 +454,7 @@ discard block |
||
454 | 454 | } elseif ( |
455 | 455 | (array_key_exists($arrayKey, self::$databaseOptions) |
456 | 456 | || array_key_exists($arrayKey, self::$tableOptions)) |
457 | - && ! self::checkIfColumnDefinitionKeyword($arrayKey) |
|
457 | + && !self::checkIfColumnDefinitionKeyword($arrayKey) |
|
458 | 458 | ) { |
459 | 459 | // This alter operation has finished, which means a comma |
460 | 460 | // was missing before start of new alter operation |
@@ -30,7 +30,7 @@ |
||
30 | 30 | * Test for loading closest SQL context |
31 | 31 | */ |
32 | 32 | #[DataProvider('contextLoadingProvider')] |
33 | - public function testLoadClosest(string $context, string|null $expected): void |
|
33 | + public function testLoadClosest(string $context, string | null $expected): void |
|
34 | 34 | { |
35 | 35 | $this->assertEquals($expected, Context::loadClosest($context)); |
36 | 36 | if ($expected !== null) { |
@@ -86,7 +86,7 @@ |
||
86 | 86 | * Test access to string. |
87 | 87 | */ |
88 | 88 | #[DataProvider('utf8StringsProvider')] |
89 | - public function testAccess(string $text, string|null $pos10, string|null $pos20): void |
|
89 | + public function testAccess(string $text, string | null $pos10, string | null $pos20): void |
|
90 | 90 | { |
91 | 91 | $str = new UtfString($text); |
92 | 92 | $this->assertEquals($pos10, $str->offsetGet(10)); |