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