> I believe the cleanest solution that we could implement would be using
> the type casting with "Type" objects.
I experimented with this for a couple of months, a couple of weeks ago. In
opinion, it does not work well. I am guessing developers at java also figured
the same since they still also have primitive types. Aside from the mentioned
performance cost, it results in ugly and clumsy code. Not to mention you need
to cast the objects into primitive types if you wish to use the variables
with PHP functions.
function random(Integer $max, Integer $min)
{
$n = rand($min->getInteger(), $max->getInteger());
return $n;
}
Implementing the __toString() method in the classes helps a little but not
much.
And really, if you think about it, just adding support to scalar type hinting
solves the hold issue, thus making this sort of solution pointless and a pit
hole wasted energy and time.
> Is there any reason we can't at least add "scalar" and
> "resource" (and possibly "object" for generic objects) to typehints?
This sounds like, at least, a partial victory to adding proper type hinting to
PHP but in my mind it is not enough. I have counted that about a quarter of
all type hints that I would make is about matching the argument's type to
scalar. The rest are about separating specific scalars from each other. In
most cases integer and boolean.
I would probably end up not using type hinting at all, just to save the users
of my API from the confusion and just do the type checks myself inside my
methods.
> Thinking about this, simply because we all know PHP __CAN__ type
> juggle, there is no need for any errors/warnings/notices on scalar
> types. It will be up to the API developer to make sure appropriate
> values are supplied (if necessary), so this reduces the type checking.
In other words, it is not "in the spirit of PHP" to enable strict type
hinting. I can understand this argument, but I still disagree heavily with
this approach.
1) It is not consistent with the way that Array and Object type hinting works.
While you might make the argument that it is not an issue because you cannot
implicitly cast those types, it does create an annoying (yet another) magic
behavior thing in PHP that people need to learn and remember. If anything, it
will confuse new users, which I believe a lot of people were concerned about.
Essentially, if it is necessary (and most of the time it is) to validate the
value beyond just the type, you might as well do the casting at the same time
as you validate.
2) The reason people are asking for type hinting for scalars is specifically
to move some of the responsibility from the API developer to the user of the
API and it is not an unreasonable request. After all, if person A has a
program that asks for user input, the best place for validation is not in the
class that person B wrote. The values should be validated in the program that
asked for the input. Since the validation is necessary, person A can easily
cast the type of the input at the end of the process, before he passes it to
the class.
E.g.
function validate($input)
{
// validate the input
// return false if it was not valid
// otherwise return a properly cast value
}
$input = $_GET['var1'];
$input = validate($input)
if(! empty($input)) {
doSomething($input);
}
This seems like a perfectly logical division of labor. The validator validates
and casts and the library class acts on the proper input.
Tomi Kaistila
PHP Developer
--
PHP Internals - PHP Runtime Development Mailing List
To unsubscribe, visit: http://www.php.net/unsub.php