Git Visualization
25 oct 14 - MeetupJS Singapore
Joshua Koo
Joshua Koo
@blurspline
Zopim / Zendesk
Git Visualization
Git Visualization
(in JS of course, duh)
3ource
a brief history...
data:image/s3,"s3://crabby-images/23689/236893d13e632719c2ac299c14cf28fe5f6d03fe" alt=""
SuperHappyDevHouse
3ource
3ource
#ph41L for s0URC3
3ource
Three Source
3ource
Tree Source or Source Tree
maybe, Tree Sauce?
Git
data:image/s3,"s3://crabby-images/403fa/403fa5781bbbdbf2a85aa569397e4c14eed3f58f" alt=""
data:image/s3,"s3://crabby-images/37f16/37f160ce48c2e663514da0afea382c2723f0e24d" alt=""
data:image/s3,"s3://crabby-images/d9bbd/d9bbd47ba239d338c76e8772bb5e6042a03b0b5a" alt=""
data:image/s3,"s3://crabby-images/f8ba2/f8ba2268e0cdebb571e7b11c975eac7698018745" alt=""
data:image/s3,"s3://crabby-images/fde7d/fde7d502a6ed389624783d9da0dcff7c8bb2c15b" alt=""
rgc() {
git commit -m"`curl -s http://whatthecommit.com/index.txt`"
}
For more: http://www.commitlogsfromlastnight.com/
Our CTO has discovered an incredible way of making developers read his commit messages. You won’t even believe how he did it!
data:image/s3,"s3://crabby-images/8704d/8704d5c1873bea45c12d540335898c87ab1c3738" alt=""
data:image/s3,"s3://crabby-images/dd1f4/dd1f4ca11ad951a010ea5818fb079368afd09bee" alt=""
http://www.commitstrip.com/en/2014/08/07/
Visualize
data:image/s3,"s3://crabby-images/07e6b/07e6bf2e8e56ddeb533ad767ad9e41fc3e5fdba1" alt=""
Mission:
how can we present git history in a way its useful and appealing?
data:image/s3,"s3://crabby-images/70a0a/70a0ae9762843bba74f076a01ebac6f98dd3485f" alt=""
data:image/s3,"s3://crabby-images/fe0a4/fe0a4b7d9b048dee82d399ac924245a35ac80184" alt=""
data:image/s3,"s3://crabby-images/738fd/738fd0bb02bb82f155ee54863bcf3323b3a822fb" alt=""
data:image/s3,"s3://crabby-images/062a9/062a96ef77e4f4355673161ad2973b949798cef0" alt=""
data:image/s3,"s3://crabby-images/03b35/03b352f17ead15e3b25ff78a802481ce401af91a" alt=""
Twitter Code Swarm
data:image/s3,"s3://crabby-images/71c55/71c55209ff454a79ec6d4b41a8464ba94e04bf1a" alt=""
Code!
Goals
- Build a Git Log viewer that runs in the browser
- Animate directory structure of repository over time
Challenges
- How do we get git data in JS to the browser?
- How do we render huge amount of logs?
- How do we visualize a git folder structure automatically?
- How do we build a nice UI?
Git Data in JS
- Github API
- Pipe Data from Command Line
- node.js Bindings
- Git in JS
Data Needed
- Git logs
- author
- message
- date
- hash
- Git tree diffs
- filenames
- add
- delete
- modified
Pipe from Process
var exec = require('child_process').exec;
exec(GIT_LOG_CMD, {
cwd: cwd,
maxBuffer: 1024 * 1024 * 200 // abuse memory up to 200MB ;P
}, function (error, stdout, stderr) {
// handle and parse stdout here
})
);
fs.writeFileSync(OUTPUT_JSON_FILE, json, 'utf8');
Custom Git Log format
git log --raw -m --pretty=format:"bla" --encoding=UTF-8
Where "bla" = pretty format placeholders
data:image/s3,"s3://crabby-images/dfa8d/dfa8d9d69a965d10dbbb4391ca289bb7469c88a9" alt=""
git log --help
Pretty Git Log Viewer
data:image/s3,"s3://crabby-images/964b4/964b4b5f4f137019adeed9d002ddfef60af966be" alt=""
Strategy
- Build the graph paths in memory
- Graph is rendered on Canvas
- Row Rendering is done with a virtual view port
Directory Rendering
- Get directory structure at commit #####
- layout algorithm
- WebGL?
Git Tree
git ls-tree -r COMMIT
Cache directory filenames
Force Directed Layouts
Nodes with simulated forces
Minilistic event dispatcher
npm install do.js
var Do = require('do.js');
var onFire = new Do();
onFire.do(something)
onFire.fire('bla');
Finally...
data:image/s3,"s3://crabby-images/ca204/ca204b0c8eb5002c060371282561f38b603615a8" alt=""
One Big Hack but a WIP
suggestions, ideas, comments
Shameless Plug:
data:image/s3,"s3://crabby-images/1d648/1d6482dbba079f85ac18f314849b7c11076e4867" alt=""
Thank you
Git & Visualization
By Joshua Koo
Git & Visualization
slides for presentation for SingaporeJS talk.js meetup http://www.meetup.com/Singapore-JS/events/197757042/
- 5,540