If set to true, the function line is printed on the same line as the first hunk header (but only if a hunk header is printed). Signed-off-by: Mark Lodato <lodatom@xxxxxxxxx> --- I was not sure if it would be better to have this as a configuration setting, a command-line option, or both. It probably doesn't matter for this round, since the main purpose of this post is to get the idea out there so people can try it out this feature see if they like it at all. There might have been a better way to implement this. Currently, we have the entire file in memory, so I could have just stored a pointer to the function name line, rather than copying it. Perhaps this would have been better? Also, I chose to only print the function name once, rather than duplicating it on each header, so as to reduce visual clutter. I can see an argument both ways, so if you would like to have the function name printed on every header, just remove the "opt->func_line[0] = '\0'" from the beginning of show_funcname_line(). Documentation/config.txt | 5 +++++ Documentation/git-grep.txt | 5 +++++ builtin/grep.c | 5 +++++ grep.c | 24 +++++++++++++++++++++++- grep.h | 3 +++ 5 files changed, 41 insertions(+), 1 deletion(-) diff --git a/Documentation/config.txt b/Documentation/config.txt index ade9503..1e3b5ec 100644 --- a/Documentation/config.txt +++ b/Documentation/config.txt @@ -1143,6 +1143,11 @@ grep.extendedRegexp:: grep.hunkHeading:: If set to true, enable '--hunk-heading' option by default. +grep.hunkHeadingFunction:: + If set to true, print the function name in the hunk heading rather + than on its own line. This only occurs when hunk headings would have + been shown and '--show-function' is used. + gpg.program:: Use this custom program instead of "gpg" found on $PATH when making or verifying a PGP signature. The program must support the diff --git a/Documentation/git-grep.txt b/Documentation/git-grep.txt index 26c085b..a32ac5e 100644 --- a/Documentation/git-grep.txt +++ b/Documentation/git-grep.txt @@ -46,6 +46,11 @@ grep.extendedRegexp:: grep.hunkHeading:: If set to true, enable '--hunk-heading' option by default. +grep.hunkHeadingFunction:: + If set to true, print the function name in the hunk heading rather + than on its own line. This only occurs when hunk headings would have + been shown and '--show-function' is used. + OPTIONS ------- diff --git a/builtin/grep.c b/builtin/grep.c index cdafc5a..d4c9f92 100644 --- a/builtin/grep.c +++ b/builtin/grep.c @@ -281,6 +281,11 @@ static int grep_config(const char *var, const char *value, void *cb) return 0; } + if (!strcmp(var, "grep.hunkheadingfunction")) { + opt->hunk_heading_function = git_config_bool(var, value); + return 0; + } + if (!strcmp(var, "grep.linenumber")) { opt->linenum = git_config_bool(var, value); return 0; diff --git a/grep.c b/grep.c index f0e00f7..49e66e3 100644 --- a/grep.c +++ b/grep.c @@ -1,6 +1,7 @@ #include "cache.h" #include "grep.h" #include "userdiff.h" +#include "utf8.h" #include "xdiff-interface.h" void append_header_grep_pattern(struct grep_opt *opt, enum grep_header_field field, const char *pat) @@ -776,6 +777,12 @@ static void show_line(struct grep_opt *opt, char *bol, char *eol, opt->output(opt, " ", 1); output_color(opt, "--", 2, opt->color_sep); } + if (opt->hunk_heading && opt->func_line[0] != '\0') { + opt->output(opt, " ", 1); + output_color(opt, opt->func_line, + strlen(opt->func_line), + opt->color_function); + } opt->output(opt, "\n", 1); } opt->last_shown = lno; @@ -882,6 +889,7 @@ static int match_funcname(struct grep_opt *opt, struct grep_source *gs, char *bo static void show_funcname_line(struct grep_opt *opt, struct grep_source *gs, char *bol, unsigned lno) { + opt->func_line[0] = '\0'; while (bol > gs->buf) { char *eol = --bol; @@ -893,7 +901,18 @@ static void show_funcname_line(struct grep_opt *opt, struct grep_source *gs, break; if (match_funcname(opt, gs, bol, eol)) { - show_line(opt, bol, eol, gs->name, lno, '='); + if (opt->hunk_heading_function && opt->hunk_heading && + opt->funcname && + (opt->pre_context || opt->post_context || + opt->funcbody)) { + unsigned long len = eol - bol; + if (len > GREP_MAX_FUNCLINE) + len = GREP_MAX_FUNCLINE; + len = utf8_truncate_line(bol, len); + memcpy(opt->func_line, bol, len); + opt->func_line[len] = '\0'; + } else + show_line(opt, bol, eol, gs->name, lno, '='); break; } } @@ -930,6 +949,8 @@ static void show_pre_context(struct grep_opt *opt, struct grep_source *gs, /* We need to look even further back to find a function signature. */ if (opt->funcname && funcname_needed) show_funcname_line(opt, gs, bol, cur); + else + opt->func_line[0] = '\0'; /* Back forward. */ while (cur < lno) { @@ -1034,6 +1055,7 @@ static int grep_source_1(struct grep_opt *opt, struct grep_source *gs, int colle opt->show_hunk_mark = 1; } opt->last_shown = 0; + opt->func_line[0] = '\0'; switch (opt->binary) { case GREP_BINARY_DEFAULT: diff --git a/grep.h b/grep.h index 761db2a..8112e07 100644 --- a/grep.h +++ b/grep.h @@ -118,6 +118,9 @@ struct grep_opt { int file_break; int heading; int hunk_heading; + int hunk_heading_function; +#define GREP_MAX_FUNCLINE 80 + char func_line[GREP_MAX_FUNCLINE+1]; void *priv; void (*output)(struct grep_opt *opt, const void *data, size_t size); -- 1.7.9.4 -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html