 4945f046c7
			
		
	
	4945f046c7
	
	
	
		
			
			In f6d25d7878 (api docs: document that BUG() emits a trace2 error event,
2021-04-13), a link to the plain text version of api-trace2 was added in
`technical/api-error-handling.txt`.
All of our other `link:`s point to the html versions.  Do the same here.
Signed-off-by: Todd Zullinger <tmz@pobox.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
	
		
			
				
	
	
		
			104 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			104 lines
		
	
	
		
			3.7 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| Error reporting in git
 | |
| ======================
 | |
| 
 | |
| `BUG`, `bug`, `die`, `usage`, `error`, and `warning` report errors of
 | |
| various kinds.
 | |
| 
 | |
| - `BUG` is for failed internal assertions that should never happen,
 | |
|   i.e. a bug in git itself.
 | |
| 
 | |
| - `bug` (lower-case, not `BUG`) is supposed to be used like `BUG` but
 | |
|   prints a "BUG" message instead of calling `abort()`.
 | |
| +
 | |
| A call to `bug()` will then result in a "real" call to the `BUG()`
 | |
| function, either explicitly by invoking `BUG_if_bug()` after call(s)
 | |
| to `bug()`, or implicitly at `exit()` time where we'll check if we
 | |
| encountered any outstanding `bug()` invocations.
 | |
| +
 | |
| If there were no prior calls to `bug()` before invoking `BUG_if_bug()`
 | |
| the latter is a NOOP. The `BUG_if_bug()` function takes the same
 | |
| arguments as `BUG()` itself. Calling `BUG_if_bug()` explicitly isn't
 | |
| necessary, but ensures that we die as soon as possible.
 | |
| +
 | |
| If you know you had prior calls to `bug()` then calling `BUG()` itself
 | |
| is equivalent to calling `BUG_if_bug()`, the latter being a wrapper
 | |
| calling `BUG()` if we've set a flag indicating that we've called
 | |
| `bug()`.
 | |
| +
 | |
| This is for the convenience of APIs who'd like to potentially report
 | |
| more than one "bug", such as the optbug() validation in
 | |
| parse-options.c.
 | |
| 
 | |
| - `die` is for fatal application errors.  It prints a message to
 | |
|   the user and exits with status 128.
 | |
| 
 | |
| - `usage` is for errors in command line usage.  After printing its
 | |
|   message, it exits with status 129.  (See also `usage_with_options`
 | |
|   in the link:api-parse-options.html[parse-options API].)
 | |
| 
 | |
| - `error` is for non-fatal library errors.  It prints a message
 | |
|   to the user and returns -1 for convenience in signaling the error
 | |
|   to the caller.
 | |
| 
 | |
| - `warning` is for reporting situations that probably should not
 | |
|   occur but which the user (and Git) can continue to work around
 | |
|   without running into too many problems.  Like `error`, it
 | |
|   returns -1 after reporting the situation to the caller.
 | |
| 
 | |
| These reports will be logged via the trace2 facility. See the "error"
 | |
| event in link:api-trace2.html[trace2 API].
 | |
| 
 | |
| Customizable error handlers
 | |
| ---------------------------
 | |
| 
 | |
| The default behavior of `die` and `error` is to write a message to
 | |
| stderr and then exit or return as appropriate.  This behavior can be
 | |
| overridden using `set_die_routine` and `set_error_routine`.  For
 | |
| example, "git daemon" uses set_die_routine to write the reason `die`
 | |
| was called to syslog before exiting.
 | |
| 
 | |
| Library errors
 | |
| --------------
 | |
| 
 | |
| Functions return a negative integer on error.  Details beyond that
 | |
| vary from function to function:
 | |
| 
 | |
| - Some functions return -1 for all errors.  Others return a more
 | |
|   specific value depending on how the caller might want to react
 | |
|   to the error.
 | |
| 
 | |
| - Some functions report the error to stderr with `error`,
 | |
|   while others leave that for the caller to do.
 | |
| 
 | |
| - errno is not meaningful on return from most functions (except
 | |
|   for thin wrappers for system calls).
 | |
| 
 | |
| Check the function's API documentation to be sure.
 | |
| 
 | |
| Caller-handled errors
 | |
| ---------------------
 | |
| 
 | |
| An increasing number of functions take a parameter 'struct strbuf *err'.
 | |
| On error, such functions append a message about what went wrong to the
 | |
| 'err' strbuf.  The message is meant to be complete enough to be passed
 | |
| to `die` or `error` as-is.  For example:
 | |
| 
 | |
| 	if (ref_transaction_commit(transaction, &err))
 | |
| 		die("%s", err.buf);
 | |
| 
 | |
| The 'err' parameter will be untouched if no error occurred, so multiple
 | |
| function calls can be chained:
 | |
| 
 | |
| 	t = ref_transaction_begin(&err);
 | |
| 	if (!t ||
 | |
| 	    ref_transaction_update(t, "HEAD", ..., &err) ||
 | |
| 	    ret_transaction_commit(t, &err))
 | |
| 		die("%s", err.buf);
 | |
| 
 | |
| The 'err' parameter must be a pointer to a valid strbuf.  To silence
 | |
| a message, pass a strbuf that is explicitly ignored:
 | |
| 
 | |
| 	if (thing_that_can_fail_in_an_ignorable_way(..., &err))
 | |
| 		/* This failure is okay. */
 | |
| 		strbuf_reset(&err);
 |