]> git.ipfire.org Git - thirdparty/git.git/blame - common-main.c
treewide: be explicit about dependence on strbuf.h
[thirdparty/git.git] / common-main.c
CommitLineData
57f5d52a 1#include "cache.h"
d807c4a0 2#include "exec-cmd.h"
f394e093 3#include "gettext.h"
1a600b75 4#include "attr.h"
e38da487 5#include "setup.h"
69a63fe6 6#include "strbuf.h"
74ea5c95 7#include "trace2.h"
3f2e2297 8
12e0437f
JK
9/*
10 * Many parts of Git have subprograms communicate via pipe, expect the
11 * upstream of a pipe to die with SIGPIPE when the downstream of a
12 * pipe does not need to read all that is written. Some third-party
13 * programs that ignore or block SIGPIPE for their own reason forget
14 * to restore SIGPIPE handling to the default before spawning Git and
15 * break this carefully orchestrated machinery.
16 *
17 * Restore the way SIGPIPE is handled to default, which is what we
18 * expect.
19 */
20static void restore_sigpipe_to_default(void)
21{
22 sigset_t unblock;
23
24 sigemptyset(&unblock);
25 sigaddset(&unblock, SIGPIPE);
26 sigprocmask(SIG_UNBLOCK, &unblock, NULL);
27 signal(SIGPIPE, SIG_DFL);
28}
29
08aade70 30int main(int argc, const char **argv)
3f2e2297 31{
ee4512ed 32 int result;
e6f8861b 33 struct strbuf tmp = STRBUF_INIT;
ee4512ed 34
a0897249
JH
35 trace2_initialize_clock();
36
57f5d52a
JK
37 /*
38 * Always open file descriptors 0/1/2 to avoid clobbering files
39 * in die(). It also avoids messing up when the pipes are dup'ed
40 * onto stdin/stdout/stderr in the child processes we spawn.
41 */
42 sanitize_stdfds();
ee4512ed
JH
43 restore_sigpipe_to_default();
44
a7bc01eb
JH
45 git_resolve_executable_dir(argv[0]);
46
1819ad32 47 setlocale(LC_CTYPE, "");
5ce5f5fa
JK
48 git_setup_gettext();
49
b2f0ecee
NTND
50 initialize_the_repository();
51
1a600b75
BW
52 attr_start();
53
5732f2b1
JK
54 trace2_initialize();
55 trace2_cmd_start(argv);
56 trace2_collect_process_info(TRACE2_PROCESS_INFO_STARTUP);
57
e6f8861b
EN
58 if (!strbuf_getcwd(&tmp))
59 tmp_original_cwd = strbuf_detach(&tmp, NULL);
60
ee4512ed
JH
61 result = cmd_main(argc, argv);
62
19d75948
ÆAB
63 /* Not exit(3), but a wrapper calling our common_exit() */
64 exit(result);
65}
66
0cc05b04
ÆAB
67static void check_bug_if_BUG(void)
68{
69 if (!bug_called_must_BUG)
70 return;
71 BUG("on exit(): had bug() call(s) in this process without explicit BUG_if_bug()");
72}
73
19d75948
ÆAB
74/* We wrap exit() to call common_exit() in git-compat-util.h */
75int common_exit(const char *file, int line, int code)
76{
368b5843 77 /*
19d75948
ÆAB
78 * For non-POSIX systems: Take the lowest 8 bits of the "code"
79 * to e.g. turn -1 into 255. On a POSIX system this is
80 * redundant, see exit(3) and wait(2), but as it doesn't harm
81 * anything there we don't need to guard this with an "ifdef".
368b5843 82 */
19d75948
ÆAB
83 code &= 0xff;
84
0cc05b04 85 check_bug_if_BUG();
19d75948
ÆAB
86 trace2_cmd_exit_fl(file, line, code);
87
88 return code;
3f2e2297 89}