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

<channel>
	<title>pixelmonkey.org - alter or abolish? &#187; Technology</title>
	<atom:link href="http://www.pixelmonkey.org/category/technology/feed" rel="self" type="application/rss+xml" />
	<link>http://www.pixelmonkey.org</link>
	<description>Andrew J. Montalenti's Blog</description>
	<lastBuildDate>Sat, 24 Apr 2010 23:50:19 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.8.4</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>Flavors.me emerges from beta: lifestreaming for the masses</title>
		<link>http://www.pixelmonkey.org/2010/02/24/flavors-me-emerges-from-beta-lifestreaming-for-the-masses</link>
		<comments>http://www.pixelmonkey.org/2010/02/24/flavors-me-emerges-from-beta-lifestreaming-for-the-masses#comments</comments>
		<pubDate>Thu, 25 Feb 2010 01:58:13 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[Programming]]></category>
		<category><![CDATA[Startups]]></category>
		<category><![CDATA[Technology]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/?p=520</guid>
		<description><![CDATA[My good friends at HiiDef just launched a new app that has been in beta for awhile, Flavors.me.  This is an excellent tool that has a great, simple, and usable design.
What&#8217;s the value preposition of Flavors.me?  It&#8217;s to unify your various &#8220;online identities&#8221; into a single, dynamic, automatically-updated, and elegant website.
What do I [...]]]></description>
			<content:encoded><![CDATA[<p>My good friends at <a href="http://hiidef.com/">HiiDef</a> just launched a new app that has been in beta for awhile, <a href="http://flavors.me">Flavors.me</a>.  This is an excellent tool that has a great, simple, and usable design.</p>
<p>What&#8217;s the value preposition of Flavors.me?  It&#8217;s to unify your various &#8220;online identities&#8221; into a single, dynamic, automatically-updated, and elegant website.</p>
<p>What do I mean by that?  OK &#8212; so, like most people on the web, you spread public information about yourself in multiple places.  You might run one or two blogs (personal and work?).  You might have a Facebook account, a Twitter account.  You may share your favorite books at GoodReads, your favorite movies at Netflix, and your favorite music on Last.fm.</p>
<p>Flavors.me lets you take all that information and put it together in a single website to serve as your &#8220;online identity&#8221;.  All your publicly shared information, aggregated in one place, and displayed beautifully.</p>
<p>I&#8217;ve been running a Flavors.me site for some time that you can see here: <a href="http://flavors.me/pixelmonkey" target="_blank">http://flavors.me/pixelmonkey</a></p>
<div align="center"><a target="_blank" href="http://flavors.me/pixelmonkey"><img src="http://www.pixelmonkey.org/wordpress/wp-content/uploads/2010/02/pixelmonkey-flavorsme1-300x187.png" alt="pixelmonkey-flavorsme" title="pixelmonkey-flavorsme" width="300" height="187" class="aligncenter size-medium wp-image-523" /></a></div>
<p>Now, that&#8217;s the end product.  All the content gets pulled dynamically from your various online feeds.  The real magic with Flavors.me is how easy it is to get there.  You can drastically change the look and feel of this site using a dynamic, &#8220;WYSIWYG&#8221; interface.  You can do one or two clicks to add a service, reorder it, rename it.  Another couple of clicks and you change font sizes, colors, and even the overall layout.</p>
<p><span id="more-520"></span></p>
<p>As I was writing this post, I noticed that Flavors.me had added LinkedIn support, which wasn&#8217;t available earlier in the beta.  So I went ahead and added it.  I simply logged in and pulled up the design panel.</p>
<div align="center"><a href="http://www.pixelmonkey.org/wordpress/wp-content/uploads/2010/02/flavors-cpanel-01.png"><img src="http://www.pixelmonkey.org/wordpress/wp-content/uploads/2010/02/flavors-cpanel-01.png" alt="flavors-cpanel-01" title="flavors-cpanel-01" width="407" height="528" class="aligncenter size-full wp-image-528" /></a></div>
<p>From there, I could navigate over to &#8220;Services&#8221;, click the &#8220;LinkedIn&#8221; logo, and Flavors.me would guide me through the authorization process to make LinkedIn data available to them for display on my page.  You simply get redirected to LinkedIn.com, log in there (if not already logged in), and then get redirected back to the Flavors control panel.</p>
<div align="center"><a href="http://www.pixelmonkey.org/wordpress/wp-content/uploads/2010/02/flavors-cpanel-02.png"><img src="http://www.pixelmonkey.org/wordpress/wp-content/uploads/2010/02/flavors-cpanel-02.png" alt="flavors-cpanel-02" title="flavors-cpanel-02" width="315" height="492" class="aligncenter size-full wp-image-529" /></a></div>
<p>Next, I could simply drag-and-drop the service box in the panel in order to reorder it on the page.  Yay, drag-and-drop!  There is also in-line editing, and editing the title of the LinkedIn &#8220;popout&#8221; dynamically updates my profile page in real-time!  Nice touch.</p>
<div align="center"><a href="http://www.pixelmonkey.org/wordpress/wp-content/uploads/2010/02/flavors-cpanel-03.png"><img src="http://www.pixelmonkey.org/wordpress/wp-content/uploads/2010/02/flavors-cpanel-03.png" alt="flavors-cpanel-03" title="flavors-cpanel-03" width="306" height="336" class="aligncenter size-full wp-image-530" /></a></div>
<p>Finally, I can go to the &#8220;Design&#8221; panel to tweak fonts, layout, sizes, etc.  Look at how Flavors.me displays fonts.  It&#8217;s amazing &#8212; this is the web, but it&#8217;s easier to change my Flavors.me web design font styles than it is to change font styles in a Microsoft Word document!</p>
<div align="center"><a href="http://www.pixelmonkey.org/wordpress/wp-content/uploads/2010/02/flavors-cpanel-04.png"><img src="http://www.pixelmonkey.org/wordpress/wp-content/uploads/2010/02/flavors-cpanel-04.png" alt="flavors-cpanel-04" title="flavors-cpanel-04" width="307" height="343" class="aligncenter size-full wp-image-531" /></a></div>
<p>Now, depending on where, exactly, you store the bits that make up your online identity, you may find yourself disappointed by a lack of this-or-that service.  They already support quite a few, and they are adding more in the future, I hear.  The one I sorely missed was <a href="http://delicious.com">Delicious</a>, so I could share my bookmarks with the world.</p>
<p>But wait!  For those services that still don&#8217;t have first-class support, Flavors.me gracefully supports RSS feeds of any variety.  I simply popped the RSS feed for my Delicious bookmarks into Flavors.me services panel, and, voila! &#8212; my bookmarks are now publicly shared!</p>
<div align="center"><a target="_blank" href="http://www.pixelmonkey.org/wordpress/wp-content/uploads/2010/02/flavors-cpanel-05.png"><img src="http://www.pixelmonkey.org/wordpress/wp-content/uploads/2010/02/flavors-cpanel-05-300x183.png" alt="flavors-cpanel-05" title="flavors-cpanel-05" width="300" height="183" class="aligncenter size-medium wp-image-532" /></a></div>
<p>It&#8217;s this kind of simplicity, design sense, and user-centric approach that makes me love the web as a place to develop, deploy, and use software.  So, what are you waiting for?  <a href="http://flavors.me/signup">Sign up for Flavors.me today: it&#8217;s free!</a></p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2010/02/24/flavors-me-emerges-from-beta-lifestreaming-for-the-masses/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>The danger of feature-driven design</title>
		<link>http://www.pixelmonkey.org/2009/12/22/the-danger-of-feature-driven-design</link>
		<comments>http://www.pixelmonkey.org/2009/12/22/the-danger-of-feature-driven-design#comments</comments>
		<pubDate>Tue, 22 Dec 2009 06:49:39 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[Programming]]></category>
		<category><![CDATA[Startups]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/?p=504</guid>
		<description><![CDATA[I recently re-read Douglas Crockford&#8217;s JavaScript: The Good Parts.  I have been writing more and more JavaScript lately, especially object-oriented JavaScript plugging into existing frameworks.  Re-reading the book has definitely been a useful exercise &#8212; I think when I first read it approximately 6 months ago, I didn&#8217;t fully understand it.  But [...]]]></description>
			<content:encoded><![CDATA[<p>I recently re-read Douglas Crockford&#8217;s <em>JavaScript: The Good Parts</em>.  I have been writing more and more JavaScript lately, especially object-oriented JavaScript plugging into existing frameworks.  Re-reading the book has definitely been a useful exercise &#8212; I think when I first read it approximately 6 months ago, I didn&#8217;t fully understand it.  But now, I do.</p>
<p>I also found it very interesting to hear Crockford wax poetic about the virtue of simplicity in all forms of software design.  The following passage concludes the book.</p>
<blockquote><p>
When I started thinking about this[...], I wanted to take the subset idea further, to show how to take an existing [product] and make significant improvements to it by making no changes except to exclude the low-value features.</p>
<p>We see a lot of feature-driven product design in which the cost of features is not properly accounted. Features can have a negative value to consumers because they make the products more difficult to understand and use. We are finding that people like products that just work. It turns out that designs that just work are much harder to produce than designs that assemble long lists of features.</p>
<p>Features have a specification cost, a design cost, and a development cost. There is a testing cost and a reliability cost. The more features there are, the more likely one will develop problems or will interact badly with another. In software systems, there is a storage cost, which was becoming negligible, but in mobile applications is becoming significant again. There are ascending performance costs because Moore’s Law doesn’t apply to batteries.  </p>
<p>Features have a documentation cost. Every feature adds pages to the manual, increasing training costs. Features that offer value to a minority of users impose a cost on all users. So, in designing products[...], we want to get the core features—the good parts—right because that is where we create most of the value.</p>
<p>We all find the good parts in the products that we use. We value simplicity, and when simplicity isn’t offered to us, we make it ourselves. My microwave oven has tons of features, but the only ones I use are cook and the clock. And setting the clock is a struggle. We cope with the complexity of feature-driven design by finding and sticking with the good parts.</p>
<p>It would be nice if products[...] were designed to have only good parts.
</p></blockquote>
<p>I removed direct references to the main subject of Crockford&#8217;s discussion &#8212; namely, the JavaScript language itself.  The truth is, this advice is much more valuable for the design of all software products.  Perhaps one day someone will write the much needed book, <em>Startups: The Good Parts</em>.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2009/12/22/the-danger-of-feature-driven-design/feed</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>Persistent Folders: Or, why ideas don&#8217;t matter, and execution does</title>
		<link>http://www.pixelmonkey.org/2009/12/11/ideas-and-execution</link>
		<comments>http://www.pixelmonkey.org/2009/12/11/ideas-and-execution#comments</comments>
		<pubDate>Fri, 11 Dec 2009 15:59:51 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[Open Source]]></category>
		<category><![CDATA[Programming]]></category>
		<category><![CDATA[Startups]]></category>
		<category><![CDATA[Technology]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/?p=475</guid>
		<description><![CDATA[I&#8217;ll start off this post with a somewhat  controversial claim: I invented Dropbox.
I&#8217;ll show why this claim doesn&#8217;t matter later, but for now, I&#8217;ll assure you that it&#8217;s true. 
How many of you out there use Dropbox?  If you don&#8217;t, you should &#8212; it&#8217;s an excellent tool.  In its free version, it [...]]]></description>
			<content:encoded><![CDATA[<p>I&#8217;ll start off this post with a somewhat  controversial claim: <i>I invented Dropbox</i>.</p>
<p>I&#8217;ll show why this claim doesn&#8217;t matter later, but for now, I&#8217;ll assure you that it&#8217;s <b>true</b>. </p>
<p>How many of you out there use <a href="http://getdropbox.com">Dropbox</a>?  If you don&#8217;t, you should &#8212; it&#8217;s an excellent tool.  In its free version, it provides you with 2GB of storage &#8220;in the cloud&#8221;, using a new kind of folder called a &#8220;Dropbox&#8221;.  What distinguishes a Dropbox from other folders on your computer?  The following:</p>
<ul>
<li>Every file put in your Dropbox is automatically (and securely) uploaded to Dropbox&#8217;s servers, ensuring you have an offsite backup of all data therein.</li>
<li>Multiple computers can gain access to a Dropbox, ensuring files are automatically synchronized across computers without having to use complication version control systems.</li>
<li>All files in your Dropbox are versioned, ensuring you can always recover an older version of a file in case you accidentally overwrite a good version.</li>
</ul>
<p>Dropbox is supported on Windows, Mac OS X, and Linux, and now even has mobile applications, as well.  Further, I have a special place in my heart for this service because I started using it almost 2 years ago, and it has acted as a file sharing and project management tool for my own startup&#8217;s internal operations at <a href="http://parse.ly">Parse.ly</a>.  I was therefore more than ecstatic to discover that this excellent tool and its smart founders had also made it through all of the hurdles necessary to get an early-stage company the financing it needs: they&#8217;ve <a href="http://gigaom.com/2009/11/24/dropbox-raises-7-25m-crosses-3m-users/">raised over $7 million in financing and have over 3 million users</a>.</p>
<p>But there is another reason I absolutely love Dropbox: because <i>it was my idea</i>.  I invented it.</p>
<p><span id="more-475"></span></p>
<p>In the summer of 2004, I was really itching to get into <a href="http://code.google.com/soc/">Google&#8217;s Summer of Code competition</a>.  This was the summer I had taken a job working from home as the lead web developer at the <a href="http://uac-ny.org">Unemployment Action Center of NY</a>.  Though the job was great experience &#8212; letting me build my first full web application for a real client &#8212; I was itching to work on a technically juicy problem, something that affected <i>me</i> in my daily computer use.  </p>
<p>And so, I sat down for a day and wrote up a Google Summer of Code proposal for a new system I had invented called <i>Persistent Folders</i>.  It wasn&#8217;t <i>exactly</i> like Dropbox, but damn close.  Even the implementation is close: Dropbox and my system both sync files using rsync, and both use a Python daemon process.  The main difference is that since my system was meant to be open source, it did not require the use of a company-maintained service; instead, I proposed that users piggyback existing storage they have via web hosting providers.</p>
<p>Unfortunately, my project wasn&#8217;t selected.</p>
<p>Why am I posting this?  I recently had a discussion with another engineer after I had discussed some of the technology behind <a href="http://parse.ly">Parse.ly</a> with him.  He was surprised at how liberal I was with explaining our internal implementation, architecture, and algorithms.  He asked me, &#8220;Aren&#8217;t you worried that I could steal your idea?&#8221;</p>
<p>I responded, &#8220;You can steal it all you want; I dare you to try and implement it!&#8221;  I then explained that to me, ideas don&#8217;t matter.  I had the idea for a hundred startups that now exist before they started.  I know from talking to users and customers of Parse.ly that they had our idea before we implemented it.  What matters in software is not an idea, but <i>execution</i> of that idea.  Ideas are a dime a dozen.</p>
<p>I began this post with the statement, <i>I invented Dropbox</i>.  And now I&#8217;m here to tell you that it <i>doesn&#8217;t matter one bit</i>, because I never <i>implemented</i> Dropbox.  And you can&#8217;t own ideas&#8230;</p>
<blockquote><p>
If nature has made any one thing less susceptible than all others of exclusive property, it is the action of the thinking power called an idea, which an individual may exclusively possess as long as he keeps it to himself; but the moment it is divulged, it forces itself into the possession of every one, and the receiver cannot dispossess himself of it. Its peculiar character, too, is that no one possesses the less, because every other possesses the whole of it. He who receives an idea from me, receives instruction himself without lessening mine; as he who lights his taper at mine, receives light without darkening me.<br />
<i>-Thomas Jefferson</i>
</p></blockquote>
<p>Imagine if when I had come up with this idea, I had patented it.  Would it really have been fair to force Dropbox to license my technology?  To sue them for &#8220;infringing&#8221; on my patent?</p>
<p>No way &#8212; these guys deserve the success they have.  How stifling it would have been for me to put any roadblocks in their way because &#8220;I had the idea first&#8221;!  The world is better because Dropbox exists.  And, these guys have had &#8212; in my opinion &#8212; <b>near-flawless execution</b>.  So, kudos to them.</p>
<p>Consider the following matrix:</p>
<div align="center">
<table style="border: 1px solid #000; padding: 3px; text-align: center;">
<tr>
<td>&nbsp;</td>
<td style="font-weight: bold; padding: 5px;">Mediocre Idea</td>
<td style="font-weight: bold; padding: 5px;">Great Idea</td>
</tr>
<tr style="background-color: #ccc;">
<td style="font-weight: bold; padding: 5px;">No implementation</td>
<td> <img src='http://www.pixelmonkey.org/wordpress/wp-includes/images/smilies/icon_sad.gif' alt=':-(' class='wp-smiley' /> </td>
<td> <img src='http://www.pixelmonkey.org/wordpress/wp-includes/images/smilies/icon_sad.gif' alt=':-(' class='wp-smiley' /> </td>
</tr>
<tr style="background-color: #ddd;">
<td style="font-weight: bold; padding: 5px;">Mediocre Implementation</td>
<td> <img src='http://www.pixelmonkey.org/wordpress/wp-includes/images/smilies/icon_sad.gif' alt=':-(' class='wp-smiley' /> </td>
<td> <img src='http://www.pixelmonkey.org/wordpress/wp-includes/images/smilies/icon_confused.gif' alt=':-?' class='wp-smiley' /> </td>
</tr>
<tr style="background-color: #eee;">
<td style="font-weight: bold; padding: 5px;">Great Implementation</td>
<td> <img src='http://www.pixelmonkey.org/wordpress/wp-includes/images/smilies/icon_smile.gif' alt=':-)' class='wp-smiley' /> </td>
<td> <img src='http://www.pixelmonkey.org/wordpress/wp-includes/images/smilies/icon_cool.gif' alt=':cool:' class='wp-smiley' /> </td>
</tr>
</table>
</div>
<p>A mediocre idea with a good implementation is worth infinitely more than a carefully-guarded, good idea with no implementation.  Of course, the best products are both great ideas and great implementations.  And I think my proposal for &#8220;Persistent Folders&#8221; &#8212; written three years before Dropbox even started &#8212; proves this to me in a very personal way.</p>
<p>Now, I&#8217;m certain the Dropbox guys never read my little proposal, because it was only sent to Google and otherwise sat on my hard drive for years, not viewed by anyone.  I had a great idea, but no implementation.  And the Dropbox guys took a great idea (one they arrived at on their own, I&#8217;m sure), and gave it the implementation it deserved.</p>
<p>For those of you who guard your ideas carefully, I&#8217;d suggest you stop wasting your time, get off your butt, and focus on <a href="http://gettingreal.37signals.com/">actually building stuff</a>.  Because if you don&#8217;t, someone else will!</p>
<div align="center"><a href="http://www.pixelmonkey.org/wordpress/wp-content/uploads/2009/12/persist-poster.jpg" target="_blank"><img src="http://www.pixelmonkey.org/wordpress/wp-content/uploads/2009/12/persist-poster-300x219.jpg" alt="persist-poster" title="persist-poster" width="300" height="219" class="aligncenter size-medium wp-image-492" /></a></div>
<p>For the curious, below is my proposal to Google Summer of Code 2004, unaltered from its original draft.  This is just a relic; for now, I&#8217;m glad to keep <a href="http://parse.ly">hacking on my own little idea</a>, hoping one day I can look back and say I <i>executed</i> as well as Dropbox did&#8230;</p>
<blockquote><p>
<strong>PERSISTENT FOLDERS: A New Metaphor for Data Synchronization</strong><br />
<i>May 13, 2004</i></p>
<p><strong>The Problem</strong></p>
<p>Computer users are more and more finding themselves with a serious problem: the fragmentation of personal data across multiple physical machines, and even multiple operating systems.  Users who find it most comfortable to have a desktop machine at home and a mobile laptop computer &#8220;on-the-go&#8221; (for business or trips) have to deal with chaotic and often frustrating manual methods to copy that data to the needed places.  Some users carry USB memory sticks &#8212; which hold their important &#8220;working set&#8221; of files &#8212; and either work directly off those disks (suffering reduced speeds) or make copies of the folders therein on their actual machines, as they become needed, spreading yet more copies and compounding the problem of synchronization.  Others abuse ubiquitous technologies for accessing important files, by either e-mailing the files to themselves or by uploading them temporarily to web or FTP servers.</p>
<p>The end result of any of these methods is fragmentation of personal data, with error-prone manual processes for replication, and the inability for a consistent way to search, backup or even just keep track of all the important files and folders spread among the PCs in question.</p>
<p>What is needed to solve this problem, or at least make the problem more manageable, is an intelligent, user-friendly, customizable cross-platform program that allows for transparent synchronization of personal data across multiple computers and systems, either via a LAN or via the Internet.</p>
<p><strong>Introducing the Persistent Folder</strong></p>
<p>Up to this point, most users are used to understanding folders as existing solely in one location.  The only way to get a folder&#8217;s data onto another machine is to copy that folder, thus making a duplicate.  The goal of this project will be to introduce a new high-level data storage mechanism known as a Persistent Folder.  Persistent Folders differ from regular folders in that they are meant to be transparently persistent, or synchronized, across different computers.</p>
<p>To explore a hypothetical example, imagine user Joe sits down to do some personal accounting work on Friday.  He creates a folder on his desktop called &#8220;Personal Accounting,&#8221; and begins working on some OpenOffice spreadsheets in that folder.  A few minutes later, Joe realizes that some of his accounting work will have to be done while he is away during the weekend, on his laptop computer.</p>
<p>To enable this, he simply right-clicks the folder on his desktop and says &#8220;Make this folder persistent across multiple computers.&#8221;  When he does this, a dialog comes up asking him to type in a description of the persistent folder, and to select computers on which he wishes to make this folder persistent.  Joe is presented with a dialog of computers currently available on the LAN.  He sees his laptop, &#8220;MobileJoe&#8221;, and selects it.  He then presses OK.</p>
<p>Within seconds, Joe sees the folder &#8220;Personal Accounting&#8221; appear on his mobile computer&#8217;s desktop, even though he hasn&#8217;t even touched his mobile computer yet.  When he enters that folder, he sees the same spreadsheets that are available on his main PC&#8217;s desktop.</p>
<p>These two folders are now treated by Joe as &#8220;one persistent folder available across two computers.&#8221;  He can add files to one folder and they will automatically be propagated to the other.  He can modify files and the new versions will then exist in the other.  Joe no longer has to worry about pushing his data back and forth across the computers.</p>
<p><strong>Internet Synchronization by way of Ubiquitous Services</strong></p>
<p>One of the major questions one may ask at this point, &#8220;that is all well and good for persistence of a folder on a LAN, but what about when I leave my home/office, and need to synchronize over the Internet?&#8221;</p>
<p>One approach would be to have a special server application with which all computers that wish to share persistent folders could synchronize.  But then the user needs his own server, and needs to install my little server daemon on it.  And not many users have their own servers on which they can just install any old application.  So for normal users, this, in fact, is no approach at all.</p>
<p>Although most users don&#8217;t run their own servers, many modern users do have _server access_.  That is, many users do have Web/FTP hosting providers to whom they pay subscriptions, and these servers power their blogs, personal photo stores, etc.  The goal of Persistent Folders would be to allow users to piggyback their existing web services to synchronize their files, essentially turning a folder on that server into a Persistent Folder Repository.</p>
<p>A dialog in the properties of a persistent folder would include a checkbox that allows the user to &#8220;make this folder available over the Internet.&#8221;  It would then allow a user to choose a method for making this folder available via the Internet, asking the user to provide a &#8220;persistent folder repository&#8221; via FTP by default (due to commonality), but equally possible would be scp, rsync, NFS, or even something like cvs/svn (the goal, of course, would be to make the design modular enough that it could support any server type with basic file system operations).</p>
<p>Then, every other visible machine on the LAN who shares that persistent folder would have option enabled automatically.  If the machines are offline, the option can be entered manually by the same method explained above.</p>
<p>From that point on, the folders become persistently available and transparently usable, just as before.  If the other computers are available on the LAN, then the program utilizes LAN speeds and synchronizes directly.  Otherwise, it synchronizes with the Internet Repository.</p>
<p>Lucky Joe is now able to work on his files in the office, leave his laptop there (&#8221;the darn thing is so heavy to carry around!&#8221;), return home, and continue right on working on those files which are now found in the &#8220;same folder&#8221; on his desktop machine at home. </p>
<p><strong>Implementation Ideas</strong></p>
<p>I plan on implementing this idea in Python, since one of the major goals of the project is to allow Persistent Folders to exist not just across computers, but also across operating systems (so that a Windows desktop could have a persistent folder that also exists on a Linux laptop, for example).  For a user interface, I plan to use PyGTK, since that&#8217;s what I know, and since it is also cross-platform.  I need something powerful like GTK since there will be times when user intervention will be necessary, but since it is a goal of this project to reduce the number of times the user must intervene, I want to make sure that when he does, he is presented with sane, human-readable, and user-friendly dialogs.</p>
<p>I don&#8217;t plan to reinvent the wheel.  Most of the magic of Persistent Folders is just making existing synchronization tools work relatively silently and in a way that makes sense with a user&#8217;s workflow.  The main tool I am thinking of using is rsync, the relatively-ubiquitous UNIX utility for incremental synchronization of directory trees.  I considered using the unison, as recommended by Ubuntu&#8217;s Wiki entry, but I saw two major problems: (1) unison is no longer under active development and (2) it is written in OCaml, a relatively obscure language which I don&#8217;t know.  Therefore, any bugs I discover in unison would not be fixed in a timely fashion by its developers, and any features I&#8217;d like to add to support my idea would be quite difficult to implement.</p>
<p>As for monitoring folders for changes, I imagine the most elegant solution would be to take advantage of inotify under Linux (like Beagle does) and perhaps handle ChangeNotify events under Windows.  I&#8217;d really like to avoid polling, since polling is just plain evil for something as potentially neat as this.  Regardless, I&#8217;ll probably need to code Yet Another Daemon (or Windows service) to keep track of Persistent Folders on the local machine and their equivalents across the network.</p>
<p>Finally, for secure synchronization of files, I plan to use SSH tunneling wherever possible, which is available under Windows under the OpenSSH for Windows Sourceforge project, http://sshwindows.sf.net.  Linux distros like Ubuntu, of course, have all the ssh support one needs.</p>
<p><strong>Conclusion</strong></p>
<p>This project aims to introduce a new metaphor users may utilize to share important files across multiple computers: the Persistent Folder.  A Persistent Folder is not a shared a folder; rather, it is seen as a single folder that exists locally across multiple computers, and can be treated by the user as such.  Changes at any one folder rapidly propagate to the others.  Properly implemented, this may provide a better way for users to manage important data that might otherwise be scattered, fragmented, and even lost through the daily shuffle of file transfers across networked PCs.</p>
<p><strong>Appendix A: Project Roadmap</strong></p>
<p>o June 24: Begin Work, with ideas now fully developed in the form of documents.  Post these documents to Ubuntu&#8217;s Wiki to encourage ideas from community. </p>
<p>o July 5: Have a console synchronization wrapper and some network discovery stuff in Python written, and have UI concepts designed in Glade.</p>
<p>o July 20: Make 0.1 (GUI and basic features working) release, so that Google can show it off at OSCON?</p>
<p>o August 1: Have other great features, like the Internet synchronization and multi-protocol support, in 0.2 release.</p>
<p>o August 10: Consider working on features to allow transparent backup and versioning, to include with bug fixes in a 0.3 release.</p>
<p>o August 20: Make simultaneous 0.4 releases on Linux and<br />
Windows, hammering out as many cross-platform issues as possible. Add inotify/ChangeNotify support if not already there.</p>
<p>o August 30: The big 0.5 release, finished for Google&#8217;s deadline.  Let Google/Ubuntu make the decision if it&#8217;s worthy of being renamed a &#8220;1.0&#8243; release.</p>
<p>o September 1: Live a less stressful life, since my files are now neatly synchronized among my PCs!  But I&#8217;ll keep making it better.</p>
<p><strong>Appendix B: Hold On, Isn&#8217;t Samba Good Enough?</strong></p>
<p>One common response to this project may be, &#8220;Aren&#8217;t Samba and SMB shared folders good enough?&#8221;  Though Samba is good, I do not believe it is good enough.  Here&#8217;s why:</p>
<p>(1) Samba does not aim to present the user with a metaphor of a folder existing in multiple locations at the same time.  I believe this metaphor would be appreciated as powerful by longtime computer users and subconsciously acknowledged as highly usable by novices.</p>
<p>(2) Samba only allows users to share folders on their drives.  Other Samba users may then mount those folders via the LAN.  This two-step, asymmetric process already seems complicated and convoluted to end users.  But more importantly, synchronization is left up to the user.  In theory, users could avoid synchronization altogether and work on the files directly, via the share.  In practice, LAN speeds are not adequate, and other issues are raised (such as file locking and write conflicts).  This forces users to home-brew their own synchronization protocol to make sure duplicate files at different versions doesn&#8217;t result in an accidental loss of data.</p>
<p>(3) Samba does not provide any easy method to access personal files once one leaves the LAN and enters the WAN, short of opening up a bunch of ports on your router and trying to connect in from outside (a very slow and insecure method).</p>
<p>(4) Samba provides no recourse when a computer is no longer available.  Persistent Folders, on the other hand, make data available &#8220;offline&#8221; by design.</p>
<p>(5) Samba does not know whether two duplicate files exist across the network.  Therefore, Samba cannot be immediately utilized as a transparent form of backup.</p>
<p>Is the Persistent Folder meant to replace Samba?  Of course not.  I believe Samba has specific purposes: to allow for easy, fast, one-time transfers of files across a LAN, and to allow networked printer and device sharing.  I do not believe Samba is an adequate solution to allow a user to  treat a folder as if it existed on multiple computers at once.</p>
<p><strong>Appendix C: Versioning&#8217;s the Thing</strong></p>
<p>Upon further contemplation of this project, I realized I had left a question unanswered in this document.  What is the right way to deal with version conflicts during the silent synchronization phase among Persistent Folders?</p>
<p>Imagine user Joe works on a file in a Persistent Folder which exists on his laptop and desktop computers.  The first version (let&#8217;s call it version 0.1) was created on his desktop, and Joe had the laptop on the same network, allowing automatic synchronization to occur.  But then Joe&#8217;s laptop was disconnected from his desktop, as Joe was without network or even Internet access.  He works on the document a bit, which can now be called version 0.2.  But then Joe forgets that he worked on the document on his laptop, and when he gets home, he works on his desktop computer, creating a version 0.2 there too.  Which version 0.2 should be synchronized?</p>
<p>Normally, the answer would be to pick the most recent one.  But we don&#8217;t want Joe&#8217;s laptop work to be lost, just because Joe forgot about his prior work, do we?  Well, what needs to happen is a bit of smart conflict resolution with no data loss.</p>
<p>I propose that Persistent Folders should also be versioned to a sane degree.  Perhaps by default 3-5 versions of files are always kept, with the most recent versions visible directly in the persistent folder, and other versions buried (in .dotfiles or hidden folders) behind there.  Then, the Persistent Folder monitor should inform Joe (&#8221;whisper&#8221; to Joe via the notification area/systray) that there was a conflict, and the newest file was chosen.  But at any point, Joe can choose to revert a file back to an older version.  The interface should be such that Joe can even see where the file was edited, for example:</p>
<p>Personal Accounts.xls &#8211; Prior Versions<br />
  o version 0.2: edited on MobileJoe<br />
  o version 0.2: edited on DesktopJoe<br />
  o version 0.1: edited on DesktopJoe</p>
<p>Of course, versioning could be disabled (at risk of data loss to the user), or could be enabled as &#8220;smart versioning&#8221; to only version files when conflicts occur during synchronization.  Some may say that versioning is dangerous because it can drastically increase disk usage, but as I mentioned above, the other benefit is that the user gets redundant network backup of files for free.  In higher versions of Persistent Folders, things could get more sophisticated by allowing users to turn off versioning even at the file-level, but I don&#8217;t think that&#8217;d be necessary in the first few releases.
</p></blockquote>
<p>So, for those not keeping score, Dropbox supports:</p>
<ul>
<li>Windows, Linux and Mac OS X syncing, using a scheme similar to that described above, except with a managed set of servers (Dropbox&#8217;s) acting as the &#8220;repository&#8221;</li>
<li>sync over LAN (in latest beta releases) when PCs are local</li>
<li>file-level versioning</li>
<li>Collaboration by sharing folders with other users &#8212; a feature I didn&#8217;t discuss in my proposal, but that would be a clear next step for a managed service</li>
</ul>
<p>Go Dropbox!</p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2009/12/11/ideas-and-execution/feed</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>Simplifying CSS with 960.gs</title>
		<link>http://www.pixelmonkey.org/2009/12/08/simplifying-css-with-960-gs</link>
		<comments>http://www.pixelmonkey.org/2009/12/08/simplifying-css-with-960-gs#comments</comments>
		<pubDate>Tue, 08 Dec 2009 20:20:52 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[Open Source]]></category>
		<category><![CDATA[Programming]]></category>
		<category><![CDATA[Technology]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/?p=469</guid>
		<description><![CDATA[I recently did some web design work in collaboration with a graphic designer.  She introduced me to what has become my latest favorite piece of CSS code: 960.gs.
960.gs is a CSS grid framework, similar in spirit to Blueprint CSS and YUI Grid.  However, 960.gs is at once more minimalist than these approaches, and [...]]]></description>
			<content:encoded><![CDATA[<p>I recently did some web design work in collaboration with a graphic designer.  She introduced me to what has become my latest favorite piece of CSS code: <a href="http://960.gs/">960.gs</a>.</p>
<p>960.gs is a CSS grid framework, similar in spirit to <a href="http://www.blueprintcss.org/">Blueprint CSS</a> and <a href="http://developer.yahoo.com/yui/grids/">YUI Grid</a>.  However, 960.gs is at once more minimalist than these approaches, and more thorough.</p>
<p>The <a href="http://sonspring.com/journal/960-grid-system">author has a detailed blog post</a> explaining his motivations for working on 960.gs, so I won&#8217;t rehash each of those.  Instead, I&#8217;ll just dive into what I liked about it.</p>
<p><span id="more-469"></span></p>
<ol>
<li><b>Very simple and comprehensible name choices for CSS classes</b>: You can see their <a href="http://960.gs/demo.html">demo page</a> (view its source) for examples, but I can even summarize the approach in a few short sentences.  You begin a grid container with a <i>container_XX</i> class, where XX is the number of total grid columns in the container.  Every child element has a <i>grid_XX</i> class, which is the number of columns (aka colspan) for that element.  All grid_XX elements should add up to the XX amount in the container if you are using all the grid elements available.  To use larger gutter widths, you can use <i>prefix_XX</i> and <i>suffix_XX</i> classes.  Finally, for any child grid elements, you need to mark the first one with an <i>alpha</i> class and the last one with an <i>omega</i> class &#8212; this is necessary to get rid of left/right margins on starting and ending elements.</li>
<li><b>Excellent CSS generator</b>: this <a href="http://www.spry-soft.com/grids/">online CSS generator</a> tool lets you generate 960.gs CSS that is just right for your website.</li>
<li><b>jQuery-based bookmarklet for double-checking grid layouts</b>: another <a href="http://gridder.andreehansson.se/">online tool</a> is a bookmarklet which will &#8220;inject&#8221; a customizable grid overlay on any existing site, to help with alignment.</li>
<li><b>Templates for every major design tool</b>: I saved the best for last.  Nathan&#8217;s focus in designing 960.gs was to allow better collaboration between trained graphic designers (whose tools are typically Adobe Photoshop, Fireworks, Illustrator, etc.) and trained web designers (whose tools are things like Rails, Grails, Django).  To ease this collaboration, the author <a href="http://bitbucket.org/nathansmith/960-grid-system/src/tip/templates/">provides templates for every major graphic design tool</a> that has &#8220;grid overlays&#8221; compatible with the 960.gs framework.</li>
</ol>
<p>Finally, the entire project is hosted <a href="http://bitbucket.org/nathansmith/960-grid-system/">on bitbucket and developed in the open</a>.  What more could you ask for?  This has really simplified my approach to standard CSS designs.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2009/12/08/simplifying-css-with-960-gs/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Parse.ly presentation at NYC Search &amp; Discovery Meetup</title>
		<link>http://www.pixelmonkey.org/2009/11/09/parse-ly-presentation-at-nyc-search-discovery-meetup</link>
		<comments>http://www.pixelmonkey.org/2009/11/09/parse-ly-presentation-at-nyc-search-discovery-meetup#comments</comments>
		<pubDate>Mon, 09 Nov 2009 11:44:03 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[Startups]]></category>
		<category><![CDATA[Technology]]></category>
		<category><![CDATA[cogtree]]></category>

		<guid isPermaLink="false">tag:blog.cogtree.com://3ff8a70fcd1be6ee3b1e63380d9c6e58</guid>
		<description><![CDATA[Hi Parse.ly fans.  Andrew here.  I just wanted to let you know that I presented Parse.ly at the NYC Search &#038; Discovery Meetup on Thurs, Oct. 29.  The meetup is organized by Otis Gospodnetic (blog), who is one of the authors of Lucene in Action and the author of the ...]]></description>
			<content:encoded><![CDATA[<p>I presented Parse.ly at the NYC Search &#038; Discovery Meetup on Thurs, Oct. 29.  The meetup is organized by Otis Gospodnetic (blog), who is one of the authors of Lucene in Action and the author of the upcoming book, Solr in Action.  We make heavy use of Lucene and Solr on Parse.ly, so it was exciting to get an opportunity to present to a community of fellow technologists building systems with these excellent technologies.</p>
<p><span id="more-460"></span></p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2009/11/09/parse-ly-presentation-at-nyc-search-discovery-meetup/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Parse.ly releases new version on Sunday, Sept. 20</title>
		<link>http://www.pixelmonkey.org/2009/09/21/parse-ly-releases-new-version-on-sunday-sept-20</link>
		<comments>http://www.pixelmonkey.org/2009/09/21/parse-ly-releases-new-version-on-sunday-sept-20#comments</comments>
		<pubDate>Tue, 22 Sep 2009 00:56:51 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[Startups]]></category>
		<category><![CDATA[Technology]]></category>
		<category><![CDATA[cogtree]]></category>

		<guid isPermaLink="false">tag:blog.cogtree.com://a2bd2fb255fbc8ab2301c4d3cd19fc41</guid>
		<description><![CDATA[If you were trying to log into Parse.ly between 11pm-1am this Sunday, you may have noticed that it was intermittently down for maintenance.  Over the last several weeks, we've been working hard to roll out some new features, polish some rough edges, and improve our infrastructure after our launch last ...]]></description>
			<content:encoded><![CDATA[<p>If you were trying to log into Parse.ly between 11pm-1am this Sunday, you may have noticed that it was intermittently down for maintenance.  Over the last several weeks, we&#8217;ve been working hard to roll out some new features, polish some rough edges, and improve our infrastructure after our launch last &#8230;</p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2009/09/21/parse-ly-releases-new-version-on-sunday-sept-20/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Chase&#8217;s completely insecure and broken &#8220;secure&#8221; document exchange system (aka securedx, secure-dx)</title>
		<link>http://www.pixelmonkey.org/2009/08/21/chase-insecure</link>
		<comments>http://www.pixelmonkey.org/2009/08/21/chase-insecure#comments</comments>
		<pubDate>Fri, 21 Aug 2009 14:41:17 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[Programming]]></category>
		<category><![CDATA[Technology]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/?p=432</guid>
		<description><![CDATA[A few days ago, I got a call from my girlfriend, Olivia.  I was so deep in working on my startup, Parse.ly, that I hadn&#8217;t checked my bank account statements in several weeks.  We just went into private beta last Thursday, after DreamIt Demo Day.  She noticed some suspicious charges, and so [...]]]></description>
			<content:encoded><![CDATA[<p>A few days ago, I got a call from my girlfriend, Olivia.  I was so deep in working on my startup, <a href="http://parse.ly">Parse.ly</a>, that I hadn&#8217;t checked my bank account statements in several weeks.  We just went into private beta last Thursday, after <a href="http://www.techcrunch.com/2009/08/13/dreamit-releases-ten-startups-into-the-wild/">DreamIt Demo Day</a>.  She noticed some suspicious charges, and so I looked into them.  Indeed, it looked like I had been a victim of fraud: there were three charges that clearly was not me.</p>
<p>I immediately called Chase Customer Service.  In order to confirm the details about my account, the representative needed me to identify the fraudulent charges, but also identify charges that were actually valid.  For this latter bit, I needed to identify the time/place of a specific transaction.  This card was mostly used for online auto bill payments, so this turned out to be impossible for any of my last 20 valid payments. Yet the customer service rep insisted that I name a time and place.  I told her, &#8220;The time and place was whenever the server for this system decided to automatically bill my account.  I don&#8217;t know where their server is, I don&#8217;t know what time their cron jobs run.&#8221;</p>
<p>&#8220;Cron jobs?&#8221; she said.</p>
<p>Right, I had been hanging around techies at <a href="http://dreamitventures.com">DreamIt Ventures</a> for too long.  &#8220;Listen, the transaction didn&#8217;t take place physically, it took place digitally.  I can identify one transaction, which is about a month old, where I actually used the card in-person to buy something.&#8221;  She finally understood and let me move on.</p>
<p><a href="http://burakkanber.blogspot.com/">Burak</a> from <a href="http://trendsta.com">Trendsta</a> said he felt bad for me, for how patient I had to be with this person.  But that was the least of it.  This little technical misunderstanding was nothing compared to what followed.</p>
<p><span id="more-432"></span></p>
<p>I was told that in order to get a credit back from my account, they had to collect from me a signed affidavit indicating the charges were fraudulent.  This affadavit would be &#8220;securely shared&#8221; with me via e-mail.  OK, &#8220;sounds good&#8221; I said.  I waited around for the e-mail to come in.</p>
<p>Finally, two e-mails arrived in my inbox.  The important bits <span style="color: red">are in red</span>.  First:</p>
<blockquote>
<h3>Message from Chase Customer Claims Secure Document Exchange</h3>
<p><strong>From:</strong> <span style="color: red">chase_customer_claims@secure-dx.com</span></p>
<p>Welcome to the Chase Customer Claims Secure Document Exchange. You recently contacted Chase regarding your claim number XXXX. Your documents are available for your review.</p>
<p>Per our telephone conversation, you will need to register to our secure website. </p>
<p><strong style="color: red"><br />
Your initial password is: password</p>
<p>Your initial user name has been sent to you in a separate email.<br />
</strong></p>
<p>On your first log in, you will be required to select a new password.</p>
<p>Thank you for using Chase Customer Claims Secure Document Exchange.</p>
<p>To contact Chase for claim related questions or to withdraw your claim, please call 1-866-564-2262.
</p></blockquote>
<p>Any geek reading this will immediately identify some key things wrong with this e-mail that make it look like a total phishing expedition.  Namely:</p>
<ol>
<li>The e-mail address, rather than being from a chase.com domain, was from a strange domain named &#8220;secure-dx.com&#8221;.</li>
<li>Rather than sending a cryptographically secure, expiring activation link, a default password was sent in plain text.</li>
<li>To make matters worse, the password is the same for all users, and thus anyone who can guess my e-mail address can easily impersonate me on this &#8220;secure document&#8221; website.</li>
<li>The default password is &#8220;password&#8221;.  WTF?! I mean, c&#8217;mon?</li>
</ol>
<p>I didn&#8217;t quite understand why I needed a &#8220;second e-mail&#8221; now, but I opened it up.  Here it is, excerpted:</p>
<blockquote>
<h3>Your Chase Customer Claims Secure Document Exchange Electronic Package is available online</h3>
<p><strong>From:</strong> <span style="color: red">chase_customer_claims@secure-dx.com</span></p>
<p>ANDREW MONTALENTI,</p>
<p>Welcome to the Chase Customer Claims Secure Document Exchange.You recently contacted Chase regarding your claim number XXXX. Your documents are available for your review. </p>
<p>Per our telephone conversation, you will need to register to our secure website by clicking on the link below or copy and paste the link into your browser&#8217;s address bar.</p>
<p><span style="color: red">https://chase.secure-dx.com/consumerdcx-chase_atm</span></p>
<p>Your user name is my.email@hidden.com</p>
<p><span style="color: red">Your initial password has been sent to you in a separate email</span></p>
<p><span style="color: red">On your first log in, you will be required to select a new password. NOTE: This site is different from Chase.com and passwords are not related. Updating your password on Chase Customer Claims Secure Document Exchange will have no impact on established Chase.com passwords.</span></p>
<p>Once registered, you will be able to access your customer correspondence on our secure website. You may be offered the option to complete and sign the form online if you wish to do so. [...]
</p></blockquote>
<p>To say I was confused would be a major understatement.  I was downright depressed.</p>
<p>My guess is that the engineers at Chase thought that by separating the &#8220;password e-mail&#8221; from the &#8220;user e-mail&#8221;, that somehow made the whole communication more secure.  Two e-mails are better than one, right?</p>
<p>The most important thing to point to is the link.  The link where this secure communication will happen is <strong>not at the chase.com domain</strong>  Instead, it is at https://<strong>chase.secure-dx.com</strong>/consumerdcx-chase_atm.  There is no way, NO WAY this is a real Chase site, I think.</p>
<p>I click on the link and in Firefox, I see this:</p>
<p><img src="http://www.pixelmonkey.org/wordpress/wp-content/uploads/2009/08/chase_forgery.png" alt="chase_forgery" title="chase_forgery" width="435" height="228" class="aligncenter size-full wp-image-437" /></p>
<p>At this point, my paranoid self turns on.  Curious, I click through the link anyway.  And I see this:</p>
<p><img src="http://www.pixelmonkey.org/wordpress/wp-content/uploads/2009/08/chase_sdx.png" alt="chase_sdx" title="chase_sdx" width="600" height="294" class="aligncenter size-full wp-image-438" /></p>
<p>Now I&#8217;m really paranoid.  Links off secure-dx.com pointing back to chase.com&#8217;s privacy policy.  A username and password box and a sort of hokey imitation of the Chase.com web design.  I realize, holy shit, I&#8217;m being duped!  Not just small-time credit card fraud, but someone has managed to really take over my life!</p>
<p>Why am I freaking out?  The customer service person I talked to, I realize what must have happened.  That wasn&#8217;t Chase.  Someone stole my credit card information and then set up a call forwarding on my cell phone, somehow, to point Chase&#8217;s customer service number to some fraudulent interceptor.  This person then diligently took my claim only to send me an e-mail that would get yet more information out of me and take me for even more money.  I freaked!</p>
<p>Immediately, I double-checked my call logs and compared them to Chase.com customer service numbers.  I made sure to change my DNS server to OpenDNS to make sure no one was somehow intercepting that.  Finally, I realized I could look at the number written on the back of my Chase credit cards.  It all checked out &#8212; the number was good.  So I switched phone.  I called Chase customer service on both my phone and Olivia&#8217;s.  I made sure the messages were exactly the same.  From Olivia&#8217;s phone, I called back Chase again to speak to someone there about this.  But then I got even more paranoid &#8212; how big could this be? &#8212; so I decided to hang up.  Instead, I called my local Chase branch in my neighborhood.</p>
<p>With my local branch&#8217;s help, I got transferred via a branch office line to the actual Chase customer service.  <em>Finally on a secure line</em>, I thought to myself.  When they picked up, I was expecting to uncover the scam of the century.  I felt like an investigative journalist right on the tail of something truly big.</p>
<p>But then I spoke to the Chase representative, on the secure line, and she explained to me that this is just the normal procedure.  secure-dx.com is the website they use for &#8220;securely&#8221; sharing documents.</p>
<p>I was livid.  I explained everything wrong with this setup.  I demanded to speak to a supervisor.  I spoke to a supervisor.  He said he did not know why the system was the way it was.  He wasn&#8217;t a software guy.  He just knew that &#8220;with the way the business is changing lately, a lot of systems are in flux.&#8221;  I said this flux was unacceptable.  &#8220;I&#8217;m a software engineer,&#8221; I said.  &#8220;How can I possibly trust Chase to manage my financial accounts if something as simple as sharing a PDF document is done in the least secure way possible?&#8221;  What other skeletons might they have in the closet?</p>
<p>I wanted to be forwarded to the department responsible for that.  After my explanation to him of what was wrong, he fully understood the problem.  To his credit, he admitted it was wrong the way it was set up.  He actually tried to track down a supervisor.  But there was none that could field IT and software requests.</p>
<p>They promised to call me once they could track someone down to talk about this.  No call yet.</p>
<p>My excitement came down a couple of notches.  I was not the investigative journalist undercovering an elaborate scam any longer.  Instead, I was a software engineer.  And some members of my profession have let me down.  Big time.</p>
<p>In the meanwhile, I did the research and found the vendor who provided this service to Chase.  They are Wolters Kluwer, a &#8220;financial services and banking compliance solutions provider&#8221;.  The product page for &#8220;SDX&#8221;, <a href="http://www.wolterskluwerfs.com/Content/Products/ProductDetail/Secure_Document_Exchange.aspx">Secure Document Exchange</a>, is completely ludicrous.  They claim this product includes &#8220;industry-leading security, including PKI encryption and multi-level user authentication, to keep communications safe at every step of the process.&#8221;  </p>
<p>Right, so the password was <strong>sent in plain text</strong>.  The <strong>default password is &#8220;password&#8221;</strong>.  And, rather than having a chase.com subdomain which points at Wolters Kluwer&#8217;s server (e.g. secure-dx.chase.com) and sharing a secure chase.com certificate with them, they decide to host the whole thing outside of the chase.com domain, so that as a user, I have no way of confirming this actually is an e-mail or system originating from Chase.  Users are so confused by this that they have already reported it as a phishing scam, even though it is not one.  </p>
<p>That&#8217;s industry-leading?  That&#8217;s &#8220;safe communication&#8221;?</p>
<p>No, that&#8217;s a joke.  Chase should be ashamed.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2009/08/21/chase-insecure/feed</wfw:commentRss>
		<slash:comments>127</slash:comments>
		</item>
		<item>
		<title>For Linux/GNOME users: tired of nm-applet? Try wicd</title>
		<link>http://www.pixelmonkey.org/2009/07/31/for-linuxgnome-users-tired-of-nm-applet-try-wicd</link>
		<comments>http://www.pixelmonkey.org/2009/07/31/for-linuxgnome-users-tired-of-nm-applet-try-wicd#comments</comments>
		<pubDate>Fri, 31 Jul 2009 23:01:44 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[GNOME]]></category>
		<category><![CDATA[Open Source]]></category>
		<category><![CDATA[Technology]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/2009/07/31/for-linuxgnome-users-tired-of-nm-applet-try-wicd/</guid>
		<description><![CDATA[This post is only intended for those who actually run GNOME and Linux, just a warning  

I just replaced network-manager on my Ubuntu Jaunty desktop with wicd.  See wicd here:

http://wicd.sourceforge.net/

What&#39;s so great about wicd?  I used to think nm-applet and NetworkManager were the best thing since sliced bread, but have grown increasingly frustrated with [...]]]></description>
			<content:encoded><![CDATA[<p>This post is only intended for those who actually run GNOME and Linux, just a warning <img src='http://www.pixelmonkey.org/wordpress/wp-includes/images/smilies/icon_smile.gif' alt=':-)' class='wp-smiley' /> </p>
<p />
<div>I just replaced <b>network-manager</b> on my Ubuntu Jaunty desktop with <b>wicd</b>.  See wicd here:
<p />
<div><a href="http://wicd.sourceforge.net/">http://wicd.sourceforge.net/</a></div>
<p />
<div>What&#39;s so great about wicd?  I used to think nm-applet and NetworkManager were the best thing since sliced bread, but have grown increasingly frustrated with these tools over time.  Here&#39;s my short list of things I dislike about NM:</div>
<p><span id="more-427"></span></p>
<p />
<div>
<ul>
<li>The wifi network list is <b>unsorted</b> (rather than <b>obviously</b> being sorted by signal strength).</li>
<li>The wifi network list uses an animated progress bar.  This may look cool in screencasts, but when there are &gt;20 networks in range, pulling up the list brings my computer to a crawl (due to 20 animated progress bars).</li>
<li>The wifi network list is only accessible by clicking on the nm-applet icon &#8212; there is no &quot;full screen&quot; view for when you have a lot of networks in range.</li>
<li>Its logic for remembering and prioritizing networks is just plain wrong, and the UI for editing this stuff is broken.</li>
<li>It does a horrible job of guessing the authentication type of a network, and takes way too long authenticating.</li>
<li>There is no command-line way to switch networks, and NM so messes with your Linux network connections that using typical command-line tools becomes painful.  I run Linux for a reason, you know <img src='http://www.pixelmonkey.org/wordpress/wp-includes/images/smilies/icon_smile.gif' alt=':-)' class='wp-smiley' /> </li>
<li>NM is written in GObject/C.  I know GObject/C, but I also know enough to know that it&#39;s too much of a pain to go in there to fix any of these problems.</li>
</ul>
<p>Enter wicd.  It seems to fix all these problems.  Like NM, wicd runs as a daemon and it is via that daemon that networks are connected.  It has a systray app like nm-applet that is written in GTK+ and easily integrates with GNOME, which is called <b>wicd-client</b>.  Unlike nm-applet, wicd-client provides a fast and ergonomic interface for browsing networks.  If you have a lot of networks in range, you get a nice window with all of them sorted by signal strength, and can easily set up &quot;automatic connect&quot; settings.</div>
<div>
<p />
<div>wicd is also written in <b>Python</b>.  I think that gives it about +100 points above NM for me, as now I can actually submit patches against my wifi manager if anything bugs me.  But so far, it actually seems like quite a neat, robust, and good little app.</div>
<p><a href='http://posterous.com/getfile/files.posterous.com/pixelmonkey/Ifp8BLBdGyZyJY9AoIjcalZ7fhiMOWZ1HCsZ8u84s7jNQHuOT1PT65KlYRbm/Screenshot-Wicd_Network_Manage.png'><img src="http://posterous.com/getfile/files.posterous.com/pixelmonkey/eeNT6N2MWDtCrPWO41WJJWAoRcvih6Mr9RSmX8rTdMOvPHgMs1PuVUQNcEzr/Screenshot-Wicd_Network_Manage.png.scaled.500.jpg" width="500" height="389"/></a></p>
<p />
<div>wicd 1.6.2 (the latest version available on their <a href="http://sf.net">sf.net</a> page) also includes <b>wicd-curses</b>, an ncurses-based command-line client for the wicd daemon.  Yes!  I can finally manage my wifi networks from the command-line.  All in all, I&#39;m glad there is a competitor to NetworkManager that is getting actively developed, because I have lived frustrated with NM for too long.  Hooray for open source, it&#39;s all about choices!</div>
</p></div>
</div>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2009/07/31/for-linuxgnome-users-tired-of-nm-applet-try-wicd/feed</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>Trouble connecting to GTalk with Pidgin?</title>
		<link>http://www.pixelmonkey.org/2009/07/13/trouble-connecting-to-gtalk-with-pidgin</link>
		<comments>http://www.pixelmonkey.org/2009/07/13/trouble-connecting-to-gtalk-with-pidgin#comments</comments>
		<pubDate>Mon, 13 Jul 2009 19:05:26 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[GNOME]]></category>
		<category><![CDATA[Open Source]]></category>
		<category><![CDATA[Technology]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/2009/07/13/trouble-connecting-to-gtalk-with-pidgin/</guid>
		<description><![CDATA[After my recent upgrade to Pidgin 2.5.5 (on Ubuntu Jaunty), GTalk mysteriously stopped working.  Check out the FAQ entry on the Pidgin developer website for an explanation.  The workaround, not listed there, is to change your &#34;Connect Server&#34; to &#34;talk.google.com&#34;.  Pidgin will then prompt you once for a certificate, and after that, it will connect fine.

A developer [...]]]></description>
			<content:encoded><![CDATA[<p>After my recent upgrade to Pidgin 2.5.5 (on Ubuntu Jaunty), GTalk mysteriously stopped working.  Check out the <a href="http://developer.pidgin.im/wiki/Protocol%20Specific%20Questions#WhycantIlogontomyGoogleTalkGoogleAppsaccountanymore">FAQ entry</a> on the Pidgin developer website for an explanation.  The workaround, not listed there, is to change your &quot;Connect Server&quot; to &quot;<a href="http://talk.google.com">talk.google.com</a>&quot;.  Pidgin will then prompt you once for a certificate, and after that, it will connect fine.
<div></div>
<div>A developer in #pidgin on <a href="irc://irc.freenode.org">irc.freenode.org</a> told me to &quot;fix my router&quot; since my &quot;router was broken&quot;.  This even though the problem has now occurred on three separate LANs, two of which I don&#39;t own/control.  Routers that are used as DNS servers are <i>very</i> common, and the fact they are broken in this regard is a reality.  Wake up &#8212; realities trump ideal every time.  Pidgin should automatically work around this problem, IMO.</div>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2009/07/13/trouble-connecting-to-gtalk-with-pidgin/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>We’ve planted our roots, and now we’re growing…</title>
		<link>http://www.pixelmonkey.org/2009/07/06/we%e2%80%99ve-planted-our-roots-and-now-we%e2%80%99re-growing%e2%80%a6</link>
		<comments>http://www.pixelmonkey.org/2009/07/06/we%e2%80%99ve-planted-our-roots-and-now-we%e2%80%99re-growing%e2%80%a6#comments</comments>
		<pubDate>Tue, 07 Jul 2009 04:44:34 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[Startups]]></category>
		<category><![CDATA[Technology]]></category>
		<category><![CDATA[cogtree]]></category>

		<guid isPermaLink="false">tag:blog.cogtree.com://0e06e4115fcbfb1df8928ff1bd909155</guid>
		<description><![CDATA[Sorry for excessive metaphors related to trees, but it just seemed so fitting.

You see, for almost a year, Sachin (the other founder of Cog Tree) and I have spent every moment of our free time to the path of starting this company.  We felt quite nomadic during that time -- ...]]></description>
			<content:encoded><![CDATA[<p>Sorry for excessive metaphors related to trees, but it just seemed so fitting.</p>
<p>You see, for almost a year, Sachin (the other founder of Cog Tree) and I have spent every moment of our free time to the path of starting this company.  We felt quite nomadic during that time &#8212; &#8230;</p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2009/07/06/we%e2%80%99ve-planted-our-roots-and-now-we%e2%80%99re-growing%e2%80%a6/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Ubuntu Jaunty installation process</title>
		<link>http://www.pixelmonkey.org/2009/06/06/ubuntu-jaunty-installation-process</link>
		<comments>http://www.pixelmonkey.org/2009/06/06/ubuntu-jaunty-installation-process#comments</comments>
		<pubDate>Sat, 06 Jun 2009 21:17:39 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[Open Source]]></category>
		<category><![CDATA[Technology]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/?p=408</guid>
		<description><![CDATA[Today, I decided to finally sit down and upgrade my Ubuntu Intrepid installation to Ubuntu Jaunty.  I torrented the live DVD last night (causing my roommates to complain of major Internet hoggage &#8212; it was downloading at 1.2MB/sec!).  I then performed a full system backup to a remote hard drive, and then repartitioned [...]]]></description>
			<content:encoded><![CDATA[<p>Today, I decided to finally sit down and upgrade my Ubuntu Intrepid installation to Ubuntu Jaunty.  I torrented the live DVD last night (causing my roommates to complain of major Internet hoggage &#8212; it was downloading at 1.2MB/sec!).  I then performed a full system backup to a remote hard drive, and then repartitioned my drives this morning using gparted, the graphical partition editor that comes with Jaunty&#8217;s live DVD.</p>
<p>The process took some time, which is why I saved it for a weekend.  To backup my hard drive took about 2 hours, and doing the partitioning operations took about 3 hours.  I went out in the nice weather and picked up groceries while it was loading.</p>
<p>When I got back and could kick off the installation process, I was pleasantly surprised by the installation wizard UI.  It easily guided me through the partition setup process.  Even though in my case I had to make use of the &#8220;Advanced&#8221; editor, it easily visualized what was going on in my hard drive, and even detected the operating systems I had on there (WinXP and Intrepid).</p>
<p>I set up my new ext3 partitions (after deciding ext4 too unstable for my taste), and got started.  I was pleasantly surprised when instead of asking me to reboot my computer, it just <em>started</em> right up.  I still had access to a functioning computer while it was installing!  Nice.  That allowed me to jump on my blog and start on this post <img src='http://www.pixelmonkey.org/wordpress/wp-includes/images/smilies/icon_smile.gif' alt=':-)' class='wp-smiley' />   I even connected my MP3 player and have some tunes playing!</p>
<p>I was considering doing an upgrade of my system from Intrepid->Jaunty, but decided to give a clean installation a try.  I get the feeling that there is some &#8220;drag&#8221; in my Linux installation which has been running on my machine for almost 3 years now.  (Wow, has it been that long since I got this laptop?)  I went through multiple releases of Ubuntu via upgrades, and I simply feel my requirements for my system have shrunk so significantly that a clean install was best to ensure my system is configured well and cleanly.</p>
<p>What do I mean by &#8220;shrunk&#8221; requirements?  Well, when I profile the usage of my computer, nowadays 90% of what I do personally happens within Firefox.  The remaining 10% are all handed by newer software.  Among things that don&#8217;t include Firefox are browsing photos and listening to MP3s.  Even some of these tasks are moving to the web platform.</p>
<p>For my work on <a href="http://www.cogtree.com">Cog Tree</a>, I really only have 3 development tools I lean on directly: vim, WingIDE (Python), and Eclipse IDE (Java).  Javascript development and debugging happens inside a browser.  I still lean on VMWare to give me some high-quality creative professional tools from the Windows world, e.g. Photoshop and Topstyle (for CSS).  Aside from these, I don&#8217;t really need nor want much other software on my system.  Any other development tools can be installed on-demand using Synaptic.</p>
<p>Jaunty&#8217;s installation percentage is about 50% right now.  We&#8217;ll see how the system runs once it boots directly off the hard drive.  I&#8217;m pleasantly surprised that most of my hardware seems to be working out of the box.  Even my volume buttons, brightness buttons and media buttons on my laptop now work, which is a nice touch.  My sound quality is still a little poor due to a chipset detection problem that still seems to be present in the snd_hda_intel driver.  But I&#8217;m pretty sure by setting some options in /etc/modprobe.d/alsa-base I&#8217;ll be able to get it working better.</p>
<p>People who know me know that I&#8217;m very skeptical about my computer and about Linux.  I regularly complain about all the little silly regressions that Linux has suffered over the years.  I&#8217;m also particularly upset about how certain beautiful and essential pieces of software never end up making it into the Linux mainstream, e.g. TuxOnIce.  But hopefully, Jaunty will capture my heart this time, and gain some love from this Linux cynic&#8230;</p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2009/06/06/ubuntu-jaunty-installation-process/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Favorite PyCon 2009 talks</title>
		<link>http://www.pixelmonkey.org/2009/04/06/favorite-pycon-2009-talks</link>
		<comments>http://www.pixelmonkey.org/2009/04/06/favorite-pycon-2009-talks#comments</comments>
		<pubDate>Mon, 06 Apr 2009 15:10:13 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[Open Source]]></category>
		<category><![CDATA[Programming]]></category>
		<category><![CDATA[Technology]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/?p=385</guid>
		<description><![CDATA[I attended PyCon 2009 this year, which was a whole lot of fun.  Quite a few people have asked me which talks I liked, so I decided to put together my &#8220;top 5 talks&#8221; list, in ranked order:

A Whirlwind Excursion through Writing a C Extension.  This talk by Ned Batchelder (author of coverage.py [...]]]></description>
			<content:encoded><![CDATA[<p>I attended PyCon 2009 this year, which was a whole lot of fun.  Quite a few people have asked me which talks I liked, so I decided to put together my &#8220;top 5 talks&#8221; list, in ranked order:</p>
<ol>
<li><a href="http://pycon.blip.tv/file/1957417/">A Whirlwind Excursion through Writing a C Extension</a>.  This talk by Ned Batchelder (author of coverage.py and cog) shows that you can write a Python C extension module in under 20 minutes.  This is my top talk because I never thought that my skills in C would be so directly useful in writing Python applications.  Considering <i>how damn easy</i> it is to write a basic C extension module, I wouldn&#8217;t be surprised if the only reason I ever write C code again is to implement some Python functions or types in C.  Truly the best of both worlds!</li>
<li><a href="http://pycon.blip.tv/file/1957215/">Reinteract: a better way to interact with Python</a>.  Owen Taylor (of GNOME/GTK+ fame) has spent some time over the last few months building a better Python shell.  Specifically, it&#8217;s a lightweight shell that is meant to be a prototyping or &#8220;worksheet&#8221; environment a la Matlab, Mathematica, or Maple.  Except, you&#8217;re running and re-evaluating Python code.  It even supports things like in-line graph plotting, but I&#8217;ve already used it to experiment with Python web services API.  Any Python programmer who has been frustrated with IPython before should check out Reinteract.</li>
<li><a href="http://pycon.blip.tv/file/1947373/">Easy AI with Python</a>.  This talk might have gotten the #1 slot for most interesting, but not the #1 slot overall because it seems like this talk has been given at a lot of conferences (not just PyCon) over the last few years.  This talk introduces some complex AI topics in a very short time frame, and in a very intuitive way.  For me, the neural networks example with Jets and Sharks was particularly impressive.  Raymond Hettinger is a great presenter, and if you have some time you should definitely check out his recipes on <a href="http://code.activestate.com/recipes/users/178123/">ActiveState&#8217;s Python Cookbook</a> and his <a href="http://users.rcn.com/python/download/Descriptor.htm">How-to Guide for Descriptors</a>.</li>
<li><a href="http://pycon.blip.tv/file/1957071/">Abstraction as Leverage</a>.  A talk by one of my favorite Python authors, Alex Martelli (who wrote the best book on Python on the market, <i>Python in a Nutshell</i>), this talk isn&#8217;t so much about Python as it is about software engineering overall.  But it&#8217;s thought-provoking as his talks usually are.</li>
<li><a href="http://pycon.blip.tv/file/1949345/">Class Decorators: Radically Simple</a>.  The presenter is the author of the Class Decorators PEP, Jack Diederich.  If you like decorators and you are curious about metaclasses, you&#8217;ll love class decorators.</li>
</ol>
<p>Feel free to share your favorites!</p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2009/04/06/favorite-pycon-2009-talks/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Beautiful Code and a Beautiful Bug</title>
		<link>http://www.pixelmonkey.org/2009/02/28/beautiful-code-and-a-beautiful-bug</link>
		<comments>http://www.pixelmonkey.org/2009/02/28/beautiful-code-and-a-beautiful-bug#comments</comments>
		<pubDate>Sun, 01 Mar 2009 02:32:14 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[Personal]]></category>
		<category><![CDATA[Programming]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/?p=374</guid>
		<description><![CDATA[I am teaching a technical course on the popular and ubiquitous version control system, Subversion, this Monday.  I thought it might be fun to give my class a little &#8220;extra credit&#8221; reading from the O&#8217;Reilly book, Beautiful Code.  In it, one of the original authors of Subversion, Karl Fogel, shares what he considers [...]]]></description>
			<content:encoded><![CDATA[<p>I am teaching a technical course on the popular and ubiquitous version control system, <a href="http://subversion.tigris.org/">Subversion</a>, this Monday.  I thought it might be fun to give my class a little &#8220;extra credit&#8221; reading from the O&#8217;Reilly book, <a href="http://oreilly.com/catalog/9780596510046/">Beautiful Code</a>.  In it, one of the original authors of Subversion, Karl Fogel, shares what he considers to be the most beautiful internal design within the codebase: the <a href="http://www.red-bean.com/kfogel/beautiful-code/bc-chapter-02.html">SVN delta editor</a>.  Though this API is not directly used in doing Subversion development, I thought it might be cool for students to have a deeper understanding of the thought that went into SVN&#8217;s codebase.  But when trying to print up some copies of the chapter for the class, I got more than I bargained for&#8230;</p>
<p><span id="more-374"></span></p>
<p><img src="http://www.pixelmonkey.org/wordpress/wp-content/uploads/2009/02/caterpillar-300x199.jpg" alt="" title="caterpillar" width="300" height="199" class="alignright size-medium wp-image-375" /></p>
<p>I highly recommend the entire book.  It is not so much a book about beautiful code as about passionate and opinionated programmers and their tastes.  But this is a good thing.  It was one of the few books about software that I have read in the last decade or so that actually gave me entirely positive feelings about my profession.  There is so much raw creativity and thought captured in these few essays.  What <a href="http://en.wikipedia.org/wiki/Brian_Kernighan">Brian Kernighan</a> finds beautiful is entirely different from what <a href="http://en.wikipedia.org/wiki/Yukihiro_Matsumoto">Matz</a> or <a href="http://en.wikipedia.org/wiki/Simon_Peyton_Jones">simonpj</a> find beautiful.  And that&#8217;s the thing about a fundamentally creative craft like software.  You put five software engineers in a room with a piece of code, and you&#8217;re lucky if you come out with only six different opinions about it.  It&#8217;s like art, or writing.  Taste matters.</p>
<p>I don&#8217;t recommend people read Beautiful Code to try to imitate some of the code described therein.  Instead, I recommend you read it as a sociological or psychological study of what makes proud and bright software engineers tick.  For example, for Kernighan it is the simplicity and minimalism that is embodied in UNIX.  For Matz, it is the notion that the programming language should be as syntactically flexible as our real languages are.  For simonpj, it&#8217;s that complicated can be made easy, given the right abstractions.  And for Jon Bentley, in one of the more thought-provoking essays in the book, beauty and elegance was only perceived as the size of his code <i>shrank</i>.</p>
<p><img src="http://www.pixelmonkey.org/wordpress/wp-content/uploads/2009/02/acroread_disaster1.png" alt="" title="acroread_disaster1" class="alignleft size-full wp-image-376" /></p>
<p>The essay about the SVN Delta Editor not only illuminates the internals of SVN, but also illustrates the social dimension to software engineering and design.  It is a story about programmers, debating an API, producing it, and then putting it into practice.  It is about give and take, and an unteachable skill in problem size and complexity reduction.  All this in C!  There was a period of time in university where I actually programmed in C full-time, so I have a lot of respect for the elegance with which they crafted this powerful API.  C gives you few tools (like OO or explicit interfaces) for doing this kind of work; they had to work in spite of the language&#8217;s features and plan carefully.</p>
<p>I have about twenty students in my class, so I was going to print up one copy and get it copied and stapled at a local print shop.  (See <a href="#note-on-copyright">note on copyright below</a>.)  I opened up my ebook PDF of Beautiful Code with acroread on UNIX.  I navigated to the right chapter and realized that I wanted to print just that single chapter.  I always remember being annoyed whenever I had to do this, for a number of reasons.</p>
<ol>
<li>PDF ebooks sometimes lack the proper &#8220;bookmark&#8221; information to navigate to the right section to print</li>
<li>Since ebooks were once print copies, they tend to have page numbers at the bottom of each page.  But since the ebook itself has a different page numbering scheme, all sorts of psychic dissonance occurs.  You navigate to page 30 (in the print copy) but have to note that it&#8217;s actually page 42 in the ebook.  You then navigate to page 45 (in the print copy) but have to note that it&#8217;s actually 57 in the ebook.</li>
<li>OK, now I know what I need to print&#8230; I think.  So now I have to enter one of those print ranges in the &#8220;Print&#8221; dialog. Is it 30-42?  No, wait, it&#8217;s 42-45&#8230; I mean, 42-57 &#8212; that&#8217;s it!  Is that inclusive or exclusive? <img src='http://www.pixelmonkey.org/wordpress/wp-includes/images/smilies/icon_smile.gif' alt=':-)' class='wp-smiley' />   Oh, my&#8230;</li>
</ol>
<p>It&#8217;s really not <i>that</i> bad, and it&#8217;s only an occasional annoyance, but it&#8217;s always there.  I&#8217;m sure you know what I&#8217;m talking about.</p>
<p><img src="http://www.pixelmonkey.org/wordpress/wp-content/uploads/2009/02/acroread_disaster2.png" alt="" title="acroread_disaster2" class="alignright size-full wp-image-377" /></p>
<p>I had recently upgraded to acroread and noticed that the UI was all spiffed up.  And I noticed that this ebook had the right metadata for the bookmarks.  I thought to myself, &#8220;Wouldn&#8217;t it be nice if acroread supported printing a <strong>chapter</strong>?&#8221;  I right-clicked on the first entry in the chapter bookmark and was astonished.  Lo and behold, my feature existed!  (See the image to the right.)  I clicked the &#8220;Print Pages&#8230;&#8221; button with a bit of discomfort.  I don&#8217;t trust software too often, and am always suspicious when I find a feature I didn&#8217;t expect to be there.  It&#8217;s like my inner programmer is saying, &#8220;Yea, right &#8212; too good to be true.&#8221;</p>
<p>A few minutes later, my chapter was printed.  I looked it over, and brought it with my other materials to the local print shop.  One hour later, I picked up my copies and brought them home to look them over.</p>
<p>I noticed something very strange.  Instead of my copies containing pages 42-57, they contained pages 42, 43, 46, 51, 55, and 57.  <i>Damn it</i>.  There didn&#8217;t seem to be much of a rhyme or reason to the pages that were selected.  What kind of sequence was this?  I felt that there <i>must</i> be some pattern, some fibonacci-like, non-obvious sequence that applied to these pages.  I suspected the first, and obvious, culprit: that the printer had made a mistake.  <i>Maybe it&#8217;s a human error</i>.  But then I looked over my original and indeed, the original only had those pages.  Not a human error.  I thought to myself, &#8220;How is this possible?&#8221;</p>
<p><img src="http://www.pixelmonkey.org/wordpress/wp-content/uploads/2009/02/butterfly-150x150.jpg" alt="" title="butterfly" width="150" height="150" class="alignright size-thumbnail wp-image-380" /></p>
<p>Of course, I&#8217;ve probably given you enough information that you&#8217;ve already figured it out.  Especially if you&#8217;re a programmer.  We&#8217;re just wired to think this way.  But in case you haven&#8217;t figured it out, I&#8217;ll indulge you.</p>
<p>When I went back into acroread, tracing back my steps, I noticed something about that menu item I clicked.  It didn&#8217;t say <i>Print chapter</i>.  Instead, it said, <i>Print pages</i>.  Now, conceptually that seems like a small distinction, but I picked up on it.</p>
<p>I started to think like a programmer, rather than a user.  This function with a for loop emerged from the program and hovered above it, almost magically.  It said:</p>

<div class="wp_syntax"><div class="code"><pre class="python" style="font-family:monospace;"><span style="color: #ff7700;font-weight:bold;">def</span> print_pages<span style="color: black;">&#40;</span><span style="color: #008000;">self</span>, selected<span style="color: black;">&#41;</span>:
    to_print = <span style="color: black;">&#91;</span><span style="color: black;">&#93;</span>
    <span style="color: #ff7700;font-weight:bold;">for</span> bookmark <span style="color: #ff7700;font-weight:bold;">in</span> selected.<span style="color: black;">self_and_bookmarked_children</span><span style="color: black;">&#40;</span><span style="color: black;">&#41;</span>:
        to_print.<span style="color: black;">append</span><span style="color: black;">&#40;</span>bookmark.<span style="color: black;">page</span><span style="color: black;">&#40;</span><span style="color: black;">&#41;</span><span style="color: black;">&#41;</span>
    PrintSubsystem.<span style="color: black;">queue_job</span><span style="color: black;">&#40;</span>to_print<span style="color: black;">&#41;</span></pre></div></div>

<p>Then I realized the pattern in the pages it picked.  There was no pattern.  This was a beautiful little bug.  A <i>butterfly</i>.</p>
<p>You see, within the narrow world of this <i>Print Pages</i> function, the &#8220;feature&#8221; works as expected.  But from a user&#8217;s perspective, it makes absolutely no sense.  Rather than printing everything from that bookmark to the next bookmark at the same level (that is, rather than printing a <i>chapter</i>), it printed each <i>individual page that happened to be physically bookmarked (or &#8217;sub-bookmarked&#8217;) in the PDF, at or below that level</i>.  This resulted in a bunch of pages being printed that happened to be the pages on which subsections began.  But this left out most of the chapter, somewhat randomly.</p>
<p>The worst traits of our profession come out when it is at its least social.  I have no doubt that this function that prints these pages was written by a single programmer in a windowless room, without any peer review, pair programming, or other check on his logic.  I am sure that he was given the narrow and ill-defined requirement to enable an action to &#8220;print bookmark pages&#8221;.  He needed to <i>think</i>, but instead, he decided to code.  And coding got &#8220;it&#8221; done, for some very weird value of &#8220;it&#8221;.  He was probably under time pressure.  But one thing is certain to me: he was alone.  No two programmers, debating the design and implementation of this feature, would let each other make this mistake.</p>
<p>The behavior it exhibited truly caught me by surprise.  Strange as it sounds, I admired how easily I had been duped by this feature.  The human error &#8212; the anti-social error &#8212; made by that programmer exhibited an odd and enigmatic computer behavior.  A human inelegance created a strange sort of cruel machine elegance.</p>
<p>I found it ironic that in trying to print a chapter about beautiful design from a book called <i>Beautiful Code</i>, I came across this beautiful bug.  I call the bug beautiful because it managed to fool me, to get me to suffer its wrath while thinking I was getting some convenience.  It exhibited behavior that challenged me to identify a pattern, where there was none.  It was so clever, it even cost me money (the printing charges).  And even though I was a discerning programmer &#8212; skeptical of the feature, and so unsure of the software&#8217;s operation that I checked the output, albeit too briefly &#8212; this little bug managed to outsmart me.</p>
<p>My students will have to live without the chapter, or read it online on their own.  I&#8217;m not upset about it.  There can be beauty, even in failure.</p>
<p><small><strong><a name="note-on-copyright">A note about copyright:</a></strong> some readers on reddit and on my comments section suggested that I might be ignoring copyright issues by thinking that I could just photocopy a chapter from this book to distribute to my students.  Trust me, I know about copyright.  The content of this chapter happens to be available <a href="http://www.red-bean.com/kfogel/beautiful-code/bc-chapter-02.html">online for free</a> under <a href="http://creativecommons.org/licenses/by/3.0/">Creative Commons Attribution 3.0</a>.  Karl Fogel, the author of the article, has even given his informal blessing in my comments section.  And finally, by most people&#8217;s interpretation of the rules of Fair Use, it was OK for me to copy a chapter for my classroom.  I&#8217;m surprised no one suggested that this bug might be beautiful in another way: that it saved me from a copyright disaster.  I don&#8217;t think it was <i>that</i> good&#8230; <img src='http://www.pixelmonkey.org/wordpress/wp-includes/images/smilies/icon_smile.gif' alt=':-)' class='wp-smiley' />   If you are really interested in seeing a debate about this, you can read <a href="http://www.reddit.com/r/programming/comments/814ku/beautiful_code_and_a_beautiful_bug/c07z97y">this thread on reddit</a>.  Warning, somewhat painful and longwinded.  (Also, if you clicked the anchor link within the article to get to this note, simply click &#8220;back&#8221; in your browser to return and continue reading.)</small></p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2009/02/28/beautiful-code-and-a-beautiful-bug/feed</wfw:commentRss>
		<slash:comments>11</slash:comments>
		</item>
		<item>
		<title>A New Yorker&#8217;s Take on San Francisco</title>
		<link>http://www.pixelmonkey.org/2007/08/07/san-francisco-trip</link>
		<comments>http://www.pixelmonkey.org/2007/08/07/san-francisco-trip#comments</comments>
		<pubDate>Wed, 08 Aug 2007 03:38:48 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[Personal]]></category>
		<category><![CDATA[Programming]]></category>
		<category><![CDATA[Technology]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/2007/08/07/san-francisco-trip/</guid>
		<description><![CDATA[I just got back from San Francisco.  This wasn&#8217;t my first time to the west coast, but it was my first time to Northern California.  Overall, I had an amazing time.

This trip emerged as a major convenience for me.  My brother was heading out to California for the Real Estate Connect conference, [...]]]></description>
			<content:encoded><![CDATA[<p>I just got back from San Francisco.  This wasn&#8217;t my first time to the west coast, but it was my first time to Northern California.  Overall, I had an amazing time.<br />
<span id="more-359"></span></p>
<p>This trip emerged as a major convenience for me.  My brother was heading out to California for the <a href="http://www.realestateconnect.com/">Real Estate Connect</a> conference, since his company is intimately involved with Real Estate technologies.  But he didn&#8217;t want to go alone, so he paid for my plane ticket and hotel stay the first few nights to convince me to come out.  (Thanks, Alex!)</p>
<p>I got in touch with some people I knew out there, but many of them weren&#8217;t going to be around during my stay, due to summer vacations, etc.</p>
<p>Joseph Sofaer, a friend of mine from NYU, was gracious enough to delay a trip to Europe to show me around the area.  I was even lucky enough that the first first day I was there, he invited me to a party at the Facebook headquarters in Palo Alto, CA, where I briefly met Mark Zuckerberg, saw Robert Scoble walking around, and met about twenty other software developers in a room of 300, who worked for companies like Yahoo, Pandora, del.icio.us, and, of course, Facebook itself.</p>
<p>The train ride home, I was riding with the <a href="http://www.milliondollarhomepage.com/faq.php#2">creator</a> of the <a href="http://www.milliondollarhomepage.com/">MillionDollarHomepage</a>, probably the best website idea of all time.</p>
<p><strong>Palo Alto and Software is Sexy<br />
</strong> &#8212;<br />
The vibe in Palo Alto was enviable, especially for a native New Yorker.  When I pull out my laptop on the train or in a cafe in NY, screens full of code or running with full-screen vterms, I get stares and strange looks.  (Including right now, as I write this blog post on the LIRR&#8230;)  In Palo Alto, my brother and I walked by two or three cafes, and in each I saw young guys and gals at their laptops, coding away, screens full of GNU make output scroling by, emacs and vim buffers splitting off.  I overheard conversation snippets like, &#8220;we&#8217;re hoping to release our next version in a couple weeks&#8221;, &#8220;you have got to try metaclass programming with Python&#8221;, and &#8220;did you see that article on /.?&#8221;</p>
<p>In New York, people aren&#8217;t that proud to be a geek.  You go to a typical gathering and say, &#8220;I&#8217;m a software developer&#8221; and the typical response is, &#8220;Oh&#8230;&#8221;, followed by silence, followed by, &#8220;I think I need another drink&#8230;&#8221;.  Sexy in New York, programming isn&#8217;t.  If you want sex appeal, go into finance, law, or politics.</p>
<p>Opposite in Palo Alto, of course.  Which makes you feel great as a software developer.  What are you into?  If you answer, &#8220;Stocks, bonds, and the market&#8221; you&#8217;ll get the treatment I described above.  You answer, &#8220;Ruby on Rails&#8221; and you&#8217;ll be having a 2-hour, heated conversation.</p>
<p>BTW, the Silicon Valley excitement about Ruby on Rails is palpable.  Everyone wants a Rails developer.</p>
<p>A quick anecdote to illustrate the NY disdain for geeks: I was out with a friend once who had attend culinary school and was trying her way up the restaurant ladder, to become a chef.  She complained, however, that the money in these entry level jobs (food preparer, etc.) in the kitchen was way too little, that it was difficult to get by.  So, someone suggested, &#8220;Why don&#8217;t you waitress on the side?&#8221;</p>
<p>Her response, &#8220;Waitress?  I&#8217;m trying to become a chef.  That&#8217;s like saying to someone who wants to run a company, &#8216;Why don&#8217;t you work as an IT guy?&#8217;&#8221;</p>
<p>Something tells me that joke wouldn&#8217;t work that well in Palo Alto.</p>
<p><strong>San Francisco and Good Coffee<br />
</strong> &#8212;<br />
It was great to be able to get a little sense of the Silicon Valley vibe on my first day in Northern California.  But by the end of the day, my head was spinning.  I was ready to head back to an environment that was less technobubble, something a bit more real.</p>
<p>My second day there, I walked around some neighborhoods on my own, particularly Union Square (which is a bit of a tourist center), the Mission (which reminds me of Astoria, but with a different set of ethnic groups), and Noe Valley (which reminds me of the Upper East Side, but with houses instead of apartment buildings).</p>
<p>In the Mission, I ended up stopping by a coffee place named <a href="http://www.philzcoffee.com/">Philz</a>.  I asked for an iced coffee.  I then watched as the barrista (who I think was <a href="http://www.philzcoffee.com/philcoffee.html">Phil</a>!) took a scoop of coffee beans, ground them in a grinder, put them in a coffee machine, and made a fresh cup of coffee.  Some ice went in with frothed milk atop it.  I kid you not, the <strong><em>BEST</em></strong> iced coffee I have ever had.</p>
<p>Later in the day, when I met up with Joey at his apartment, I mentioned that I had just stumbled upon the best iced coffee of my life a couple hours ago.  And he said, &#8220;Oh, man&#8230; if you want good coffee, you have to try this place Philz.&#8221;</p>
<p>I laughed and said &#8220;THAT&#8217;s exactly where I was!&#8221; and he responded, &#8220;Man, you had &#8216;just stumbled upon&#8217; possibly the best coffee in the world.&#8221;  So that was a bit of good luck.  We ended up going back to Philz later that day <img src='http://www.pixelmonkey.org/wordpress/wp-includes/images/smilies/icon_wink.gif' alt=';-)' class='wp-smiley' /> </p>
<p>Joey had to leave the next day for Europe, but we spent the rest of the afternoon chatting about software ideas, in particular details about his latest idea, a Blackboard replacement application hosted on the Facebook Platform.  If you&#8217;re on the Facebook, check out the application called &#8220;Courses&#8221;.  It&#8217;s quite cool, even if it is in the early stages.</p>
<p><strong>The Weekend</strong><br />
&#8212;<br />
My brother&#8217;s real estate conference was winding down, so he snuck me in so I could catch the last couple presenters.  Unfortunately, I had missed the presentation by Craig Newmark (of craiglist fame), which was apparently pretty good.  Instead, I caught a panel by some head honchos of real estate technology at Google, Yahoo, Microsoft and Realtor.com.This panel was mighty uninteresting.  Despite the fact that these guys were all supposed to be team leads and head-techies-in-charge, they all gave tired lines and made me question whether they actually knew what they were talking about.</p>
<p>Nonetheless, it was interesting to see a conference of this kind &#8212; lots of buzz, lots of software developers all gathered together, a lot of excitement about an emerging market.</p>
<p>That afternoon, we took a bus tour of San Francisco, which was well worth it due to the hilarious tour guide named &#8220;Silvio.&#8221;</p>
<p>We spent that night at a Vietnamese Restaurant named &#8220;<a href="http://www.lecolonialsf.com/index_flash.html">La Colonial</a>&#8220;.  Excellent.</p>
<p>Saturday morning, we walked around the city, starting out in Union Square, moving through to Civic Center.  We stopped at the <a href="http://www.asianart.org/">Asian Art Museum</a>, where I saw an exhibit on <a href="http://www.marvelofmanga.org/">Manga</a> and <a href="http://www.asianart.org/yoshitoshi.htm">Japanese Wood Block art</a>, both very good, among others.  Finally, we ended up in the Lower Haight and Haight Ashbury, where we spent the afternoon lounging and exploring.</p>
<p>At night, we headed to North Beach and <a href="http://www.stepsofrome.com/">ate dinner</a> there.  We ended the night at the bar at the top of the Sir Francis Drake hotel, which my brother said reminded him a bit of Windows on the World, when that was still around.</p>
<p><strong>Conclusion</strong><br />
&#8212;</p>
<p>For a short trip, I got to see a good chunk of the city, and even got to take that important visit outside the city.  Overall, I had a great time.</p>
<p>As a technologist based out of New York, I have to say that San Francisco is quite appealing.  The weather, the laid back attitude, the independent shops, cafes and restaurants, the technology buzz.  But moving there would certainly seem like selling out.  Sure, we may not be able to <a href="http://www.paulgraham.com/siliconvalley.html">reproduce Silicon Valley</a> but we can <a href="http://en.wikipedia.org/wiki/Silicon_Alley">do our own thing</a>.  New York is too strong a city to be left in the hands of financiers and lawyers.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2007/08/07/san-francisco-trip/feed</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>An Empty Calendar, a Dusty Blog</title>
		<link>http://www.pixelmonkey.org/2007/07/08/an-empty-calendar-a-dusty-blog</link>
		<comments>http://www.pixelmonkey.org/2007/07/08/an-empty-calendar-a-dusty-blog#comments</comments>
		<pubDate>Sun, 08 Jul 2007 19:52:25 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[Personal]]></category>
		<category><![CDATA[Politics]]></category>
		<category><![CDATA[Technology]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/2007/07/08/an-empty-calendar-a-dusty-blog/</guid>
		<description><![CDATA[I took a look at my Wordpress calendar, and realized I haven&#8217;t written a post in over a month.  A sad state of affairs &#8212; I guess my blog waxes/wanes in and out of popularity for me.
One thing I have wanted to do is to create a &#8220;schism&#8221; in my blog between the political [...]]]></description>
			<content:encoded><![CDATA[<p>I took a look at my Wordpress calendar, and realized I haven&#8217;t written a post in over a month.  A sad state of affairs &#8212; I guess my blog waxes/wanes in and out of popularity for me.</p>
<p>One thing I have wanted to do is to create a &#8220;schism&#8221; in my blog between the political and technological sections.  I realize there is no sense forcing my audience to wade through technology posts to get to the political stuff they may be interested in, and vice versa.</p>
<p>The main thing stopping me from doing so is the fact that even as I have a single blog for these two topics, I hardly find the time to post to either of them.  That isn&#8217;t to say I don&#8217;t have much to say.  I&#8217;ve been reading quite a bit lately about Lisp (for the first time in my life), and have interesting ideas surrounding my use of <a href="http://www.eclipse.org">Eclipse</a> technologies and modeling tools at work.  I have been following a lot on the political side of things, from Libby&#8217;s commuted sentence to debates over globalization, to WSJ&#8217;s potential new owner.  And I&#8217;ve finished a slew of books, from John Kenneth Galbraith&#8217;s <em>The Affluent Society</em> to Jared Diamond&#8217;s <em>Guns, Germs and Steel</em>.</p>
<p>But I just lack the time to write.  I&#8217;m busy at work (at least 10-12 hours a day, when you include commute time), and the last thing I want to do when I get home is use computers some more.  Which is sad, but an inevitable result of my situation.</p>
<p>I truly do not want this blog to die.  How might I save it?</p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2007/07/08/an-empty-calendar-a-dusty-blog/feed</wfw:commentRss>
		<slash:comments>4</slash:comments>
		</item>
		<item>
		<title>Dilbertization of IT</title>
		<link>http://www.pixelmonkey.org/2007/03/19/dilbertization-of-it</link>
		<comments>http://www.pixelmonkey.org/2007/03/19/dilbertization-of-it#comments</comments>
		<pubDate>Mon, 19 Mar 2007 18:14:18 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[Programming]]></category>
		<category><![CDATA[Technology]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/2007/03/19/dilbertization-of-it/</guid>
		<description><![CDATA[There is an article on eWeek I encountered via del.icio.us called &#8220;The Dilbertization of IT.&#8221;  Though it says a lot of stuff most IT workers already know (that in many places, the &#8220;creative&#8221; work is being de-emphasized while &#8220;firefighting&#8221; or &#8220;maintainence&#8221; is emphasized), the more important thing to point out is the cause of [...]]]></description>
			<content:encoded><![CDATA[<p>There is an article on eWeek I encountered via del.icio.us called &#8220;<a href="http://www.eweek.com/article2/0,1895,2104997,00.asp">The Dilbertization of IT</a>.&#8221;  Though it says a lot of stuff most IT workers already know (that in many places, the &#8220;creative&#8221; work is being de-emphasized while &#8220;firefighting&#8221; or &#8220;maintainence&#8221; is emphasized), the more important thing to point out is the cause of this Dilbertization.  I found an insightful <a href="http://www.eweek.com/talkback_details/0,1932,s=26767&#038;a=203343,00.asp?m=22328">comment</a> which points to some of them.</p>
<blockquote><p>Dilbert&#8217;s pointy-headed managers are everywhere. In my current Fortune 100 company, virtually none of the managers with any authority have ANY IT development background. They manage entirely by cost and project plan &#8211; ignoring any and all input from those developers who actually have a successful track record.</p></blockquote>
<p>I can&#8217;t say this is true in my team, at my company, but I have certainly heard it from a lot of my IT friends.  Also, I have an acquaintence who is an IT Project Manager who thinks that development is &#8220;easy work&#8221; and that most software developers are just &#8220;lazy&#8221;, which is why projects end up behind schedule.  I think many <a href="http://innumeracy.com/">innumerate</a> IT managers share this opinion, and this can lead to problems, low morale, and resentment.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2007/03/19/dilbertization-of-it/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Nat&#8217;s Pendulum</title>
		<link>http://www.pixelmonkey.org/2007/03/18/nats-pendulum</link>
		<comments>http://www.pixelmonkey.org/2007/03/18/nats-pendulum#comments</comments>
		<pubDate>Sun, 18 Mar 2007 19:24:57 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[GNOME]]></category>
		<category><![CDATA[Open Source]]></category>
		<category><![CDATA[Programming]]></category>
		<category><![CDATA[Technology]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/2007/03/18/nats-pendulum/</guid>
		<description><![CDATA[Metacity (the window manager for GNOME) has this annoying and ugly minimize animation that looks like a bunch of cascading rectangles flying at your taskbar.  I&#8217;ve always hated it, but dealt with it for awhile.
Today, I did some digging on the Metacity bugzilla to see if it was fixed, and found this bug.
Over the [...]]]></description>
			<content:encoded><![CDATA[<p>Metacity (the window manager for GNOME) has this annoying and ugly minimize animation that looks like a bunch of cascading rectangles flying at your taskbar.  I&#8217;ve always hated it, but dealt with it for awhile.</p>
<p>Today, I did some digging on the Metacity bugzilla to see if it was fixed, and found <a href="http://bugzilla.gnome.org/show_bug.cgi?id=95777">this bug</a>.</p>
<p>Over the course of 3.5 years, this bug has sat on the bugzilla, and still isn&#8217;t satisfactorily resolved.  There is now a reduced_resources flag in gconf, but this flag only disables the minimize animation at the expense of forcing you to use an ugly wireframe window dragging animation.  (Complete, utter insanity.)</p>
<p><span id="more-349"></span></p>
<p>I don&#8217;t understand how after two years of debate, and nearly 3.5 years down th road from when this bug was first opened, the final fix was something that throws the baby out with the bathwater.</p>
<p>I don&#8217;t want the minimize animation, but I don&#8217;t want wireframe windows, either.  Why can I only opt out of them as a couple?</p>
<p>Havoc, you asked for rationale and not rant, and lloyd had provided it:</p>
<blockquote><p>the window minimization animation&#8217;s sole purpose is to indicate to an absolute GUI neophyte &#8220;where the window goes&#8221; when it&#8217;s minimized.  for a huge number of users &#8211; basically anyone who&#8217;s ever used a GUI with a taskbar before, which is in excess of 98% of current desktop computer users &#8211; they are never useful because they already know this.</p>
<p>for the remainder, window animations are useful exactly once in their lifetimes &#8211; the first time they minimize a window and wonder where their application window &#8220;went&#8221;.</p>
<p>thereafter, window animations are a distracting waste of time, and to me and many others, an annoyance.  it&#8217;s roughly equivalent to never being able to turn off Clippy.</p></blockquote>
<p>I wholeheartedly agree with this analysis.  Minimize animations are useful to newbies, not useful to anyone else.</p>
<p>The lack of an ability to disable this animation (<em>alone</em>, not in a catch-all flag that enables wireframe drawing, for crying out loud!) is completely absurd.  On my Core Duo 1.6 Ghz machine running an Nvidia graphics card, this animation still feels slow and clunky, and is completely superfluous.</p>
<p>In the future, maybe we&#8217;ll be able to use compiz and get nice fade in and fade out that works smoothly and nicely.  Even then, I&#8217;ll still want to be able to disable it, because <em>it serves no purpose for me, and isn&#8217;t central to metacity&#8217;s operation</em>.</p>
<p>In the GNOME community, we&#8217;ve heard mention of &#8220;Nat&#8217;s Pendulum&#8221;, referring to Nat Friedman&#8217;s insistence that the GNOME &#8220;usability pendulum&#8221; has swung too far in the other direction.  The 3.5 years spent blocking on the inclusion of this simple gconf flag, was, I think, a perfect illustration of what Nat meant.  The fact that the flag still isn&#8217;t there in the form suggested may mean that the damage may just be permanent in this community surrounding metacity development.</p>
<p>Why must gconf be &#8220;usable&#8221; too?  Don&#8217;t give me a <em>reduced_resources</em> catch-all flag, but give me separate flags to enable/disable certain animations/effects. Is this really such a usability disaster, or are you just being a Metacity Nazi:&#8221;no fine-grained configuration for you!&#8221;</p>
<p>As Jeff Waugh has mentioned, religious usability insistence like that expressed in this thread was enough to send many would-be GNOME users and contributors packing for projects like KDE, XFCE, or even to proprietary platforms like OS X.  The damage is deep and felt.  I lost a lot of faith in GNOME personally because of these issues, and am only slowly regaining it.</p>
<p>Has anyone already written a patch which removes the <em>reduced_resources</em> flag and adds this fine-grained control of the minimize and wireframe animations?  If not, I&#8217;ll write it and attach it to this issue.</p>
<p>I will <em>not</em> open a new bugzilla bug for this, because I think history is important so that we learn from our past mistakes.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2007/03/18/nats-pendulum/feed</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>HOWTO: Get microphone, headphone, automute and sound properly working on an HP DV2000 laptop in Linux</title>
		<link>http://www.pixelmonkey.org/2007/03/18/dv2000-alsa-patches</link>
		<comments>http://www.pixelmonkey.org/2007/03/18/dv2000-alsa-patches#comments</comments>
		<pubDate>Sun, 18 Mar 2007 16:51:20 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[Open Source]]></category>
		<category><![CDATA[Technology]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/2007/03/18/howto-get-microphone-headphone-automute-and-sound-properly-working-on-an-hp-dv2000-laptop-in-linux/</guid>
		<description><![CDATA[Note: This entry is now wildly out of date.  Try these instructions at your own risk.  If I get a few moments, I will revise these instructions in the future. 
I&#8217;ve been in contact with an ALSA hacker, Tobin Davis, over a series of patches that provide support for the sound chipset (intel-hda) that is part [...]]]></description>
			<content:encoded><![CDATA[<p><strong>Note: This entry is now wildly out of date.  Try these instructions at your own risk.  If I get a few moments, I will revise these instructions in the future. </strong></p>
<p>I&#8217;ve been in contact with an ALSA hacker, Tobin Davis, over a series of patches that provide support for the sound chipset (intel-hda) that is part of the HP DV2000 laptop.</p>
<p>His patches over ALSA 1.0.14rc3 enable the following new features:</p>
<ul>
<li>The headphone port now works, and the speakers automute when the headphones are plugged in.</li>
<li>The microphone port now works, with great sound quality.</li>
<li>The built-in mic on the monitor now works, though obviously with worse sound quality due to ambient noise.</li>
</ul>
<p>The new patches aren&#8217;t perfect.  I&#8217;m noticing some sound quality issues at high volumes, and in order to get it to work Tobin had to essentially enable two PCM channels (PCM and PCM-2), which have a very strange behavior.  The first one controls the volume directly from the sound system.  The second one controls the volume only between the sound system and the speakers (and thus, will have no effect on the sound when the headphones are plugged in).  The master volume control effectively modulates both of these.  Tobin has told me that the chipset produced by Conexant is particularly weird, which is why he had to this.  I find that it&#8217;s not so bad, as long as I keep a launcher to gnome-volume-control set up so that I can control it, knowing these rules.</p>
<p>That said, it&#8217;s a huge improvement over out of the box sound support for Ubuntu (which is ALSA 1.0.11).  Inside this post you&#8217;ll find further instructions, which are adapted from a text document Tobin sent his tester group via e-mail.  These are step by step instructions to set up 1.0.14rc3 ALSA drivers plus Tobin&#8217;s latest patch.</p>
<p><span id="more-348"></span></p>
<p><strong>1. Backup your current drivers</strong></p>
<blockquote>
<pre>tar -zcvf original-drivers.tgz /lib/modules/`uname -r`/kernel/sound</pre>
</blockquote>
<p><strong>2. Next, get the latest release and bring it current.</strong></p>
<blockquote>
<pre>wget ftp://ftp.alsa-project.org/pub/driver/alsa-driver-1.0.14rc3.tar.bz2</pre>
<pre>wget http://members.dsl-only.net/~tdavis/alsa-patches/conexant-latest-rc3.patch</pre>
<pre>tar -jxf alsa-driver-1.0.14rc3.tar.bz2</pre>
<pre>cd alsa-driver-1.0.14rc3/alsa-kernel</pre>
<pre>patch -p1 < ../../conexant-latest-rc3.patch</pre>
</pre>
<pre>cd ../../</pre>
</blockquote>
<p><strong>3. Build the code.</strong></p>
<blockquote>
<pre>cd alsa-driver-1.0.14rc3</pre>
<pre>./configure --with-debug=detect --with-cards=hda-intel</pre>
<pre>make</pre>
<pre>sudo make install</pre>
<pre>sudo depmod -a</pre>
<pre>sudo dmesg -c >/dev/null</pre>
</blockquote>
<p><strong>4. Stop all audio applications and remove all audio drivers</strong></p>
<p>On my system, the following works:</p>
<blockquote>
<pre>modprobe -r snd-usb-audio</pre>
<pre>modprobe -r snd-hda-intel snd-hda-codec snd-pcm-oss snd-mixer-oss snd-pcm snd-timer snd snd-page-alloc</pre>
</blockquote>
<p><strong>5. Reload the new driver</strong></p>
<p>Simply run modprobe snd-hda-intel, look at the dmesg output and test it out.</p>
<p>Using alsamixer will show you all available channels.  In gnome-volume-control, you can also enable additional channels with Edit->Preferences.  You&#8217;ll need at least Master, PCM, and PCM-2 enabled to get proper volume working on the headphones and speakers.  You&#8217;ll need Capture enabled in the Capture tab to get mic input working.</p>
<p>If nothing works, or one function doesn&#8217;t work, try reloading the driver with &#8220;model=test&#8221; as a parameter.  On Ubuntu, this can be done by doing sudo vim /etc/modprobe.d/alsa-base and adding a line to the end that says This should enable everything.</p>
<p>If you have issues, you can try to contact Tobin Davis or other hackers at the ALSA team.  Or you could even post a comment here and I&#8217;ll pass it along.  Please include the system make/model, the subsystem line from &#8220;lspci -s 0:1b -vn&#8221; (Ex: Subsystem: 103c:30b2), the dmesg output from above, and the output from &#8220;cat /proc/asound/card0/codec#0&#8243;.</p>
<p><strong><em>Update</em></strong>: Modified instructions based on Henrique&#8217;s input below.  (Patchlevel argument for patch command was incorrect.)</p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2007/03/18/dv2000-alsa-patches/feed</wfw:commentRss>
		<slash:comments>29</slash:comments>
		</item>
		<item>
		<title>&#8220;This isn&#8217;t elitist, this is egalitarian.&#8221;</title>
		<link>http://www.pixelmonkey.org/2007/03/18/this-isnt-elitist-this-is-egalitarian</link>
		<comments>http://www.pixelmonkey.org/2007/03/18/this-isnt-elitist-this-is-egalitarian#comments</comments>
		<pubDate>Sun, 18 Mar 2007 15:43:00 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[GNOME]]></category>
		<category><![CDATA[Open Source]]></category>
		<category><![CDATA[Programming]]></category>
		<category><![CDATA[Technology]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/2007/03/18/this-isnt-elitist-this-is-egalitarian/</guid>
		<description><![CDATA[A surprisingly articulate post on OSNews about Free Software:
Asking me to get off my a$$ and code drivers for this baby is what I consider elitist and a very unreasonable demand on the end user. It&#8217;s one thing that gives GNU/Linux zealots a very bad name in the real world.
I have sneaking suspicion that you [...]]]></description>
			<content:encoded><![CDATA[<p>A <a href="http://osnews.com/read_thread.php?news_id=17505&#038;comment_id=222131">surprisingly articulate post</a> on OSNews about Free Software:</p>
<blockquote><p><em>Asking me to get off my a$$ and code drivers for this baby is what I consider elitist and a very unreasonable demand on the end user. It&#8217;s one thing that gives GNU/Linux zealots a very bad name in the real world.</em></p>
<p>I have sneaking suspicion that you get this response from the Linux community because we feel you&#8217;re placing unreasonable demands on us. Your points are valid, but your energy is misdirected. Unfortunately for those who don&#8217;t like to code, that&#8217;s how software is created and improved. We invite you to participate in our projects in a variety of capacities including but not limited to programming, but of course participation is not required.</p>
<p>I think that Linux &#8220;zealots&#8221; get a bad name because much of the &#8220;real world&#8221; believes in a culture of entitlement. Look at everybody living life with a chip on their shoulder, blaming everyone else for their problems and scoffing at the notion that they take responsibility for their own situation. Somewhere along the line we stopped believing in opportunity as a means of realizing our dreams and began to foster the idea that we&#8217;re entitled to our expectations. In &#8220;Linux land,&#8221; we believe that the opportunity to participate in our information society is fundamental to our inherent desire as human beings to better our situation and control our own destiny.</p>
<p>Of course, money can make just about any dream come true. Mark Shuttleworth, for [example], invested $10 million to help make the Ubuntu project a reality. But years ago my great-grandmother told me the story of how my family came to America with nothing but the promise that here they would find a land of opportunity. This is the same promise we make with free software. This isn&#8217;t elitist, this is egalitarian.</p></blockquote>
<p>I have to say, this is part of what makes me love Free Software.  It&#8217;s this idea of widespread opportunity.  Sure, F/OSS has power structures and means of coercion/control built into certain parts of it, but for the most part, it&#8217;s based upon a very simple, powerful, and egalitarian idea.  &#8220;Anyone can improve this, anyone can make it better.&#8221;  It&#8217;s that kernel of an idea that makes any process &#8212; whether software production, <a href="http://www.socialtext.net/codev2/index.cgi">book editing</a>, <a href="http://www.socialtext.net/codev2/index.cgi">encyclopedia editing</a>, or even <a href="http://www.wired.com/news/business/0,1367,68144,00.html">beer brewing</a>, more enjoyable to those involved, and, as a side effect, better for the general public.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2007/03/18/this-isnt-elitist-this-is-egalitarian/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Hilarious posts on Linux vs. Windows: satire or real thing?</title>
		<link>http://www.pixelmonkey.org/2007/03/16/hilarious-posts-on-linux-vs-windows-satire-or-real-thing</link>
		<comments>http://www.pixelmonkey.org/2007/03/16/hilarious-posts-on-linux-vs-windows-satire-or-real-thing#comments</comments>
		<pubDate>Fri, 16 Mar 2007 16:09:57 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[Microsoft]]></category>
		<category><![CDATA[Open Source]]></category>
		<category><![CDATA[Technology]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/2007/03/16/hilarious-posts-on-linux-vs-windows-satire-or-real-thing/</guid>
		<description><![CDATA[Take a look at these two posts from a ZDNet debate:
A poster under the name &#8220;jerryleecooper&#8221; says,
Vista is far more powerful than windows XP, and runs twice as fast. It is also much harder to pirate, and this point more than anything else has the Linux crowd in a panic.
and, in a follow-up post,
Are you [...]]]></description>
			<content:encoded><![CDATA[<p>Take a look at these two posts from a ZDNet debate:</p>
<p>A poster under the name &#8220;jerryleecooper&#8221; <a href="http://talkback.zdnet.com/5208-12355-0.html?forumID=1&#038;threadID=31199&#038;messageID=579073&#038;start=44">says</a>,</p>
<blockquote><p>Vista is far more powerful than windows XP, and runs twice as fast. It is also much harder to pirate, and this point more than anything else has the Linux crowd in a panic.</p></blockquote>
<p>and, <a href="http://talkback.zdnet.com/5208-12355-0.html?forumID=1&#038;threadID=31199&#038;messageID=579806&#038;start=45">in a follow-up pos</a>t,</p>
<blockquote><p>Are you saying that this linux can run on a computer without windows underneath it, at all? As in, without a boot disk, without any drivers, and without any services?  That sounds preposterous to me.</p></blockquote>
<p>Is this serious, or satire?  If it&#8217;s serious, it&#8217;s absurd.  If it&#8217;s satire, it&#8217;s genius.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2007/03/16/hilarious-posts-on-linux-vs-windows-satire-or-real-thing/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>More on Internet Radio: NPR Takes Action</title>
		<link>http://www.pixelmonkey.org/2007/03/15/more-on-internet-radio-npr-takes-action</link>
		<comments>http://www.pixelmonkey.org/2007/03/15/more-on-internet-radio-npr-takes-action#comments</comments>
		<pubDate>Thu, 15 Mar 2007 16:34:38 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[Corporate Power]]></category>
		<category><![CDATA[Economics]]></category>
		<category><![CDATA[Politics]]></category>
		<category><![CDATA[Technology]]></category>
		<category><![CDATA[US Government]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/2007/03/15/more-on-internet-radio-npr-takes-action/</guid>
		<description><![CDATA[From TFA:
This is a stunning, damaging decision for public radio and its commitment to music discovery and education, which has been part of our tradition for more than half a century.  Public radio’s agreements on royalties with all such organizations, including the RIAA, have always taken into account our public service mission and non-profit [...]]]></description>
			<content:encoded><![CDATA[<p>From <a href="http://featuresblogs.chicagotribune.com/technology_internetcritic/2007/03/npr_may_lead_fi.html">TFA</a>:</p>
<blockquote><p>This is a stunning, damaging decision for public radio and its commitment to music discovery and education, which has been part of our tradition for more than half a century.  Public radio’s agreements on royalties with all such organizations, including the RIAA, have always taken into account our public service mission and non-profit status. These new rates, at least 20 times more than what stations have paid in the past, treat us as if we were commercial radio – although by its nature, public radio cannot increase revenue from more listeners or more content, the factors that set this new rate.  Also, we are being required to pay an internet royalty fee that is vastly more expensive than what we pay for over-the-air use of music, although for a fraction of the over-the-air audience.</p></blockquote>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2007/03/15/more-on-internet-radio-npr-takes-action/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Save Internet Radio</title>
		<link>http://www.pixelmonkey.org/2007/03/15/save-internet-radio</link>
		<comments>http://www.pixelmonkey.org/2007/03/15/save-internet-radio#comments</comments>
		<pubDate>Thu, 15 Mar 2007 13:54:55 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[Corporate Power]]></category>
		<category><![CDATA[Economics]]></category>
		<category><![CDATA[Politics]]></category>
		<category><![CDATA[Technology]]></category>
		<category><![CDATA[US Government]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/2007/03/15/save-internet-radio/</guid>
		<description><![CDATA[Internet Radio is in danger.  (Thanks for the heads up, Jeff Evans.)  This means sites like Pandora may have to be shut down.  Do something about it.  I wrote the following letter to my NY representatives:
The Copyright Royalty Fees for Internet Radio broadcasters (like the hugely innovative Pandora.com) have been increased to the point where [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://www.saveourinternetradio.com/2007/03/04/the-view-from-paradise/">Internet Radio is in danger.</a>  (Thanks for the heads up, Jeff Evans.)  This means sites like <a href="http://www.pandora.com">Pandora</a> may have to be shut down.  <a href="http://www.saveourinternetradio.com/2007/03/05/mad-as-hell-about-the-threat-to-internet-radio/">Do something about it</a>.  I wrote the following letter to my NY representatives:</p>
<blockquote><p>The Copyright Royalty Fees for Internet Radio broadcasters (like the hugely innovative Pandora.com) have been increased to the point where many of these stations will have to close down.</p>
<p>The music industry has certainly made a big fuss about threats coming from the Internet, but I don&#8217;t spend any of my nights crying for the music industry.  They make millions upon millions of dollars, and keep America locked in a relative monoculture where new and independent artists are left out of the musical discourse while mindless and mind-numbing music is played everyday on radio stations across the ClearChannel nation.</p>
<p>Yet, despite my relative dislike for this exploitive industry, I have to say that every technological innovation that we&#8217;ve seen &#8212; from LPs to tape cassettes to CDs, and now to MP3s &#8212; has seen an increasingly growing recording industry, usually due to, rather than in spite of, these technologies.</p>
<p>Interent Radio actually has more of a potential to benefit the music industry than any other one of these technologies.  If you don&#8217;t know, Pandora.com is an amazing site based upon &#8220;The Music Genome Project.&#8221;  The concept is simple: you enter a song or artist on the site, and it creates a playlist of songs that &#8220;sound like&#8221; that artist or song.  I can mix these intangibles (&#8221;The Doors&#8221; and &#8220;Michael Jackson&#8221; gives me classic rock tones with pop melodies) and discover new artists I had never even heard about, simply by exploring my &#8220;taste matrix.&#8221;  This amazing functionality comes in particular handy after I get my paycheck, since I go to Pandora.com, see which artists/songs I&#8217;ve listened to lately, and with a click I can purchase these songs from the music industry.</p>
<p>I hadn&#8217;t bought a CD in years, until discovering Pandora and, through it, independent music I liked.</p>
<p>Who, exactly, loses in this situation?  I discover songs I&#8217;ve never heard of, I buy CDs that probably don&#8217;t sell very well, I get to benefit from high-quality radio from work on my work PC, and Pandora makes a tiny slice of money on advertising.</p>
<p>I&#8217;m sure the music industry wishes they had thought of Pandora, so that the little money that it does make from advertising would be theirs.  But tough!  This is supposed to be a competitive economic system, and if you snooze, you lose.  (Given actions like these by government, I&#8217;m not sure that it is really a competitive economic system, unfortunately!)</p>
<p>This is only the beginning of the places these technologies can go.  Don&#8217;t allow their efforts to be quelled by big corporate interests!  Please strike down these ridiculous copyright fees!</p></blockquote>
<p>Think Corporate Power is showing any signs of weakness?  Nope.  The big wheels keep on turning&#8230;</p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2007/03/15/save-internet-radio/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Catching up on the reading list</title>
		<link>http://www.pixelmonkey.org/2007/03/09/catching-up-on-the-reading-list</link>
		<comments>http://www.pixelmonkey.org/2007/03/09/catching-up-on-the-reading-list#comments</comments>
		<pubDate>Fri, 09 Mar 2007 23:41:07 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[Books]]></category>
		<category><![CDATA[Corporate Power]]></category>
		<category><![CDATA[Economics]]></category>
		<category><![CDATA[Globalization]]></category>
		<category><![CDATA[Open Source]]></category>
		<category><![CDATA[Personal]]></category>
		<category><![CDATA[Politics]]></category>
		<category><![CDATA[Programming]]></category>
		<category><![CDATA[Technology]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/2007/03/09/catching-up-on-the-reading-list/</guid>
		<description><![CDATA[Lately, I&#8217;ve been very diligent about catching up on my reading.
I have been perpetually delaying a review of Capitalism 3.0 and Dreaming in Code, both of whom deserve it.  But I promise one soon.  I use Hofstadter&#8217;s Rule of Thumb lately for estimating time: however long you think it&#8217;s gonna take, double it [...]]]></description>
			<content:encoded><![CDATA[<p>Lately, I&#8217;ve been very diligent about catching up on my reading.</p>
<p>I have been perpetually delaying a review of <em>Capitalism 3.0</em> and <em>Dreaming in Code</em>, both of whom deserve it.  But I promise one soon.  I use Hofstadter&#8217;s Rule of Thumb lately for estimating time: however long you think it&#8217;s gonna take, double it and add a unit of time.  So if you think it&#8217;ll take two hours, it&#8217;ll really take four days.  If you think it&#8217;ll take five days, it&#8217;ll really take 10 weeks.  And so on.</p>
<p>In the meanwhile, I&#8217;ve been busy at work &#8212; actually working on some cool stuff from a technology standpoint, mainly in the realm of hacking with pieces of the <a href="http://www.eclipse.org/modeling/emf/?project=emf">Eclipse Modeling Framework</a>, and its related projects like GMF, RCP, Eclipse Core, etc.</p>
<p>On my commute, I&#8217;ve been enjoying reading <em>Making Globalization Work</em> by Stiglitz.  Although one of my friends mentioned to me that this book would be quite boring, and for the most part he was right.  Not the lofty stuff of Barnes in <em>Capitalism 3.0</em>; but perhaps Stiglitz&#8217;s recommendations are much more practical for ways to improve the current system.</p>
<p>The other book I started recently is a long, written interview with <a href="http://en.wikipedia.org/wiki/John_Kenneth_Galbraith">John Kenneth Galbraith</a> (much in the style of Socrates) which is entitled, <em>Almost Everyone&#8217;s Guide to Economics</em>.  What&#8217;s amazing is to see Galbraith, this towering (literally) Keynesian economic thinker, speaking in the 70s of the growth of corporate power, the undermining of labor, and the insidious nature of market fundamentalism.  And yet, here we are, 30 years later, heeding none of his warnings, and entering into the new &#8220;global age&#8221; of &#8220;The World is Flat&#8221;.</p>
<p>Oh yes indeed, I do need to write some reviews very soon.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2007/03/09/catching-up-on-the-reading-list/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Finished Dreaming in Code</title>
		<link>http://www.pixelmonkey.org/2007/02/23/finished-dreaming-in-code</link>
		<comments>http://www.pixelmonkey.org/2007/02/23/finished-dreaming-in-code#comments</comments>
		<pubDate>Fri, 23 Feb 2007 14:54:48 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[Books]]></category>
		<category><![CDATA[Corporate Power]]></category>
		<category><![CDATA[Globalization]]></category>
		<category><![CDATA[Open Source]]></category>
		<category><![CDATA[Personal]]></category>
		<category><![CDATA[Politics]]></category>
		<category><![CDATA[Programming]]></category>
		<category><![CDATA[Technology]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/2007/02/23/finished-dreaming-in-code/</guid>
		<description><![CDATA[Overall, Dreaming in Code was an interesting book.  For programmers who already are obsessed with the classics of software engineering (Mythical Man-Month and friends), you probably won&#8217;t learn much new stuff in this book.  However, the personal illustrations using OSAF did lead me to some self-evaluation of the work I do.  It [...]]]></description>
			<content:encoded><![CDATA[<p>Overall, <em>Dreaming in Code</em> was an interesting book.  For programmers who already are obsessed with the classics of software engineering (Mythical Man-Month and friends), you probably won&#8217;t learn much new stuff in this book.  However, the personal illustrations using OSAF did lead me to some self-evaluation of the work I do.  It was also interesting to see the internal workings of an organization which seems to be set up ideally for programmers &#8212; a good mission, an open source project, no real deadlines or users in the beginning, design-focused, etc. &#8212; and still see it run into the same issues traditional software shops run into.</p>
<p>I&#8217;d post a longer review, but I&#8217;m headed down to New Orleans today.  Will post a longer review when I get back, hopefully also of <em>Capitalism 3.0</em>, whose ideas have been swimming in my head the last few days of commute.  I think they really deserve to be summarized and presented here.</p>
<p>In the meanwhile, I&#8217;ve started reading <em>Making Globalization Work</em> by Joseph Stiglitz. This book, in particular, has been a kind of catharsis for most of my armchair ideas in economics, at least so far.  It&#8217;s a very strange feeling to read the ex-Chief Economist of the World Bank explaining his own ideas about overcoming the zealousness of &#8220;market fundamentalism&#8221; prevalent in economic circles, while I, who never studied economics formally, think, &#8220;Why would anyone trained in this discipline <em>actually believe</em> that markets are a magic force that work on their own?&#8221;  But I guess ideology always trumps rationality.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2007/02/23/finished-dreaming-in-code/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Dell IdeaStorm</title>
		<link>http://www.pixelmonkey.org/2007/02/23/dell-ideastorm</link>
		<comments>http://www.pixelmonkey.org/2007/02/23/dell-ideastorm#comments</comments>
		<pubDate>Fri, 23 Feb 2007 14:50:07 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[Open Source]]></category>
		<category><![CDATA[Technology]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/2007/02/23/dell-ideastorm/</guid>
		<description><![CDATA[A friend from NYU, Luke Geldermans, pointed me to this website the other day.  It&#8217;s really an amazing example of how much real demand there is for Linux on the desktop.
The website provides a way for Dell customers to vote on the issues which are most important to them.  The number 1 issue [...]]]></description>
			<content:encoded><![CDATA[<p>A friend from NYU, Luke Geldermans, pointed me to this website the other day.  It&#8217;s really an amazing example of how much <em>real</em> demand there is for Linux on the desktop.</p>
<p>The website provides a way for Dell customers to vote on the issues which are most important to them.  The number 1 issue right now is making Linux available as an install option on their Dell PCs.  There are a slew of issues below that related to gaining driver support for Linux, and offering Windows with OOo and Firefox, and even offering OS-less computers to avoid the Microsoft tax.</p>
<p>It&#8217;d be interesting to see how this pans out, but in the meanwhile, go ahead and <a href="http://www.dellideastorm.com">contribute a vote</a>!</p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2007/02/23/dell-ideastorm/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Dreaming in Code</title>
		<link>http://www.pixelmonkey.org/2007/02/11/dreaming-in-code</link>
		<comments>http://www.pixelmonkey.org/2007/02/11/dreaming-in-code#comments</comments>
		<pubDate>Sun, 11 Feb 2007 18:00:26 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[Books]]></category>
		<category><![CDATA[Open Source]]></category>
		<category><![CDATA[Programming]]></category>
		<category><![CDATA[Technology]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/2007/02/11/dreaming-in-code/</guid>
		<description><![CDATA[I just picked up a copy of Dreaming in Code from Barnes &#038; Noble.  Will probably devour it in the next couple of days.
]]></description>
			<content:encoded><![CDATA[<p>I just picked up a copy of <a href="http://www.dreamingincode.com/">Dreaming in Code</a> from Barnes &#038; Noble.  Will probably devour it in the next couple of days.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2007/02/11/dreaming-in-code/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Open Source Talks at Google, and VIM creator</title>
		<link>http://www.pixelmonkey.org/2007/02/07/open-source-talks-at-google-and-vim-creator</link>
		<comments>http://www.pixelmonkey.org/2007/02/07/open-source-talks-at-google-and-vim-creator#comments</comments>
		<pubDate>Wed, 07 Feb 2007 18:03:37 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[Open Source]]></category>
		<category><![CDATA[Programming]]></category>
		<category><![CDATA[Technology]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/2007/02/07/open-source-talks-at-google-and-vim-creator/</guid>
		<description><![CDATA[Google has an interesting talk about &#8220;How Open Source Projects Survive Poisonous People&#8221; at Google Video.
On February 13, they&#8217;re going to have the creator of VIM, Bram Moolenaar, giving a talk on VIM7.  What&#8217;s funny is that Bram, who has been working full-time on VIM for the past few years (living entirely on donations and [...]]]></description>
			<content:encoded><![CDATA[<p>Google has an interesting talk about <a href="http://video.google.com/videoplay?docid=-4216011961522818645">&#8220;How Open Source Projects Survive Poisonous People&#8221;</a> at Google Video.</p>
<p>On February 13, they&#8217;re going to have the creator of <a href="http://www.vim.org">VIM</a>, Bram Moolenaar, giving a talk on VIM7.  What&#8217;s funny is that Bram, who has been working full-time on VIM for the past few years (living entirely on donations and money votes for VIM features) has now been hired by Google.  Smart move.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2007/02/07/open-source-talks-at-google-and-vim-creator/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Way more interesting than YouTube</title>
		<link>http://www.pixelmonkey.org/2007/02/06/way-more-interesting-than-youtube</link>
		<comments>http://www.pixelmonkey.org/2007/02/06/way-more-interesting-than-youtube#comments</comments>
		<pubDate>Tue, 06 Feb 2007 19:41:07 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[Corporate Power]]></category>
		<category><![CDATA[Politics]]></category>
		<category><![CDATA[Technology]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/2007/02/06/way-more-interesting-than-youtube/</guid>
		<description><![CDATA[I found a site today called &#8220;Fora.tv&#8221;.  It&#8217;s way more interesting than YouTube: it&#8217;s a free video site that features intellectuals and figures in public discourse.
Perfect for my commute.  Up till now, I&#8217;ve been depending on PBS, which has good content, but doesn&#8217;t give it all away for free.
Check it out: Fora.tv.
In particular, [...]]]></description>
			<content:encoded><![CDATA[<p>I found a site today called &#8220;Fora.tv&#8221;.  It&#8217;s way more interesting than YouTube: it&#8217;s a free video site that features intellectuals and figures in public discourse.</p>
<p>Perfect for my commute.  Up till now, I&#8217;ve been depending on PBS, which has good content, but doesn&#8217;t give it all away for free.</p>
<p>Check it out: <a href="http://fora.tv/">Fora.tv</a>.</p>
<p>In particular, there&#8217;s a talk by Peter Barnes (author of Capitalism 3.0) in there.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2007/02/06/way-more-interesting-than-youtube/feed</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>Spirited Discussion with Miguel de Icaza on Mono and Microsoft</title>
		<link>http://www.pixelmonkey.org/2007/02/04/spirited-discussion-with-miguel-de-icaza-on-mono-and-microsoft</link>
		<comments>http://www.pixelmonkey.org/2007/02/04/spirited-discussion-with-miguel-de-icaza-on-mono-and-microsoft#comments</comments>
		<pubDate>Sun, 04 Feb 2007 17:33:58 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[GNOME]]></category>
		<category><![CDATA[Microsoft]]></category>
		<category><![CDATA[Open Source]]></category>
		<category><![CDATA[Programming]]></category>
		<category><![CDATA[Technology]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/2007/02/04/spirited-discussion-with-miguel-de-icaza-on-mono-and-microsoft/</guid>
		<description><![CDATA[I got fired up by the evidence coming out of Microsoft from yesterday, and decided to write a post to Miguel de Icaza&#8217;s blog.
Here&#8217;s what I wrote:
Hi Miguel,
It looks like a new set of &#8220;Halloween Documents&#8221; have come out, thanks to a case in Iowa, Comes et. al. v. Microsoft (http://iowaconsumercase.org/index.html). I&#8217;m wondering if you [...]]]></description>
			<content:encoded><![CDATA[<p>I got fired up by the evidence coming out of Microsoft from yesterday, and decided to write a post to <a href="http://tirania.org/blog/">Miguel de Icaza&#8217;s</a> blog.</p>
<p>Here&#8217;s what I wrote:</p>
<blockquote><p>Hi Miguel,</p>
<p>It looks like a new set of &#8220;Halloween Documents&#8221; have come out, thanks to a case in Iowa, Comes et. al. v. Microsoft (http://iowaconsumercase.org/index.html). I&#8217;m wondering if you have any comments on this document in particular, which suggests that Microsoft management knew full well they were &#8220;stealing Java&#8221; to intentionally marginalize the cross-platform language issue.</p>
<p>A select quote from the document, &#8220;Screw Sun, cross-platform will never work. Let&#8217;s move on and steal the Java language.&#8221;<br />
Here&#8217;s the e-mail archives, which was submitted into evidence:</p>
<p>http://www.iowaconsumercase.org/011107/PX_2768.pdf</p>
<p>I&#8217;m wondering, given these thoughts from within Microsoft management, and given the recent news of Sun open sourcing the Java language under GPL terms, how is it that you can still push for the Mono project on Linux? Aren&#8217;t we always going to be fighting an uphill battle against a monopoly company protecting its biggest cash cow: the Windows platform?</p></blockquote>
<p>Although my question was more &#8220;devil&#8217;s advocate&#8221; and meant to rile him up, Miguel provided some of the <a href="http://groups.google.com/group/tiraniaorg-blog-comments/browse_thread/thread/e0797330090eb791">strongest and most cogent arguments</a> for Mono that I&#8217;ve seen on record.</p>
<p>I just want to say great work to Miguel and the Mono team, and that if you ever doubted your <em>raison d&#8217;etre</em>, all it would take is reading this thread to be convinced!  You&#8217;ve certainly convinced me!</p>
<p><strong>Update:</strong> it&#8217;s really <a href="http://blogs.sun.com/jeffdillon/entry/net_and_mono_the_libraries">this kind of dependency</a> on Windows I&#8217;m worried about in .NET.  I think it&#8217;s just that the culture of the Java runtime is one of platform independence, whereas .NET from Microsoft is one of &#8220;platform dominance,&#8221; and Mono is some sort of stepping stone between Microsoft&#8217;s single-platform vision and those of us who want to write cross-platform apps using .NET.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2007/02/04/spirited-discussion-with-miguel-de-icaza-on-mono-and-microsoft/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>It&#8217;s Official Now: Microsoft Stole Java to Minimize Cross-Platform Languages</title>
		<link>http://www.pixelmonkey.org/2007/02/03/its-official-now-microsoft-stole-java-in-c-to-minimize-cross-platform-languages</link>
		<comments>http://www.pixelmonkey.org/2007/02/03/its-official-now-microsoft-stole-java-in-c-to-minimize-cross-platform-languages#comments</comments>
		<pubDate>Sat, 03 Feb 2007 18:15:35 +0000</pubDate>
		<dc:creator>pixelmonkey</dc:creator>
				<category><![CDATA[Microsoft]]></category>
		<category><![CDATA[Technology]]></category>

		<guid isPermaLink="false">http://www.pixelmonkey.org/2007/02/03/its-official-now-microsoft-stole-java-in-c-to-minimize-cross-platform-languages/</guid>
		<description><![CDATA[Well, I&#8217;ve always suspected that C# was nothing but a Java rip without cross-platform support, meant to marginalize Java so that cross-platform languages don&#8217;t become as pervasive as Microsoft&#8217;s single-platform, Windows-only languages.  Now, evidence has come out of Microsoft e-mail archives that proves not only that they just &#8220;stole Java&#8221; in those pivotal years, [...]]]></description>
			<content:encoded><![CDATA[<p>Well, I&#8217;ve always suspected that C# was nothing but a Java rip <em>without</em> cross-platform support, meant to marginalize Java so that cross-platform languages don&#8217;t become as pervasive as Microsoft&#8217;s single-platform, Windows-only languages.  Now, evidence has come out of Microsoft e-mail archives that proves not only that they just &#8220;stole Java&#8221; in those pivotal years, but that managers knew full well they would never make an effort to keep the language cross-platform.  A classic &#8220;embrace and extend&#8221; situation.<br />
A select quote from the document, &#8220;Screw Sun, cross-platform will never work.  Let&#8217;s move on and steal the Java language.&#8221;</p>
<p>You can read the entire thing in a <a href="http://www.iowaconsumercase.org/011107/PX_2768.pdf">scanned copy from the Iowa case Comes et. al. v. Microsoft Corp</a>.</p>
<p><strong><em>Update:</em></strong> my discussion with Miguel de Icaza makes this seem &#8220;less official,&#8221; but I still think the mentality from this document also pervaded the mentality of .NET development, specifically that cross-platform would never be a goal of Microsoft .NET.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.pixelmonkey.org/2007/02/03/its-official-now-microsoft-stole-java-in-c-to-minimize-cross-platform-languages/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>
