From owner-freebsd-hackers Tue Nov 21 22:26:53 2000 Delivered-To: freebsd-hackers@freebsd.org Received: from peach.ocn.ne.jp (peach.ocn.ne.jp [210.145.254.87]) by hub.freebsd.org (Postfix) with ESMTP id 9E0B837B479 for ; Tue, 21 Nov 2000 22:26:48 -0800 (PST) Received: from newsguy.com (p51-dn02kiryunisiki.gunma.ocn.ne.jp [211.0.245.116]) by peach.ocn.ne.jp (8.9.1a/OCN/) with ESMTP id PAA26353; Wed, 22 Nov 2000 15:26:23 +0900 (JST) Message-ID: <3A1B66A3.D29C8565@newsguy.com> Date: Wed, 22 Nov 2000 15:24:35 +0900 From: "Daniel C. Sobral" X-Mailer: Mozilla 4.7 [en] (Win98; I) X-Accept-Language: en,pt-BR MIME-Version: 1.0 To: Garance A Drosihn Cc: Robert Nordier , hackers@FreeBSD.ORG Subject: Re: fclose vs ferror (from libc/getcap) References: <200011201020.MAA23349@siri.nordier.com> <3A1B5592.89A7BBE2@newsguy.com> Content-Type: text/plain; charset=us-ascii Content-Transfer-Encoding: 7bit Sender: owner-freebsd-hackers@FreeBSD.ORG Precedence: bulk X-Loop: FreeBSD.ORG Garance A Drosihn wrote: > > >Undefined behavior means anything goes. On a standard, it means the > >behaviour is implementation-defined (which may be undefined or not). > > But if "anything goes", then that you can not expect it to > work; certainly not when porting to other platforms. Sure enough. The behavior of any function on a closed FILE* is not defined by standards. > I am not saying that what freebsd does is wrong. But Robert > said that "[that code is a silly thing], but if I was porting > some hairy old C code I'd tend to expect it to work." > It seems to me that if the behavior is explicitly undefined > then you can NOT expect much of anything when porting. He said he would _tend_ to expect it to work. To me, that means the code is dubious, but is likely to work. > > And notice that ferror() is not an access to the stream. > > In the section I quoted from unix spec, "stream" refers to the > variable passed to fclose (though that isn't obvious, because I > didn't copy the formatting). ferror certainly does access that > variable. MMmmmm. That's a dubious interpretation. The variable is a handle to the stream, not the stream itself. Are you sure of the SUS wording? -- Daniel C. Sobral (8-DCS) dcs@newsguy.com dcs@freebsd.org capo@united.bsdconspiracy.net "All right, Lieutenant, let's see what you do know. Whatever it is, it's not enough, but at least you haven't done anything stupid yet." "I've hardly had time, sir." "There's a naive statement." To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-hackers" in the body of the message