diff options
| author | Ben Straub <bs@github.com> | 2013-10-10 13:56:28 -0700 |
|---|---|---|
| committer | Ben Straub <bs@github.com> | 2013-10-10 13:56:28 -0700 |
| commit | d2e7532f620acd467ebeef0b3c4318420f445a13 (patch) | |
| tree | db1c34492cfbcd8e459f2e813fdf8b69e8b8efdd /examples | |
| parent | 0a23d2058dc61a6d11e9da6aadf431d69e738601 (diff) | |
| download | libgit2-d2e7532f620acd467ebeef0b3c4318420f445a13.tar.gz | |
Be more flexible with argument order and format
Diffstat (limited to 'examples')
| -rw-r--r-- | examples/blame.c | 39 |
1 files changed, 31 insertions, 8 deletions
diff --git a/examples/blame.c b/examples/blame.c index a7d0a12a5..6423b3ca6 100644 --- a/examples/blame.c +++ b/examples/blame.c @@ -17,7 +17,7 @@ static void usage(const char *msg, const char *arg) fprintf(stderr, "%s: %s\n", msg, arg); else if (msg) fprintf(stderr, "%s\n", msg); - fprintf(stderr, "usage: blame <path> [options] [<commit range>]\n"); + fprintf(stderr, "usage: blame [options] [<commit range>] <path>\n"); fprintf(stderr, "\n"); fprintf(stderr, " <commit range> example: `HEAD~10..HEAD`, or `1234abcd`\n"); fprintf(stderr, " -L <n,m> process only line range n-m, counting from 1\n"); @@ -30,8 +30,8 @@ static void usage(const char *msg, const char *arg) int main(int argc, char *argv[]) { int i, line; - char *path = NULL, *a; - const char *rawdata, *commitspec=NULL; + const char *path = NULL, *a; + const char *rawdata, *commitspec=NULL, *bare_args[3] = {0}; char spec[1024] = {0}; git_repository *repo = NULL; git_revspec revspec = {0}; @@ -42,16 +42,24 @@ int main(int argc, char *argv[]) git_threads_init(); if (argc < 2) usage(NULL, NULL); - path = argv[1]; - for (i=2; i<argc; i++) { + for (i=1; i<argc; i++) { a = argv[i]; - if (!strcmp(a, "-M")) + if (a[0] != '-') { + int i=0; + while (bare_args[i] && i < 3) ++i; + if (i >= 3) + usage("Invalid argument set", NULL); + bare_args[i] = a; + } + else if (!strcmp(a, "--")) + continue; + else if (!strcasecmp(a, "-M")) opts.flags |= GIT_BLAME_TRACK_COPIES_SAME_COMMIT_MOVES; - else if (!strcmp(a, "-C")) + else if (!strcasecmp(a, "-C")) opts.flags |= GIT_BLAME_TRACK_COPIES_SAME_COMMIT_COPIES; - else if (!strcmp(a, "-L")) { + else if (!strcasecmp(a, "-L")) { i++; a = argv[i]; if (i >= argc) check(-1, "Not enough arguments to -L"); check(sscanf(a, "%d,%d", &opts.min_line, &opts.max_line)-2, "-L format error"); @@ -63,6 +71,21 @@ int main(int argc, char *argv[]) } } + /* Handle the bare arguments */ + if (!bare_args[0]) usage("Please specify a path", NULL); + path = bare_args[0]; + if (bare_args[1]) { + /* <commitspec> <path> */ + path = bare_args[1]; + commitspec = bare_args[0]; + } + if (bare_args[2]) { + /* <oldcommit> <newcommit> <path> */ + path = bare_args[2]; + sprintf(spec, "%s..%s", bare_args[0], bare_args[1]); + commitspec = spec; + } + /* Open the repo */ check(git_repository_open_ext(&repo, ".", 0, NULL), "Couldn't open repository"); |
