summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: 3714e7c)
raw | patch | inline | side by side (parent: 3714e7c)
author | Junio C Hamano <junkio@cox.net> | |
Sun, 8 Apr 2007 08:28:00 +0000 (01:28 -0700) | ||
committer | Junio C Hamano <junkio@cox.net> | |
Tue, 10 Apr 2007 19:48:35 +0000 (12:48 -0700) |
Signed-off-by: Junio C Hamano <junkio@cox.net>
builtin-shortlog.c | patch | blob | history | |
t/t4201-shortlog.sh | patch | blob | history |
diff --git a/builtin-shortlog.c b/builtin-shortlog.c
index 2cdd528967c4a0f545750698dd1afda1341bdb01..3f93498bb711ccaf1f8a1ad5ed9ac8e02958d357 100644 (file)
--- a/builtin-shortlog.c
+++ b/builtin-shortlog.c
}
+static int parse_uint(char const **arg, int comma)
+{
+ unsigned long ul;
+ int ret;
+ char *endp;
+
+ ul = strtoul(*arg, &endp, 10);
+ if (endp != *arg && *endp && *endp != comma)
+ return -1;
+ ret = (int) ul;
+ if (ret != ul)
+ return -1;
+ *arg = endp;
+ if (**arg)
+ (*arg)++;
+ return ret;
+}
+
+static const char wrap_arg_usage[] = "-w[<width>[,<indent1>[,<indent2>]]]";
+#define DEFAULT_WRAPLEN 76
+#define DEFAULT_INDENT1 6
+#define DEFAULT_INDENT2 9
+
+static void parse_wrap_args(const char *arg, int *in1, int *in2, int *wrap)
+{
+ arg += 2; /* skip -w */
+
+ *wrap = parse_uint(&arg, ',');
+ if (*wrap < 0)
+ die(wrap_arg_usage);
+ *in1 = parse_uint(&arg, ',');
+ if (*in1 < 0)
+ die(wrap_arg_usage);
+ *in2 = parse_uint(&arg, '\0');
+ if (*in2 < 0)
+ die(wrap_arg_usage);
+
+ if (!*wrap)
+ *wrap = DEFAULT_WRAPLEN;
+ if (!*in1)
+ *in1 = DEFAULT_INDENT1;
+ if (!*in2)
+ *in2 = DEFAULT_INDENT2;
+ if (*wrap &&
+ ((*in1 && *wrap <= *in1) ||
+ (*in2 && *wrap <= *in2)))
+ die(wrap_arg_usage);
+}
+
int cmd_shortlog(int argc, const char **argv, const char *prefix)
{
struct rev_info rev;
struct path_list list = { NULL, 0, 0, 1 };
int i, j, sort_by_number = 0, summary = 0;
+ int wrap_lines = 0;
+ int wrap = DEFAULT_WRAPLEN;
+ int in1 = DEFAULT_INDENT1;
+ int in2 = DEFAULT_INDENT2;
/* since -n is a shadowed rev argument, parse our args first */
while (argc > 1) {
else if (!strcmp(argv[1], "-s") ||
!strcmp(argv[1], "--summary"))
summary = 1;
+ else if (!prefixcmp(argv[1], "-w")) {
+ wrap_lines = 1;
+ parse_wrap_args(argv[1], &in1, &in2, &wrap);
+ }
else if (!strcmp(argv[1], "-h") || !strcmp(argv[1], "--help"))
usage(shortlog_usage);
else
} else {
printf("%s (%d):\n", list.items[i].path, onelines->nr);
for (j = onelines->nr - 1; j >= 0; j--) {
- int col = print_wrapped_text(onelines->items[j].path,
- 6, 9, 76);
- if (col != 76)
- putchar('\n');
+ const char *msg = onelines->items[j].path;
+
+ if (wrap_lines) {
+ int col = print_wrapped_text(msg, in1, in2, wrap);
+ if (col != wrap)
+ putchar('\n');
+ }
+ else
+ printf(" %s\n", msg);
}
putchar('\n');
}
diff --git a/t/t4201-shortlog.sh b/t/t4201-shortlog.sh
index ab8a0888f65df0ce99df8d6730c70c518cc85962..321429c8fa94b238c77d6a0bb41857b528876adf 100644 (file)
--- a/t/t4201-shortlog.sh
+++ b/t/t4201-shortlog.sh
echo 5 > a1
git commit -m "a 12 34 56 78" a1
-git shortlog HEAD > out
+git shortlog -w HEAD > out
cat > expect << EOF
A U Thor (5):