<?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>Trausch’s Little Home &#187; FLOSS</title>
	<atom:link href="http://mike.trausch.us/blog/category/floss/feed/" rel="self" type="application/rss+xml" />
	<link>http://mike.trausch.us/blog</link>
	<description>My writing on life, computers, and technology</description>
	<lastBuildDate>Wed, 09 Feb 2011 18:16:20 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.0.1</generator>
		<item>
		<title>Can you force freedom and it still be freedom?</title>
		<link>http://mike.trausch.us/blog/2010/01/19/can-you-force-freedom-and-it-still-be-freedom/</link>
		<comments>http://mike.trausch.us/blog/2010/01/19/can-you-force-freedom-and-it-still-be-freedom/#comments</comments>
		<pubDate>Tue, 19 Jan 2010 05:12:57 +0000</pubDate>
		<dc:creator>Michael Trausch</dc:creator>
				<category><![CDATA[FLOSS]]></category>
		<category><![CDATA[GNU/Linux]]></category>
		<category><![CDATA[GPLv3]]></category>
		<category><![CDATA[Rant]]></category>
		<category><![CDATA[computing]]></category>
		<category><![CDATA[freedom]]></category>
		<category><![CDATA[free software]]></category>
		<category><![CDATA[software]]></category>
		<category><![CDATA[Ubuntu]]></category>
		<category><![CDATA[wtf‽]]></category>

		<guid isPermaLink="false">http://mike.trausch.us/blog/?p=581</guid>
		<description><![CDATA[So back on this topic again today.  I am going to take a look at a few different statements here in this post, and then I&#8217;m going to go over them and explain why these statements are or are not correct.  Should you wish to verify any of my information, you&#8217;re more than welcome to [...]]]></description>
			<content:encoded><![CDATA[<p>So back on this topic again today.  I am going to take a look at a few different statements here in this post, and then I&#8217;m going to go over them and explain why these statements are or are not correct.  Should you wish to verify any of my information, you&#8217;re more than welcome to do so—just make sure you actually know what you&#8217;re talking about before you call me “wrong” on this one, or I will absolutely ignore you.  I have other—and more important—things to do than put up with <a href="http://en.wikipedia.org/wiki/Troll_(internet)">trolls</a> who cannot do basic research (of course, this means that I expect that you know how to use <a href="http://www.google.com/">Google</a> and <a href="http://en.wikipedia.org/">Wikipedia</a> and will do so before writing your responses, but hey, I could be expecting too much).</p>
<h3>“You can have <a href="http://en.wikipedia.org/wiki/Freedom_(philosophy)">freedom</a> without <a href="http://en.wikipedia.org/wiki/Choice">choice</a>.”</h3>
<p>That someone could even come up with this one is just amazing to me. Note that this is not an exact quote, but it is the summary of Friday&#8217;s topic. For example, this summary comes from the idea that <a href="http://en.wikipedia.org/wiki/Canonical_Ltd.">Canonical</a> is bad for <a href="http://ubuntuforums.org/showthread.php?t=1381221">considering making mainstream non-free software available for Ubuntu based on user preferences</a>. It does not matter who came up with it, of course, but the important thing is that it be called what it is: patently absurd. The ability to choose is a major part of what freedom—or <a href="http://en.wikipedia.org/wiki/Liberty">liberty</a>—is. If you cannot make a choice on a matter, then by definition you do not have freedom in the context of that matter. It is quite simple and self-explanatory. Canonical is seeking to <em>increase</em> freedom here, not take it away. Some people actually <em>want</em> to use <a href="http://en.wikipedia.org/wiki/Proprietary_software">non-free software</a>; others may not want to use it, but aren&#8217;t aware of alternatives. The latter group of people should have our focus with regard to education (but then we should <em>let them make the choice for themselves</em>!).</p>
<p>Note that I am not one of these people: I would rather use <a href="http://en.wikipedia.org/wiki/Free_software">free software</a> because of the liberty it gives me that I have come to expect over the years. But I am <em>not</em> going to tell someone else that they are <em>harming</em> me because they would rather use non-free software that is familiar to them. All I can do is show them that there are free alternatives that exist. I cannot—and I will not—make them use it or make them feel bad for not using it. I may not like proprietary software for a variety of reasons, but I will defend people&#8217;s right to use it just as I will defend even a <a href="http://en.wikipedia.org/wiki/Stupidity">stupid</a> person&#8217;s right to spew nonsense by way of speech or written word. In other words, “<a href="http://en.wikiquote.org/wiki/Evelyn_Beatrice_Hall">I disapprove of what you say, but I will defend to the death your right to say it</a>,” or perhaps more appropriately, “I [may] disapprove of what [software you run], but I will defend to the death your right to [run] it.” Even I use a <a href="http://en.wikipedia.org/wiki/Fglrx">package</a> or <a href="http://en.wikipedia.org/wiki/NVIDIA#Documentation_and_drivers">two</a> that is proprietary in nature (though it is looking like I will not have to do so for much longer, given the efforts to replace these packages with equivalent free software).</p>
<p>It is worth it to note that by adding non-free software to <a href="http://www.ubuntu.com">Ubuntu</a>, the free software that is already there does not change. The mere existence of non-free software within its repositories does not make Ubuntu somehow bad or evil. It would add choices that do not currently exist, and that one such as myself or yourself can certainly opt out of—I most likely would, for the most part, as I do not need to depend on non-free application software, and I only use non-free drivers if I have hardware where anything else is nonviable (and only until there are functional free software drivers). Did you know that Ubuntu has <a href="https://lists.ubuntu.com/archives/gobuntu-devel/2008-April/000651.html">an option in the installer to only install free software</a>? Can you say that for your favorite desktop <a href="http://en.wikipedia.org/wiki/Operating_system">operating system</a> distribution, whatever that might be?</p>
<p>The response to this idea, then, is that without choice, there is very little—if any, really—freedom. The thing that gives us freedom with free software is that we are able to to download the source code, to review/audit it, to change it to fit our needs or fix a problem, and to share those changes. If we cannot do those things, then it is not free software; see the <a href="http://www.gnu.org/philosophy/free-sw.html">essential freedoms</a>. But non-free software inside a distribution is not something that should not cause you great consternation even if you are among the most dedicated of freedom advocates, for if you are a true advocate of <em>freedom</em> then by definition you <em>must</em> respect a computer user&#8217;s freedom of choice. Remember that we choose to run free software because of the benefits it brings to us; we choose to improve upon free software for much the same reason. Eventually, I think that free software will <a href="http://en.wikipedia.org/wiki/History_of_free_software">once again</a> become the norm for computer software, on <a href="http://en.wiktionary.org/wiki/merit">merit</a> alone, for no other reason than the development, release, and usage of free software is a highly practical solution for many things ranging from <a href="http://en.wikipedia.org/wiki/Library_(computing)">library code</a> to <a href="http://en.wikipedia.org/wiki/Application_software">application software</a> to complete operating systems. It is worth noting that <a href="http://en.wikipedia.org/wiki/Free_content">free content</a>—which is similar in concept to free software, which itself is merely a specific application of freedom itself—also appears to making major headway towards becoming mainstream; it is doing so more quickly than free software is, but there is every reason to believe that free software will follow, for it is already.</p>
<h4>An Example</h4>
<p>Imagine that you are in a store, because you need some milk for dinner some night. You always get 1 gallon of 2%. But, the store has stopped carrying it, because more people buy whole milk and they were throwing away the 2% milk—demand was low, supply got to be too high, so they just stopped carrying it altogether. You leave the store and head to the next in the same town and you find the same thing there. You have a choice of stores to go to, and you have made the choice to go buy yourself some milk. But there is only one type of milk. You no longer have the choice to buy 2% where you are, and so effectively, your freedom to buy it has been taken away. (Of course, <a href="http://www.thriftyfun.com/tf73187289.tip.html">you can make 2% milk</a> <a href="http://answers.yahoo.com/question/index?qid=20090809170811AAT0NO3">from whole milk</a> (and <a href="http://wiki.answers.com/Q/How_much_butter_added_to_skim_milk_will_make_whole_milk">make whole from 2% even</a>, or <a href="http://www.cookingforengineers.com/article/113/Making-Butter">even butter</a>), but I suspect just as many people want to do that as want to write their own free software that they <em>demand</em> simply must exist, but doesn&#8217;t yet).</p>
<p>Now, the point here is that there is more than one freedom in play: the freedom of the store to stock (or not stock) various products, which affects your freedom as a <a href="http://en.wikipedia.org/wiki/Consumer">consumer</a> to buy the product you want. In the case of software, and choice, if the software you are running gives you all the choices you want, <em>then it fits your needs</em>. If it does <em>not</em>, then you are not going to be able to use it the way you want. Now you have two choices: you can do the work that it would take to make your desired choice possible, or you can use another system (free or proprietary) that will give you the choice that you want. Many people will choose the latter, especially if they are non-programmers. Though I&#8217;ve seen programmers also choose to use proprietary systems for something that they could themselves implement. That is their choice, of course. After all, if you really wanted 2% milk, you would have the same choice: make it yourself, or drive to the next town over which might have it available for you (assuming that there is some in stock and that the stores neighboring towns have not also decided to stop stocking 2% milk).</p>
<h4>Ubuntu One: The Reason Behind This</h4>
<p>This discussion came up because someone on <a href="http://identi.ca">identi.ca</a> made the claim that Canonical is forcing proprietary software into Ubuntu by way of the <a href="http://en.wikipedia.org/wiki/Ubuntu_One">Ubuntu One</a> client software. I cannot even begin to state just how woefully incorrect this point of view is. First off: the <em>only</em> thing added to Ubuntu is the ability to connect to Ubuntu One, and the software that was added to Ubuntu do to that is licensed under Version 3 of the <a href="http://en.wikipedia.org/wiki/GPL"><strong>GNU General Public License</strong></a>. The claim made in response to that was that Ubuntu One is only <em>partly</em> free software, because the server is somewhere else and has not been released. As we shall soon see, that claim is nonsensical—it depends on an extremely naïve view of how software actually works in order to make sense, really.</p>
<p>So, first things first: Ubuntu One, which was added to Ubuntu 9.04, is <em>not</em> proprietary software. The proof rests in the fact that it GNU GPL v3.0, and we know <em>a priori</em> that software licensed under the GPL is free software, so we do not need to go further on that point.</p>
<p>Now, because the software in question added to Ubuntu is free software, we can read it. The essential freedoms granted to us by truly free software ensure this, and the GPLv3 is indeed a truly free software license because it grants those freedoms. Because we are able to study the software and see how it communicates with the server. Once we know how to communicate with the server, we can write that up and design a server that communicates exactly the same way. From there, it is just a matter of patching the sync dæmon that is in Ubuntu to talk to an arbitrary, Ubuntu One compatible server. To determine how to do that, one need only read the <a href="http://python.org/">Python</a> source code contained in the <code>python-ubuntuone-storageprotocol</code> and <code>python-ubuntuone-client</code> packages. If you do not know Python well, you might expect to spend several days doing that, but if it bothers you so tremendously that you are going to practically start a flame war over it, you may find it worth it to do so.</p>
<p>Of course, the other side to that is this: if you really want Ubuntu One to talk to an arbitrary server that runs free software, and you want that free software to be written, you can fund the effort to write the free software. Approach a proficient developer somewhere out there on the Internet and ask them how much they&#8217;d charge to write a server for Ubuntu One. You might not be able to afford the fund the project entirely, but if you get a number from someone, you can start a coordinated effort to raise the funds. If you are lucky enough to be able to fund the whole project, then do so: it is but one way that you can help provide something back to the community. This does not apply to just an implementation of the Ubuntu One protocol, it could apply to anything that you see that is missing and needs to be created. Or you could spend time learning what you need to learn to pick up the project yourself, if you care for the project that deeply. The most important attribute that a person can have in order to get started with development is motivation—<a href="http://jameswestby.net/weblog">James Westby</a> reminded me of this a couple of years ago, something which I had forgotten.</p>
<h4>Perceptions: Another (Possible) Reason</h4>
<p>It was suggested to me that another possible reason that people would object to having non-free software inside an operating system distribution such as Ubuntu is that they are afraid that the proprietary options have higher quality, or offer superior features, or provide functionality that is not offered by any existing free software. Thus, they have this perception that by adding such non-free software into a distribution like Ubuntu, people will automatically use and prefer it over free software. This simply is not the case. Sure, some people will use iTunes if it is available on Ubuntu. Maybe many people would. I <em>might</em> even do so, if it were legally available for me to use that way <em>and</em> if it supports the purchase of <a href="http://en.wikipedia.org/wiki/Digital_rights_management">DRM</a>-free music. However, if there were a free software client for the iTunes store, I&#8217;d much prefer to use that. To my knowledge, however, there is no such thing that exists.</p>
<p>If there is not a free software alternative for a non-free component inside a distribution of software, if you are offended by that, then by all means, <em>create a free software alternative for it</em>! As mentioned above, you can start on such a project&#8217;s development, or you can look for people that would be interested in volunteering for it and coordinating them, or you can put up funds to pay developers to implement it. If you have money, this can be the easy part: find someone who is willing to accept payment for the service of implementing the free software alternative for whatever it is that someone else has funded, wrote, and released as proprietary software. It is not like free software is developed without cost (and if you think that it is, then you seriously do not understand what free software is or anything about the world of free software and have no standing to be getting mad when a company spends money writing software and does not release it as free software. You can try to write companies that write such software and ask them if they will give you any form of written specifications for the software, or an interface definition, or something along those lines. The worst thing that could happen is that you will be told “no”. And do so <em>nicely</em>, or they&#8217;ll be more inclined to tell you “bugger off” instead of simply “no”.</p>
<h3>“Allowing users to choose proprietary software is anti-freedom.”</h3>
<p>Nothing could be farther from the truth; it is the same, in fact, as the above statement that one can have freedom without choice. For example, if Ubuntu adopts iTunes and makes it so that you can “sudo aptitude install itunes” in the future, that is <em><strong>not</strong></em> a bad thing! How <em>can</em> it be—It contributes to the ability to choose, and thereby <em>contributes to the freedom of the end-user</em>. If you are a die-hard free software supporter and do not want to run non-free software on your system, then there is a very simple solution for you: <em><strong>simply don&#8217;t install it</strong></em>.  That <strong>is</strong> a valid solution to the problem. There are tools already available that can be run as a <a href="http://en.wikipedia.org/wiki/Cron">cron job</a> and report on any non-free software that you might have accidentally (or even intentionally) installed. If you are worried about additional non-free software getting into Ubuntu, then help enhance those tools. Or write a <a href="http://en.wikipedia.org/wiki/GUI">GUI</a> <a href="http://en.wikipedia.org/wiki/Front_end">front-end</a> for something like the <a href="http://en.wikipedia.org/wiki/Vrms">virtual RMS</a> program and work to get that included into Ubuntu as well, perhaps something that can run every time you login to the computer, or that runs as a persistent process that watches the package database on your distribution of choice for updates and then checks to see if newly installed software is non-free and alerts the user. Of course, it&#8217;d be most effective as an opt-in system, and not an <a href="http://en.wikipedia.org/wiki/Opt-out">opt-out</a> one where it would just be annoying.</p>
<p>There is no way, then, that freedom is actually reduced in this way when another choice becomes available. If iTunes were to be included in the repositories (and I suspect it would be, <a href="http://www.ubuntu.com/community/ubuntustory/components">like the restricted, universe and multiverse repositories</a>, a separate opt-in repository; perhaps simply “proprietary” would be fitting), this does not reduce your ability to choose to run a free software media player and manager like <a href="http://banshee-project.org/">Banshee</a>, or <a href="http://projects.gnome.org/rhythmbox/">Rhythmbox</a>, or even <a href="http://amarok.kde.org/">AmaroK</a> if you are so inclined to run that KDE stuff.</p>
<p>Once upon a time, <a href="http://en.wikipedia.org/wiki/Fear,_uncertainty_and_doubt">FUD (fear, uncertainty, and doubt)</a> was the tool of Microsoft. We (the free software world) <em>completely</em> hated it when Microsoft would put out FUD, because we would then have to fight that FUD by way of explanation and demonstration. Well, some time ago, a subgroup of the free software world decided to start using FUD themselves—it was done with <a href="http://en.wikipedia.org/wiki/Mono_(software)">Mono</a>, and it is being done now with just a <em>survey</em> asking people what sort of software they would like to see in Ubuntu. Now, those of us who are left who are advocates of liberty—both personal and societal—are stuck potentially fighting <strong><em>two</em></strong> battles. One with Microsoft&#8217;s FUD—such as the constant notion that you have to pay for software—and one with the &#8220;free software evangelists&#8221; FUD, who have even gone so far as to say that people should not use certain types of free software (the one who calls himself “The Open Sourcer” <a href="http://www.theopensourcerer.com/tag/mono/">even still today tells people to remove certain truly free software from their systems</a>). The truth is somewhere in the middle, between these two ends of the spectrum.</p>
<h3>Conclusion</h3>
<p>Back to the point at hand: to say that giving a person a choice is a constraint on that person&#8217;s freedom, that is <a href="http://en.wikipedia.org/wiki/Doublespeak">doublespeak</a>.; it is saying that “slavery is freedom,” albeit to a lesser degree than that very melodramatic extreme—it simply does not make sense. The concept just does not make sense unless the words that are used to express the concept are dramatically redefined to mean things vastly different from what standard English dictionaries define them to be. The only reason that one has to try to convince someone that additional choice is a constraint on freedom is to try to convince people of things that are not true; to install fear, uncertainty, and doubt into people. This is the sort of behavior that—no matter <em><strong>what</strong></em> community it originates from—is completely immoral, unethical, and absolutely unacceptable. It&#8217;s dishonest, and for those of you who know me personally, you know what I think of dishonesty.</p>
]]></content:encoded>
			<wfw:commentRss>http://mike.trausch.us/blog/2010/01/19/can-you-force-freedom-and-it-still-be-freedom/feed/</wfw:commentRss>
		<slash:comments>20</slash:comments>
		</item>
		<item>
		<title>On mailing list management software: Part 1</title>
		<link>http://mike.trausch.us/blog/2009/10/14/on-mailing-list-management-software-part-1/</link>
		<comments>http://mike.trausch.us/blog/2009/10/14/on-mailing-list-management-software-part-1/#comments</comments>
		<pubDate>Wed, 14 Oct 2009 17:52:52 +0000</pubDate>
		<dc:creator>Michael Trausch</dc:creator>
				<category><![CDATA[FLOSS]]></category>
		<category><![CDATA[The MUA Saga]]></category>
		<category><![CDATA[computing]]></category>
		<category><![CDATA[freedom]]></category>
		<category><![CDATA[programming]]></category>

		<guid isPermaLink="false">http://mike.trausch.us/blog/?p=571</guid>
		<description><![CDATA[Frequently enough, I&#160;see people forwarding messages to mailing lists that were intended to get to the ML&#160;in the first place, but didn&#8217;t happen due to some configuration issue or whatever.&#160; There are people that think this is fine, this is workable, and it is correct.&#160; I&#160;happen to disagree, but discussing this in the context of [...]]]></description>
			<content:encoded><![CDATA[<p>Frequently enough, I&nbsp;see people forwarding messages to mailing lists that were intended to get to the ML&nbsp;in the first place, but didn&#8217;t happen due to some configuration issue or whatever.&nbsp; There are people that think this is fine, this is workable, and it is correct.&nbsp; I&nbsp;happen to disagree, but discussing this in the context of an existing mailing list software&#8217;s mailing list is proving to be fruitless (I would have guessed this initially anyway, but it wasn&#8217;t my idea to take the conversation there&#8230;).&nbsp; So, here, I&nbsp;attempt to state exactly where I&#8217;m coming from as a starting point.&nbsp; This is the first part of what will hopefully be a productive series of posts that strive to define what mailing list software&nbsp;ought to be, how it ought to work, and gradually refining detail until it becomes a blueprint for an initial implementation, at which point it would be my intention to begin a project to do the implementation.</p>
<h2>Base Position</h2>
<p>Mailing lists should Just Work.&nbsp; Mailing list management servers are software just like any other software, and they can be made to do what is convenient for us humans, and they <em>should</em> be made to do what is convenient for us humans.&nbsp; Mailing list software should cater to the needs and desires <em>of all its users</em>, regardless of technical aptitude or choice of MUA&nbsp;(mail user agent, email client)&nbsp;software.&nbsp; Mailing list software should be updated to operate with the expectations and flexibility expected of software used in the 21st century, and provide more options for interaction both technical users and non-technical users alike can love and use.</p>
<p>It is my personal belief that both mailing list software and MUA&nbsp;software should follow the established philosophy of &quot;do one thing and do it well&quot;.&nbsp; That means that MUA software should be expected to only be capable of being a basic mail user agent, and that mailing list server software should be expected to be capable of everything required to manage a mailing list for end-users, technical users, and list administrators.&nbsp; A finer-grained permission model in mailing list server software could be adopted to make some of the proposed features even more convenient and get rid of the &quot;administrator&quot;&nbsp;vs. &quot;user&quot;&nbsp;line (i.e., &quot;Jack can unsubscribe users&quot;, or &quot;Carla can list messages in the mailing list&#8217;s pending approval queue&quot;, or whatever).</p>
<p>Furthermore, it is my belief that enabling convenience for end-users does not necessarily mean taking advanced functionality away from technical users: with careful thought and design, <em>both</em> needs can be met with a single standard.&nbsp; It is also my belief that the most important part of any proposed design is the consideration of users ranging from complete newbies to people that have no time in the world but to learn about every feature that is available and find applications for them.</p>
<p>It is <em>not</em> my belief that mailing list management software should be extended to do things beyond the realm of mailing list management, though I&nbsp;believe that mailing lists are also currently very narrowly defined to be a mirror of public forums such as Usenet, and mailing lists certainly do not need to be restricted to such a model when a little bit of extension can bring a great deal of benefit for all users involved.</p>
<p>In short, mailing list management software should maximize flexibility while minimizing the amount of knowledge required to initially begin using the mailing list system (at the end-user level, at the technical user level, at the administrative level) and regularly interact with the system. &nbsp;Convenience, ease-of-learning, continued ease-of-use, flexibility in usage patterns/workflows and use cases <strong><em>are all equally important</em></strong>.</p>
<h2>Functionality Target Proposal</h2>
<p>Let us assume the following statements are true:</p>
<ol>
<li>Mail User Agent software can only be relied upon to have barebones message handling functionality that does not encompass mailing-list aware logic.</li>
<li>Users can only be relied upon to have barebones message handling functionality with only message-level context, such that they know that they are responding to a message.</li>
</ol>
<p>Now, let&#8217;s define a few other assumptions that we will take to be true with regard to MUA software:</p>
<ol>
<li>MUA&nbsp;software properly sends <em>either</em> a References header <em>or</em> an In-Reply-To header, which facilitates threading (should not be an issue, since RFC{<a href="http://tools.ietf.org/html/rfc822">822</a>,<a href="http://tools.ietf.org/html/rfc2822">2822</a>,<a href="http://tools.ietf.org/html/rfc5322">5322</a>} specifies the header and it should be supported universally).</li>
<li>MUA&nbsp;software gives the end user no ability to send custom headers as a base feature.</li>
<li>MUA&nbsp;software gives the end user no ability to modify headers  <em>during message composition </em>other than To, Cc, Bcc, and Subject as a base feature.</li>
<li>Even if MUA&nbsp;software can do items 2 and 3 above, it is safe to assume that:
<ol>
<li>It is terribly inconvenient to do so, or</li>
<li>The user does not know how to do so.</li>
</ol>
</li>
</ol>
<p>Now, let&#8217;s define a few other assumptions that we will take to be true with regard to this ideal mailing list management software:</p>
<ol>
<li>The mailing list management software remembers mailing list threads by remembering message IDs.</li>
<li>The mailing list management software may or may not fall back to identification of threads by subject line, timestamp, or some other means, depending on what is most feasible and whether or not there are any accurate huristics that can be applied to make a determination with reasonable confidence.</li>
<li>The mailing list management software is remembers messages and posters, and stores information about each message in a manner that makes filtering (e.g., filters for the display of archives, or filters for sending back out to the mailing list)&nbsp;on the server side possible.</li>
<li>The mailing list management software can apply a limited number of per-user preferences on the server, including multiple addresses associated with a single subscriber, mode of subscription (digest, normal), interval of digests with at least an option for daily or per-<em>x</em>-number of messages with <em>x</em> being a server-specific configuration item, and perhaps server-side support for bandwidth saving features such as server-side &quot;killfiles&quot;.</li>
<li>The mailing list management software <em>never</em> <strong><em>requires </em></strong>custom message headers or interfaces other than email for management of the server or per-user preferences, though it can implement such features <em>in addition to</em> a base interface which depends only on an RFC{<a href="http://tools.ietf.org/html/rfc822">822</a>,<a href="http://tools.ietf.org/html/rfc2822">2822</a>,<a href="http://tools.ietf.org/html/rfc5322">5322</a>} capable mailer.</li>
<li>The mailing list management server uses all allowable standard headers for list management such that MUA&nbsp;software implementing those standards can use the information, but <strong>does not assume</strong> that MUA&nbsp;software is actually compliant to those specifications, instead treating them as optional in nature.</li>
</ol>
<p>Let&#8217;s further define a few modes of operation.&nbsp; We will discuss potential implementations for these modes later; for now, we are just defining the modes of operation.&nbsp; If you have a new mode to suggest, please post it in the comments section below, in the same format.&nbsp; A solution for how to make the mode work is not required, but if desired can be supplied as well if it is in the framework of this post.&nbsp; We&#8217;re talking about the <em>ideal</em> mailing list management software here, not any currently existing one.&nbsp; </p>
<p>Here is the first (and probably most common) mode of operation, which we will call Mode 1 (&quot;Typical operation&quot;):</p>
<ol>
<li>Bob wants to send an original post to a mailing list (e.g., start a new thread).&nbsp; He enters To and Subject headers, and composes his message just as if he&#8217;s sending to an individual.&nbsp; <em>Note that current mailing lists already do that, and thus mailing lists are in this respect transparent.</em></li>
<li>Bob&#8217;s message hits the mailing list server and is distributed to the subscribers of the mailing list as expected.</li>
<li>Alice sees Bob&#8217;s message, and wishes to add to the thread of discussion, so she hits &quot;Reply&quot;, and enters her message as a reply to Bob&#8217;s.&nbsp; She then hits send.</li>
<li>Alice&#8217;s message hits the mailing list server and is distributed to the subscribers of the mailing list as expected.</li>
</ol>
<p>Here is Mode 2 (&quot;Private replies&quot;):</p>
<ol>
<li>Bob wants to send an original post to a mailing list (e.g., start a new thread).&nbsp; However, the thread is intended to be a private poll, and so replies should go to Bob directly and not be distributed to the mailing list.</li>
<li>Bob&#8217;s message hits the mailing list server and is distributed to the subscribers of the mailing list as expected.</li>
<li>Alice replies to Bob&#8217;s mailing list post, which goes to Bob without being distributed to the mailing list.</li>
</ol>
<p>Here is Mode 3 (&quot;Private subthreads&quot;):</p>
<ol>
<li>Bob wants to send an original post to a mailing list (e.g., start a new thread) normally.</li>
<li>Bob&#8217;s message hits the mailing list server and is distributed to the subscribers of the mailing list as expected.</li>
<li>Alice responds to Bob&#8217;s message with a few queries and sends the message to the mailing list.</li>
<li>Frank responds to Alice&#8217;s queries with a few more to seek clarification.</li>
<li>Bob responds to Alice normally.</li>
<li>Bob responds to Frank normally.</li>
<li>Jo sees Bob&#8217;s response to Frank and has a question that should be addressed to Bob directly, without going to the mailing list.&nbsp; Jo sends an email that should get directly to Bob and not be distributed to the mailing list.
<ol>
<li><strong>Note</strong><strong>:</strong> mail filtering (if Bob uses it) should not filter the mail as if it came from the mailing list, but the message should thread properly if mail filtering is not considered or if the message is moved to a folder with the rest of the mailing list messages.</li>
<li>Bob receives the response and replies to the message, which goes to Jo and does not get distributed to the whole of the mailing list.</li>
</ol>
</li>
</ol>
<p>Here is Mode 4 (&quot;Dead thread&quot;):</p>
<ol>
<li>Bob wants to send an original post to a mailing list that is normally a discussion list, but this is an announcement and there should be no replies.</li>
<li>Bob&#8217;s message hits the mailing list server and is distributed to the subscribers of the mailing list as expected.</li>
<li>Alice responds to Bob&#8217;s message with some questions pertaining to the announcement.</li>
<li>The mailing list software informs Alice that responses were disabled on the post.</li>
</ol>
<p>Here is Mode 4a (&quot;Dead subthread&quot;):</p>
<ol>
<li>Bob wants to send an original post to a mailing list normally.</li>
<li>Bob&#8217;s message hits the mailing list server and is distributed to the subscribers of the mailing list as expected.</li>
<li>Alice responds to Bob&#8217;s message with some questions.</li>
<li>Bob responds to Alice&#8217;s message, answering the questions, and noting that the discussion should go elsewhere for any reason, and that the subthread is closed.</li>
<li>Richard responds to Bob&#8217;s message, trolling.</li>
<li>The mailing list software informs Richard that responses were disabled on the subthread.</li>
</ol>
<p>Here is Mode 4b (&quot;Killed thread&quot;):</p>
<ol>
<li>Bob wants to send an original post to a mailing list normally.</li>
<li>Bob&#8217;s message hits the mailing list server and is distributed to the subscribers of the mailing list as expected.</li>
<li>Alice responds to Bob&#8217;s message.</li>
<li>Frank responds to Bob&#8217;s message.</li>
<li>Jo responds to Bob&#8217;s message.</li>
<li>Frank responds to Alice&#8217;s message.</li>
<li>Frank responds to Jo&#8217;s message.</li>
<li>&#8230;</li>
<li>Eventually, the thread gets out of hand, and everyone but the trolls want the thread dead.&nbsp; Bob sends a message stating that the thread is dead, and dead it remains.</li>
<li>Future messages in reply to the thread are responded to by the mailing list software with a message stating that the thread was killed and replies are disabled on the post.</li>
</ol>
<p>Here is Mode 5&nbsp;(&quot;Muted thread&quot;):</p>
<ol>
<li>Bob wants to send an original post to a mailing list normally.</li>
<li>Bob&#8217;s message hits the mailing list server and is distributed to the subscribers of the mailing list as expected.</li>
<li>Conversation ensues and certain users are utterly disinterested and do not want to receive messages on the thread any longer.</li>
<li>Jo sends a message to the mailing list indicating disinterest and the mailing list server obliges by not sending Jo any more messages from the thread.</li>
</ol>
<p>Here is Mode 5a (&quot;Muted subthread&quot;):</p>
<ol>
<li>Bob wants to send an original post to a mailing list normally.</li>
<li>Bob&#8217;s message hits the mailing list server and is distributed to the subscribers of the mailing list as expected.</li>
<li>Conversation occurs.</li>
<li>Jo sends a message to the mailing list indicating disinterest in a subthread, and the mailing list server obliges by not sending Jo any more messages from that subthread.</li>
</ol>
<p>Here is&nbsp;Mode 5b&nbsp;(&quot;Temporary Mute&quot;):</p>
<ol>
<li>A mailing list has &quot;blown up&quot; and some of its users would rather not see any mail from the list for a period of time (say, a day or a week).</li>
<li>Users respond to any message in the mailing list and state that they want the list totally muted from their perspective for a specific (but arbitrary)&nbsp;duration.</li>
</ol>
<p>Here is Mode 6&nbsp;(&quot;Named Subgroups&quot;):</p>
<ol>
<li>Bob is on a mailing list for a project and has a security issue to discuss.&nbsp; He sends a message with [security] in the subject.</li>
<li>The message is delivered to only people that are in the [security] subgroup; whether the subgroup is open for joining by members of the mailing list or is closed off is up to mailing list server configuration.</li>
<li>Replies are contained within the named subgroup.</li>
</ol>
<p>Here is Mode 7&nbsp;(&quot;Hidden Addresses&quot;):</p>
<ol>
<li>A group of users would like to have a mailing list, but they <em>do not want their addresses shared with other users when they post</em>, for whatever reason.
<ol>
<li><strong>Note</strong> that this can be used to prevent spammers from subscribing to the list, lurking, and harvesting addresses&#8211;very useful today.</li>
</ol>
</li>
<li>The mailing list software takes posts and:
<ol>
<li>Modifies the &quot;From&quot;&nbsp;header of the message to retain the name component, and changes the address component to that of the mailing list.</li>
<li>Replaces the Message-ID&nbsp;header of the message with one generated by the mailing list software for the mailing list itself.</li>
<li>Removes any Received headers.</li>
<li>Removes (but remembers!)&nbsp;any Cc headers that were applied to the incoming message, and honors them until such time as it is told that the Cc should be dropped explicitly, for example by a recipient of the Cc (who sees the Cc line with only their address in it) or a trust list administrator or trusted list helper that can act on the behalf of the Cc recipient&nbsp;(&quot;plz stop sending mailz 2 me k thx&quot;).</li>
</ol>
</li>
</ol>
<h3>Possible Implementation&nbsp;(High Level)&nbsp;Notes</h3>
<p>Now, between these seven distinct modes and their submodes, all the infrastructure that is necessary to expand the mailing list&#8217;s utility are possible to fit nearly any type of usage pattern/use case&#8211;transparently, and without any special requirements on MUA&nbsp;software beyond very simple, basic message receiving/display and sending.&nbsp; At this point, I&#8217;m interested in collecting other use cases that I&nbsp;may not have thought about, but that people already use or would imagine would be useful.&nbsp; The goal, ultimately, is to attempt to come up with a design and specification for a truly transparent mailing list management system that is more flexible than today&#8217;s software, that can have per-user preferences that are centralized and MUA-independent, and have features that can be used in the context of messages sent to the mailing list.</p>
<p>One idea is to use in-band signaling on the mailing list to indicate various things.&nbsp; Unlike list software like majordomo where commands are sent to special mailing addresses, it&#8217;s possible that some things can be done by adopting existing conventions and others can be done by adding special information to the message body itself.&nbsp; For example, Mode 6 is imagined as being part of the already-widely adopted convention that people can filter out based on [tags] in the subject, so an [OT] is used for off-topic, [RFC] for request-for-comments, and so forth.&nbsp; <em>The advantage of adopting conventions and in-band signaling is that it is inherently portable to nearly all MUA&nbsp;software, regardless of age or capability, as long as either References are In-Reply-To are supported.</em></p>
<h3>Additional Modes</h3>
<p>If you know of a workflow or a mode of operation/use case that <strong>would not fit</strong> in with this proposal, state it&nbsp;(I&#8217;m <em>not</em> looking for technical arguments of feasibility right now, just desired modes of operation; a future post and/or wiki page will serve the purpose of overall technical feasibility evalutation).&nbsp; Consider this to be the &quot;research stage&quot;&nbsp;of a system to-be-specified, with potential for becoming an RFC a published Internet standard with the goal of improving life for all of us: non-technical users, technical users, users married to our workflow (or not).&nbsp; <em>The only correct system is one that works for everyone in as flexible manner as is possible.</em></p>
<h2>Centralization</h2>
<p>Many of these use cases (modes)&nbsp;require that mailing lists are a &quot;gateway&quot;&nbsp;for all of the interaction between users unless things are explicitly taken off-list, which of course users are free to do, if desired.&nbsp; Some would seem to believe that if everything is centralized that certain use cases become inherently impossible.&nbsp; While that might have been true given the computing resources that were available in the 1990s, it is not true today, and we shouldn&#8217;t pretend that it is; even a uniprocessor server running with a 266 MHz CPU&nbsp;and 64&nbsp;MB&nbsp;of RAM&nbsp;should be able to run a mail list server implementing these features, serving a moderate number of users and still be fast and responsive.</p>
<p>Sure, lists that are the size of the <a href="http://lkml.org/">LKML</a>&nbsp;would probably want to run the mail list server on one machine and the database server on another, or have a distributed environment where the workload can be handed between mail list servers running for the same list (or family of lists), but if the software is correctly designed and implemented with such a configuration in mind, it would be easy for even very large, very active mailing lists to use a featureful system such as this.&nbsp; For that matter, correctly designed, &quot;centralized&quot;&nbsp;does not have to mean&nbsp;&quot;not highly available&quot;, because here I&nbsp;am talking about the service being centralized for a single list, although it would be possible in theory to have the mailing list run on only donated CPU&nbsp;time from volunteers (that said, DNS&nbsp;already makes this possible when combined with a well-planned and well-executed deployment process, though not terribly easily on the IPv4 Internet).</p>
<p>Others state that a centralized setup would take away their freedom to interact with the mailing list in some way: <em>I am saying that this doesn&#8217;t have to be the case</em>.&nbsp; It may be with the way current mailing lists are implemented, but it doesn&#8217;t have to be that way at all!&nbsp; <em>And</em> it can be done in a way that is intuitive&#8211;or at the very least, makes sense to users and is easy to learn, if not 100% intuitive.</p>
<p>Again, however, the motivation at this point is a high-level conversation that seeks to be gradually refined into lower and lower levels of abstraction until the final product is source code that can be seen and examined.</p>
<h2>Motivation</h2>
<p>Why am I motivated now?&nbsp;&nbsp;Because it is plain as day that a universally applicable solution <em>can</em> be made to exist, and it&#8217;s even clearer that there&#8217;s no reason for it not to.&nbsp; I&nbsp;<em>don&#8217;t</em> expect that this would be an overnight process, but I&nbsp;think that given ample discussion and interest, we can figure out a way to make <em>everyone</em> happy, even those that are way out with the extreme corner cases.&nbsp; After all, there is <em>no</em> reason that systems cannot serve both complete end users <em>and</em> extremely adept technical users seeking to use every available feature.</p>
<p>In short, I&nbsp;think it&#8217;s time for a change in the way we think about what mailing lists are and how they work, and I&nbsp;think that it&#8217;s time that we consider how to make them useful and transparent to us, all of us, regardless of technical knowledge or background, regardless of the end user&#8217;s stringent desire to follow RFCs, and without having to be concerned about everything the system can do (while knowing that if you want to learn about all of the features and use them all, you certainly could).&nbsp; I think it&#8217;s time to drop the assumptions that we&#8217;ve made for the last several decades with regards to mailing lists and redefine them.</p>
<p>So, who is interested?</p>
]]></content:encoded>
			<wfw:commentRss>http://mike.trausch.us/blog/2009/10/14/on-mailing-list-management-software-part-1/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>And the Douchebag Award goes to&#8230;</title>
		<link>http://mike.trausch.us/blog/2009/09/24/and-the-douchebag-award-goes-to/</link>
		<comments>http://mike.trausch.us/blog/2009/09/24/and-the-douchebag-award-goes-to/#comments</comments>
		<pubDate>Thu, 24 Sep 2009 21:27:02 +0000</pubDate>
		<dc:creator>Michael Trausch</dc:creator>
				<category><![CDATA[FLOSS]]></category>
		<category><![CDATA[GNU/Linux]]></category>
		<category><![CDATA[Rant]]></category>
		<category><![CDATA[computing]]></category>
		<category><![CDATA[freedom]]></category>
		<category><![CDATA[wtf‽]]></category>
		<category><![CDATA[c#]]></category>
		<category><![CDATA[free software]]></category>
		<category><![CDATA[FUD]]></category>
		<category><![CDATA[software]]></category>

		<guid isPermaLink="false">http://mike.trausch.us/blog/?p=566</guid>
		<description><![CDATA[Richard Stallman. That&#8217;s right.&#160; Now, there are many things that the man has done that have been effective, and the man has worked hard to ensure that we have freedom in the vast world of software.&#160; But recently, he has stated that Miguel de Icaza &#8220;is basically a traitor to the free software community,&#8221; and [...]]]></description>
			<content:encoded><![CDATA[<p><strong>Richard Stallman</strong>.</p>
<p>That&#8217;s right.&nbsp; Now, there are many things that the man has done that have been effective, and the man has worked hard to ensure that we have freedom in the vast world of software.&nbsp; But recently, he has stated that Miguel de Icaza &ldquo;is basically a traitor to the free software community,&rdquo; and no matter <em>how</em> much good a person has done, I&nbsp;cannot stand by such a fallacious statement.</p>
<p>What is freedom, people?&nbsp; The two cornerstones of freedom are <em>education</em> and <em>choice</em>.&nbsp; A person who is uneducated cannot choose, and so one depends on the other.&nbsp; Some people will choose to use either free software or proprietary software exclusively, and others will mix the two together, with varying priorities that they place on their choices.&nbsp; As long as people are aware of what&#8217;s out there and can determine what is best for the way they use their own systems, <em>freedom is available</em>.&nbsp; Yes, that means some people may choose to run Windows.&nbsp; Many will not, and if one makes a conscious choice, that is for them to do for themselves.&nbsp; My concern is that people need to know about the choices in order to make a choice to begin with.</p>
<p>Now, de Icaza has done a <strong><em><u>great deal of work for the open source community</u></em></strong>.&nbsp; He&#8217;s one of the key people who has been behind Midnight Commander and GNOME.&nbsp; And of course, Mono.&nbsp; He has given us a great deal of good quality, free software that many people can choose to use, and he has given the ability to use a VM-based runtime environment that previously was not cross-platform, as well, on nearly any platform that can be chosen.&nbsp; The GNU&nbsp;people are even working on a similar one.&nbsp; But this is not the reason that de Icaza is supposedly a traitor to the community.&nbsp; The reason?&nbsp;&nbsp;de Icaza is helping Microsoft out with their new &ldquo;Open Source Labs&rdquo;.</p>
<p>Guess what, Mr. Stallman?&nbsp;&nbsp;The fact that Microsoft is starting to enter the world of free software <em>cannot</em> be considered to be a bad thing.&nbsp; You did a great deal of work to ensure that free software that is adequately licensed can stay that way, and the turn the copyright system around on those who have sought out to corrupt it.&nbsp; You have put free software on the radar around the world.&nbsp; You have done a great many things that others would not have the heart, nor the motivation, to carry out.&nbsp; It would appear, however, your time is up:&nbsp; the world can and will move on without you, and I declare that it is time for you to go away.&nbsp; When you start attacking people in the very world that you helped to create, you become obsolete and no longer serve your purpose.&nbsp; I&nbsp;dub St. Ignucius of the Church of Emacs to be a heathen who has forgotten his message, forgotten his values, and is now a harmful creature; hardly a saint, more like a devil.&nbsp; Overtaken with fits of arrogance.&nbsp; Lately, you have caused a great deal of infighting within the community.&nbsp; As I&nbsp;am sure you are well aware, infighting serves very little useful purpose but to tear apart communities.&nbsp; And now you make a bold, arrogant, and false statement that serves only that purpose, but to an extent the likes of which we have never seen from you.</p>
<p>I&nbsp;say that we shun him&mdash;and his kind. Things are starting&mdash;albeit slowly&mdash;to come around to the way we want them, and he would prefer to attack it.&nbsp; Why?&nbsp;&nbsp;What logical reason is there to do so?&nbsp;&nbsp;Because he&#8217;s not the controller of it?&nbsp; Because it grew to be something that even companies that he helped cultivate an irrational, religious-like hatred of, are beginning to see is useful (not only to them, but to all of us)?&nbsp; What is his new goal, that all software should be GPL&#8217;d and if it isn&#8217;t it is evil?&nbsp; We should not tolerate these sorts of counterproductive behaviors.&nbsp; Stallman has reduced himself to a Schestowitz, a creature who deserves no respect.&nbsp; A troll.&nbsp; I&nbsp;suppose in his old age, he has decided that attention is more important than our freedoms.</p>
<p>Richard Matthew Stallman, you are no longer relevant to our community, our world, the world of people who truly believe in and advocate for freedom, that of choice and that of the rights to study, improve, and distribute software.&nbsp; Thank you for your services, for they were needed to get us where we are today.&nbsp; However, you have chosen to do us no further good, only ill.&nbsp; And for that, I say damn you.&nbsp; Leave the Free Software Foundation and permit it to continue to work for freedom, or take it down and let the GNU&nbsp;project carry on to produce software without all of the utter crap that you have begun to spew of late. &nbsp;I&nbsp;have no problem with the GNU&nbsp;project.&nbsp; I&nbsp;love the GNU&nbsp;project.&nbsp; And I&nbsp;am grateful for the work that you, independently and through the Free&nbsp;Software Foundation, have done so that we can enjoy the freedom to choose a free software system to do our work and our play.&nbsp; But you are no longer helping; you have become a bully, an old troll.&nbsp; You do not help free software any more.&nbsp; Your recent action is a great offense to free software, and very much condemning a road which will lead to more free software.&nbsp; Go away, troll.</p>
<p>Long live freedom&mdash;true freedom&mdash;and free software.&nbsp; And thank you, Miguel de Icaza, for all of the great software that you have given us, as well, for your continued work to make software more useful and portable.&nbsp; May you never wind up irrelevant and petty as Stallman has wound up being.</p>
]]></content:encoded>
			<wfw:commentRss>http://mike.trausch.us/blog/2009/09/24/and-the-douchebag-award-goes-to/feed/</wfw:commentRss>
		<slash:comments>8</slash:comments>
		</item>
		<item>
		<title>On communicating with software authors</title>
		<link>http://mike.trausch.us/blog/2009/09/09/on-communicating-with-software-authors/</link>
		<comments>http://mike.trausch.us/blog/2009/09/09/on-communicating-with-software-authors/#comments</comments>
		<pubDate>Thu, 10 Sep 2009 02:09:11 +0000</pubDate>
		<dc:creator>Michael Trausch</dc:creator>
				<category><![CDATA[AllTray]]></category>
		<category><![CDATA[FLOSS]]></category>
		<category><![CDATA[Personal]]></category>
		<category><![CDATA[computing]]></category>
		<category><![CDATA[life]]></category>
		<category><![CDATA[programming]]></category>
		<category><![CDATA[random thoughts]]></category>
		<category><![CDATA[tips & tricks]]></category>
		<category><![CDATA[software]]></category>

		<guid isPermaLink="false">http://mike.trausch.us/blog/?p=559</guid>
		<description><![CDATA[AllTray is a rather small project&#8212;for the moment, there is a single developer working on it (myself), and there aren&#8217;t a terribly great number of users, though the users that it does have are most excellent.&#160; For a long time, the users didn&#8217;t have the ability to observe the development processes for AllTray, nor did [...]]]></description>
			<content:encoded><![CDATA[<p>AllTray is a rather small project&mdash;for the moment, there is a single developer working on it (myself), and there aren&#8217;t a terribly great number of users, though the users that it does have are most excellent.&nbsp; For a long time, the users didn&#8217;t have the ability to observe the development processes for AllTray, nor did they have a bug tracker or any point of contact to the author/maintainer other than email.&nbsp; Things have gotten better there, since AllTray development takes place in the open on Launchpad (though I&nbsp;do have to get better about publishing feature branches that last longer than a day or two so that people can see them as well while they are in progress).</p>
<p>Many projects that are all about being open and transparent provide mechanisms for their users to get in touch with the developers.&nbsp; Launchpad has become an excellent place to do these things; Launchpad&#8217;s Answers and Bugs components are <em>truly excellent</em> ways to get in touch with people that manage software there.&nbsp; The system is so good that I&#8217;d advocate that every project try to move to it.&nbsp; Launchpad <em>does</em> have its issues, though they are often quickly fixed (and can be fixed even quicker now that it is free software).&nbsp; But between Bazaar (a truly amazing and flexible distributed version control system) for code hosting and the other components of Launchpad such as the Answers, Bugs, and Translations components, Launchpad provides virtually everything that a project needs to communicate effectively with its users aside from the project&#8217;s Web site.&nbsp; And users seem to naturally be able to reach out using it.</p>
<p>In the nearly one year that I&#8217;ve been working with AllTray, I&#8217;ve talked&mdash;well, written to&mdash;several people who have asked questions and acted in their own ways to work to improve the software.&nbsp; Development on AllTray has been made much easier just because people are willing to speak up.&nbsp; Everything from the random &ldquo;thank you&rdquo; to &ldquo;hey, are you going to do this?&rdquo; or &ldquo;I&#8217;d like to see feature <em>x</em> in the new version&rdquo; or whatever.&nbsp; It&#8217;s truly great.&nbsp; I can&#8217;t say that every project has users quite like AllTray&#8217;s, because AllTray is something of a niche application, but AllTray&#8217;s users are a great model for other projects.&nbsp; There has been virtually no negativity from users and everything has been constructive.</p>
<p>To anyone who manages a project that <em>doesn&#8217;t</em> use Launchpad, I&#8217;d <strong>strongly</strong> encourage them to do so.&nbsp; Its users are great, and as far as management of the overall project goes, it&#8217;s <em>very</em> easy for project people to communicate back and manage communications in a single spot.&nbsp; It&#8217;s also great that users can ask a question and that the project can do things like go, &ldquo;oh, hey, this is really a bug,&rdquo; or vice versa with bugs&rarr;questions.&nbsp; And if you don&#8217;t use Launchpad because you don&#8217;t want to use Bazaar&nbsp;(I&nbsp;hear that users of git are pretty dedicated to it; I&nbsp;can understand that, but it&#8217;s just not for me&mdash;it&#8217;s too complex, and I&nbsp;like that Bazaar just stays out of my way), consider using LP&nbsp;for everything <em>but</em> code hosting.&nbsp; Or consider using Launchpad&#8217;s code hosting to mirror your project from git, it does this quite nicely.&nbsp; Or, find some way to do what Launchpad does wherever you do project management.&nbsp; It works really well, and it&#8217;s a big help.</p>
<p>And to AllTray&#8217;s users. A big <span style="font-size: x-large;">Thank You</span>.&nbsp; You guys and gals are great.&nbsp; Keep communicating!</p>
]]></content:encoded>
			<wfw:commentRss>http://mike.trausch.us/blog/2009/09/09/on-communicating-with-software-authors/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>Education is the road to freedom&#8230; but only sometimes</title>
		<link>http://mike.trausch.us/blog/2009/08/26/education-is-the-road-to-freedom-but-only-sometimes/</link>
		<comments>http://mike.trausch.us/blog/2009/08/26/education-is-the-road-to-freedom-but-only-sometimes/#comments</comments>
		<pubDate>Wed, 26 Aug 2009 21:17:03 +0000</pubDate>
		<dc:creator>Michael Trausch</dc:creator>
				<category><![CDATA[FLOSS]]></category>
		<category><![CDATA[Rant]]></category>
		<category><![CDATA[Your Rights]]></category>
		<category><![CDATA[computing]]></category>
		<category><![CDATA[freedom]]></category>
		<category><![CDATA[counterproductive]]></category>
		<category><![CDATA[free software]]></category>
		<category><![CDATA[fsf]]></category>
		<category><![CDATA[gnu]]></category>
		<category><![CDATA[microsoft]]></category>
		<category><![CDATA[UNIX]]></category>
		<category><![CDATA[windows]]></category>
		<category><![CDATA[windows7sins]]></category>

		<guid isPermaLink="false">http://mike.trausch.us/blog/?p=550</guid>
		<description><![CDATA[Windows 7 Sins.  It is the name of a campaign and Web site launched by the Free Software Foundation in a misguided (IMHO) attempt to publicize some of the issues in software choice.  Right from the start and without reading a word on the Web site, it says two things very strongly: Windows 7 commits [...]]]></description>
			<content:encoded><![CDATA[<p><em>Windows 7 Sins</em>.  It is the name of a campaign and Web site launched by the <a href="http://www.fsf.org/">Free Software Foundation</a> in a misguided (IMHO) attempt to publicize some of the issues in software choice.  Right from the start and without reading a word on the Web site, it says two things very strongly:</p>
<ol>
<li>Windows 7 commits <em>sins</em>.</li>
<li>Windows 7 users are <em>sinners</em>.</li>
</ol>
<p>The site provides a decent amount of information.  But I would imagine that a good portion of its potential readers that are linked to the site will stop reading at the domain name, <em>windows7sins.org</em>, just for the two very clear things it says.  Okay, so we have a very strong tie to science, but does that mean that we should alienate people from the start?  I do not think so.  If you are curious, the alleged “sins” are: poisoning education, invading privacy, monopoly behavior, lock-in, abusing standards, enforcing DRM, and threatening user security.</p>
<p>So, we can hold those points as true: Microsoft has done all of these things, and many more, which make supporting it as an organization something that some of us would shudder to think of, and that many more of us simply would not do if given the choice.  And <em>that</em> is the real key to freedom, is it not?  That we should give out the information in a way so as to reach the widest possible audience, that is.  <em>Not</em> that we use emotional manipulation to compel the audience to switch because then all we are doing is forcing them to feel they need to change.  Instead, users should change (or try) when they are ready—not before they are ready, and not because you offended them and made them feel dirty.  That is exactly the same tactic Microsoft uses on its customers in order to convince them of various things like “you get what you pay for,” or “if you did not pay for the software, it is pirated, it’s not legitimate,” or that free software is a form of “malware,” and so forth.  Why should we stoop down to <em><strong>their</strong></em> level?</p>
<p>Wait, am I saying that it is okay if users choose to use Windows?  Yes, I am.  But if Windows is the only thing that you are aware of, and it is all that you know (and believe me, there are still <em>many</em> such people out there) then it is naturally going to be what you are using.  So they&#8217;re a “sinner” by default, and that is offensive.  The only thing that they are guilty of is ignorance, and ignorance has a very simple fix: deliver information, let them learn of these things, and then there is no more ignorance.  For many, it is not even <em>intentional</em> ignorance.  They simply do not know.</p>
<p>I think that this campaign would have been a good thing if it did not seek to offend to make its point.  That&#8217;s resorting to a very below-the-belt tactic, and it makes the Free Software Foundation (in this case) come out looking no better than Microsoft itself which is unfortunate.  They have done the wrong thing, for the right reason, and it is constructed to make very little go their way.</p>
<p>So, do not refer users to the Windows 7 Sins Web site when attempting to convince them that they should not choose to upgrade to Windows 7 (or are already running it in one of its pre-release forms).  Instead, offer them information.  Explain things to them, and if they aren’t ready to try something else, whatever.  If they want to try something else, and they wind up going back to running Windows for one reason or another, then by all means, let them.  Of course, find out why they did, first, and maybe you can fix something that will eliminate a problem for others, too.</p>
<p>That is freedom.  It’s not free and it’s not easy.  But just remember that users have the freedom to choose, and that is a bigger freedom than what some of them will ever see or understand in free software.  And if they choose to use something we don’t like, that&#8217;s <em>fine</em>; it is, after all, their choice.  Who cares if it is not the choice that you would make?</p>
]]></content:encoded>
			<wfw:commentRss>http://mike.trausch.us/blog/2009/08/26/education-is-the-road-to-freedom-but-only-sometimes/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>The Mono war is over and we have won, thanks to Microsoft.</title>
		<link>http://mike.trausch.us/blog/2009/07/06/the-mono-war-is-over-and-we-have-won-thanks-to-microsoft/</link>
		<comments>http://mike.trausch.us/blog/2009/07/06/the-mono-war-is-over-and-we-have-won-thanks-to-microsoft/#comments</comments>
		<pubDate>Mon, 06 Jul 2009 23:18:58 +0000</pubDate>
		<dc:creator>Michael Trausch</dc:creator>
				<category><![CDATA[FLOSS]]></category>
		<category><![CDATA[computing]]></category>
		<category><![CDATA[cool stuff]]></category>
		<category><![CDATA[freedom]]></category>
		<category><![CDATA[programming]]></category>
		<category><![CDATA[wtf‽]]></category>
		<category><![CDATA[c#]]></category>
		<category><![CDATA[FUD]]></category>
		<category><![CDATA[microsoft]]></category>
		<category><![CDATA[mono]]></category>
		<category><![CDATA[software]]></category>
		<category><![CDATA[Ubuntu]]></category>
		<category><![CDATA[UNIX]]></category>

		<guid isPermaLink="false">http://mike.trausch.us/blog/?p=543</guid>
		<description><![CDATA[Yeah, alright.  Those are words I would never have thought I&#8217;d see in a title in a blog post, “thanks to Microsoft.”  But, it is true.  Microsoft is adding C# and the CLI to the list of technologies that it promises it will not sue for.  This is Microsoft&#8217;s “Community Promise”, which means that to [...]]]></description>
			<content:encoded><![CDATA[<p>Yeah, alright.  Those are words I would never have thought I&#8217;d see in a title in a blog post, “thanks to Microsoft.”  But, it is true.  <a href="http://port25.technet.com/archive/2009/07/06/the-ecma-c-and-cli-standards.aspx">Microsoft is adding C# and the CLI to the list of technologies that it promises it will not sue for</a>.  This is Microsoft&#8217;s “Community Promise”, which means that to all of you who claimed that patents were a problem for Mono, if you were not wrong before, you are <em>absolutely, categorically, totally, utterly</em> wrong now.</p>
<p>One of the very few times I have uttered this phrase, but it works now:  <strong>Thanks, Microsoft</strong>.</p>
]]></content:encoded>
			<wfw:commentRss>http://mike.trausch.us/blog/2009/07/06/the-mono-war-is-over-and-we-have-won-thanks-to-microsoft/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>On Replacing AllTray &amp; Other Docking Software</title>
		<link>http://mike.trausch.us/blog/2008/10/21/on-replacing-alltray-other-docking-software/</link>
		<comments>http://mike.trausch.us/blog/2008/10/21/on-replacing-alltray-other-docking-software/#comments</comments>
		<pubDate>Tue, 21 Oct 2008 19:27:26 +0000</pubDate>
		<dc:creator>Michael Trausch</dc:creator>
				<category><![CDATA[FLOSS]]></category>
		<category><![CDATA[GNU/Linux]]></category>
		<category><![CDATA[GPLv3]]></category>
		<category><![CDATA[UNIX]]></category>
		<category><![CDATA[Ubuntu]]></category>
		<category><![CDATA[computing]]></category>
		<category><![CDATA[gnome]]></category>
		<category><![CDATA[AllTray]]></category>
		<category><![CDATA[programming]]></category>
		<category><![CDATA[software]]></category>

		<guid isPermaLink="false">http://www.trausch.us/?p=432</guid>
		<description><![CDATA[This post is a bit of a “brain dump” of sorts for some thoughts that I have as to replacing AllTray with a more versatile, powerful, and robust tool to handle various needs of users when it comes to taking applications and docking them to the system tray. Why? I&#8217;ve used AllTray for a long [...]]]></description>
			<content:encoded><![CDATA[<p>This post is a bit of a “brain dump” of sorts for some thoughts that I have as to replacing AllTray with a more versatile, powerful, and robust tool to handle various needs of users when it comes to taking applications and docking them to the system tray.</p>
<h3>Why?</h3>
<p>I&#8217;ve used AllTray for a long time.  It is one of those pieces of software that performs a useful function, but you have to know its quirks to make it do what you want quite often, and you have to work around some of the things that it does for it to retain that usefulness.  Users shouldn&#8217;t have to do that—they should just be able to start using a program or utility and have it work properly.  Also, utilities should be (reasonably) independent of the environment that they run within, which AllTray isn&#8217;t.  And, good utilities should integrate with the system pretty well, which AllTray does not, since it carries a hard dependency on GDK/GTK.  (Kdocker is an alternative piece of software, and while I don&#8217;t know how well it works compared to AllTray, I know that it is bound to Qt, which is just as bad.)</p>
<p>The license will most likely be GPLv3, since nothing will actually link to it and it&#8217;s not a library.  If there is a library component, it will be LGPLv3.</p>
<h3>The actual &#8220;braindump&#8221;</h3>
<p>The actual *docking* part isn&#8217;t terribly hard, it would seem.  With GTK+ it can be done in only a few lines of code (especially in C#).  However, C# wouldn&#8217;t be the language to use for the this tool, because of the dependency on Mono.  My thinking is that the proper language to use would be C itself.  It makes me think of how easy everything would be if only the desktop environment and all its software were already written in managed code&#8230; the effective cost of using C# would be significantly less than it is already.</p>
<p>Using C as the language isn&#8217;t that big a deal to me.  What <em>is</em> a big deal to me is that the application be well-integrated and well-behaved.  For example, AllTray depends on GTK for some of its tasks, and uses a custom (ugly, IMHO) widget for displaying its title when you over over it in the system tray.  There&#8217;s another program out there, KDocker, that would appear to be slightly more featureful than AllTray, but it carries with it a dependency on Qt, which I don&#8217;t like.  Ideally, the core for such a docking utility should be able to have various back-ends that serve the purpose of integration with the system, with a single back-end that would apply without dependencies on anything else for the rare scenario where neither GTK+ nor Qt are available.</p>
<p>What would this thing be required to do?</p>
<ul>
<li>Dock any arbitrary application to the system tray, not just a single window from the application. (Using the <a href="http://standards.freedesktop.org/systemtray-spec/systemtray-spec-latest.html" title="System Tray Protocol Specification">System Tray Protocol Specification</a>)</li>
<li>Run in a single instance, managing multiple applications within that instance if necessary.</li>
<li>Provide <a href="http://en.wikipedia.org/wiki/Session_management" title="Wikipedia: Session management">session management</a> for those who use it, and act as a session manager for applications that are run underneath it that support session management.</li>
<li>Be able to use something like <code>inotify</code> to be able to show an indication of when the application&#8217;s title for its windows change.</li>
<li>Use a single icon for the application, with a window list if the application carries more than a single window.</li>
<li>Use individual backends which provide a native look and feel depending on the desktop environment currently in use.</li>
<li>Use the application’s icon to represent the application in the system tray.</li>
<li>Support blinking the icon when the application decides to do something like present a modal dialog box or something (if this is even possible, that much I am not quite sure of).</li>
<li>Detect the desktop environment currently in use and (if possible) load a backend to integrate with it.</li>
<li>Carry a dependency on <a href="http://en.wikipedia.org/wiki/GLib" title="Wikipedia: GLib">GLib</a> so as to make implementing it quicker and less error-prone.</li>
<li>NOT carry any hard dependencies on any widget libraries like <a href="http://en.wikipedia.org/wiki/GTK+" title="Wikipedia: GTK+">GTK+</a> or <a href="http://en.wikipedia.org/wiki/Qt_(toolkit)" title="Wikipedia: Qt (toolkit)">Qt</a>.</li>
<li>Return an error to the user if there is no running system tray, and there isn&#8217;t one after some sort of timeout (say, when starting the desktop environment, there may not be a system tray right away).  (I don&#8217;t think that sort of situation would be commonplace, but it&#8217;s not really the job of this program to create a system tray if one doesn&#8217;t exist, since this is the job of the desktop environment.)</li>
</ul>
<p>The backends would not have any specific configuration items (the entire configuration would be housed somewhere like <code>${HOME}/.config/docker</code>, for example).  There probably ought to be a backend entrypoint that would show a dialog for configuration, but I haven&#8217;t really figured out if that&#8217;d be the case yet.  The docker should probably do all of its configuration by way of the command line for each invocation, which is suitable for use as a desktop shortcut or panel launcher.</p>
<p>This approach requires that each individual desktop environment have its own backend, which might become a bit of a pain for supporting a great number of desktop environments, but the upshot of that is that the application then feels native no matter what environment the user is using.  Obviously support for GNOME and KDE would happen, and most everything else would depend on someone with programming experience for various environments to implement a backend for it.</p>
<p>The backend doesn&#8217;t handle, say, docking, since there&#8217;s a standard for that already.  It would handle things like displaying the tip when hovered over or displaying a menu when right-clicked.  So, the job that each backend would do would be pretty lightweight.  And as much as possible should be handled in the core, with the backend consisting of just enough &#8220;hooks&#8221; into the target system to be able to provide a useful interface.</p>
<p>The way that this would have to work, using C as the programming language, would be that the core would have to use <code>dlopen()</code> and friends to load the backend and then use the entrypoints that the backend provides.  Since <code>dlopen</code>, <code>dlclose</code>, <code>dlsym</code>, and <code>dlerror</code> are defined by POSIX.1-2001, support for those should be in every reasonably modern Unix-like system that supports at least a subset of POSIX.  This of course eliminates Windows, but I am not terribly worried about that since there are probably other Windows-only utilities that serve this purpose.</p>
<p>The primary goal, then, is to replace other DE-dependent and toolkit-dependent dockers with a utility that carries the goal to be universally useful and highly robust.  The aim of this goal is to replace AllTray entirely in (at the very least) Ubuntu, and hopefully be seen as useful in other distributions as well.</p>
<h3>I&#8217;ll need some help&#8230;</h3>
<p>This is the part where it&#8217;ll get interesting.  I&#8217;ll need some help in actually doing this, in many areas.</p>
<p>For the moment, where I&#8217;ll need help (be that from Google, or from people in-the-know that happen upon this post) is to find all of the documentation that I&#8217;ll need to understand how to implement the software.  I can use software that already exists to try to learn how the underlying system works, to a degree anyway.  But some of the software doesn&#8217;t handle various situations correctly (or I don&#8217;t have a way to see if it does) and so studying them would be less than useful for everything I am trying to do.  Namely, the things I need to find out yet are:</p>
<ul>
<li>How to run a program in such a way as to be able to reliably know what windows belong to the program and be able to dock them.  I <strong>suspect</strong> that it&#8217;d involve using <code>LD_PRELOAD</code> and some monitoring trickery, but I would hope that there is some sort of API to do this already.  Also, need to know how to manage the application itself; say it continues running but without any windows, the tray icon should obviously disappear while it&#8217;s running like that, until it has windows to manage again.</li>
<li>How to perform session management and be a session manager for subordinate programs.  (I might be able to study the source for KDocker to learn the answer to that, though I am not 100% certain yet of that.)  I also have a paper to read yet on the subject that may have all the information that I am looking for, though I am not certain there yet, either.</li>
<li>How to reliably detect the running desktop environment without resorting to ugly kludges and ad-hoc trickery.</li>
<li>How to work independent of the currently-running window manager and operate reliably for any standards-compliant WM that is running, without having to special-case for various types of software or various types of window managers.</li>
</ul>
<p>I suspect that there is useful documentation out there for most (if not all) of those things for X11 and other relevant points.  I just haven&#8217;t found what I am looking for yet for all of it.  Standards documents and system documentation are useful things to find, and maybe an example or two of source code on how to do it as well, are what I am looking for, so that I can try to understand these things better.</p>
<p>At some point down the road, I&#8217;ll need help with getting the backends written when they have an API to conform to.  I can, in all probability, write a GTK+ backend that will work for XFCE and GNOME since I use GNOME.  However, I don&#8217;t use KDE or anything that runs on top of Qt, so I will definitely need help from someone that is familiar with writing software for Qt to get a Qt backend written.  If XFCE has any sort of non-standard special UI guidelines that are incompatible with GNOME, then I&#8217;ll need some help there, too.  Any other non-GNOME or non-KDE environments (such as <a href="http://en.wikipedia.org/wiki/GNUstep" title="Wikipedia: GNUstep">GNUstep</a>, if it supports it anyway) that support the <a href="http://standards.freedesktop.org/systemtray-spec/systemtray-spec-latest.html" title="System Tray Protocol Specification">System Tray Protocol Specification</a> will need backends written for them by people that are able to do so.</p>
]]></content:encoded>
			<wfw:commentRss>http://mike.trausch.us/blog/2008/10/21/on-replacing-alltray-other-docking-software/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>I think I read about this recently: Video Surveillance Tech Detects Abnormal Activity</title>
		<link>http://mike.trausch.us/blog/2008/07/29/i-think-i-read-about-this-recently-video-surveillance-tech-detects-abnormal-activity/</link>
		<comments>http://mike.trausch.us/blog/2008/07/29/i-think-i-read-about-this-recently-video-surveillance-tech-detects-abnormal-activity/#comments</comments>
		<pubDate>Tue, 29 Jul 2008 19:22:59 +0000</pubDate>
		<dc:creator>Michael Trausch</dc:creator>
				<category><![CDATA[FLOSS]]></category>
		<category><![CDATA[Stuff I Read]]></category>
		<category><![CDATA[The Treacherous USA]]></category>
		<category><![CDATA[Your Rights]]></category>
		<category><![CDATA[computing]]></category>
		<category><![CDATA[freedom]]></category>
		<category><![CDATA[wtf‽]]></category>
		<category><![CDATA[“security”]]></category>

		<guid isPermaLink="false">http://www.trausch.us/?p=355</guid>
		<description><![CDATA[Slashdot &#124; Video Surveillance Tech Detects Abnormal Activity Yup, I did. It was Little Brother. Haven&#8217;t read it yet? Go, read it, I&#8217;m not kidding.]]></description>
			<content:encoded><![CDATA[<p><a href="http://yro.slashdot.org/article.pl?sid=08/07/29/0314208">Slashdot | Video Surveillance Tech Detects Abnormal Activity</a></p>
<p>Yup, I did.  It was <a href="http://craphound.com/littlebrother/download/">Little Brother</a>.  Haven&#8217;t read it yet?  Go, <a href="http://craphound.com/littlebrother/download/">read it, I&#8217;m not kidding.</a></p>
]]></content:encoded>
			<wfw:commentRss>http://mike.trausch.us/blog/2008/07/29/i-think-i-read-about-this-recently-video-surveillance-tech-detects-abnormal-activity/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>On copyright and copying/sharing software&#8230;</title>
		<link>http://mike.trausch.us/blog/2008/07/24/on-copyright-and-copyingsharing-software/</link>
		<comments>http://mike.trausch.us/blog/2008/07/24/on-copyright-and-copyingsharing-software/#comments</comments>
		<pubDate>Thu, 24 Jul 2008 13:45:57 +0000</pubDate>
		<dc:creator>Michael Trausch</dc:creator>
				<category><![CDATA[FLOSS]]></category>
		<category><![CDATA[GNU/Linux]]></category>
		<category><![CDATA[Stuff I Read]]></category>
		<category><![CDATA[The Internet]]></category>
		<category><![CDATA[The Treacherous USA]]></category>
		<category><![CDATA[Ubuntu]]></category>
		<category><![CDATA[Uncategorized]]></category>
		<category><![CDATA[Your Rights]]></category>
		<category><![CDATA[computing]]></category>
		<category><![CDATA[freedom]]></category>
		<category><![CDATA[strange]]></category>
		<category><![CDATA[wtf‽]]></category>
		<category><![CDATA[“security”]]></category>
		<category><![CDATA[bsa]]></category>
		<category><![CDATA[copying]]></category>
		<category><![CDATA[microsoft]]></category>
		<category><![CDATA[sharing]]></category>
		<category><![CDATA[software]]></category>

		<guid isPermaLink="false">http://www.trausch.us/?p=346</guid>
		<description><![CDATA[An article over at “Works With U” has an interesting thing that I have run into a few times before: And here’s another ironic twist: Consumers may actually prefer to pay for Ubuntu — rather than get it for free. No joke: Many consumers don’t like free software. They fear it. My brother in law [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://www.workswithu.com/2008/07/09/best-buy-selling-ubuntu-now-the-bad-news/">An article over at “Works With U”</a> has an interesting thing that I have run into a few times before:</p>
<blockquote><p>And here’s another ironic twist: Consumers may actually prefer to pay for Ubuntu — rather than get it for free. No joke: Many consumers don’t like free software. They fear it. My brother in law didn’t understand how Ubuntu and OpenOffice could be free. “Is it legal to actually download and share that software?” he wondered.</p></blockquote>
<p>I understand how some people can feel like it may not be legal to acquire software that is free, I suppose.  Microsoft and the BSA have pretty well attempted to drill the thought into people&#8217;s minds that software acquired without a financial cost can be somehow illegitimate, implying that it&#8217;s simply not possible for the Internet&#8217;s citizens to create software that is of any measurable quality.  Of course, anyone that is “in the know” is quite aware of just how wrong this idea is; the quality of Microsoft&#8217;s own software is somewhat debatable.</p>
<p>The simple truth is that people just like you can learn to write software, and write high-quality software if motivated to do so.  A large portion of free/open-source software is worked on by people such as yourself.  Things ranging from the actual programming, to bug management, to documentation—all of those things can be done by regular, everyday people.  There&#8217;s nothing—other than Microsoft&#8217;s business strategy—that says that the work that you or I do on a free or open-source software project is automatically of any sort of lower quality when compared to Microsoft&#8217;s software.  In fact, the major argument <em>for</em> such software is its transparency.  I know that when it comes to <em>any</em> software, I often want to change it to fit me better than the original programmer or company provided for.  For software such as Windows, or Internet Explorer, or Microsoft Office, or any other proprietary software offering, this is impossible without violating some sort of license agreement.  Now, that having been said, there is the belief that copyright law permits some “tinkering” of something which one has the right to use.  I suppose this make sense—nobody would dare invoke copyright law to declare that the notes you&#8217;ve written in the margin of your textbook are illegal.  Effectively, writing notes in the margin of a textbook or highlighting passages is “patching” the textbook to contain more information and do more things for you the next time you read it.  So, why should it be illegal for a Windows user to write (or run) software to bypass the silly restrictions on theming in modern versions of Windows?  It&#8217;s essentially the same thing.</p>
<p>The fact that Microsoft, the BSA, and other companies and organizations are so successful in drilling this “thou shalt pay for thy software” commandment into people&#8217;s brains is somewhat terrifying to me.  It means that people in general are still easily had; they think that a corporation that makes billions in revenue every year is somehow more legitimate than the loosely-knit ecosystem of free/open-source software programmers.  Of course, we can confirm that idea by simply looking at the U.S. Government, as well; people are inclined to trust it to provide the freedoms that we&#8217;re supposed to have, while all the while taking those freedoms away in the name of “national security”.</p>
<p>The point?  <em>Think</em> before accepting what corporations and alliances such as the BSA quote as gospel truth.  Yes, it is illegal to copy and redistribute <em><strong>Microsoft</strong></em> software without a grant of permission from Microsoft to do so.  That restriction does not hold true for <strong>all</strong> software, though; you can freely copy and redistribute the Linux kernel, the Firefox Web browser, the OpenOffice.org suite of office software,˙and so many more, worthwhile pieces of software—including the entire Ubuntu operating system distribution discs.  (In fact, they even say “Pass it on!” on the official media!)  There is a lot of value to a system that can be modified on the fly to fit the needs of its user&#8230; and this is something that corporations and “copyright advocates” will seemingly never understand.</p>
]]></content:encoded>
			<wfw:commentRss>http://mike.trausch.us/blog/2008/07/24/on-copyright-and-copyingsharing-software/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>On ExtJS and GPL</title>
		<link>http://mike.trausch.us/blog/2008/05/14/on-extjs-and-gpl/</link>
		<comments>http://mike.trausch.us/blog/2008/05/14/on-extjs-and-gpl/#comments</comments>
		<pubDate>Wed, 14 May 2008 19:15:53 +0000</pubDate>
		<dc:creator>Michael Trausch</dc:creator>
				<category><![CDATA[FLOSS]]></category>
		<category><![CDATA[GPLv3]]></category>
		<category><![CDATA[Stuff I Read]]></category>
		<category><![CDATA[computing]]></category>
		<category><![CDATA[freedom]]></category>
		<category><![CDATA[law]]></category>
		<category><![CDATA[programming]]></category>
		<category><![CDATA[ExtJS]]></category>
		<category><![CDATA[FUD]]></category>
		<category><![CDATA[PHP]]></category>
		<category><![CDATA[software licensing]]></category>
		<category><![CDATA[Web programming]]></category>

		<guid isPermaLink="false">http://www.trausch.us/2008/05/14/on-extjs-and-gpl/</guid>
		<description><![CDATA[Here is an interesting short article on ExtJS and the GNU GPL. First off, if you are a developer (open source, closed source, doesn&#8217;t matter), you need to know the area of licensing. You should actually have read, studied, and understood at least the most popular licenses out there, so that you know what you [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://pooteeweet.org/blog/1084">Here is an interesting short article</a> on ExtJS and the GNU GPL.</p>
<p>First off, if you are a developer (open source, closed source, doesn&#8217;t matter), you need to know the area of licensing.  You should actually have read, studied, and understood at least the most popular licenses out there, so that you know what you can (and cannot) do when you link with code that uses those licenses.</p>
<p>Secondly, <em>JavaScript code runs on the client, not the server, and cannot link to the server&#8217;s code</em>.  This also means that a JavaScript framework can be licensed under the GPL, and you have no requirement to release the source code to the back-end processing code.  When you design a Web application, there are two components to it:  The front-end and the back-end.  These can be further subdivided a bit, if you were to employ the use of the <a href="http://en.wikipedia.org/wiki/Model-view-controller" title="Wikipedia: Model-view-controller">MVC architecture</a> for your application.  However, no matter how sloppy you write it, there are two distinct components:  The front-end and the back-end.  That&#8217;s it.</p>
<p>Now, these are logically speaking two separate programs.  They may work cooperatively, but think about it like this:  The Web browser is a framework for zero-install client application software, which uses a network connection to talk to server application software.  The front-end code, logically speaking, can be used on different back-end servers, too.  It doesn&#8217;t <em>have</em> to be only for the backend it was designed for, nor does anything stop the backend from talking to a third party client application that isn&#8217;t in a Web browser.</p>
<p>Think about it this way for a minute:  Amazon&#8217;s S3 service publishes only an API.  You must write a front-end to sit on top of it.  Your front-end being GPL&#8217;d will not force Amazon to open up S3, no matter what.  It&#8217;s clearly separated.</p>
<p>So, think about those licenses and their interactions and do not spread FUD when you do not understand the interactions that are there.  If you cannot distinguish between the front-end and back-end of a Web application by looking a working copy of it, you should probably consider learning more before you continue to write software.  Writing software is a construction activity and does require real knowledge and experience, as well as the ability to think critically about problems—and a few minutes of critical thinking would save a lot of people from reading ranty, panicy posts on things like licensing issues.  (This is also why management, unless they are technical-minded, really should not be making technical decisions, but that&#8217;s another post for another time.)</p>
]]></content:encoded>
			<wfw:commentRss>http://mike.trausch.us/blog/2008/05/14/on-extjs-and-gpl/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

