>People generally prefer compile-time >control which is derived from definition rather than per-instance >runtime control (implementing interface vs. checking each time if class >has certain methods).
It's me again, sorry. So, if I understand you well, Stanislas, you are personally not much into "static::" but more into making that sort of code working : interface iC { public $structure; } abstract class A implements iC { public function display() { echo self::$structure; } } class B extends A { static public $structure = "This is a string."; } $b = new B(); $b->display(); If so, what's the problem? Is there a technical difficulty of implementation behind? Or is it because we are unsure whether all the people asking for "LSB" would be satisfied with that way? BTW, here's a funny sort of polymorphism with static members that already runs great with the actual PHP release: interface iC { function getStructure(); } abstract class A implements iC { public function display() { echo $this->getStructure(); } } abstract class B extends A { static public $structure = "This is a string from B."; } class C extends B { static public $structure = "This is a string from C."; public function getStructure() { return self::$structure; } } $c = new C(); $c->display(); Remove the definition of $structure in C, and the one in B will apply. I suppose Michael Lively's example would be solved (the one with the TableSelectQueries), if it could work the same way in a fully static context (and without the help of an additional method like getStructure) ... Right ? Baptiste -- PHP Internals - PHP Runtime Development Mailing List To unsubscribe, visit: http://www.php.net/unsub.php