Conditions | 3 |
Paths | 3 |
Total Lines | 218 |
Lines | 0 |
Ratio | 0 % |
Changes | 0 |
Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.
For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.
Commonly applied refactorings include:
If many parameters/temporary variables are present:
1 | <?php |
||
45 | public function provideShortcodes() |
||
46 | { |
||
47 | $s = new CommonSyntax(); |
||
48 | |||
49 | $tests = array( |
||
50 | // invalid |
||
51 | array($s, '', array()), |
||
52 | array($s, '[]', array()), |
||
53 | array($s, '', array()), |
||
54 | array($s, 'x html([a. title][, alt][, classes]) x', array()), |
||
55 | array($s, '[/y]', array()), |
||
56 | array($s, '[sc', array()), |
||
57 | array($s, '[sc / [/sc]', array()), |
||
58 | array($s, '[sc arg="val', array()), |
||
59 | |||
60 | // single shortcodes |
||
61 | array($s, '[sc]', array( |
||
62 | new ParsedShortcode(new Shortcode('sc', array(), null), '[sc]', 0), |
||
63 | )), |
||
64 | array($s, '[sc arg=val]', array( |
||
65 | new ParsedShortcode(new Shortcode('sc', array('arg' => 'val'), null), '[sc arg=val]', 0), |
||
66 | )), |
||
67 | array($s, '[sc novalue arg="complex value"]', array( |
||
68 | new ParsedShortcode(new Shortcode('sc', array('novalue' => null, 'arg' => 'complex value'), null), '[sc novalue arg="complex value"]', 0), |
||
69 | )), |
||
70 | array($s, '[sc x="ąćęłńóśżź ĄĆĘŁŃÓŚŻŹ"]', array( |
||
71 | new ParsedShortcode(new Shortcode('sc', array('x' => 'ąćęłńóśżź ĄĆĘŁŃÓŚŻŹ'), null), '[sc x="ąćęłńóśżź ĄĆĘŁŃÓŚŻŹ"]', 0), |
||
72 | )), |
||
73 | array($s, '[sc x="multi'."\n".'line"]', array( |
||
74 | new ParsedShortcode(new Shortcode('sc', array('x' => 'multi'."\n".'line'), null), '[sc x="multi'."\n".'line"]', 0), |
||
75 | )), |
||
76 | array($s, '[sc noval x="val" y]content[/sc]', array( |
||
77 | new ParsedShortcode(new Shortcode('sc', array('noval' => null, 'x' => 'val', 'y' => null), 'content'), '[sc noval x="val" y]content[/sc]', 0), |
||
78 | )), |
||
79 | array($s, '[sc x="{..}"]', array( |
||
80 | new ParsedShortcode(new Shortcode('sc', array('x' => '{..}'), null), '[sc x="{..}"]', 0), |
||
81 | )), |
||
82 | array($s, '[sc a="x y" b="x" c=""]', array( |
||
83 | new ParsedShortcode(new Shortcode('sc', array('a' => 'x y', 'b' => 'x', 'c' => ''), null), '[sc a="x y" b="x" c=""]', 0), |
||
84 | )), |
||
85 | array($s, '[sc a="a \"\" b"]', array( |
||
86 | new ParsedShortcode(new Shortcode('sc', array('a' => 'a \"\" b'), null), '[sc a="a \"\" b"]', 0), |
||
87 | )), |
||
88 | array($s, '[sc/]', array( |
||
89 | new ParsedShortcode(new Shortcode('sc', array(), null), '[sc/]', 0), |
||
90 | )), |
||
91 | array($s, '[sc /]', array( |
||
92 | new ParsedShortcode(new Shortcode('sc', array(), null), '[sc /]', 0), |
||
93 | )), |
||
94 | array($s, '[sc arg=val cmp="a b"/]', array( |
||
95 | new ParsedShortcode(new Shortcode('sc', array('arg' => 'val', 'cmp' => 'a b'), null), '[sc arg=val cmp="a b"/]', 0), |
||
96 | )), |
||
97 | array($s, '[sc x y /]', array( |
||
98 | new ParsedShortcode(new Shortcode('sc', array('x' => null, 'y' => null), null), '[sc x y /]', 0), |
||
99 | )), |
||
100 | array($s, '[sc x="\ " /]', array( |
||
101 | new ParsedShortcode(new Shortcode('sc', array('x' => '\ '), null), '[sc x="\ " /]', 0), |
||
102 | )), |
||
103 | array($s, '[ sc x = "\ " y = value z / ]', array( |
||
104 | new ParsedShortcode(new Shortcode('sc', array('x' => '\ ', 'y' => 'value', 'z' => null), null), '[ sc x = "\ " y = value z / ]', 0), |
||
105 | )), |
||
106 | array($s, '[ sc x= "\ " y =value ] vv [ / sc ]', array( |
||
107 | new ParsedShortcode(new Shortcode('sc', array('x' => '\ ', 'y' => 'value'), ' vv '), '[ sc x= "\ " y =value ] vv [ / sc ]', 0), |
||
108 | )), |
||
109 | array($s, '[sc url="http://giggle.com/search" /]', array( |
||
110 | new ParsedShortcode(new Shortcode('sc', array('url' => 'http://giggle.com/search'), null), '[sc url="http://giggle.com/search" /]', 0), |
||
111 | )), |
||
112 | |||
113 | // bbcode |
||
114 | array($s, '[sc = "http://giggle.com/search" /]', array( |
||
115 | new ParsedShortcode(new Shortcode('sc', array(), null, 'http://giggle.com/search'), '[sc = "http://giggle.com/search" /]', 0), |
||
116 | )), |
||
117 | |||
118 | // multiple shortcodes |
||
119 | array($s, 'Lorem [ipsum] random [code-code arg=val] which is here', array( |
||
120 | new ParsedShortcode(new Shortcode('ipsum', array(), null), '[ipsum]', 6), |
||
121 | new ParsedShortcode(new Shortcode('code-code', array('arg' => 'val'), null), '[code-code arg=val]', 21), |
||
122 | )), |
||
123 | array($s, 'x [aa] x [aa] x', array( |
||
124 | new ParsedShortcode(new Shortcode('aa', array(), null), '[aa]', 2), |
||
125 | new ParsedShortcode(new Shortcode('aa', array(), null), '[aa]', 9), |
||
126 | )), |
||
127 | array($s, 'x [x]a[/x] x [x]a[/x] x', array( |
||
128 | new ParsedShortcode(new Shortcode('x', array(), 'a'), '[x]a[/x]', 2), |
||
129 | new ParsedShortcode(new Shortcode('x', array(), 'a'), '[x]a[/x]', 13), |
||
130 | )), |
||
131 | array($s, 'x [x x y=z a="b c"]a[/x] x [x x y=z a="b c"]a[/x] x', array( |
||
132 | new ParsedShortcode(new Shortcode('x', array('x' => null, 'y' => 'z', 'a' => 'b c'), 'a'), '[x x y=z a="b c"]a[/x]', 2), |
||
133 | new ParsedShortcode(new Shortcode('x', array('x' => null, 'y' => 'z', 'a' => 'b c'), 'a'), '[x x y=z a="b c"]a[/x]', 27), |
||
134 | )), |
||
135 | array($s, 'x [code /] y [code]z[/code] x [code] y [code/] a', array( |
||
136 | new ParsedShortcode(new Shortcode('code', array(), null), '[code /]', 2), |
||
137 | new ParsedShortcode(new Shortcode('code', array(), 'z'), '[code]z[/code]', 13), |
||
138 | new ParsedShortcode(new Shortcode('code', array(), null), '[code]', 30), |
||
139 | new ParsedShortcode(new Shortcode('code', array(), null), '[code/]', 39), |
||
140 | )), |
||
141 | array($s, 'x [code arg=val /] y [code cmp="xx"/] x [code x=y/] a', array( |
||
142 | new ParsedShortcode(new Shortcode('code', array('arg' => 'val'), null), '[code arg=val /]', 2), |
||
143 | new ParsedShortcode(new Shortcode('code', array('cmp' => 'xx'), null), '[code cmp="xx"/]', 21), |
||
144 | new ParsedShortcode(new Shortcode('code', array('x' => 'y'), null), '[code x=y/]', 40), |
||
145 | )), |
||
146 | array($s, 'x [ code arg=val /]a[ code/]c[x / ] m [ y ] c [ / y]', array( |
||
147 | new ParsedShortcode(new Shortcode('code', array('arg' => 'val'), null), '[ code arg=val /]', 2), |
||
148 | new ParsedShortcode(new Shortcode('code', array(), null), '[ code/]', 23), |
||
149 | new ParsedShortcode(new Shortcode('x', array(), null), '[x / ]', 32), |
||
150 | new ParsedShortcode(new Shortcode('y', array(), ' c '), '[ y ] c [ / y]', 47), |
||
151 | )), |
||
152 | |||
153 | // other syntax |
||
154 | array(new Syntax('[[', ']]', '//', '==', '""'), '[[code arg==""val oth""]]cont[[//code]]', array( |
||
155 | new ParsedShortcode(new Shortcode('code', array('arg' => 'val oth'), 'cont'), '[[code arg==""val oth""]]cont[[//code]]', 0), |
||
156 | )), |
||
157 | array(new Syntax('^', '$', '&', '!!!', '@@'), '^code a!!!@@\"\"@@ b!!!@@x\"y@@ c$cnt^&code$', array( |
||
158 | new ParsedShortcode(new Shortcode('code', array('a' => '\"\"', 'b' => 'x\"y', 'c' => null), 'cnt'), '^code a!!!@@\"\"@@ b!!!@@x\"y@@ c$cnt^&code$', 0), |
||
159 | )), |
||
160 | |||
161 | // UTF-8 sequences |
||
162 | array($s, '’’’’[sc]’’[sc]', array( |
||
163 | new ParsedShortcode(new Shortcode('sc', array(), null), '[sc]', 4), |
||
164 | new ParsedShortcode(new Shortcode('sc', array(), null), '[sc]', 10), |
||
165 | )), |
||
166 | |||
167 | // performance |
||
168 | // array($s, 'x [[aa]] y', array()), |
||
169 | array($s, str_repeat('[a]', 20), array_map(function($offset) { // 20 |
||
170 | return new ParsedShortcode(new Shortcode('a', array(), null), '[a]', $offset); |
||
171 | }, range(0, 57, 3))), |
||
172 | array($s, '[b][a]x[a][/a][/a][/b] [b][a][a][/a]y[/a][/b]', array( |
||
173 | new ParsedShortcode(new Shortcode('b', array(), '[a]x[a][/a][/a]'), '[b][a]x[a][/a][/a][/b]', 0), |
||
174 | new ParsedShortcode(new Shortcode('b', array(), '[a][a][/a]y[/a]'), '[b][a][a][/a]y[/a][/b]', 23), |
||
175 | )), |
||
176 | array($s, '[b] [a][a][a] [/b] [b] [a][a][a] [/b]', array( |
||
177 | new ParsedShortcode(new Shortcode('b', array(), ' [a][a][a] '), '[b] [a][a][a] [/b]', 0), |
||
178 | new ParsedShortcode(new Shortcode('b', array(), ' [a][a][a] '), '[b] [a][a][a] [/b]', 19), |
||
179 | )), |
||
180 | array($s, '[name]random[/other]', array( |
||
181 | new ParsedShortcode(new Shortcode('name', array(), null), '[name]', 0), |
||
182 | )), |
||
183 | array($s, '[0][1][2][3]', array( |
||
184 | new ParsedShortcode(new Shortcode('0', array(), null), '[0]', 0), |
||
185 | new ParsedShortcode(new Shortcode('1', array(), null), '[1]', 3), |
||
186 | new ParsedShortcode(new Shortcode('2', array(), null), '[2]', 6), |
||
187 | new ParsedShortcode(new Shortcode('3', array(), null), '[3]', 9), |
||
188 | )), |
||
189 | array($s, '[_][na_me][_name][name_][n_am_e][_n_]', array( |
||
190 | new ParsedShortcode(new Shortcode('_', array(), null), '[_]', 0), |
||
191 | new ParsedShortcode(new Shortcode('na_me', array(), null), '[na_me]', 3), |
||
192 | new ParsedShortcode(new Shortcode('_name', array(), null), '[_name]', 10), |
||
193 | new ParsedShortcode(new Shortcode('name_', array(), null), '[name_]', 17), |
||
194 | new ParsedShortcode(new Shortcode('n_am_e', array(), null), '[n_am_e]', 24), |
||
195 | new ParsedShortcode(new Shortcode('_n_', array(), null), '[_n_]', 32), |
||
196 | )), |
||
197 | array($s, '[x]/[/x] [x]"[/x] [x]=[/x] [x]][/x] [x] [/x] [x]x[/x]', array( |
||
198 | new ParsedShortcode(new Shortcode('x', array(), '/'), '[x]/[/x]', 0), |
||
199 | new ParsedShortcode(new Shortcode('x', array(), '"'), '[x]"[/x]', 9), |
||
200 | new ParsedShortcode(new Shortcode('x', array(), '='), '[x]=[/x]', 18), |
||
201 | new ParsedShortcode(new Shortcode('x', array(), ']'), '[x]][/x]', 27), |
||
202 | new ParsedShortcode(new Shortcode('x', array(), ' '), '[x] [/x]', 36), |
||
203 | new ParsedShortcode(new Shortcode('x', array(), 'x'), '[x]x[/x]', 45), |
||
204 | )), |
||
205 | array($s, '[a]0[/a]', array( |
||
206 | new ParsedShortcode(new Shortcode('a', array(), '0'), '[a]0[/a]', 0), |
||
207 | )), |
||
208 | array($s, '[fa icon=fa-camera /] [fa icon=fa-camera extras=fa-4x /]', array( |
||
209 | new ParsedShortcode(new Shortcode('fa', array('icon' => 'fa-camera'), null), '[fa icon=fa-camera /]', 0), |
||
210 | new ParsedShortcode(new Shortcode('fa', array('icon' => 'fa-camera', 'extras' => 'fa-4x'), null), '[fa icon=fa-camera extras=fa-4x /]', 22), |
||
211 | )), |
||
212 | array($s, '[fa icon=fa-circle-o-notch extras=fa-spin,fa-3x /]', array( |
||
213 | new ParsedShortcode(new Shortcode('fa', array('icon' => 'fa-circle-o-notch', 'extras' => 'fa-spin,fa-3x'), null), '[fa icon=fa-circle-o-notch extras=fa-spin,fa-3x /]', 0), |
||
214 | )), |
||
215 | array($s, '[z =]', array()), |
||
216 | array($s, '[x=#F00 one=#F00 two="#F00"]', array( |
||
217 | new ParsedShortcode(new Shortcode('x', array('one' => '#F00', 'two' => '#F00'), null, '#F00'), '[x=#F00 one=#F00 two="#F00"]', 0), |
||
218 | )), |
||
219 | array($s, '[*] [* xyz arg=val]', array( |
||
220 | new ParsedShortcode(new Shortcode('*', array(), null, null), '[*]', 0), |
||
221 | new ParsedShortcode(new Shortcode('*', array('xyz' => null, 'arg' => 'val'), null, null), '[* xyz arg=val]', 4), |
||
222 | )), |
||
223 | array($s, '[*=bb x=y]cnt[/*]', array( |
||
224 | new ParsedShortcode(new Shortcode('*', array('x' => 'y'), 'cnt', 'bb'), '[*=bb x=y]cnt[/*]', 0), |
||
225 | )), |
||
226 | array($s, '[ [] ] [x] [ ] [/x] ] [] [ [y] ] [] [ [z] [/#] [/z] [ [] ] [/] [/y] ] [z] [ [/ [/] /] ] [/z]', array( |
||
227 | new ParsedShortcode(new Shortcode('x', array(), ' [ ] ', null), '[x] [ ] [/x]', 7), |
||
228 | new ParsedShortcode(new Shortcode('y', array(), ' ] [] [ [z] [/#] [/z] [ [] ] [/] ', null), '[y] ] [] [ [z] [/#] [/z] [ [] ] [/] [/y]', 27), |
||
229 | new ParsedShortcode(new Shortcode('z', array(), ' [ [/ [/] /] ] ', null), '[z] [ [/ [/] /] ] [/z]', 70), |
||
230 | )), |
||
231 | // falsy string values |
||
232 | array($s, '[a=0 b=0]0[/a]', array( |
||
233 | new ParsedShortcode(new Shortcode('a', array('b' => '0'), '0', '0'), '[a=0 b=0]0[/a]', 0), |
||
234 | )), |
||
235 | ); |
||
236 | |||
237 | /** |
||
238 | * WordPress can't handle: |
||
239 | * - incorrect shortcode opening tag (blindly matches everything |
||
240 | * between opening token and closing token) |
||
241 | * - spaces between shortcode open tag and its name ([ name]), |
||
242 | * - spaces around BBCode part ([name = "bbcode"]), |
||
243 | * - escaped tokens anywhere in the arguments ([x arg=" \" "]), |
||
244 | * - configurable syntax (that's intended), |
||
245 | * - numbers in shortcode name. |
||
246 | * |
||
247 | * Tests cases from array above with identifiers in the array below must be skipped. |
||
248 | */ |
||
249 | $wordpressSkip = array(3, 6, 16, 21, 22, 23, 25, 32, 33, 34, 46, 47, 49, 51); |
||
250 | $result = array(); |
||
251 | foreach($tests as $key => $test) { |
||
252 | $syntax = array_shift($test); |
||
253 | |||
254 | $result[] = array_merge(array(new RegexParser($syntax)), $test); |
||
255 | $result[] = array_merge(array(new RegularParser($syntax)), $test); |
||
256 | if(!in_array($key, $wordpressSkip, true)) { |
||
257 | $result[] = array_merge(array(new WordpressParser()), $test); |
||
258 | } |
||
259 | } |
||
260 | |||
261 | return $result; |
||
262 | } |
||
263 | |||
322 |
It seems like the type of the argument is not accepted by the function/method which you are calling.
In some cases, in particular if PHP’s automatic type-juggling kicks in this might be fine. In other cases, however this might be a bug.
We suggest to add an explicit type cast like in the following example: