On Wed, Jul 13, 2011 at 2:36 PM, Colin Patrick McCabe <colin.mccabe@xxxxxxxxxxxxx> wrote: > On Wed, Jul 13, 2011 at 1:25 PM, Yehuda Sadeh Weinraub > <yehudasa@xxxxxxxxx> wrote: >> On Wed, Jul 13, 2011 at 12:54 PM, Colin Patrick McCabe >> <colin.mccabe@xxxxxxxxxxxxx> wrote: >>> On Wed, Jul 13, 2011 at 11:59 AM, Yehuda Sadeh Weinraub >>> <yehudasa@xxxxxxxxx> wrote: >>>> On Wed, Jul 13, 2011 at 11:21 AM, Colin McCabe <cmccabe@xxxxxxxxxxxxxx> wrote: >>>>> On Wed, Jul 13, 2011 at 10:52 AM, Yehuda Sadeh Weinraub >>> [snip class variable naming discussion] >>> >>> You seem to have two objections to the proposed naming. One is that >>> you don't like the trailing underscore. That is fine-- I like the "m_" >>> prefix better myself. >>> >>> The second is that you don't want "mixed code." I really don't >>> understand this objection. We have "mixed code" right now... there are >>> some classes currently use m_ prefixes, some that use underscore >>> prefixes, and some that use none of the above. There are some people >>> using the exact same variable names for class variables and local >>> variable names-- like the example that I gave-- and relying on the C++ >>> shadowing rules. I don't see how any reasonable person can read that >>> kind of code and not feel confused and frustrated. >> >> Hmm.. I might have not been clear enough. I said that introducing this >> now won't fix anything as we have enough code that doesn't follow >> these rules to dim it ineffective. Moreover, introducing it now as a >> rule, will just add further confusion for people who'd read the code >> and assume certain things about the coding style. > > You just need a tool that understands C++ to do the renaming. I think > eclipse's "rename variable" function might be able to fix pretty > quickly. I also predict that we would uncover some actual errors this > way by eliminating the confusion between local variables and class > variables. > > We were trying to do the same thing with -Wshadow a while ago, but we > got bogged down because that compiler warning included a lot of > unecessary stuff not directly related to variables. Swiping changes tend to have unexpected results. I'd avoid doing anything like that. > >> >>>> >>>> The same goes here. Default parameters *may* bite, yes. But they're >>>> also an important tool that can ease up development and make code look >>>> much more concise and readable. >>> >>> I want to quote the discussion included in the Google coding standard >>> here, because it's very well-thought-out: >>>> Pros: >>>> Often you have a function that uses lots of default values, but >>>> occasionally you want to override the defaults. Default parameters allow >>>> an easy way to do this without having to define many functions for the >>>> rare exceptions. >>>> >>>> Cons: >>>> People often figure out how to use an API by looking at existing code that >>>> uses it. Default parameters are more difficult to maintain because >>>> copy-and-paste from previous code may not reveal all the parameters. >>>> Copy-and-pasting of code segments can cause major problems when the >>>> default arguments are not appropriate for the new code. >> >> Sorry, it didn't convince me. Copy and pasting of code segments can >> cause other major problems not related to default parameters. > > If you have two code segments that perform the same task, and one of > them requires a lot of context to understand, and the other requires > very little, the second one is the better code. I'd argue that code aesthetics has a not-less-important value too. Adding strange variable names, and/or having longer function calls due to default avoidance impairs that. > > This is the same reason why unecessary global variables and global > state are bad. It's the same reason why poorly documented code is bad. > The harder it is to understand what is going on, the worse it is. Life is not black and white, so is coding. If you see everything in dichotomy, you end up impractically and blindly following rules you don't understand the reasoning behind them. > > Secondly... let the programmer who has never copied and pasted, throw > the first stone. I'm sure that it won't be either of us. I'd take the word of a person that never did that with a grain of salt as he obviously hasn't done much actual development. Yehuda -- To unsubscribe from this list: send the line "unsubscribe ceph-devel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html