4 `die`, `usage`, `error`, and `warning` report errors of various
7 - `die` is for fatal application errors. It prints a message to
8 the user and exits with status 128.
10 - `usage` is for errors in command line usage. After printing its
11 message, it exits with status 129. (See also `usage_with_options`
12 in the link:api-parse-options.html[parse-options API].)
14 - `error` is for non-fatal library errors. It prints a message
15 to the user and returns -1 for convenience in signaling the error
18 - `warning` is for reporting situations that probably should not
19 occur but which the user (and Git) can continue to work around
20 without running into too many problems. Like `error`, it
21 returns -1 after reporting the situation to the caller.
23 Customizable error handlers
24 ---------------------------
26 The default behavior of `die` and `error` is to write a message to
27 stderr and then exit or return as appropriate. This behavior can be
28 overridden using `set_die_routine` and `set_error_routine`. For
29 example, "git daemon" uses set_die_routine to write the reason `die`
30 was called to syslog before exiting.
35 Functions return a negative integer on error. Details beyond that
36 vary from function to function:
38 - Some functions return -1 for all errors. Others return a more
39 specific value depending on how the caller might want to react
42 - Some functions report the error to stderr with `error`,
43 while others leave that for the caller to do.
45 - errno is not meaningful on return from most functions (except
46 for thin wrappers for system calls).
48 Check the function's API documentation to be sure.
53 An increasing number of functions take a parameter 'struct strbuf *err'.
54 On error, such functions append a message about what went wrong to the
55 'err' strbuf. The message is meant to be complete enough to be passed
56 to `die` or `error` as-is. For example:
58 if (ref_transaction_commit(transaction, &err))
61 The 'err' parameter will be untouched if no error occured, so multiple
62 function calls can be chained:
64 t = ref_transaction_begin(&err);
66 ref_transaction_update(t, "HEAD", ..., &err) ||
67 ret_transaction_commit(t, &err))
70 The 'err' parameter must be a pointer to a valid strbuf. To silence
71 a message, pass a strbuf that is explicitly ignored:
73 if (thing_that_can_fail_in_an_ignorable_way(..., &err))
74 /* This failure is okay. */