On Sat, 2004-05-01 at 22:09, Marcus Boerger wrote:
> Hello internals,
>
> while working with php 5 the last days i find it more and more
> annoying that we allow NULL with type hints.
> From my perspective allowing NULL with typehints would happen
> only very rare.
I don't think this is true. I think there are a number of cases where
passing NULL is used to "unset" or "delete" something. For example, say
a class supports debugging using a listener model:
class Foo {
function setEventListener(Listener $l) { ... }
}
$foo= new Foo();
$foo->setEventListener(new ConsoleListener());
// ...
$foo->setEventListener(NULL);
This makes perfect sense to me and also gets rid of the constraint of
having to define an "unsetEventListener" method.
To wrap it up: Would you agree that being able to pass NULL to any
pointer argument in C is annoying?
[...]
> 2) (Andi) introduce 'not null' after php 5.0. This won't introduce
> a BC break. But it would require two new keywords 'NOT' and 'NULL'.
> The latter is not a problem because it is a define at the moment
> and the patch (a) shows that it easy to change it into a keyword.
> The problem is the new keyword 'not' which would introduce a BC
> break for everyone using the word 'not' already.
I like this idea best: No magic such as "only when it is the first
default argument" (the question "why" will inevitably come up sooner or
later); plus no BC break.
Concerning the new keyword argument, how about using the exclamation
mark (already meaning "not"), as in:
* function foo(Classname !NULL $val) { }
The same as Andi's suggestion, but using ! instead of "not"
* function foo(Classname $val !NULL) { }
Ditto, but using postfix notation. Comes close to default value
syntax which people are already used to.
* function foo(Classname $val != NULL) { }
This would be even more similar to the default value syntax.
- Timm
--
PHP Internals - PHP Runtime Development Mailing List
To unsubscribe, visit: http://www.php.net/unsub.php