-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathSoftwareHygiene.asc
40 lines (40 loc) · 6.79 KB
/
SoftwareHygiene.asc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
I had the privilege of working with David Tilbrook almost 25 years ago. He was the first person with whom I ever worked that clearly articulated proper software construction discipline for collaborative endeavours and captured a summary of it under the title of “<a href="http://www.qef.com/html/docs/swhygiene.pdf">Washing Behind Your Ears: Principles of Software Hygiene</a>”. <br />
<br />
David articulated these practices pre-World Wide Web. We weren’t yet living in a world where the Web had so completely removed the friction of time and space from sharing and collaborating on software that even the early Internet enabled. The Open Source Definition hadn’t yet been coined. The forges hadn’t yet been built. <br />
<br />
The world has progressed and there’s a new sort of software hygiene that’s now required. I first learned back in May 2012 that one of the most popular software collaboration forges, Github, doesn’t require a project creator to choose a license for their software. Today, James Governor reminded me of this madness when he tweeted: <br />
<br />
<blockquote class="twitter-tweet">
<p>younger devs today are about POSS - Post open source software. f### the license and governance, just commit to github.</p>
— James Governor (@monkchips) <a data-datetime="2012-09-17T06:34:00+00:00" href="https://twitter.com/monkchips/status/247584170967175169">September 17, 2012</a></blockquote>
<br />
I replied:<br />
<br />
<blockquote class="twitter-tweet" data-in-reply-to="247584170967175169">
<p>@<a href="https://twitter.com/monkchips">monkchips</a> Governance implies community but promiscuous sharing w/out a license leads to software transmitted diseases</p>
— Stephen Walli (@stephenrwalli) <a href="https://twitter.com/stephenrwalli/status/247597785069789184" data-datetime="2012-09-17T07:28:06+00:00">September 17, 2012</a></blockquote>
<br />
Pretty soon, a lively discussion was off and running with <a href="https://twitter.com/nearyd">@nearyd</a>, <a href="https://twitter.com/mmilinkov">@mmilinkov</a>, <a href="https://twitter.com/webmink">@webmink</a>, <a href="https://twitter.com/dberkholz">@dberkholz</a>, and <a href="https://twitter.com/tieguy">@tieguy</a> joining in. (Well as lively as Twitter can get.) <br />
<br />
Here’s the problem: governments protect software creations using copyright law. Different governments have different views of how it applies and slightly different terminology. Some countries worry about author’s moral rights. Others don’t. Countries also have different opinions on what the public domain means and how it can (or can’t) be applied with respect to software. Essentially, as with all things in the software legal space, it’s a mess. [This is probably a good time to remind the reader that I Am Not A Lawyer.]<br />
<br />
Living in a proprietary software world, it was relatively “easy”. Companies asserted their copyrights as protection for their software products. As software publication and collaboration became ubiquitous, we saw the rise of free and open source software licenses. These were used as statements of sharing intent and expectation by authors on their works. If a collaborative community arose around the project, these licenses were often the initial declaration of the social contract long before the community ever evolved to statements of governance and codes of conduct. <br />
<br />
So here’s the problem. If you share software on the Internetz without using a license, the software is protected by your copyright and all rights revert to you. You have made no statement about how it might be used, or what you would agree to, now or in the future. If you share on a promiscuous site like Github, where forking is encouraged, and you make no such sharing statement, and start accepting change requests from other developers without licenses, then you’re collectively creating a copyright mess that will eventually hurt people using your software. <br />
<br />
Not caring, or naively believing it doesn’t matter because you believe “people can do whatever they want with my software,” or worse using others’ unlicensed software in your own means you will eventually hit a point where you stifle the growth of your software. It’s not that you’re necessarily creating a provenance mess where “dirty” IP will creep into the mix (although I’m sure some companies will try to provoke that fear to sell you things, or worse sell other people things to “protect them” from <span style="text-decoration: underline;"><em>your software</em></span>). It’s very possible that you could create a Software Transmitted Disease, but what you are definitely doing is limiting your project’s growth. <br />
<br />
Professional developers have a working understanding of software copyright. By professional, I mean developers more knowledgeable than you that can make your project better through contribution. When they see that there’s no license on your pool of software, if you’re lucky, they will ask you to declare one so they can know if they want to adopt and contribute. If you’re not lucky, then they will simply move on and you will have lost whatever contributions they may have brought to your party. I’m not talking about Great Knowledgeable Developers who are going to join your project and stay. If you’re lucky, you’ll attract a few folks to your world that know a few things more about it and share them. That’s ultimately the economic strength of a well run open source project. Collectively we're better. Neither am I talking about you might need to do when Building a Big Community. I’m simply talking about sharing your software brilliance. Because that’s why you published on a site like Github, right? So you could share and learn. If you don’t put a license on it, you risk losing knowledgeable participation.<br />
<br />
So here are some “bumper sticker” banners to help remind you of the necessary software hygiene of the new millennium: <br />
<ul>
<li>
Github without licenses is like free sex without condoms.</li>
<li>
Practice safe software on the Internet -- use a license. </li>
<li>
Practice good software hygiene -- license your software.</li>
<li>
Don’t fork around without a license. </li>
</ul>
<p>Collaborative development with liberal open source licenses is one of the best things that has come out of the World Wide Web phenomenon and helps sustain and grow it. Do it wisely.</p>