-
Notifications
You must be signed in to change notification settings - Fork 9
Expand file tree
/
Copy pathStringValueParser.php
More file actions
106 lines (90 loc) · 2.13 KB
/
StringValueParser.php
File metadata and controls
106 lines (90 loc) · 2.13 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
<?php
declare( strict_types = 1 );
namespace ValueParsers;
use InvalidArgumentException;
use RuntimeException;
/**
* Basic implementation for DataValue parsers that share one or more of the following aspects:
* - The provided input must be a string.
* - The parser utilizes ParserOptions.
* - The parser utilizes a "lang" option, which defaults to "en".
*
* @since 0.1
*
* @license GPL-2.0-or-later
* @author Jeroen De Dauw < jeroendedauw@gmail.com >
*/
abstract class StringValueParser implements ValueParser {
/**
* @var ParserOptions
*/
protected $options;
/**
* @param ParserOptions|null $options
*/
public function __construct( ?ParserOptions $options = null ) {
$this->options = $options ?: new ParserOptions();
$this->defaultOption( ValueParser::OPT_LANG, 'en' );
}
/**
* @see ValueParser::parse
*
* @param string $value
*
* @return mixed
* @throws ParseException if the provided value is not a string
*/
public function parse( $value ) {
if ( is_string( $value ) ) {
return $this->stringParse( $value );
}
throw new ParseException( 'Not a string' );
}
/**
* Parses the provided string and returns the result.
*
* @param string $value
*
* @return mixed
*/
abstract protected function stringParse( $value );
public function setOptions( ParserOptions $options ) {
$this->options = $options;
}
/**
* @return ParserOptions
*/
public function getOptions() {
return $this->options;
}
/**
* Shortcut to $this->options->getOption.
*
* @param string $option
*
* @throws InvalidArgumentException
* @return mixed
*/
final protected function getOption( $option ) {
return $this->options->getOption( $option );
}
/**
* Shortcut to $this->options->requireOption.
*
* @param string $option
*
* @throws RuntimeException
*/
final protected function requireOption( $option ) {
$this->options->requireOption( $option );
}
/**
* Shortcut to $this->options->defaultOption.
*
* @param string $option
* @param mixed $default
*/
final protected function defaultOption( $option, $default ) {
$this->options->defaultOption( $option, $default );
}
}