<?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>jaredrobinson.com</title>
	<atom:link href="http://jaredrobinson.com/blog/feed/" rel="self" type="application/rss+xml" />
	<link>http://jaredrobinson.com/blog</link>
	<description></description>
	<lastBuildDate>Tue, 07 Feb 2012 04:11:24 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.3.1</generator>
		<item>
		<title>Treating work like a race</title>
		<link>http://jaredrobinson.com/blog/treating-work-like-a-race/</link>
		<comments>http://jaredrobinson.com/blog/treating-work-like-a-race/#comments</comments>
		<pubDate>Tue, 07 Feb 2012 04:11:24 +0000</pubDate>
		<dc:creator>Jared</dc:creator>
				<category><![CDATA[Quotes]]></category>
		<category><![CDATA[Work]]></category>

		<guid isPermaLink="false">http://jaredrobinson.com/blog/?p=742</guid>
		<description><![CDATA[Chad Fowler, in his book, My Job Went to India, made the following remarks about working effectively: If you treat your projects like a race, you&#8217;ll get to the end a lot faster than if you treat them like a &#8230; <a href="http://jaredrobinson.com/blog/treating-work-like-a-race/">Continue reading <span class="meta-nav">&#8594;</span></a>]]></description>
			<content:encoded><![CDATA[<p>Chad Fowler, in his book, <em>My Job Went to India</em>, made the following remarks about working effectively:
<p style="padding-left: 30px;">If you treat your projects like a race, you&#8217;ll get to the end a lot faster than if you treat them like a prison cell.</p>
<p style="padding-left: 30px;">A sense of urgency, even if manufactured, is enough to easily double or triple your productivity.</p>
I&#8217;d add that it needs to be an enjoyable race, and that urgency, sustained for too long, can wear a person out. Races are more enjoyable when run with a group of friends.</p>

<p>&nbsp;</p>
]]></content:encoded>
			<wfw:commentRss>http://jaredrobinson.com/blog/treating-work-like-a-race/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Autojump: Faster than &#8216;cd&#8217;</title>
		<link>http://jaredrobinson.com/blog/autojump-faster-than-cd/</link>
		<comments>http://jaredrobinson.com/blog/autojump-faster-than-cd/#comments</comments>
		<pubDate>Sun, 05 Feb 2012 04:32:50 +0000</pubDate>
		<dc:creator>Jared</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[Programming]]></category>
		<category><![CDATA[Tech]]></category>

		<guid isPermaLink="false">http://jaredrobinson.com/blog/?p=734</guid>
		<description><![CDATA[Here&#8217;s a cool tool: autojump, written by Joel Schaerer (thanks, Joel). I spend much of my day as a programmer navigating around in the linux filesystem. Built-in tools like &#8216;pushd&#8217; and &#8216;popd&#8217; are nice, as are subprocesses &#8212; e.g. (cd &#8230; <a href="http://jaredrobinson.com/blog/autojump-faster-than-cd/">Continue reading <span class="meta-nav">&#8594;</span></a>]]></description>
			<content:encoded><![CDATA[<p>Here&#8217;s a cool tool: <a title="Autojump as detailed on lifehacker.com" href="http://lifehacker.com/5583546/autojump-is-a-faster-way-to-browse-your-filesystem">autojump</a>, written by Joel Schaerer (thanks, Joel). I spend much of my day as a programmer navigating around in the linux filesystem. Built-in tools like &#8216;pushd&#8217; and &#8216;popd&#8217; are nice, as are subprocesses &#8212; e.g.
<pre> (cd ~/Download &amp;&amp; wget http://somewhere.com/path/to/file)</pre>
&#8230; and when it finishes downloading, I&#8217;m still in the directory I was in before the download was started.</p>

<p>Now there&#8217;s autojump to add in to the mix. After I &#8216;cd&#8217; to various directories, later, I can type &#8216;j Down&#8217; to cd to my Downloads directory. Very convenient. I just wish it were built into every distribution of linux.</p>
]]></content:encoded>
			<wfw:commentRss>http://jaredrobinson.com/blog/autojump-faster-than-cd/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Linux tty auditing</title>
		<link>http://jaredrobinson.com/blog/linux-tty-auditing/</link>
		<comments>http://jaredrobinson.com/blog/linux-tty-auditing/#comments</comments>
		<pubDate>Fri, 20 Jan 2012 05:47:28 +0000</pubDate>
		<dc:creator>Jared</dc:creator>
				<category><![CDATA[Fedora]]></category>
		<category><![CDATA[Linux]]></category>
		<category><![CDATA[Security]]></category>
		<category><![CDATA[Tech]]></category>

		<guid isPermaLink="false">http://jaredrobinson.com/blog/?p=721</guid>
		<description><![CDATA[Since RHEL 5.4, and in recent Fedora releases, it&#8217;s possible to audit what users type at their tty (command prompt), thanks to the work of Steve Grubb, a RedHat employee. Edit /etc/pam.d/system-auth and append the following, but not both: session &#8230; <a href="http://jaredrobinson.com/blog/linux-tty-auditing/">Continue reading <span class="meta-nav">&#8594;</span></a>]]></description>
			<content:encoded><![CDATA[<p>Since RHEL 5.4, and in recent Fedora releases, it&#8217;s possible to audit what users type at their tty (command prompt), thanks to the work of Steve Grubb, a RedHat employee.</p>

<p>Edit /etc/pam.d/system-auth and append the following, <strong>but not both</strong>:
<pre>session required pam&#95;tty&#95;audit.so disable=&#42; enable=root
session required pam&#95;tty&#95;audit.so enable=&#42;</pre>
Wait for users to log in and type into a terminal. Later, to see audited tty input, run:
<pre>aureport --tty</pre>
When a user logs in, the pam module tells the kernel to enable tty auditing for a process and its children. All tty input is logged, but it may not be incredibly easy to read (it includes backspaces, control characters, etc.). I&#8217;m unclear as to when and how often the kernel flushes out accumulated tty input to the audit log. The records are identified with a type of TTY in /var/log/audit/audit.log.</p>

<p>In addition to tty auditing, RedHat patched their bash shell so that it neatly audits each and every command line it executes, with a record type of USER&#95;TTY. It&#8217;s prettier to read than raw tty auditing &#8212; and it&#8217;s easy for a user to bypass by using a shell that doesn&#8217;t send its commands to the Linux audit system, like zsh, or a custom-built unpatched bash. Maybe that&#8217;s why &#8220;aureport &#8211;tty&#8221; doesn&#8217;t show USER&#95;TTY records.</p>

<hr />

<p>The Linux auditing system is powerful. It&#8217;s possible to write rules that watch for modification to certain files, or that log the use of certain system calls. See the &#8220;audit.rules&#8221; manpage for more information.</p>
]]></content:encoded>
			<wfw:commentRss>http://jaredrobinson.com/blog/linux-tty-auditing/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Pitfalls of verifying signed jar files</title>
		<link>http://jaredrobinson.com/blog/pitfalls-of-verifying-signed-jar-files/</link>
		<comments>http://jaredrobinson.com/blog/pitfalls-of-verifying-signed-jar-files/#comments</comments>
		<pubDate>Mon, 12 Dec 2011 17:10:31 +0000</pubDate>
		<dc:creator>Jared</dc:creator>
				<category><![CDATA[java]]></category>
		<category><![CDATA[Programming]]></category>
		<category><![CDATA[Tech]]></category>

		<guid isPermaLink="false">http://jaredrobinson.com/blog/?p=715</guid>
		<description><![CDATA[In the Java world, it&#8217;s possible to digitally sign a jar file using &#8216;keytool&#8217; to generate or import a digital signature, and &#8216;jarsigner&#8217; to do the signing. What isn&#8217;t so obvious is that when we use &#8216;jarsigner&#8217; to verify a &#8230; <a href="http://jaredrobinson.com/blog/pitfalls-of-verifying-signed-jar-files/">Continue reading <span class="meta-nav">&#8594;</span></a>]]></description>
			<content:encoded><![CDATA[<p>In the Java world, it&#8217;s possible to digitally sign a jar file using &#8216;keytool&#8217; to generate or import a digital signature, and &#8216;jarsigner&#8217; to do the signing. What isn&#8217;t so obvious is that when we use &#8216;jarsigner&#8217; to verify a signed jar, it doesn&#8217;t verify that we <em>trust</em> the signature that signed the file. It simply tells us whether the contents were signed by a public key that was <em>included with the jar file</em>.</p>

<p>Surprisingly, there&#8217;s no option to tell jarsigner to check for trusted signatures.</p>

<p>In code, we can use java.util.jar.JarFile to check the validity of a jar file. By default, the constructor to JarFile says we want to check the validity. Code must then iterate through each entry in the JarFile and seek to the end of each input stream, otherwise, the integrity isn&#8217;t checked. In other words, the java.util.jar.JarFile doesn&#8217;t give us the integrity checking with a simple method call such as isValid(), and it doesn&#8217;t give us an easy way to check that we <em>trust</em> the signature that the entries were signed with.</p>

<p>Anyone, anywhere, can create their own certificate, and sign a jar file &#8212; so if we want to establish trust for a signed jar, we get to do extra work. On <a href="http://stackoverflow.com/questions/1374170/how-to-verify-a-jar-signed-with-jarsigner-programmatically">stackoverflow.com</a>, Jarek Przygódzki linked to <a href="https://svn.cs.cf.ac.uk/projects/whip/trunk/whip-core/src/main/java/org/whipplugin/data/bundle/JarVerifier.java">code that shows how</a> to check for trusted signatures.</p>

<p>I wonder why establishing trust for a signed jar isn&#8217;t easier. Could it be that signed jar files originated in the bygone era when we ran Java applets in our web browsers? Did web browsers use their certificate authority database to verify some level of trust for the signature contained in a jar file?</p>

<p>Verifying trust is a delicate issue, as demonstrated by the <a href="https://www.google.com/search?q=hacked+certificate+authorities">recently hacked certificate authorities</a> including Diginotar and Comodo. Perhaps it&#8217;s a good thing that Java&#8217;s libraries and command line tools don&#8217;t make it deceptively simple to check jar files based on certificates trusted by Certificate Authorities.</p>

<p>Still, I wish the documentation for jarsigner and JarFile would shed more light on the limits of their default verification. I&#8217;d call it &#8220;hash checking&#8221; or &#8220;integrity checking based on hashing&#8221;.</p>

<p>&nbsp;</p>
]]></content:encoded>
			<wfw:commentRss>http://jaredrobinson.com/blog/pitfalls-of-verifying-signed-jar-files/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Easy updates with iOS and Linux vs bomardment from Windows</title>
		<link>http://jaredrobinson.com/blog/why-i-love-my-ipod-touch-linux/</link>
		<comments>http://jaredrobinson.com/blog/why-i-love-my-ipod-touch-linux/#comments</comments>
		<pubDate>Mon, 12 Dec 2011 16:33:13 +0000</pubDate>
		<dc:creator>Jared</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[Tech]]></category>
		<category><![CDATA[Windows]]></category>

		<guid isPermaLink="false">http://jaredrobinson.com/blog/?p=692</guid>
		<description><![CDATA[When I want to check email on my iPod Touch, I simply unlock it, load the email application, and read messages. What a joy. The tool works and works for me. It is my servant, instead of me being its &#8230; <a href="http://jaredrobinson.com/blog/why-i-love-my-ipod-touch-linux/">Continue reading <span class="meta-nav">&#8594;</span></a>]]></description>
			<content:encoded><![CDATA[<p>When I want to check email on my iPod Touch, I simply unlock it, load the email application, and read messages. What a joy. The tool works and works for me. It is my servant, instead of me being its servant.</p>

<p>Compare that to my corporate Windows Laptop. I open the lid and unlock it, wait for corporate anti-virus (I think) to chew through the I/O on my machine for several minutes. Then I can read my email using the unimpressive and slow Lotus Notes<em> (</em>I&#8217;d rather be using Thunderbird, Outlook, or speedy <em><a href="http://en.wikipedia.org/wiki/Mutt_(e-mail_client)">mutt</a></em>).</p>

<p>Or compare to my home Windows Laptop. I open the lid, log in, and am bombarded with requests from several programs to install updates. I just want to check my email, not be attacked with annoying &#8220;update me!&#8221; windows. I see one from Thunderbird, another from Adobe Flash, another from Mozy and another from Firefox. By the time I&#8217;ve upgraded, sometimes I&#8217;ve forgotten what I wanted to accomplish in the first place.</p>

<p>Apple has it right with updates for the iPod Touch: They stay out of my way until I want to bother with them, and then they&#8217;re all manged together.</p>

<p>Linux has it right: A single package manager updates everything, in one shot, including from third parties.</p>

<p>I&#8217;ll continue to use Windows. There are other benefits, even though third-party updates are annoying.</p>
]]></content:encoded>
			<wfw:commentRss>http://jaredrobinson.com/blog/why-i-love-my-ipod-touch-linux/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>The dog ate my grub.conf; unwanted LVM indirection</title>
		<link>http://jaredrobinson.com/blog/the-dog-ate-my-grub-conf-unwanted-lvm-indirection/</link>
		<comments>http://jaredrobinson.com/blog/the-dog-ate-my-grub-conf-unwanted-lvm-indirection/#comments</comments>
		<pubDate>Sat, 12 Nov 2011 04:38:31 +0000</pubDate>
		<dc:creator>Jared</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[Tech]]></category>

		<guid isPermaLink="false">http://jaredrobinson.com/blog/?p=706</guid>
		<description><![CDATA[In September, I updated packages on my Fedora 14 machine using &#8216;yum&#8217; (Yellowdog Updater Modified), and rebooted. I was greeted with an unfriendly grub prompt. Boot was broken, and I didn&#8217;t know why. Normally when I want to rescue a &#8230; <a href="http://jaredrobinson.com/blog/the-dog-ate-my-grub-conf-unwanted-lvm-indirection/">Continue reading <span class="meta-nav">&#8594;</span></a>]]></description>
			<content:encoded><![CDATA[<p>In September, I updated packages on my Fedora 14 machine using &#8216;yum&#8217; (Yellowdog Updater Modified), and rebooted. I was greeted with an unfriendly grub prompt. Boot was broken, and I didn&#8217;t know why.</p>

<p>Normally when I want to rescue a Linux system, I use the Fedora install DVD&#8217;s rescue mode. Unfortunately, my DVD drive stopped working just after the warranty expired. So I booted using a Linux-on-a-USB image that I carry around with me.</p>

<p>I planned on replicating the rescue mode experience by manually mounting the partitions in /mnt/sysimage, then chroot, and then run &#8216;grub-install&#8217; to fix things. And that&#8217;s what I did, except for a few snags.</p>

<p>The first snag is that I had installed Fedora with default partitioning options (something I rarely do), and it had helpfully used LVM to configure my disk drive. LVM adds a layer of indirection, so I had to figure out how to mount an LVM volume instead of a disk partition. As a general rule, I never use LVM on desktop or laptop machines because I don&#8217;t like the additional complexity, especially when I&#8217;m trying to mount a drive to recover data.</p>

<p>The next snag is that Linux uses UUIDs for hard disks these days, instead of helpful, human-readable labels. In the good old days, Linux distributions would label the root partition, the home partition, and others. But not when I let the installer work its default magic. So, I had to figure out which volume contained my root partition, my boot partition, and so forth.</p>

<p>Once I mounted my partitions properly, I was ready to &#8220;chroot /mnt/sysimage&#8221;, and after I did, I ran &#8220;grub-install&#8221;. No luck. This was the third snag.</p>

<p>I realized that /boot/grub/grub.conf was empty. And grub-install doesn&#8217;t fix the problem &#8212; it can&#8217;t populate information that is completely missing, like knowing what disk UUID to use for the root partition.</p>

<p>&#8220;No problem,&#8221; I thought, &#8220;I&#8217;ll just restore from backup&#8230;&#8221;. Except, I didn&#8217;t have a backup. As a general rule, I back up /var, /home and /etc, but not /boot. Now I know better.</p>

<p>Surely, I thought, there should be a copy of grub.conf that the package updates had left around. But there wasn&#8217;t.</p>

<p>Such a critical file, and there was no automated backup. No &#8220;restore point&#8221;. No way to recreate it from data in /etc. What an oversight!</p>

<p>This is the first time I can remember having had an update eat my grub.conf file, and I&#8217;ve been running Linux since before distributions switched to grub as a boot loader. On the other hand, maybe I jumped to to an incorrect conclusion &#8212; it&#8217;s possible that the updates didn&#8217;t eat my grub.conf. Regardless, grub.conf was empty and my system wouldn&#8217;t boot.</p>

<p>It seems to me that something this important should have been designed with more resilence.</p>

<p>There were two ways to fix it, as far as I could see. One is upgrade from Fedora 14 to Fedora 14 (thus preserving my data). The second is to recreate grub.conf by hand, and for that, I needed an example &#8212; a template. I used the one at http://forums.fedoraforum.org/showthread.php?t=227358. My boot up screen isn&#8217;t as pretty as it once was, but it is functional.</p>

<p>Lastly, I made copy of /boot/grub/grub.conf. Now where did I put it?&#8230;</p>
]]></content:encoded>
			<wfw:commentRss>http://jaredrobinson.com/blog/the-dog-ate-my-grub-conf-unwanted-lvm-indirection/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Technology and greatness</title>
		<link>http://jaredrobinson.com/blog/technology-and-greatness/</link>
		<comments>http://jaredrobinson.com/blog/technology-and-greatness/#comments</comments>
		<pubDate>Mon, 22 Aug 2011 16:54:07 +0000</pubDate>
		<dc:creator>Jared</dc:creator>
				<category><![CDATA[Quotes]]></category>

		<guid isPermaLink="false">http://jaredrobinson.com/blog/?p=699</guid>
		<description><![CDATA[I like this quote: No technology, no matter how amazing&#8230; can by itself ignite a shift from good to great&#8230;. No technology can turn the wrong people into the right people. No technology can instill the discipline to confront brutal &#8230; <a href="http://jaredrobinson.com/blog/technology-and-greatness/">Continue reading <span class="meta-nav">&#8594;</span></a>]]></description>
			<content:encoded><![CDATA[<p>I like this quote: <em>No technology, no matter how amazing&#8230; can by itself ignite a shift from good to great&#8230;. No technology can turn the wrong people into the right people. No technology can instill the discipline to confront brutal facts of reality, nor can it instill unwavering faith. No technology can supplant the need for deep understanding&#8230;. No technology can create a culture of discipline</em>. &#8212; <a href="http://www.criticalthink.info/Phil1301/goodtogreat.htm">Jim Collins, Good to Great, p 161</a>.</p>
]]></content:encoded>
			<wfw:commentRss>http://jaredrobinson.com/blog/technology-and-greatness/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Hazards of Best Practices</title>
		<link>http://jaredrobinson.com/blog/hazards-of-best-practices/</link>
		<comments>http://jaredrobinson.com/blog/hazards-of-best-practices/#comments</comments>
		<pubDate>Mon, 22 Aug 2011 16:50:13 +0000</pubDate>
		<dc:creator>Jared</dc:creator>
				<category><![CDATA[Quotes]]></category>

		<guid isPermaLink="false">http://jaredrobinson.com/blog/?p=687</guid>
		<description><![CDATA[&#8220;Best practices are a hazard because they ask us to substitute slogans for thinking.&#8221; &#8212; Pete McBreen, p. 125 Software Craftmanship. Sometimes best practices are used to shift blame by using the bandwagon fallacy: &#8220;Everyone else is doing it &#8212; &#8230; <a href="http://jaredrobinson.com/blog/hazards-of-best-practices/">Continue reading <span class="meta-nav">&#8594;</span></a>]]></description>
			<content:encoded><![CDATA[<p>&#8220;Best practices are a hazard because they ask us to substitute slogans for thinking.&#8221; &#8212; Pete McBreen, p. 125 Software Craftmanship.</p>

<p>Sometimes best practices are used to shift blame by using the bandwagon fallacy: &#8220;Everyone else is doing it &#8212; it&#8217;s a best practice, so don&#8217;t blame me&#8221;. Sure, there&#8217;s strength in numbers, but not necessarily wisdom in numbers.</p>
]]></content:encoded>
			<wfw:commentRss>http://jaredrobinson.com/blog/hazards-of-best-practices/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>ORM Solutions for C++ and sqlite: hiberlite, SOCI</title>
		<link>http://jaredrobinson.com/blog/orm-solutions-for-c-and-sqlite-hiberlite-soci/</link>
		<comments>http://jaredrobinson.com/blog/orm-solutions-for-c-and-sqlite-hiberlite-soci/#comments</comments>
		<pubDate>Fri, 05 Aug 2011 04:23:49 +0000</pubDate>
		<dc:creator>Jared</dc:creator>
				<category><![CDATA[Programming]]></category>
		<category><![CDATA[Tech]]></category>

		<guid isPermaLink="false">http://jaredrobinson.com/blog/?p=689</guid>
		<description><![CDATA[I think SQLite is a great database for a C/C++ application to use. It sure is easy to query the data that way, without intrinsic support from the application. When the application changes, the database is still accessible via standard &#8230; <a href="http://jaredrobinson.com/blog/orm-solutions-for-c-and-sqlite-hiberlite-soci/">Continue reading <span class="meta-nav">&#8594;</span></a>]]></description>
			<content:encoded><![CDATA[<p>I think SQLite is a great database for a C/C++ application to use. It sure is easy to query the data that way, without intrinsic support from the application. When the application changes, the database is still accessible via standard sqlite clients. Yet using SQLite in an application can require a lot of repetitive code to serialize objects to and from the database, so I wondered if there are ORM solutions for C/C++. It turns out that there are. I only had to turn to <a href="http://stackoverflow.com/questions/74141/good-orm-for-c-solutions">stackoverflow.com to find the following</a> (among many):
<ol>
    <li><a href="http://code.google.com/p/hiberlite/wiki/Tutorial">Hiberlite</a></li>
    <li><a href="http://soci.sourceforge.net/">SOCI</a></li>
</ol></p>
]]></content:encoded>
			<wfw:commentRss>http://jaredrobinson.com/blog/orm-solutions-for-c-and-sqlite-hiberlite-soci/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>NPR: When Patents Attack!</title>
		<link>http://jaredrobinson.com/blog/npr-when-patents-attack/</link>
		<comments>http://jaredrobinson.com/blog/npr-when-patents-attack/#comments</comments>
		<pubDate>Fri, 05 Aug 2011 04:14:01 +0000</pubDate>
		<dc:creator>Jared</dc:creator>
				<category><![CDATA[Tech]]></category>
		<category><![CDATA[Patents]]></category>
		<category><![CDATA[tech]]></category>

		<guid isPermaLink="false">http://jaredrobinson.com/blog/?p=685</guid>
		<description><![CDATA[I write software for a living, and I have a hard time recognizing redeeming value of software patents (other than to have something to negotiate with when someone tries to sue a company). Reading the NPR transcript about patents got &#8230; <a href="http://jaredrobinson.com/blog/npr-when-patents-attack/">Continue reading <span class="meta-nav">&#8594;</span></a>]]></description>
			<content:encoded><![CDATA[<p>I write software for a living, and I have a hard time recognizing redeeming value of software patents (other than to have something to negotiate with when someone tries to sue a company). Reading the NPR transcript about patents got my blood boiling. The system has been gamed, and patent troll companies legally extort money from other companies.</p>

<p>Read or listen <a href=" http://www.thisamericanlife.org/radio-archives/episode/441/when-patents-attack">here</a>. Are there good reasons to have software patents, and if so, on what types of inventions and in what circumstances?</p>
]]></content:encoded>
			<wfw:commentRss>http://jaredrobinson.com/blog/npr-when-patents-attack/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

