X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=rev-parse.c;h=7abad35de90b190c5d5e5456661853cf8167954a;hb=fc5be4fdaa063a667d17ae40e4ad130e2177b0f8;hp=adfc68c9be7b5ff2a8b576837048f4e9c034207b;hpb=c1aaa5d9ea4a148a964f8c4d6de8bc65f1dc44fd;p=git.git diff --git a/rev-parse.c b/rev-parse.c index adfc68c9..7abad35d 100644 --- a/rev-parse.c +++ b/rev-parse.c @@ -34,6 +34,7 @@ static int is_rev_argument(const char *arg) static const char *rev_args[] = { "--all", "--bisect", + "--dense", "--header", "--max-age=", "--max-count=", @@ -44,6 +45,7 @@ static int is_rev_argument(const char *arg) "--parents", "--pretty", "--show-breaks", + "--sparse", "--topo-order", "--unpacked", NULL @@ -129,25 +131,12 @@ static int show_reference(const char *refname, const unsigned char *sha1) static void show_datestring(const char *flag, const char *datestr) { - FILE *date; static char buffer[100]; - static char cmd[1000]; - int len; /* date handling requires both flags and revs */ if ((filter & (DO_FLAGS | DO_REVS)) != (DO_FLAGS | DO_REVS)) return; - len = strlen(flag); - memcpy(buffer, flag, len); - - snprintf(cmd, sizeof(cmd), "date --date=%s +%%s", sq_quote(datestr)); - date = popen(cmd, "r"); - if (!date || !fgets(buffer + len, sizeof(buffer) - len, date)) - die("git-rev-list: bad date string"); - pclose(date); - len = strlen(buffer); - if (buffer[len-1] == '\n') - buffer[--len] = 0; + snprintf(buffer, sizeof(buffer), "%s%lu", flag, approxidate(datestr)); show(buffer); } @@ -165,6 +154,7 @@ int main(int argc, char **argv) const char *prefix = setup_git_directory(); for (i = 1; i < argc; i++) { + struct stat st; char *arg = argv[i]; char *dotdot; @@ -227,6 +217,18 @@ int main(int argc, char **argv) puts(prefix); continue; } + if (!strcmp(arg, "--show-cdup")) { + const char *pfx = prefix; + while (pfx) { + pfx = strchr(pfx, '/'); + if (pfx) { + pfx++; + printf("../"); + } + } + putchar('\n'); + continue; + } if (!strcmp(arg, "--git-dir")) { const char *gitdir = getenv(GIT_DIR_ENVIRONMENT); static char cwd[PATH_MAX]; @@ -292,6 +294,9 @@ int main(int argc, char **argv) } if (verify) die("Needed a single revision"); + if (lstat(arg, &st) < 0) + die("'%s': %s", arg, strerror(errno)); + as_is = 1; show_file(arg); } show_default();