5 #include "parse-options.h"
9 #define BUILTIN_HOOK_RUN_USAGE \
10 N_("git hook run [--ignore-missing] <hook-name> [-- <hook-args>]")
12 static const char * const builtin_hook_usage
[] = {
13 BUILTIN_HOOK_RUN_USAGE
,
17 static const char * const builtin_hook_run_usage
[] = {
18 BUILTIN_HOOK_RUN_USAGE
,
22 static int run(int argc
, const char **argv
, const char *prefix
)
25 struct run_hooks_opt opt
= RUN_HOOKS_OPT_INIT
;
26 int ignore_missing
= 0;
27 const char *hook_name
;
28 struct option run_options
[] = {
29 OPT_BOOL(0, "ignore-missing", &ignore_missing
,
30 N_("silently ignore missing requested <hook-name>")),
35 argc
= parse_options(argc
, argv
, prefix
, run_options
,
36 builtin_hook_run_usage
,
37 PARSE_OPT_KEEP_DASHDASH
);
43 * Having a -- for "run" when providing <hook-args> is
46 if (argc
> 1 && strcmp(argv
[1], "--") &&
47 strcmp(argv
[1], "--end-of-options"))
50 /* Add our arguments, start after -- */
51 for (i
= 2 ; i
< argc
; i
++)
52 strvec_push(&opt
.args
, argv
[i
]);
54 /* Need to take into account core.hooksPath */
55 git_config(git_default_config
, NULL
);
59 opt
.error_if_missing
= 1;
60 ret
= run_hooks_opt(hook_name
, &opt
);
61 if (ret
< 0) /* error() return */
65 usage_with_options(builtin_hook_run_usage
, run_options
);
68 int cmd_hook(int argc
, const char **argv
, const char *prefix
)
70 struct option builtin_hook_options
[] = {
74 argc
= parse_options(argc
, argv
, NULL
, builtin_hook_options
,
75 builtin_hook_usage
, PARSE_OPT_STOP_AT_NON_OPTION
);
79 if (!strcmp(argv
[0], "run"))
80 return run(argc
, argv
, prefix
);
83 usage_with_options(builtin_hook_usage
, builtin_hook_options
);