How Broken is Microsoft?
-
Font Size:
Moishe Lettvin, a software engineer for Google who previously worked for Microsoft, just revealed how broken Microsoft's software development processes are. Mr. Lettvin spent a year designing the Off menu for Vista. The design of the Off menu, he reports, took a full-time team of 8 people, with wider involvement from another 16, and a total of 43 "with a voice in this feature". Here's his description of how the team worked:
...approximately every 4 weeks, at our weekly meeting, our PM would say, "the shell team disagrees with how this looks/feels/works" and/or "the kernel team has decided to include/not include some functionality which lets us/prevents us from doing this particular thing". And then in our weekly meeting we'd spent approximately 90 minutes discussing how our feature -- er, menu -- should look based on this "new" information. Then at our next weekly meeting we'd spend another 90 minutes arguing about the design, then at the next weekly meeting we'd do the same, and at the next weekly meeting we'd agree on something... just in time to get some other missing piece of information from the shell or kernel team, and start the whole process again.
I'd also like to sketch out how actual coding -- what there is of it -- works on the Windows team.
In small programming projects, there's a central repository of code. Builds are produced, generally daily, from this central repository. Programmers add their changes to this central repository as they go, so the daily build is a pretty good snapshot of the current state of the product.
In Windows, this model breaks down simply because there are far too many developers to access one central repository -- among other problems, the infrastructure just won't support it. So Windows has a tree of repositories: developers check in to the nodes, and periodically the changes in the nodes are integrated up one level in the hierarchy. At a different periodicity, changes are integrated down the tree from the root to the nodes. In Windows, the node I was working on was 4 levels removed from the root. The periodicity of integration decayed exponentially and unpredictably as you approached the root so it ended up that it took between 1 and 3 months for my code to get to the root node, and some multiple of that for it to reach the other nodes. It should be noted too that the only common ancestor that my team, the shell team, and the kernel team shared was the root.
So in addition to the above problems with decision-making, each team had no idea what the other team was actually doing until it had been done for weeks.
The end result of all this is what finally shipped: the lowest common denominator, the simplest and least controversial option.
Joel Spolsky, another programmer (unaffiliated with Microsoft or Google) comments on this:
Every piece of evidence I've heard from developers inside Microsoft supports my theory that the company has become completely tangled up in bureaucracy, layers of management, meetings ad infinitum, and overstaffing.
Value investors who hold Microsoft stock -- be careful!
Get Seeking Alpha Free Stock Alerts by Email!
Get Free Stock Alerts by Email!
-
Editor's Picks
-
Most Popular
- Inside the Dubai Gold & Commodities Exchange: An Interview with Malcolm Wall Morris
- How the U.S. Financial Crisis Resembles Japan’s 'Lost Decade' - And How to Play it
- How the U.S. Financial Crisis Resembles Japan’s 'Lost Decade' - And How to Play It, Part II
- How High Leverage Has Brought Down the Whole Banking Industry
- These Days, Preferred Stocks Are Anything But Dull
- Free the Frozen Fed!
- Full list of Editor's Picks »
- Gas Lines Coming This Fall »
- Suncor, US Bancorp and MasterCard: Using a Stop Loss When Investing »
- Was That a Bottom? Should We Even Care? »
- Gold to Replicate Oil's Parabolic Move; 30-yr Treasury Yields to Soar »
- Earnings Preview: Citigroup »
- An In-Depth Look at Solar Stocks »
- You Knew the Short Squeeze Was Coming »
- The Oil Bubble Will Meet the Same Fate as Tech, Housing »
- The Death of Natural Gas »
- Apple Feels 'Max Pain' »
- Potash Heats Up: $1000 a Tonne? »
-
Long Ideas
-
Short Ideas
-
Cramer's Picks
- Majority of Americans Support Ethanol
- Thinking About Currency ETFs and Sovereign Debt
- ETF Pick of the Week: ProShares UltraShort Oil & Gas
- Google Proves Mortal: Opportunity Knocks?
- Amazon: New Kindle To Tap $5.5 Billion Textbook Market?
- Blockbuster - Profiting More Than the Profiteers
- Coal Stocks: Make Money in Picks and Shovels
- ConocoPhillips: Why the Sell-off?
- US Steel: Solid as They Come
- Two Water Transport Plays - Besides DryShips
- Full list of Long Ideas »
- The SEC's Campaign Against Naked Shorting: Misguided or Right On?
- The Oil Bubble Will Meet the Same Fate as Tech, Housing
- Why I'm Shorting Apple Ahead of Earnings
- The Best Safe-Haven Investments, and Some Potential Threats
- Do Tell, Intel - Fast Money Recap (7/15/08)
- Separate Abusive Short Sellers from Those Who Play by the Rules
- Lehman: The End Game
- Freddie, Fannie and the French Revolution- Fast Money Recap (7/14/08)
- Meredith Whitney Slams Wachovia: Actionable Short Opportunity
- Chipotle Mexican Grill: Beware of Value Trap
- Full list of Short Ideas »
- For Everything, Wind - Stop Trading! (7/17/08)
- Market Lunacy Provides Opportunity - Cramer's Lightning Round (7/17/08)
- Market Rotation Underway - Cramer's Mad Money (7/17/08)
- Cox Not Watching - Cramer's Stop Trading! (7/16/08)
- Buy Boring Gas and Oil - Cramer's Lightning Round (7/16/08)
- Bear Market Rally - Mad Money Recap (7/16/08)
- The Great American Sellout - Cramer's Stop Trading! (7/15/08)
- Natural Gas Will Stay - Cramer's Lightning Round (7/15/08)
- The Windex Will Clean Up - Cramer's Mad Money (7/15/08)
- Fearful Day for Financials - Stop Trading! (7/14/08)
- Full list of Cramers Picks »
Most Popular Feeds
-
ETFs
-
US Market
-
Long Ideas
-
Alt. Energy
- Full list of feeds »
Hedge Fund Jobs
Job Seekers:
- Search jobs by category
- Get job alerts by email or live feed
- Apply online
Employers
- See all recruitment options
- Get applications online or by email


