Date: Sat, 02 May 2009 09:27:51 +0200 From: Christoph Mallon <christoph.mallon@gmx.de> To: "M. Warner Losh" <imp@bsdimp.com> Cc: rick-freebsd2008@kiwi-computer.com, freebsd-hackers@FreeBSD.org Subject: Re: C99: Suggestions for style(9) Message-ID: <49FBF5F7.7000600@gmx.de> In-Reply-To: <20090501.083712.396385864.imp@bsdimp.com> References: <20090430.183727.803597558.imp@bsdimp.com> <49FA8E88.1040905@gmx.de> <20090501.081229.1359784281.imp@bsdimp.com> <20090501.083712.396385864.imp@bsdimp.com>
next in thread | previous in thread | raw e-mail | index | archive | help
M. Warner Losh schrieb: > In message: <20090501.081229.1359784281.imp@bsdimp.com> > M. Warner Losh <imp@bsdimp.com> writes: > : In message: <49FA8E88.1040905@gmx.de> > : Christoph Mallon <christoph.mallon@gmx.de> writes: > : : M. Warner Losh schrieb: > : : > In message: <20090430233648.GA95360@keira.kiwi-computer.com> > : : > "Rick C. Petty" <rick-freebsd2008@kiwi-computer.com> writes: > : : > : On Thu, Apr 30, 2009 at 09:02:26AM -0600, M. Warner Losh wrote: > : : > : > > : : > : > This is the biggest one, and I think it may be too soon. Also, we > : : > : > need to be careful on the initialization side of things because we > : : > : > currently have a lot of code that looks like: > : : > : > > : : > : > > : : > : > struct foo *fp; > : : > : > struct bar *bp; > : : > : > > : : > : > fp = get_foo(); > : : > : > if (!fp) return; > : : > : > bp = fp->bp; > : : > : > > : : > : > this can't easily be translated to the more natural: > : : > : > > : : > : > struct foo *fp = get_foo(); > : : > : > struct bar *bp = fp->bp; > : : > : > > : : > : > since really you'd want to write: > : : > : > > : : > : > struct foo *fp = get_foo(); > : : > : > if (!fp) return; > : : > : > struct bar *bp = fp->bp; > : : > : > > : : > : > which isn't legal in 'C'. > : : > : > : : > : I thought we were talking about C99, in which case this is perfectly legal. > : : > : I certainly use it all the time in my C99 code. > : : > > : : > Hmmm, looks like that was added. That's ugly as C++... > : : > : : I do not think, this is ugly. On the contrary, it aids maintainability, > : : because it reduces the scope of variables. Also quite some variables are > : : only initialised and not changed afterwards, so it's nice to have the > : : declaration and the only assignment in a single place. IMO this is a > : : quite natural style, because you don't have anything in the code, before > : : it is needed: Get the first pointer; if something is wrong, bail out; > : : get the second pointer - the second pointer does not (textually) exist > : : before it is needed. > : > : It is ugly. Hunting for declarations sucks, and it is one of the > : things I really like about BSD code is that I don't have to. > : > : This is a religious point, and we're dangerously close to saying my > : religion is better than your religion. I don't like this part of the > : proposal at all. I can see the value in relaxing it for when you have > : a series of variables that are initialized, but relaxing it to the > : point where you intermix code and declarations goes way too far. It > : is bad enough to have to deal with inner scopes, but tolerable. It is > : intolerable to have to look for it anywhere in a big function. It > : tends to encourage spaghetti code, which is one of the things that > : style(9) tries to discourage in many subtle ways. > > This came off a little more absolute than I wanted. I should have > added "in the absence of hard data..." There is hard data: For example look at r190098 and the following discussion, which you took part in. Obviously style(9) is too subtle at best or counterproductive at worst to achieve the desired goal. It is worrisome that somebody is inclined to obfuscate the code (in this case replacing multiple variables with descriptive names by a single variable with a generic name) because it is less hassle to conform to style(9) this way. I also have to object, that it leads to hunting for declarations. Actually it usually reduces scrolling around in the code: Many variables are only assigned once. A typical example is getting the softc of a device; especially there the type is important, because device_get_softc() returns void*. So it is very convenient to have this single assignment and its declaration at the same place. Not only the type of a variable is important, but also its value, so this assignment needs to be looked up, too. Doing declaration and initialisation at once you only have to look at one place instead of two. If you use vim as editor, then the current way makes it hard to find this assignment: "gd" jumps only to the declaration, the assignment is somewhere else. But if the declaration and the only assignment are the same, you get both at the same place and time. Even if there are multiple assignments, the first one often is a point of interest, e.g. int found = 0; followed by a search loop. Of course, if you abuse a variable in multiple contexts, then there are multiple "first" assignments and this coupling of declaration and first assignment gets lost. Therefore I am against re-using a variable in multiple contexts. In conclusion, I argue that declaring a variable right at its first (and often only) assignment does not lead to "spaghetti code" or "sloppy code", but in contrary makes the code more concise and easier to navigate. Christoph
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?49FBF5F7.7000600>