Error handling for libical.
More...
Go to the source code of this file.
|
#define | ICAL_ERRORS_ARE_FATAL 0 |
| Determines if all libical errors are fatal and lead to the process aborting.
|
|
#define | ICAL_SETERROR_ISFUNC |
|
#define | icalerrno (*(icalerrno_return())) |
| Access the current icalerrno value.
|
|
#define | icalerror_assert(test, message) |
| Assert with a message.
|
|
#define | icalerror_check_arg(test, arg) |
| Checks the assertion test and raises error on failure.
|
|
#define | icalerror_check_arg_re(test, arg, error) |
| Checks the assertion test and raises error on failure, returns error.
|
|
#define | icalerror_check_arg_rv(test, arg) |
| Checks the assertion test and raises error on failure, returns void.
|
|
#define | icalerror_check_arg_rx(test, arg, x) |
| Checks the assertion test and raises error on failure, returns x.
|
|
#define | icalerror_check_arg_rz(test, arg) |
| Checks the assertion test and raises error on failure, returns 0.
|
|
#define | icalerror_check_component_type(value, type) |
|
#define | icalerror_check_parameter_type(value, type) |
|
#define | icalerror_check_property_type(value, type) |
|
#define | icalerror_check_value_type(value, type) |
|
#define | icalerror_warn(message) |
| Prints a formatted warning message to stderr.
|
|
|
enum | icalerrorenum {
ICAL_NO_ERROR = 0
, ICAL_BADARG_ERROR
, ICAL_NEWFAILED_ERROR
, ICAL_ALLOCATION_ERROR
,
ICAL_MALFORMEDDATA_ERROR
, ICAL_PARSE_ERROR
, ICAL_INTERNAL_ERROR
, ICAL_FILE_ERROR
,
ICAL_USAGE_ERROR
, ICAL_UNIMPLEMENTED_ERROR
, ICAL_UNKNOWN_ERROR
} |
| Represents the different types of errors that can be triggered in libical. More...
|
|
enum | icalerrorstate { ICAL_ERROR_FATAL
, ICAL_ERROR_NONFATAL
, ICAL_ERROR_DEFAULT
, ICAL_ERROR_UNKNOWN
} |
| Determine if an error is fatal or non-fatal. More...
|
|
Error handling for libical.
Most routines will set the global error value icalerrno on errors. This variable is an enumeration; permissible values can be found in icalerror.h. If the routine returns an enum icalerrorenum, then the return value will be the same as icalerrno. You can use icalerror_strerror() to get a string that describes the error, or icalerror_perror() to get a string describing the current error set in icalerrno.
◆ ICAL_ERRORS_ARE_FATAL
#define ICAL_ERRORS_ARE_FATAL 0 |
Determines if all libical errors are fatal and lead to the process aborting.
If set to 1, all libical errors are fatal and lead to the process aborting upon encountering on. Otherwise, errors are nonfatal.
Can be checked with libical_get_errors_are_fatal().
◆ icalerrno
#define icalerrno (*(icalerrno_return())) |
Access the current icalerrno value.
- Returns
- The current icalerrno value
- Note
- Pseudo-variable that can be used to access the current icalerrno.
- Usage
}
@ ICAL_NO_ERROR
Definition icalerror.h:78
@ ICAL_PARSE_ERROR
Definition icalerror.h:93
#define icalerrno
Access the current icalerrno value.
Definition icalerror.h:144
◆ icalerror_assert
#define icalerror_assert |
( |
| test, |
|
|
| message ) |
Assert with a message.
- Parameters
-
test | The assertion to test |
message | The message to print on failure of assertion |
Tests the given assertion test, and if it fails, prints the message given on stderr as a warning and aborts the process. This only works if ICAL_ERRORS_ARE_FATAL is true, otherwise does nothing.
◆ icalerror_check_arg
#define icalerror_check_arg |
( |
| test, |
|
|
| arg ) |
Value:if (!(test)) { \
}
@ ICAL_BADARG_ERROR
Definition icalerror.h:81
Checks the assertion test and raises error on failure.
- Parameters
-
test | The assertion to check |
arg | The argument involved (as a string) |
This function checks the assertion test, which is used to test if the parameter arg is correct. If the assertion fails, it sets icalerrno to ICAL_BADARG_ERROR.
- Example
}
#define icalerror_check_arg(test, arg)
Checks the assertion test and raises error on failure.
Definition icalerror.h:441
Definition icalcomponent.c:36
◆ icalerror_check_arg_re
#define icalerror_check_arg_re |
( |
| test, |
|
|
| arg, |
|
|
| error ) |
Value:if (!(test)) { \
icalerror_stop_here(); \
assert(0); \
return error; \
}
Checks the assertion test and raises error on failure, returns error.
- Parameters
-
test | The assertion to check |
arg | The argument involved (as a string) |
error | What to return on error |
This function checks the assertion test, which is used to test if the parameter arg is correct. If the assertion fails, it aborts the process with assert(0)
and causes the enclosing function to return error.
- Example
return icalcomponent_get_first_real_component(component);
}
#define icalerror_check_arg_re(test, arg, error)
Checks the assertion test and raises error on failure, returns error.
Definition icalerror.h:518
◆ icalerror_check_arg_rv
#define icalerror_check_arg_rv |
( |
| test, |
|
|
| arg ) |
Value:if (!(test)) { \
return; \
}
Checks the assertion test and raises error on failure, returns void.
- Parameters
-
test | The assertion to check |
arg | The argument involved (as a string) |
This function checks the assertion test, which is used to test if the parameter arg is correct. If the assertion fails, it sets icalerrno to ICAL_BADARG_ERROR and causes the enclosing function to return void
.
- Example
}
#define icalerror_check_arg_rv(test, arg)
Checks the assertion test and raises error on failure, returns void.
Definition icalerror.h:465
◆ icalerror_check_arg_rx
#define icalerror_check_arg_rx |
( |
| test, |
|
|
| arg, |
|
|
| x ) |
Value:if (!(test)) { \
return x; \
}
Checks the assertion test and raises error on failure, returns x.
- Parameters
-
test | The assertion to check |
arg | The argument involved (as a string) |
x | What to return on error |
This function checks the assertion test, which is used to test if the parameter arg is correct. If the assertion fails, it sets icalerrno to ICAL_BADARG_ERROR and causes the enclosing function to return x.
- Example
return icalcomponent_get_first_real_component(component);
}
#define icalerror_check_arg_rx(test, arg, x)
Checks the assertion test and raises error on failure, returns x.
Definition icalerror.h:546
◆ icalerror_check_arg_rz
#define icalerror_check_arg_rz |
( |
| test, |
|
|
| arg ) |
Value:if (!(test)) { \
return 0; \
}
Checks the assertion test and raises error on failure, returns 0.
- Parameters
-
test | The assertion to check |
arg | The argument involved (as a string) |
This function checks the assertion test, which is used to test if the parameter arg is correct. If the assertion fails, it sets icalerrno to ICAL_BADARG_ERROR and causes the enclosing function to return 0
.
- Example
return icalcomponent_count_kinds(component, ICAL_ANY_COMPONENT);
}
#define icalerror_check_arg_rz(test, arg)
Checks the assertion test and raises error on failure, returns 0.
Definition icalerror.h:491
◆ icalerror_check_component_type
#define icalerror_check_component_type |
( |
| value, |
|
|
| type ) |
◆ icalerror_check_parameter_type
#define icalerror_check_parameter_type |
( |
| value, |
|
|
| type ) |
◆ icalerror_check_property_type
#define icalerror_check_property_type |
( |
| value, |
|
|
| type ) |
◆ icalerror_check_value_type
#define icalerror_check_value_type |
( |
| value, |
|
|
| type ) |
◆ icalerror_warn
#define icalerror_warn |
( |
| message | ) |
|
Value:{fprintf(stderr, "%s:%d: %s\n", __FILE__, __LINE__, message);}
Prints a formatted warning message to stderr.
- Parameters
-
message | Warning message to print |
- Usage
#define icalerror_warn(message)
Prints a formatted warning message to stderr.
Definition icalerror.h:192
◆ icalerrorenum
Represents the different types of errors that can be triggered in libical.
Each of these values represent a different type of error, which is stored in icalerrno on exit of the library function (or can be returned, but if it is, icalerrno is also set).
Enumerator |
---|
ICAL_NO_ERROR | No error happened.
|
ICAL_BADARG_ERROR | A bad argument was passed to a function.
|
ICAL_NEWFAILED_ERROR | An error occurred while creating a new object with a *_new() routine.
|
ICAL_ALLOCATION_ERROR | An error occurred while allocating some memory.
|
ICAL_MALFORMEDDATA_ERROR | Malformed data was passed to a function.
|
ICAL_PARSE_ERROR | An error occurred while parsing part of an iCal component.
|
ICAL_INTERNAL_ERROR | An internal error happened in library code.
|
ICAL_FILE_ERROR | An error happened while working with a file.
|
ICAL_USAGE_ERROR | Failure to properly sequence calls to a set of interfaces.
|
ICAL_UNIMPLEMENTED_ERROR | An unimplemented function was called.
|
ICAL_UNKNOWN_ERROR | An unknown error occurred.
|
◆ icalerrorstate
Determine if an error is fatal or non-fatal.
Enumerator |
---|
ICAL_ERROR_FATAL | Fatal.
|
ICAL_ERROR_NONFATAL | Non-fatal.
|
ICAL_ERROR_DEFAULT | Fatal if icalerror_errors_are_fatal(), non-fatal otherwise.
|
ICAL_ERROR_UNKNOWN | Asked state for an unknown error type.
|
◆ ical_bt()
Prints backtrace.
- Note
- Only works on systems that support it (HAVE_BACKTRACE enabled).
- Usage
-
◆ icalerrno_return()
Returns the current icalerrno value.
- Returns
- A pointer to the current icalerrno value
Yields a pointer to the current icalerrno value. This can be used to access (read from and write to) it.
- Examples
-
◆ icalerror_clear_errno()
void icalerror_clear_errno |
( |
void | | ) |
|
Resets icalerrno to ICAL_NO_ERROR.
- Usage
icalerror_clear_errno();
}
◆ icalerror_crash_here()
void icalerror_crash_here |
( |
void | | ) |
|
Triggered to abort the process.
This routine is called to abort the process in the case of an error.
◆ icalerror_error_from_string()
Reads an error from a string.
- Parameters
-
- Returns
- An icalerrorenum representing the error
- Error handling
- If the error specified in str can't be found, instead ICAL_UNKNOWN_ERROR is returned.
- Usage
@ ICAL_UNKNOWN_ERROR
Definition icalerror.h:108
◆ icalerror_get_error_state()
Gets the error state (severity) for a given error.
- Parameters
-
error | The error to examine |
- Returns
- Returns the severity of the error
◆ icalerror_get_errors_are_fatal()
int icalerror_get_errors_are_fatal |
( |
void | | ) |
|
Determine if errors are fatal.
- Returns
- True if libical errors are fatal
- Usage
if(icalerror_get_errors_are_fatal()) {
}
◆ icalerror_perror()
const char * icalerror_perror |
( |
void | | ) |
|
Returns the description string for the current error in icalerrno.
- Error handling
- If the type of error e wasn't found, it returns the description for ICAL_UNKNOWN_ERROR.
- Ownership
- The string that is returned is owned by the library and must not be free'd() by the user.
- Usage
printf("%s\n", icalerror_perror());
}
◆ icalerror_restore()
Assigns the given error the given icalerrorstate (severity).
- Parameters
-
error | The error in question |
es | The icalerrorstate (severity) to set it to |
Calling the function changes the icalerrorstate of the given error.
- Usage
icalerror_supress("INTERNAL");
@ ICAL_ERROR_DEFAULT
Definition icalerror.h:223
◆ icalerror_set_errno()
◆ icalerror_set_error_state()
Sets the icalerrorstate for a given icalerrorenum error.
- Parameters
-
error | The error to change |
state | The new error state of the error |
Sets the severity of a given error. For example, it can be used to set the severity of an ICAL_PARSE_ERROR to be an ICAL_ERROR_NONFATAL.
- Usage
@ ICAL_ERROR_NONFATAL
Definition icalerror.h:220
◆ icalerror_set_errors_are_fatal()
void icalerror_set_errors_are_fatal |
( |
int | fatal | ) |
|
Change if errors are fatal.
- Parameters
-
fatal | If true, libical aborts after a call to icalerror_set_error() |
- Warning
- NOT THREAD SAFE: it is recommended that you do not change this in a multithreaded program.
- Usage
icalerror_set_errors_are_fatal(true);
icalerror_set_errors_are_fatal(false);
◆ icalerror_stop_here()
void icalerror_stop_here |
( |
void | | ) |
|
Triggered before any error is called.
This routine is called before any error is triggered. It is called by icalerror_set_errno(), so it does not appear in all of the macros below.
This routine can be used while debugging by setting a breakpoint here.
◆ icalerror_strerror()
Finds the description string for error.
- Parameters
-
e | The type of error that occurred |
- Returns
- A string describing the error that occurred
- Error handling
- If the type of error e wasn't found, it returns the description for ICAL_UNKNOWN_ERROR.
- Ownership
- The string that is returned is owned by the library and must not be free'd() by the user.
- Usage
printf(
"%s\n", icalerror_strerror(
icalerrno));
}
◆ icalerror_supress()
Suppresses a given error.
- Parameters
-
error | The name of the error to suppress |
- Returns
- The previous icalerrorstate (severity)
Calling this function causes the given error to be listed as ICAL_ERROR_NONFATAL, and thus suppressed. Error states can be restored with icalerror_restore().
- Usage
icalerror_supress("INTERNAL");