From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (qmail 22638 invoked by alias); 7 May 2011 22:17:39 -0000 Mailing-List: contact zsh-workers-help@zsh.org; run by ezmlm Precedence: bulk X-No-Archive: yes List-Id: Zsh Workers List List-Post: List-Help: X-Seq: 29179 Received: (qmail 1841 invoked from network); 7 May 2011 22:17:28 -0000 X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on f.primenet.com.au X-Spam-Level: X-Spam-Status: No, score=-2.7 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,FREEMAIL_FROM,RCVD_IN_DNSWL_LOW autolearn=ham version=3.3.1 Received-SPF: pass (ns1.primenet.com.au: SPF record at _spf.google.com designates 209.85.220.171 as permitted sender) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=gamma; h=domainkey-signature:mime-version:in-reply-to:references:date :message-id:subject:from:to:cc:content-type; bh=1R+nieO3oVideGib3gUdlC4Mzs2+PDiNsyRdu9ijkSM=; b=Y4bwiFc55hVHw+19G2e6WBQVwmt2h/zLorlbKFhnCRUbwE4GDONOAdVzFibu06+xDa Cs5fyNkNSRPaoNyQ8sxyc/N9kdyySNm7cvIMNeuAU4hO+4q1mq/XOcWp0CVcXnhE2+oU 31yhR8NgvPXxKtk7Ut82RcpMLd4CuncWxc/vI= DomainKey-Signature: a=rsa-sha1; c=nofws; d=gmail.com; s=gamma; h=mime-version:in-reply-to:references:date:message-id:subject:from:to :cc:content-type; b=q+59QmyDap3GuEVMnW1Wum2lwX6Th9LQPPiZau0rbHpy7nt4Q4vlfPGoaicPNaBJb1 FXjvASh1gnQaK4taJ/EwijgQmd45q1o78WDCw8xZC7pNocZpiSDyAT/ibesPHMRL1ivi u3xUfyP6TeN9WmVQ6lQQ5JFN1yaujjs+uSoxA= MIME-Version: 1.0 In-Reply-To: References: Date: Sun, 8 May 2011 00:17:23 +0200 Message-ID: Subject: Re: SIGFPE crash From: Mikael Magnusson To: Jon Mayo Cc: zsh workers Content-Type: text/plain; charset=UTF-8 On 7 May 2011 23:56, Jon Mayo wrote: > echo $[-9223372036854775808/-1] > > this causes zsh to exit immediately with an FPE. Does anyone have a > patch to fix this? diff --git a/Src/math.c b/Src/math.c index 35b362d..3c08052 100644 --- a/Src/math.c +++ b/Src/math.c @@ -1053,8 +1053,12 @@ op(int what) return; if (c.type == MN_FLOAT) c.u.d = a.u.d / b.u.d; - else - c.u.l = a.u.l / b.u.l; + else { + if (a.u.l == LONG_MIN && b.u.l == -1) + c.u.l = 0; + else + c.u.l = a.u.l / b.u.l; + } break; case MOD: case MODEQ: Do we want to print a warning and/or use another value than 0 in this case? -- Mikael Magnusson