Newsgroups: php.internals Path: news.php.net Xref: news.php.net php.internals:112562 Return-Path: Delivered-To: mailing list internals@lists.php.net Received: (qmail 76757 invoked from network); 20 Dec 2020 11:00:01 -0000 Received: from unknown (HELO php-smtp4.php.net) (45.112.84.5) by pb1.pair.com with SMTP; 20 Dec 2020 11:00:01 -0000 Received: from php-smtp4.php.net (localhost [127.0.0.1]) by php-smtp4.php.net (Postfix) with ESMTP id 45A2C1804D1 for ; Sun, 20 Dec 2020 02:32:11 -0800 (PST) X-Spam-Checker-Version: SpamAssassin 3.4.2 (2018-09-13) on php-smtp4.php.net X-Spam-Level: X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,FREEMAIL_FROM,HTML_MESSAGE, RCVD_IN_DNSWL_NONE,RCVD_IN_MSPIKE_H2,SPF_HELO_NONE,SPF_PASS autolearn=no autolearn_force=no version=3.4.2 X-Spam-Virus: No X-Envelope-From: Received: from mail-lf1-f47.google.com (mail-lf1-f47.google.com [209.85.167.47]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange ECDHE (P-256) server-signature RSA-PSS (4096 bits) server-digest SHA256) (No client certificate requested) by php-smtp4.php.net (Postfix) with ESMTPS for ; Sun, 20 Dec 2020 02:32:10 -0800 (PST) Received: by mail-lf1-f47.google.com with SMTP id y19so16581170lfa.13 for ; Sun, 20 Dec 2020 02:32:10 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=QiCFiI0uKzjUMnbyt7iG0oW58n9DPW7uCLqvMA6JptU=; b=LKsqfSofy8kHInwcghKd4R7tDmMlnB7kGVUU0avws1DD0YcQzemHn0AtPM6oF3jY/L oE8DXKaAvTA5VrJU2+yuuMVdvHSm4LTnXPWzI9T4GfXAbsK9HdQ4Cvu6vy6jaZoJ5/Gz 1wqwADe3CUWmfD8lxDLk2dNU+AyaMtrolq+9XfSV2BWXtwF1a6rOXay6s+vthf/G0LZ7 fT0ctCxEWqpAYFyAr0Wga5VAg3KgRYQP6ognqOYJ7WUzUkn8PcARZXo4Ck3g++qKeh7c jALr2S/UMkMabbibxfZ7Uc0X27mOHGEcZ4gZVgj/JTvFhcD3OKMdfskSMIRNlEmD4666 hfOA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=QiCFiI0uKzjUMnbyt7iG0oW58n9DPW7uCLqvMA6JptU=; b=c1iueeEqK1lvix5l7U/riFGNv7I0i/VwYbVvIWOlETPnHl38dXZGs36frFVPT6EF02 bTdjgIZZ9Fs8J6+nbp2+lxoz8QXnNxaafXsqRxwmkfzaunFTIdUYG6sea1UCJhC4+WJn yDCwYIAeFG3FGefcRmS/ossTWTEIQVHVN9qm3TNIplW4g/+njLUuWftFk/BJlhkLfEo2 nccg/qSJ9Mc7H5KioxPSNXVljKdnEIefBUw9A+s+w4doVLPkw6R7SnEmzrb2JIu/Xj5t muLIRY4l61iTyX8jgNaa1bctZfkLo6afZOSuYh9ADu0AbXnfVDqgpd+H8uxOjHi/sLPO DESQ== X-Gm-Message-State: AOAM5326IHYNj1DPiSYN7gwo3E34BejEg9DRSaLDRoEATFV9KIPdlO0+ o8nDT0aP2NIxVSe7oxZvAuxWMGlfQLuc4owK7Ns= X-Google-Smtp-Source: ABdhPJxV/cJ3K1a0jNHGI1Tm3Qrm3SXmo4848OU+m4aACLVeTdniV64DqKhJdCpqgDQWW1sIqqx9skRQ3FUe6XRnGAM= X-Received: by 2002:ac2:4987:: with SMTP id f7mr4387482lfl.41.1608460328226; Sun, 20 Dec 2020 02:32:08 -0800 (PST) MIME-Version: 1.0 References: <490a62fb-f6f4-4d7b-b46d-571abfa28618@www.fastmail.com> <24f119cf-0ab5-4db6-8940-062f08d5a8cb@www.fastmail.com> In-Reply-To: <24f119cf-0ab5-4db6-8940-062f08d5a8cb@www.fastmail.com> Date: Sun, 20 Dec 2020 11:31:54 +0100 Message-ID: To: Larry Garfield Cc: php internals Content-Type: multipart/alternative; boundary="0000000000007fd3bc05b6e2da6b" Subject: Re: [PHP-DEV] [RFC] Short-match From: olleharstedt@gmail.com (=?UTF-8?Q?Olle_H=C3=A4rstedt?=) --0000000000007fd3bc05b6e2da6b Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable On Sat, 19 Dec 2020, 02:48 Larry Garfield, wrote: > On Fri, Dec 18, 2020, at 1:40 PM, Olle H=C3=A4rstedt wrote: > > What about matching on a variable's type? > > > > ``` > > match { > > $var: string =3D> "is a string" > > $var: array =3D> "something else" > > } > > ``` > > > > This could be used with flow-sensitive typing, e.g. assume the type of > $var > > being string in the string block. Psalm works like this for > if-statements. > > Also consider the case with generics. > > > > Compare with generalised algebraic data types in FP (GADT). > > > > Olle > > That would be more along the lines of the pattern matching RFC that Ilija > and I have been kicking around for post-enums: > https://wiki.php.net/rfc/pattern-matching > > That's still in the "it would be cool if" stage only, and is IMO off topi= c > from the abbreviation effort in this RFC. > > --Larry Garfield > Very cool. Thanks for the link. Looking forward to further implementations! Olle --=20 > PHP Internals - PHP Runtime Development Mailing List > To unsubscribe, visit: https://www.php.net/unsub.php > > --0000000000007fd3bc05b6e2da6b--