Browse Source

Merge branch 'js/wrap-log'

* js/wrap-log:
  Fix permissions on test scripts
  Fix t4201: accidental arithmetic expansion
  shortlog -w: make wrap-line behaviour optional.
  Use print_wrapped_text() in shortlog
maint
Junio C Hamano 18 years ago
parent
commit
aa36985161
  1. 73
      builtin-shortlog.c
  2. 0
      t/diff-lib.sh
  3. 0
      t/lib-read-tree-m-3way.sh
  4. 50
      t/t4201-shortlog.sh
  5. 0
      t/t6023-merge-file.sh
  6. 0
      t/t6024-recursive-merge.sh
  7. 0
      t/t6025-merge-symlinks.sh
  8. 0
      t/test-lib.sh

73
builtin-shortlog.c

@ -4,6 +4,7 @@ @@ -4,6 +4,7 @@
#include "diff.h"
#include "path-list.h"
#include "revision.h"
#include "utf8.h"

static const char shortlog_usage[] =
"git-shortlog [-n] [-s] [<commit-id>... ]";
@ -276,11 +277,64 @@ static void get_from_rev(struct rev_info *rev, struct path_list *list) @@ -276,11 +277,64 @@ static void get_from_rev(struct rev_info *rev, struct path_list *list)

}

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) {
@ -289,6 +343,10 @@ int cmd_shortlog(int argc, const char **argv, const char *prefix) @@ -289,6 +343,10 @@ int cmd_shortlog(int argc, const char **argv, const char *prefix)
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
@ -323,9 +381,18 @@ int cmd_shortlog(int argc, const char **argv, const char *prefix) @@ -323,9 +381,18 @@ int cmd_shortlog(int argc, const char **argv, const char *prefix)
printf("%s: %d\n", list.items[i].path, onelines->nr);
} else {
printf("%s (%d):\n", list.items[i].path, onelines->nr);
for (j = onelines->nr - 1; j >= 0; j--)
printf(" %s\n", onelines->items[j].path);
printf("\n");
for (j = onelines->nr - 1; j >= 0; j--) {
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');
}

onelines->strdup_paths = 1;

0
t/diff-lib.sh

0
t/lib-read-tree-m-3way.sh

50
t/t4201-shortlog.sh

@ -0,0 +1,50 @@ @@ -0,0 +1,50 @@
#!/bin/sh
#
# Copyright (c) 2006 Johannes E. Schindelin
#

test_description='git-shortlog
'

. ./test-lib.sh

echo 1 > a1
git add a1
tree=$(git write-tree)
commit=$( (echo "Test"; echo) | git commit-tree $tree )
git update-ref HEAD $commit

echo 2 > a1
git commit -m "This is a very, very long first line for the commit message to see if it is wrapped correctly" a1

# test if the wrapping is still valid when replacing all i's by treble clefs.
echo 3 > a1
git commit -m "$(echo "This is a very, very long first line for the commit message to see if it is wrapped correctly" | sed "s/i/1234/g" | tr 1234 '\360\235\204\236')" a1

# now fsck up the utf8
git repo-config i18n.commitencoding non-utf-8
echo 4 > a1
git commit -m "$(echo "This is a very, very long first line for the commit message to see if it is wrapped correctly" | sed "s/i/1234/g" | tr 1234 '\370\235\204\236')" a1

echo 5 > a1
git commit -m "a 12 34 56 78" a1

git shortlog -w HEAD > out

cat > expect << EOF
A U Thor (5):
Test
This is a very, very long first line for the commit message to see if
it is wrapped correctly
Thð<EFBFBD>„žs ð<EFBFBD>„žs a very, very long fð<EFBFBD>„žrst lð<EFBFBD>„žne for the commð<EFBFBD>„žt message to see ð<EFBFBD>„žf
ð<EFBFBD>„žt ð<EFBFBD>„žs wrapped correctly
Thø<EFBFBD>„žs ø<EFBFBD>„žs a very, very long fø<EFBFBD>„žrst lø<EFBFBD>„žne for the commø<EFBFBD>„žt
message to see ø<EFBFBD>„žf ø<EFBFBD>„žt ø<EFBFBD>„žs wrapped correctly
a 12 34
56 78

EOF

test_expect_success 'shortlog wrapping' 'diff -u expect out'

test_done

0
t/t6023-merge-file.sh

0
t/t6024-recursive-merge.sh

0
t/t6025-merge-symlinks.sh

0
t/test-lib.sh

Loading…
Cancel
Save