Joseph Hallenbeck
January 02, 2014

2013 In Review

Filed under: Journal part of Annual Reviews

In the spirit of the season, I hope to do a little navel gazing. So, if reading through a pile of narcissistic schlock wherein I attempt to showcase just how amazing my life is, read on. Otherwise, it would be best to skip this. Honestly, I would not blame you at all.

Professionally this year has held quite a roller coaster of changes. I changed firms, moving over to 44 Interactive. This brought with it a much wider range of responsibilities and opened doors into expanding my skills into a avenues that I had not yet explored.

Bogun

At the new firm, I switched to developing 100% on Linux (Ubuntu and CentOS). It was a rocky first month, but now I would never switch back to working in the Windows environment. I oversaw a major revision of production servers at the new firm, getting things PCI compliant and automating a lot of processes using Python and Bash – two languages that I picked up last spring.

I picked up a lot of new tools with the move as well. I started doing regular development in Code Igniter, expanded my knowledge of Lemonstand, and wrote an internal toolset using Silex. I modernized my front-end skills – working with LESS, HTML5, and building increasingly more complex ajax sites with a much more solid understanding of modular/pseudo-classical JavaScript.

I worked on our custom CMS, normalizing it’s database structures, introducing a number of design patterns to enhance re-usability, getting it into a repository, and wrangling out a lot of cruft as it became a leaner, more focused application.

As for personal projects, I rewrote the templates for my portfolio and “culture” blogs, moved them onto my own VPN, started hosting my own e-mail server, and got onto Linkedin and back into regularly blogging. I started to revise my old coursework in C and daydreaming of making some small game projects in C/Python.

2013 saw me move four times. I started with a move to a new house in Sioux Falls on the first of the year. I split my time at that house with traveling to a second rental in Hullet, Wyoming. In May, the rental in Hullet went away and I began dividing my time between Sioux Falls and Island Park, Idaho (and later on another move down the mountain to Ashton, Idaho where I began to telecommute 100% of the time).

All this moving gave me quite an incentive to cut down on my possessions. It is amazing what a couple years of sedentary life can do for property. When I moved to Sioux Falls a couple years past, all I owned fit in my trailer. This year, it took me six loads to haul it all out to Idaho.

Oak Table

The new house, in Sioux Falls, lacked counter space, so I took this as a challenge to take up carpentry. I built a fine Oak butcher-block style table that now resides in my home office as a standing desk.

In Sioux Falls, I made it to figure drawing nearly every week that I was in town, amassing quite a collection of drawings and sketches.

In Idaho, I explored Craters of the Moon, backpacked the Jedediah Smith Wilderness Area, dipped my toes in Bear Lake, explored half a dozen different day hikes throughout the area, and am now regularly snow shoeing along old rail road right of ways. All of this resulting in a pile of nature photographs that I am just now starting to compile and process.

I had a bit of a health scare in Idaho. A false appendicitis lead to all kinds of new experiences with the American medical system. A sciatica afterwards left me crippled for nearly a month. In the end, I found myself resolved to get back into shape by switching to a standing desk and waking early for a heavy dose of aerobics before work.

Through the year, I discovered Black Books, read Chomsky, the translated works of Yoshitiro Tatsumi, Lovecraft’s At the Mountains of Madness, re-visited Kerouac, and the poetry of Allen Ginsberg. I played Fez and Shelter. I began the Prince of Persia series and Zelda Twilight Princess.

I made it a point to try to put 30 minutes each day into reading a text about computer science, be it a volume on patterns for Python, pointer arithmetic in C, or artfully designing databases. I feel that I have reached the point where I just “get” it when it comes to development. I can sit and read across the field and generally understand the content and feel confident that I can apply the techniques in the texts without misinterpreting them or misapplying them.

2014 In Resolution

So, I suppose now that I have sat down and covered the many highlights of the last year I should address myself to the upcoming new year and the good things that I want to bring about.

I am going to keep reading. I am going to keep putting that 30 minutes of personal development in CS each day, but I also should set more time aside to just sit down and game. Two hours for two nights a week and maybe a couple binges – lets say 160 hours by the end of the year which would put me through four decently sized games. Now that we’re on the new console generation it is time to pick up a PS3 and the backlog of exclusive titles along with all the Wii titles that I let slip.

I hope to pick up a role playing group for one evening of the week, and challenging myself to finally break down and go to Friday-Night Magic.

I want to challenge myself to bike to Driggs and back this summer (80 Miles). I would also like to backpack Targhee Peak via Coffin lakes, challenge myself to complete the backpacking trip to Jedediah Smith Wilderness Area, snow shoe to Warm River Cabin, canoe Warm River to Snake River, and spend a week backpacking in Escalante.

The big thing is going to be the projects for this next year. Items, I really am excited to see. I just have been so busy the last couple of years to really focus any of my attention on some personal projects other than the occasional essay.

Pecunia

I’ve already addressed Pecunia in this blog. This is my open-source financial planner/budget maker built around Silex (although, I am now leaning towards Laraval4). I envision this as a multi-user website that will allow users to create budgets, log expenses, and keep track of their personal finances. Oh, and it will be completely open-source and available for review on my BitBucket account. (Personal Deadline: Spring 2014)

PyGame

This is a much more vague idea, because I just have not sat down to flesh it out. I want to sit down and make a small collection of old-school arcade clones in Python, and slowly work my way up to creating a nicely polished 2D platformer. (Personal Deadline: 2015)

The Weird Tale

