Merge branch 'maint'
[git/git.git] / run-command.h
CommitLineData
b1bf95bb
JW
1#ifndef RUN_COMMAND_H
2#define RUN_COMMAND_H
3
b1bf95bb
JW
4enum {
5 ERR_RUN_COMMAND_FORK = 10000,
6 ERR_RUN_COMMAND_EXEC,
4919bf03 7 ERR_RUN_COMMAND_PIPE,
b1bf95bb
JW
8 ERR_RUN_COMMAND_WAITPID,
9 ERR_RUN_COMMAND_WAITPID_WRONG_PID,
10 ERR_RUN_COMMAND_WAITPID_SIGNAL,
11 ERR_RUN_COMMAND_WAITPID_NOEXIT,
12};
13
f1000898
SP
14struct child_process {
15 const char **argv;
ebcb5d16 16 pid_t pid;
4919bf03 17 int in;
f4bba25b 18 int out;
4919bf03 19 unsigned close_in:1;
f4bba25b 20 unsigned close_out:1;
f1000898 21 unsigned no_stdin:1;
e4507ae8 22 unsigned no_stdout:1;
f1000898
SP
23 unsigned git_cmd:1; /* if this is to be git sub-command */
24 unsigned stdout_to_stderr:1;
25};
26
ebcb5d16
SP
27int start_command(struct child_process *);
28int finish_command(struct child_process *);
f1000898
SP
29int run_command(struct child_process *);
30
95d3c4f5 31#define RUN_COMMAND_NO_STDIN 1
77cb17e9 32#define RUN_GIT_CMD 2 /*If this is to be git sub-command */
cd83c74c 33#define RUN_COMMAND_STDOUT_TO_STDERR 4
9b0b5093 34int run_command_v_opt(const char **argv, int opt);
b1bf95bb
JW
35
36#endif