Cool! I was actually just looking for a tool like this a couple of weeks ago. I stumbled across git-cal[1], which only works on one repository at a time, but it doesn't require you to import your commits first like this one does[2].
Here's my output from both tools, generated from the repo I spend most of my time in at work: http://i.imgur.com/chrmeP6.png.
I'm only half-awake, so maybe I'm missing something obvious. Why is the README talking about a git commit hook? Why not just take the data from the log?
It seems like for performance reasons, git-stats wants to update the calendar on commit instead of generating it on the fly. git-cal[0] just does this on the fly and works reasonably fast for me. The UI looks very comparable.
Hmm, just installed git-cal and it certainly is adequately fast on my main work repo. But it seems to just be for the current branch? (That seems sensible enough, but also makes it somewhat less useful.)
Looks like that he parses the log with the hook and then stores the json output in ~/.git-stats (git-stats --record), my guess is that he then generates the calendar only from that data so that he doesn't have to parse the whole history all over again. I'm a bit worried about the size of that file though...
I like the commit streak statistic because, when I attempt to maintain a long streak, I get into the habit of committing something - even something small - once a day. Once I've made even the slightest change, I'm more likely to keep working. I find that it's a good motivator.
I would love it if, for things like my work repo, I could count "Don't break the chain of weekday commits" -- I would prefer not to be penalized for not working on the weekend. :)
It's totally superficial, but I find it fun. It's something to check once in a while and be like "hey, I have a dark green box. I wonder how many times I committed that day."
When I left my previous job, they revoked my Github access and I lost 3k commits on the calendar and it was a bummer. I wasn't throwing a fit or anything. I just had to start over :).
Cool, I always enjoy clever git visualisation tools. While you are immersed in code it's hard to get a good grasp on what are your routines, or on what you've accomplished, and these tools give you a nice picture of that - and I've found them rather useful on retrospective or post-mortem moments.
git-stats-importer also only imports commits by the user set in the global user.email config. Since you haven't made any commits to the git-stats repo, it doesn't show anything.
Edit: it will use the local user.email if that is set. It also will use the GIT_AUTHOR_EMAIL but only as a fallback if user.email is unset
Awesome stuff, I really like this for the following reason:
While I do push data to github for various projects, I actually take part in 3-4 active, self-hosted redmine projects that would never be counted in the github graph. Same for a seldom-updated bitbucket project.
I find it funny that I was down-voted so for this. I haven't maligned the project at all; in fact, I think it's incredibly cool, I'm just not a huge fan of node.
I downvoted you because negative nonconstructive comments may as well not be posted. They provide no tangible benefit to anyone who participates in the discussion.
If you have a compelling reason as to why this project would be better done in another language then it would be prudent to include this reason in your original post. If all you're going off is personal preference then it may be best to keep this to yourself.
I understand your hope for comments to be constructive, and if you would like to have a discussion about the negatives of Node, it seems like that might be better on an article actually discussing that (though I will include them in this post to sate your curiosity :P). Additionally, I did not wish to start a flamewar (which always happens when you get into a discussion about the relative merits of a language on the internet).
My reservations about Node stem from this kind of app actually; the creation of a tool that goes far beyond the realistic and sensible use-case for Node.
That is, the huge benefit that Node offers is the ability to have both server- and client-side scripting in the same language; that's awesome. However, it's a fairly common bit of knowledge that JS is less than ideal for a wide variety of reasons (e.g., no integers, breaking the commutative property, etc.). While it may be a great alternative to PHP, it's still not that great of a language. So, to go beyond the notion of just using it to unify the language for webapps and to start creating userland applications on such a platform seems very counterproductive to me.
In this case, I am especially taken by the fact that this author has made three or four projects which all do similar things but for different use-cases. If this project were made into, for example, a C library, all of the derivative projects could just source that library and be simpler for it. Not to mention the fact that other projects could interface with it as well.
Despite C's reputation as being rather hard to make portable code, a public API with a C library actually makes it incredibly portable and extensible.
Again, I am completely okay with Node (I don't crusade against its existence), it just saddens me to see such cool projects be based on such a platform when there are obvious benefits to using something closer to the metal.
Actually, if you look at the project more closely, it does support github. In fact, there's even a derivative project that directly interacts with github. However, I think the point of this poster's comment was that this project's scope doens't include ey's needs, not that it doesn't interface with a particular service (I, of course, could be wrong in that interpretation).
Here's my output from both tools, generated from the repo I spend most of my time in at work: http://i.imgur.com/chrmeP6.png.
[1] https://github.com/k4rthik/git-cal
[2] https://github.com/IonicaBizau/git-stats#importing-and-delet...
EDIT: Just noticed that the "contributions" counts differ.
But git-stats shows 1292. What does it count as a contribution?