Shhh.. don’t tell anyone but i’ve quietly launched the eatStatic demo site, which now runs from the master branch of the github repo. This is still the PHP version, slightly tidied up, and now using twitter bootstrap for the default skin. I had previously said that I wouldn’t be maintaining the PHP version in favour of building a python/ django version, but as i’ve thought of a new personal project to build with django (which for once – STOP PRESS – is not a blog engine or CMS), I thought it would be good to get the PHP version tidied up into a usable state if anyone else wants to try it out. Also, as I happily run this blog from it, and am likely to do for years to come, it would be nice to get all the features built in that i’d like to use, and bugs ironed out.
When I first saw the macbook air I was awe-struck by it’s design and portability, and like many people I was wondering if it would be up to the job of being an everyday work machine for web development. At the time I was primarily interested in the 11 inch version – I wrote off the idea of the 13 inch version, thinking that if I wasn’t going to get the really small version, I might as well just get a more feature-rich and powerful 13 inch macbook pro. Several of my friends have got the 11 inch version, and have found it very capable, however..
Power and Storage
A couple of people have asked me about the power and storage – I went for the highest spec I could, so this has an i7 chip and 256gb SSD. I’ve been using it for a month or so and still have 130gb spare on the SSD, so the drive is plenty big enough once all my software, music, photos, a few movies and TV series are on it, not to mention several work projects. I would have been struggling with the 128gb version, though arguably I could use an external drive for all the media, and be ruthless with deleting stuff, and just about get away with it.
I haven’t done any speed benchmarks, but this machine feels blazingly fast compared to my old core duo macbook, in fact i’ve never used a faster machine! Photoshop opens very quickly and it handles large photoshop files really well, is plenty fast enough for general web development and associated tools. The most demanding scenario for me is having multiple browsers (and dev plugins) open, using my usual dev tools along with a massive multi-layered photoshop file open in CS5, at the same time as virtualbox running windows 7 for IE browser testing. While this pretty much uses all of the 4GB of ram, it still runs really happily compared to my old macbook – probably because the disk is much faster.
The only thing I haven’t done is try editing a video with final cut pro – I know this machine has the same graphics capability as the 13 inch macbook pro (“Intel HD Graphics 3000 processor with 384MB of DDR3 SDRAM shared with main memory”), so should be capable, though not as good as the 15 inch and 17 inch pro, which have a second dedicated graphics chip and memory. I would imagine it is entirely possible to edit and process large videos on this, though if video editing were my primary job (and needed a portable editing machine), i’d have gone for a 15 inch pro at least! My video editing amounts to occasionally splicing together clips in iMovie, and adding titles and soundtracks – it is more than capable of doing that, including HD.
The advertised battery time on the 13 inch air is up to 7 hours – another selling point for me in comparison to the 5 hours on the 11 inch version. I haven’t had the full 7 hours yet, but whenever i’m working I nearly always have a whole load of stuff running, so i’m getting more like 4 – 5 hours. Coconut battery is telling me I have a max capacity of 6450 mAh as opposed to the design capacity of 6700 mAh – I may pop in to the apple store to see if this anything to worry about, though i’m not keen on the idea of it being taken away from me for more than an hour or two to have a new battery put in!
Obviously this is a big plus with the air – the backache I used to get carrying round my old macbook in a backpack is no longer a problem – I can barely tell whether it’s in my bag or not. If you spend half your life on a train or plane, the smaller version may of course be preferable, but i’ve not yet been in a position where this one feels too big.
I would definitely recommend the macbook air 13 inch as a portable web dev machine! I’m really happy with it and hopefully i’ll get many years out of it, just like I did with my old macbook and the powerbook that preceded it. As ever, whenever you commit to buying a new mac, there’s always the “but aren’t the new ones being released tomorrow/ next week/ next year?” consideration. I think if a macbook air with 8GB of ram suddenly appears i’ll have slight regrets for not hanging on, but other than that i’m very happy that i’ve made the right choice!
I was pleased to see people recently enthusing on twitter about text-file based blog and CMS tools – nesta CMS, Kirby and scriptogr.am, as it validated my theory that there is a demand for tools like these – I was met with fairly bemused looks when i’ve explained the concept to people in the past!.
I was also slightly annoyed with myself for not pushing my own text file based blogging system more and taking it further, as maybe people could have been getting excited about my project instead. It seems fairly pointless to develop it further now when these other tools exist, and i’d already decided to park it last year. My other reason for halting development on it was because it is written in PHP, and i’m determined to concentrate my efforts on django and python for personal projects.
Whilst at New Adventures in web design conference on thursday, I was feeling inspired to create something, so thought maybe I should build a django version of one of these systems. For a crazy second there I thought maybe I would be the first person to think of this, so I did about 30 seconds research and found that Luis Pedro has already created a django text file based blog/ CMS called Git CMS. It looks great, so my first reaction was that I should fork it and develop some of my other ideas around it, but then I noticed that he is still using a database, with a sync script to populate Django models from the text files. This is actually a very sensible way of doing it as it means that you can take advantage of all the stuff you get for free in django. However, my initial goal for eatStatic was to avoid the need for a database at all..
So i’ve decided to do a more or less straight port of eatStatic blog engine to python – a standalone text file blog engine implemented as a python library, that can be dropped into a django project, or any other python web framework, with little or no configuration. I’ve given myself an initial goal of moving this blog over to it as soon as it is stable, but then I want to take it further, and do some marketing around it – encourage people to try it, and to fork it, join me in my quest for a really fast, really simple, really portable, really powerful python powered database-less blog and cms. As soon as I have the initial code ready, and am convinced it isn’t too embarrassing i’ll get it up on gitHub alongside the PHP version 🙂
Just before xmas I installed the Path app out of curiosity, as I had noticed that a few of my friends were using it. It’s a lovely app, and I really like their policy of limiting connections to 150 to encourage it to be used as a communication tool for friends rather than a crazy marketing scatter-gun to be used for self-promotion by individuals and businesses, as most social networks inevitably become.
However, i’ve barely used it, partly because it doesn’t have a critical mass of people I know using it yet, but also because it doesn’t have a web version – currently it is restricted to app-only for iPhone and Android (will it always be?), and even though I carry my iPhone everywhere, I feel restricted and claustrophobic if I am forced to only use a mobile app.
This post isn’t a criticism of Path though, it’s about mobile internet usage in general. By mobile, I mean smartphone, rather than tablets/ netbooks. Nearly always when i’m using a mobile version of something, I feel claustrophobic – from ham-fisted accidentally liking or retweeting stuff to not being able to find missing or hidden features, I feel myself desperate to get on a laptop and use the “full” version instead.
Mobile web usage (by which i’m including standalone apps which transfer data via the internet) is going through the roof – but how much of that is people using it only because they happen to be somewhere where they haven’t access to a laptop/ desktop computer, versus people who would actively decide to use a mobile version of something in preference to a “full” version on a laptop?
There’s been much debate recently about responsive web design in the last year and about favoured approaches to making websites and web applications adapt to different devices. One of my arguments in that is that I like the option to zoom out and in of the full “desktop” version of a web page when i’m using my iPhone – I like to scan around and zoom in to parts of a page, particularly on a news site, rather than scrolling through loads of text on a mobile version of the site, feeling like i’m missing stuff, and anxious to at least see the desktop version, zoomed out to see where I am in relation to everything else.
However, that doesn’t seem to be a popular opinion – I wonder if i’m part of a dying “desktop orientated” generation – I can use and enjoy a mobile version, but always feel shortchanged – it’s never as satisfying as the “real thing”, whereas the next generation, introduced to the web via a mobile device don’t feel that lack of wider context (wider meaning literally wider in some cases), and feel shortchanged when they get something aimed at a desktop/ laptop computer?
I can’t remember where I saw this (twitter probably) a few weeks ago, but I can’t help laughing about this whenever I start a new project – I think no matter how well reasoned my choices are at the outset of a project, this is how most of my personal projects work out!
A while back I wrote about how I use subversion (SVN) version control as part of my workflow, when working alone and as part of a team. I’ve observed many of my friends and colleagues dropping SVN and moving onto GIT, and used it when working on swoop patagonia but personally carried on using SVN as my default preference, in a “if it ain’t broke don’t fix it” kind of way.
However, this has recently changed, having learned a bit more about it using it as part of the workflow at my new gig at potato, I can’t see me creating any more SVN repos by choice. So here is how i’m using it – note this is very basic usage – i’m far from an expert at this point.
The basic setup is similar to how i’ve been using svn:-
- Create a repo on a remote host (e.g. github/unfuddle/my own server)
- Check it out to my local machine (in git terminology “clone” it)
- Make some changes, add some new files, delete files
- Commit changes back to the remote repo (in git you commit locally, then push the changes back to the server)
To clone the repository to your machine:-
git clone https://your/repote/repo
To add new files to it:-
git add /your/new/file
To see the status of your local repo
To commit changes (this is where SVN users get confused), first “stage” your changes:-
git add /the/file/you/changed/or/added
Then commit (note this just commits it locally):-
git commit -m 'message here'
or to add a commit message using your default editor:-
So at this point you haven’t sent anything back to the remote repo, you can carry on making changes and committing locally (this is one of the advantages of GIT over SVN). When you are ready to update the remote repo:-
First pull down any changes from the remote repo (assuming you are still on the master branch – i’ll come to branching later):-
git pull origin master
At this point if there are any conflicts you will need to resolve them, which is usually a case of editing any conflicted files, then adding and committing them. Then you push:-
git push origin master
So this is basically not far off how I used to work with SVN – the only difference being that I have a local change history, so (in theory at least) I can roll back changes if I get into a mess.
Where it gets more interesting and useful is where you introduce branches. I know SVN has branching, but i’ve mostly ignored it, but with GIT i’m always creating branches, which i’ll cover in another post..
These retrospective posts are annoying aren’t they – kind of like the xmas round-robin letters?! However, I wanted to do one again, because it helps me keep track of things, where i’ve been (and when – it all becomes a blur..). So, as I did with 2009, 2010 and 2011, I wanted to revisit the list from last year and see what happened and what didn’t.
- Buy a new Bass Guitar and play the hell out of it – I did just that, although it still needs a load more playing. I think initially I started focussing too much on kit and trying to compose and remix stuff and generally ending up stuck in front of a computer, which was something I was trying to avoid! So this is carried over – but with the goal of having a jam or two in a room with actual humans rather than garageband. Not sure i’m ready to commit the time to a gigging band yet, though it certainly appeals..
- More “work from anywhere” adventures. I worked from a few different places, but in doing so, came to the conclusion that I wish I was just on holiday and could actually spend it with my wife and son and leave my laptop shut! I’m now working full-time at Potato, office-based, which I have to say i’m enjoying, though I get to travel to London fairly regularly, and hopefully other places, so still interested in mobile working tech. I actually plan to merge the content from my seperate mobile working blog into this site
- More blogging! – including some personal blogging – um.. I think I blogged a bit more – certainly after moving this blog over to eatStatic. I hope to keep this up and improve my output – one thing i’ll be doing is stepping away from the firehose of twitter for a bit again, and try to get my thoughts and opinions down in considered blog posts rather than the rapid-fire train-of-thought (with compromised punctuation!) that twitter encourages.
- Attend at least one web conference – this nearly didn’t happen until a last minute decision to attend WebDevConf in Bristol, which I enjoyed a lot. I’m happy to say that i’ve got a ticket for new adventures in web design, so this goal will be achieved early in 2012.
- Get further than “hello world” with Django – I’m certainly further than hello world now! My first few months at Potato were like an intravenous injection of Django, and i’m now proud to introduce myself as a Django developer rather than just a web developer. I’ve still got a lot to learn though, but all new personal projects will likely be Django from now on, rather than PHP.
- Use and understand some technologies that i’ve been ignoring – as ever, there’s always new stuff on the horizon, but my first goal is to finally learn regular expressions properly, having successfully ignored them for the last decade!
- More on-site freelancing for agencies – ditched for obvious reasons! I was actually a full-time on-site freelancer for potato before I went full time, so it’s clear that this one worked out for me in 2011.
- Keep Trading and survive the recession – I achieved that this year, but I guess now this point needs changing to “keep employed”!
- Launch a web app – In a very low key way I achieved this by making my eatStatic library/ blog engine public this year. However, even though i’m pleased with the way it works, i’m not intending on developing it any further, as i’ve already started on another blog engine for Too Old To Skate using Django, mainly as a learning exercise. I think maybe this goal should be changed to “do not start any more blog engines”? Now i’m out of freelance, 2012 is really going to be all about the work/life balance and not spending evenings with my face stuck in a laptop, but on the other hand I have a few ideas floating around…
- Relaunch Too Old To Skate – See above. as ever, an ongoing project.
- Attend at least one BarCamp – Failed. These type of informal events are the ones i’m interested in though – hacknights, barcamps, skillswaps, anything which is run for the fun and community of it rather than profit.
- Skateboarding! – this isn’t new, but 2011 was the most lax year since I started skating regularly again, so need to get skating while my knees can still take it 😉
- Learn to touch type – I’ve been saying this for years, but it’s about time I stopped typing with two fingers like someone playing Daley Thompsons Decathlon on a ZX Spectrum..
- Be more proactive with geek socials – Bristol has a great geek/ design community, but I seem to have completely missed most of the face-to-face stuff recently and want to change that.
- Practical Skills – growing things, making things, fixing things – not sure exactly what yet but it’s all about the analog at the moment…
As i’ve exclusively been using app engine in my day job at Potato, I haven’t yet had to deal with deploying a django site on my own Ubuntu server yet. I knew that I would be using virtualenv, apache and mod_wsgi, but hadn’t yet worked out how this is done.
Rather than repeating it all here – I followed most of the steps in this blog post.
However, there were a few points where things didn’t go to plan:-
First of all I got the ubiquitous mysql_config not found error when attempting to install:-
pip install mysql-python
So, apparently the solution is to install libmysqlclient-dev:-
sudo apt-get install libmysqlclient-dev
However, if you get this error:-
error: command 'gcc' failed with exit status 1
You need to install python-dev:-
sudo apt-get install python-dev
A month or so ago I took toooldtoskate.com offline as it seems that it was being used as a spam relay. It was running an ancient unpatched version of wordpress, so this came as no surprise. I thought it would be a good opportunity to rebuild it using django. So yet another django blog engine has sprung into existence – all really simple stuff though, just a couple of models and some class-based generic views, a familiarisation exercise rather than an attempt to build a wordpress clone.
A work in progress, as ever..
- Commenting (i’ll integrate disqus)
- Filtering by type/ channel (e.g. video and author)
- Merchandise (I will sell at least one mug, in 2012 I swear!)
- Blogroll/ links