Browse Source

Merge branch 'jg/auto-initialize-notes-with-percent-n-in-format'

* jg/auto-initialize-notes-with-percent-n-in-format:
  t3301: add tests to use --format="%N"
  pretty: Initialize notes if %N is used
maint
Junio C Hamano 15 years ago
parent
commit
779f9467eb
  1. 6
      builtin/log.c
  2. 5
      commit.h
  3. 40
      pretty.c
  4. 18
      t/t3301-notes.sh

6
builtin/log.c

@ -36,6 +36,7 @@ static void cmd_log_init(int argc, const char **argv, const char *prefix, @@ -36,6 +36,7 @@ static void cmd_log_init(int argc, const char **argv, const char *prefix,
{
int i;
int decoration_style = 0;
struct userformat_want w;

rev->abbrev = DEFAULT_ABBREV;
rev->commit_format = CMIT_FMT_DEFAULT;
@ -58,7 +59,10 @@ static void cmd_log_init(int argc, const char **argv, const char *prefix, @@ -58,7 +59,10 @@ static void cmd_log_init(int argc, const char **argv, const char *prefix,
usage(builtin_log_usage);
argc = setup_revisions(argc, argv, rev, opt);

if (!rev->show_notes_given && !rev->pretty_given)
memset(&w, 0, sizeof(w));
userformat_find_requirements(NULL, &w);

if (!rev->show_notes_given && (!rev->pretty_given || w.notes))
rev->show_notes = 1;
if (rev->show_notes)
init_display_notes(&rev->notes_opt);

5
commit.h

@ -74,11 +74,16 @@ struct pretty_print_context @@ -74,11 +74,16 @@ struct pretty_print_context
struct reflog_walk_info *reflog_info;
};

struct userformat_want {
unsigned notes:1;
};

extern int has_non_ascii(const char *text);
struct rev_info; /* in revision.h, it circularly uses enum cmit_fmt */
extern char *reencode_commit_message(const struct commit *commit,
const char **encoding_p);
extern void get_commit_format(const char *arg, struct rev_info *);
extern void userformat_find_requirements(const char *fmt, struct userformat_want *w);
extern void format_commit_message(const struct commit *commit,
const char *format, struct strbuf *sb,
const struct pretty_print_context *context);

40
pretty.c

@ -775,10 +775,13 @@ static size_t format_commit_one(struct strbuf *sb, const char *placeholder, @@ -775,10 +775,13 @@ static size_t format_commit_one(struct strbuf *sb, const char *placeholder,
}
return 0; /* unknown %g placeholder */
case 'N':
format_display_notes(commit->object.sha1, sb,
git_log_output_encoding ? git_log_output_encoding
: git_commit_encoding, 0);
return 1;
if (c->pretty_ctx->show_notes) {
format_display_notes(commit->object.sha1, sb,
git_log_output_encoding ? git_log_output_encoding
: git_commit_encoding, 0);
return 1;
}
return 0;
}

/* For the rest we have to parse the commit header. */
@ -855,6 +858,35 @@ static size_t format_commit_item(struct strbuf *sb, const char *placeholder, @@ -855,6 +858,35 @@ static size_t format_commit_item(struct strbuf *sb, const char *placeholder,
return consumed + 1;
}

static size_t userformat_want_item(struct strbuf *sb, const char *placeholder,
void *context)
{
struct userformat_want *w = context;

if (*placeholder == '+' || *placeholder == '-')
placeholder++;

switch (*placeholder) {
case 'N':
w->notes = 1;
break;
}
return 0;
}

void userformat_find_requirements(const char *fmt, struct userformat_want *w)
{
struct strbuf dummy = STRBUF_INIT;

if (!fmt) {
if (!user_format)
return;
fmt = user_format;
}
strbuf_expand(&dummy, user_format, userformat_want_item, w);
strbuf_release(&dummy);
}

void format_commit_message(const struct commit *commit,
const char *format, struct strbuf *sb,
const struct pretty_print_context *pretty_ctx)

18
t/t3301-notes.sh

@ -55,6 +55,15 @@ test_expect_success 'handle empty notes gracefully' ' @@ -55,6 +55,15 @@ test_expect_success 'handle empty notes gracefully' '
git notes show ; test 1 = $?
'

test_expect_success 'show non-existent notes entry with %N' '
for l in A B
do
echo "$l"
done >expect &&
git show -s --format='A%n%NB' >output &&
test_cmp expect output
'

test_expect_success 'create notes' '
git config core.notesRef refs/notes/commits &&
MSG=b4 git notes add &&
@ -65,6 +74,15 @@ test_expect_success 'create notes' ' @@ -65,6 +74,15 @@ test_expect_success 'create notes' '
test_must_fail git notes show HEAD^
'

test_expect_success 'show notes entry with %N' '
for l in A b4 B
do
echo "$l"
done >expect &&
git show -s --format='A%n%NB' >output &&
test_cmp expect output
'

cat >expect <<EOF
d423f8c refs/notes/commits@{0}: notes: Notes added by 'git notes add'
EOF

Loading…
Cancel
Save