Sorry for the lack of activity lately. I was moving from Atlanta and CCP’s studio there, back to Austin for a week, got married, moved to Iceland, started at CCP Reykjavik, and found a new apartment. So I’ve barely blogged or G+’ed anything. I’m going to start blogging again, focusing on fleshing out my GDC presentation at the Tech Art Bootcamp, so expect some posts about training technical artists. After that, I hope to continue my work on pynocle and get back to my regular blogging and posting.
Archive of published articles on October, 2011Back home
New pynocle uploaded to google code (not PyPI yet). In this is a much better dependency graph rendering, module filename resolution, optimizations (such as only calculating dependency data and filename resolutions once), replacing imports with AST, and other improvements. However I took out the ability to run pynocle over more than just a single directory :( Hopefully this can be added back in. I really need to refactor and test some of this code, though, since it’s becoming quite hairy. The python import machinery is the first thing I’ve truly hated about python.
Next up is probably a substantial refactor of the entire system to work from a relational DB (or maybe even a python mapping pickle), rather than the ad-hoc method it uses right now. This should allow richer metrics and more flexibility in their use.
The big backend problems right now are exactly that lack of relational data (which I can hopefully solve with a rewrite), and the difficulty in testing the module import mechanisms. Trying to test it thoroughly meaning practically rewriting and testing all of python’s module import resolution, and then creating a sample of test data that can replicate all of the hundreds of edge-cases (paths with mixed slashes, relative paths, absolute paths with relative pieces, builtin modules with no files, modules not available on the test machine, modules in god knows where in the sys path, etc.). I’ve done myself a disservice by not building enough tests where I can build them, though (post about this in a few days). Anyway, I’ll update when I can.
See current metrics here: http://pynocle.googlecode.com/hg/exampleoutput/index.html
Dependency graph here: