Newsgroups: php.internals Path: news.php.net Xref: news.php.net php.internals:52404 Return-Path: Mailing-List: contact internals-help@lists.php.net; run by ezmlm Delivered-To: mailing list internals@lists.php.net Received: (qmail 37200 invoked from network); 16 May 2011 19:18:19 -0000 Received: from unknown (HELO lists.php.net) (127.0.0.1) by localhost with SMTP; 16 May 2011 19:18:19 -0000 Authentication-Results: pb1.pair.com header.from=andrewcurioso@gmail.com; sender-id=pass; domainkeys=bad Authentication-Results: pb1.pair.com smtp.mail=andrewcurioso@gmail.com; spf=pass; sender-id=pass Received-SPF: pass (pb1.pair.com: domain gmail.com designates 209.85.212.42 as permitted sender) DomainKey-Status: bad X-DomainKeys: Ecelerity dk_validate implementing draft-delany-domainkeys-base-01 X-PHP-List-Original-Sender: andrewcurioso@gmail.com X-Host-Fingerprint: 209.85.212.42 mail-vw0-f42.google.com Received: from [209.85.212.42] ([209.85.212.42:49453] helo=mail-vw0-f42.google.com) by pb1.pair.com (ecelerity 2.1.1.9-wez r(12769M)) with ESMTP id 62/C0-26716-97871DD4 for ; Mon, 16 May 2011 15:18:18 -0400 Received: by vwl1 with SMTP id 1so4128616vwl.29 for ; Mon, 16 May 2011 12:18:15 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=gamma; h=domainkey-signature:mime-version:in-reply-to:references:date :message-id:subject:from:to:cc:content-type; bh=997lomK7LayFRqDerVmfOea3g+slbmfsXPA17eJ4Vzc=; b=CqDXNDECsYtqpMq9aLm/8kxxuTTLZ0vItye+ZREBzJy6AHJLOFa0ZVeqWD7G5uBA7L KoNSYhd+UCpaGOMjTm/4nfURqyW23p0SV5gTivZ7LNCJr/2oMdO86qxd5V6TSMaLSxCE ZMC+WeFfDcdqJMx4pzmpzZi0SqdzjZxPGrqhc= DomainKey-Signature: a=rsa-sha1; c=nofws; d=gmail.com; s=gamma; h=mime-version:in-reply-to:references:date:message-id:subject:from:to :cc:content-type; b=tMbhnMQMIeRxoUwTT9Kz/AaFdDLfuFRxCm72e4kOu7PkJzS2i+lPCYhOcsps06/QdX yOtuFHKAjczdsGYfN+CL0SMnklusea7g/FBsCc+1CiAw+vFzfGbyBKllXqCPrDG4/Gpk +k6THV8zwCJHlpWeJLlX8z0tEidi93AVKfbRM= MIME-Version: 1.0 Received: by 10.52.171.69 with SMTP id as5mr6501022vdc.138.1305573494910; Mon, 16 May 2011 12:18:14 -0700 (PDT) Received: by 10.52.101.167 with HTTP; Mon, 16 May 2011 12:18:14 -0700 (PDT) In-Reply-To: References: <1305570720.1344.535.camel@guybrush> Date: Mon, 16 May 2011 15:18:14 -0400 Message-ID: To: Anthony Ferrara Cc: =?ISO-8859-1?Q?Johannes_Schl=FCter?= , smalyshev@sugarcrm.com, internals@lists.php.net Content-Type: multipart/alternative; boundary=bcaec53d5d8764712c04a3698467 Subject: Re: [PHP-DEV] Inconsistencies with constructors in SPL From: andrewcurioso@gmail.com (Andrew Curioso) --bcaec53d5d8764712c04a3698467 Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: quoted-printable To play devil's advocate a bit: It's a special case. If it was really an undefined method then this is suddenly ambiguous: $foo =3D new Foo(); If __construct() is undefined, what is being called in that case? By the same logic, that should throw an error as well. On the other hand, if __construct is presumed to be implicitly defined then I think it makes logical sense for parent::__construct() to always succeed. Side note: If __construct is implicit then __destruct should also be. On Mon, May 16, 2011 at 3:10 PM, Anthony Ferrara wrote= : > Personally, I really don't care for something like this. Would it be > caught by a __call declaration if one existed (since it is a call to > an undefined method)? Would you expect it to? > > I'd rather see calls to non-existent methods generate a catachable > fatal error (rather than a hard fatal error that's currently thrown). > That way we can use an error exception to "catch" the fatal and > recover from it if necessary. > > But silently ignoring a called function, something just doesn't sit > right about that... > > > > On Mon, May 16, 2011 at 2:44 PM, Andrew Curioso > wrote: > > I like that idea and I like that it works for userland classes as well. > > > > +1 > > > > Do you think it should throw a warning, notice, or -- as you both > suggested > > -- just silently succeed? > > > > > > > > > > 2011/5/16 Johannes Schl=FCter > > > >> Hi, > >> > >> I|d actuallz suggest a different option: > >> > >> If a parent constructor is called but doesn't exist the engine should > >> ignore this. The same goes for destructors. > >> > >> This solution would also work for userland classes. > >> > >> johannes > >> > >> On Mon, 2011-05-16 at 14:14 -0400, Andrew Curioso wrote: > >> > So, I ran across bug #54631 > >> > > >> > A fatal error is thrown if you try to call parent::__construct() fro= m > a > >> > subclass > >> > of SplObjectStorage. > >> > > >> > I was going to close it as "expected behavior" since that is pretty > >> normal > >> > if the parent class doesn't implement __construct(). > >> > Also, the docs don't list it as having a __construct() method. > >> > > >> > But then look at SplDoublyLinkedList (and a bunch of others). They a= re > >> > documented > >> > as having a __construct() method, yet it triggers a fatal error when > you > >> try > >> > to call > >> > "parent::__construct()" from a subclass' constructor . > >> > > >> > So it seems to me that there are two possible solutions: > >> > > >> > - Update the docs to remove ::__construct() for classes that don't > have > >> one. > >> > - Make sure __construct() is implemented in all SPL classes * and > update > >> the > >> > docs. > >> > > >> > * Even if it is empty. > >> > > >> > What's everyone thinking? > >> > > >> > I'd be more than happy to add the constructors to the code where > needed, > >> I > >> > just > >> > want to make sure that it is the right move first. > >> > > >> > > >> > - Andrew > >> > >> > >> > >> -- > >> PHP Internals - PHP Runtime Development Mailing List > >> To unsubscribe, visit: http://www.php.net/unsub.php > >> > >> > > > --=20 Andrew Curioso --bcaec53d5d8764712c04a3698467--