@ 2013-08-07T14:38:08Z <?php
trait setData {
static function setData( $data ) {
DataCollector::collectedData( 'set', $data );
}
}
trait dataHandler {
use setData;
private static function getCollectedData() {
return DataCollector::collectedData( 'get' );
}
private static function collectedData( $type, $value = NULL ) {
if( strtolower( $type ) === 'set' ) {
DataCollector::$CollectionData[] = $value;
var_dump( DataCollector::$CollectionData );
}
elseif( strtolower( $type ) === 'get' )
return DataCollector::$CollectionData;
}
}
class DataCollector {
use dataHandler { getCollectedData as public; }
private static $CollectionData = array();
}
class Form { use setData {} }
class Field extends Form {
public function __construct( $type, $text = NULL ) {
$this->setData( $type );
}
}
class A {
use setData{}
public function __construct( $type, $text = NULL ) {
$this->setData( $type );
}
}
$Field1 = new Field( '1' );
$Field2 = new Field( '2' );
$A = new A( '3' );
DataCollector::setData('4');
dataHandler::setData('5');
var_dump( $A::getCollectedData(), DataCollector::getCollectedData() );
Enable javascript to submit You have javascript disabled. You will not be able to edit any code.
Output for 8.0.0 - 8.0.30 , 8.1.0 - 8.1.28 , 8.2.0 - 8.2.18 , 8.3.0 - 8.3.6 Fatal error: Uncaught Error: Call to private method DataCollector::collectedData() from scope Form in /in/gE81M:4
Stack trace:
#0 /in/gE81M(34): Form::setData('1')
#1 /in/gE81M(46): Field->__construct('1')
#2 {main}
thrown in /in/gE81M on line 4
Process exited with code 255 . Output for 7.0.0 - 7.0.20 , 7.1.0 - 7.1.20 , 7.2.0 - 7.2.33 , 7.3.12 - 7.3.33 , 7.4.0 - 7.4.33 Fatal error: Uncaught Error: Call to private method DataCollector::collectedData() from context 'Form' in /in/gE81M:4
Stack trace:
#0 /in/gE81M(34): Form::setData('1')
#1 /in/gE81M(46): Field->__construct('1')
#2 {main}
thrown in /in/gE81M on line 4
Process exited with code 255 . Output for 5.4.0 - 5.4.45 , 5.5.0 - 5.5.38 , 5.6.0 - 5.6.28 Fatal error: Call to private method DataCollector::collectedData() from context 'Form' in /in/gE81M on line 4
Process exited with code 255 . Output for 4.4.2 - 4.4.9 , 5.1.0 - 5.1.6 , 5.2.0 - 5.2.17 , 5.3.0 - 5.3.29 Parse error: syntax error, unexpected T_STRING in /in/gE81M on line 2
Process exited with code 255 . Output for 4.3.0 - 4.3.1 , 4.3.5 - 4.3.11 , 4.4.0 - 4.4.1 , 5.0.0 - 5.0.5 Parse error: parse error, unexpected T_STRING in /in/gE81M on line 2
Process exited with code 255 . Output for 4.3.2 - 4.3.4 Parse error: parse error in /in/gE81M on line 2
Process exited with code 255 . preferences:dark mode live preview
243.82 ms | 401 KiB | 358 Q