<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>My Zen Arcade &#187; software design</title>
	<atom:link href="http://myzenarcade.com/tag/software-design/feed/" rel="self" type="application/rss+xml" />
	<link>http://myzenarcade.com</link>
	<description>If you meet the Buddha on the road, shoot him with a rocket launcher</description>
	<lastBuildDate>Fri, 30 Apr 2010 00:18:05 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.8.4</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>Software Specifications</title>
		<link>http://myzenarcade.com/2008/10/31/software-specifications/</link>
		<comments>http://myzenarcade.com/2008/10/31/software-specifications/#comments</comments>
		<pubDate>Fri, 31 Oct 2008 14:33:12 +0000</pubDate>
		<dc:creator>moleboy</dc:creator>
				<category><![CDATA[Uncategorized]]></category>
		<category><![CDATA[my life]]></category>
		<category><![CDATA[software]]></category>
		<category><![CDATA[software design]]></category>

		<guid isPermaLink="false">http://myzenarcade.com/?p=272</guid>
		<description><![CDATA[Software specifications, when introduced for the first time to a company, can be a horrible thing. 
There&#8217;s the initial design of the specification document, who gets to write them, etc.
Process stuff.
But there&#8217;s a bigger problem.
The lie.
When a specification is written, and sent to development, it should be a static document.  Understandably, this isn&#8217;t always possible.  Not [...]]]></description>
			<content:encoded><![CDATA[<!-- sphereit start --><p>Software specifications, when introduced for the first time to a company, can be a horrible thing. </p>
<p>There&#8217;s the initial design of the specification document, who gets to write them, etc.</p>
<p>Process stuff.</p>
<p>But there&#8217;s a bigger problem.</p>
<p>The lie.</p>
<p>When a specification is written, and sent to development, it should be a static document.  Understandably, this isn&#8217;t always possible.  Not every company has the resources to do the kind of thorough design review best practices require, and during development you learn, change your mind, etc.  So, in a perfect world, a specification is static, but in the real world, not so much.</p>
<p>The problem is when a specification changes but the document doesn&#8217;t.  If you tell me to do A,B,C and then change it to A,B+1,C and don&#8217;t change the document, we are living a lie.  And mostly I&#8217;m worried about the damage the lie can do to me.  Really, I can&#8217;t win.  If I do what the designer ask, and it goes poorly, they go back to the document and see that what I did doesn&#8217;t match the specification.  If I go with the original document and it goes poorly, the designer can complain about how they made a change and just didn&#8217;t record it. </p>
<p>If a design specification document is not sacrosanct, then the developer has to work overtime keeping track of things so that when people come to complain, his ass is covered.</p>
<!-- sphereit end --><span style="margin-bottom:40px; border-bottom:none;"><a class="iconsphere" title="Sphere: Related Content" onclick="return Sphere.Widget.search('http://myzenarcade.com/2008/10/31/software-specifications/')" href="http://www.sphere.com/search?q=sphereit:http://myzenarcade.com/2008/10/31/software-specifications/">Sphere: Related Content</a></span><br/><br/>]]></content:encoded>
			<wfw:commentRss>http://myzenarcade.com/2008/10/31/software-specifications/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>
