Total Complexity | 6 |
Total Lines | 36 |
Duplicated Lines | 0 % |
Changes | 1 | ||
Bugs | 0 | Features | 0 |
1 | <?php |
||
5 | class XrefService |
||
6 | { |
||
7 | /** |
||
8 | * Regex patterns to parse Xref tokens (e.g. alt.binaries.* optionally followed by :number). |
||
9 | */ |
||
10 | private const XREF_PATTERN_WITH_NUM = '/(^[a-zA-Z]{2,3}\\.(bin(aries|arios|aer))\\.[a-zA-Z0-9]?.+)(:\\d+)/'; |
||
11 | |||
12 | private const XREF_PATTERN_NO_NUM = '/(^[a-zA-Z]{2,3}\\.(bin(aries|arios|aer))\\.[a-zA-Z0-9]?.+)/'; |
||
13 | |||
14 | /** |
||
15 | * Extracts valid Xref tokens from a space-separated Xref string. |
||
16 | */ |
||
17 | public function extractTokens(?string $xref): array |
||
18 | { |
||
19 | if (empty($xref)) { |
||
20 | return []; |
||
21 | } |
||
22 | $tokens = []; |
||
23 | foreach (explode(' ', $xref) as $token) { |
||
24 | if (preg_match(self::XREF_PATTERN_WITH_NUM, $token, $m) || preg_match(self::XREF_PATTERN_NO_NUM, $token, $m)) { |
||
25 | $tokens[] = $m[0]; |
||
26 | } |
||
27 | } |
||
28 | |||
29 | return $tokens; |
||
30 | } |
||
31 | |||
32 | /** |
||
33 | * Returns tokens that appear in $headerXref but not in $existingXref. |
||
34 | */ |
||
35 | public function diffNewTokens(?string $existingXref, ?string $headerXref): array |
||
41 | } |
||
42 | } |
||
43 |