From: Kevin Day Date: Sun, 11 Mar 2012 04:33:04 +0000 (-0600) Subject: Add Project: fl_errors X-Git-Tag: 0.3.0~93 X-Git-Url: https://git.kevux.org/?a=commitdiff_plain;h=bd8ccc4a198429e5452021db34c27026dadf57a6;p=fll Add Project: fl_errors Add the level 1 errors project that provides error code to string translation for standard error codes. --- diff --git a/level_1/fl_errors/bash/errors.sh b/level_1/fl_errors/bash/errors.sh new file mode 100644 index 0000000..5705425 --- /dev/null +++ b/level_1/fl_errors/bash/errors.sh @@ -0,0 +1,11 @@ +# FLL - Level 0 +# Project: Errors +# Version: 0.3.x +# Licenses: flll, lgplv2.1 +# Programmers: Kevin Day +# Documentation: Provides error codes + +f_true=1 +f_false=0 +f_warn=2 +f_unknown=3 diff --git a/level_1/fl_errors/c/errors.c b/level_1/fl_errors/c/errors.c new file mode 100644 index 0000000..70b144f --- /dev/null +++ b/level_1/fl_errors/c/errors.c @@ -0,0 +1,297 @@ +/* FLL - Level 1 + * Project: Errors + * Version: 0.3.x + * Licenses: lgplv2.1 + * Programmers: Kevin Day + * Documentation: + * + * Provides error functions, such as those that translate error codes into strings. + */ +#include + +#ifdef __cplusplus +extern "C"{ +#endif + +#ifndef _di_fl_errors_to_string_ + // Convert error codes to their string equivalents. + f_return_status fl_errors_to_string(const f_status error, f_string *string){ + #ifndef _di_level_1_parameter_checking_ + if (string == f_null) return f_invalid_parameter; + #endif // _di_level_1_parameter_checking_ + + switch(error){ + #ifndef _di_fl_errors_booleans_ + case f_false: + *string = "false"; + break; + case f_true: + *string = "true"; + break; + #endif // _di_fl_errors_booleans_ + + #ifndef _di_fl_errors_basic_ + case f_none: + *string = "none"; + break; + case f_dummy: + *string = "dummy"; + break; + case f_warn: + *string = "warn"; + break; + case f_critical: + *string = "critical"; + break; + case f_unsupported: + *string = "unsupported"; + break; + case f_invalid_parameter: + *string = "invalid parameter"; + break; + case f_invalid_syntax: + *string = "invalid syntax"; + break; + case f_invalid_data: + *string = "invalid data"; + break; + case f_no_data: + *string = "no data"; + break; + case f_output_error: + *string = "output error"; + break; + case f_does_not_exist: + *string = "does not exist"; + break; + case f_failure: + *string = "failure"; + break; + #endif // _di_fl_errors_basic_ + + #ifndef _di_fl_errors_digits_ + case f_underflow: + *string = "underflow"; + break; + case f_overflow: + *string = "overflow"; + break; + case f_divide_by_zero: + *string = "divide_by_zero"; + break; + case f_cannot_be_negative: + *string = "cannot_be_negative"; + break; + case f_cannot_be_positive: + *string = "cannot_be_positive"; + break; + case f_cannot_be_zero: + *string = "cannot_be_zero"; + break; + #endif // _di_fl_errors_digits_ + + #ifndef _di_fl_errors_buffers_ + case f_no_data_on_eof: + *string = "no data on eof"; + break; + case f_no_data_on_eos: + *string = "no data on eos"; + break; + case f_no_data_on_stop: + *string = "no data on stop"; + break; + case f_none_on_eof: + *string = "none on eof"; + break; + case f_none_on_eos: + *string = "none on eos"; + break; + case f_none_on_stop: + *string = "none on stop"; + break; + case f_error_on_eof: + *string = "error on eof"; + break; + case f_error_on_eos: + *string = "error on eos"; + break; + case f_error_on_stop: + *string = "error on stop"; + break; + case f_buffer_too_small: + *string = "buffer too small"; + break; + case f_buffer_too_large: + *string = "buffer too large"; + break; + case f_string_too_small: + *string = "string too small"; + break; + case f_string_too_large: + *string = "string too large"; + break; + case f_unterminated_nest: + *string = "unterminated nest"; + break; + case f_unterminated_nest_on_eos: + *string = "unterminated nest on eos"; + break; + case f_unterminated_nest_on_eof: + *string = "unterminated nest on eof"; + break; + case f_unterminated_nest_on_stop: + *string = "unterminated nest on stop"; + break; + case f_unterminated_group: + *string = "unterminated group"; + break; + case f_unterminated_group_on_eos: + *string = "unterminated group on eos"; + break; + case f_unterminated_group_on_eof: + *string = "unterminated group on eof"; + break; + case f_unterminated_group_on_stop: + *string = "unterminated group on_ top"; + break; + #endif // _di_fl_errors_buffers_ + + #ifndef _di_fl_errors_allocation_ + case f_allocation_error: + *string = "allocation error"; + break; + case f_reallocation_error: + *string = "reallocation error"; + break; + #endif // _di_fl_errors_allocation_ + + #ifndef _di_fl_errors_fork_ + case f_fork_failed: + *string = "fork failed"; + break; + #endif // _di_fl_errors_fork_ + + #ifndef _di_fl_errors_file_ + case f_file_seek_error: + *string = "file seek error"; + break; + case f_file_read_error: + *string = "file read error"; + break; + case f_file_write_error: + *string = "file write error"; + break; + case f_file_flush_error: + *string = "file flush error"; + break; + case f_file_purge_error: + *string = "file purge error"; + break; + case f_file_open_error: + *string = "file open error"; + break; + case f_file_close_error: + *string = "file close error"; + break; + case f_file_synchronize_error: + *string = "file synchronize error"; + break; + case f_file_descriptor_error: + *string = "file descriptor error"; + break; + case f_file_not_found: + *string = "file not found"; + break; + case f_file_is_empty: + *string = "file is empty"; + break; + case f_file_not_open: + *string = "file not open"; + break; + case f_file_allocation_error: + *string = "file allocation error"; + break; + case f_file_reallocation_error: + *string = "file reallocation error"; + break; + case f_file_stat_error: + *string = "file stat error"; + break; + case f_file_error: + *string = "file error"; + break; + #endif // _di_fl_errors_file_ + + // most of these are a guess until I get around to researching & implementing linux directory I/O + #ifndef _di_fl_errors_directory_ + case f_directory_read_error: + *string = "directory read error"; + break; + case f_directory_write_error: + *string = "directory write error"; + break; + case f_directory_flush_error: + *string = "directory flush error"; + break; + case f_directory_purge_error: + *string = "directory purge error"; + break; + case f_directory_open_error: + *string = "directory open error"; + break; + case f_directory_close_error: + *string = "directory close error"; + break; + case f_directory_synchronize_error: + *string = "directory synchronize error"; + break; + case f_directory_descriptor_error: + *string = "directory descriptor error"; + break; + case f_directory_not_found: + *string = "directory not found"; + break; + case f_directory_is_empty: + *string = "directory is empty"; + break; + case f_directory_not_open: + *string = "directory not open"; + break; + case f_directory_allocation_error: + *string = "directory allocation error"; + break; + case f_directory_reallocation_error: + *string = "directory reallocation error"; + break; + case f_directory_error: + *string = "directory error"; + break; + #endif // _di_fl_errors_directory_ + + #ifndef _di_fll_error_non_ + case f_less_than: + *string = "less than"; + break; + case f_equal_to: + *string = "equal to"; + break; + case f_not_equal_to: + *string = "not equal to"; + break; + case f_greater_than: + *string = "greater than"; + break; + #endif // _di_fl_errors_non_ + + default: + *string = f_null; + return f_invalid_data; + } + + return f_none; + } +#endif // _di_fl_errors_to_string_ + +#ifdef __cplusplus +} // extern "C" +#endif diff --git a/level_1/fl_errors/c/errors.h b/level_1/fl_errors/c/errors.h new file mode 100644 index 0000000..429ac4b --- /dev/null +++ b/level_1/fl_errors/c/errors.h @@ -0,0 +1,30 @@ +/* FLL - Level 1 + * Project: Errors + * Version: 0.3.x + * Licenses: lgplv2.1 + * Programmers: Kevin Day + * Documentation: + * + * Provides error functions, such as those that translate error codes into strings. + */ +#ifndef _FL_errors_h +#define _FL_errors_h + +// fll-0 includes +#include +#include + +#ifdef __cplusplus +extern "C"{ +#endif + +#ifndef _di_fl_errors_to_string_ + // Convert error codes to their string equivalents. + extern f_return_status fl_errors_to_string(const f_status error, f_string *string); +#endif // _di_fl_errors_to_string_ + +#ifdef __cplusplus +} // extern "C" +#endif + +#endif // _FL_errors_h diff --git a/level_1/fl_errors/data/build/settings b/level_1/fl_errors/data/build/settings new file mode 100644 index 0000000..b96f799 --- /dev/null +++ b/level_1/fl_errors/data/build/settings @@ -0,0 +1,21 @@ +# fss-0000 + +project_name fl_errors +project_level 1 + +version_major 0 +version_minor 3 +version_micro 0 + +build_compiler gcc +build_libraries -lc +build_sources_library errors.c +build_sources_program +build_sources_headers errors.h +build_shared yes + +flags_all -z now +flags_shared +flags_static +flags_library -fPIC +flags_program -fPIE