Edit report at http://bugs.php.net/bug.php?id=53081&edit=1
ID: 53081
Comment by: giorgio dot liscio at email dot it
Reported by: giorgio dot liscio at email dot it
Summary: why you should bring back abstract static methods
Status: Bogus
Type: Feature/Change Request
Package: Class/Object related
PHP Version: 5.3.3
Block user comment: N
New Comment:
...
Previous Comments:
------------------------------------------------------------------------
[2010-10-20 16:47:42] giorgio dot liscio at email dot it
i know... could someone analyze my request please? i know that a lot of
bug reports are bogus, but not all
------------------------------------------------------------------------
[2010-10-17 13:59:48] cmanley at xs4all dot nl
Georgio,
Your example makes perfect sense. I just wish the bug handlers wouldn't
be so rude
as to flag valid reports as bogus when users spend effort to report
these bugs
with examples.
There's nothing bad about having abstract static methods in a language
that
finally supports static inheritance (since PHP 5.3). This is normal
practice in
other languages too so E_STRICT shouldn't be emitted.
------------------------------------------------------------------------
[2010-10-17 02:56:08] giorgio dot liscio at email dot it
simplified case
abstract class AFSItem
{
public static function getIfValid ($fullPath)
{
// i use static::isValid to get the method defined in the
called class
if(static::isValid($fullPath)) return new static($fullPath);
}
protected function __construct ($fp){}
// i want to force real classes to implement a way to check a path
before instance an object
protected abstract static function isValid ($fullPath); //
abstract declaration
}
class File extends AFSItem
{
protected static function isValid ($fullPath) //
implementation
{
return is_file($fullPath);
}
}
class Dir extends AFSItem
{
protected static function isValid ($fullPath) //
implementation
{
return is_dir($fullPath);
}
}
class Image extends File
{
protected static function isValid ($fullPath) //
implementation with override
{
if(parent::isValid($fullPath) AND
(bool)getimagesize($fullPath)) return true; return false;
}
}
------------------------------------------------------------------------
[2010-10-17 02:03:36] cmanley at xs4all dot nl
This bug (emitting E_STRICT for abstract static methods in PHP 5.3 while
static
inheritance has finally been implemented) leads to another bug that I
recently
submitted: http://bugs.php.net/bug.php?id=53086
These are definately different bugs, but this bug spawns the other one
which is
more catestrophic.
If you don't see the bug, then add E_STRICT to your error reporting:
error_reporting(E_ALL | E_STRICT);
------------------------------------------------------------------------
[2010-10-16 20:23:31] giorgio dot liscio at email dot it
Strict Standards: Static function cA::B() should not be abstract in
..\www\index.php on line 6
5.3.3
------------------------------------------------------------------------
The remainder of the comments for this report are too long. To view
the rest of the comments, please view the bug report online at
http://bugs.php.net/bug.php?id=53081
--
Edit this bug report at http://bugs.php.net/bug.php?id=53081&edit=1