GitLogParser.js
[gitlive] / GitLogParser.js
1
2 var File = imports.File.File;
3 xDate = imports.Date;
4
5
6 GitLogParser = { 
7
8     parse : function(date)
9     {
10         this.date  = date;        
11         var home  = GLib.get_home_dir();
12         
13         var lines = File.read(  home + '/.gitlog' + date.format('/Y/M/d') + 'txt').split("\n");
14         // first just convert them..
15         // we had an old bug that did not put line breaks in there..
16         // however 00:00:00: is pretty distinct, so let'st try and split on it..
17         
18         
19         
20         
21         for (var i = 0; i < lines.length; i++) {
22             var xl = lines[i].split(/([0-9]{2}:[0-9]{2}:[0-9]{2})/);
23             
24             
25             
26             lines[i] = this.parseLine(lines[i]);
27             if (i > 0) {
28                 lines[i-1].span = lines[i].start - lines[i-1].start; // should be seconds..?
29             }
30         };
31         // summarize data...
32         var hours = {};
33         for (var i = 0; i < lines.length; i++) {
34             var line = lines[i];
35             var hour = hours[line].start.format('H');
36             hours[hour] = (typeof(hours[hour]) == 'undefined') ? {} : hours[hour];
37             hours[hour][project] = (typeof(hours[project]) == 'undefined') ? 
38                     { total : 0, items : [] } 
39                     : hours[project];
40             hours[hour][project].total += line.span;
41             hours[hour][project].items.push(line);
42         }
43         return hours;
44
45     },
46     parseLine : function(l) 
47     {
48         var ret = { cmd : false,  line : l };
49         var ar = l.split(/\S+/);
50         var time = ar.shift();
51         ret.start = xDate.Date.parseDate(this.date.format('Y-m-d') + ' ' + time, 'Y-m-d H:i:s');
52
53
54         while (ret.cmd !== false) {
55             var ta = ar.pop();
56             if (ta == 'false'  || ta[0] == '/') {
57                 ret.cmd = ta;
58                 break;
59             }
60             if (!ar.length) {
61                 throw "invalid line: " + l;
62             }
63
64         }
65         ret.title = ar.join(' ');
66         if (ret.title == 'IDLE') {
67             ret.project = 'IDLE';
68             return ret;        
69         }
70                 
71         
72
73         if (typeof(this[ret.cmd])=='undefined') {
74             throw "Unknown application: " + ret.line;
75         }
76         if (typeof(this[ret.cmd])=='string') {
77             ret.project = this[ret.cmd]  
78         } else {
79
80             this[ret.cmd](ret);
81         }
82
83
84         return ret;
85
86     },
87
88     '/usr/bin/perl' : function(ret) {
89         if (ret.title.match(/^PAC/)) {
90             ret.project = 'Unknown';
91             return;
92         }
93         throw "Unknown match: " + ret.line;
94     },
95     '/usr/lib/icedove/icedove-bin' : 'Checking Mail',
96     '/usr/lib/chromium/chromium' : function (ret) {
97
98           switch(true) {
99
100                 case (ret.title.match(/Media Clipping Portal/)):
101                     ret.project = 'Media Outreach';
102                     return;
103                 
104                 default:
105                     ret.project = 'Browsing';
106                     return;
107           }
108
109     },
110     '/usr/lib/Komodo-Edit-7/lib/mozilla/komodo' : function(ret) {
111           var l = ret.title.match(/Project\s+(^\)+)/);
112           print(l);
113               
114          throw "Unknown match: " + ret.line;
115     },
116     'guake' : 'Local Terminal',
117
118
119 }
120
121 var res = GitLogParser.parse(xDate.Date.parseDate('2012-07-31', 'Y-m-d'));
122 print(JSON.stringify(res,null,4));
123
124 // open file..
125
126 // read lines
127
128 // summarize each hour
129
130 //convert line into 'Project / filename'
131
132