@@ -1,6 +1,6 @@ discard block |
||
1 | 1 | <?php |
2 | 2 | |
3 | -include_once __DIR__ . '/LoggerAwareTestCase.php'; |
|
3 | +include_once __DIR__.'/LoggerAwareTestCase.php'; |
|
4 | 4 | |
5 | 5 | /** |
6 | 6 | * Tests involving xml parsing. |
@@ -101,7 +101,7 @@ discard block |
||
101 | 101 | |
102 | 102 | public function testI8() |
103 | 103 | { |
104 | - if (PHP_INT_SIZE == 4 ) { |
|
104 | + if (PHP_INT_SIZE == 4) { |
|
105 | 105 | $this->markTestSkipped('Can not test i8 as php is compiled in 32 bit mode'); |
106 | 106 | } |
107 | 107 | |
@@ -175,7 +175,7 @@ discard block |
||
175 | 175 | |
176 | 176 | public function testUnicodeInMemberName() |
177 | 177 | { |
178 | - $str = "G" . chr(252) . "nter, El" . chr(232) . "ne"; |
|
178 | + $str = "G".chr(252)."nter, El".chr(232)."ne"; |
|
179 | 179 | $v = array($str => new xmlrpcval(1)); |
180 | 180 | $r = new xmlrpcresp(new xmlrpcval($v, 'struct')); |
181 | 181 | $r = $r->serialize(); |
@@ -191,7 +191,7 @@ discard block |
||
191 | 191 | $response = @utf8_encode( |
192 | 192 | '<?xml version="1.0"?> |
193 | 193 | <!-- covers what happens when lib receives UTF8 chars in response text and comments --> |
194 | -<!-- ' . chr(224) . chr(252) . chr(232) . 'àüè --> |
|
194 | +<!-- ' . chr(224).chr(252).chr(232).'àüè --> |
|
195 | 195 | <methodResponse> |
196 | 196 | <fault> |
197 | 197 | <value> |
@@ -202,7 +202,7 @@ discard block |
||
202 | 202 | </member> |
203 | 203 | <member> |
204 | 204 | <name>faultString</name> |
205 | -<value><string>' . chr(224) . chr(252) . chr(232) . 'àüè</string></value> |
|
205 | +<value><string>' . chr(224).chr(252).chr(232).'àüè</string></value> |
|
206 | 206 | </member> |
207 | 207 | </struct> |
208 | 208 | </value> |
@@ -211,7 +211,7 @@ discard block |
||
211 | 211 | $m = $this->newRequest('dummy'); |
212 | 212 | $r = $m->parseResponse($response); |
213 | 213 | $v = $r->faultString(); |
214 | - $this->assertEquals(chr(224) . chr(252) . chr(232) . chr(224) . chr(252) . chr(232), $v); |
|
214 | + $this->assertEquals(chr(224).chr(252).chr(232).chr(224).chr(252).chr(232), $v); |
|
215 | 215 | } |
216 | 216 | |
217 | 217 | public function testBrokenRequests() |
@@ -468,8 +468,8 @@ discard block |
||
468 | 468 | $i = \PhpXmlRpc\PhpXmlRpc::$xmlrpc_reject_invalid_values; |
469 | 469 | \PhpXmlRpc\PhpXmlRpc::$xmlrpc_reject_invalid_values = true; |
470 | 470 | |
471 | - foreach($values as $value) { |
|
472 | - $f = '<?xml version="1.0"?><methodResponse><params><param><value>' . $value . '</value></param></params></methodResponse> '; |
|
471 | + foreach ($values as $value) { |
|
472 | + $f = '<?xml version="1.0"?><methodResponse><params><param><value>'.$value.'</value></param></params></methodResponse> '; |
|
473 | 473 | $r = $s->parseResponse($f); |
474 | 474 | $v = $r->faultCode(); |
475 | 475 | $this->assertEquals(2, $v, "Testing $value"); |
@@ -574,11 +574,11 @@ discard block |
||
574 | 574 | |
575 | 575 | public function testUTF8Response() |
576 | 576 | { |
577 | - $string = chr(224) . chr(252) . chr(232); |
|
577 | + $string = chr(224).chr(252).chr(232); |
|
578 | 578 | |
579 | 579 | $s = $this->newRequest('dummy'); |
580 | - $f = "HTTP/1.1 200 OK\r\nContent-type: text/xml; charset=UTF-8\r\n\r\n" . '<?xml version="1.0"?><methodResponse><params><param><value><struct><member><name>userid</name><value>311127</value></member> |
|
581 | -<member><name>dateCreated</name><value><dateTime.iso8601>20011126T09:17:52</dateTime.iso8601></value></member><member><name>content</name><value>' . @utf8_encode($string) . '</value></member><member><name>postid</name><value>7414222</value></member></struct></value></param></params></methodResponse> |
|
580 | + $f = "HTTP/1.1 200 OK\r\nContent-type: text/xml; charset=UTF-8\r\n\r\n".'<?xml version="1.0"?><methodResponse><params><param><value><struct><member><name>userid</name><value>311127</value></member> |
|
581 | +<member><name>dateCreated</name><value><dateTime.iso8601>20011126T09:17:52</dateTime.iso8601></value></member><member><name>content</name><value>' . @utf8_encode($string).'</value></member><member><name>postid</name><value>7414222</value></member></struct></value></param></params></methodResponse> |
|
582 | 582 | '; |
583 | 583 | $r = $s->parseResponse($f, false, 'phpvals'); |
584 | 584 | $v = $r->value(); |
@@ -586,7 +586,7 @@ discard block |
||
586 | 586 | $this->assertEquals($string, $v); |
587 | 587 | |
588 | 588 | $f = '<?xml version="1.0" encoding="UTF-8"?><methodResponse><params><param><value><struct><member><name>userid</name><value>311127</value></member> |
589 | -<member><name>dateCreated</name><value><dateTime.iso8601>20011126T09:17:52</dateTime.iso8601></value></member><member><name>content</name><value>' . @utf8_encode($string) . '</value></member><member><name>postid</name><value>7414222</value></member></struct></value></param></params></methodResponse> |
|
589 | +<member><name>dateCreated</name><value><dateTime.iso8601>20011126T09:17:52</dateTime.iso8601></value></member><member><name>content</name><value>' . @utf8_encode($string).'</value></member><member><name>postid</name><value>7414222</value></member></struct></value></param></params></methodResponse> |
|
590 | 590 | '; |
591 | 591 | $r = $s->parseResponse($f, false, 'phpvals'); |
592 | 592 | $v = $r->value(); |
@@ -602,11 +602,11 @@ discard block |
||
602 | 602 | |
603 | 603 | public function testLatin1Response() |
604 | 604 | { |
605 | - $string = chr(224) . chr(252) . chr(232); |
|
605 | + $string = chr(224).chr(252).chr(232); |
|
606 | 606 | |
607 | 607 | $s = $this->newRequest('dummy'); |
608 | - $f = "HTTP/1.1 200 OK\r\nContent-type: text/xml; charset=ISO-8859-1\r\n\r\n" . '<?xml version="1.0"?><methodResponse><params><param><value><struct><member><name>userid</name><value>311127</value></member> |
|
609 | -<member><name>dateCreated</name><value><dateTime.iso8601>20011126T09:17:52</dateTime.iso8601></value></member><member><name>content</name><value>' . $string . '</value></member><member><name>postid</name><value>7414222</value></member></struct></value></param></params></methodResponse> |
|
608 | + $f = "HTTP/1.1 200 OK\r\nContent-type: text/xml; charset=ISO-8859-1\r\n\r\n".'<?xml version="1.0"?><methodResponse><params><param><value><struct><member><name>userid</name><value>311127</value></member> |
|
609 | +<member><name>dateCreated</name><value><dateTime.iso8601>20011126T09:17:52</dateTime.iso8601></value></member><member><name>content</name><value>' . $string.'</value></member><member><name>postid</name><value>7414222</value></member></struct></value></param></params></methodResponse> |
|
610 | 610 | '; |
611 | 611 | $r = $s->parseResponse($f, false, 'phpvals'); |
612 | 612 | $v = $r->value(); |
@@ -614,7 +614,7 @@ discard block |
||
614 | 614 | $this->assertEquals($string, $v); |
615 | 615 | |
616 | 616 | $f = '<?xml version="1.0" encoding="ISO-8859-1"?><methodResponse><params><param><value><struct><member><name>userid</name><value>311127</value></member> |
617 | -<member><name>dateCreated</name><value><dateTime.iso8601>20011126T09:17:52</dateTime.iso8601></value></member><member><name>content</name><value>' . $string . '</value></member><member><name>postid</name><value>7414222</value></member></struct></value></param></params></methodResponse> |
|
617 | +<member><name>dateCreated</name><value><dateTime.iso8601>20011126T09:17:52</dateTime.iso8601></value></member><member><name>content</name><value>' . $string.'</value></member><member><name>postid</name><value>7414222</value></member></struct></value></param></params></methodResponse> |
|
618 | 618 | '; |
619 | 619 | $r = $s->parseResponse($f, false, 'phpvals'); |
620 | 620 | $v = $r->value(); |
@@ -1,6 +1,6 @@ discard block |
||
1 | 1 | <?php |
2 | 2 | |
3 | -include_once __DIR__ . '/ServerAwareTestCase.php'; |
|
3 | +include_once __DIR__.'/ServerAwareTestCase.php'; |
|
4 | 4 | |
5 | 5 | /** |
6 | 6 | * @todo Long-term, this should replace all testing of the legacy API done via the main test-suite... |
@@ -14,7 +14,7 @@ discard block |
||
14 | 14 | { |
15 | 15 | /// @todo pass on as cli args for the executed script all the args that are already parsed by now, plus $this->testId |
16 | 16 | |
17 | - exec('php ' . __DIR__ . '/legacy_loader_test.php', $out, $result); |
|
17 | + exec('php '.__DIR__.'/legacy_loader_test.php', $out, $result); |
|
18 | 18 | |
19 | 19 | /// @todo dump output if in debug mode or if test fails |
20 | 20 |
@@ -1,6 +1,6 @@ discard block |
||
1 | 1 | <?php |
2 | 2 | |
3 | -include_once __DIR__ . '/LoggerAwareTestCase.php'; |
|
3 | +include_once __DIR__.'/LoggerAwareTestCase.php'; |
|
4 | 4 | |
5 | 5 | use PHPUnit\Extensions\SeleniumCommon\RemoteCoverage; |
6 | 6 | use PHPUnit\Framework\TestResult; |
@@ -30,7 +30,7 @@ discard block |
||
30 | 30 | */ |
31 | 31 | public function _run($result = NULL) |
32 | 32 | { |
33 | - $this->testId = get_class($this) . '__' . $this->getName(); |
|
33 | + $this->testId = get_class($this).'__'.$this->getName(); |
|
34 | 34 | |
35 | 35 | if ($result === NULL) { |
36 | 36 | $result = $this->createResult(); |
@@ -62,13 +62,13 @@ discard block |
||
62 | 62 | |
63 | 63 | // Set up a database connection or other fixture which needs to be available. |
64 | 64 | self::$randId = uniqid(); |
65 | - file_put_contents(sys_get_temp_dir() . '/phpunit_rand_id.txt', self::$randId); |
|
65 | + file_put_contents(sys_get_temp_dir().'/phpunit_rand_id.txt', self::$randId); |
|
66 | 66 | } |
67 | 67 | |
68 | 68 | public static function tear_down_after_class() |
69 | 69 | { |
70 | - if (is_file(sys_get_temp_dir() . '/phpunit_rand_id.txt')) { |
|
71 | - unlink(sys_get_temp_dir() . '/phpunit_rand_id.txt'); |
|
70 | + if (is_file(sys_get_temp_dir().'/phpunit_rand_id.txt')) { |
|
71 | + unlink(sys_get_temp_dir().'/phpunit_rand_id.txt'); |
|
72 | 72 | } |
73 | 73 | |
74 | 74 | parent::tear_down_after_class(); |
@@ -79,15 +79,15 @@ discard block |
||
79 | 79 | parent::set_up(); |
80 | 80 | |
81 | 81 | // assumes HTTPURI to be in the form /tests/index.php?etc... |
82 | - $this->baseUrl = 'http://' . $this->args['HTTPSERVER'] . preg_replace('|\?.+|', '', $this->args['HTTPURI']); |
|
83 | - $this->coverageScriptUrl = 'http://' . $this->args['HTTPSERVER'] . preg_replace('|/tests/index\.php(\?.*)?|', '/tests/phpunit_coverage.php', $this->args['HTTPURI']); |
|
82 | + $this->baseUrl = 'http://'.$this->args['HTTPSERVER'].preg_replace('|\?.+|', '', $this->args['HTTPURI']); |
|
83 | + $this->coverageScriptUrl = 'http://'.$this->args['HTTPSERVER'].preg_replace('|/tests/index\.php(\?.*)?|', '/tests/phpunit_coverage.php', $this->args['HTTPURI']); |
|
84 | 84 | } |
85 | 85 | |
86 | 86 | protected function getClient() |
87 | 87 | { |
88 | 88 | $server = explode(':', $this->args['HTTPSERVER']); |
89 | 89 | /// @todo use the non-legacy API calling convention, except in a dedicated test |
90 | - if (count($server) > 1) { |
|
90 | + if (count($server)>1) { |
|
91 | 91 | $client = new xmlrpc_client($this->args['HTTPURI'], $server[0], $server[1]); |
92 | 92 | } else { |
93 | 93 | $client = new xmlrpc_client($this->args['HTTPURI'], $this->args['HTTPSERVER']); |
@@ -1,6 +1,6 @@ discard block |
||
1 | 1 | <?php |
2 | 2 | |
3 | -include_once __DIR__ . '/08ServerTest.php'; |
|
3 | +include_once __DIR__.'/08ServerTest.php'; |
|
4 | 4 | |
5 | 5 | /** |
6 | 6 | * Tests which stress http features of the library. |
@@ -34,7 +34,7 @@ discard block |
||
34 | 34 | { |
35 | 35 | $methods = array(); |
36 | 36 | // as long as we are descendants, get_class_methods will list private/protected methods |
37 | - foreach(get_class_methods('ServerTest') as $method) |
|
37 | + foreach (get_class_methods('ServerTest') as $method) |
|
38 | 38 | { |
39 | 39 | if (strpos($method, 'test') === 0 && !in_array($method, $this->unsafeMethods)) |
40 | 40 | { |
@@ -148,7 +148,7 @@ discard block |
||
148 | 148 | // this checks for a non-failed call |
149 | 149 | $time = microtime(true); |
150 | 150 | $this->send($m); |
151 | - $time = microtime(true) - $time; |
|
151 | + $time = microtime(true)-$time; |
|
152 | 152 | $this->assertGreaterThan(1.0, $time); |
153 | 153 | $this->assertLessThan(2.0, $time); |
154 | 154 | |
@@ -156,7 +156,7 @@ discard block |
||
156 | 156 | $m = new xmlrpcmsg('tests.sleep', array(new xmlrpcval(5, 'int'))); |
157 | 157 | $time = microtime(true); |
158 | 158 | $r = $this->send($m, array(0, PhpXmlRpc\PhpXmlRpc::$xmlrpcerr['http_error'], PhpXmlRpc\PhpXmlRpc::$xmlrpcerr['curl_fail'])); |
159 | - $time = microtime(true) - $time; |
|
159 | + $time = microtime(true)-$time; |
|
160 | 160 | $this->assertGreaterThan(2.0, $time); |
161 | 161 | $this->assertLessThan(4.0, $time); |
162 | 162 | |
@@ -176,7 +176,7 @@ discard block |
||
176 | 176 | $this->addQueryParams(array('SLOW_LORIS' => 1)); |
177 | 177 | $time = microtime(true); |
178 | 178 | $this->send($m, array(0, PhpXmlRpc\PhpXmlRpc::$xmlrpcerr['http_error'], PhpXmlRpc\PhpXmlRpc::$xmlrpcerr['curl_fail'])); |
179 | - $time = microtime(true) - $time; |
|
179 | + $time = microtime(true)-$time; |
|
180 | 180 | $this->assertGreaterThan(2.0, $time); |
181 | 181 | $this->assertLessThan(4.0, $time); |
182 | 182 | } |
@@ -355,7 +355,7 @@ discard block |
||
355 | 355 | preg_match('/ubunutu([0-9]+)/', $output[0], $matches); |
356 | 356 | $ubuntuVersion = @$matches[1]; |
357 | 357 | } |
358 | - if ($ubuntuVersion >= 20 && $this->args['SSLVERSION'] != 6) { |
|
358 | + if ($ubuntuVersion>=20 && $this->args['SSLVERSION'] != 6) { |
|
359 | 359 | $this->markTestSkipped('HTTPS via Socket known to fail on php less than 7.2 on Ubuntu 20 and higher'); |
360 | 360 | } |
361 | 361 | } |
@@ -380,7 +380,7 @@ discard block |
||
380 | 380 | $this->client->setOption(\PhpXmlRpc\Client::OPT_EXTRA_SOCKET_OPTS, |
381 | 381 | array('ssl' => array( |
382 | 382 | // security level is available as of php 7.2.0 + openssl 1.1.0 according to the docs |
383 | - 'security_level' => min(1 + $version[1], 5), |
|
383 | + 'security_level' => min(1+$version[1], 5), |
|
384 | 384 | // capture_session_meta was deprecated in php 7.0 |
385 | 385 | //'capture_session_meta' => true, |
386 | 386 | )) |
@@ -528,7 +528,7 @@ discard block |
||
528 | 528 | if (version_compare(PHP_VERSION, '8.0', '>=') && $this->args['SSLVERSION'] == 0) |
529 | 529 | { |
530 | 530 | $version = explode('.', PHP_VERSION); |
531 | - $this->client->setSSLVersion(min(4 + $version[1], 7)); |
|
531 | + $this->client->setSSLVersion(min(4+$version[1], 7)); |
|
532 | 532 | } |
533 | 533 | |
534 | 534 | $this->$method(); |
@@ -304,8 +304,7 @@ discard block |
||
304 | 304 | if (!function_exists('curl_init')) |
305 | 305 | { |
306 | 306 | $this->markTestSkipped('CURL missing: cannot test https functionality'); |
307 | - } |
|
308 | - else if ($this->args['HTTPSSERVER'] == '') |
|
307 | + } else if ($this->args['HTTPSSERVER'] == '') |
|
309 | 308 | { |
310 | 309 | $this->markTestSkipped('HTTPS SERVER definition missing: cannot test https'); |
311 | 310 | } |
@@ -480,8 +479,7 @@ discard block |
||
480 | 479 | if (!function_exists('curl_init')) |
481 | 480 | { |
482 | 481 | $this->markTestSkipped('CURL missing: cannot test http 1.1 w. proxy'); |
483 | - } |
|
484 | - else if ($this->args['PROXYSERVER'] == '') |
|
482 | + } else if ($this->args['PROXYSERVER'] == '') |
|
485 | 483 | { |
486 | 484 | $this->markTestSkipped('PROXYSERVER definition missing: cannot test proxy w. http 1.1'); |
487 | 485 | } |
@@ -505,12 +503,10 @@ discard block |
||
505 | 503 | if (!function_exists('curl_init')) |
506 | 504 | { |
507 | 505 | $this->markTestSkipped('CURL missing: cannot test https w. proxy'); |
508 | - } |
|
509 | - else if ($this->args['PROXYSERVER'] == '') |
|
506 | + } else if ($this->args['PROXYSERVER'] == '') |
|
510 | 507 | { |
511 | 508 | $this->markTestSkipped('PROXYSERVER definition missing: cannot test proxy w. https'); |
512 | - } |
|
513 | - else if ($this->args['HTTPSSERVER'] == '') |
|
509 | + } else if ($this->args['HTTPSSERVER'] == '') |
|
514 | 510 | { |
515 | 511 | $this->markTestSkipped('HTTPS SERVER definition missing: cannot test https w. proxy'); |
516 | 512 | } |
@@ -54,7 +54,7 @@ discard block |
||
54 | 54 | */ |
55 | 55 | public function echoInput() |
56 | 56 | { |
57 | - $r = new PhpXmlRpc\Response(new PhpXmlRpc\Value("'Aha said I: '" . file_get_contents('php://input'), 'string')); |
|
57 | + $r = new PhpXmlRpc\Response(new PhpXmlRpc\Value("'Aha said I: '".file_get_contents('php://input'), 'string')); |
|
58 | 58 | print $r->serialize(); |
59 | 59 | } |
60 | 60 | |
@@ -65,7 +65,7 @@ discard block |
||
65 | 65 | */ |
66 | 66 | public function &__get($name) |
67 | 67 | { |
68 | - switch($name) { |
|
68 | + switch ($name) { |
|
69 | 69 | case 'dmap': |
70 | 70 | return $this->dmap; |
71 | 71 | default: |
@@ -96,30 +96,30 @@ discard block |
||
96 | 96 | Server::xmlrpc_debugmsg($m); |
97 | 97 | } |
98 | 98 | |
99 | -function _xmlrpcs_getCapabilities($server, $m=null) |
|
99 | +function _xmlrpcs_getCapabilities($server, $m = null) |
|
100 | 100 | { |
101 | 101 | return Server::_xmlrpcs_getCapabilities($server, $m); |
102 | 102 | } |
103 | 103 | |
104 | -$_xmlrpcs_listMethods_sig=array(array(\PhpXmlRpc\Value::$xmlrpcArray)); |
|
105 | -$_xmlrpcs_listMethods_doc='This method lists all the methods that the XML-RPC server knows how to dispatch'; |
|
106 | -$_xmlrpcs_listMethods_sdoc=array(array('list of method names')); |
|
107 | -function _xmlrpcs_listMethods($server, $m=null) // if called in plain php values mode, second param is missing |
|
104 | +$_xmlrpcs_listMethods_sig = array(array(\PhpXmlRpc\Value::$xmlrpcArray)); |
|
105 | +$_xmlrpcs_listMethods_doc = 'This method lists all the methods that the XML-RPC server knows how to dispatch'; |
|
106 | +$_xmlrpcs_listMethods_sdoc = array(array('list of method names')); |
|
107 | +function _xmlrpcs_listMethods($server, $m = null) // if called in plain php values mode, second param is missing |
|
108 | 108 | { |
109 | 109 | return Server::_xmlrpcs_listMethods($server, $m); |
110 | 110 | } |
111 | 111 | |
112 | -$_xmlrpcs_methodSignature_sig=array(array(\PhpXmlRpc\Value::$xmlrpcArray, \PhpXmlRpc\Value::$xmlrpcString)); |
|
113 | -$_xmlrpcs_methodSignature_doc='Returns an array of known signatures (an array of arrays) for the method name passed. If no signatures are known, returns a none-array (test for type != array to detect missing signature)'; |
|
114 | -$_xmlrpcs_methodSignature_sdoc=array(array('list of known signatures, each sig being an array of xmlrpc type names', 'name of method to be described')); |
|
112 | +$_xmlrpcs_methodSignature_sig = array(array(\PhpXmlRpc\Value::$xmlrpcArray, \PhpXmlRpc\Value::$xmlrpcString)); |
|
113 | +$_xmlrpcs_methodSignature_doc = 'Returns an array of known signatures (an array of arrays) for the method name passed. If no signatures are known, returns a none-array (test for type != array to detect missing signature)'; |
|
114 | +$_xmlrpcs_methodSignature_sdoc = array(array('list of known signatures, each sig being an array of xmlrpc type names', 'name of method to be described')); |
|
115 | 115 | function _xmlrpcs_methodSignature($server, $m) |
116 | 116 | { |
117 | 117 | return Server::_xmlrpcs_methodSignature($server, $m); |
118 | 118 | } |
119 | 119 | |
120 | -$_xmlrpcs_methodHelp_sig=array(array(\PhpXmlRpc\Value::$xmlrpcString, \PhpXmlRpc\Value::$xmlrpcString)); |
|
121 | -$_xmlrpcs_methodHelp_doc='Returns help text if defined for the method passed, otherwise returns an empty string'; |
|
122 | -$_xmlrpcs_methodHelp_sdoc=array(array('method description', 'name of the method to be described')); |
|
120 | +$_xmlrpcs_methodHelp_sig = array(array(\PhpXmlRpc\Value::$xmlrpcString, \PhpXmlRpc\Value::$xmlrpcString)); |
|
121 | +$_xmlrpcs_methodHelp_doc = 'Returns help text if defined for the method passed, otherwise returns an empty string'; |
|
122 | +$_xmlrpcs_methodHelp_sdoc = array(array('method description', 'name of the method to be described')); |
|
123 | 123 | function _xmlrpcs_methodHelp($server, $m) |
124 | 124 | { |
125 | 125 | return Server::_xmlrpcs_methodHelp($server, $m); |
@@ -1,5 +1,5 @@ discard block |
||
1 | 1 | <?php |
2 | -require_once __DIR__ . "/_prepend.php"; |
|
2 | +require_once __DIR__."/_prepend.php"; |
|
3 | 3 | |
4 | 4 | /** |
5 | 5 | * Demoing the code-generation capabilities of the library: create a client class which exposes a bunch of methods |
@@ -26,12 +26,12 @@ discard block |
||
26 | 26 | ); |
27 | 27 | |
28 | 28 | // the generated code does not have an autoloader included - we need to add in one |
29 | -$autoloader = __DIR__ . "/_prepend.php"; |
|
29 | +$autoloader = __DIR__."/_prepend.php"; |
|
30 | 30 | |
31 | -$targetFile = sys_get_temp_dir() . '/MyClient.php'; |
|
31 | +$targetFile = sys_get_temp_dir().'/MyClient.php'; |
|
32 | 32 | $generated = file_put_contents($targetFile, |
33 | - "<?php\n\n" . |
|
34 | - "require_once '$autoloader';\n\n" . |
|
33 | + "<?php\n\n". |
|
34 | + "require_once '$autoloader';\n\n". |
|
35 | 35 | $code['code'] |
36 | 36 | ); |
37 | 37 | |
@@ -51,8 +51,8 @@ discard block |
||
51 | 51 | $client = new MyClient(); |
52 | 52 | $sorted = $client->examples_sortByAge(array( |
53 | 53 | array('name' => 'Dave', 'age' => 24), |
54 | - array('name' => 'Edd', 'age' => 45), |
|
55 | - array('name' => 'Joe', 'age' => 37), |
|
54 | + array('name' => 'Edd', 'age' => 45), |
|
55 | + array('name' => 'Joe', 'age' => 37), |
|
56 | 56 | array('name' => 'Fred', 'age' => 27), |
57 | 57 | )); |
58 | 58 |
@@ -1,5 +1,5 @@ discard block |
||
1 | 1 | <?php |
2 | -require_once __DIR__ . "/_prepend.php"; |
|
2 | +require_once __DIR__."/_prepend.php"; |
|
3 | 3 | |
4 | 4 | /** |
5 | 5 | * Demoing the code-generation capabilities of the library: create all that is required to expose as xml-rpc methods |
@@ -13,7 +13,7 @@ discard block |
||
13 | 13 | use PhpXmlRpc\Wrapper; |
14 | 14 | |
15 | 15 | // CommentManager is the "xml-rpc-unaware" class, whose methods we want to make accessible via xml-rpc calls |
16 | -$cm = new CommentManager(sys_get_temp_dir() . "/comments.db"); |
|
16 | +$cm = new CommentManager(sys_get_temp_dir()."/comments.db"); |
|
17 | 17 | |
18 | 18 | // analyze the CommentManager instance and generate both code defining stub-methods and a dispatch map for the xml-rpc Server |
19 | 19 | $w = new Wrapper(); |
@@ -31,40 +31,40 @@ discard block |
||
31 | 31 | // and a controller, to be accessed from the internet. This split allows to a) hand-edit the controller code if needed, |
32 | 32 | // and b) later regenerate the stub-methods-holder and dispatch map without touching the controller. |
33 | 33 | // NB: good security practices dictate that none of those files should be writeable by the webserver user account |
34 | -$targetClassFile = sys_get_temp_dir() . '/MyServerClass.php'; |
|
35 | -$targetDispatchMapFile = sys_get_temp_dir() . '/myServerDispatchMap.php'; |
|
36 | -$targetControllerFile = sys_get_temp_dir() . '/myServerController.php'; |
|
34 | +$targetClassFile = sys_get_temp_dir().'/MyServerClass.php'; |
|
35 | +$targetDispatchMapFile = sys_get_temp_dir().'/myServerDispatchMap.php'; |
|
36 | +$targetControllerFile = sys_get_temp_dir().'/myServerController.php'; |
|
37 | 37 | |
38 | 38 | // generate a file with a class definition |
39 | 39 | |
40 | 40 | // the generated code does not have an autoloader included - we need to add in one |
41 | -$autoloader = __DIR__ . "/_prepend.php"; |
|
41 | +$autoloader = __DIR__."/_prepend.php"; |
|
42 | 42 | |
43 | 43 | file_put_contents($targetClassFile, |
44 | - "<?php\n\n" . |
|
45 | - "require_once '$autoloader';\n\n" . |
|
44 | + "<?php\n\n". |
|
45 | + "require_once '$autoloader';\n\n". |
|
46 | 46 | "class MyServerClass\n{\n\n" |
47 | 47 | ) || die('uh oh'); |
48 | 48 | |
49 | 49 | // we mangle a bit the code we get from wrapPhpClass to turn it into a php class definition instead of a bunch of functions |
50 | 50 | |
51 | -foreach($code as $methodName => $methodDef) { |
|
52 | - file_put_contents($targetClassFile, ' ' . str_replace(array('function ', "\n"), array('public static function ', "\n "), $methodDef['source']) . "\n\n", FILE_APPEND) || die('uh oh'); |
|
53 | - $code[$methodName]['function'] = 'MyServerClass::' . $methodDef['function']; |
|
51 | +foreach ($code as $methodName => $methodDef) { |
|
52 | + file_put_contents($targetClassFile, ' '.str_replace(array('function ', "\n"), array('public static function ', "\n "), $methodDef['source'])."\n\n", FILE_APPEND) || die('uh oh'); |
|
53 | + $code[$methodName]['function'] = 'MyServerClass::'.$methodDef['function']; |
|
54 | 54 | unset($code[$methodName]['source']); |
55 | 55 | } |
56 | 56 | file_put_contents($targetClassFile, "}\n", FILE_APPEND) || die('uh oh'); |
57 | 57 | |
58 | 58 | // generate separate files with the xml-rpc server instantiation and its dispatch map |
59 | 59 | |
60 | -file_put_contents($targetDispatchMapFile, "<?php\n\nreturn " . var_export($code, true) . ";\n"); |
|
60 | +file_put_contents($targetDispatchMapFile, "<?php\n\nreturn ".var_export($code, true).";\n"); |
|
61 | 61 | |
62 | 62 | file_put_contents($targetControllerFile, |
63 | - "<?php\n\n" . |
|
63 | + "<?php\n\n". |
|
64 | 64 | |
65 | - "require_once '$autoloader';\n\n" . |
|
65 | + "require_once '$autoloader';\n\n". |
|
66 | 66 | |
67 | - "require_once '$targetClassFile';\n\n" . |
|
67 | + "require_once '$targetClassFile';\n\n". |
|
68 | 68 | |
69 | 69 | // NB: since we are running the generated code within the same script, the existing CommentManager instance will be |
70 | 70 | // available for usage by the methods of MyServerClass, as we keep a reference to them within the variable Wrapper::$objHolder |
@@ -74,12 +74,12 @@ discard block |
||
74 | 74 | // Wrapper::holdObject('xmlrpc_CommentManager_addComment', $cm); |
75 | 75 | // Wrapper::holdObject('xmlrpc_CommentManager_getComments', $cm); |
76 | 76 | |
77 | - "\$dm = require_once '$targetDispatchMapFile';\n" . |
|
78 | - '$s = new \PhpXmlRpc\Server($dm, false);' . "\n\n" . |
|
79 | - '// NB: do not leave these 2 debug lines enabled on publicly accessible servers!' . "\n" . |
|
80 | - '$s->setOption(\PhpXmlRpc\Server::OPT_DEBUG, 2);' . "\n" . |
|
81 | - '$s->setOption(\PhpXmlRpc\Server::OPT_EXCEPTION_HANDLING, 1);' . "\n\n" . |
|
82 | - '$s->service();' . "\n" |
|
77 | + "\$dm = require_once '$targetDispatchMapFile';\n". |
|
78 | + '$s = new \PhpXmlRpc\Server($dm, false);'."\n\n". |
|
79 | + '// NB: do not leave these 2 debug lines enabled on publicly accessible servers!'."\n". |
|
80 | + '$s->setOption(\PhpXmlRpc\Server::OPT_DEBUG, 2);'."\n". |
|
81 | + '$s->setOption(\PhpXmlRpc\Server::OPT_EXCEPTION_HANDLING, 1);'."\n\n". |
|
82 | + '$s->service();'."\n" |
|
83 | 83 | ) || die('uh oh'); |
84 | 84 | |
85 | 85 | // test that everything worked by running it in realtime (note that this script will return an xml-rpc error message if |
@@ -8,23 +8,23 @@ |
||
8 | 8 | * `$functions_parameters_type` and `$exception_handling` |
9 | 9 | */ |
10 | 10 | |
11 | -require_once __DIR__ . "/_prepend.php"; |
|
11 | +require_once __DIR__."/_prepend.php"; |
|
12 | 12 | |
13 | 13 | require_once __DIR__.'/methodProviders/CommentManager.php'; |
14 | 14 | |
15 | 15 | use PhpXmlRpc\Server; |
16 | 16 | use PhpXmlRpc\Value; |
17 | 17 | |
18 | -$manager = new CommentManager(sys_get_temp_dir() . "/comments.db"); |
|
18 | +$manager = new CommentManager(sys_get_temp_dir()."/comments.db"); |
|
19 | 19 | |
20 | 20 | $addComment_sig = array(array(Value::$xmlrpcInt, Value::$xmlrpcString, Value::$xmlrpcString, Value::$xmlrpcString)); |
21 | 21 | |
22 | -$addComment_doc = 'Adds a comment to an item. The first parameter is the item ID, the second the name of the commenter, ' . |
|
22 | +$addComment_doc = 'Adds a comment to an item. The first parameter is the item ID, the second the name of the commenter, '. |
|
23 | 23 | 'and the third is the comment itself. Returns the number of comments against that ID.'; |
24 | 24 | |
25 | 25 | $getComments_sig = array(array(Value::$xmlrpcArray, Value::$xmlrpcString)); |
26 | 26 | |
27 | -$getComments_doc = 'Returns an array of comments for a given ID, which is the sole argument. Each array item is a struct ' . |
|
27 | +$getComments_doc = 'Returns an array of comments for a given ID, which is the sole argument. Each array item is a struct '. |
|
28 | 28 | 'containing name and comment text.'; |
29 | 29 | |
30 | 30 | $srv = new Server(); |
@@ -98,7 +98,7 @@ discard block |
||
98 | 98 | $this->me['struct'] = $val; |
99 | 99 | break; |
100 | 100 | default: |
101 | - $this->getLogger()->error("XML-RPC: " . __METHOD__ . ": not a known type ($type)"); |
|
101 | + $this->getLogger()->error("XML-RPC: ".__METHOD__.": not a known type ($type)"); |
|
102 | 102 | } |
103 | 103 | } |
104 | 104 | } |
@@ -128,7 +128,7 @@ discard block |
||
128 | 128 | } |
129 | 129 | |
130 | 130 | if ($typeOf !== 1) { |
131 | - $this->getLogger()->error("XML-RPC: " . __METHOD__ . ": not a scalar type ($type)"); |
|
131 | + $this->getLogger()->error("XML-RPC: ".__METHOD__.": not a scalar type ($type)"); |
|
132 | 132 | return 0; |
133 | 133 | } |
134 | 134 | |
@@ -145,10 +145,10 @@ discard block |
||
145 | 145 | |
146 | 146 | switch ($this->mytype) { |
147 | 147 | case 1: |
148 | - $this->getLogger()->error('XML-RPC: ' . __METHOD__ . ': scalar xmlrpc value can have only one value'); |
|
148 | + $this->getLogger()->error('XML-RPC: '.__METHOD__.': scalar xmlrpc value can have only one value'); |
|
149 | 149 | return 0; |
150 | 150 | case 3: |
151 | - $this->getLogger()->error('XML-RPC: ' . __METHOD__ . ': cannot add anonymous scalar to struct xmlrpc value'); |
|
151 | + $this->getLogger()->error('XML-RPC: '.__METHOD__.': cannot add anonymous scalar to struct xmlrpc value'); |
|
152 | 152 | return 0; |
153 | 153 | case 2: |
154 | 154 | // we're adding a scalar value to an array here |
@@ -192,7 +192,7 @@ discard block |
||
192 | 192 | |
193 | 193 | return 1; |
194 | 194 | } else { |
195 | - $this->getLogger()->error('XML-RPC: ' . __METHOD__ . ': already initialized as a [' . $this->kindOf() . ']'); |
|
195 | + $this->getLogger()->error('XML-RPC: '.__METHOD__.': already initialized as a ['.$this->kindOf().']'); |
|
196 | 196 | return 0; |
197 | 197 | } |
198 | 198 | } |
@@ -223,7 +223,7 @@ discard block |
||
223 | 223 | |
224 | 224 | return 1; |
225 | 225 | } else { |
226 | - $this->getLogger()->error('XML-RPC: ' . __METHOD__ . ': already initialized as a [' . $this->kindOf() . ']'); |
|
226 | + $this->getLogger()->error('XML-RPC: '.__METHOD__.': already initialized as a ['.$this->kindOf().']'); |
|
227 | 227 | return 0; |
228 | 228 | } |
229 | 229 | } |
@@ -288,7 +288,7 @@ discard block |
||
288 | 288 | $val = reset($this->me); |
289 | 289 | $typ = key($this->me); |
290 | 290 | |
291 | - return '<value>' . $this->serializeData($typ, $val, $charsetEncoding) . "</value>\n"; |
|
291 | + return '<value>'.$this->serializeData($typ, $val, $charsetEncoding)."</value>\n"; |
|
292 | 292 | } |
293 | 293 | |
294 | 294 | /** |
@@ -303,7 +303,7 @@ discard block |
||
303 | 303 | { |
304 | 304 | $this->logDeprecationUnlessCalledBy('serialize'); |
305 | 305 | |
306 | - if (!isset(static::$xmlrpcTypes[(string)$typ])) { |
|
306 | + if (!isset(static::$xmlrpcTypes[(string) $typ])) { |
|
307 | 307 | return ''; |
308 | 308 | } |
309 | 309 | |
@@ -311,19 +311,19 @@ discard block |
||
311 | 311 | case 1: |
312 | 312 | switch ($typ) { |
313 | 313 | case static::$xmlrpcBase64: |
314 | - $rs = "<{$typ}>" . base64_encode($val) . "</{$typ}>"; |
|
314 | + $rs = "<{$typ}>".base64_encode($val)."</{$typ}>"; |
|
315 | 315 | break; |
316 | 316 | case static::$xmlrpcBoolean: |
317 | - $rs = "<{$typ}>" . ($val ? '1' : '0') . "</{$typ}>"; |
|
317 | + $rs = "<{$typ}>".($val ? '1' : '0')."</{$typ}>"; |
|
318 | 318 | break; |
319 | 319 | case static::$xmlrpcString: |
320 | 320 | // Do NOT use htmlentities, since it will produce named html entities, which are invalid xml |
321 | - $rs = "<{$typ}>" . $this->getCharsetEncoder()->encodeEntities($val, PhpXmlRpc::$xmlrpc_internalencoding, $charsetEncoding) . "</{$typ}>"; |
|
321 | + $rs = "<{$typ}>".$this->getCharsetEncoder()->encodeEntities($val, PhpXmlRpc::$xmlrpc_internalencoding, $charsetEncoding)."</{$typ}>"; |
|
322 | 322 | break; |
323 | 323 | case static::$xmlrpcInt: |
324 | 324 | case static::$xmlrpcI4: |
325 | 325 | case static::$xmlrpcI8: |
326 | - $rs = "<{$typ}>" . (int)$val . "</{$typ}>"; |
|
326 | + $rs = "<{$typ}>".(int) $val."</{$typ}>"; |
|
327 | 327 | break; |
328 | 328 | case static::$xmlrpcDouble: |
329 | 329 | // avoid using standard conversion of float to string because it is locale-dependent, |
@@ -331,16 +331,16 @@ discard block |
||
331 | 331 | // sprintf('%F') could be most likely ok, but it fails e.g. on 2e-14. |
332 | 332 | // The code below tries its best at keeping max precision while avoiding exp notation, |
333 | 333 | // but there is of course no limit in the number of decimal places to be used... |
334 | - $rs = "<{$typ}>" . preg_replace('/\\.?0+$/', '', number_format((float)$val, PhpXmlRpc::$xmlpc_double_precision, '.', '')) . "</{$typ}>"; |
|
334 | + $rs = "<{$typ}>".preg_replace('/\\.?0+$/', '', number_format((float) $val, PhpXmlRpc::$xmlpc_double_precision, '.', ''))."</{$typ}>"; |
|
335 | 335 | break; |
336 | 336 | case static::$xmlrpcDateTime: |
337 | 337 | if (is_string($val)) { |
338 | 338 | $rs = "<{$typ}>{$val}</{$typ}>"; |
339 | 339 | // DateTimeInterface is not present in php 5.4... |
340 | 340 | } elseif (is_a($val, 'DateTimeInterface') || is_a($val, 'DateTime')) { |
341 | - $rs = "<{$typ}>" . $val->format('Ymd\TH:i:s') . "</{$typ}>"; |
|
341 | + $rs = "<{$typ}>".$val->format('Ymd\TH:i:s')."</{$typ}>"; |
|
342 | 342 | } elseif (is_int($val)) { |
343 | - $rs = "<{$typ}>" . date('Ymd\TH:i:s', $val) . "</{$typ}>"; |
|
343 | + $rs = "<{$typ}>".date('Ymd\TH:i:s', $val)."</{$typ}>"; |
|
344 | 344 | } else { |
345 | 345 | // not really a good idea here: but what should we output anyway? left for backward compat... |
346 | 346 | $rs = "<{$typ}>{$val}</{$typ}>"; |
@@ -362,14 +362,14 @@ discard block |
||
362 | 362 | case 3: |
363 | 363 | // struct |
364 | 364 | if ($this->_php_class) { |
365 | - $rs = '<struct php_class="' . $this->_php_class . "\">\n"; |
|
365 | + $rs = '<struct php_class="'.$this->_php_class."\">\n"; |
|
366 | 366 | } else { |
367 | 367 | $rs = "<struct>\n"; |
368 | 368 | } |
369 | 369 | $charsetEncoder = $this->getCharsetEncoder(); |
370 | 370 | /** @var Value $val2 */ |
371 | 371 | foreach ($val as $key2 => $val2) { |
372 | - $rs .= '<member><name>' . $charsetEncoder->encodeEntities($key2, PhpXmlRpc::$xmlrpc_internalencoding, $charsetEncoding) . "</name>\n"; |
|
372 | + $rs .= '<member><name>'.$charsetEncoder->encodeEntities($key2, PhpXmlRpc::$xmlrpc_internalencoding, $charsetEncoding)."</name>\n"; |
|
373 | 373 | $rs .= $val2->serialize($charsetEncoding); |
374 | 374 | $rs .= "</member>\n"; |
375 | 375 | } |
@@ -581,7 +581,7 @@ discard block |
||
581 | 581 | */ |
582 | 582 | public function structMemExists($key) |
583 | 583 | { |
584 | - $this->logDeprecation('Method ' . __METHOD__ . ' is deprecated'); |
|
584 | + $this->logDeprecation('Method '.__METHOD__.' is deprecated'); |
|
585 | 585 | |
586 | 586 | return array_key_exists($key, $this->me['struct']); |
587 | 587 | } |
@@ -597,7 +597,7 @@ discard block |
||
597 | 597 | */ |
598 | 598 | public function structMem($key) |
599 | 599 | { |
600 | - $this->logDeprecation('Method ' . __METHOD__ . ' is deprecated'); |
|
600 | + $this->logDeprecation('Method '.__METHOD__.' is deprecated'); |
|
601 | 601 | |
602 | 602 | return $this->me['struct'][$key]; |
603 | 603 | } |
@@ -610,7 +610,7 @@ discard block |
||
610 | 610 | */ |
611 | 611 | public function structReset() |
612 | 612 | { |
613 | - $this->logDeprecation('Method ' . __METHOD__ . ' is deprecated'); |
|
613 | + $this->logDeprecation('Method '.__METHOD__.' is deprecated'); |
|
614 | 614 | |
615 | 615 | reset($this->me['struct']); |
616 | 616 | } |
@@ -624,7 +624,7 @@ discard block |
||
624 | 624 | */ |
625 | 625 | public function structEach() |
626 | 626 | { |
627 | - $this->logDeprecation('Method ' . __METHOD__ . ' is deprecated'); |
|
627 | + $this->logDeprecation('Method '.__METHOD__.' is deprecated'); |
|
628 | 628 | |
629 | 629 | $key = key($this->me['struct']); |
630 | 630 | $value = current($this->me['struct']); |
@@ -643,7 +643,7 @@ discard block |
||
643 | 643 | */ |
644 | 644 | public function arrayMem($key) |
645 | 645 | { |
646 | - $this->logDeprecation('Method ' . __METHOD__ . ' is deprecated'); |
|
646 | + $this->logDeprecation('Method '.__METHOD__.' is deprecated'); |
|
647 | 647 | |
648 | 648 | return $this->me['array'][$key]; |
649 | 649 | } |
@@ -657,7 +657,7 @@ discard block |
||
657 | 657 | */ |
658 | 658 | public function arraySize() |
659 | 659 | { |
660 | - $this->logDeprecation('Method ' . __METHOD__ . ' is deprecated'); |
|
660 | + $this->logDeprecation('Method '.__METHOD__.' is deprecated'); |
|
661 | 661 | |
662 | 662 | return count($this->me['array']); |
663 | 663 | } |
@@ -671,7 +671,7 @@ discard block |
||
671 | 671 | */ |
672 | 672 | public function structSize() |
673 | 673 | { |
674 | - $this->logDeprecation('Method ' . __METHOD__ . ' is deprecated'); |
|
674 | + $this->logDeprecation('Method '.__METHOD__.' is deprecated'); |
|
675 | 675 | |
676 | 676 | return count($this->me['struct']); |
677 | 677 | } |
@@ -683,12 +683,12 @@ discard block |
||
683 | 683 | case 'me': |
684 | 684 | case 'mytype': |
685 | 685 | case '_php_class': |
686 | - $this->logDeprecation('Getting property Value::' . $name . ' is deprecated'); |
|
686 | + $this->logDeprecation('Getting property Value::'.$name.' is deprecated'); |
|
687 | 687 | return $this->$name; |
688 | 688 | default: |
689 | 689 | /// @todo throw instead? There are very few other places where the lib trigger errors which can potentially reach stdout... |
690 | 690 | $trace = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS, 1); |
691 | - trigger_error('Undefined property via __get(): ' . $name . ' in ' . $trace[0]['file'] . ' on line ' . $trace[0]['line'], E_USER_WARNING); |
|
691 | + trigger_error('Undefined property via __get(): '.$name.' in '.$trace[0]['file'].' on line '.$trace[0]['line'], E_USER_WARNING); |
|
692 | 692 | $result = null; |
693 | 693 | return $result; |
694 | 694 | } |
@@ -700,13 +700,13 @@ discard block |
||
700 | 700 | case 'me': |
701 | 701 | case 'mytype': |
702 | 702 | case '_php_class': |
703 | - $this->logDeprecation('Setting property Value::' . $name . ' is deprecated'); |
|
703 | + $this->logDeprecation('Setting property Value::'.$name.' is deprecated'); |
|
704 | 704 | $this->$name = $value; |
705 | 705 | break; |
706 | 706 | default: |
707 | 707 | /// @todo throw instead? There are very few other places where the lib trigger errors which can potentially reach stdout... |
708 | 708 | $trace = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS, 1); |
709 | - trigger_error('Undefined property via __set(): ' . $name . ' in ' . $trace[0]['file'] . ' on line ' . $trace[0]['line'], E_USER_WARNING); |
|
709 | + trigger_error('Undefined property via __set(): '.$name.' in '.$trace[0]['file'].' on line '.$trace[0]['line'], E_USER_WARNING); |
|
710 | 710 | } |
711 | 711 | } |
712 | 712 | |
@@ -716,7 +716,7 @@ discard block |
||
716 | 716 | case 'me': |
717 | 717 | case 'mytype': |
718 | 718 | case '_php_class': |
719 | - $this->logDeprecation('Checking property Value::' . $name . ' is deprecated'); |
|
719 | + $this->logDeprecation('Checking property Value::'.$name.' is deprecated'); |
|
720 | 720 | return isset($this->$name); |
721 | 721 | default: |
722 | 722 | return false; |
@@ -729,13 +729,13 @@ discard block |
||
729 | 729 | case 'me': |
730 | 730 | case 'mytype': |
731 | 731 | case '_php_class': |
732 | - $this->logDeprecation('Unsetting property Value::' . $name . ' is deprecated'); |
|
732 | + $this->logDeprecation('Unsetting property Value::'.$name.' is deprecated'); |
|
733 | 733 | unset($this->$name); |
734 | 734 | break; |
735 | 735 | default: |
736 | 736 | /// @todo throw instead? There are very few other places where the lib trigger errors which can potentially reach stdout... |
737 | 737 | $trace = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS, 1); |
738 | - trigger_error('Undefined property via __unset(): ' . $name . ' in ' . $trace[0]['file'] . ' on line ' . $trace[0]['line'], E_USER_WARNING); |
|
738 | + trigger_error('Undefined property via __unset(): '.$name.' in '.$trace[0]['file'].' on line '.$trace[0]['line'], E_USER_WARNING); |
|
739 | 739 | } |
740 | 740 | } |
741 | 741 | } |