Newsgroups: php.internals Path: news.php.net Xref: news.php.net php.internals:85719 Return-Path: Mailing-List: contact internals-help@lists.php.net; run by ezmlm Delivered-To: mailing list internals@lists.php.net Received: (qmail 60193 invoked from network); 3 Apr 2015 19:31:42 -0000 Received: from unknown (HELO lists.php.net) (127.0.0.1) by localhost with SMTP; 3 Apr 2015 19:31:42 -0000 Authentication-Results: pb1.pair.com header.from=morrison.levi@gmail.com; sender-id=pass Authentication-Results: pb1.pair.com smtp.mail=morrison.levi@gmail.com; spf=pass; sender-id=pass Received-SPF: pass (pb1.pair.com: domain gmail.com designates 209.85.214.172 as permitted sender) X-PHP-List-Original-Sender: morrison.levi@gmail.com X-Host-Fingerprint: 209.85.214.172 mail-ob0-f172.google.com Received: from [209.85.214.172] ([209.85.214.172:34899] helo=mail-ob0-f172.google.com) by pb1.pair.com (ecelerity 2.1.1.9-wez r(12769M)) with ESMTP id 3F/54-23347-E9AEE155 for ; Fri, 03 Apr 2015 14:31:42 -0500 Received: by obbfy7 with SMTP id fy7so97223452obb.2 for ; Fri, 03 Apr 2015 12:31:39 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=mime-version:sender:in-reply-to:references:date:message-id:subject :from:to:cc:content-type; bh=0V1RV3I1VO9V6+9ZZXVXCAu6cJes5lEqhWoEO9Iroy4=; b=P4/BGJnAZXL+qJSpRG8zZDxntn/CmZzk94Pl1z9Tf+J6dQFsaI8nnQKyR4Qr9EDTBM FPRXreBEBiVpldYHgrlotuIBrWognFnhNQh8vjEbhIz1d+eaSkiztrmYnCAVUhw13rL9 YNgiTP+BJjVG0TYt04Uzbd0yP2u58bZNEnDGDkaF3+4zskwUh7k1k7yn/yap2gNH3zAH zHU2ZrMWkFWL896qF4u9T3XgO6IuKmU9cZUwxglYa544dbZTN+HJtZV1a2OmZVkzG1M+ yeYkuNNBaZJUP0VBWVEPGiKeVybKXp8EYJi/SaoVl5/1L0XQeZAgqrVIUYegEVKpr304 fc4g== MIME-Version: 1.0 X-Received: by 10.60.51.6 with SMTP id g6mr4651737oeo.45.1428089499725; Fri, 03 Apr 2015 12:31:39 -0700 (PDT) Sender: morrison.levi@gmail.com Received: by 10.76.93.136 with HTTP; Fri, 3 Apr 2015 12:31:39 -0700 (PDT) In-Reply-To: <33BCE1D0-BA6D-464C-B23D-69AF71356111@ajf.me> References: <33BCE1D0-BA6D-464C-B23D-69AF71356111@ajf.me> Date: Fri, 3 Apr 2015 13:31:39 -0600 X-Google-Sender-Auth: BL3fJAnz8y_OlNN8yjJt_9AqcrE Message-ID: To: Andrea Faulds Cc: Dmitry Stogov , PHP Internals , Nikita Popov Content-Type: text/plain; charset=UTF-8 Subject: Re: [PHP-DEV] Re: Fix division by zero to throw exception From: levim@php.net (Levi Morrison) On Fri, Apr 3, 2015 at 1:10 PM, Andrea Faulds wrote: > Hi Dmitry, > >> On 3 Apr 2015, at 20:04, Dmitry Stogov wrote: >> >> 2) Very similar weird behavior was introduced for shift with negative offsets. I also propose to change it in the same way (Fatal error at compile-time, Exception in run-time). >> >> Any thoughts? objections? > > For consistency with IEEE 754, shouldn't we produce INF on a division by zero, at least for floats (but probably integers too because of weak typing)? I don't think producing a warning is an issue, but FALSE isn't the right value to produce. I agree with Andrea. Currently we do floating point division even if both arguments are integers, and the correct behavior for a floating point divide by zero is to produce an INF or -INF.