From mboxrd@z Thu Jan 1 00:00:00 1970 X-Spam-Checker-Version: SpamAssassin 3.4.4 (2020-01-24) on polar.synack.me X-Spam-Level: X-Spam-Status: No, score=0.2 required=5.0 tests=BAYES_00,INVALID_MSGID, REPLYTO_WITHOUT_TO_CC autolearn=no autolearn_force=no version=3.4.4 X-Google-Language: ENGLISH,ASCII-7-bit X-Google-Thread: fac41,9a0ff0bffdf63657 X-Google-Attributes: gidfac41,public X-Google-Thread: 103376,4b06f8f15f01a568 X-Google-Attributes: gid103376,public X-Google-Thread: f43e6,9a0ff0bffdf63657 X-Google-Attributes: gidf43e6,public X-Google-Thread: 1108a1,9a0ff0bffdf63657 X-Google-Attributes: gid1108a1,public From: Loryn Jenkins Subject: Re: Software landmines (loops) Date: 1998/09/05 Message-ID: <35F0B963.24E56952@s054.aone.net.au>#1/1 X-Deja-AN: 388062612 Content-Transfer-Encoding: 7bit References: <902934874.2099.0.nnrp-10.c246a717@news.demon.co.uk> <6r1glm$bvh$1@nnrp1.dejanews.com> <6r9f8h$jtm$1@nnrp1.dejanews.com> <6renh8$ga7$1@nnrp1.dejanews.com> <6rf59b$2ud$1@nnrp1.dejanews.com> <6rfra4$rul$1@nnrp1.dejanews.com> <35DBDD24.D003404D@calfp.co.uk> <6sbuod$fra$1@hirame.wwa.com> <35f51e53.48044143@ <904556531.666222@miso.it.uq.edu.au> <35EAEC47.164424A7@s054.aone.net.au> <35EBBFAF.DE38C061@s054.aone.net.au> <35F09855.D035AFDC@earthlink.net> X-Priority: 3 (Normal) Content-Type: text/plain; charset=us-ascii X-Trace: news.mel.aone.net.au 904968584 4953 203.12.186.163 (5 Sep 1998 04:09:44 GMT) Organization: TekRite Pty Ltd Mime-Version: 1.0 Reply-To: loryn@acm.org NNTP-Posting-Date: 5 Sep 1998 04:09:44 GMT Newsgroups: comp.lang.eiffel,comp.object,comp.software-eng,comp.lang.ada Date: 1998-09-05T04:09:44+00:00 List-Id: Charles Hixson wrote: > > Loryn Jenkins wrote: > .. > > Ah! For some reason, I thought you were testing the first item on the > > stack. So, my amended code, to match your semantics is thus: > > > > equal (l,r: LIST): BOOLEAN is > > require > > l /= Void and r /= Void > > do > > Result := l.count /= r.count > > if Result then > > from > > l.start; r.start > > until > > not Result or l.off > > loop > > Result := l.item /= r.item > > l.forth; r.forth > > end > > end > > end > > > ... > > > > Loryn Jenkins > > > > Is the if test important? The until test should catch it anyway, and > the code would read more cleanly without it. Not really. It is an optimization. But do note, that if you removed it, you *must* change the loop to the following: > > equal (l,r: LIST): BOOLEAN is > > require > > l /= Void and r /= Void > > do > > from > > l.start; r.start > > until > > not Result or l.off or r.off > > loop > > Result := l.item /= r.item > > l.forth; r.forth > > end > > end ... just in case r is shorter than l. Loryn Jenkins