We are not now that strength which in old days; Moved earth and heaven

Despite being originally taken in 1962, the above remains a well-recognized photograph: That’s James Meredith, the first black student admitted to the University of Mississippi, walking to class accompanied by U.S. Marshal James McShane on his left and John Doar of the Justice Department to his right.

John Doar was bestowed with the Presidential Medal of Freedom yesterday. Sometimes it seems like the world is running out of men like Mr. Doar; men and women willing to put their lives on the line to take an unpopular stand and do what they think is right.

Heroku’s Adam Wiggins on how to scale a development team

Not much to say here; I think this is an excellent template for growing a software company and this is my way or preserving copy for when I need it.

Adam Wiggins – How To Scale a Development Team

As hackers, we’re familiar with the need to scale web servers, databases, and other software systems. An equally important challenge in a growing business is scaling your development team.

Most technology companies hit a wall with dev team scalability somewhere around ten developers. Having navigated this process fairly successfully over the last few years at Heroku, this post will present what I see as the stages of life in a development team, and the problems and potential solutions at each stage.

Stage 1: Homebrewing

In the beginning, your company is 2 – 4 guys/gals working in someone’s living room, a cafe, or a coworking space. Communication and coordination is easy: with just a few people sitting right next to each other, everyone knows what everyone else is working on. Founders and early employees tend to be very self-directed so the need for management is nearly non-existent. Everyone is a generalist and works on a little bit of everything. You have a single group chat channel and a single [email protected] mailing list. There’s no real need to track any tasks or even bugs. A full copy of the state of the entire company and your product is easily contained within everyone’s brain.

At this stage, you’re trying to create and vet your minimum viable product, which is a fancy way of saying that you’re trying to figure out what you’re even doing here. Any kind of structure or process at this point will be extremely detrimental. Everyone has to be a generalist and able to work on any kind of problem – specialists will be (at best) somewhat bored and (at worst) highly distracting because they want to steer product development into whatever realm they specialize in.

Read More

2012 vs. 1984: Comparing the costs of tuition and housing

One of Canada’s best finance journalists, Rob Carrick, wrote this piece in response to the furious protests being held by students in Quebec regarding skyrocketing tuition fees and living expenses.

The Globe And Mail – 2012 vs. 1984: Young adults really do have it harder today

All young adults who think they’re getting a raw deal in today’s economy, let me tell you about how it was back in my day.

In 1984, my final undergraduate year of university, tuition cost more or less $1,000. I earned that much in a summer without breaking a sweat.

When I went looking for a new car in 1986, the average cost was roughly half of what it is now. It was totally affordable.

The average price of a house in Toronto back in 1984 was just over $96,000. I wasn’t buying just then, but it’s worth noting that the average family after-tax income back then was close to $50,000. Buy a first home? Easy to imagine for new graduates of the day.

Read More

The Hindenburg over Manhattan

20120513-094009.jpg

The Hindenburg floats past the Empire State Building over Manhattan on August 8, 1936, en route to Lakehurst, New Jersey, from Germany. (AP Photo)

In Focus – 75 Years Since The Hindenburg Disaster

Soliciting browser type, version, OS and cookie settings from your users

I lost track of this site and happily re-found it – tell your website customers to open http://supportdetails.com/ in a new tab when they have issues with your website and to use the form built in to e-mail you their information. Super handy.

Infographic: The size of the United States military

The National Post graphics department is amongst the best in the business. After the U.S. troop withdrawal from Iraq, they did up this infographic about what the size and placement of the U.S. military remains to be. Click the image below to see it at full size.

A Terms Of Service page done right (or at least better)

The 500px Terms of Service page strikes a great balance (a 50/50 balance, to be precise) between necessary legalese and something the layman can understand.


Very basic JSONP

JSONP allows you to make HTTP requests outside of your own domain due to the SCRIPT tag not having the same-domain limitation XMLHttpRequest does. The basic form of this workaround is as follows:

var scr = document.createElement('script');
scr.src = 'http://openexchangerates.org/latest.json?callback=formatCurrency';
document.body.appendChild(scr);

function formatCurrency(data) {
	// Do stuff with the data that's been returned.
	1;
}

Lines 1 – 3 of the above create a SCRIPT tag in the DOM, defines the URL to retrieve data from and in line 3 makes the request. To continue the execution cycle, the script at openexchangerates.org must wrap its data in a function:

formatCurrency({ "hello" : "Hi, I'm JSON. Who are you?"})

This calls the locally defined function formatCurrency(), which does whatever it needs to do with the returned data. A quick hack to make your API (assuming you control it) work with JSONP would be as follows:

// assume $json holds the JSON response
if ($GET['callback'] != '') $json = $GET['callback']."( $json )";
return $json;

I have yet to test this, but I imagine you could also be much more daring and avoid having to get the following code uploaded to your API of choice. To do this, execute the first bit of JavaScript on this page, and then execute an eval() statement on the data in the manner of the below:

eval('formatCurrency(' + returned_data + ')');

How to center text within a DIV element

This is one of those things I’m blogging about strictly so I can search it later and find the answer. Below, we use a DIV contained within a DIV to center text/images/anything on a page, which we’ve arbitrarily decided is 1024px in width.

<div style="width: 1024px;">
	<div style="width: 50%; margin: 0 auto;">
		Everything within this DIV element will be centered within the 1024px outer DIV element!
	</div>
</div>

Reference: StackOverflow – How to center DIV in DIV?

Doing a speed test at a shell prompt

Optimum Online has a couple of test files publicly available for download to see what kind of speeds you can achieve. The following points to a 64 MB file, which is a nice size to discover what your sustained transfer speed is.

$ wget ftp://ftp1.optonline.net/test64