I agree with the notion of typing in function arguments, though I'm not a
fan of this particular approach.  Specifically, I don't like the idea of
"1aaa" throwing one kind of error (E_NOTICE) and array($whatever) throwing
another kind of error.  They should both throw the same error because
they're both incompatible types; i.e. "1" == 1 but "1aaa" != 1.  I don't
like the idea of saying that one incompatible type is "worse" than
another.  I just don't see any value in that and it ultimately just makes
things more confusing and complicated than they need to be for the end-user.

Instead, they should both throw the same kind of error.  Whether it's just
E_RECOVERABLE_ERROR or we give the developer a choice by having
strong/weak, I'm fine either way (though I think the second approach adds
more flexibility without any practical drawbacks).


And again, let's avoid using phrases like "most people".  I'll let
Wikipedia elaborate on why:

http://en.wikipedia.org/wiki/Weasel_word

--Kris


On Wed, Feb 29, 2012 at 2:26 AM, Simon Schick
<simonsimc...@googlemail.com>wrote:

> Hi, Arvids
>
> I did not meant to putt all in one big RFC but more to think about the
> connection between these two while developing.
>
> Bye
> Simon
>
> 2012/2/29 Arvids Godjuks <arvids.godj...@gmail.com>
>
> > Combining different things into one big RFC is not a good idea. It's
> > hard to develop and test the work it it's in one big chunk.
> > Decomposition makes it much easier. Type hinting has to have it's own
> > RFC.
> > Besides - someone can be willing to do type hinting patch and don't
> > want to do the object_cast_magic one.
> >
> > And thanks for the support :)
> >
> > 2012/2/29 Simon Schick <simonsimc...@googlemail.com>:
> > > Hi,
> > >
> > > We could even combine this with the following RFC:
> > > https://wiki.php.net/rfc/object_cast_magic
> > >
> > > If an integer is required and you pass an object, it first checks if
> this
> > > object is castable to integer ;)
> > >
> > > Bye
> > > Simon
> > >
> > > 2012/2/29 Simon Schick <simonsimc...@googlemail.com>
> > >
> > >> Hi, John
> > >>
> > >> I personally do not care about weak or strong variables at all ... I
> > only
> > >> want what Arvids suggested last time:
> > >>
> > >>
> > >> > test(1, 2); // 2;
> > >> > test("1", 2); // 2
> > >> > test("1aaa", 2); // E_NOTICE or E_TYPE and result 2
> > >> > test(array(2), 2); // E_RECOVERABLE_ERROR - just like with array
> type
> > >> hint now.
> > >> >
> > >> > It's really what the most people want. Simple, easy to pick up
> (object
> > >> > and array already have this) and is just optional.
> > >>
> > >> I count myself as a part of *most people* in this statement ;)
> > >> I'm also quite fine with the current type-hints as you'd anyways get
> an
> > >> error if you try something like this:
> > >>
> > >> function foo(SimpleClass $a) {
> > >>   $a->getName();
> > >> }
> > >>
> > >> foo("Test");
> > >>
> > >> If you now get *method called from an non-object* or a message that
> you
> > >> have passed a value that's not compatible with *SimpleClass* ...
> > >>
> > >> I'd like to split this discussion in parts:
> > >>
> > >>    - just type-hint in functions (as we have it with classes and
> arrays)
> > >>    or bind a variable to a strict type?
> > >>       - should it then also be possible bind variables to a specific
> > >>       class or interface?
> > >>    - should we go for weak or strong types?
> > >>       - the type-hint is also weak in one way because it accepts all
> > >>       that's compatible with the given type.
> > >>
> > >> Bye
> > >> Simon
> > >>
> > >>
> > >> 2012/2/29 John Crenshaw <johncrens...@priacta.com>
> > >>
> > >>> I would personally be inclined towards something simpler like
> E_NOTICE
> > or
> > >>> E_WARNING, but current type hints all raise E_RECOVERABLE_ERROR. I
> > think we
> > >>> should be consistent, and the consistency argument may make the
> > difference.
> > >>>
> > >>> There may be a strong case for changing the error level on all type
> > hints
> > >>> to something simpler (or new, like E_TYPE), but I think that might be
> > >>> better to tackle that in a separate discussion.
> > >>>
> > >>> John Crenshaw
> > >>> Priacta, Inc.
> > >>>
> > >>> From: Kris Craig [mailto:kris.cr...@gmail.com]
> > >>> Sent: Tuesday, February 28, 2012 8:40 PM
> > >>> To: John Crenshaw
> > >>> Cc: Rick WIdmer; internals@lists.php.net
> > >>> Subject: Re: [PHP-DEV] Scalar type hinting
> > >>>
> > >>> I wouldn't mind that, though I'm concerned that it may not be
> sellable
> > >>> because some people on here have expressed a strong opinion that this
> > >>> shouldn't throw anything more than a notice or a warning at most,
> > something
> > >>> that I and others strongly disagree with.  The logical approach, to
> me
> > at
> > >>> least, is to follow the example of include() and require(); i.e.
> > they're
> > >>> both identical except that one throws a scary error while the other
> > one is
> > >>> just a warning.
> > >>>
> > >>> I'm fine with just throwing E_RECOVERABLE_ERROR, though I fear that
> may
> > >>> alienate too many people for us to be able to get this through.
>  Though
> > >>> it's possible I might be overestimating that factor.
> > >>>
> > >>> --Kris
> > >>>
> > >>> On Tue, Feb 28, 2012 at 5:17 PM, John Crenshaw <
> > johncrens...@priacta.com
> > >>> <mailto:johncrens...@priacta.com>> wrote:
> > >>> > On Tue, Feb 28, 2012 at 3:03 PM, Rick WIdmer <
> > vch...@developersdesk.com
> > >>> <mailto:vch...@developersdesk.com>>wrote:
> > >>> >
> > >>> > > On 2/28/2012 2:58 PM, Kris Craig wrote:
> > >>> > >
> > >>> > >  strong int $a = "1"; // Converts to 1.  May or may not throw an
> > error
> > >>> > > (I'm
> > >>> > >> still on the fence).
> > >>> > >>
> > >>> > >
> > >>> > > It this is an error, it is no longer PHP.
> > >>> > >
> > >>> >
> > >>> > @Rick Though I'm not sure I'd agree with the overly broad "it is no
> > >>> longer PHP" hyperbole, I think the basic point that it would be a
> > >>> significant departure from the current model has merit.  So ok,
> you've
> > >>> convinced me.
> > >>> That example should not throw any errors.  I'm officially no longer
> on
> > >>> the fence with that.  =)
> > >>> >
> > >>> > --Kris
> > >>> OK, if we're all on the same page there, I think this means that
> there
> > is
> > >>> no significant difference between the "strong int" and "weak int" in
> > your
> > >>> proposal (the only remaining difference being the level of error
> raised
> > >>> when it cannot be converted, which IMO is not substantial enough to
> > deserve
> > >>> a keyword.) I'd prefer to just pick one error level to use
> > >>> (E_RECOVERABLE_ERROR would be the most consistent) and keep
> everything
> > >>> simple.
> > >>>
> > >>> John Crenshaw
> > >>> Priacta, Inc.
> > >>>
> > >>>
> > >>
> >
>

Reply via email to