<?xml version="1.0" encoding="UTF-8"?>
<?xml-stylesheet type="text/xsl" media="screen" href="/~d/styles/atom10titles.xsl"?><?xml-stylesheet type="text/css" media="screen" href="http://feeds.feedburner.com/~d/styles/itemtitles.css"?><feed xmlns="http://www.w3.org/2005/Atom" xmlns:openSearch="http://a9.com/-/spec/opensearch/1.1/" xmlns:blogger="http://schemas.google.com/blogger/2008" xmlns:georss="http://www.georss.org/georss" xmlns:gd="http://schemas.google.com/g/2005" xmlns:thr="http://purl.org/syndication/thread/1.0" xmlns:geo="http://www.w3.org/2003/01/geo/wgs84_pos#" xmlns:feedburner="http://rssnamespace.org/feedburner/ext/1.0" gd:etag="W/&quot;DkQESX49cSp7ImA9WhFTEUU.&quot;"><id>tag:blogger.com,1999:blog-30950679</id><updated>2013-06-02T07:45:08.069-07:00</updated><category term="resumes" /><category term="cvs" /><category term="continuous integration" /><category term="sql" /><category term="java" /><category term="spring" /><category term="tips" /><category term="bamboo" /><category term="security" /><category term="programming" /><category term="passwords" /><category term="oql" /><category term="interviews" /><category term="rants" /><category term="source control" /><category term="gwt" /><category term="ideas" /><category term="svn" /><category term="hiring" /><title>Regular Expressions</title><subtitle type="html">Now you have two problems.</subtitle><link rel="http://schemas.google.com/g/2005#feed" type="application/atom+xml" href="http://idcmp.linuxstuff.org/feeds/posts/default" /><link rel="alternate" type="text/html" href="http://idcmp.linuxstuff.org/" /><link rel="next" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default?start-index=26&amp;max-results=25&amp;redirect=false&amp;v=2" /><author><name>Idcmp</name><uri>http://www.blogger.com/profile/03829017208885409542</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><generator version="7.00" uri="http://www.blogger.com">Blogger</generator><openSearch:totalResults>47</openSearch:totalResults><openSearch:startIndex>1</openSearch:startIndex><openSearch:itemsPerPage>25</openSearch:itemsPerPage><atom10:link xmlns:atom10="http://www.w3.org/2005/Atom" rel="self" type="application/atom+xml" href="http://feeds.feedburner.com/idcmp" /><feedburner:info uri="idcmp" /><atom10:link xmlns:atom10="http://www.w3.org/2005/Atom" rel="hub" href="http://pubsubhubbub.appspot.com/" /><geo:lat>49.27</geo:lat><geo:long>-123.12</geo:long><feedburner:feedFlare href="http://add.my.yahoo.com/rss?url=http%3A%2F%2Ffeeds.feedburner.com%2Fidcmp" src="http://us.i1.yimg.com/us.yimg.com/i/us/my/addtomyyahoo4.gif">Subscribe with My Yahoo!</feedburner:feedFlare><feedburner:feedFlare href="http://feeds.my.aol.com/add.jsp?url=http%3A%2F%2Ffeeds.feedburner.com%2Fidcmp" src="http://o.aolcdn.com/favorites.my.aol.com/webmaster/ffclient/webroot/locale/en-US/images/myAOLButtonSmall.gif">Subscribe with My AOL</feedburner:feedFlare><feedburner:feedFlare href="http://www.bloglines.com/sub/http://feeds.feedburner.com/idcmp" src="http://www.bloglines.com/images/sub_modern11.gif">Subscribe with Bloglines</feedburner:feedFlare><feedburner:feedFlare href="http://www.netvibes.com/subscribe.php?url=http%3A%2F%2Ffeeds.feedburner.com%2Fidcmp" src="http://www.netvibes.com/img/add2netvibes.gif">Subscribe with Netvibes</feedburner:feedFlare><feedburner:feedFlare href="http://fusion.google.com/add?feedurl=http%3A%2F%2Ffeeds.feedburner.com%2Fidcmp" src="http://buttons.googlesyndication.com/fusion/add.gif">Subscribe with Google</feedburner:feedFlare><feedburner:feedFlare href="http://www.pageflakes.com/subscribe.aspx?url=http%3A%2F%2Ffeeds.feedburner.com%2Fidcmp" src="http://www.pageflakes.com/ImageFile.ashx?instanceId=Static_4&amp;fileName=ATP_blu_91x17.gif">Subscribe with Pageflakes</feedburner:feedFlare><feedburner:feedFlare href="http://www.addtoany.com/?linkname=Regular%20Expressions&amp;linkurl=http%3A%2F%2Ffeeds.feedburner.com%2Fidcmp&amp;type=feed" src="http://www.addtoany.com/addfr-b.gif">Add to Any Feed Reader</feedburner:feedFlare><feedburner:feedFlare href="http://www.fwicki.com/users/default.aspx?addfeed=http%3A%2F%2Ffeeds.feedburner.com%2Fidcmp" src="http://www.fwicki.com/images/ui/fwicki_clicklet.png">Subscribe with fwicki</feedburner:feedFlare><entry gd:etag="W/&quot;CEUBRX46fyp7ImA9WhVUGU0.&quot;"><id>tag:blogger.com,1999:blog-30950679.post-8921851002400761675</id><published>2012-05-24T16:28:00.001-07:00</published><updated>2012-05-24T16:30:54.017-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2012-05-24T16:30:54.017-07:00</app:edited><title>Navigation 2.0: The Missing Features</title><content type="html">I recently found myself driving a car in an unfamiliar city relying heavily on Google Navigation on my phone to get me from point A to point B (and back to point A again).  From this two week experience I found some things in the Navigation experience I'd really love to have.  Maybe other Navigation apps have this and I've just been googleblind.

&lt;h1&gt;Not Looking At The Phone&lt;/h1&gt;
Most of the time I'm driving, I'm relying on Navigation to tell me what's going on. You're probably the same. Some simple options would make me a lot more comfortable.  These also apply to when I'm on a motorbike and my phone is locked away in a pocket.

&lt;ol&gt;
&lt;li&gt;Don't tell me compass directions:  If I'm in a new city, in a new area telling me "Head East" is useless.  Especially at night where I can't use the Sun to figure out which way East is.&lt;/li&gt;

&lt;li&gt;Give me a hint which lane I should eventually be in, "Travel three kilometers, eventually turning left."&lt;/li&gt;

&lt;li&gt;If I'm driving for thirty minutes on a highway, periodically remind me that you haven't crashed or suddenly run out of battery power. Even a little beep every 10 minutes (or % of a leg) would be nice.  Maybe even tell me what % of battery is left.&lt;/li&gt;

&lt;li&gt;Along those lines, since Navigation knows how fast I'm going and how far I have to go, telling me "Continue for about 15 minutes." is more handy than "continue for 23 kilometers".&lt;/li&gt;

&lt;li&gt;On navigation start, tell me something useful; even "Route calculated" or "Estimated twenty minutes of travel time."&lt;/li&gt;

&lt;li&gt;If I'll have less than 10% battery life by the calculated arrival time, tell me this up front and give me the option to just read the list without actual navigation.&lt;/li&gt;

&lt;li&gt;It may annoy you, but I like to know when Navigation has changed its mind about where we're going.  Telling me that a route has been recalculated is re-assuring.&lt;/li&gt;
&lt;/ol&gt;

&lt;h1&gt;Tell Me Less&lt;/h1&gt;
There are some things where being quieter makes more sense:

&lt;ol&gt;
&lt;li&gt;Cut me some slack in a parking lot.  Unless you're going to tell me exactly how to get out of the parking lot, keep quiet until I'm close to an exit.  Calculate some routes of the closest few exits and get ready to tell me "Turn left here." or "Turn right here.".  Telling me to "Head North to 11th Ave South West going to 23rd Street East going East." is just distracting while I'm trying to navigate the maze of grocery carts and SUVs.&lt;/li&gt;


&lt;li&gt;Some cities have Main St. North, West, East, South or North East / North West / etc. &amp;nbsp;If I'm on "Main St North West" turning onto "1st Street North West", don't say "Northwest" both times. &amp;nbsp;In fact, unless I'm close to a boundary where it's important to know which cardinal direction of the street I'm on, simply saying "Turn left onto First Street." is fine.&lt;/li&gt;
&lt;/ol&gt;

&lt;h1&gt;Nicer Touches&lt;/h1&gt;
And there are a few nice things I bet wouldn't be too hard.

&lt;ol&gt;
&lt;li&gt;Traffic Lights.  I'm sure most cities have a database of which intersections have traffic lights.  Telling me "At the lights, turn left onto Third street." trumps "In six hundred and fifty meters turn left onto Third street.".&lt;/li&gt;

&lt;li&gt;Let me mark certain areas as "well known" areas and silence turn by turn directions if my destination is in that area unless I ask for them to be re-enabled.&lt;/li&gt;

&lt;li&gt;All major highways in Canada have numbered exits.  They're numbered based on kilometer distance.  If I'm at exit 35, and I'm going to exit 25, I know there's ten kilometers to go.  When I get on a highway, let me know the exit number I'm going to be exiting on.&lt;/li&gt;

&lt;li&gt;If I'm going to a destination that has a Google Place (or whatever they're called now), and it seems that they'll be closed or closing within an hour of the calculated arrival, give me an option to call the place.&lt;/li&gt;

&lt;li&gt;Let me tell Navigation how comfortable I am with a given city or area.  If I don't know it very well, give me notifications earlier and take me on possibly longer but easier to navigate routes.&lt;/li&gt;
&lt;/ol&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/idcmp?a=Gjze3oOwDWU:LmFGaiDCX2g:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/idcmp?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/idcmp/~4/Gjze3oOwDWU" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://idcmp.linuxstuff.org/feeds/8921851002400761675/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=30950679&amp;postID=8921851002400761675" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/8921851002400761675?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/8921851002400761675?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/idcmp/~3/Gjze3oOwDWU/driving-20-missing-features.html" title="Navigation 2.0: The Missing Features" /><author><name>Idcmp</name><uri>http://www.blogger.com/profile/03829017208885409542</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>0</thr:total><feedburner:origLink>http://idcmp.linuxstuff.org/2012/05/driving-20-missing-features.html</feedburner:origLink></entry><entry gd:etag="W/&quot;AkMDR306eip7ImA9WhRVEEQ.&quot;"><id>tag:blogger.com,1999:blog-30950679.post-2982789559133120227</id><published>2012-01-08T23:54:00.000-08:00</published><updated>2012-01-09T00:41:16.312-08:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2012-01-09T00:41:16.312-08:00</app:edited><title>New Plugin: licensing-maven-plugin</title><content type="html">Ever wanted to know what licenses your dependencies (and their dependencies) are using?  Maybe you work for a company that wants to sell their source code so you're wanting to avoid the GPL (and AGPL)?  I've got the plugin for you!&lt;br /&gt;
&lt;br /&gt;
I mentioned a while back that the build process at my day job had been declared bankrupt.  Well, it's doing much better now; what used to be a multi-day process where you were never quite sure if it was working 100% now takes less than an hour (including data population).  We're quite happy about that part.&lt;br/&gt;&lt;br/&gt;

