• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

brick / postcode / 19098923587

05 Nov 2025 10:27AM UTC coverage: 81.782% (-17.6%) from 99.396%
19098923587

Pull #19

github

web-flow
Merge 79bf98178 into 8ef37e5aa
Pull Request #19: Add hint to formatter, so a hint can be provided if postcode is invalid

5 of 184 new or added lines in 183 files covered. (2.72%)

2 existing lines in 1 file now uncovered.

826 of 1010 relevant lines covered (81.78%)

15.02 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

88.89
/src/Formatter/SAFormatter.php
1
<?php
2

3
declare(strict_types=1);
4

5
namespace Brick\Postcode\Formatter;
6

7
use Brick\Postcode\CountryPostcodeFormatter;
8

9
use function preg_match;
10
use function strlen;
11
use function substr;
12

13
/**
14
 * Validates and formats postcodes in Saudi Arabia.
15
 *
16
 * The postcode format is NNNNN for PO Boxes and NNNNN-NNNN for home delivery, N standing for a digit.
17
 *
18
 * @see https://en.wikipedia.org/wiki/List_of_postal_codes
19
 */
20
final class SAFormatter implements CountryPostcodeFormatter
21
{
22
    public function hint(): string
23
    {
NEW
24
        return 'The postcode format is NNNNN for PO Boxes and NNNNN-NNNN for home delivery, N standing for a digit.';
×
25
    }
26

27
    public function format(string $postcode): ?string
28
    {
29
        if (preg_match('/^[0-9]+$/', $postcode) !== 1) {
20✔
30
            return null;
11✔
31
        }
32

33
        $length = strlen($postcode);
9✔
34

35
        if ($length === 5) {
9✔
36
            return $postcode;
1✔
37
        }
38

39
        if ($length === 9) {
8✔
40
            return substr($postcode, 0, 5) . '-' . substr($postcode, -4);
1✔
41
        }
42

43
        return null;
7✔
44
    }
45
}
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2026 Coveralls, Inc