Newsgroups: php.internals Path: news.php.net Xref: news.php.net php.internals:98485 Return-Path: Mailing-List: contact internals-help@lists.php.net; run by ezmlm Delivered-To: mailing list internals@lists.php.net Received: (qmail 71032 invoked from network); 11 Mar 2017 16:24:16 -0000 Received: from unknown (HELO lists.php.net) (127.0.0.1) by localhost with SMTP; 11 Mar 2017 16:24:16 -0000 Authentication-Results: pb1.pair.com smtp.mail=michael.vostrikov@gmail.com; spf=pass; sender-id=pass Authentication-Results: pb1.pair.com header.from=michael.vostrikov@gmail.com; sender-id=pass Received-SPF: pass (pb1.pair.com: domain gmail.com designates 209.85.161.173 as permitted sender) X-PHP-List-Original-Sender: michael.vostrikov@gmail.com X-Host-Fingerprint: 209.85.161.173 mail-yw0-f173.google.com Received: from [209.85.161.173] ([209.85.161.173:33511] helo=mail-yw0-f173.google.com) by pb1.pair.com (ecelerity 2.1.1.9-wez r(12769M)) with ESMTP id 1A/33-38004-0B424C85 for ; Sat, 11 Mar 2017 11:24:16 -0500 Received: by mail-yw0-f173.google.com with SMTP id v76so39620590ywg.0 for ; Sat, 11 Mar 2017 08:24:16 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:in-reply-to:references:from:date:message-id:subject:to; bh=meOCoO3NxNqcqpoJUAKdBLbv/MV9Wz5gOuthho7X6YE=; b=qigyI9kLTHvUDcdeMPrgqOFuqalgaWv7uinpRZB0k2kOTLCzQ8LH21nSbOnT9hdiXm PhwWgPuVCnORey/GLsEDS88MnmKrEkF2WuwS79hFdgJQv1Vj76Yd+c4jb8zm8nu9Hh/c yUhMQSIe5N3B5WQYVA7IyBmr8I22e48XQi70xgwdnqdSck62OEYG+P77UkvXo+V4vn5r 0RL7RaqCzlEQKij6bYahbkLbnEFWaL6+WsECP4wVN8Y8aqENc6iKYOUGQQcJCDl+ZKRw frM4awhb6Hgk+W4BWTm6v4RD54r3KYie/s/Qo0J2UsMUlvaHO/LGr97mq1ieh2HsdN3c EOVw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:in-reply-to:references:from:date :message-id:subject:to; bh=meOCoO3NxNqcqpoJUAKdBLbv/MV9Wz5gOuthho7X6YE=; b=HFK3sivq84Bt52kT6DgmdnOuLe4hlLUB5+QWZURhwbXJnuAYJoYCNl/IsOyUzi3vyS GmKAKC7YloKl3SxG/I8FL6GGDfX0ryibiu0V++3F+7qutXJ7PU2ncMkQkULM+wBxgHp7 1WBtfQ9gq2uhMM9UQ1SgSZgIvJi1vsMats6jrq11CGxHAQA5iEse13tnxADYNS90I+NS fZTeRVIy5C8YwqPld4bG5JmUixrZN9iuiErXlWHIcKJYIO0BcE8NPB2HDuRSqE7ggnjn +9tp1HrtEvbkIkV+8YlyQhDIS8FQ0yGMkLb5Ib/O9H43KVVASmxXTr12p9nKdGbAik4l GuSQ== X-Gm-Message-State: AMke39ka8WQfq9elhdmxZy/F5C5HgT0c+HzhhUlbdWXTvJ/IiWQ5QrEPziYzDpbs4rxR5YHyTl/VqLi3JVbj2g== X-Received: by 10.13.225.142 with SMTP id k136mr11873705ywe.178.1489249453883; Sat, 11 Mar 2017 08:24:13 -0800 (PST) MIME-Version: 1.0 Received: by 10.13.224.196 with HTTP; Sat, 11 Mar 2017 08:24:13 -0800 (PST) In-Reply-To: References: Date: Sat, 11 Mar 2017 21:24:13 +0500 Message-ID: To: PHP Internals Content-Type: multipart/alternative; boundary=94eb2c0612c0ae51d2054a76e849 Subject: Re: [PHP-DEV] Type variants From: michael.vostrikov@gmail.com (Michael Vostrikov) --94eb2c0612c0ae51d2054a76e849 Content-Type: text/plain; charset=UTF-8 > 'Order does not match OrderForCheckout. Reason: ...'. Sorry, this is text for second example) I missed this moment. But I think the idea is clear. For manual call of __match() type casting can be used: $orderForCheckout = (OrderForCheckout)$order; Also this feature can be used for checking enum values or intervals. class Value { public $value; public function __construct($value) { $this->value = $value; } } class State variant of Value { const ACTIVE = 1; const INACTIVE = 2; public function __match() { return in_array($this->value, [self::ACTIVE, self::INACTIVE]); } } function setState(State $s) { ... } setState(new State(3)); In constructions like "new State($value)" __match() can be called after __construct(). If to add a possibility to use data types, class Value will not be needed: class State variant of integer { ... public function __match() { return in_array($this, [self::ACTIVE, self::INACTIVE]); } } setState(3); --94eb2c0612c0ae51d2054a76e849--