Browse Source

pretty.c: add %x00 format specifier.

This adds a %xXX format which inserts two hexdigits after %x as a byte
value in the resulting string.  This can be used to add a NUL byte or any
other byte that can make machine parsing easier.  It is also necessary to
use fwrite to print out the data since printf will terminate if you feed
it a NUL.

Signed-off-by: Govind Salinas <blix@sophiasuchtig.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
maint
Govind Salinas 17 years ago committed by Junio C Hamano
parent
commit
42c8c74c14
  1. 1
      Documentation/pretty-formats.txt
  2. 6
      log-tree.c
  3. 11
      pretty.c

1
Documentation/pretty-formats.txt

@ -123,3 +123,4 @@ The placeholders are:
- '%Creset': reset color - '%Creset': reset color
- '%m': left, right or boundary mark - '%m': left, right or boundary mark
- '%n': newline - '%n': newline
- '%x00': print a byte from a hex code

6
log-tree.c

@ -317,8 +317,10 @@ void show_log(struct rev_info *opt, const char *sep)
if (opt->show_log_size) if (opt->show_log_size)
printf("log size %i\n", (int)msgbuf.len); printf("log size %i\n", (int)msgbuf.len);


if (msgbuf.len) if (msgbuf.len) {
printf("%s%s%s", msgbuf.buf, extra, sep); fwrite(msgbuf.buf, sizeof(char), msgbuf.len, stdout);
printf("%s%s", extra, sep);
}
strbuf_release(&msgbuf); strbuf_release(&msgbuf);
} }



11
pretty.c

@ -457,6 +457,7 @@ static size_t format_commit_item(struct strbuf *sb, const char *placeholder,
const struct commit *commit = c->commit; const struct commit *commit = c->commit;
const char *msg = commit->buffer; const char *msg = commit->buffer;
struct commit_list *p; struct commit_list *p;
int h1, h2;


/* these are independent of the commit */ /* these are independent of the commit */
switch (placeholder[0]) { switch (placeholder[0]) {
@ -478,6 +479,16 @@ static size_t format_commit_item(struct strbuf *sb, const char *placeholder,
case 'n': /* newline */ case 'n': /* newline */
strbuf_addch(sb, '\n'); strbuf_addch(sb, '\n');
return 1; return 1;
case 'x':
/* %x00 == NUL, %x0a == LF, etc. */
if (0 <= (h1 = hexval_table[0xff & placeholder[1]]) &&
h1 <= 16 &&
0 <= (h2 = hexval_table[0xff & placeholder[2]]) &&
h2 <= 16) {
strbuf_addch(sb, (h1<<4)|h2);
return 3;
} else
return 0;
} }


/* these depend on the commit */ /* these depend on the commit */

Loading…
Cancel
Save