From owner-freebsd-arch@FreeBSD.ORG Tue Dec 6 15:13:43 2011 Return-Path: Delivered-To: freebsd-arch@FreeBSD.ORG Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id DBD2D106564A; Tue, 6 Dec 2011 15:13:43 +0000 (UTC) (envelope-from des@des.no) Received: from smtp.des.no (smtp.des.no [194.63.250.102]) by mx1.freebsd.org (Postfix) with ESMTP id 9953A8FC0A; Tue, 6 Dec 2011 15:13:43 +0000 (UTC) Received: from ds4.des.no (des.no [84.49.246.2]) by smtp.des.no (Postfix) with ESMTP id 2DE676C8B; Tue, 6 Dec 2011 14:55:17 +0000 (UTC) Received: by ds4.des.no (Postfix, from userid 1001) id 12DBC8FB9; Tue, 6 Dec 2011 15:55:17 +0100 (CET) From: =?utf-8?Q?Dag-Erling_Sm=C3=B8rgrav?= To: Rick Macklem References: <1697386241.723355.1322748438341.JavaMail.root@erie.cs.uoguelph.ca> Date: Tue, 06 Dec 2011 15:55:16 +0100 In-Reply-To: <1697386241.723355.1322748438341.JavaMail.root@erie.cs.uoguelph.ca> (Rick Macklem's message of "Thu, 1 Dec 2011 09:07:18 -0500 (EST)") Message-ID: <86borlda23.fsf@ds4.des.no> User-Agent: Gnus/5.13 (Gnus v5.13) Emacs/23.3 (berkeley-unix) MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: quoted-printable Cc: Zack Kirsch , mdf@FreeBSD.ORG, David Schultz , John Baldwin , freebsd-arch@FreeBSD.ORG Subject: Re: Use of bool / stdbool.h in kernel X-BeenThere: freebsd-arch@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Discussion related to FreeBSD architecture List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 06 Dec 2011 15:13:43 -0000 Rick Macklem writes: > If this is added, would the style gods approve of the following: > > (A) bool test_func(); > > if (test_func()) > ... > > instead of: > > (B) int test_func(); > > if (test_func() !=3D 0) > ... Part of the problem is that the opposite semantics are widely used, i.e. 0 indicates success and non-zero indicates failure, possibly with different non-zero values having different specific meanings. There are also cases (such as open() and socket()) where >=3D 0 indicates success while < 0 indicates failure. Therefore, an explicit comparison is preferred, except for functions like isspace() and the like whose names clearly indicate that they are predicates. DES --=20 Dag-Erling Sm=C3=B8rgrav - des@des.no