diff options
| author | Ben Straub <bstraub@github.com> | 2012-05-10 13:40:53 -0700 | 
|---|---|---|
| committer | Ben Straub <bstraub@github.com> | 2012-05-11 11:35:50 -0700 | 
| commit | 2b35c45f1be2c5384100625ae7c2a31b5f75acb4 (patch) | |
| tree | b7e37335df5080ae78faecac32977f015483a3ba /src/revparse.c | |
| parent | 46c2ead05d289b4ed1ad96c63b75a228f02dd74c (diff) | |
| download | libgit2-2b35c45f1be2c5384100625ae7c2a31b5f75acb4.tar.gz | |
Rev-parse: now @{-N} syntax searches in the right direction!
Diffstat (limited to 'src/revparse.c')
| -rw-r--r-- | src/revparse.c | 32 | 
1 files changed, 19 insertions, 13 deletions
| diff --git a/src/revparse.c b/src/revparse.c index c22bd98d8..53cc7a347 100644 --- a/src/revparse.c +++ b/src/revparse.c @@ -130,7 +130,7 @@ static int walk_ref_history(git_object **out, git_repository *repo, const char *     git_reference *ref;     git_reflog *reflog = NULL;     int n, retcode = GIT_ERROR; -   size_t i, refloglen; +   int i, refloglen;     const git_reflog_entry *entry;     git_buf buf = GIT_BUF_INIT;     size_t refspeclen = strlen(refspec); @@ -144,6 +144,8 @@ static int walk_ref_history(git_object **out, git_repository *repo, const char *     /* "@{-N}" form means walk back N checkouts. That means the HEAD log. */     if (refspeclen == 0 && !git__prefixcmp(reflogspec, "@{-")) { +      regex_t regex; +        if (git__strtol32(&n, reflogspec+3, NULL, 0) < 0 ||            n < 1) {           giterr_set(GITERR_INVALID, "Invalid reflogspec %s", reflogspec); @@ -153,18 +155,22 @@ static int walk_ref_history(git_object **out, git_repository *repo, const char *        git_reflog_read(&reflog, ref);        git_reference_free(ref); -      refloglen = git_reflog_entrycount(reflog); -      for (i=0; i < refloglen; i++) { -         const char *msg; -         entry = git_reflog_entry_byindex(reflog, i); - -         msg = git_reflog_entry_msg(entry); -         if (!git__prefixcmp(msg, "checkout: moving")) { -            n--; -            if (!n) { -               char *branchname = strrchr(msg, ' ') + 1; -               retcode = revparse_lookup_object(out, repo, branchname); -               break; +      if (!regcomp(®ex, "checkout: moving from (.*) to .*", REG_EXTENDED)) { +         regmatch_t regexmatches[2]; + +         refloglen = git_reflog_entrycount(reflog); +         for (i=refloglen-1; i >= 0; i--) { +            const char *msg; +            entry = git_reflog_entry_byindex(reflog, i); + +            msg = git_reflog_entry_msg(entry); +            if (!regexec(®ex, msg, 2, regexmatches, 0)) { +               n--; +               if (!n) { +                  git_buf_put(&buf, msg+regexmatches[1].rm_so, regexmatches[1].rm_eo - regexmatches[1].rm_so); +                  retcode = revparse_lookup_object(out, repo, git_buf_cstr(&buf)); +                  break; +               }              }           }        } | 