Along the way we started looking at some of the other bits that fit more into release management; one of them was a "licensing report". This report listed most of our dependencies and which open source license they were in.  Instead of hacking at the old scripts, we decided to let Maven take over and handle providing licensing and dependency information.&lt;br /&gt;
&lt;br /&gt;
So with a rough idea of what we wanted to do, I put together the Licensing Maven Plugin.  It has a few handy features:&lt;br /&gt;&lt;br/&gt;
&lt;ol&gt;
&lt;li&gt;Transitively aggregate licensing information of dependencies of child modules in multi-module reactors (or in English, it works the way you would expect it to on multi-module builds).&lt;/li&gt;
&lt;li&gt;Coalesce license names (so "Apache License, Version 2.0", "Apache 2.0" and "ASLv2.0" can all be reported as "The Apache Software License, Version 2.0").&lt;/li&gt;
&lt;li&gt;Fail builds if a dependency is only available under a disliked license.&lt;/li&gt;
&lt;li&gt;Exempt artifacts under disliked licenses from failing the build.&lt;/li&gt;
&lt;li&gt;Manually declare licenses for dependencies that fail to provide their own.&lt;/li&gt;
&lt;/ol&gt;
&lt;br /&gt;&lt;br/&gt;
It's hosted on central, so give it a whirl:&lt;br /&gt;&lt;br/&gt;
&lt;span style="font-family: 'Courier New', Courier, monospace;"&gt;
mvn org.linuxstuff.maven:licensing-maven-plugin:1.5:aggregate&lt;/span&gt;&lt;br /&gt;&lt;br/&gt;
You'll see a truckload of warnings go by, and when it stops, you'll have a &lt;b&gt;target/aggregated-third-party-licensing.xml&lt;/b&gt; file (yes, I know it's not nicely formatted yet).
&lt;br /&gt;&lt;br/&gt;

If you'd like some more details, checkout the &lt;a href="https://github.com/idcmp/licensing-maven-plugin/blob/master/README"&gt;licensing-maven-plugin README&lt;/a&gt;.&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/idcmp?a=pXb2Lmfv_D8:oBJ0kq2WuhE:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/idcmp?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/idcmp/~4/pXb2Lmfv_D8" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://idcmp.linuxstuff.org/feeds/2982789559133120227/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=30950679&amp;postID=2982789559133120227" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/2982789559133120227?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/2982789559133120227?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/idcmp/~3/pXb2Lmfv_D8/new-plugin-licensing-maven-plugin.html" title="New Plugin: licensing-maven-plugin" /><author><name>Idcmp</name><uri>http://www.blogger.com/profile/03829017208885409542</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>0</thr:total><feedburner:origLink>http://idcmp.linuxstuff.org/2012/01/new-plugin-licensing-maven-plugin.html</feedburner:origLink></entry><entry gd:etag="W/&quot;DEACQXozeip7ImA9WhRXEU0.&quot;"><id>tag:blogger.com,1999:blog-30950679.post-2587979587006680050</id><published>2011-12-14T01:03:00.000-08:00</published><updated>2011-12-16T23:26:00.482-08:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-12-16T23:26:00.482-08:00</app:edited><title>Hello Developers, look at your code.</title><content type="html">Hello developers, look at your code, now back to me, now back at your code, now back to me.  Sadly, your code isn't me, but if it stopped collecting tech debt and you started making time for technical quality it could smell like me.  Page down, back up.  Where are you? You're at an interface with the code that your code could smell like. What's in your hand, back at me. I have it, it's an oyster with two different implementations to that thing you have an API for. Look again, the implementation is now secure and scalable.  Anything is possible when your code has no smells. 

I'm on a horse.&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/idcmp?a=n-huPlLI3KA:5tIK1gAVgQM:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/idcmp?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/idcmp/~4/n-huPlLI3KA" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://idcmp.linuxstuff.org/feeds/2587979587006680050/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=30950679&amp;postID=2587979587006680050" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/2587979587006680050?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/2587979587006680050?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/idcmp/~3/n-huPlLI3KA/hello-developers-look-at-your-code-now.html" title="Hello Developers, look at your code." /><author><name>Idcmp</name><uri>http://www.blogger.com/profile/03829017208885409542</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>0</thr:total><feedburner:origLink>http://idcmp.linuxstuff.org/2011/12/hello-developers-look-at-your-code-now.html</feedburner:origLink></entry><entry gd:etag="W/&quot;C08GRHw9fyp7ImA9WhRTEUs.&quot;"><id>tag:blogger.com,1999:blog-30950679.post-5152321728563778063</id><published>2011-11-01T08:37:00.001-07:00</published><updated>2011-11-01T08:37:05.267-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-11-01T08:37:05.267-07:00</app:edited><title>A Patentable Idea</title><content type="html">A quick post that if someone were to come up with a "USB Charger Condom" that I could plug into those free charging stations (or into my phone) which acted like an application layer proxy for my phone and prevented the charging station for giving anything more than power and not access anything on my phone that I'd gladly use one, and I'd make everyone I know use one too.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/idcmp?a=U1966LgnDp8:yNT2vy8JgVo:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/idcmp?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/idcmp/~4/U1966LgnDp8" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://idcmp.linuxstuff.org/feeds/5152321728563778063/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=30950679&amp;postID=5152321728563778063" title="1 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/5152321728563778063?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/5152321728563778063?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/idcmp/~3/U1966LgnDp8/patentable-idea.html" title="A Patentable Idea" /><author><name>Idcmp</name><uri>http://www.blogger.com/profile/03829017208885409542</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>1</thr:total><feedburner:origLink>http://idcmp.linuxstuff.org/2011/11/patentable-idea.html</feedburner:origLink></entry><entry gd:etag="W/&quot;A0cHQHs-fSp7ImA9WhdUEEQ.&quot;"><id>tag:blogger.com,1999:blog-30950679.post-6885473480302960162</id><published>2011-09-26T21:50:00.000-07:00</published><updated>2011-09-26T21:50:31.555-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-09-26T21:50:31.555-07:00</app:edited><title>Real Reasons Developers Leave Jobs</title><content type="html">While I'm still working on &lt;a href="http://idcmp.linuxstuff.org/2011/09/write-better-comments-by-tomorrow.html"&gt;improving my commenting skills&lt;/a&gt;, I've also started trying to ponder how to write software in company with high developer turnover.&lt;br /&gt;
&lt;br /&gt;
You see, I've always said that software reflects the team that writes it. &amp;nbsp;If you have a team of people who are seriously experienced at writing stored procedures and OSGi, you can expect that the software they write will use that. &amp;nbsp;On the flip side, a team who knows JavaScript and CSS, asked to write the same software will write something completely different.&amp;nbsp;So, given an environment that has higher turnover, how does someone design a system that embraces and survives?&lt;br /&gt;
&lt;br /&gt;
While I was researching about turnover, I found a survey on why developers left their&amp;nbsp;current positions (or rather, why they &lt;i&gt;would&lt;/i&gt;&amp;nbsp;leave their current position). &lt;br /&gt;
&lt;div&gt;
&lt;br /&gt;&lt;/div&gt;
&lt;div&gt;
The survey is a bit older, but the list is pretty fascinating:&lt;/div&gt;
&lt;div&gt;
&lt;ol&gt;
&lt;li&gt;Higher Salary&lt;/li&gt;
&lt;li&gt;More Experience&lt;/li&gt;
&lt;li&gt;More Interesting Work&lt;/li&gt;
&lt;li&gt;Need for a Change&lt;/li&gt;
&lt;li&gt;More Challenge&lt;/li&gt;
&lt;li&gt;Greater Chance of Promotion&lt;/li&gt;
&lt;li&gt;Better Location&lt;/li&gt;
&lt;li&gt;Present Company Getting too Large&lt;/li&gt;
&lt;li&gt;More Control over own Work&lt;/li&gt;
&lt;li&gt;Keep Up With Technical Knowledge&lt;/li&gt;
&lt;li&gt;Run Own Company&lt;/li&gt;
&lt;li&gt;More Flexible Working Arrangements&lt;/li&gt;
&lt;li&gt;Greater Structure in Work&lt;/li&gt;
&lt;li&gt;Go to More Successful Company&lt;/li&gt;
&lt;li&gt;Difficulties with Immediate Boss&lt;/li&gt;
&lt;li&gt;Friendlier Company&lt;/li&gt;
&lt;li&gt;Opportunity for Equity Stake&lt;/li&gt;
&lt;li&gt;Go to Less Commercial Company&lt;/li&gt;
&lt;li&gt;Go to More Commercial Company&lt;/li&gt;
&lt;/ol&gt;
&lt;div&gt;
&lt;br /&gt;&lt;/div&gt;
&lt;/div&gt;
&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/idcmp?a=qYryJycHLrw:KyW-D-mPJZ8:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/idcmp?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/idcmp/~4/qYryJycHLrw" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://idcmp.linuxstuff.org/feeds/6885473480302960162/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=30950679&amp;postID=6885473480302960162" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/6885473480302960162?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/6885473480302960162?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/idcmp/~3/qYryJycHLrw/real-reasons-developers-leave-jobs.html" title="Real Reasons Developers Leave Jobs" /><author><name>Idcmp</name><uri>http://www.blogger.com/profile/03829017208885409542</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>0</thr:total><feedburner:origLink>http://idcmp.linuxstuff.org/2011/09/real-reasons-developers-leave-jobs.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CUIGRHw5eCp7ImA9WhdVEk4.&quot;"><id>tag:blogger.com,1999:blog-30950679.post-5840457123710622908</id><published>2011-09-16T21:25:00.000-07:00</published><updated>2011-09-16T21:25:25.220-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-09-16T21:25:25.220-07:00</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="java" /><category scheme="http://www.blogger.com/atom/ns#" term="tips" /><category scheme="http://www.blogger.com/atom/ns#" term="programming" /><title>Write Better Comments by Tomorrow Morning</title><content type="html">I've spent some time recently trying to improve my code comments. &amp;nbsp;Most of us just write comments without much thought and carry on with the task at hand, however after a couple of weeks of iterative improvement I have some really simple tips that will make you write better comments tomorrow.&lt;br /&gt;
&lt;br /&gt;
&lt;span class="Apple-style-span" style="font-size: large;"&gt;Tip 1: Delete Bad Comments&lt;/span&gt;&lt;br /&gt;
&lt;br /&gt;
If you're working on a large code base, you'll invariably find some comment that's questionable, but sometimes you'll find comments that are even worse, and those comments simply need to go. &amp;nbsp;To me, the two kinds of comments that fit in this category are:&lt;br /&gt;
&lt;br /&gt;
&lt;ol&gt;
&lt;li&gt;Machine generated comments: These tend to be blatant and useless. &amp;nbsp;"&lt;i&gt;The getFoo method gets Foo&lt;/i&gt;." or "&lt;i&gt;The isNotEnabled method returns the value of notEnabled.&lt;/i&gt;". &amp;nbsp;If you're using Eclipse, the shortcut &lt;b&gt;Ctrl-D&lt;/b&gt;&amp;nbsp;can be used to delete a line and these comments are ripe for the killing.&lt;/li&gt;
&lt;li&gt;Lies: Over time code is refactored, shaped, copy-pasted, "fixed", outsourced, insourced, sold, bought until it eventually winds up in front of you. &amp;nbsp;During all this ebb and flow, some comments don't keep up with the code. &amp;nbsp;If the method signature you're looking at is "&lt;b&gt;public List obtainShipments(Locale locale, Country country);&lt;/b&gt;"&amp;nbsp;and the comment is "&lt;i&gt;This method will return true if the system can ship to the given country.&lt;/i&gt;" then you know it's wrong. &amp;nbsp; If this is not code you're currently cleaning up, then delete it. &amp;nbsp;&lt;/li&gt;
&lt;/ol&gt;
&lt;div&gt;
Wait, this sounds harsh. &amp;nbsp;You should spend the time to rewrite it as a proper comment, right? &amp;nbsp;Wrong, and here's why.&lt;/div&gt;
&lt;div&gt;
&lt;br /&gt;&lt;/div&gt;
&lt;div&gt;
If you've been a developer for a while, you know the feeling of being "in the zone". &amp;nbsp;That time where the entire system you're working on is in your head and you can think of side-effects and how everything works. &amp;nbsp;You're one with the matrix. If you're not working on the methods with the generated comments and lies, then you're not going to add any value trying to write comments and it's going to pull you out of the zone; so don't.&lt;/div&gt;
&lt;div&gt;
&lt;br /&gt;&lt;/div&gt;
&lt;div&gt;
Also, the comments that you see there will leave you (and others) with the feeling that comments are there to help you. &amp;nbsp;You've probably scanned a class before and thought "Uh-oh, there's almost no comments here, this could be tricky." &amp;nbsp;With the above two types of comments in that class it gives you a false sense of security. &amp;nbsp;You've got source control. &amp;nbsp;Bad comments are &lt;i&gt;worse&lt;/i&gt; than no comments, delete them and move on.&lt;/div&gt;
&lt;div&gt;
&lt;br /&gt;&lt;/div&gt;
&lt;div&gt;
&lt;span class="Apple-style-span" style="font-size: large;"&gt;Tip 2: &amp;nbsp;Explain the WTF's&lt;/span&gt;&lt;/div&gt;
&lt;div&gt;
&lt;br /&gt;&lt;/div&gt;
&lt;div&gt;
Sometimes the code you're working on has something weird and counter-intuitive about it. &amp;nbsp;Things that you totally understand, but others may not. &amp;nbsp;Usually they're the result of bugs or missing features elsewhere in the system. &amp;nbsp;When you're writing code that works around a bug, go find the issue # in that project's issue tracker and add the full URL in a comment. &amp;nbsp;Also explain what you would rather the code do if the bug weren't there. &amp;nbsp;If there isn't an existing bug then file one. &amp;nbsp;You may discover you misunderstood some functionality or that it's fixed in a newer version. &amp;nbsp;&lt;/div&gt;
&lt;div&gt;
&lt;br /&gt;&lt;/div&gt;
&lt;div&gt;
If you can't upgrade the library you depend on, mention that the bug is fixed in a newer version in your comment.&amp;nbsp;Also, if you use a dependency management system like Maven or Ivy, add a comment near the dependency "&lt;i&gt;Version 2.1.2 will fix BUG-7509 and then we can remove the workaround in SuperFancyImpl&lt;/i&gt;". This tiny investment of time will help the next developer who looks at the code.&lt;/div&gt;
&lt;div&gt;
&lt;br /&gt;&lt;/div&gt;
&lt;div&gt;
&lt;span class="Apple-style-span" style="font-size: large;"&gt;Tip 3: &amp;nbsp;Describe Relationships&lt;/span&gt;&lt;/div&gt;
&lt;div&gt;
&lt;br /&gt;&lt;/div&gt;
&lt;div&gt;
More than the other two tips, this tip takes your comments to the next level.&lt;/div&gt;
&lt;div&gt;
&lt;br /&gt;&lt;/div&gt;
&lt;div&gt;
A developer will stumble across your code, &lt;i&gt;following data flow&lt;/i&gt;. &amp;nbsp;They'll want to know why your code is here and how it interacts with other code, so tell them!&lt;/div&gt;
&lt;div&gt;
&lt;br /&gt;&lt;/div&gt;
&lt;div&gt;
Lets imagine a restaurant simulator. &amp;nbsp; As a developer you find the "&lt;b&gt;Table&lt;/b&gt;" class. &amp;nbsp;Comments like "&lt;i&gt;A table in a restaurant.&lt;/i&gt;" or "&lt;i&gt;An implementation of a Table.&lt;/i&gt;" are good &lt;b&gt;Ctrl-D&lt;/b&gt;&amp;nbsp;candidates. &amp;nbsp;Instead, here's something a little better:&lt;/div&gt;
&lt;blockquote&gt;
"&lt;i&gt;Tables represent a location in a restaurant where customers are served food. &amp;nbsp;&lt;/i&gt;&lt;i&gt;Restaurant &lt;b&gt;Customers&lt;/b&gt; attach themselves to a &lt;b&gt;Table&lt;/b&gt; which is then served by a number of &lt;b&gt;TableWorkers&lt;/b&gt; including the &lt;b&gt;Server&lt;/b&gt; &lt;b&gt;Employee&lt;/b&gt; and &lt;b&gt;TableCleaner&lt;/b&gt;. &amp;nbsp;It is often allocated by the &lt;b&gt;Reservation&lt;/b&gt; system, check &lt;b&gt;CustomerSeater&lt;/b&gt; for how Customers are seated. &amp;nbsp;Constructed Tables usually come from the &lt;b&gt;TableFactory&amp;nbsp;&lt;/b&gt;and are always added to the &lt;b&gt;RestaurantBuilding&lt;/b&gt;.&lt;/i&gt;"&lt;/blockquote&gt;
&lt;div&gt;
Let's take a look at the recipe this comment follows:&lt;/div&gt;
&lt;div&gt;
&lt;ol&gt;
&lt;li&gt;Who Am I: If this class represents a business object or business activity, then copy and paste the description from any documentation or planning sessions you've had. &amp;nbsp;If there isn't any, then write a note to yourself about why you decided you wanted to make a new class.&lt;/li&gt;
&lt;li&gt;My Close Family: This class describes very simply how it interacts with other classes around it, either in the same package or members that would reference it.&lt;/li&gt;
&lt;li&gt;Bend Encapsulation: In the comment we mention &lt;b&gt;TableCleaner&lt;/b&gt;&amp;nbsp;as an implementation of &lt;b&gt;TableWorker&lt;/b&gt;. &amp;nbsp;Chances are the Table class doesn't have any code reference to &lt;b&gt;TableCleaner&lt;/b&gt;, but our comment does. &amp;nbsp;This can be an "Aha!" moment for a developer. &amp;nbsp;Eclipse is smart enough to dig around in comments when you're refactoring so it's not as dangerous as you might think.&lt;/li&gt;
&lt;li&gt;Use "usually" and "often":&amp;nbsp;Should &lt;b&gt;Table&lt;/b&gt; know that it comes from a &lt;b&gt;TableFactory&lt;/b&gt;? No. &amp;nbsp;Should a developer know this? Absolutely. &amp;nbsp;By saying "&lt;i&gt;usually&lt;/i&gt;", we hint to the developer that this is probably the common case, but because of the separation we can't say definitively this will be true.&lt;/li&gt;
&lt;/ol&gt;
&lt;div&gt;
The last two ingredients are what makes this comment a cut above the rest. It helps guide me up and beyond what most other comments would help me with.&lt;/div&gt;
&lt;/div&gt;
&lt;div&gt;
&lt;br /&gt;&lt;/div&gt;
&lt;div&gt;
&lt;span class="Apple-style-span" style="font-size: large;"&gt;What If I Have To Have Comments?&lt;/span&gt;&lt;/div&gt;
&lt;div&gt;
&lt;span class="Apple-style-span" style="font-size: large;"&gt;&lt;span class="Apple-style-span" style="font-size: small;"&gt;&lt;div&gt;
&lt;br /&gt;&lt;/div&gt;
&lt;div&gt;
You might wondering what to do if you have a tool that enforces comments in your system and will fail your CI build if you start getting&amp;nbsp;&lt;b&gt;Ctrl-D&lt;/b&gt;&amp;nbsp;happy. &amp;nbsp;It's pretty simple, disable the rules that force you to write comments. &amp;nbsp;&lt;/div&gt;
&lt;div&gt;
&lt;br /&gt;&lt;/div&gt;
&lt;div&gt;
At my work place we have rules that all methods must have comments, and comments must end with a period for proper grammar. &amp;nbsp;Want to know what comment I've seen more times than I'd like to admit?&lt;/div&gt;
&lt;div&gt;
&lt;span class="Apple-style-span" style="font-family: 'Courier New', Courier, monospace;"&gt;&lt;br /&gt;&lt;/span&gt;&lt;/div&gt;
&lt;div&gt;
&lt;span class="Apple-style-span" style="font-family: 'Courier New', Courier, monospace;"&gt;&lt;b&gt;&amp;nbsp;/**&lt;/b&gt;&lt;/span&gt;&lt;/div&gt;
&lt;div&gt;
&lt;b&gt;&lt;span class="Apple-style-span" style="font-family: 'Courier New', Courier, monospace;"&gt;&amp;nbsp;&amp;nbsp;&lt;/span&gt;* .&lt;/b&gt;&lt;/div&gt;
&lt;div&gt;
&lt;b&gt;&amp;nbsp; &amp;nbsp; * @return boolean .&lt;/b&gt;&lt;/div&gt;
&lt;div&gt;
&lt;b&gt;&amp;nbsp; &amp;nbsp; */&lt;/b&gt;&lt;/div&gt;
&lt;div&gt;
&lt;br /&gt;&lt;/div&gt;
&lt;div&gt;
Yup. &amp;nbsp;The problem with enforcing comments is you're enforcing their &lt;i&gt;existence&lt;/i&gt;, not their &lt;i&gt;content&lt;/i&gt; and simply having a comment isn't ever going to be enough. &amp;nbsp;The code metric tools don't enforce quality, just quantity. &amp;nbsp;So ask people around you if it's more important to have&amp;nbsp;&lt;b&gt;lots&lt;/b&gt;&amp;nbsp;of comments or if it's important to have&amp;nbsp;&lt;b&gt;better&lt;/b&gt;&amp;nbsp;comments. &amp;nbsp;Maybe for your workplace, quantity is better...&lt;/div&gt;
&lt;div&gt;
&amp;nbsp;&lt;/div&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/div&gt;
&lt;div&gt;
&lt;span class="Apple-style-span" style="font-size: large;"&gt;That's It!&lt;/span&gt;&lt;/div&gt;
&lt;div&gt;
&lt;br /&gt;&lt;/div&gt;
&lt;div&gt;
I'm still experimenting with other techniques, but so far these have had a great impact in my development. Other tips and ideas are welcome!&lt;/div&gt;
&lt;div&gt;
&lt;br /&gt;&lt;/div&gt;
&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/idcmp?a=Dj3Aj7_-W0U:pmiIRAd2ozw:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/idcmp?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/idcmp/~4/Dj3Aj7_-W0U" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://idcmp.linuxstuff.org/feeds/5840457123710622908/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=30950679&amp;postID=5840457123710622908" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/5840457123710622908?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/5840457123710622908?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/idcmp/~3/Dj3Aj7_-W0U/write-better-comments-by-tomorrow.html" title="Write Better Comments by Tomorrow Morning" /><author><name>Idcmp</name><uri>http://www.blogger.com/profile/03829017208885409542</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>0</thr:total><feedburner:origLink>http://idcmp.linuxstuff.org/2011/09/write-better-comments-by-tomorrow.html</feedburner:origLink></entry><entry gd:etag="W/&quot;DUAGQns5cCp7ImA9WhZREkw.&quot;"><id>tag:blogger.com,1999:blog-30950679.post-6122423004338729708</id><published>2011-03-29T21:07:00.003-07:00</published><updated>2011-04-07T16:08:43.528-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2011-04-07T16:08:43.528-07:00</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="programming" /><category scheme="http://www.blogger.com/atom/ns#" term="rants" /><title>Technical Debt</title><content type="html">Our build came up recently in a planning session at work. It's a standard big ball of mud, with hidden knowledge all over. It's frail, inconsistent and unhelpful, it's complicated to work with and almost nobody ever gets their local build past "good enough for now" to "working well".&lt;br /&gt;&lt;br /&gt;This has been an issue for a while and it hadn't been given the proper attention to be improved. Every change had been reactionary to various needs and it had changed hands so many times that any beliefs or design philosophies it had were long lost.  &lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;One developer estimated that wrangling the build system alone accounted for 30% of their development time (that's three days of a two week iteration).&lt;div&gt;&lt;br /&gt;When asked how much effort was required to fix it, the answer was "&lt;i&gt;You can't.&lt;/i&gt;"&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span"&gt;&lt;span class="Apple-style-span"&gt;Taking Out Your Technical Loan&lt;/span&gt;&lt;br /&gt;&lt;/span&gt;&lt;br /&gt;While I wasn't originally, I'm now a fan of the term "technical debt".  It brings with it a handful of related concepts and terminology that make discussions easier.  In this case, &lt;b&gt;compound interest&lt;/b&gt;, and &lt;b&gt;bankruptcy&lt;/b&gt;.&lt;br /&gt;&lt;br /&gt;It all starts when you first make a big investment; probably your first release. Fixing up the last minute bugs before release, cutting corners in the name of getting to market, making "just for now" trade offs going against technical soundness.  Each of these things add to your technical debt. There's nothing wrong with this, it's expected.&lt;br /&gt;&lt;br /&gt;But then your debt starts adding up pretty quickly:&lt;div&gt;&lt;ul&gt;&lt;li&gt;Changes in business needs for the system&lt;/li&gt;&lt;li&gt;Changes in company direction&lt;/li&gt;&lt;li&gt;Changes in team composition, staff sizing&lt;/li&gt;&lt;li&gt;Cutting corners on in-code documentation &lt;/li&gt;&lt;li&gt;Industry changes&lt;/li&gt;&lt;li&gt;Not keeping up with underlying frameworks&lt;/li&gt;&lt;li&gt;Not following proper language techniques&lt;/li&gt;&lt;li&gt;Quick security patches&lt;/li&gt;&lt;li&gt;Scalability needs&lt;/li&gt;&lt;li&gt;Blindly meeting code metrics&lt;/li&gt;&lt;li&gt;Over reliance on under-skilled developers&lt;/li&gt;&lt;li&gt;Not testing on up to date integration points (databases, operating systems, etc)&lt;/li&gt;&lt;li&gt;Quick and dirty bug fixes&lt;/li&gt;&lt;li&gt;Minor improvements&lt;/li&gt;&lt;/ul&gt;&lt;div&gt;Any of these things can put you further into debt, and while you're in debt you'll need to pay &lt;b&gt;&lt;span&gt;&lt;span&gt;compound interest &lt;/span&gt;&lt;/span&gt;&lt;/b&gt;on your technical debt.  What was one day of work to fix this iteration can become two days of work a few iterations from now and a week of work next release.  Leave it longer and suddenly it's a month of work two years from now.&lt;/div&gt;&lt;/div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span"&gt;How does this happen?&lt;/span&gt;&lt;/div&gt;&lt;br /&gt;Lots of ways. &lt;/div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;One of the beautiful things about refactoring is the way it takes into consideration the "context" that a developer has gained in immediately working with the code.  Their short-term memory is filled with nuances and intents and allows them to glide smoothly through code.  They can envision the refactoring and perform it optimally.&lt;br /&gt;&lt;br /&gt;As time passes, they lose some of the context. Surrounding code begins to change, bug fixes are introduced, and other developers build on what was written instead of what was intended. More time passes and other code is refactored, team members come and go or the pattern gets copied elsewhere in your code base.&lt;/div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;A few iterations later, there's a hierarchy of dependencies built on this code and what was once a simple refactoring has become a costly code spill cleanup effort.&lt;/div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;Eventually the frameworks become out of date and coding styles fall out of style.  Instead of wanting to clean up the code, new developers will work around it, introduce a functional duplicate, wrap it or simply make their changes as a series of hacks.&lt;/div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;If code quality drops too low, some say morale will follow and keeping more than a handful of experienced developers will become a challenge; attracting developers eager to land their first job, negative velocity developers or those that simply don't care.  &lt;/div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;This affects your ability to pay off your debt.&lt;/div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span"&gt;Ways To Pay&lt;br /&gt;&lt;/span&gt;&lt;br /&gt;Every organization has different priorities, goals and principles. As such, calculating how or where to pay for your technical debt varies wildly.  Of course, the rule of thumb is "Pay off debt that is costing you the most."  There are a handful of ways to do this:&lt;/div&gt;&lt;div&gt;&lt;ul&gt;&lt;li&gt;Research and Analysis: Work to establish what business functionality should be delivered next then prototype any areas that are known hot spots or developers do not have experience with.  With the gained experience determine if the code in question is deeply in debt or if it can &lt;i&gt;afford&lt;/i&gt; the new feature.&lt;/li&gt;&lt;li&gt;Raise Rates: When asked to estimate a new feature in an area that has high technical debt, focus on estimates which include needed code revitalization. Just as it's the business duty to plan features customers want, it's a developer's responsibility &lt;i&gt;manage risk&lt;/i&gt; ensuring it's done technically correct.&lt;/li&gt;&lt;li&gt;Foreign Exchange: &lt;i&gt;Exchange&lt;/i&gt; the technical currency into salaries as an incentive to keep developers.  Many larger, non-technical firms follow this route. It's like buying carbon credits; the debt is still there, but developers are rewarded for tolerating it.&lt;/li&gt;&lt;li&gt;Creative Accounting: Buffer estimates and deliverables with needed cleanups.  Once someone knows an area of code well, perform small improvements under other ledgers.&lt;/li&gt;&lt;li&gt;Get a Second Job: One of the most dire methods is to band together and either work nights or through lunchtime to make the needed improvements.&lt;/li&gt;&lt;li&gt;Bankruptcy: Sometimes there's honestly no other choice other than to start over. &lt;/li&gt;&lt;/ul&gt;&lt;div&gt;&lt;span class="Apple-style-span"&gt;Back To The Build&lt;/span&gt;&lt;/div&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span"&gt;&lt;br /&gt;&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span"&gt;Our build system had gone &lt;b&gt;bankrupt&lt;/b&gt;.  It had gained such complexity that we could no longer service the interest on the debt.&lt;/span&gt;&lt;/div&gt;&lt;/div&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span"&gt;&lt;br /&gt;&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span"&gt;In our case, this opened the door to switching build tools, cleaning up packaging and performing much needed work on the development environment. It's exciting, as it will not only boost the productivity of each developer, but it hopes to also be something that isn't always dreaded; so developers can focus on solving their problems more effectively and not how to make sure everything builds properly.  &lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span"&gt;&lt;br /&gt;&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span"&gt;And, if the payments are made on it on a regular basis, serve our needs well for years to come.&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span"&gt;&lt;br /&gt;&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span"&gt;&lt;br /&gt;&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span"&gt;&lt;br /&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/idcmp?a=TTmxH1xsRfw:AqAnUkyMuxE:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/idcmp?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/idcmp/~4/TTmxH1xsRfw" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://idcmp.linuxstuff.org/feeds/6122423004338729708/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=30950679&amp;postID=6122423004338729708" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/6122423004338729708?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/6122423004338729708?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/idcmp/~3/TTmxH1xsRfw/technical-debt.html" title="Technical Debt" /><author><name>Idcmp</name><uri>http://www.blogger.com/profile/03829017208885409542</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>0</thr:total><feedburner:origLink>http://idcmp.linuxstuff.org/2011/03/technical-debt.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CEAAR304eip7ImA9Wx5UF08.&quot;"><id>tag:blogger.com,1999:blog-30950679.post-2558070341728220948</id><published>2010-10-21T20:05:00.004-07:00</published><updated>2010-10-21T21:45:46.332-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2010-10-21T21:45:46.332-07:00</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="programming" /><title>Who Owns Your Code?</title><content type="html">At work, our marketing team is in control of deciding where development spends time on products. This is an effective way to ensure that our product meets the needs of the market we're in.&lt;br /&gt;&lt;br /&gt;In fact, I would say we have an effective backlog of "big features" that are desired by our target market. We're only limited by the resources we have on hand to deliver these features. Therein lies the challenge; almost every feature is done on a tight timeline, and once it's in a non-laughable state, it's released and the team goes on to the next big feature.  No time is really spent revisiting the overall design of the product, or just bringing its dependencies up to date.&lt;br /&gt;&lt;br /&gt;In a previous workplace, the development team had strong say on what was worked on. This was an effective way to ensure the product was relatively nice to work on and its technology up to date.  New features were strongly scrutinized and often there was a focus on picking newer technologies that made it easier to develop and service. The challenge was we'd fall behind on bolting on new business features from time to time.&lt;br /&gt;&lt;br /&gt;In yet another workplace, our SEO team had the strongest say in what happened. Our main products were publicly accessible websites, but I feel like this was a pretty unique situation.  Many technical decisions had to be discussed with the SEO team (which CMS should be chosen, which captcha system should be employed,  etc..) and everything from character set encodings, performance trade offs and cache expiry times needed to have their approval.  Our challenge there was that the success of some SEO practices are not easily measured, it was difficult to assign a ROI on particular decisions.&lt;br /&gt;&lt;br /&gt;Who owns your product? How does that shape it?&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/idcmp?a=baaF20gRyU0:OlnSVPXXoHI:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/idcmp?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/idcmp/~4/baaF20gRyU0" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://idcmp.linuxstuff.org/feeds/2558070341728220948/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=30950679&amp;postID=2558070341728220948" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/2558070341728220948?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/2558070341728220948?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/idcmp/~3/baaF20gRyU0/who-owns-your-code.html" title="Who Owns Your Code?" /><author><name>Idcmp</name><uri>http://www.blogger.com/profile/03829017208885409542</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>0</thr:total><feedburner:origLink>http://idcmp.linuxstuff.org/2010/10/who-owns-your-code.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CEQGRXw6fCp7ImA9Wx5VGUk.&quot;"><id>tag:blogger.com,1999:blog-30950679.post-7346122722247723662</id><published>2010-10-12T20:24:00.004-07:00</published><updated>2010-10-12T20:58:44.214-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2010-10-12T20:58:44.214-07:00</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="hiring" /><category scheme="http://www.blogger.com/atom/ns#" term="interviews" /><category scheme="http://www.blogger.com/atom/ns#" term="programming" /><title>Negative Velocity Developers</title><content type="html">I've worked on a handful of projects over my career where there's been a developer that I've started to coin as "&lt;i&gt;negative velocity&lt;/i&gt;".&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;Their positive impact on projects is best when they're on vacation or spinning their wheels in meetings.  Everything they touch could instantly earn an @Deprecated annotation, and often when they're focused on their next tasks, the rest of the team is left to either throw out and rewrite, duplicate in parallel or at best refactor the work they've done.&lt;/div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;Some of the best code they write is copy and pasted from other code, some of the worst is of their own design.  Often the team works hard to try to minimize the impact of the developer, but they simply just don't understand what they're doing.&lt;/div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;Agile projects make the results of this developer even more vicious as they get to choose what area of the project they will molest next. Also, many teams are "agile but" where the team follows some practices, they are not empowered to remove that developer from the team.&lt;/div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;Often those that make employment changing decisions don't have the tools to validate such a claim.  So what's one to do with a negative velocity developer? How does one capture enough information to prove to someone non-technical that their skill sets would best be used elsewhere?&lt;/div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span" style="font-size: 15.9722px; "&gt;&lt;i&gt;Note: This is &lt;b&gt;not&lt;/b&gt; a current situation for me.&lt;/i&gt;&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span" style="font-size: 15.9722px; "&gt;&lt;br /&gt;&lt;/span&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/idcmp?a=HjXpauv_054:yYOSdoUrW_I:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/idcmp?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/idcmp/~4/HjXpauv_054" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://idcmp.linuxstuff.org/feeds/7346122722247723662/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=30950679&amp;postID=7346122722247723662" title="2 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/7346122722247723662?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/7346122722247723662?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/idcmp/~3/HjXpauv_054/negative-velocity-developers.html" title="Negative Velocity Developers" /><author><name>Idcmp</name><uri>http://www.blogger.com/profile/03829017208885409542</uri><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>2</thr:total><feedburner:origLink>http://idcmp.linuxstuff.org/2010/10/negative-velocity-developers.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CkYNQ3o_fip7ImA9Wx5WFUg.&quot;"><id>tag:blogger.com,1999:blog-30950679.post-6631377669491664896</id><published>2010-03-10T15:55:00.004-08:00</published><updated>2010-09-26T18:16:32.446-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2010-09-26T18:16:32.446-07:00</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="interviews" /><category scheme="http://www.blogger.com/atom/ns#" term="resumes" /><category scheme="http://www.blogger.com/atom/ns#" term="tips" /><category scheme="http://www.blogger.com/atom/ns#" term="rants" /><title>What Your Hiring Process Says About You</title><content type="html">&lt;span class="Apple-style-span" style="font-family: Arial; font-size: small;"&gt;&lt;span class="Apple-style-span" style="font-size: 13px;"&gt;&lt;div&gt;&lt;span class="Apple-style-span" style="font-family: Arial;"&gt;&lt;span class="Apple-style-span" style="font-size: medium;"&gt;What's your hiring experience like?  How many "hoops" do you make candidates go through?  Why do you make them go through them?  In this post I'll recount some hiring processes I experienced and chat a bit about what (as a candidate) they said about the company. At the end I have a potential checklist.&lt;/span&gt;&lt;/span&gt;&lt;/div&gt;&lt;/span&gt;&lt;/span&gt;&lt;div&gt;&lt;div&gt;&lt;br /&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;span class="Apple-style-span" style="font-size: x-large;"&gt;1. Longest: Archiving Company&lt;/span&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;br /&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;As a referral, I was spared an initial phone screen and instead was brought in person to meet an operations manager.  His questions were non-technical and focused along the "How well do you deal with conflict?  How well do you deal with challenging people to work with?  Have you been in an environment where people were difficult to get along with?".  We ran over time and I was asked to come back to talk to a project manager.  &lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;br /&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;I returned a few days later and the interviewer was reading off situational HR questions, all with a tilt toward conflict resolution.  &lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;br /&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;A few days later, I was asked to complete an assignment - write a service with certain features, complete with documentation and tests. Unfortunately I received the assignment on a Friday and was told it had to be completed before Monday morning.  This was a surprise and a bit of a disappointment as it conflicted with birthday plans I had that weekend.&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;br /&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;A few days later I was brought in for a third interview with a developer, project manager and product manager.  Very few questions were asked about my assignment and the developer asked me some technical questions (some were unrelated to the problem domain they were in).  One was my own question that my previous co-worker had brought with him to the company! Further general questions about process followed from their project manager and product manager.&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;br /&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;As the interview was closing up, I discovered they'd like me to write two tests: a number matching test and an IQ test.  Both timed, both while a loud lunch party was happening through the adjacent wall.  The number matching was a doubled-sided, double-columned list.  Each entry had a hand written number and a printed number; I was to mark an X on the ones that differed.  The IQ test was pretty standard with tricky logic, English and math questions. &lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;br /&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;Two days later I received a call from their receptionist saying they were no longer interested.  Naturally I contacted my reference to find out more.  He responded that as far as he knew, they were still discussing it. He confirmed this later, it was a mistake on their part.&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;br /&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;The next day he contacted me with their decision; they were no longer interested.  Infact, he said that it was a mistake to even begin the interview process with me as they weren't looking for me.&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;br /&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;i&gt;(Had they been interested, I would have been asked back for an additional interview with the CEO.)&lt;/i&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;br /&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;span class="Apple-style-span" style="font-size: x-large;"&gt;Notes&lt;/span&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;span class="Apple-style-span" style="font-size: x-large;"&gt;&lt;br /&gt;&lt;/span&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;Needless to say I was disappointed in this process and if it wasn't for the initial reference, I would have given up on this path much sooner. &lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;br /&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;b&gt;Explain the workflow to the candidate.&lt;/b&gt;  Before I started the process I was told it was similar to a previous company I worked at.  It was most definitely not.  Not knowing the steps in the hiring workflow, a candidate has no idea that he's about to invest a dozen hours.&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;b&gt;&lt;br /&gt;&lt;/b&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;b&gt;Screen for culture.&lt;/b&gt; Every organization has a different "culture", and it's important to double check that a person will fit in with the existing employees (or if they'll shake things up in a good way!)&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;b&gt;&lt;br /&gt;&lt;/b&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;b&gt;Your questions will reflect what a candidate thinks is important to you.&lt;/b&gt;  When three separate employees ask questions about navigating difficult people, constantly changing requirements and micromanagement, this is what your candidate will think your place is like.  If you ask questions about networking protocols or multi-threaded programming, then your candidate will feel the position will involve both. When I asked "Do you use the technology you're asking me about?", I was surprised their answer was "Not really.".&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;br /&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;b&gt;Sell the company to the candidate. &lt;/b&gt;I was walked around the development area on two occasions and got the feel of the environment.  I was told about some of the unique perks of the company too.  This kept me interested.&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;br /&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;b&gt;Involve only the right people.&lt;/b&gt;  Out of the five people who interviewed me, one was for technical purposes and the other I would potentially be reporting to.  The other three were brought in "just to meet me" and "had no real serious questions to ask".  As a candidate, this tells me your decision making process requires people who may be uninvolved with a decision to approve. &lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;br /&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;b&gt;Limit an interview time. &lt;/b&gt;After about 90 minutes, my ability to continue to answer a barrage of questions begins to diminish.  After two hours, I really felt that writing a surprise number-matching and IQ test was quite unfair.&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;br /&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;b&gt;Hiring processes should be fail-fast.&lt;/b&gt;  As soon as an organization realizes it's not interested, the process should stop. Clearly this one suffered from poor internal communication and lack of direction. Consuming not only my time, but employee time too.&lt;/div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;The "assignment" was an interesting project, but given the investment I made and how little it was referenced, I was quite disappointed to waste my time on it.  I got the feeling the developer hadn't had time to read it, or that this was just an extra step he disagreed with.  The length of this process gave me a lot of experience in what not to do.  Had I been accepted, refactoring the hiring workflow was going to be a personal side project.  &lt;/div&gt;&lt;br /&gt;&lt;span class="Apple-style-span" style="font-size: x-large;"&gt;Shortest: Payment Company&lt;/span&gt;&lt;br /&gt;&lt;br /&gt;Reading up about the company, I figured that I would be a good fit.  I emailed a simple cover letter with some specifics of where I'd fit in.  Their CTO responded back and we set up an in-person interview.&lt;br /&gt;&lt;br /&gt;The interview with the CTO went well, but he was hoping to have me fill a different role than I was looking for.  I met after with two of their developers who were prepared to ask me questions relating to the other role and were ill-prepared to ask me Java related questions.&lt;br /&gt;&lt;br /&gt;The next day I heard back from the CTO; his team didn't feel I was Java-savvy enough.&lt;br /&gt;&lt;br /&gt;&lt;span class="Apple-style-span" style="font-size: x-large;"&gt;Notes&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span"&gt;&lt;/span&gt;&lt;span class="Apple-style-span" style="font-size: x-large;"&gt;&lt;br /&gt;&lt;/span&gt;Short, and sweet.  Within a few days this company came and left my radar.&lt;br /&gt;&lt;br /&gt;&lt;b&gt;Know what you're looking for. &lt;/b&gt;Before bringing in candidates, clearly define the role you're looking for.  If you're not sure (it happens sometimes), then spend time defining what you're &lt;i&gt;not&lt;/i&gt; looking for.&lt;br /&gt;&lt;br /&gt;&lt;b&gt;Be prepared.&lt;/b&gt;  Having stock questions to get a conversation going is fine, but if you haven't read the candidate's resume and don't know what to expect, you'll be ill-prepared to ask the right questions to find out their skills, and most likely opt not to hiring them simply because of this.&lt;br /&gt;&lt;br /&gt;They did an excellent job explaining the technology, where they were going and what challenges were ahead for them.  The developers I chatted with were interesting, but since they had a "systems guy" and not a "Java guy" mindset, they didn't know what to ask.&lt;br /&gt;&lt;br /&gt;&lt;span class="Apple-style-span" style="font-size: x-large;"&gt;Accepted: eCommerce Company&lt;/span&gt;&lt;br /&gt;&lt;div&gt;&lt;span class="Apple-style-span" style="font-size: x-large;"&gt;&lt;br /&gt;&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span"&gt;Did some research to discover they'd been looking for someone to fill this position for a while, skipped their online application form and found the email address for hiring.  I had customized my cover letter to ensure they realized I was looking for a specific role and highlighted how my experience meshes with what I was looking for.&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span"&gt;&lt;br /&gt;&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span"&gt;I received a call back from their hiring team and we set up a phone screen.  During the phone screen we discussed what I was looking for, salary expectations, and more about what the company does.  From there I was told there was an online Java quiz to do.&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span"&gt;&lt;br /&gt;&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span"&gt;The quiz was timed and fairly wide reaching.&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span"&gt;&lt;br /&gt;&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span"&gt;I heard back a couple days later that they would like to schedule an in-person technical and HR interview.  I asked if this was &lt;b&gt;&lt;i&gt;the&lt;/i&gt;&lt;/b&gt; interview or if there were multiple steps.  At the time I was told that this was &lt;b&gt;&lt;i&gt;the&lt;/i&gt;&lt;/b&gt; interview, so I fit it in the day before I left on a trip.&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;I met with a developer there who knew his stuff, and he asked me a stock set of questions and asked me to clarify something from the quiz.  Apparently I had got one question wrong but they were still interested.  After, I met with the internal recruiter and we talked more about the company and where things were.  She let me know that there were two more steps: a refactoring exercise and a second interview.&lt;br /&gt;&lt;br /&gt;My first interview went well and I received the assignment while on my trip.  Once I returned I sent back my answer and a couple days later I was asked in for a second interview.  The assignment took probably an hour or two.&lt;br /&gt;&lt;br /&gt;This interview I met with their development manager and we discussed my solution, my decisions, alternatives, drawbacks and technology in general.  Later I met with their CTO who asked me some higher level questions.&lt;br /&gt;&lt;br /&gt;Then I waited.  After what seemed unusually long, I was asked to provide references. After I did, it took an additional week to check them; mid-week I was told why.  The company was making some internal changes and this role may not be exactly what it initially was.  After discussing it further, I was still on board and was asked for a third interview - more of a just a chat - with the person who would signoff on the hiring paperwork.&lt;br /&gt;&lt;br /&gt;I was in the next day and chatted with the VP in question for approximately 10 minutes and he was sold; an offer was made later that day.&lt;br /&gt;&lt;br /&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;span class="Apple-style-span" style="font-size: x-large;"&gt;Notes&lt;/span&gt;&lt;/div&gt;&lt;div style="margin-bottom: 0px; margin-left: 0px; margin-right: 0px; margin-top: 0px;"&gt;&lt;span class="Apple-style-span" style="font-size: x-large;"&gt;&lt;br /&gt;&lt;/span&gt;&lt;/div&gt;&lt;div&gt;Internal political changes made this hiring process a lot longer than it should have been, and being accidentally mislead about the hiring process was a bit of a disappointment.  &lt;/div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;&lt;b&gt;Funnel Requests. &lt;/b&gt;A month prior to emailing them directly, I had filled out an online application form on their site and never heard from them.  Since I felt I was a strong potential, I skipped that step when I later saw the role was still unfilled.  I still wonder where my first application went..  Make sure that all different interfaces candidates can apply through are given equal priority.&lt;/div&gt;&lt;div&gt;&lt;b&gt;&lt;br /&gt;&lt;/b&gt;&lt;/div&gt;&lt;div&gt;&lt;b&gt;Have Discussions. &lt;/b&gt;In a previous company, I would bring whatever problem I was currently tackling to the interview and ask the candidate, providing as much background as I could.  We'd work through it together and see where we got.   Having a refactoring assignment to chat about simulated this and turned the interview from Q&amp;amp;A to more of a free flowing discussion of ideas.&lt;/div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span" style="font-size: x-large;"&gt;Summary&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;The eCommerce Company with their phone screen and online quiz had a "fail-fast" process, and I met only with relevant people.  They mostly knew what they were looking for, but internal change made the hiring more challenging.  I only answered a handful of direct "fit" questions.  Everyone I chatted with was open about the challenges they were facing but also quick to highlight some of the great things they really liked.  I discovered that both the quiz and the assignment came from existing weaknesses in their team and code base.&lt;/div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span" style="font-size: x-large;"&gt;The Checklist&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;ul&gt;&lt;li&gt;We explain our complete hiring workflow to candidates up front and keep them informed of their progress.&lt;/li&gt;&lt;li&gt;We will stop the hiring process as soon as we feel the answer would be "no".  Our process is optimized to make this happen as soon as possible.&lt;/li&gt;&lt;li&gt;We limit the time an interview will take, but will cut it short if the answer is a definite "yes" or "no".&lt;/li&gt;&lt;li&gt;All potential candidates which enter our hiring system are treated equally, regardless of source.&lt;/li&gt;&lt;li&gt;We ensure candidates will be a good fit with the rest of the people here, and we feel we can do this mostly by discussing relevant topics with them.&lt;/li&gt;&lt;li&gt;Our interviewers always take time to prepare before an interview.&lt;/li&gt;&lt;li&gt;Our questions are relevant to the company, technology and role we're looking to fill.&lt;/li&gt;&lt;li&gt;We know the specific skills needed to succeed in the role we're looking to fill.&lt;/li&gt;&lt;li&gt;Our hiring process includes conversations with candidates similar to the ones that we have internally already.&lt;/li&gt;&lt;li&gt;We involve the fewest people necessary, each person adds unique value to the process.&lt;/li&gt;&lt;li&gt;We're honest about our challenges, and we mention the great things about our company throughout the hiring process.&lt;/li&gt;&lt;/ul&gt;&lt;/div&gt;&lt;/div&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/idcmp?a=OqbLEs129vA:EXBpxmKbOVY:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/idcmp?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/idcmp/~4/OqbLEs129vA" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://idcmp.linuxstuff.org/feeds/6631377669491664896/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=30950679&amp;postID=6631377669491664896" title="2 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/6631377669491664896?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/6631377669491664896?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/idcmp/~3/OqbLEs129vA/what-your-hiring-process-says-about-you.html" title="What Your Hiring Process Says About You" /><author><name>Idcmp</name><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>2</thr:total><feedburner:origLink>http://idcmp.linuxstuff.org/2010/03/what-your-hiring-process-says-about-you.html</feedburner:origLink></entry><entry gd:etag="W/&quot;DUIDRn4yeCp7ImA9WxBUGEQ.&quot;"><id>tag:blogger.com,1999:blog-30950679.post-6990644466253781709</id><published>2010-03-06T09:46:00.000-08:00</published><updated>2010-03-06T09:46:17.090-08:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2010-03-06T09:46:17.090-08:00</app:edited><title>Winner of the Worst Java API Award Goes To.....</title><content type="html">One of my Java interview questions revolves around the best/worst Java APIs a candidate has worked with. &amp;nbsp;Tiago Fernandez has thought to take this question to the next level and posted a poll. &amp;nbsp;While he had less than 100&amp;nbsp;respondents, it meshes pretty closely with my&amp;nbsp;experience, so I would say that the results are pretty accurate. &amp;nbsp;Check out the&amp;nbsp;&lt;a href="http://tiagofernandez.blogspot.com/2010/03/worst-java-apis-poll-results.html"&gt;winner of the worst Java API&lt;/a&gt;. &amp;nbsp;Now, how long will we have to wait for JSR-310?&lt;div&gt;&lt;br /&gt;
&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/idcmp?a=MzQWm3G7KxQ:pF1npAO1h1I:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/idcmp?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/idcmp/~4/MzQWm3G7KxQ" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://idcmp.linuxstuff.org/feeds/6990644466253781709/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=30950679&amp;postID=6990644466253781709" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/6990644466253781709?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/6990644466253781709?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/idcmp/~3/MzQWm3G7KxQ/winner-of-worst-java-api-award-goes-to.html" title="Winner of the Worst Java API Award Goes To....." /><author><name>Idcmp</name><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>0</thr:total><feedburner:origLink>http://idcmp.linuxstuff.org/2010/03/winner-of-worst-java-api-award-goes-to.html</feedburner:origLink></entry><entry gd:etag="W/&quot;A0QERH87eCp7ImA9WxBUEEk.&quot;"><id>tag:blogger.com,1999:blog-30950679.post-7686701389836877995</id><published>2010-02-24T14:08:00.000-08:00</published><updated>2010-02-24T14:08:25.100-08:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2010-02-24T14:08:25.100-08:00</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="java" /><category scheme="http://www.blogger.com/atom/ns#" term="interviews" /><title>My Java Developer Interview Questions</title><content type="html">&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;Here it is! Many people have asked for this list - it's one I built, borrowed and tweaked over the years.&amp;nbsp;&lt;span class="Apple-style-span" style="font-family: 'Times New Roman';"&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;I place a lot of value in "&lt;/span&gt;&lt;i&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;I don't know&lt;/span&gt;&lt;/i&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;" over inventing answers as that's what I'd expect a colleague&amp;nbsp;to do. &amp;nbsp;&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;div&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;&lt;span class="Apple-style-span" style="font-family: 'Times New Roman';"&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;&lt;span class="Apple-style-span" style="font-family: 'Times New Roman';"&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;It's really important to tailor questions to each candidate. &amp;nbsp;I'm a strong believer that a smart, experienced developer can pickup new frameworks, APIs, etc, so a lot of these questions are not Java specific.&lt;/span&gt;&lt;/span&gt;&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;Know the answers to any of these? :)&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;div&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;&lt;span class="Apple-style-span" style="font-size: x-large;"&gt;Difference Questions&lt;/span&gt;&lt;/span&gt;&lt;br /&gt;
&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;br /&gt;
&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;These are really great kinds of questions,&amp;nbsp;candidates can talk approach the answer however they feel comfortable and aren't required to give "definitions" of things.&lt;/span&gt;&lt;br /&gt;
&lt;br /&gt;
&lt;ol&gt;&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;What's the difference between TCP and UDP? (if they know, follow up asking about&amp;nbsp;UDP vs ICMP)&lt;/span&gt;&lt;/li&gt;
&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;What's the difference between Bandwidth and Latency?&lt;/span&gt;&lt;/li&gt;
&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;What's the difference between an Inner Join and an Outer Join?&lt;/span&gt;&lt;/li&gt;
&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;What's the difference between NoClassDefFoundError &amp;nbsp;and ClassNotFoundException?&lt;/span&gt;&lt;/li&gt;
&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;What's the difference between SAX and DOM?&lt;/span&gt;&lt;/li&gt;
&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;What's the difference between a Thread and Process?&lt;/span&gt;&lt;/li&gt;
&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;Order from slowest to fastest: register read, disk seek, context switch, read from main memory.&lt;/span&gt;&lt;/li&gt;
&lt;/ol&gt;&lt;div&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;&lt;span class="Apple-style-span" style="font-size: x-large;"&gt;Design Questions&lt;/span&gt;&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;/div&gt;&lt;ol&gt;&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;Let's say you're reviewing (or writing) a simple system that requests an email address, a password and comments (in a textarea) then stores those values in a database. Pretending performance isn't an issue, what kinds of things would you ensure in place before it went live?&lt;/span&gt;&lt;i&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;Sometimes candidates would need some assistance on topics (security, usability, database schemas).&lt;/span&gt;&lt;/i&gt;&lt;/li&gt;
&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;Let's say McDonald's has asked you to develop their "N millions served" counter for their main website. &amp;nbsp;This value comes from a slower system (via HTTP). &amp;nbsp;Talk a bit about how you would design this. &amp;nbsp;&lt;/span&gt;&lt;/li&gt;
&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;How do you traverse a cyclic graph?&lt;/span&gt;&lt;/li&gt;
&lt;/ol&gt;&lt;div&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;&lt;span class="Apple-style-span" style="font-size: x-large;"&gt;Java Specific Questions&lt;/span&gt;&lt;/span&gt;&lt;/div&gt;&lt;ol&gt;&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;What is autoboxing? Had any problems with it?&lt;/span&gt;&lt;/li&gt;
&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;Every worked with JMS topic/queue, clustered?&lt;/span&gt;&lt;/li&gt;
&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;How are Servlets and JSPs different?&lt;/span&gt;&lt;/li&gt;
&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;What does 'final' mean? &amp;nbsp;Ever worked with a class marked final? (&lt;i&gt;bonus points if they laugh on the second question&lt;/i&gt;)&lt;/span&gt;&lt;/li&gt;
&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;What does 'static' mean?&lt;/span&gt;&lt;/li&gt;
&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;List and describe different access modifiers.&lt;/span&gt;&lt;/li&gt;
&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;How would you diagnose a memory leak?&lt;/span&gt;&lt;/li&gt;
&lt;/ol&gt;&lt;div&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;&lt;span class="Apple-style-span" style="font-size: x-large;"&gt;Random Grab-Bag Questions&lt;/span&gt;&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;A bit of systems, object-orienteering, and such.&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;ol&gt;&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;How do you check error conditions in bash? (&lt;i&gt;If they list shell scripting&lt;/i&gt;)&lt;/span&gt;&lt;/li&gt;
&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;What's the difference between lazy and greedy regular expressions?&lt;/span&gt;&lt;/li&gt;
&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;What's a context switch?&lt;/span&gt;&lt;/li&gt;
&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;Ever worked on an "AJAX"y system? &amp;nbsp;What challenges did you run into? (&lt;i&gt;a little bit dated now I guess!&lt;/i&gt;)&lt;/span&gt;&lt;/li&gt;
&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;What's a deadlock?&amp;nbsp; How do you prevent deadlocks?&lt;/span&gt;&lt;/li&gt;
&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;What is Polymorphism?&lt;/span&gt;&lt;/li&gt;
&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;What are the characteristics of a singleton?&lt;/span&gt;&lt;/li&gt;
&lt;/ol&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;&lt;span class="Apple-style-span" style="font-size: x-large;"&gt;General Opinion/Discussion Questions&lt;/span&gt;&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;/div&gt;&lt;ol&gt;&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;What makes a good build tool?&amp;nbsp; What makes a bad build tool?&lt;/span&gt;&lt;/li&gt;
&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;What's your favourite/least favourite API/package? Why?&lt;/span&gt;&lt;/li&gt;
&lt;li&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;Have you worked on a high-volume system before? &amp;nbsp;What is "high volume" to you?&lt;/span&gt;&lt;/li&gt;
&lt;/ol&gt;&lt;div&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;What have you been asked before?&lt;/span&gt;&lt;/div&gt;&lt;div&gt;&lt;span class="Apple-style-span" style="font-family: Verdana, sans-serif;"&gt;&lt;br /&gt;
&lt;/span&gt;&lt;/div&gt;&lt;/div&gt;&lt;/div&gt;&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/idcmp?a=9WPcrgKs-QE:-qXdyF7usi8:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/idcmp?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/idcmp/~4/9WPcrgKs-QE" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://idcmp.linuxstuff.org/feeds/7686701389836877995/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=30950679&amp;postID=7686701389836877995" title="4 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/7686701389836877995?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/7686701389836877995?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/idcmp/~3/9WPcrgKs-QE/my-java-developer-interview-questions.html" title="My Java Developer Interview Questions" /><author><name>Idcmp</name><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>4</thr:total><feedburner:origLink>http://idcmp.linuxstuff.org/2010/02/my-java-developer-interview-questions.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CEcNSX0_eyp7ImA9WxBVGEo.&quot;"><id>tag:blogger.com,1999:blog-30950679.post-5123809186451034053</id><published>2010-02-22T12:53:00.002-08:00</published><updated>2010-02-22T12:54:58.343-08:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2010-02-22T12:54:58.343-08:00</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="programming" /><title>97 Things Every Programmer Should Know</title><content type="html">Short on the heels of the now-lost 97 Things Every Software Architect Should Know comes a similar list for developers. &amp;nbsp;It covers a wide variety of ideas from ethics and requirements to code formatting and testing. &amp;nbsp;You can &lt;a href="http://oreilly.com/catalog/9780596809485/"&gt;buy it from O'Reilly&lt;/a&gt; or check out the &lt;a href="http://programmer.97things.oreilly.com/wiki/index.php/Contributions_Appearing_in_the_Book"&gt;97 things online&lt;/a&gt;.&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/idcmp?a=-Jw6IyK1L4Q:ptfoOEdxKH4:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/idcmp?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/idcmp/~4/-Jw6IyK1L4Q" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://idcmp.linuxstuff.org/feeds/5123809186451034053/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=30950679&amp;postID=5123809186451034053" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/5123809186451034053?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/5123809186451034053?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/idcmp/~3/-Jw6IyK1L4Q/97-things-every-programmer-should-know.html" title="97 Things Every Programmer Should Know" /><author><name>Idcmp</name><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>0</thr:total><feedburner:origLink>http://idcmp.linuxstuff.org/2010/02/97-things-every-programmer-should-know.html</feedburner:origLink></entry><entry gd:etag="W/&quot;C0EMQnkyeyp7ImA9WxBXFk4.&quot;"><id>tag:blogger.com,1999:blog-30950679.post-1201668331325727657</id><published>2010-01-26T13:10:00.012-08:00</published><updated>2010-01-27T14:34:43.793-08:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2010-01-27T14:34:43.793-08:00</app:edited><title>Four Easy and Practical Tips When Visiting Vancouver for the 2010 Winter Olympics</title><content type="html">I've lived in Vancouver for a while now, and realize that you (and 2.3 million of your closest friends) may be coming to visit for the Winter Olympics.  Here are some dead easy tidbits that will make your stay more enjoyable. You may want to bookmark this post for while you're here.&lt;br /&gt;&lt;h2&gt;Tip #1: Eating&lt;/h2&gt;Typical Vancouver food is Japanese food, mainly &lt;a href="http://maps.google.ca/maps?f=q&amp;amp;source=s_q&amp;amp;hl=en&amp;amp;geocode=&amp;amp;q=sushi&amp;amp;sll=49.278837,-123.134851&amp;amp;sspn=0.043339,0.073986&amp;amp;ie=UTF8&amp;amp;radius=1.67&amp;amp;rq=1&amp;amp;ev=zi&amp;amp;hq=sushi&amp;amp;hnear=&amp;amp;ll=49.277885,-123.130045&amp;amp;spn=0.04334,0.073986&amp;amp;z=14"&gt;sushi&lt;/a&gt;.  There are &lt;i&gt;many&lt;/i&gt; good, cheap Japanese/Sushi places all over the city. If you've never had Japanese food before (and you're nervous), check out the all-you-can-eat places that offer appetizer sizes of anything. Leaving Vancouver without at least trying would be pretty close to a crime.&lt;br /&gt;&lt;br /&gt;Once you've had your fill of sushi, use &lt;a href="http://www.urbanspoon.com/c/14/Vancouver-restaurants.html"&gt;Urban Spoon&lt;/a&gt; to find other places to eat (&lt;a href="http://dinehere.ca/vancouver/"&gt;Dine Here&lt;/a&gt; is good too - but a little less friendly).  If you like greasy-spoon breakfasts, try &lt;a href="http://www.urbanspoon.com/r/14/452299/restaurant/Robson-Street-West-End/Joes-Grill-Vancouver"&gt;Joe's Grill&lt;/a&gt; or &lt;a href="http://www.urbanspoon.com/r/14/180204/restaurant/Hastings-Sunrise/Bons-Off-Broadway-Vancouver"&gt;&lt;span class="blsp-spelling-error" id="SPELLING_ERROR_0"&gt;Bon's&lt;/span&gt; Off Broadway&lt;/a&gt;. I like &lt;a href="http://www.urbanspoon.com/r/14/181802/restaurant/Downtown/Templeton-Vancouver"&gt;Templeton&lt;/a&gt; (don't let its appearance deceive you!) and &lt;a href="http://www.urbanspoon.com/r/14/180953/restaurant/Robson-Street-West-End/Kams-Place-Vancouver"&gt;&lt;span class="blsp-spelling-error" id="SPELLING_ERROR_1"&gt;Kam's&lt;/span&gt; Place&lt;/a&gt; (tasty Singaporean food) but they're probably going to be packed while you're here. &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_2"&gt;&lt;br /&gt;&lt;br /&gt;Kam's&lt;/span&gt; Place has had a two-for-one coupon near the back of the &lt;a href="http://www.straight.com/"&gt;Georgia Straight&lt;/a&gt; (weekly free Vancouver newspaper) every week for the past five years.  Lastly, there are a number of delicious restaurants in the Commercial Drive area.&lt;br /&gt;&lt;br /&gt;&lt;span class="blsp-spelling-error" id="SPELLING_ERROR_3"&gt;Your&lt;/span&gt; life will be just as fulfilling if you didn't go to Denny's or White Spot.&lt;br /&gt;&lt;br /&gt;Don't forget grocery stores for when you just want to pick up some snacks on the go. Vancouver has a few chains including &lt;a href="http://maps.google.ca/maps?q=iga,+vancouver"&gt;&lt;span class="blsp-spelling-error" id="SPELLING_ERROR_4"&gt;IGA&lt;/span&gt;&lt;/a&gt;, &lt;a href="http://maps.google.ca/maps?q=safeway,vancouver"&gt;Safeway&lt;/a&gt;, &lt;a href="http://maps.google.ca/maps?q=save+on+foods,vancouver"&gt;Save On Foods&lt;/a&gt;, &lt;a href="http://maps.google.ca/maps?q=urban+fare,vancouver"&gt;Urban Fare&lt;/a&gt;.&lt;br /&gt;&lt;br /&gt;If you're from outside Canada and want to try "Canadian food", don't ask us. Most of us will have no idea. Look around for &lt;a href="http://en.wikipedia.org/wiki/Nanaimo_bar"&gt;&lt;span class="blsp-spelling-error" id="SPELLING_ERROR_5"&gt;nanaimo&lt;/span&gt; bars&lt;/a&gt;, &lt;a href="http://en.wikipedia.org/wiki/Poutine"&gt;&lt;span class="blsp-spelling-error" id="SPELLING_ERROR_6"&gt;poutine&lt;/span&gt;&lt;/a&gt;, &lt;a href="http://en.wikipedia.org/wiki/Bannock_%28food%29"&gt;bannock&lt;/a&gt;, &lt;a href="http://en.wikipedia.org/wiki/Tourti%C3%A8re"&gt;tourtiere&lt;/a&gt;, &lt;a href="http://images.google.ca/images?q=lobster%20rolls"&gt;lobster rolls&lt;/a&gt;, &lt;a href="http://images.google.ca/images?q=steamed+fiddleheads"&gt;steamed &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_7"&gt;fiddleheads&lt;/span&gt;&lt;/a&gt;, and &lt;a href="http://images.google.ca/images?q=maple+sugar+pie"&gt;maple sugar pie&lt;/a&gt; - all genuinely Canadian. (If you've got a sweet tooth, seek out &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_8"&gt;nanaimo&lt;/span&gt; bars).  Vancouver also has a number of local breweries, and BC has a number of wineries.&lt;br /&gt;&lt;br /&gt;With over 120 Starbucks in Vancouver, we're definitely a coffee-culture city. Other chains include Waves and &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_9"&gt;Blenz&lt;/span&gt; (both offering free &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_10"&gt;wifi&lt;/span&gt;), as well as the more ubiquitous Tim Horton's (origin of the term &lt;a href="http://www.urbandictionary.com/define.php?term=Double-Double"&gt;double double&lt;/a&gt;). If you're a Starbucks &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_11"&gt;fanboy&lt;/span&gt;, I encourage you to make your way to the corner of &lt;a href="http://maps.google.ca/maps?f=q&amp;amp;source=s_q&amp;amp;hl=en&amp;amp;geocode=&amp;amp;q=Robson+St+%26+Thurlow+St,+Vancouver,+BC&amp;amp;sll=49.276522,-123.12519&amp;amp;sspn=0.011633,0.018497&amp;amp;ie=UTF8&amp;amp;hq=&amp;amp;hnear=Robson+St+%26+Thurlow+St,+Vancouver,+Greater+Vancouver+Regional+District,+British+Columbia&amp;amp;ll=49.284523,-123.124622&amp;amp;spn=0.002908,0.004624&amp;amp;z=18"&gt;Robson and &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_12"&gt;Thurlow&lt;/span&gt;&lt;/a&gt; - a famous intersection with &lt;span style="font-weight: bold;"&gt;two Starbuckseseses&lt;/span&gt;.&lt;br /&gt;&lt;br /&gt;&lt;h2&gt;Tip #2: Getting Around&lt;/h2&gt;&lt;span style="font-weight: bold;"&gt;Don't Drive&lt;/span&gt;.  I really can't stress this enough.  The city has recently extended pay-parking hours to 10pm - seven days a week &lt;span style="font-style: italic;"&gt;everywhere&lt;/span&gt; in the city.  Even without the 2.3 million additional people, driving in Vancouver is a pain.  I've read somewhere that all tickets to Olympic events include transportation to/from the event.  Please check into this!&lt;br /&gt;&lt;br /&gt;Public transportation in Vancouver is run by &lt;a href="http://www.translink.ca/"&gt;&lt;span class="blsp-spelling-error" id="SPELLING_ERROR_13"&gt;TransLink&lt;/span&gt;&lt;/a&gt;.  It includes buses, subways (Canada Line), light rail (&lt;span class="blsp-spelling-error" id="SPELLING_ERROR_14"&gt;SkyTrain&lt;/span&gt;) and ferries (&lt;span class="blsp-spelling-error" id="SPELLING_ERROR_15"&gt;SeaBus&lt;/span&gt;).  &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_16"&gt;TransLink&lt;/span&gt; fares work on a "zone" system.  Your fare corresponds to how many zones you'll be travelling through.  I found a pretty good &lt;a href="http://members.shaw.ca/david.marlor/vrt2009.jpg"&gt;&lt;span class="blsp-spelling-error" id="SPELLING_ERROR_17"&gt;TransLink&lt;/span&gt; Map&lt;/a&gt;.  As a rule, &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_18"&gt;SkyTrain&lt;/span&gt; and Canada Line stops have fare machines which accept &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_19"&gt;Interac&lt;/span&gt;, credit card and Canadian cash. Buses are exact-fare.&lt;br /&gt;&lt;br /&gt;Google Maps has a "Directions by Transit" for getting around the city.  I encourage you to use this as a &lt;span style="font-style: italic;"&gt;backup&lt;/span&gt; during the Olympics as some operating changes just for the Olympics have been made and I'm not sure if Google has been updated.  Instead, use the pretty decent&lt;br /&gt;&lt;a href="http://tripplanning.translink.ca/"&gt;&lt;span class="blsp-spelling-error" id="SPELLING_ERROR_20"&gt;TransLink&lt;/span&gt; Trip Planner&lt;/a&gt;.&lt;br /&gt;&lt;br /&gt;If you don't have prepaid tickets (&lt;span class="blsp-spelling-error" id="SPELLING_ERROR_21"&gt;FareCards&lt;/span&gt;), there will be a $5 surcharge (per person) traveling from the airport on &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_22"&gt;TransLink&lt;/span&gt; (via the Canada Line).  It's still cheaper than taking a taxi.  If you see someone at the airport selling &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_23"&gt;FareCards&lt;/span&gt;, you may want to take them up on the offer.  To ensure it's legit, make sure the magnetic stripe side of the &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_24"&gt;FareCard&lt;/span&gt; doesn't already have an expiry time printed on it.&lt;br /&gt;&lt;br /&gt;If you use the Trip Planner and you see "get off one &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_25"&gt;SkyTrain&lt;/span&gt;, get on another &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_26"&gt;SkyTrain&lt;/span&gt;" around Broadway-Commercial, I will confess it is a bit confusing the first time you do so, but you won't be alone in the necessary confusion.  It's all well-marked.&lt;br /&gt;&lt;br /&gt;Looking for something kinda fun to do? There is a &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_27"&gt;SeaBus&lt;/span&gt; that goes from &lt;a href="http://maps.google.ca/maps?f=d&amp;amp;source=s_d&amp;amp;saddr=Waterfront+Stn+SeaBus+Northbound&amp;amp;daddr=Lonsdale+Quay+SeaBus+Northbound&amp;amp;geocode=%3BFVdp8AIdrOap-ClbpOsjs3GGVDFaRk5fSs86sQ&amp;amp;hl=en&amp;amp;mra=ls&amp;amp;dirflg=r&amp;amp;date=10%2F01%2F26&amp;amp;time=14:25&amp;amp;ttype=dep&amp;amp;noexp=0&amp;amp;noal=0&amp;amp;sort=&amp;amp;tline=&amp;amp;sll=49.286084,-123.110213&amp;amp;sspn=0.002908,0.004624&amp;amp;ie=UTF8&amp;amp;ll=49.293953,-123.093052&amp;amp;spn=0.046517,0.073986&amp;amp;t=h&amp;amp;z=14&amp;amp;start=0"&gt;Waterfront to &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_28"&gt;Lonsdale&lt;/span&gt;&lt;/a&gt;, it's a two-zone ride (cheaper on the weekends).  It's a fun little ride.  The &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_29"&gt;Lonsdale&lt;/span&gt; side has a market with fresh food stuffs too.  You'll have a nice view of downtown from the &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_30"&gt;Lonsdale&lt;/span&gt; side too.  Great on a sunny day!&lt;br /&gt;&lt;br /&gt;When walking downtown, streets that run NW/SE are just generally referred to as "North" or "South" by &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_32"&gt;downtowners&lt;/span&gt;.  "If you can see the mountains, you're facing North." is a rule many locals have.  I think (at least downtown) locals are pretty happy to help a lost soul.&lt;br /&gt;&lt;br /&gt;Lastly, if you can avoid taking public transportation from 7am-10am and from 3pm-6pm, those of us going to work would greatly appreciate it. :-)&lt;br /&gt;&lt;br /&gt;If you are driving, and you're from outside BC, you'll want to know about our &lt;a href="http://blog.webfoot.com/2006/11/22/flashing-green-lights/"&gt;BC traffic lights&lt;/a&gt;.&lt;br /&gt;&lt;br /&gt;&lt;h2&gt;Tip #3: Weather&lt;/h2&gt;Vancouver is generally a rainy city.  The outskirts are cold enough to get snow, but usually not a lot.  If you want to see what it looks like right now in Vancouver, the popular and mostly reliable &lt;a href="http://www.katkam.ca/"&gt;Kat &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_33"&gt;Kam&lt;/span&gt;&lt;/a&gt; web cam is a great start.&lt;br /&gt;&lt;br /&gt;I pretty much swear by Environment Canada's &lt;a href="http://www.weatheroffice.gc.ca/city/pages/bc-74_metric_e.html"&gt;Vancouver Seven Day Forecast&lt;/a&gt;.&lt;br /&gt;&lt;br /&gt;Dress in layers (guys too), but leave your umbrella at home.  Instead, bring a long a hooded rain jacket.  You'll navigate the sidewalks a lot more effectively and you're not likely to leave your jacket behind somewhere.&lt;br /&gt;&lt;br /&gt;Locals tend to need higher amounts of rain to trigger their "I should put my hood up" feeling.&lt;br /&gt;&lt;br /&gt;Vancouver is stunning when it's sunny out.  If you can, make your way to the &lt;a href="http://maps.google.ca/maps?f=q&amp;amp;source=s_q&amp;amp;hl=en&amp;amp;geocode=&amp;amp;q=4608+Cypress+Bowl+Rd,+West+Vancouver,+BC&amp;amp;sll=49.35363,-123.179376&amp;amp;sspn=0.011615,0.018497&amp;amp;g=4608+Cypress+Bowl+Rd&amp;amp;ie=UTF8&amp;amp;hq=&amp;amp;hnear=4608+Cypress+Bowl+Rd,+West+Vancouver,+Greater+Vancouver+Regional+District,+British+Columbia&amp;amp;ll=49.351142,-123.17723&amp;amp;spn=0.011616,0.018497&amp;amp;t=h&amp;amp;z=16"&gt;Lookout at Cypress Mountain&lt;/a&gt; for pretty much the best view of Vancouver day or night.&lt;br /&gt;&lt;h2&gt;Tip #4: Blending In&lt;/h2&gt;Here are some random tips you may want to keep in mind:&lt;br /&gt;&lt;br /&gt;Just like the Tube, &lt;span class="blsp-spelling-error" id="SPELLING_ERROR_34"&gt;Vancouverites&lt;/span&gt; follow "Stand to the side to let people out before getting on" for public transportation.  If you do this too, you'll blend in a lot better.&lt;br /&gt;&lt;br /&gt;Most people here don't speak French; there are easily more Chinese/Japanese/Korean speakers than French speakers in Vancouver.&lt;br /&gt;&lt;br /&gt;Generally speaking in the rain, if you're without a hooded jacket or umbrella, walk nearest to buildings. If you've got an umbrella, walk &lt;span class="blsp-spelling-corrected" id="SPELLING_ERROR_35"&gt;furthermost&lt;/span&gt; from buildings.&lt;br /&gt;&lt;br /&gt;On stairs and escalators, we follow the "stand on the right, walk on the left" rule.&lt;br /&gt;&lt;br /&gt;The weather is a popular conversation topic and can be used to talk to just about anyone - especially if it's nice out!&lt;br /&gt;&lt;br /&gt;&lt;h2&gt;That's It&lt;/h2&gt;Enjoy your trip!  And if you're looking for someone to go for sushi with, drop me an email. :-)&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/idcmp?a=EnzU9pZbOOg:GrUwKEi1x1o:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/idcmp?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/idcmp/~4/EnzU9pZbOOg" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://idcmp.linuxstuff.org/feeds/1201668331325727657/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=30950679&amp;postID=1201668331325727657" title="1 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/1201668331325727657?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/1201668331325727657?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/idcmp/~3/EnzU9pZbOOg/four-easy-and-practical-tips-when.html" title="Four Easy and Practical Tips When Visiting Vancouver for the 2010 Winter Olympics" /><author><name>Idcmp</name><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>1</thr:total><feedburner:origLink>http://idcmp.linuxstuff.org/2010/01/four-easy-and-practical-tips-when.html</feedburner:origLink></entry><entry gd:etag="W/&quot;DUQCRH4_eCp7ImA9WxVbF04.&quot;"><id>tag:blogger.com,1999:blog-30950679.post-4187149614066667587</id><published>2009-04-02T22:35:00.002-07:00</published><updated>2009-04-02T22:42:45.040-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2009-04-02T22:42:45.040-07:00</app:edited><title>Xen vs KVM</title><content type="html">I wanted to chime in on the Xen vs. KVM discussions, and give you some food for thought.&lt;br /&gt;&lt;br /&gt;I've been using Xen now for years, having replaced UserModeLinux on my personal server, and it's seen a lot of production use at my current job.  &lt;br /&gt;&lt;br /&gt;That said, KVM is ultimately the right way to go. Constant maintenance of Xen's hypervisor kernel is what causes Linux distributions grief with Xen.  Those that keep doing it, do so because it's performant, tested and well-understood.&lt;br /&gt;&lt;br /&gt;So you're stuck wondering which virtualization technology you should pick.  Here it is: &lt;a href="http://libvirt.org/"&gt;libvirt&lt;/a&gt; (with Xen).&lt;br /&gt;&lt;br /&gt;Base your toolset, deployment, configuration, and maintenance on libvirt, and use the Xen hypervisor for now.&lt;br /&gt;&lt;br /&gt;libvirt provides an easy upgrade path from Xen to KVM once KVM's performance and stability have been battle hardened. Same virtual machine configuration, same provisioning, same disk images.  Just grab a new kernel, change which hypervisor you're using and you'll be in the land of tomorrow.&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/idcmp?a=G0bWwEeEiO0:f0hFv58CUKc:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/idcmp?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/idcmp/~4/G0bWwEeEiO0" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://idcmp.linuxstuff.org/feeds/4187149614066667587/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=30950679&amp;postID=4187149614066667587" title="4 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/4187149614066667587?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/4187149614066667587?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/idcmp/~3/G0bWwEeEiO0/xen-vs-kvm.html" title="Xen vs KVM" /><author><name>Idcmp</name><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>4</thr:total><feedburner:origLink>http://idcmp.linuxstuff.org/2009/04/xen-vs-kvm.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CkIFR3s6fip7ImA9WxVSEU8.&quot;"><id>tag:blogger.com,1999:blog-30950679.post-4456828730153334798</id><published>2009-01-04T16:46:00.007-08:00</published><updated>2009-01-04T17:55:16.516-08:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2009-01-04T17:55:16.516-08:00</app:edited><title>Provisioning Servers: An Afternoon with Cobbler</title><content type="html">I spent some time evaluating Fedora's &lt;a href="https://fedorahosted.org/cobbler/"&gt;Cobbler&lt;/a&gt; installation service. If you play with many machines - real or virtual - you should definitely take a look. Some handy features:&lt;br /&gt;&lt;br /&gt;* Kickstart Setup: For Red Hat &lt;i&gt;breed&lt;/i&gt; systems, existing Kickstart configurations (found on installation media) are exposed as &lt;b&gt;profiles&lt;/b&gt; in Cobbler.  You can add your own Kickstart configurations too (imagine a "rhel5-webserver" profile).&lt;br /&gt;&lt;br /&gt;* PXE Management: Tied in with a DHCP server, cobbler will offer profiles up for installation for servers during PXE boot (often called &lt;i&gt;Boot from network&lt;/i&gt;), since these profiles are tied with Kickstart configurations, servers can be setup or re-setup with just a few keystrokes. KVM seems to support PXE boots; less hoops for installation your VMs.&lt;br /&gt;&lt;br /&gt;* Repository Mirroring: Cobbler can take the URL to a repository and mirror it locally, both yum and apt style repositories (rpm and deb) are supported.  Use &lt;b&gt;cobbler reposync&lt;/b&gt; to keep local mirrors up to date.  &lt;br /&gt;&lt;br /&gt;* Distribution Swallowing: Cobbler can copy installation media and copy it locally.&lt;br /&gt;&lt;br /&gt;* Boot ISO / Live CD: If your server doesn't support PXE, or if tying into DHCP isn't an option, cobbler can make burnable ISOs (and thus USB thumb images) that can be used to perform network installs.&lt;br /&gt;&lt;br /&gt;* MAC Address to Profile Management: Cobbler can associate a particular MAC address with a particular profile.&lt;br /&gt;&lt;br /&gt;* Automatic Repository Setup: Cobbler can setup your local yum mirror in your newly created server automatically for you.&lt;br /&gt;&lt;br /&gt;* Triggers / Puppet Integration: Cobbler can be configured to register the new machine with puppet, or run other triggers (imagine automatic graphs in Cacti, monitoring in OpsView, etc, etc).&lt;br /&gt;&lt;br /&gt;* KOAN: Koan is a command line tool that talks with the Cobbler server. It can be used to set up new VMs (using libvirtd), or with a special &lt;b&gt;--replace-self&lt;/b&gt; option, cause an existing installation to reinstall itself.  (Only works with Red Hat breed systems.)&lt;br /&gt;&lt;br /&gt;* Zeroconf: Avahi is among one of the coolest technologies I've played with recently. Specifying &lt;b&gt;--server=DISCOVER&lt;/b&gt; on the koan command line will find the cobbler server on the network. I love stuff like that.&lt;br /&gt;&lt;br /&gt;* Configuration Cloning: Move your test environment configuration into production (or mirror for HA, etc)&lt;br /&gt;&lt;br /&gt;I really like the architecture of Cobbler too; an XMLRPC server that both the command line tools and web interface use.  The web interface is handled by Apache and mod_python, so authentication and authorization are handled by Apache (ie, basically anything you can think of).&lt;br /&gt;&lt;br /&gt;Lastly, one nice touch is &lt;b&gt;cobbler check&lt;/b&gt;.  Run right after a fresh install it checks your environment and lets you know of anything that could potentially hamper Cobbler from working.&lt;br /&gt;&lt;br /&gt;I haven't yet tried Cobbler with an existing DHCP server, and I'm not sure it supports ISC DHCP's failover capabilities (even with OMAPI).&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/idcmp?a=Hrl5rW7_7o4:jFoI89miHGg:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/idcmp?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/idcmp/~4/Hrl5rW7_7o4" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://idcmp.linuxstuff.org/feeds/4456828730153334798/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=30950679&amp;postID=4456828730153334798" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/4456828730153334798?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/4456828730153334798?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/idcmp/~3/Hrl5rW7_7o4/provisioning-servers-afternoon-with.html" title="Provisioning Servers: An Afternoon with Cobbler" /><author><name>Idcmp</name><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>0</thr:total><feedburner:origLink>http://idcmp.linuxstuff.org/2009/01/provisioning-servers-afternoon-with.html</feedburner:origLink></entry><entry gd:etag="W/&quot;C0cMR3s9eCp7ImA9WxVTFUQ.&quot;"><id>tag:blogger.com,1999:blog-30950679.post-4439859257237931845</id><published>2008-12-29T09:03:00.002-08:00</published><updated>2008-12-29T14:51:26.560-08:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2008-12-29T14:51:26.560-08:00</app:edited><title>Ye Olde Job: Technology That Wasn't</title><content type="html">Our system could accept transactions over the phone (via a clerk) or through our website.  The clerk on the phone used a semi-web based application to interact with the system.&lt;br /&gt;&lt;br /&gt;The headache with this was that the code base for the "semi-web" and "actual web" only became a common code path much, much deeper in the code. So the plan was simple, redo the website code such that it could eventually be leveraged to replace the semi-web code.&lt;br /&gt;&lt;br /&gt;We prototyped, mocked up, tested and developed a new part of the application on our website using &lt;a href="http://code.google.com/webtoolkit/"&gt;GWT&lt;/a&gt;. It went through load testing, SEO-approval and I believe we even did a couple in-company demos of the technology.&lt;br /&gt;&lt;br /&gt;The code was "done" (in the "given to QA to break" sense of the word) when I left, but when I check the website now I see it never made it to production.&lt;br /&gt;&lt;br /&gt;I cared about this for the first month or so after I left, so I pinged around to find out what happened.  The short version is that it got stuck in developer mythology, and with nobody there to lead it out, I knew it would never see the light of day.&lt;br /&gt;&lt;br /&gt;I wonder just how much technology is "done" that has never seen the real world?&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/idcmp?a=YC9jnuwfhic:Ix6ViEuC4xI:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/idcmp?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/idcmp/~4/YC9jnuwfhic" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://idcmp.linuxstuff.org/feeds/4439859257237931845/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=30950679&amp;postID=4439859257237931845" title="1 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/4439859257237931845?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/4439859257237931845?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/idcmp/~3/YC9jnuwfhic/ye-olde-job-technology-that-wasnt.html" title="Ye Olde Job: Technology That Wasn't" /><author><name>Idcmp</name><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>1</thr:total><feedburner:origLink>http://idcmp.linuxstuff.org/2008/12/ye-olde-job-technology-that-wasnt.html</feedburner:origLink></entry><entry gd:etag="W/&quot;C0EEQn0_fCp7ImA9WxVTFUQ.&quot;"><id>tag:blogger.com,1999:blog-30950679.post-2533826725614276009</id><published>2008-12-26T09:58:00.009-08:00</published><updated>2008-12-29T15:00:03.344-08:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2008-12-29T15:00:03.344-08:00</app:edited><title>Ye Olde Job: First Post - So You're the Boss</title><content type="html">It's been seven months since I left my old job, and I feel it's alright to talk about some things.&lt;br /&gt;&lt;br /&gt;If you're in a situation where you're finding yourself leading a team of developers without any mentoring from anyone on how the heck to do that, I offer you some food for thought.&lt;br /&gt;&lt;br /&gt;As a developer, you measure your own progress by the code you write, the bugs you fix, stored procedures you debug, problems you solve and features that get released.  You have days where you go home "having done nothing" because you have a dozen variables in your head and you've been nose deep in code, but whatever it is still isn't working.&lt;br /&gt;&lt;br /&gt;Or maybe you wouldn't debug the stored procedures, but instead really wish that you could replace them with something else; a nice cup of Java, easy to unit test and a breeze to step through.  &lt;br /&gt;&lt;br /&gt;One thing I figured out that really helped me: &lt;i&gt;When leading a team, put the team first.&lt;/i&gt;&lt;br /&gt;&lt;br /&gt;What the heck does that mean?&lt;br /&gt;&lt;br /&gt;It means getting to know the strengths and weaknesses of not only your team, but of the teams you interact with.  One developer has a knack at networking, another at databases, another one refactors code from a city dump into a gorgeous mansion.  When the work is important - major features on a tight timeline - use peoples strength. When it's less important - minor bugs, features that are 'nice to have' - let them work on their weaknesses. If other teams have weaknesses in areas, work to help them, or fortify against it.&lt;br /&gt;&lt;br /&gt;It means being two steps ahead of your team, knowing where you're going next.  If nobody else in your company can give you direction two steps ahead, then take matters into your own hands.  Don't just start piecemealing things; always have a vision.  If you don't know where you're going, you won't know when you've gone off course. Obviously, be flexible with your vision for that idle Wednesday when some manager presents his vision to you so you can embrace it and walk together.&lt;br /&gt;&lt;br /&gt;It means giving that improvement away. This was the hardest for me: giving up writing that feature you really wanted or fixing that bug that drives you nuts. You will write less code, but your team will write more code than you ever could. You will want to use a bit of the downtime you'll get to assign yourself some work, but you know you'll never get to it.  Use that downtime to better map out your plan, to make sure everyone has got the work they need and to fish around to see if maybe that company plan or vision is hiding somewhere... ..anywhere.. ..maybe?&lt;br /&gt;&lt;br /&gt;It means accepting shades of grey. There are many wrong ways to do things and few right ways. But there is definitely more than one right way.  The way someone on your team might craft something may not be bytecode-for-bytecode how you would do it, but it may still fall in the realm of right.  Accept that it's not how you would do it.  That's fine.  But is it wrong?&lt;br /&gt;&lt;br /&gt;It means keeping it in the team. Just like most code bases that earn a over a billion dollars, the code base I worked on was suboptimal. We all knew it, but we knew we were there not to whine about it, but to make it better. Bit by bit, day by day. Start with the biggest problems, work toward your vision.&lt;br /&gt;&lt;br /&gt;It means that stored procedure is going to stay; both the DBA and I know how to tune, monitor and troubleshoot it.  We've minimized the row locking in it and fixed a deadlock problem in the logic. Also, next week you'll be fixing it to be resilient against another team's code, because their code does table scans and table locks and it will soon be our busy season and the potential for headaches is not part of my vision.&lt;br /&gt;&lt;br /&gt;&lt;i&gt;Updated:&lt;/i&gt; While stored procedures vs ORM is part of a future post, I hope that people who are in the "You've been here the longest, you're in charge" situation can benefit a bit from keeping in mind that they need to put their team before themselves. I know it's hard to switch gears.&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/idcmp?a=RBRBY1goWVs:VzDUEfEiaWo:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/idcmp?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/idcmp/~4/RBRBY1goWVs" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://idcmp.linuxstuff.org/feeds/2533826725614276009/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=30950679&amp;postID=2533826725614276009" title="4 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/2533826725614276009?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/2533826725614276009?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/idcmp/~3/RBRBY1goWVs/ye-olde-job-first-post-so-youre-boss.html" title="Ye Olde Job: First Post - So You're the Boss" /><author><name>Idcmp</name><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>4</thr:total><feedburner:origLink>http://idcmp.linuxstuff.org/2008/12/ye-olde-job-first-post-so-youre-boss.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CUYNQ3Y_cSp7ImA9WxRVEko.&quot;"><id>tag:blogger.com,1999:blog-30950679.post-7841236467567219617</id><published>2008-11-09T10:36:00.001-08:00</published><updated>2008-11-09T15:26:32.849-08:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2008-11-09T15:26:32.849-08:00</app:edited><title>Seven Reasons I Didn't Pick Your Open Source Project</title><content type="html">After a really relaxing summer, I've picked up a job as a Systems Architect at local company suffering from growing pains. After almost a decade, I've put down my debugger and picked up a budget..for now. I've found myself &lt;a href="http://freenas.org/"&gt;looking&lt;/a&gt; &lt;a href="http://wandisco.com/"&gt;at&lt;/a&gt; &lt;a href="http://www.opengroupware.org/"&gt;many&lt;/a&gt; &lt;a href="http://www.horde.org/groupware/"&gt;different&lt;/a&gt; &lt;a href="http://www.zimbra.com/"&gt;options&lt;/a&gt; &lt;a href="http://www.microsoft.com/exchange/default.mspx"&gt;of&lt;/a&gt; &lt;a href="http://www.dell.com/content/products/category.aspx/storage"&gt;products&lt;/a&gt; &lt;a href="http://www.netapp.com/us"&gt;some&lt;/a&gt; &lt;a href="http://www.digium.com/en/"&gt;open&lt;/a&gt; &lt;a href="http://openvpn.org/"&gt;source&lt;/a&gt; &lt;a href="http://www.cisco.com/en/US/products/sw/voicesw/index.html"&gt;some&lt;/a&gt; &lt;a href="http://openfiler.com/"&gt;not&lt;/a&gt;. I want to apologize to those open source projects I've rejected and wanted to let you know why:&lt;br /&gt;&lt;br /&gt;1. Capacity Planning: You lack any realistic guidelines for server sizing. I have no idea how much memory, disk, bandwidth or cpu cycles I need to support 250 users checking their email every morning and you have no tools to simulate load.&lt;br /&gt;&lt;br /&gt;2. You're Working On the "Next Gen" Version: You've stopped working on the version people are using in order to rewrite the application using technology that follows your new beliefs. The current version is now suffering from bitrot and your new version is undergoing its third major refactoring. &lt;br /&gt;&lt;br /&gt;3. Your Community: Your forums are an abandoned town with tumbleweed rolling through waking up the sleeping armadillos. Questions go unanswered for months at a time, most of the posts are spam or people asking if the project is dead (which it is).&lt;br /&gt;&lt;br /&gt;4. Installation: Your twelve-step installation process involving a different version of Perl, MySQL, and PHP plugins I don't have is a headache. This is the world of LiveCDs, embedded servlet containers, virtual machines, Web Start, VNC, hosted-demos or at least RPM/DEB packages.&lt;br /&gt;&lt;br /&gt;5. Your Features: They're geared towards other developers and not users.  I realize you're "not M$", and it's swell you think "Not Written in Java, so it's Fast!" is important, and it's sure great that you "use AOP extensively", but if those are the features you list instead of "works through NAT","supports 802.3ad bonding" or "integrates with iCal" then you're pretty far removed from your user base.&lt;br /&gt;&lt;br /&gt;6. Maintenance Headaches: According to your documentation, your upgrade process is "Backup all data. Install new version.  Restore all data."  That's fine if "all data" is the dhcpd leases file, but not so great when it's 9TB of files that users access all day.&lt;br /&gt;&lt;br /&gt;7. Price: Your project has a "commercially supported" version. That's cool, but when the rates listed are more expensive than the defacto standard you can pretty much guarantee I'm not going to be able to sell it upwards.&lt;br /&gt;&lt;br /&gt;I'll let you know what I've picked and how it turns out in the next few months. I'm also looking for a really good Linux sysadmin. :)&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/idcmp?a=FtLf4q23CNs:-5KU_WcjBNk:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/idcmp?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/idcmp/~4/FtLf4q23CNs" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://idcmp.linuxstuff.org/feeds/7841236467567219617/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=30950679&amp;postID=7841236467567219617" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/7841236467567219617?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/7841236467567219617?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/idcmp/~3/FtLf4q23CNs/seven-reasons-i-didnt-pick-your-open.html" title="Seven Reasons I Didn't Pick Your Open Source Project" /><author><name>Idcmp</name><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>0</thr:total><feedburner:origLink>http://idcmp.linuxstuff.org/2008/11/seven-reasons-i-didnt-pick-your-open.html</feedburner:origLink></entry><entry gd:etag="W/&quot;DkcBQ3k7fip7ImA9WxRQF0g.&quot;"><id>tag:blogger.com,1999:blog-30950679.post-2377623438054508630</id><published>2008-10-11T12:35:00.002-07:00</published><updated>2008-10-11T12:40:52.706-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2008-10-11T12:40:52.706-07:00</app:edited><title>Wave Tracing: Ray Tracing for Sound</title><content type="html">Here's the pitch: With &lt;a href="http://en.wikipedia.org/wiki/Ray_tracing_(graphics)"&gt;regular ray tracing&lt;/a&gt;, rays of light are traced backward from a pixel of the camera, to an object and eventually to a light source (or lack thereof).  If you can do that with light, why can't it be done with sound?&lt;br /&gt;&lt;br /&gt;Over ten years ago I was having breakfast with a friend and I sketched out the idea on a napkin. This kind of math is definitely not my strong point. But instead of a camera, have a microphone.  Instead of tracing rays, trace vibrations, and instead of light sources, there's air and friction; or so the napkin said.&lt;br /&gt;&lt;br /&gt;Instruments aren't the goal, but a simple model to test would be a &lt;a href="http://en.wikipedia.org/wiki/Recorder"&gt;&lt;br /&gt;grade school caliber recorder&lt;/a&gt;. After modeling materials, blown air resonates down the tube of the recorder generating sound.&lt;br /&gt;&lt;br /&gt;As different quality of air and different materials are created, artists build wireframes of different instruments. The effects of room acoustics could be modeled too.&lt;br /&gt;&lt;br /&gt;This would culminate in a completely rendered orchestra performing a wave traced rendition of Beethoven's Symphony No 5.&lt;br /&gt;&lt;br /&gt;As I mentioned earlier, instruments aren't the goal: Voices are.&lt;br /&gt;&lt;br /&gt;After modeling complex instruments, the next step is to model and animate the speech pathway from lungs to lips. The speech animated model (or "Sam" for short) would start with simple vowels like the [a:] sound in raw, or the [æ] sound in "bad".  (Wikipedia's page on the &lt;a href='http://en.wikipedia.org/wiki/International_Phonetic_Alphabet'&gt;IPA&lt;/a&gt; has some good introductory information). Eventually Sam would be animated to fluidly pronounce most phonemes. Linguistics are also not my strong point.&lt;br /&gt;&lt;br /&gt;I'd imagine that Sam would sound very lifeless and flat. So we would capture data from sensors attached to voice model actors. Voice capture artists would smooth out the data and bring Sam to life.  Motion capture is also not my strong point.&lt;br /&gt;&lt;br /&gt;With only a handful of voice model actors, spoken phrases could be captured for an entire movie or video game! The captured data could be applied to dozens or hundreds of different sounding models by adjusting Sam's variables. Accents would easy to add by changing the way Sam enunciates words. Playing with Sam's breathing rate would simulate a person out of breath or scared. Sam's voice could be lowered or raised or even modeled after a real person.&lt;br /&gt;&lt;br /&gt;Eventually the captured data could be used to animate 3D model too!&lt;br /&gt;&lt;br /&gt;This would be a perfect for RPG games like &lt;a href='http://www.elderscrolls.com/home/home.php'&gt;Oblivion&lt;/a&gt; or &lt;a href='http://en.wikipedia.org/wiki/Grand_Theft_Auto'&gt;GTA&lt;/a&gt; that can benefit from an almost endless supply of different voices.&lt;br /&gt;&lt;br /&gt;Let me know if you ever do anything with this, or find something that does.  Especially if you're &lt;a href='http://www.bethsoft.com/'&gt;Bethesda&lt;/a&gt;!&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/idcmp?a=ypUM45MssiA:AwkKFnPAW3k:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/idcmp?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/idcmp/~4/ypUM45MssiA" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://idcmp.linuxstuff.org/feeds/2377623438054508630/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=30950679&amp;postID=2377623438054508630" title="6 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/2377623438054508630?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/2377623438054508630?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/idcmp/~3/ypUM45MssiA/wave-tracing-ray-tracing-for-sound.html" title="Wave Tracing: Ray Tracing for Sound" /><author><name>Idcmp</name><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>6</thr:total><feedburner:origLink>http://idcmp.linuxstuff.org/2008/10/wave-tracing-ray-tracing-for-sound.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CUUNRHk5eCp7ImA9WxRRFEs.&quot;"><id>tag:blogger.com,1999:blog-30950679.post-2704391621386087854</id><published>2008-09-26T14:08:00.000-07:00</published><updated>2008-09-26T14:08:15.720-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2008-09-26T14:08:15.720-07:00</app:edited><category scheme="http://www.blogger.com/atom/ns#" term="java" /><category scheme="http://www.blogger.com/atom/ns#" term="gwt" /><title>GWT: Generators HowTo (BuildStamp)</title><content type="html">If you're curious what generators are, or have never used them with GWT, this simple generator will give you a quick introduction to get your hamster wheels turning.&lt;br /&gt;&lt;br /&gt;I do a lot of prototyping in GWT before I build the backend and I've recently had the need to generate a "build version" for my GWT interface.  While there are about fiftybazillionmillion different ways to do this, I've chosen a GWT generator to create a buildstamp.  This&lt;br /&gt;lets me tar up the www results of clicking on "Compile/Browse" and fire them off for others to play.  &lt;br /&gt;&lt;br /&gt;In your Java code, you just add:&lt;br /&gt;&lt;pre&gt;&lt;br /&gt;          ...&lt;br /&gt;          BuildStamp buildStamp = GWT.create(BuildStamp.class);&lt;br /&gt;          yourLogo.setTitle(buildStamp.getBuildStamp());&lt;br /&gt;          ... &lt;br /&gt;&lt;/pre&gt;&lt;br /&gt;This will add a tooltip to &lt;b&gt;yourLogo&lt;/b&gt; which looks like: "&lt;b&gt;Built on kikai.linuxstuff.org at Tue Jul 29 19:07:05 PDT 2008&lt;/b&gt;".  &lt;br /&gt;&lt;br /&gt;When you compile your GWT application the generator is compiled and run. It generates Java code which is converted to JavaScript along with the rest of your application.  When this happens the timestamp is "frozen".&lt;br /&gt;&lt;br /&gt;Code and wiring follows. Imports omitted, use your favourite IDE to fill them in. This makes a pretty simple Hello World example.&lt;br /&gt;&lt;br /&gt;Comments are more than welcome. &lt;br /&gt;&lt;pre style="background-color:white; overflow:scroll;width:440px;border: 1px solid black;"&gt;package org.example.rebind;&lt;br /&gt;&lt;br /&gt;public class BuildStampGenerator extends Generator {&lt;br /&gt;&lt;br /&gt;        private String className;&lt;br /&gt;        private String packageName;&lt;br /&gt;&lt;br /&gt;        @Override&lt;br /&gt;        public String generate(TreeLogger logger, GeneratorContext context, String typeName)&lt;br /&gt;                        throws UnableToCompleteException {&lt;br /&gt;&lt;br /&gt;                try {&lt;br /&gt;&lt;br /&gt;                        TypeOracle typeOracle = context.getTypeOracle();&lt;br /&gt;                        JClassType classType = typeOracle.getType(typeName);&lt;br /&gt;                        packageName = classType.getPackage().getName();&lt;br /&gt;                        className = classType.getSimpleSourceName() + "Impl";&lt;br /&gt;&lt;br /&gt;                        generateClass(logger, context);&lt;br /&gt;&lt;br /&gt;                } catch (Exception e) {&lt;br /&gt;                        logger.log(TreeLogger.ERROR, "Exception during BuildStamp creation.", e);&lt;br /&gt;                }&lt;br /&gt;&lt;br /&gt;                return packageName + "." + className;&lt;br /&gt;&lt;br /&gt;        }&lt;br /&gt;&lt;br /&gt;        private void generateClass(TreeLogger logger, GeneratorContext context) {&lt;br /&gt;&lt;br /&gt;                PrintWriter printWriter = context.tryCreate(logger, packageName, className);&lt;br /&gt;&lt;br /&gt;                /* Returns null if the package has already been generated. */&lt;br /&gt;                if (printWriter == null) {&lt;br /&gt;                        return;&lt;br /&gt;                }&lt;br /&gt;&lt;br /&gt;                ClassSourceFileComposerFactory composer =&lt;br /&gt;                  new ClassSourceFileComposerFactory(packageName, className);&lt;br /&gt;&lt;br /&gt;                // shouldn't magic just happen here?&lt;br /&gt;                composer.addImplementedInterface(BuildStamp.class.getCanonicalName());&lt;br /&gt;&lt;br /&gt;                SourceWriter sourceWriter = composer.createSourceWriter(context, printWriter);&lt;br /&gt;&lt;br /&gt;                writeGetBuildStamp(sourceWriter);&lt;br /&gt;&lt;br /&gt;                sourceWriter.outdent();&lt;br /&gt;                sourceWriter.println("}");&lt;br /&gt;&lt;br /&gt;                context.commit(logger, printWriter);&lt;br /&gt;&lt;br /&gt;        }&lt;br /&gt;&lt;br /&gt;        /**&lt;br /&gt;         * Write the source code for {@code BuildStamp#getBuildStamp()}.&lt;br /&gt;         */&lt;br /&gt;        private void writeGetBuildStamp(SourceWriter sourceWriter) {&lt;br /&gt;                sourceWriter.println("public String getBuildStamp() {");&lt;br /&gt;                sourceWriter.println(" return \"" + Generator.escape(getBuildStamp()) + "\";");&lt;br /&gt;                sourceWriter.println("}");&lt;br /&gt;        }&lt;br /&gt;&lt;br /&gt;        /**&lt;br /&gt;         * Executed at *compile* time, this generates a string that is embedded in the&lt;br /&gt;         * generated class. In hosted mode, this code is rebuilt each Refresh.&lt;br /&gt;         *&lt;br /&gt;         * @return A user-friendly build string, good for hiding in tooltips.&lt;br /&gt;         */&lt;br /&gt;        String getBuildStamp() {&lt;br /&gt;                StringBuilder msg = new StringBuilder();&lt;br /&gt;                msg.append("Built on ");&lt;br /&gt;                try {&lt;br /&gt;                        String hostname = InetAddress.getLocalHost().getCanonicalHostName();&lt;br /&gt;                        msg.append(hostname);&lt;br /&gt;                } catch (UnknownHostException e) {&lt;br /&gt;                        msg.append("(hostname not available)");&lt;br /&gt;                }&lt;br /&gt;                msg.append(" at ");&lt;br /&gt;                msg.append(new Date());&lt;br /&gt;                return msg.toString();&lt;br /&gt;        }&lt;br /&gt;&lt;br /&gt;}&lt;br /&gt;&lt;/pre&gt;&lt;br /&gt;You will need a BuildStamp interface:&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;pre style="background-color:white; overflow:scroll;width:440px;border: 1px solid black;"&gt;package org.example.client;&lt;br /&gt;public interface BuildStamp { public String getBuildStamp(); }&lt;br /&gt;&lt;/pre&gt;&lt;br /&gt;And wire it up in your .gwt.xml:&lt;br /&gt;&lt;pre style="background-color:white; overflow:scroll;width:440px;border: 1px solid black;"&gt;&amp;lt;generate-with class="org.example.rebind.BuildStampGenerator"&amp;gt;&lt;br /&gt;  &amp;lt;when-type-assignable class="org.example.client.BuildStamp" /&amp;gt;&lt;br /&gt;&amp;lt;/generate-with&amp;gt;&lt;br /&gt;&lt;/pre&gt;&lt;br /&gt;&lt;br /&gt;What do you think?&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/idcmp?a=j8DrRoDMcEY:WHgjQhHxFls:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/idcmp?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/idcmp/~4/j8DrRoDMcEY" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://idcmp.linuxstuff.org/feeds/2704391621386087854/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=30950679&amp;postID=2704391621386087854" title="1 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/2704391621386087854?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/2704391621386087854?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/idcmp/~3/j8DrRoDMcEY/gwt-generators-howto-buildstamp.html" title="GWT: Generators HowTo (BuildStamp)" /><author><name>Idcmp</name><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>1</thr:total><feedburner:origLink>http://idcmp.linuxstuff.org/2008/09/gwt-generators-howto-buildstamp.html</feedburner:origLink></entry><entry gd:etag="W/&quot;DkMFSHk8eip7ImA9WxRSFEs.&quot;"><id>tag:blogger.com,1999:blog-30950679.post-4251323027291805850</id><published>2008-09-15T00:16:00.003-07:00</published><updated>2008-09-15T00:40:19.772-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2008-09-15T00:40:19.772-07:00</app:edited><title>Spore on Linux</title><content type="html">If you're a Linux user wondering if Spore works, the answer is: Sorta.&lt;br /&gt;&lt;br /&gt;I bought the download version from the EA Store.  Nothing mentioned until after my purchase was complete that I needed a Windows-only downloader.  I didn't test this under Wine.&lt;br /&gt;&lt;br /&gt;&lt;i&gt;Aside: The EA Store website allows &lt;b&gt;+&lt;/b&gt; in email addresses, but the Spore online login does not.&lt;/i&gt;&lt;br /&gt;&lt;br /&gt;I'm using Ubuntu 8.04 with a custom build of Wine 1.1.4 (includes a patch needed to make Spore run).  The installer runs fine in Wine.  Skip the DirectX install. While the game works, piracy prevention code doesn't.  You'll need to find a cracked SporeApp.exe floating around to work around the issue. I believe a similar workaround is needed if you purchase the boxed game.&lt;br /&gt;&lt;br /&gt;I'm still on the creature level, I've found a few graphical glitches:&lt;br /&gt;&lt;br /&gt;&lt;ul&gt;&lt;li&gt;Minor: Turn "Shadows" to "Low" to reduce some of the bizarre sploches of blackness.&lt;br /&gt;&lt;li&gt;Minor: The icon by the mouse pointer seems to not be transparent properly&lt;br /&gt;&lt;li&gt;Minor: Text describing your goals overlaps the text describing items you've picked up.&lt;br /&gt;&lt;li&gt;Medium: The water isn't rendered.&lt;br /&gt;&lt;/ul&gt;&lt;br /&gt;&lt;br /&gt;Check the &lt;a href="http://appdb.winehq.org/objectManager.php?sClass=version&amp;iId=13652"&gt;the WineHQ page about Spore&lt;/a&gt;.&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/idcmp?a=fn2Kxm3Ggjo:7JOhQe2kdd0:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/idcmp?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/idcmp/~4/fn2Kxm3Ggjo" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://idcmp.linuxstuff.org/feeds/4251323027291805850/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=30950679&amp;postID=4251323027291805850" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/4251323027291805850?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/4251323027291805850?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/idcmp/~3/fn2Kxm3Ggjo/spore-on-linux.html" title="Spore on Linux" /><author><name>Idcmp</name><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>0</thr:total><feedburner:origLink>http://idcmp.linuxstuff.org/2008/09/spore-on-linux.html</feedburner:origLink></entry><entry gd:etag="W/&quot;CEMFQnk-eSp7ImA9WxRTFEo.&quot;"><id>tag:blogger.com,1999:blog-30950679.post-403798459687629689</id><published>2008-09-03T12:28:00.005-07:00</published><updated>2008-09-03T13:06:53.751-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2008-09-03T13:06:53.751-07:00</app:edited><title>Chromium and Bees</title><content type="html">Watching what Google does feels like watching X-Files. I want to believe there's some grand master plan, but I'm pretty sure they're just making things up as they go.&lt;br /&gt;&lt;br /&gt;Hank Williams over at &lt;a href="http://www.whydoeseverythingsuck.com/"&gt;Why Does Everything Suck&lt;/a&gt; pretty much covers my thoughts on Google's new web browser in his &lt;a href="http://whydoeseverythingsuck.com/2008/09/who-cares-about-chrome-ie6-has-25.html"&gt;Huh?&lt;/a&gt; and &lt;a href="http://whydoeseverythingsuck.com/2008/09/redefining-operating-system.html"&gt;Huh!&lt;/a&gt; posts.&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/idcmp?a=LelfPIEo6aQ:YSW07hUsvKU:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/idcmp?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/idcmp/~4/LelfPIEo6aQ" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://idcmp.linuxstuff.org/feeds/403798459687629689/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=30950679&amp;postID=403798459687629689" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/403798459687629689?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/403798459687629689?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/idcmp/~3/LelfPIEo6aQ/chromium-and-bees.html" title="Chromium and Bees" /><author><name>Idcmp</name><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>0</thr:total><feedburner:origLink>http://idcmp.linuxstuff.org/2008/09/chromium-and-bees.html</feedburner:origLink></entry><entry gd:etag="W/&quot;A08CQXw4fip7ImA9WxdVEUk.&quot;"><id>tag:blogger.com,1999:blog-30950679.post-5672734053272664779</id><published>2008-07-15T11:10:00.003-07:00</published><updated>2008-07-15T12:24:20.236-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2008-07-15T12:24:20.236-07:00</app:edited><title>Nine Handy Tips for Taking the Summer Off</title><content type="html">Six weeks ago I quit my job; six weeks later I've never been happier. I had grown jaded about technology and worn down about my work.  This post isn't about how to quit your job, how to budget for the summer or how to get your next job; it's what I've learned in the  brief oasis between those points in my life.&lt;br /&gt;&lt;br /&gt;&lt;h3&gt;The Beginning&lt;/h3&gt;&lt;br /&gt;&lt;br /&gt;1. Do Not Look For Your Next Job: You know internally if you're at the point in your career that taking the summer off is realistic. Don't start looking for your next job right away. You'll find it (or it will find you), and it will fill your mind space, or even shorten your planned sabbatical (then you'll need another one!).&lt;br /&gt;&lt;br /&gt;2. Break Your Old Routine: Three days and a plane ride after quitting my job I was crashing out on a friends couch across the country (thanks Lori!). Shake your life up enough that you don't realize you've left your job.  You'll forget about your BlackBerry in two days.&lt;br /&gt;&lt;br /&gt;3. Leave Your Identity Behind:  If you've ever moved cities, you've said "Back home at &lt;span style="font-style:italic;"&gt;originalCity&lt;/span&gt;....".  It takes time to adjust to big changes, so correct yourself if you refer to your old team/workplace/etc in present tense.  Many people and social circles define will assess your value based solely on your job; you'll need to feel comfortable telling people you're taking a break. It took me a while to really let go of this. &lt;br /&gt;&lt;br /&gt;4. Travel: Find something interesting going on in a different city and go there. One friend suggested I go tour around Europe for a few months; if you can do it, go for it.&lt;br /&gt;&lt;br /&gt;5. Turn Off Your Alarm Clock:  Unless you already have a morning ritual, turn it off.  Wake up when you feel like it. As new-agey as this sounds, give yourself permission to do nothing.  All those "if I had time, I would do it" things can wait (see below).&lt;br /&gt;&lt;br /&gt;6. Don't Code: Or if you do, don't code in your normal language (admit it: you really want to learn ActionScript :-).  Your skills &lt;span style="font-weight:bold;"&gt;will&lt;/span&gt; still be around in two months.&lt;br /&gt;&lt;br /&gt;&lt;h3&gt;The Middle&lt;/h3&gt;&lt;br /&gt;&lt;br /&gt;7. Turn On Your Alarm Clock: So, it's been a few weeks of laziness, make yourself a daily ritual.  Set your alarm clock again. It's okay if you were up late the night before, just take a nap. Now is the time to make and start working through that list you've been ignoring.&lt;br /&gt;&lt;br /&gt;8. Resist Gossip: I still hear from friends at my old job; nothing has changed.  Each time, I I feel stress returning in my back muscles.  When we hang out now, I try to guide the conversation away from all the usual rants. "You sound like you could use some time off to relax."&lt;br /&gt;&lt;br /&gt;9. Hobby: Pick up a hobby or two to fill your time. Unlikely retirement, these can be hobbies you have no intention of keeping after the summer, so go out on a limb and try something really different.&lt;br /&gt;&lt;br /&gt;&lt;h3&gt;The End&lt;/h3&gt;&lt;br /&gt;&lt;br /&gt;I still have six more weeks of planned vacation left before I start really getting into job hunting mentality. Time will tell how it ends.&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/idcmp?a=DWCcY_AFi2A:UQ1RSP3ETas:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/idcmp?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/idcmp/~4/DWCcY_AFi2A" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://idcmp.linuxstuff.org/feeds/5672734053272664779/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=30950679&amp;postID=5672734053272664779" title="4 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/5672734053272664779?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/5672734053272664779?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/idcmp/~3/DWCcY_AFi2A/nine-handy-tips-for-taking-summer-off.html" title="Nine Handy Tips for Taking the Summer Off" /><author><name>Idcmp</name><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>4</thr:total><feedburner:origLink>http://idcmp.linuxstuff.org/2008/07/nine-handy-tips-for-taking-summer-off.html</feedburner:origLink></entry><entry gd:etag="W/&quot;C0AGRHs6cSp7ImA9WxdQFko.&quot;"><id>tag:blogger.com,1999:blog-30950679.post-514900216617857856</id><published>2008-06-16T20:02:00.000-07:00</published><updated>2008-06-16T20:02:05.519-07:00</updated><app:edited xmlns:app="http://www.w3.org/2007/app">2008-06-16T20:02:05.519-07:00</app:edited><title>Google's Conference on Scalability</title><content type="html">This is the second year I've attended Google's conference on scalability, the talks were more academic this time around. One organizer indicated that this was indeed the goal of this year's conference.  I enjoyed last year how much of the information was really hands on, but there's some value in seeing what's coming down the research pipe.&lt;br /&gt;&lt;br /&gt;The conference is an example of what googlers do with their "20% time".&lt;br /&gt;&lt;br /&gt;I took lots of notes, but I'll summarize just the overarching concepts:&lt;br /&gt;&lt;br /&gt;* Go Scale Yourself: Everyone seems to suffer from interruptions and it can take up to 1/2 hour to refocus after one.  Asking the interrupter to file a ticket was suggested (something I've had lackluster success at).  A better idea: keeping a pad of post it notes and writing down their request and telling them you'll get to it. The physical demonstration of accepting their request makes the requester feel they're being heard.&lt;br /&gt;&lt;br /&gt;Good quote: "We're too busy mopping the floor to turn off the faucet."  Sounds familiar.&lt;br /&gt;&lt;br /&gt;* P2P: Lots of talk directly and indirectly on peer-to-peer, on the desktop, in the datacenter and under-water.  Lots of interesting issues with lots of potential on both the small and large scale.&lt;br /&gt;&lt;br /&gt;* Distributed Hashtables: Many talks mentioned distributed hashtables as a solution for one problem or another.  I haven't read up on the details, so I don't have much to add.&lt;br /&gt;&lt;br /&gt;* Multi-Core: We write a lot of plumbing code now to handle multiple threads, and really, we shouldn't have to.  Cray's talk on Chapel showed how brittle our code is (because Doing It Right Is Hard) and Google had a presentation on Transactional Memory.  If you've never heard of TM, then the talk is a great introduction.  &lt;br /&gt;&lt;br /&gt;I had an interesting chat with a database developer on the effects of solid state storage on database engines and a guy from Microsoft who had done a fair bit of P2P research.  &lt;br /&gt;&lt;br /&gt;The talks and slides will be up on YouTube over the next week.  The talks were brought down a manageable 30 minutes from the originally scheduled hour, so if the presenters seem rushed, they probably were.&lt;div class="feedflare"&gt;
&lt;a href="http://feeds.feedburner.com/~ff/idcmp?a=fAOS-n_USD4:ZRBfDE2Z_qg:yIl2AUoC8zA"&gt;&lt;img src="http://feeds.feedburner.com/~ff/idcmp?d=yIl2AUoC8zA" border="0"&gt;&lt;/img&gt;&lt;/a&gt;
&lt;/div&gt;&lt;img src="http://feeds.feedburner.com/~r/idcmp/~4/fAOS-n_USD4" height="1" width="1"/&gt;</content><link rel="replies" type="application/atom+xml" href="http://idcmp.linuxstuff.org/feeds/514900216617857856/comments/default" title="Post Comments" /><link rel="replies" type="text/html" href="http://www.blogger.com/comment.g?blogID=30950679&amp;postID=514900216617857856" title="0 Comments" /><link rel="edit" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/514900216617857856?v=2" /><link rel="self" type="application/atom+xml" href="http://www.blogger.com/feeds/30950679/posts/default/514900216617857856?v=2" /><link rel="alternate" type="text/html" href="http://feedproxy.google.com/~r/idcmp/~3/fAOS-n_USD4/googles-conference-on-scalability.html" title="Google's Conference on Scalability" /><author><name>Idcmp</name><email>noreply@blogger.com</email><gd:image rel="http://schemas.google.com/g/2005#thumbnail" width="16" height="16" src="http://img2.blogblog.com/img/b16-rounded.gif" /></author><thr:total>0</thr:total><feedburner:origLink>http://idcmp.linuxstuff.org/2008/06/googles-conference-on-scalability.html</feedburner:origLink></entry></feed>
