Signed-off-by: Thomas Ackermann <th.acker@arcor.de> Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
			
				
	
	
		
			76 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			76 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
Error reporting in git
 | 
						|
======================
 | 
						|
 | 
						|
`die`, `usage`, `error`, and `warning` report errors of various
 | 
						|
kinds.
 | 
						|
 | 
						|
- `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.
 | 
						|
 | 
						|
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);
 |