This issue was mentioned in bug #73948. The PREG_PATTERN_ORDER
padding was performed without respecting the PREF_OFFSET_CAPTURE
flag, which resulted in unmatched subpatterns being either null or
[null, -1] depending on where they occur. Now they will always be
[null, -1], consistent with other usages.
*/
if (count < num_subpats) {
for (; i < num_subpats; i++) {
- if (unmatched_as_null) {
+ if (offset_capture) {
+ add_offset_pair(
+ &match_sets[i], NULL, 0, PCRE2_UNSET,
+ NULL, unmatched_as_null);
+ } else if (unmatched_as_null) {
add_next_index_null(&match_sets[i]);
} else {
add_next_index_str(&match_sets[i], ZSTR_EMPTY_ALLOC());
),
1 =>
array (
- 0 => NULL,
+ 0 =>
+ array (
+ 0 => NULL,
+ 1 => -1,
+ ),
1 =>
array (
0 => NULL,
0 => '4',
1 => 3,
),
- 3 => NULL,
+ 3 =>
+ array (
+ 0 => NULL,
+ 1 => -1,
+ ),
),
2 =>
array (
- 0 => NULL,
+ 0 =>
+ array (
+ 0 => NULL,
+ 1 => -1,
+ ),
1 =>
array (
0 => '2',
1 => 1,
),
- 2 => NULL,
- 3 => NULL,
+ 2 =>
+ array (
+ 0 => NULL,
+ 1 => -1,
+ ),
+ 3 =>
+ array (
+ 0 => NULL,
+ 1 => -1,
+ ),
),
)
),
'a' =>
array (
- 0 => NULL,
+ 0 =>
+ array (
+ 0 => NULL,
+ 1 => -1,
+ ),
1 =>
array (
0 => NULL,
0 => '4',
1 => 3,
),
- 3 => NULL,
+ 3 =>
+ array (
+ 0 => NULL,
+ 1 => -1,
+ ),
),
1 =>
array (
- 0 => NULL,
+ 0 =>
+ array (
+ 0 => NULL,
+ 1 => -1,
+ ),
1 =>
array (
0 => NULL,
0 => '4',
1 => 3,
),
- 3 => NULL,
+ 3 =>
+ array (
+ 0 => NULL,
+ 1 => -1,
+ ),
),
'b' =>
array (
- 0 => NULL,
+ 0 =>
+ array (
+ 0 => NULL,
+ 1 => -1,
+ ),
1 =>
array (
0 => '2',
1 => 1,
),
- 2 => NULL,
- 3 => NULL,
+ 2 =>
+ array (
+ 0 => NULL,
+ 1 => -1,
+ ),
+ 3 =>
+ array (
+ 0 => NULL,
+ 1 => -1,
+ ),
),
2 =>
array (
- 0 => NULL,
+ 0 =>
+ array (
+ 0 => NULL,
+ 1 => -1,
+ ),
1 =>
array (
0 => '2',
1 => 1,
),
- 2 => NULL,
- 3 => NULL,
+ 2 =>
+ array (
+ 0 => NULL,
+ 1 => -1,
+ ),
+ 3 =>
+ array (
+ 0 => NULL,
+ 1 => -1,
+ ),
),
)