Newsgroups: php.internals Path: news.php.net Xref: news.php.net php.internals:94636 Return-Path: Mailing-List: contact internals-help@lists.php.net; run by ezmlm Delivered-To: mailing list internals@lists.php.net Received: (qmail 18176 invoked from network); 22 Jul 2016 15:54:35 -0000 Received: from unknown (HELO lists.php.net) (127.0.0.1) by localhost with SMTP; 22 Jul 2016 15:54:35 -0000 Authentication-Results: pb1.pair.com header.from=larry@garfieldtech.com; sender-id=unknown Authentication-Results: pb1.pair.com smtp.mail=larry@garfieldtech.com; spf=permerror; sender-id=unknown Received-SPF: error (pb1.pair.com: domain garfieldtech.com from 66.111.4.29 cause and error) X-PHP-List-Original-Sender: larry@garfieldtech.com X-Host-Fingerprint: 66.111.4.29 out5-smtp.messagingengine.com Received: from [66.111.4.29] ([66.111.4.29:33054] helo=out5-smtp.messagingengine.com) by pb1.pair.com (ecelerity 2.1.1.9-wez r(12769M)) with ESMTP id E6/B5-24343-AB142975 for ; Fri, 22 Jul 2016 11:54:35 -0400 Received: from compute3.internal (compute3.nyi.internal [10.202.2.43]) by mailout.nyi.internal (Postfix) with ESMTP id 19563203D9 for ; Fri, 22 Jul 2016 11:54:32 -0400 (EDT) Received: from web3 ([10.202.2.213]) by compute3.internal (MEProxy); Fri, 22 Jul 2016 11:54:32 -0400 DKIM-Signature: v=1; a=rsa-sha1; c=relaxed/relaxed; d= messagingengine.com; h=content-transfer-encoding:content-type :date:from:in-reply-to:message-id:mime-version:references :subject:to:x-sasl-enc:x-sasl-enc; s=smtpout; bh=ANDxoYR5eYtiyWV sJP3aHotuWoY=; b=GutUrTETPy4bYlylMdAAPBnewjgU/GYb5QkTDO+gPAZp6io futIC/bPDWVUiFqooetlzS3ujbPZWj6RwGdk/EikNtunt0P2Tv5QUeAckPnbElBN oArp8YoXkh6DNO7106zG84Ewzu6DTmr1hDtQxHFmgmcMYOG9RYuzuOFGLhYI= Received: by mailuser.nyi.internal (Postfix, from userid 99) id E2D5C166FF; Fri, 22 Jul 2016 11:54:31 -0400 (EDT) Message-ID: <1469202871.3732759.673953873.7108115D@webmail.messagingengine.com> X-Sasl-Enc: goTDspew0X+Hh8eR9hgGQEpw5tMb37bug66kKYkOq69u 1469202871 To: internals@lists.php.net MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Content-Type: text/plain X-Mailer: MessagingEngine.com Webmail Interface - ajax-2ccfea0a In-Reply-To: References: <5786dd74-8a32-eb16-aec1-77b12d5af1c1@garfieldtech.com> Date: Fri, 22 Jul 2016 10:54:31 -0500 Subject: Re: [PHP-DEV] Pipe Operator v2 From: larry@garfieldtech.com (Larry Garfield) On Wed, Jul 20, 2016, at 11:37 PM, Sara Golemon wrote: > > However, the introduction discusses fluent chained methods of objects, and > > states " This RFC aims to improve code readability by bringing fluent > > expressions to functional and OOP libraries not originally designed for the > > task." The examples, however, all seem to be centered around procedural > > calls. (A static method call is the same thing as a procedural function > > call in this respect.) When dealing with methods on an object, it seems it > > wouldn't offer much. > > > In this context, I'd argue instance method calls aren't much different > from static method calls either, but I wanted to avoid too many > abstract/contrived examples. > > I suppose one might do something like: > > return $this->loadConfig() > |> $arg->useConfig($$) > |> $this->loadUser($$) > |> array_merge($$, $this->userDefaults); > > But the PSR7 example is already contrived as it is. > > > This other recent discussion/proposal for a "Cascade" operator seems like it > > would handle the OOP/method case much better: > > > > http://news.php.net/php.internals/94466 > > > > Note: I am not suggesting one is a substitute for the other; rather, that > > they are complementary by addressing different parts of the problem space, > > and the Pipe RFC should likely not emphasize OOP usage potential as I see > > not a great deal there. I am still in favor of it, but let's not over-state > > its use cases. > > > Fair enough. They certainly complement one another and I wouldn't > argue either is a one-job-fits-all solution. I wasn't trying to > emphasize OOP usage so much as include it as applicable. I think we > might actually be agreeing in principle even if we're diverging in our > word choices. :) I agree. I'm entirely on board with the feature; more just critiquing the RFC intro text, which mentions OOP fluency as a use case, which I think is an over-reach. It's a useful enough feature even without talking about that, and it seems we agree that the syntax when used with methods is a bit awkward. > P.S. - I'm totes going to make that a secondary voting choice now. > Name the token, 50% majority wins. :-) --Larry Garfield