Ayende @ Rahien

My name is Oren Eini
Founder of Hibernating Rhinos LTD and RavenDB.
You can reach me by phone or email:


+972 52-548-6969

, @ Q c

Posts: 6,026 | Comments: 44,842

filter by tags archive



It's hard to form an opinion without putting that slide into context. It could mean:

a) Represents the general feel of many managers, developers

b) Represents you not being interested in code quality.

Also, Code Quality is a broad term and can mean numerous things. I can say that my code quality is based on a series of numerous design principles, whereas someone else can consider quality as a means of a number of bugs irrelevant of the design. Then you have MS's view of code quality...

Patrick Smacchia

I agree with Joe, this sounds like marketing slide with a buzzword to attract attention.

What is code quality? Rationalized dependencies and sustained good design? Low method and class complexity? Good code coverage by tests? Limited side-effect? I don't think that any of this is meaningless.

Lucas Goodwin


You're in a real "stir the sh*t" mood lately ;)

Without context, all I can say is its a well designed slide.

Lucas Goodwin

Bah, forgot to say I suppose that's the point. Code Quality is a meaningless term on its own.

Steve Smith

I agree with Lucas, I think Ayende is impersonating a UseNet troll on his blog lately to stir up interesting discussion. :) That said, I'm sure there's some context coming to justify the position, like "the customer never sees the code so they don't care about its 'quality' only whether it solves the task they want the software to solve'.


I would reverse it:



I see where you're going with this. Code quality (what does that even mean?) is invisible to everyone but developers anyway - what matters is turning that code into something that generates revenue.


It´s often hard to sell Code quality, may be some numbers could help us to open manager´s eyes...

Sidar Ok

I'd say its meaning is overloaded rather than it being meaningless.


Ironic that a post which has as its' only statement that something is uninteresting should be so, interesting.

Now please put the world out of its' misery and explain yourself :)


Well, I'll bite. I'm inclined to agree with Lucas that as a context-free property, there is no there there. At the same time, there is something useful in the notion of code quality. Maybe that could be attached to other ilities instead?

One challenge I see is separation from efficiency, which has its own demons, and understandability.

Hmm, there are trade-offs here. No way to make trade-offs without context. I wonder how one would attach "code quality" matters to risk management for a software project that addresses the full software lifecycle. Or is that a pipe dream too?

Joao Braganca

Hey, just cause it isn't interesting or exciting doesn't mean it ain't important.


I know one practical code quality (CQ) metric - WTFs per minute at the time of code review =) Other are really not so interested. But, why MS included tools to calculate this parameter? Also, why is FxCop for?

Second, your slide has web2.0 style (bottom mirroring) - so does this statement about CQ mostly refers to web2.0 projects?

Igor Damiani

do you need to create a mission-critical software to put in production in ten minutes?

ok, you don't need high code quality.


Comment preview

Comments have been closed on this topic.


No future posts left, oh my!


  1. Technical observations from my wife (3):
    13 Nov 2015 - Production issues
  2. Production postmortem (13):
    13 Nov 2015 - The case of the “it is slow on that machine (only)”
  3. Speaking (5):
    09 Nov 2015 - Community talk in Kiev, Ukraine–What does it take to be a good developer
  4. Find the bug (5):
    11 Sep 2015 - The concurrent memory buster
  5. Buffer allocation strategies (3):
    09 Sep 2015 - Bad usage patterns
View all series


Main feed Feed Stats
Comments feed   Comments Feed Stats