An Escape From Front End Development

Thursday, January 8, 2015

The year 2015 starts and I’m working on a code generator, which is one of the more enjoyable tasks in software for me. Code generators and meta programming requires considerably more mental focus than banging out business code, the kind of focus where any interruption is tantamount to dumping the Atlantic Ocean on a continental scale forest fire. It also means the interrupter is subject to an assortment of growls, stares, and verbal assaults, and for these I apologize.

The are a couple specific challenges  this project, but the general challenge in building code generation software is in building a model that can serve two masters. On one hand, the model has to make the actual generation phase easier. On the other hand, the model has to be easy to build from some source of data, be it a visual designer or, in my case, XML. Not just any XML, but XML of debilitating complexity as one critic puts it, and I agree. There are times when I suspect someone has willfully obfuscated the XML, but then I remember Hanlon’s razor (with a twist):

Never attribute to malice that which is adequately explained by stupidity, or is the output of a standards committee. 

Regardless of the data source, I’ve been to the codegen rodeo before, and the code usually falls into place like the following:

codegen

Adapters have to surround the model to make it usable from both ends. In this scenario there are parsers to transform XML into meaningful data structures, and adapters to facilitate the code generation. Ironically, this has been done before as open source, but the output is JavaScript. JavaScript and it’s various server-side runtimes have some strengths, but algorithmic number crunching and set sorting at scale is not one of the those.

I’m replacing JavaScript code then, with something I hope is better. The irony is how I spent 2014 writing more JavaScript code than I have in the previous 15 years, on the server but mostly on the client, and I needed a break. A problem with real teeth. It’s not that front end development doesn’t have any challenges, but I’ve been frustrated by the irresponsible amounts of accidental complexity in front end development.

Ah, you must be talking about the complex framework by the name of Angular.

Well, no, but let’s use Angular as an example. It is, truthfully, a simple framework when you discard all the permutations offered and stick to simple, disciplined, and calculated practices. Projects go haywire for any number of reasons, here are three examples I’ve seen in just the last week.

1) Projects that treat Angular modules as CommonJS or AMD modules, in the sense that every little component needs a dedicated module. With Angular this practice only creates more work and bookkeeping for little gain.

2) The confusion between module.factory and module.service. I always try to tell people to think of factory and service as registration APIs only. To the consumer, it doesn’t matter which one you choose, they both create a service component. When people tell me they are passing a factory to their controller, I get confused. The factory API registers a factory function, but the function is not what the injector will pass to a controller, the injector will pass the output of the method, which is the service.

Taking a step back, both of these problems stem from one of the “two hard things”:

There are only two hard things in Computer Science: cache invalidation and naming things.

-- Phil Karlton

And that’s something I won’t escape from. Naming things is hard on the frontend, but also here on the backend, too.


Comments
gravatar Douglas Starnes Thursday, January 8, 2015
I'm going the opposite direction, from back end to front end development. I jumped on the AngularJS bandwagon recently. In August I realized ES6 is for real. I've being working with Dart more and more and TypeScript is my latest obsession. Of course Dart and TypeScript work full stack.
gravatar Jesse Slicer Thursday, January 8, 2015
...and off-by-one errors.
gravatar Stacy Thursday, January 8, 2015
I thought an Angular SPA would be great until I picked it up and it turned into a snake. Back to server side MVC and javascript libraries for interactions.
gravatar Gomes Thursday, January 8, 2015
AngularJS 2.0 team keeping both Dart and Typescript in mind and revamping the entire angularjs.
gravatar Wayne Friday, January 9, 2015
Surely a project doesn't fail because of the difference between a factory and a service
gravatar Scott Friday, January 9, 2015
@Wayne: Nothing failed. The amount of misinformation is ridiculous.
gravatar street Sunday, January 11, 2015
welcome to HL7 and its smorgasbord of standards.. a study was done a few years back where test subjects were placed in an mri machine and shown images of optical illusions or output of the various hl7 standards, unsurprisingly their brain scan signatures matched exactly between the two
gravatar Matthijs Tuesday, January 13, 2015
Hey Scott, In your post (near the end) you say: "Projects go haywire for any number of reasons, here are three examples I’ve seen in just the last week" If I count the examples I only get to 2. Did one get away?
gravatar Scott Tuesday, January 13, 2015
@Matthijs - yes, good catch. Currently still frustrated with JS codebases in general, I could rattle off 5 or 6 more, but instead of complaining I hope to contribute something that can improve the situation. More on that soon.
Comments are closed.

My Pluralsight Courses

K.Scott Allen OdeToCode by K. Scott Allen
What JavaScript Developers Should Know About ECMAScript 2015
The Podcast!