<?xml version="1.0" encoding="utf-8"?>
<feed version="0.3" xmlns="http://purl.org/atom/ns#" xmlns:dc="http://purl.org/dc/elements/1.1/" xml:lang="en">
  <title>Blood, Sweat and Tiers</title>
  <link rel="alternate" type="text/html" href="http://www.redhillconsulting.com.au/blogs/james/" />
  <modified>2006-10-08T00:40:42Z</modified>
  <tagline></tagline>
  <id>tag:www.redhillconsulting.com.au,2006:/blogs/james/2</id>
  <generator url="http://www.movabletype.org/" version="3.2">Movable Type</generator>
  <copyright>Copyright (c) 2006, james</copyright>
  <entry>
    <title>The Turth or a Comforting Lie?</title>
    <link rel="alternate" type="text/html" href="http://www.redhillconsulting.com.au/blogs/james/archives/2006/10/the_turth_or_a.html" />
    <modified>2006-10-08T00:40:42Z</modified>
    <issued>2006-10-08T10:28:38+10:00</issued>
    <id>tag:www.redhillconsulting.com.au,2006:/blogs/james/2.362</id>
    <created>2006-10-08T00:28:38Z</created>
    <summary type="text/plain">Long time no blog. I&apos;ve been distracted in recent months learning about non-geek stuff like investing in the stock market, which I may blog about at some point. But what has inspired me to pick up my virtual pen again...</summary>
    <author>
      <name>james</name>
      
      <email>james-keyword-myblog.9cc4ba@cathandjames.com</email>
    </author>
    <dc:subject>Agile</dc:subject>
    <content type="text/html" mode="escaped" xml:lang="en" xml:base="http://www.redhillconsulting.com.au/blogs/james/">
      <![CDATA[<p>Long time no blog. I've been distracted in recent months  learning about non-geek stuff like investing in the stock market, which I may blog about at some point. But what has inspired me to pick up my virtual pen again is the apparent mainstream rise in popularity of agile development. Bear in mind that I'm in Australia so your time lines may vary, but these days there are very large organisations stating agile development as a key aspiration and sending head hunters around about scrounging for anyone who can spell it correctly to lead them to the promised land.  Five years ago we relatively early adopters of eXtreme Programming would band together and tell each other stories of what a wonderful world it would be when major banks and telcos saw the light and changed their evil waterfall ways. Now it seems we may have gotten what we wished for and perhaps we should have been more careful.</p>

<p>Refer to <a href="http://www.martinfowler.com/bliki/AgileImposition.html">Martin Fowler's recent post</a> on how top-down imposition of agile is pretty un-agile by definition; he's far more calm and articulate then I am. But as someone who has seen agile succeed and fail, I thought I'd throw my opinion into the ring for a bit of perspective for the recently converted. The greatest success with which I have been involved personally was simply awesome. A true agile poster child project: the brochure for it would tell you that we estimated it almost perfectly, delivered it on time and on budget, have had so few bugs in two years of production use that you'd have several fingers left counting them digitally, and the system transformed the business in a truly fundamental way. And we're not talking about a small project here: 20 people all up for 18 months and several million dollars. This is all absolutely true. What the brochure would fail to mention most likely is that we clashed with several internal stakeholders to the point where I was excluded from the building for a week in the middle of the project, that we needed the best team of developers I've ever seen to pull it off, the best project manager I've ever seen, the best iteration manager, customer representative and analysts and we had to fight off any number of die-hard process nazis who did not share our value system of actually delivering something of value (think Vogons). The brochure would also fail to mention that the organisation that witnessed this startling occurrence was quite committed to hiding this anomalous project like an embarrassing relative; you see, we outsiders had been brought in as the third attempt at this project in three years, and were set up to fail. The brochure probably would not mention that either. </p>

<p>Where I've seen agile fail is quite simply when you don't have all of these things working for you. Like having a distracted customer who can't spend the time with the team. Like having developers who really don't care about the craftsmanship of their work. Like having analysts who just type requirements into documents without any actual analysis. Like testers who just do the happy scenarios because the other ones are too hard. Like having a project manager who focuses on avoiding failure rather than achieving success. The problem with agile is that any one of these can severely damage or even kill your project despite the health of the others.</p>

<p>So the good news is that agile can and does work. The bad news is that agile can and does fail. So what are you to do? Looking back on that successful project, what made it work was, unfortunately, probably the same old things that have made any project work in any human endeavour since human endeavours began; highly skilled and committed people who bust a gut, put their necks on the line and get really lucky as well. And guess what? If you took these circumstances and did waterfall, you'd be just fine.  What agile is great at is failing fast and eliminating waste. The feedback cycles are there to detect and correct the course of the project almost as soon as it starts. I'm not sure how common this expression is, but when someone asks you a question to which the true answer will be very upsetting for them, the initial response is often, "Do you prefer the truth or a comforting lie?" That successful project had been estimated prior to my team's arrival. When we took a look, our estimate was 3.5 times higher and the duration was twice as long. We had extreme pressure to just hide our estimate and do the typical budget blowout thing later on. Not doing so and being honest nearly killed the project before it started. Agile is for those who can handle the truth; waterfall is for those who prefer the comforting lie. Either one may be right for you and your organisation. </p>]]>
      
    </content>
  </entry>
  <entry>
    <title>Speed Read With Your Eyes Shut</title>
    <link rel="alternate" type="text/html" href="http://www.redhillconsulting.com.au/blogs/james/archives/2006/05/speed_read_with.html" />
    <modified>2006-05-27T14:12:51Z</modified>
    <issued>2006-05-28T00:01:01+10:00</issued>
    <id>tag:www.redhillconsulting.com.au,2006:/blogs/james/2.324</id>
    <created>2006-05-27T14:01:01Z</created>
    <summary type="text/plain">Q: What do you get when you cross: * your Mac * your ipod * Project Gutenberg, my favourite source of great literature in goold old single-file ASCII text * Cepstral William, the sexiest robot text-to-speech voice around, and *...</summary>
    <author>
      <name>james</name>
      
      <email>james-keyword-myblog.9cc4ba@cathandjames.com</email>
    </author>
    <dc:subject>General Geek Stuff</dc:subject>
    <content type="text/html" mode="escaped" xml:lang="en" xml:base="http://www.redhillconsulting.com.au/blogs/james/">
      <![CDATA[<p>Q: What do you get when you cross:</p>

<p>* your Mac<br />
* your ipod<br />
* <a href="http://www.gutenberg.org/">Project Gutenberg</a>, my favourite source of great literature in goold old single-file ASCII text<br />
* <a href="http://www.cepstral.com/demos/">Cepstral William</a>, the sexiest robot text-to-speech voice around, and<br />
* <a href="http://www.rogueamoeba.com/audiohijackpro/">Audio Hijack Pro</a> to capture whatever William says and turn it into bookmarkable mp3 files to put on your ipod...?</p>

<p>A: A supply of the world's best audiobooks that will last longer than you will, that you can take anywhere with you, enjoy with your feet up and your eyes closed (unless you're driving, of course). But not only that, unlike a normal audiobook that you might buy from <a href="http://www.audible.com">Audible</a>, you can crank the speed up to whatever your brain can handle! Speed reading with your eyes shut. Cool.</p>]]>
      
    </content>
  </entry>
  <entry>
    <title>Joining the Rails fashion set</title>
    <link rel="alternate" type="text/html" href="http://www.redhillconsulting.com.au/blogs/james/archives/2006/04/joining_the_rai.html" />
    <modified>2006-04-25T00:51:57Z</modified>
    <issued>2006-04-25T10:18:55+10:00</issued>
    <id>tag:www.redhillconsulting.com.au,2006:/blogs/james/2.315</id>
    <created>2006-04-25T00:18:55Z</created>
    <summary type="text/plain">Last weekend Simon and Stuart The Blogless and I joined the fashion set by putting our first Rails application into production. It&apos;s a real estate web site for a beautiful part of Australia called the Southern Highlands (about an hour...</summary>
    <author>
      <name>james</name>
      
      <email>james-keyword-myblog.9cc4ba@cathandjames.com</email>
    </author>
    <dc:subject>General Geek Stuff</dc:subject>
    <content type="text/html" mode="escaped" xml:lang="en" xml:base="http://www.redhillconsulting.com.au/blogs/james/">
      <![CDATA[<p>Last weekend <a href="http://www.redhillconsulting.com.au/blogs/simon">Simon</a> and Stuart The Blogless and I joined the fashion set by putting our first Rails application into production. It's a real estate web site for a beautiful part of Australia called the Southern Highlands (about an hour from Sydney). You can visit <a href="http://www.campbelljonesproperty.com.au">Campbell Jones Property</a> for a look if you like. </p>

<p>A few features of the site:<br />
* the constrained box design was chosen by the client so don't blame me!<br />
* funky interactive map on <a href="http://www.campbelljonesproperty.com.au/buy/search">the search page</a> - go Stuart!<br />
* little ajaxy forms to submit feedback without doing page refreshes<br />
* main image on <a href="http://www.campbelljonesproperty.com.au/buy/property_listing/141/main">the property listing page</a> changes as you hover over the thumbnails<br />
* client-side scrolling of bio information on <a href="http://www.campbelljonesproperty.com.au/sell/meet_our_team">the meet the team page</a></p>

<p>A few 'behind the scenes' things:<br />
* all the images are in a <a href="http://www.postgresql.org">Postgres</a> database but are cached by Rails as they are used<br />
* images are uploaded in hi-res by the client and crunched on the server using <a href="http://www.imagemagick.org/">ImageMagick</a> to generate the various form factors required for the site - a real time saver for the client<br />
* lots of admin screens for updating listings, team members, etc</p>

<p>A few lessons learned as a J2EE guy working on his first Rails app:<br />
* Rails makes the backend stuff so easy that the pain in the butt becomes all about the HTML and CSS - by far the most painful part on such a pixel-perfect design like this. Normally on a J2EE app you don't notice because everything is that painful!<br />
* Postgres rocks<br />
* Rails caching is very cool. The site warms up nicely<br />
* database migrations are good but you can't sustain writing them using model objects if your model is changing (which it will). So you're basically writing SQL for migrations, but that's ok<br />
* some of the Rails association stuff is a bit weird, but the worst thing is some of the 'silent failures' you get when saving related records. Never a good idea.<br />
* some of the Rails plugins are a bit naive. For example, acts_as_list, which lets a model include positional ordering, doesn't let you put a UNIQUE constraint in the database for the position column as the update code is not transactional. Hope to find some time to fix that one.<br />
* Rails routes rock</p>

<p>So what's the conclusion about Rails? Is it perfect? Hell, no! Is it productive? Hell, yes! Does it beat the J2EE stack for database-backed web apps? By a country mile. I will not choose J2EE over Rails to build such an application, that's for sure. To be honest, it feels a little like the Mac/Windows discussions I find myself having reasonably regularly. To say something is way better than something else does not mean the thing is perfect. It just means it's better. Rails is like that - it's not perfect, it's just way better. I sincerely hope that Rails does not go mainstream or we'll all have to go find something else to be our competitive advantage. May the industry behemoths ignore Rails for many years to come!</p>]]>
      
    </content>
  </entry>
  <entry>
    <title>The &apos;Things That S**t Me&apos; List</title>
    <link rel="alternate" type="text/html" href="http://www.redhillconsulting.com.au/blogs/james/archives/2006/04/the_things_that.html" />
    <modified>2006-04-16T13:34:26Z</modified>
    <issued>2006-04-16T17:59:49+10:00</issued>
    <id>tag:www.redhillconsulting.com.au,2006:/blogs/james/2.312</id>
    <created>2006-04-16T07:59:49Z</created>
    <summary type="text/plain">As a card-carrying member for several years of the cult of &apos;Getting Things Done&apos;, a way of running one&apos;s life that has proven hugely beneficial, I find that every year or so I tweak and extend the system in an...</summary>
    <author>
      <name>james</name>
      
      <email>james-keyword-myblog.9cc4ba@cathandjames.com</email>
    </author>
    <dc:subject>Personal</dc:subject>
    <content type="text/html" mode="escaped" xml:lang="en" xml:base="http://www.redhillconsulting.com.au/blogs/james/">
      <![CDATA[<p>As a card-carrying member for several years of the cult of <a href="http://www.davidco.com/">'Getting Things Done'</a>, a way of running one's life that has proven hugely beneficial, I find that every year or so I tweak and extend the system in an effort to make it work better. For example, I've tried several different computerised systems to implement the GTD methodology, from <a href="http://www.thebrain.com">Personal Brain</a> to <a href="http://shared.snapgrid.com/gtd_tiddlywiki.html">GTD Tiddlywiiki</a> to <a href="http://www.mindjet.com">Mind Manager</a>. My latest incarnation is some hand-written shell scripts using a command line (bash shell) that runs on both Mac and PC and is super-fast to use. I'll blog about this in more detail some time soon.</p>

<p>But now I have stumbled across an enhancement to the methodology itself. If you're not familiar with it, it's basically a personal workflow system wit major steps: collect, process, organise, review, do. At first it's hard to get your head around how much work you have to do before you do any work! There are also several defined lists that you maintain, such as agendas for each person you interact with regularly, a list of things you're waiting for others to do, a 'someday maybe' list, next actions lists organised by context (such as home, work, online, travelling, out and about) etc, etc. The idea is that you capture everythhing (and I do mean everything), review it regularly and enable yourself to notch forward on many fronts in small increments in a context-optimised way just like a multitasking operating system.</p>

<p>So I offer to the GTD community my personal recommendation to maintain a 'things that shit me' list. Keep it up to date, capture new things into it often, review it every week, and use it as inspiration to make improvements. If you think I'm being flippant, think again. When you're angry, frustrated, stressed,or otherwise unhappy and the solution isn't immediately apparent, it's an effective short circuit just to name it, look at it next to all the other things that drive you nuts, and choose when you have the energy and time to pick some of them to turn into projects in your GTD system for improving your life. There is a very good feeling when you delete something from this list, let me tell you, and that's the real key. It's a smell if all you ever do is add to it, so make sure you pat yourself on the back each week by knocking something off your 'things that shit me' list. You'll be a nicer person to be around and that is probably the biggest benefit of all.</p>

<p>I assume you're interested in an example, so here's an excerpt from my current 'things that shit me' list:</p>

<p>The leaves in the skylight in the kitchen<br />
I don't have enough storage space in the office at home<br />
my house keys don't open the side door<br />
the way my phone only starts telling you the battery is low when it has a minute of life left<br />
I can't use my little dictaphone in bright sunlight 'cos I can't read the screen<br />
the tree that overhangs the carport<br />
I haven't figured out how to do my fortnightly trips with just a backpack<br />
you can't get clip-on sunnies for my glasses<br />
I'm not set up to scan things conveniently at home or at work<br />
the handrail in the bathroom keeps falling off<br />
the laundry door leaked in the last big storm we had<br />
I never have time to play the drums<br />
theres piles of mysterious crap in my book case<br />
i am notsure if priorities in my gtd system should be related to projects or actions<br />
i get so much comment spam on my blog<br />
moving around the screen on the mac when the zoom is on is too slow<br />
i cant print on my home printer when i'm connected to the vpn<br />
the plumbago outt the front is out of control<br />
wikiwords seems to have been turned off in the wiki<br />
ruby barking drives us mad<br />
the hard drive on the mac is just about full<br />
i do not have a functional tickler file at least electronically<br />
i have no way to track how much support work we're doing versus project work<br />
we don't use a single issue tracking system<br />
i can't print from the mac on my home network</p>]]>
      
    </content>
  </entry>
  <entry>
    <title>A Revised National Anthem for Australia</title>
    <link rel="alternate" type="text/html" href="http://www.redhillconsulting.com.au/blogs/james/archives/2006/03/a_revised_natio.html" />
    <modified>2006-03-23T11:20:13Z</modified>
    <issued>2006-03-23T21:18:06+10:00</issued>
    <id>tag:www.redhillconsulting.com.au,2006:/blogs/james/2.309</id>
    <created>2006-03-23T11:18:06Z</created>
    <summary type="text/plain">To celebrate the 10th anniversary of the most pathetic government in Australia&apos;s history (I mean, really, how you can keep a straight face sending troops to Iraq while funding the Iraqi regime via the AWB and locking up those who...</summary>
    <author>
      <name>james</name>
      
      <email>james-keyword-myblog.9cc4ba@cathandjames.com</email>
    </author>
    <dc:subject>Personal</dc:subject>
    <content type="text/html" mode="escaped" xml:lang="en" xml:base="http://www.redhillconsulting.com.au/blogs/james/">
      <![CDATA[<p>To celebrate the 10th anniversary of the most pathetic government in Australia's history (I mean, really, how you can keep a straight face sending troops to Iraq while funding the Iraqi regime via the AWB and locking up those who flee the chaos and seek asylum with no legal recourse is quite beyond me), I hereby present a revised national anthem in Little Johnny's honour. Just in time for the happily frequent renditions at the Commonwealth Games:</p>

<h3>"Advance Whose Skin Is Fair"</h3>
by James Ross

<p>Australians all let us rejoice<br />
For we are rich and white<br />
With golden soil and lust for oil<br />
We reckon she'll be right<br />
Our land abounds in nature's gifts<br />
We've never learned to share<br />
In history's page let every stage<br />
Advance whose skin is fair</p>

<p>Beneath our radiant southern cross<br />
We'll toil with hearts and hands<br />
To make sure noone different<br />
Sets foot upon our lands<br />
For those who come across the sea<br />
We've prison cells to spare<br />
With courage let us all combine to<br />
advance whose skin is fair<br />
In joyful strains then let us sing<br />
advance whose skin is fair</p>

<p>Copyright &copy; 2006 James Ross. All Rights Reserved. Of course. This machine kills fascists.</p>

<p>We now return you to your regularly scheduled program of agile software development....</p>]]>
      
    </content>
  </entry>
  <entry>
    <title>Signal to Noise Ratio in Rails</title>
    <link rel="alternate" type="text/html" href="http://www.redhillconsulting.com.au/blogs/james/archives/2005/12/signal_to_noise.html" />
    <modified>2005-12-24T00:27:40Z</modified>
    <issued>2005-12-24T10:24:24+10:00</issued>
    <id>tag:www.redhillconsulting.com.au,2005:/blogs/james/2.300</id>
    <created>2005-12-24T00:24:24Z</created>
    <summary type="text/plain">Like all the other Mac-toting fashion hounds, I&apos;ve been playing with Ruby on Rails of late. I have the good fortune of having a buddy who has a paying gig building a Rails site and he is kind enough to...</summary>
    <author>
      <name>james</name>
      
      <email>james-keyword-myblog.9cc4ba@cathandjames.com</email>
    </author>
    <dc:subject>Java</dc:subject>
    <content type="text/html" mode="escaped" xml:lang="en" xml:base="http://www.redhillconsulting.com.au/blogs/james/">
      <![CDATA[<p>Like all the other Mac-toting fashion hounds, I've been playing with Ruby on Rails of late. I have the good fortune of having a buddy who has a paying gig building a Rails site and he is kind enough to give me commit rights so I can use it in a meaningful way without giving up my day job as a J2EE guy, and without having to find an excuse to use it at work.</p>

<p>Without getting all hysterical about it, there are many things in Rails that should give pause to the J2EE crowd. When I switched from C++ to Java, the thing I liked most about coding in Java was the much improved signal-to-noise ratio compared with C++. I found I spent much less time thinking about computer stuff and much more time thinking about the problem at hand and the concepts of the problem space, largely ignoring the problems of the implementation  space. This was partly the language, partly the libraries, and partly the community around Java at the time, but when you add it all up, the result was better software faster, which is really all I want.</p>

<p>Now, having used the classic J2EE stack for a while (Struts/Tiles/Hibernate, et al), and having watched J2EE vendors bloat their products to the point of collapse, using Rails has given me the same feeling. No struts-config.xml, no tiles-defs.xml, no *.hbm.xml files, and much less time thinking about the machine and its implementation layers. The signal-to-noise ratio is simply better than in the form of J2EE I've learned. Ruby/Rails also appear to have the libraries and the community to make the whole stack work. The whole setup feels more supple and malleable than Java, and, since that feeling was what attracted me to Java, that has to be a concern for those who think Java is some kind of universal maximum, rather than just a local one, as all technologies are.</p>

<p>There are some things in Rails about which I retain mixed feelings.  ActiveRecord seems to me to be less of an O/R mapping layer, and more of an O/R unification layer. This caused me severe brain ache for a while, but I'm suspending disbelief for the moment. The unit testing model involves database access (and lots of it), which is a definition of unit testing I've always disliked strongly. The functional testing model (so far as I have looked) doesn't use a model based on parsing and filling out and submitting the HTML forms served by the running application. It appears to be more a controller-testing setup than what I would call a functional testing setup. But I'm only a newbie and might have missed some stuff.</p>]]>
      
    </content>
  </entry>
  <entry>
    <title>Brain Fade?</title>
    <link rel="alternate" type="text/html" href="http://www.redhillconsulting.com.au/blogs/james/archives/2005/11/brain_fade.html" />
    <modified>2005-11-22T00:46:43Z</modified>
    <issued>2005-11-22T10:31:49+10:00</issued>
    <id>tag:www.redhillconsulting.com.au,2005:/blogs/james/2.293</id>
    <created>2005-11-22T00:31:49Z</created>
    <summary type="text/plain">How can the most important application I have be so neglected by its creators? I&apos;ve been waiting a year and a half for a new version of Personal Brain and this is what I get - half a dozen fixes...</summary>
    <author>
      <name>james</name>
      
      <email>james-keyword-myblog.9cc4ba@cathandjames.com</email>
    </author>
    <dc:subject>General Geek Stuff</dc:subject>
    <content type="text/html" mode="escaped" xml:lang="en" xml:base="http://www.redhillconsulting.com.au/blogs/james/">
      <![CDATA[<p>How can the most important application I have be so neglected by its creators? I've been waiting a year and a half for a new version of <a href="http://www.thebrain.com">Personal Brain</a> and<a href="http://www.thebrain.com/products/personalbrain/support/whatsnew.html"> this is what I get</a> - half a dozen fixes to bugs I hadn't noticed and not a single new feature. One of the highlights is that they've updated their phone number because they moved offices! I don't know if this company is starved for resources, but if ever there was a company that deserves some, this is it. I hope I don't jinx them and they get snapped up by Microsoft and ruined, but this slow death is possibly worse!</p>]]>
      
    </content>
  </entry>
  <entry>
    <title>The iTunes Music Chore</title>
    <link rel="alternate" type="text/html" href="http://www.redhillconsulting.com.au/blogs/james/archives/2005/11/the_itunes_musi.html" />
    <modified>2005-12-08T11:10:29Z</modified>
    <issued>2005-11-09T21:19:53+10:00</issued>
    <id>tag:www.redhillconsulting.com.au,2005:/blogs/james/2.291</id>
    <created>2005-11-09T11:19:53Z</created>
    <summary type="text/plain">When I heard the iTunes Music Store was finally open in Australia, I was keen to try it out. It was easy to use as you&apos;d expect, but the lackk of many of the artists I was searching for was...</summary>
    <author>
      <name>james</name>
      
      <email>james-keyword-myblog.9cc4ba@cathandjames.com</email>
    </author>
    <dc:subject>Macintosh</dc:subject>
    <content type="text/html" mode="escaped" xml:lang="en" xml:base="http://www.redhillconsulting.com.au/blogs/james/">
      <![CDATA[<p>When I heard the <a href="http://www.apple.com/au/itunes/">iTunes Music Store was finally open in Australia</a>, I was keen to try it out. It was easy to use as you'd expect, but the lackk of many of the artists I was searching for was disappointing. Apparently Sony/BMG aren't playing ball with Apple. But anyway, they had <a href="http://www.paulkelly.com.au/">Paul Kelly's new album</a> so I clicked away my seventeen bucks and tried it out. 'Click' is the operative word here, 'cos that's what I got. Don't get me wrong, the album was great, and the whole purchasing experience was a breeze, but I can do without the digital pops and burps scattered throughout every damned track! I burned a CD of it and they're on it as well. Totally bummed at this experience, I guess Apple should take note that my first thought was to tell the world how crap it was before even calling them to complain. </p>

<p>So in an effort to find some of the artists that were lacking and to try out the competition to see if they could do any better, I headed on over to <a href="http://www.bigpondmusic.com/">Bigpond Music</a>, which has been around for a bit but I never bothered trying. A nice web 2.0 interface, by the way. Now the deal here is that it's a Windows-only system (boo!) that uses the DRM capabilities of Windows Media Player to manage the licensing process. So I left the Powerbook for a minute and clicked away a morre comfortable fifteen bucks to see what <a href="http://www.alexlloyd.com/">Alex Lloyd's new album</a> is like. Astute readers will notice it's only Australian musiic involved here - I can get your yankee junk on bit torrent and still sleep. That's a joke, by the way (also of an Australian variety)</p>

<p>Twenty minutes later and I had an absolutely pristine, fart-free version of some fine Aussie rock with which I am well pleased. I can even burn a CD and rip it into iTunes where it belongs.  Oops. Did I say that out loud?</p>

<p>So as much as it pains me to say it, the Apple experience was not one I am likely to repeat in a hurry. Bummer.</p>

<p>Updated 2005-12-4: Apple got back to me after three and a half weeks to say they were looking into it and were planning to refund the purchase of the album. So I still don't have Paul Kelly's new album like I'm supposed to. Makes a visit to the bricks and mortar store look quite attractive at this point.</p>]]>
      
    </content>
  </entry>
  <entry>
    <title>Now we&apos;re cooking</title>
    <link rel="alternate" type="text/html" href="http://www.redhillconsulting.com.au/blogs/james/archives/2005/10/now_were_cookin.html" />
    <modified>2005-10-28T12:55:58Z</modified>
    <issued>2005-10-28T22:40:54+10:00</issued>
    <id>tag:www.redhillconsulting.com.au,2005:/blogs/james/2.287</id>
    <created>2005-10-28T12:40:54Z</created>
    <summary type="text/plain">I&apos;ve only recently started using a laptop all day every day, so I thought it was time to put to use a trick shown to me by some buddies for making the all-day laptop experience a lot more ergonomic. So...</summary>
    <author>
      <name>james</name>
      
      <email>james-keyword-myblog.9cc4ba@cathandjames.com</email>
    </author>
    <dc:subject>General Geek Stuff</dc:subject>
    <content type="text/html" mode="escaped" xml:lang="en" xml:base="http://www.redhillconsulting.com.au/blogs/james/">
      <![CDATA[<p>I've only recently started using a laptop all day every day, so I thought it was time to put to use a trick shown to me by some buddies for making the all-day laptop experience a lot more ergonomic. So a quick trip to the homewares store for a cook book stand, and bingo! You've got the screen at eye level. Check out the picture for an idea of how it works. You need to invest in an external keyboard and mouse, of course, but it's the poor man's docking station. Start a fashion trend in your cube farm today!</p>

<p><img alt="cooking.jpg" src="http://www.redhillconsulting.com.au/blogs/james/archives/cooking.jpg" /></p>]]>
      
    </content>
  </entry>
  <entry>
    <title>Flat Out in First</title>
    <link rel="alternate" type="text/html" href="http://www.redhillconsulting.com.au/blogs/james/archives/2005/10/flat_out_in_fir.html" />
    <modified>2005-10-27T08:07:53Z</modified>
    <issued>2005-10-27T18:05:54+10:00</issued>
    <id>tag:www.redhillconsulting.com.au,2005:/blogs/james/2.286</id>
    <created>2005-10-27T08:05:54Z</created>
    <summary type="text/plain">Imagine you&apos;re driving from one side of the city to the other with a friend and you&apos;re in a big hurry. You&apos;re running really late and you&apos;re desperate to get where you&apos;re going. To your amazement, your friend sets off...</summary>
    <author>
      <name>james</name>
      
      <email>james-keyword-myblog.9cc4ba@cathandjames.com</email>
    </author>
    <dc:subject>Agile</dc:subject>
    <content type="text/html" mode="escaped" xml:lang="en" xml:base="http://www.redhillconsulting.com.au/blogs/james/">
      <![CDATA[<p>Imagine you're driving from one side of the city to the other with a friend and you're in a big hurry. You're running really late and you're desperate to get where you're going. To your amazement, your friend sets off down the road and puts the pedal to the metal in first gear. He's gripping the wheel, concentrating fiercely, the engine is screaming, and you're being overtaken by every car on the road, doing about 30kph. </p>

<p>You say to your friend, "Hey, don't you want to go into second gear?"</p>

<p>But your friend says, "Don't interrupt me, man, I'm going as fast as I can and I really need to concentrate here"</p>

<p>You try again. "But we'll get there faster if you change gears!"</p>

<p>But your friend says, "No we won't! I tried that before and putting in the clutch __definitely__ slows you down, silly! And the last thing I can do now is slow down when we're running so late!"</p>

<p>The problem with development teams is that you can't actually hear the engine screaming and see the car shaking and feel the lack of speed. But it seems to me a lot of development teams are flat out in first gear. Agile development has a lot of practices that are all about changing gears.<br />
</p>]]>
      
    </content>
  </entry>
  <entry>
    <title>An Agile Requirements Parable</title>
    <link rel="alternate" type="text/html" href="http://www.redhillconsulting.com.au/blogs/james/archives/2005/10/an_agile_requir.html" />
    <modified>2005-10-22T05:16:04Z</modified>
    <issued>2005-10-22T15:14:23+10:00</issued>
    <id>tag:www.redhillconsulting.com.au,2005:/blogs/james/2.285</id>
    <created>2005-10-22T05:14:23Z</created>
    <summary type="text/plain">In my current role I&apos;m trying to introduce agile development into a team of about 30 people. One of the challenges is the approach to requirements. The incumbent process is pretty standard waterfall with requirements documents that are both too...</summary>
    <author>
      <name>james</name>
      
      <email>james-keyword-myblog.9cc4ba@cathandjames.com</email>
    </author>
    <dc:subject>Agile</dc:subject>
    <content type="text/html" mode="escaped" xml:lang="en" xml:base="http://www.redhillconsulting.com.au/blogs/james/">
      <![CDATA[<p>In my current role I'm trying to introduce agile development into a team of about 30 people. One of the challenges is the approach to requirements. The incumbent process is pretty standard waterfall with requirements documents that are both too big to read and too short to be used as the only input for development, as well as being written from an implementation perspective rather than a user perspective. As well as being written up front in their entirety before coding begins. So no news here.</p>

<p>But the biggest issue is (as usual) not a technical one but a human one, in this case the implicit belief that requirements can be 'captured' if you just think hard enough (and long enough) as opposed to the agile view that requirements need to be trawled for constantly, starting at a high level and increasing the resolution as implementation approaches, leaving the resolution lower for far-off things. </p>

<p>I unwittingly stumbled on a requirements parable the other day when, of all things, I attempted to buy a new pen. I succeeded in purchasing a pen, but I failed to get one that met all my requirements. I'm serious; I couldn't even buy a pen for myself that satisfied all my requirements. Read on if you are still on your chair.</p>

<p>So, why did I need this pen? I carry around a pocket notebook and a pen wherever I go, having learned from experience that freeing my brain from minutiae leaves it free to dream and create.  I've tried other tools, PDA's, dictaphones, etc, but the good old pen and notebook just works. The definition of 'works' here is that the time and effort between being confronted with something that I need to remember but that I don't want to deal with emmediately must be minimised. I even have a kind of code for the notes I take to speed it up, and recently spent half an hour in a stationery shop buying just the right notebook (with high end features like one of those built in straps to mark your page). So I'm pretty serious about this pen. It has to be able to be connected to the notebook firmly so they can't be separated accidentally, and it has to have a broad enough point that my dim eyes can see what I've written.</p>

<p>So how did I go wrong? Well, the pen I've used for a long time started to become unreliable, so I had to replace it. It literally did not occur to me that the fact it was one of those ones that you press the top to extend the ballpoint was important. I was thinking maybe I'd try a felt tip pen rather than a ballpoint as the nibs come in wider formats.  So I looked at the mountains of pens in the store and picked a broad-nib felt tip number with a clip that attached snugly to my notebook. So how long did it take to realise my error? The first thought I had that I wanted to write down, I pulled the unit out of my pocket, separated the pen and instinctively went to push the button to extend the ballpoint with one hand while flipping to the current page with the other. Only there was no button. There was a cap! That requires two hands (or one hand far more dextrous than mine) to pull off and put somewhere else, probably on the butt of the body of the pen. I was stupefied. I was now thinking about the damned pen and not the brilliant idea I'd just had.. If there is something you just want to stay out of your way, it's the thing between you and your great ideas.</p>

<p>So what's the moral of the story? I guess it's something like this: Assuming you are capable of defining requirements up front without exposing users to the solution is bogus. Even if the system is well established. Even if it's as simple as a pen. Even if you're so clever that you can read the customer's mind. :P</p>]]>
      
    </content>
  </entry>
  <entry>
    <title>Back in the iLife</title>
    <link rel="alternate" type="text/html" href="http://www.redhillconsulting.com.au/blogs/james/archives/2005/09/back_in_the_ili.html" />
    <modified>2005-09-03T12:04:46Z</modified>
    <issued>2005-09-03T22:02:11+10:00</issued>
    <id>tag:www.redhillconsulting.com.au,2005:/blogs/james/2.275</id>
    <created>2005-09-03T12:02:11Z</created>
    <summary type="text/plain">When I started my new job a few weeks ago, I had to wait a while before my new laptop arrived from Dell. So I turned up on the first day with my Powerbook and plugged in. I was very...</summary>
    <author>
      <name>james</name>
      
      <email>james-keyword-myblog.9cc4ba@cathandjames.com</email>
    </author>
    <dc:subject>Personal</dc:subject>
    <content type="text/html" mode="escaped" xml:lang="en" xml:base="http://www.redhillconsulting.com.au/blogs/james/">
      <![CDATA[<p>When I started my new job a few weeks ago, I had to wait a while before my new laptop arrived from Dell. So I turned up on the first day with my Powerbook and plugged in. I was very pleased to find that Apple Mail knows all about Exchange servers out of the box, so I was up and running with no problems and went on happily for a couple of weeks. When the Dell arrived, I spent a couple of days with both machines on the desk while getting it all set up. It was only after switching the Mac back to home use mode and starting to use the Dell for work that I was struck by an obvious solution to a problem I'd been facing for a long time. One of the reasons I switched jobs was in pursuit of a better work/life balance. To me this means drawing a sharper line between the two something I've struggled with in recent years. And here I was looking at the solution: use one computer for work and another for life. Sounds simple, but I missed it until now. So now the Dell stays off over the weekend (it stays on long enough to check the week's work in to CVS at home), and doesn't get looked at until Monday morning. The Mac, with photos, videos, electronic books, music software and fun geek stuff like Ruby and Objective C stays on all weekend and is nothing but fun. Nice.</p>]]>
      
    </content>
  </entry>
  <entry>
    <title>It&apos;s Mac time now...for my old man</title>
    <link rel="alternate" type="text/html" href="http://www.redhillconsulting.com.au/blogs/james/archives/2005/08/its_mac_time_no.html" />
    <modified>2005-09-01T23:38:49Z</modified>
    <issued>2005-08-18T16:18:44+10:00</issued>
    <id>tag:www.redhillconsulting.com.au,2005:/blogs/james/2.262</id>
    <created>2005-08-18T06:18:44Z</created>
    <summary type="text/plain">It&apos;s been a while since I blogged at all, having been a little busy switching jobs, having recently also switched computers (to a Mac Powerbook) and having tried to switch programming languages (learning some Objective C, which is lots of...</summary>
    <author>
      <name>james</name>
      
      <email>james-keyword-myblog.9cc4ba@cathandjames.com</email>
    </author>
    <dc:subject>Personal</dc:subject>
    <content type="text/html" mode="escaped" xml:lang="en" xml:base="http://www.redhillconsulting.com.au/blogs/james/">
      <![CDATA[<p>It's been a while since I blogged at all, having been a little busy switching jobs, having recently also switched computers (to a Mac Powerbook) and having tried to switch programming languages (learning some Objective C, which is lots of fun). But I'm convinced enough by my Mac experience to have convinced my dear old dad to jump as well (to a Mac Mini) on the demise of his old PC. So does that make me an official cult member? I've also started thinking that one of those flat panel iMacs will look pretty good next to the espresso machine for my wife and daughters to use......:P<br />
</p>]]>
      
    </content>
  </entry>
  <entry>
    <title>It (sort of) just works!</title>
    <link rel="alternate" type="text/html" href="http://www.redhillconsulting.com.au/blogs/james/archives/2005/06/it_sort_of_just.html" />
    <modified>2005-09-01T23:38:48Z</modified>
    <issued>2005-06-14T22:41:14+10:00</issued>
    <id>tag:www.redhillconsulting.com.au,2005:/blogs/james/2.257</id>
    <created>2005-06-14T12:41:14Z</created>
    <summary type="text/plain">A lot of my geek buddies have been switching to the Mac over the last 18 months or so, and with the new FBT year rolling around, I thought I&apos;d get a half-price PowerBook 15-inch with all the bells and...</summary>
    <author>
      <name>james</name>
      
      <email>james-keyword-myblog.9cc4ba@cathandjames.com</email>
    </author>
    <dc:subject>Macintosh</dc:subject>
    <content type="text/html" mode="escaped" xml:lang="en" xml:base="http://www.redhillconsulting.com.au/blogs/james/">
      <![CDATA[<p>A lot of my geek buddies have been switching to the Mac over the last 18 months or so, and with the new FBT year rolling around, I thought I'd get a half-price PowerBook 15-inch with all the bells and whistles to join in the fun. For those of you not in Australia (shame on you), there is a tax law here that allows anyone to buy a laptop each year with pre-tax dollars. This is a great deal (since our top tax rate is almost 50 percent) and is very popular as you might imagine.</p>

<p>Anyway, I'm showing my age by saying it's 19 years since I last had a Mac, so I knew things would have changed quite a bit in the meantime. I've been reading 'Mac OS X The Missing Manual' while waiting for my machine to arrive so I already had some of the keyboard shortcuts down before I had the box open. Which brings me to the first of my observations about the oft-repeated cries of "It just works" by the MacCult members...don't get me wrong, this little baby is a beautiful thing, but in the interests of full disclosure, I thought I'd jot down my notes on the switching experience...</p>

<p>Getting the machine delivered was something Apple found quite challenging. I ordered the PowerBook, MS Office, iWork, .mac and Logic Express, and they got off to a bad start by shipping the software individually so that a couple of times  when the courier's arrival at my house found nobody at home, they went away until we called them and could commit to waiting at home for a full day before they'd deliver. Not so bad for a single delivery, but when the order is part-shipped in four separate trips, this gets a bit old. Of course the software was no use without the machine, which didn't turn up at all. Problem was, the online order status page showed it as having been shipped many days ago. Several calls to the courier and Apple finally led to the discovery that the courier had returned it to Apple because the exterior box was slightly damaged in transit. Still no drama, except that Apple seemed to not have a process to keep it moving. I had to call them multiple times to get multiple people to find the box and ship it to me after testing that the machine was OK. Very annoying.</p>

<p>The machine arrived last Friday and with sweaty palms I fired it up. The warm, welcoming and soothing setup process came to a shuddering halt at the wireless network setup screen. No matter what I did, I could not get it to connect to my network. Now I know my 128-bit WEP key off by heart, so this should not be hard. Eventually I gave up in disgust and told it I didn't have a network at all. When I got into the OS proper, I found I had extra options, including to change its default WEP key size of 40 bits to the 128 I needed. Up and running immediately, but obviously unimpressed with the unnecessary dumbing down of the setup program.</p>

<p>A little later on, I cracked open my iWork 05 disc and stuck it in. Lo and behold, the machine refused to install the software because a later version was already installed on the machine. So I go hunting and find a trial version of iWork, which I start and am annoyed to find there is no 'enter the serial number from your boxed copy you just brought home from the store and I'll start working for you' option. So I drag the application to the trash, since that's what book said was all that was needed to uninstall an application. No dice. A call to a Mac buddy and a little Spotlight magic later and I find a couple of files in the /Library/Receipts folder, which has something to do with the auto-update feature for the software. Killing off the files and now I can install my software. This is software I bought with the machine, you realise. And the machine won't let me install it. This is not what I call 'It just works'</p>

<p>The rest of my installs go pretty much according to plan (after Office downloads the 50Mb of updates needed to actually get it to run properly). The only other disappointment was the Logic Express has not had the latest UI goodness like the rest of the apps that sport the Apple logo. They've done the box up nice, but the app must be one of those 'carbonised' ones they talk about.</p>

<p>Of course, before I could really start using the apps, I had to sort out the accessibility options. Being a visually impaired person, one of the things that tipped me to considering the Mac was the built in accessibility features, particularly the new VoiceOver software that speaks the UI to you as you use the machine. Annoying as all get out to anyone standing nearby, but pretty darn useful for me. In fact, as I type this, it's reading each word as I go. Overall, the software is good, and I can save the money I'd normally have to spend getting set up with specialist software, so I'm happy about that. It's got a few minor issues like jumping around a little crazily when the screen is magnified and the focus shifts, and not reading full paragraphs of text in Safari if they contain a (gasp!) hyperlink, but not too bad at all.</p>

<p>Things really started to crank when I got my head around expose, spotlight and some of the apps that come with it. iMovie is awesome in its elegance and simplicity and speed (I talk as someone who purchased Pinnacle video editing software for Windows) and iPhoto blew me away when I imported my six years worth of photos from its home in a nicely structured directory, and iPhoto turned the directory names into keywords that I can search, so 'Antonia's Wedding' instantly finds all the right pics. Awesome.</p>

<p>I find I'm not as productive when typing and editing text because I don't know all the keyboard shortcuts for selecting a word or a paragraph, but that will come with practice. It is true what they say that it just feels solid, and having a large number of apps open doesn't seem to have the same drag effect as it does in Windows. Now I just have to figure out how to replace all the apps I rely on like The Brain and Microsoft Money. I'm not in a great hurry as I invested in Virtual PC to ease the transition. I haven't actually used it yet, as I'm trying to just feel the vibe for now. And I must say it feels pretty gooood. I look forward to being snobbish and dismissive of my Windows colleagues very soon.</p>]]>
      
    </content>
  </entry>
  <entry>
    <title>Too busy to blog</title>
    <link rel="alternate" type="text/html" href="http://www.redhillconsulting.com.au/blogs/james/archives/2005/05/too_busy_to_blo.html" />
    <modified>2005-09-01T23:38:48Z</modified>
    <issued>2005-05-15T21:41:01+10:00</issued>
    <id>tag:www.redhillconsulting.com.au,2005:/blogs/james/2.255</id>
    <created>2005-05-15T11:41:01Z</created>
    <summary type="text/plain">Lately I&apos;ve been too busy to blog, as I&apos;ve been helping Simon write his first book. As far as we know, it&apos;s the first book on algorithms to use design patterns and TDD, but I could be wrong. Be sure...</summary>
    <author>
      <name>james</name>
      
      <email>james-keyword-myblog.9cc4ba@cathandjames.com</email>
    </author>
    <dc:subject>Personal</dc:subject>
    <content type="text/html" mode="escaped" xml:lang="en" xml:base="http://www.redhillconsulting.com.au/blogs/james/">
      <![CDATA[<p>Lately I've been too busy to blog, as I've been helping <a href="http://www.redhillconsulting.com.au/blogs/simon/">Simon</a> write <a href="http://tinyurl.com/cnwen">his first book</a>. As far as we know, it's the first book on algorithms to use design patterns and <a href="http://c2.com/cgi/wiki?TestDrivenDevelopment">TDD</a>, but I could be wrong. Be sure to buy your mum one for christmas...:P</p>

<p>Having finally succumbed to the weight of my geek buddies buying Macs, I've just ordered a new <a href="http://store.apple.com/1-800-MY-APPLE/WebObjects/AppleStore.woa/72102/wo/Qt6fjD2bLSqk2csDmVG19eXPxur/0.0.11.1.0.6.23.1.1.1.1.0.0.1.0">Powerbook</a>, so I reckon I'll be posting a bit about the experience. I've had to buy a copy of <a href="http://store.apple.com/1-800-MY-APPLE/WebObjects/AppleStore.woa/72102/wo/Qt6fjD2bLSqk2csDmVG19eXPxur/4.0.11.1.0.6.25.7.11.0.3">Virtual PC</a> to ease the switch, but I'd like to retire all my Windows apps if I can.</p>]]>
      
    </content>
  </entry>

</feed>