]> git.ipfire.org Git - thirdparty/git.git/blame - builtin/for-each-ref.c
Merge branch 'ak/rebase-autosquash'
[thirdparty/git.git] / builtin / for-each-ref.c
CommitLineData
baffc0e7 1#include "builtin.h"
b2141fc1 2#include "config.h"
f394e093 3#include "gettext.h"
9f613ddd
JH
4#include "refs.h"
5#include "object.h"
c3428da8 6#include "parse-options.h"
69b1cf91 7#include "ref-filter.h"
88e4e183 8#include "strbuf.h"
b73dec55 9#include "strvec.h"
49abcd21 10#include "commit-reach.h"
9f613ddd 11
c3428da8 12static char const * const for_each_ref_usage[] = {
9c9b4f2f 13 N_("git for-each-ref [<options>] [<pattern>]"),
d325406e 14 N_("git for-each-ref [--points-at <object>]"),
21bf9339 15 N_("git for-each-ref [--merged [<commit>]] [--no-merged [<commit>]]"),
ac3f5a34 16 N_("git for-each-ref [--contains [<commit>]] [--no-contains [<commit>]]"),
c3428da8
PH
17 NULL
18};
19
20int cmd_for_each_ref(int argc, const char **argv, const char *prefix)
9f613ddd 21{
98e7ab6d
JH
22 struct ref_sorting *sorting;
23 struct string_list sorting_options = STRING_LIST_INIT_DUP;
9d4fcfe1 24 int icase = 0;
b9f7daa6 25 struct ref_filter filter = REF_FILTER_INIT;
4a68e36d 26 struct ref_format format = REF_FORMAT_INIT;
b73dec55
DS
27 int from_stdin = 0;
28 struct strvec vec = STRVEC_INIT;
9f613ddd 29
c3428da8 30 struct option opts[] = {
4a68e36d 31 OPT_BIT('s', "shell", &format.quote_style,
18913521 32 N_("quote placeholders suitably for shells"), QUOTE_SHELL),
4a68e36d 33 OPT_BIT('p', "perl", &format.quote_style,
18913521 34 N_("quote placeholders suitably for perl"), QUOTE_PERL),
4a68e36d 35 OPT_BIT(0 , "python", &format.quote_style,
18913521 36 N_("quote placeholders suitably for python"), QUOTE_PYTHON),
4a68e36d 37 OPT_BIT(0 , "tcl", &format.quote_style,
b799a696 38 N_("quote placeholders suitably for Tcl"), QUOTE_TCL),
9d4fcfe1 39 OPT_BOOL(0, "omit-empty", &format.array_opts.omit_empty,
aabfdc95 40 N_("do not output a newline after empty formatted refs")),
c3428da8
PH
41
42 OPT_GROUP(""),
9d4fcfe1 43 OPT_INTEGER( 0 , "count", &format.array_opts.max_count, N_("show only <n> matched refs")),
4a68e36d 44 OPT_STRING( 0 , "format", &format.format, N_("format"), N_("format to use for the output")),
0c88bf50 45 OPT__COLOR(&format.use_color, N_("respect format colors")),
8255dd8a 46 OPT_REF_FILTER_EXCLUDE(&filter),
98e7ab6d 47 OPT_REF_SORT(&sorting_options),
d325406e
KN
48 OPT_CALLBACK(0, "points-at", &filter.points_at,
49 N_("object"), N_("print only refs which points at the given object"),
50 parse_opt_object_name),
7c328348
KN
51 OPT_MERGED(&filter, N_("print only refs that are merged")),
52 OPT_NO_MERGED(&filter, N_("print only refs that are not merged")),
4a71109a 53 OPT_CONTAINS(&filter.with_commit, N_("print only refs which contain the commit")),
ac3f5a34 54 OPT_NO_CONTAINS(&filter.no_commit, N_("print only refs which don't contain the commit")),
3bb16a8b 55 OPT_BOOL(0, "ignore-case", &icase, N_("sorting and filtering are case insensitive")),
b73dec55 56 OPT_BOOL(0, "stdin", &from_stdin, N_("read reference patterns from stdin")),
c3428da8
PH
57 OPT_END(),
58 };
59
4a68e36d
JK
60 format.format = "%(objectname) %(objecttype)\t%(refname)";
61
d8b68686
JK
62 git_config(git_default_config, NULL);
63
56d26ade
VD
64 /* Set default (refname) sorting */
65 string_list_append(&sorting_options, "refname");
66
37782920 67 parse_options(argc, argv, prefix, opts, for_each_ref_usage, 0);
9d4fcfe1
VD
68 if (format.array_opts.max_count < 0) {
69 error("invalid --count argument: `%d'", format.array_opts.max_count);
c3428da8 70 usage_with_options(for_each_ref_usage, opts);
9f613ddd 71 }
4a68e36d 72 if (HAS_MULTI_BITS(format.quote_style)) {
c9ecf4f1 73 error("more than one quoting style?");
c3428da8
PH
74 usage_with_options(for_each_ref_usage, opts);
75 }
4a68e36d 76 if (verify_ref_format(&format))
c3428da8 77 usage_with_options(for_each_ref_usage, opts);
9f613ddd 78
98e7ab6d 79 sorting = ref_sorting_options(&sorting_options);
7c269a7b 80 ref_sorting_set_sort_flags_all(sorting, REF_SORTING_ICASE, icase);
3bb16a8b 81 filter.ignore_case = icase;
9f613ddd 82
b73dec55
DS
83 if (from_stdin) {
84 struct strbuf line = STRBUF_INIT;
85
86 if (argv[0])
87 die(_("unknown arguments supplied with --stdin"));
88
89 while (strbuf_getline(&line, stdin) != EOF)
90 strvec_push(&vec, line.buf);
91
92 strbuf_release(&line);
93
94 /* vec.v is NULL-terminated, just like 'argv'. */
95 filter.name_patterns = vec.v;
96 } else {
97 filter.name_patterns = argv;
98 }
99
bef0e12b 100 filter.match_as_path = 1;
e7574b0c 101 filter_and_format_refs(&filter, FILTER_REFS_ALL, sorting, &format);
844c3f0b 102
b571fb98 103 ref_filter_clear(&filter);
e5fb0286 104 ref_sorting_release(sorting);
b73dec55 105 strvec_clear(&vec);
9f613ddd
JH
106 return 0;
107}