Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with
or
.
Download ZIP
A git query language
Go
Branch: develop

README.md

Gitql Build Status

Gitql is a Git query language.
In a repository path ...

how to use

See more here

Requirements

  • Go
  • cmake

Install

  • go get -u -d github.com/cloudson/gitql
  • cd $GOPATH/src/github.com/cloudson/gitql
  • make
  • sudo make install
  • export LD_LIBRARY_PATH=$PWD/libgit2/install/lib on linux or export DYLD_LIBRARY_PATH=$PWD/libgit2/install/libon Mac OS.

Examples

gitql "your query"
or
git ql "your query"

Look the table of commits:

commits
author
author_email
committer
committer_email
hash
date
message
full_message

(see more tables here)

You can do:

  • select hash, author, message from commits limit 3
  • select hash, message from commits where 'hell' in full_message or 'Fuck' in full_message
  • select hash, message, author_email from commits where author = 'cloudson'
  • select date, message from commits where date < '2014-04-10'
  • select message from commits where 'hell' in message order by date asc

Questions?

gitql -h or open an issue

Notes:

  • Gitql doesn't want kill git log :sweat_smile: . It was created just for science!!
  • It's read-only. Nothing about delete, insert or update commits :stuck_out_tongue_closed_eyes:
  • The limit default is 10 rows
  • It's inspired by textql
  • But, why gitql is a compiler/interpreter instead of just read a sqlite database with all commits, tags and etc? Answer: Because we would need to sync the tables everytime before run sql and we would have sqlite bases for each repository. :neutral_face:
Something went wrong with that request. Please try again.