Completed
Pull Request — master (#16)
by Matt
08:23 queued 05:46
created

functions.php ➔ as_string()   D

Complexity

Conditions 9
Paths 9

Size

Total Lines 32
Code Lines 16

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 14
CRAP Score 9.0239
Metric Value
cc 9
eloc 16
nc 9
nop 1
dl 0
loc 32
ccs 14
cts 15
cp 0.9333
crap 9.0239
rs 4.909
1
<?php
2
3
namespace League\JsonGuard;
4
5
/**
6
 * @param string $json
7
 * @param bool   $assoc
8
 * @param int    $depth
9
 * @param int    $options
10
 * @return mixed
11
 * @throws \InvalidArgumentException
12
 */
13
function json_decode($json, $assoc = false, $depth = 512, $options = 0)
14
{
15 14
    $data = \json_decode($json, $assoc, $depth, $options);
16
17 14
    if (json_last_error() !== JSON_ERROR_NONE) {
18
        throw new \InvalidArgumentException(sprintf('Invalid JSON: %s', json_last_error_msg()));
19
    }
20
21 14
    return $data;
22
}
23
24
/**
25
 * @param $string
26
 * @return int
27
 */
28
function strlen($string)
29
{
30 4
    if (extension_loaded('intl')) {
31 4
        return grapheme_strlen($string);
32
    }
33
34
    if (extension_loaded('mbstring')) {
35
        return mb_strlen($string, mb_detect_encoding($string));
36
    }
37
38
    return strlen($string);
39
}
40
41
/**
42
 * Returns the string representation of a value.
43
 *
44
 * @param mixed $value
45
 * @return string
46
 */
47
function as_string($value)
48
{
49 31
    if (is_string($value)) {
50 16
        return $value;
51
    }
52
53 25
    if (is_int($value)) {
54 20
        return (string)$value;
55
    }
56
57 14
    if (is_bool($value)) {
58 4
        return $value ? '<TRUE>' : '<FALSE>';
59
    }
60
61 12
    if (is_object($value)) {
62 3
        return get_class($value);
63
    }
64
65 12
    if (is_array($value)) {
66 4
        return '<ARRAY>';
67
    }
68
69 10
    if (is_resource($value)) {
70
        return '<RESOURCE>';
71
    }
72
73 10
    if (is_null($value)) {
74 3
        return '<NULL>';
75
    }
76
77 8
    return '<UNKNOWN>';
78
}
79
80
/**
81
 * Get the properties matching $pattern from the $data.
82
 *
83
 * @param string       $pattern
84
 * @param array|object $data
85
 * @return array
86
 */
87
function properties_matching_pattern($pattern, $data)
88
{
89
    // If an object is supplied, extract an array of the property names.
90 2
    if (is_object($data)) {
91 2
        $data = array_keys(get_object_vars($data));
92 2
    }
93
94 2
    return preg_grep(delimit_pattern($pattern), $data);
95
}
96
97
/**
98
 * Delimit a regular expression pattern.
99
 *
100
 * The regular expression syntax used for JSON schema is ECMA 262, from Javascript,
101
 * and does not use delimiters.  Since the PCRE functions do, this function will
102
 * delimit a pattern and escape the delimiter if found in the pattern.
103
 *
104
 * @see http://json-schema.org/latest/json-schema-validation.html#anchor6
105
 * @see http://php.net/manual/en/regexp.reference.delimiters.php
106
 *
107
 * @param string $pattern
108
 *
109
 * @return string
110
 */
111
function delimit_pattern($pattern)
112
{
113 3
    return '/' . str_replace('/', '\\/', $pattern) . '/';
114
}
115
116
/**
117
 * Escape a JSON Pointer.
118
 *
119
 * @param  string $pointer
120
 * @return string
121
 */
122
function escape_pointer($pointer)
123
{
124 30
    $pointer = str_replace('~', '~0', $pointer);
125 30
    return str_replace('/', '~1', $pointer);
126
}
127