I have this short story that has been in the works for three years. In my day planner, it’s noted down as “the weird tale.” It’s a Lovecraftian tale of monsters and madness. I really need to finish it. (Personal Deadline: Rough Draft Summer 2014, Final Draft Fall 2014)

Blog

It’s nice to be blogging regularly again. This year, I aim for 12 solid articles.

Architectural Drawing

I have spent the last three years working on figure drawing. It’s time to return to architectural drawing. Once it gets nice outside, I aim to take the easel outside and start sketching out each of the buildings in this small town.

Photo Showcase

An annual addition to the list, since I still haven’t done it. I really need to get a gallery showing put together of my photos. The issue is always that by the time I have a good enough collection of photos for a given place, I move. (Personal Deadline: Fall 2014)

NaNoWriMo

I’ve been off NaNoWriMo since somewhere around 2007. It’s time to get back in there and write a new one. So this year, let’s be serious and put it on the list.

Inevitably, more projects will probably arise in my mind through the year, and I will address them as they appear, but for now that’s the whole list.

Bear Lake Panorama

I have taken to experimenting with stitching panoramic images together. The one above is of Bear Lake in September of this year. We sped around the lake at sunset hoping to get to the eastern shore in time for the shot. I ran out of the truck down onto the stony beach and started shooting.

The resulting photo has has had little post work done in lightroom, but was stitched together using photoshop with a dash of content aware fill to fill in where the distortion curved down into the blue sky and took out a chunk of the right-most mountain.

Settings

Model: Nikon D80 /w Nikon 35mm f/1.8 AF-S DX

Shutter: 1/160 sec

Exposure Program: Manual

F-Stop: f/9

ISO: 400

Focal Length: 35mm

Lighting: None

No of Stitched Photos 4

December 02, 2013

My Favorite PHP Helper Function - A Better Isset()

Filed under: Software Development (updated on 2017-08-22 09:30)

PHP7’s Null Coalesce Operator

As of PHP 7 the function described below is no longer neccessary as it’s been superceded by the Null Coalesce Operator.

Null Coalesce allows a nice bit of syntactical sugar for a checking if a variable is set and then returns that variable if it is or some fallback value if it is not:

<?= $title ?? 'Blog Title' ?>

Outputs the value of $title if it is set or ‘Blog Title’ if it is not. It is the same as doing:

<?= isset($title) ? $title : 'Blog Title' ?>

My favorite helper function for CodeIgniter is a ridiculously simple function that has an amazing amount of utility. I stole, at least the idea of, this function from LemonStand and it has since made its way into nearly every CMS that I have worked on:

<?php

/**
*  Check if $var is set and if not return null or default
*  @param mixed $var The var to check if it is set.
*  @param mixed $default The value to return if var is not set.
*/
function h( &$var, $default = null) {
    return isset( $var ) ? $var: $default;
}

At first this doesn’t really seem to be doing much, after all at first glance it looks like it is nothing more than a wrapper for isset, but this improves heavily upon isset in two very important ways. First, let’s look at how this function works.

In the function definition we are taking a reference to a variable. Recall, a reference is pointing at the memory, not value, of a variable and so we can actually pass to our helper function a variable that has not yet been initialized. This saves us from receiving a notice that the variable does not exist. Our call to isset thus checks our memory to see if it is actually referencing a variable or nothing at all. If it is referencing an actual variable it returns that variable, otherwise it returns null (our default default) or whatever value has been assigned to $default.

The utility of this is best expressed in handful of examples. The biggest use of this is in a view. Let us look at a view constructed without the use of our helper function:

<h2><?= isset( $title ) ? $title : 'Blog Title' ?></h2>
<p><?= isset( $content ) ? $content : null ?></p>
etc.

In a sizable view the above can get quite long and quite cumbersome to maintain. Each call to isset is checking to see if the controller actually passed the value on to the view ( $title or $content ). If we did not do this we would get a notice from PHP. Sometimes this is resolved by programmers by using the error suppression symbal (@), however the notices will still end up in the logs of many frameworks that strictly check for errors. Contrast this with a view using our helper function:

<h1><?= h( $title, 'Blog Title' ) ?></h2>
<p><?= h( $content ) ?></p>
etc.

The above is a much, much more concise view that is easier to read and is still a strictly valid snippet of PHP that generates no warnings or notices. Once we start to use this helper function regularly all different kinds of uses come up for it, for example we can use it to see if a model returned a value:

<?php

/* 1. Longer method without using the helper function */
$page = $this->pages->getByURI( $url );
if( ! $page )
{
    $page = $this->pages->get404();
}
$this->render( $page );

/* 2. With helper function */
$page = h( $this->pages->getByURI( $url ), $this->pages->get404() );
$this->render( $page );

The above snippets are fairly simple, but let’s walk through them. In both instances we need to pass some page object on to the render method. An error occurs if it does not get a valid page object so we must check after retrieving a page that it actually exists. In the first snippet we use four lines of code to first get a page by $url (the value of which is set somewhere else). Now if the pages model returns nothing then we enter a conditional statement that retrieves the 404 error page.

However, with the use of our helper function we can shorten the code in half and remove the conditional all together make it a much more readable snippet of code. The first line of the second snippet simply passes the return of the pages model and the get404 method into our helper function which returns the first if it returns something or the latter if it does not. The only downside is the additional load since the 404 page would also need to be loaded concurrent to the current page with each request, but in most cases this is going to be negligible.

Having looked at two different uses for our helper function, we can begin to see that we can get quite a bit out of some very very small functions. If you have your own favorite one-liner functions feel free to share in the comments below.