Newsgroups: php.internals Path: news.php.net Xref: news.php.net php.internals:91417 Return-Path: Mailing-List: contact internals-help@lists.php.net; run by ezmlm Delivered-To: mailing list internals@lists.php.net Received: (qmail 4726 invoked from network); 25 Feb 2016 18:31:18 -0000 Received: from unknown (HELO lists.php.net) (127.0.0.1) by localhost with SMTP; 25 Feb 2016 18:31:18 -0000 Authentication-Results: pb1.pair.com smtp.mail=derokorian@gmail.com; spf=pass; sender-id=pass Authentication-Results: pb1.pair.com header.from=derokorian@gmail.com; sender-id=pass Received-SPF: pass (pb1.pair.com: domain gmail.com designates 74.125.82.44 as permitted sender) X-PHP-List-Original-Sender: derokorian@gmail.com X-Host-Fingerprint: 74.125.82.44 mail-wm0-f44.google.com Received: from [74.125.82.44] ([74.125.82.44:34435] helo=mail-wm0-f44.google.com) by pb1.pair.com (ecelerity 2.1.1.9-wez r(12769M)) with ESMTP id 69/B4-11730-5784FC65 for ; Thu, 25 Feb 2016 13:31:17 -0500 Received: by mail-wm0-f44.google.com with SMTP id b205so43466708wmb.1 for ; Thu, 25 Feb 2016 10:31:17 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=mime-version:in-reply-to:references:date:message-id:subject:from:to :cc; bh=8oU23Pl1wR+Hc0Isi0Ec1gWlt2jKJsJb9UtUS4cdSkk=; b=CLlL9zcA/NjtYue5nX7GmKCSLjRkrsv2rxweRvI6xJgIcW6ISdqm9qnWfh+MUzwuGB AUCamo9KlnPdG6H/Ym+J6Sw1rQ28+B9CMnGI/v+IH/MNXrXehJxQijCXzBuknEB1vtMW doMCsX757addQSvi4CM3WUKvGZS4r6Cf+0yENLjYppZIWaICphEVZmx2D+WbJBvSI0I4 A5i2VfsJtOrvqBKZ74zw4ji1gThPFOM9ZFIblnu5Nem/8cTGEwwd8h/ZwEvTtwKLkwW2 uNTZdxicn+k/VHjAzGpn3/qydHPbmKZcCA1ZWTUmA8cifzdAV8AcGec0f+KgV2lR8uOU XAjg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20130820; h=x-gm-message-state:mime-version:in-reply-to:references:date :message-id:subject:from:to:cc; bh=8oU23Pl1wR+Hc0Isi0Ec1gWlt2jKJsJb9UtUS4cdSkk=; b=MbqehEVJpRX3r8pa1crD21XnTro3d4uPLL8jzdF7a2Wg4yDpz/9wP57XpB/kb+nj0Z 4uP+0AF5j5A1wx9V29AmZlQOZkMocrGeBfsnXrivbYovWoXjbHksw7qyU7p0JUxB3noi io6VeFfKskw73psGcVoSgoPtAw/n0lb3IotnOH+8qIGa73EMgngCLxcec91XSpX1Fsxs 1Sdnyx8V42h4Pn7FcoeX2LHj3kkMryZaYI5/mToH4UrFgYdaKGbG1DF/xoX7jaPzaOB7 WlpDQKRAw3v8zbpLPkQ5MDvGgHlPJ1NaLzih0FFp6o6kzuGFRdq5vho2CzPnuHBDTd4t yOPA== X-Gm-Message-State: AG10YOS9xF+UhuTRqTn3ui2lJrvRXrP4k5o6lW7ot49UBCubLpDyIQMHx6sRY6Tzy1B5urF8utzmPl/fX3Oyrw== MIME-Version: 1.0 X-Received: by 10.28.221.68 with SMTP id u65mr43687wmg.95.1456425074906; Thu, 25 Feb 2016 10:31:14 -0800 (PST) Received: by 10.28.68.215 with HTTP; Thu, 25 Feb 2016 10:31:14 -0800 (PST) In-Reply-To: References: Date: Thu, 25 Feb 2016 11:31:14 -0700 Message-ID: To: Marco Pivetta Cc: Dan Ackroyd , "internals@lists.php.net" Content-Type: multipart/alternative; boundary=001a1148fd8e3b6539052c9c6354 Subject: Re: [PHP-DEV] [RFC] Callable constructors From: derokorian@gmail.com (Ryan Pallas) --001a1148fd8e3b6539052c9c6354 Content-Type: text/plain; charset=UTF-8 On Thu, Feb 25, 2016 at 11:20 AM, Marco Pivetta wrote: > Just adding to the use-cases: I really could've needed this the other day: > > > $records = array_map([MyRecord::class, '__construct'], > $db->someQuery()->fetchAll()); > > I used a named constructor instead, but this results with more internal > method calls: > > $records = array_map([MyRecord::class, 'fromResultSetRow'], > $db->someQuery()->fetchAll()); > If fetchAll is coming from PDO. then you could have simply done this: $records = $db->someQuery()->fetchAll(MyRecord::class); --001a1148fd8e3b6539052c9c6354--