mirror of
https://github.com/php/php-src.git
synced 2025-08-15 21:48:51 +02:00
Merge branch 'PHP-8.0'
* PHP-8.0: Fix #74264: grapheme_strrpos() broken for negative offsets
This commit is contained in:
commit
097cae9d90
2 changed files with 42 additions and 5 deletions
|
@ -157,16 +157,29 @@ int32_t grapheme_strpos_utf16(char *haystack, size_t haystack_len, char *needle,
|
|||
goto finish;
|
||||
}
|
||||
status = U_ZERO_ERROR;
|
||||
usearch_setOffset(src, offset_pos, &status);
|
||||
usearch_setOffset(src, last ? 0 : offset_pos, &status);
|
||||
STRPOS_CHECK_STATUS(status, "Invalid search offset");
|
||||
}
|
||||
|
||||
|
||||
if(last) {
|
||||
char_pos = usearch_last(src, &status);
|
||||
if(char_pos < offset_pos) {
|
||||
/* last one is beyound our start offset */
|
||||
char_pos = USEARCH_DONE;
|
||||
if (offset >= 0) {
|
||||
char_pos = usearch_last(src, &status);
|
||||
if(char_pos < offset_pos) {
|
||||
/* last one is beyond our start offset */
|
||||
char_pos = USEARCH_DONE;
|
||||
}
|
||||
} else {
|
||||
/* searching backwards is broken, so we search forwards, albeit it's less efficient */
|
||||
int32_t prev_pos = USEARCH_DONE;
|
||||
do {
|
||||
char_pos = usearch_next(src, &status);
|
||||
if (char_pos == USEARCH_DONE || char_pos > offset_pos) {
|
||||
char_pos = prev_pos;
|
||||
break;
|
||||
}
|
||||
prev_pos = char_pos;
|
||||
} while(1);
|
||||
}
|
||||
} else {
|
||||
char_pos = usearch_next(src, &status);
|
||||
|
|
24
ext/intl/tests/bug74264.phpt
Normal file
24
ext/intl/tests/bug74264.phpt
Normal file
|
@ -0,0 +1,24 @@
|
|||
--TEST--
|
||||
Bug #74264 (grapheme_sttrpos() broken for negative offsets)
|
||||
--EXTENSIONS--
|
||||
intl
|
||||
--FILE--
|
||||
<?php
|
||||
foreach (range(-5, -1) as $offset) {
|
||||
var_dump(
|
||||
grapheme_strrpos('déjàààà', 'à', $offset),
|
||||
grapheme_strripos('DÉJÀÀÀÀ', 'à', $offset)
|
||||
);
|
||||
}
|
||||
?>
|
||||
--EXPECT--
|
||||
bool(false)
|
||||
bool(false)
|
||||
int(3)
|
||||
int(3)
|
||||
int(4)
|
||||
int(4)
|
||||
int(5)
|
||||
int(5)
|
||||
int(6)
|
||||
int(6)
|
Loading…
Add table
Add a link
Reference in a new issue