186 lines
9.2 KiB
C
186 lines
9.2 KiB
C
/*****************************************************************************
|
|
* RRDtool 1.4.9 Copyright by Tobi Oetiker, 1997-2014
|
|
*****************************************************************************
|
|
* rrd_error.c Common Header File
|
|
*****************************************************************************
|
|
* $Id$
|
|
* $Log$
|
|
* Revision 1.4 2003/02/22 21:57:03 oetiker
|
|
* a patch to avoid a memory leak and a Makefile.am patch to
|
|
* distribute all required source files -- Peter Stamfest <peter@stamfest.at>
|
|
*
|
|
* Revision 1.3 2003/02/13 07:05:27 oetiker
|
|
* Find attached the patch I promised to send to you. Please note that there
|
|
* are three new source files (src/rrd_is_thread_safe.h, src/rrd_thread_safe.c
|
|
* and src/rrd_not_thread_safe.c) and the introduction of librrd_th. This
|
|
* library is identical to librrd, but it contains support code for per-thread
|
|
* global variables currently used for error information only. This is similar
|
|
* to how errno per-thread variables are implemented. librrd_th must be linked
|
|
* alongside of libpthred
|
|
*
|
|
* There is also a new file "THREADS", holding some documentation.
|
|
*
|
|
* -- Peter Stamfest <peter@stamfest.at>
|
|
*
|
|
* Revision 1.2 2002/02/01 20:34:49 oetiker
|
|
* fixed version number and date/time
|
|
*
|
|
* Revision 1.1.1.1 2001/02/25 22:25:05 oetiker
|
|
* checkin
|
|
*
|
|
* changed by yubo@yubo.org
|
|
*
|
|
*************************************************************************** */
|
|
|
|
|
|
#include <stdlib.h>
|
|
#include <stdio.h>
|
|
|
|
#include "rrd_error.h"
|
|
|
|
char const *rrd_err_text[RRD_ERR_NUM] = {
|
|
"allocating error", /* RRD_ERR_ALLOC */
|
|
"Invalid DS name", /* RRD_ERR_INVALID_DS_NAME */
|
|
"Invalid DS type", /* RRD_ERR_INVALID_DS_TYPE */
|
|
"Duplicate DS name", /* RRD_ERR_DUPLICATE_DS_NAME */
|
|
"Invalid DS format", /* RRD_ERR_INVALID_DS_FORMAT */
|
|
"Invalid DS type specified", /* RRD_ERR_INVALID_DS_TYPE_SPEC */
|
|
"creating rrd error", /* RRD_ERR_CREATE_WRITE */
|
|
"Failed to parse CF name", /* RRD_ERR_FAILED_PARSE_CF_NAME */
|
|
"Unrecognized consolidation function", /* RRD_ERR_UNREC_CONSOLIDATION_FUNC */
|
|
"Invalid row count", /* RRD_ERR_INVALID_ROW_COUNT */
|
|
"Invalid xff: must be between 0 and 1", /* RRD_ERR_INVALID_XFF */
|
|
"Invalid alpha: must be between 0 and 1", /* RRD_ERR_INVALID_ALPHA */
|
|
"Invalid gamma: must be between 0 and 1", /* RRD_ERR_INVALID_GAMMA */
|
|
"Failure threshold is out of range 1, 28", /* RRD_ERR_FAILURE_THRESHOLD_OUT_OF_RANGE */
|
|
"Invalid step: must be >= 1", /* RRD_ERR_INVALID_STEP */
|
|
"Invalid beta: must be between 0 and 1", /* RRD_ERR_INVALID_BETA */
|
|
"Window length is out of range 1, 28", /* RRD_ERR_WIN_LEN_OUT_OF_RANGE */
|
|
"Window length is shorter than the failure threshold", /* RRD_ERR_WINLEN_SHORTER_FAILURE_THRESHOLD */
|
|
"Unexpected extra argument for consolidation function DEVPREDICT", /* RRD_ERR_INVALID_ARG1 */
|
|
"The time spanned by the database is too large: must be <= 4294967296 seconds", /* RRD_ERR_TIME_TOO_LARGE */
|
|
"Invalid smoothing-window : must be between 0 and 1", /* RRD_ERR_INVALID_SMOOTHING_WINDOW */
|
|
"Invalid option", /* RRD_ERR_INVALID_OPT */
|
|
"Length of seasonal cycle exceeds length of HW prediction array", /* RRD_ERR_LEN_OF_SEASONAL_CYCLE */
|
|
"Unexpected extra argument for consolidation function", /* RRD_ERR_INVALID_ARG2 */
|
|
"Unknown error", /* RRD_ERR_UNKNOWN_ERROR */
|
|
"Expected at least xxx arguments for RRA but got ooo", /* RRD_ERR_ARG3 */
|
|
"creating contingent RRA", /* RRD_ERR_CREATING_RRA */
|
|
"can't parse argument", /* RRD_ERR_ARG4 */
|
|
"you must define at least one Round Robin Archive", /* RRD_ERR_ARG5 */
|
|
"you must define at least one Data Source", /* RRD_ERR_ARG6 */
|
|
"min must be less than max in DS definition", /* RRD_ERR_ARG7 */
|
|
"failed to parse data source ??", /* RRD_ERR_ARG8 */
|
|
"rrd_open() creating file error", /* RRD_ERR_CREATE_FILE1 */
|
|
"malloc fetch ds_namv array", /* RRD_ERR_MALLOC1 */
|
|
"malloc fetch ds_namv entry", /* RRD_ERR_MALLOC2 */
|
|
"the RRD does not contain an RRA matching the chosen CF", /* RRD_ERR_NO_MATCH_RRA */
|
|
"malloc fetch data area", /* RRD_ERR_MALLOC3 */
|
|
"seek error in RRA", /* RRD_ERR_SEEK_RRA */
|
|
"wrap seek in RRA did fail", /* RRD_ERR_SEEK_RRA1 */
|
|
"fetching cdp from rra", /* RRD_ERR_FETCH_CDP */
|
|
"unknown data source name", /* RRD_ERR_UNKNOWN_DS_NAME */
|
|
"memory allocation failure: seasonal coef", /* RRD_ERR_MALLOC4 */
|
|
"read operation failed in lookup_seasonal()", /* RRD_ERR_READ1 */
|
|
"seek operation failed in lookup_seasonal()", /* RRD_ERR_SEEK1 */
|
|
"apply smoother: memory allocation failure", /* RRD_ERR_MALLOC5 */
|
|
"seek to rra failed", /* RRD_ERR_SEEK2 */
|
|
"reading value failed: ??", /* RRD_ERR_READ2 */
|
|
"apply smoother: SEASONAL rra doesn't have valid dependency", /* RRD_ERR_DEP1 */
|
|
"apply_smoother: seek to cdp_prep failed", /* RRD_ERR_SEEK3 */
|
|
"apply_smoother: cdp_prep write failed", /* RRD_ERR_WRITE1 */
|
|
"apply_smoother: seek to pos ?? failed", /* RRD_ERR_SEEK4 */
|
|
"apply_smoother: write failed to xxx", /* RRD_ERR_WRITE2 */
|
|
"reached EOF while loading header ", /* RRD_ERR_READ3 */
|
|
"rrd_read() malloc error", /* RRD_ERR_MALLOC6 */
|
|
"short read while reading header ", /* RRD_ERR_READ4 */
|
|
"allocating rrd_file descriptor for 'xxx'", /* RRD_ERR_MALLOC7 */
|
|
"allocating rrd_simple_file for 'xxx'", /* RRD_ERR_MALLOC8 */
|
|
"in read/write request mask", /* RRD_ERR_IO1 */
|
|
"opening error", /* RRD_ERR_OPEN_FILE */
|
|
"fstat error", /* RRD_ERR_STAT_FILE */
|
|
"write error", /* RRD_ERR_WRITE5 */
|
|
"mmap error", /* RRD_ERR_MMAP */
|
|
"This file is not an RRD file", /* RRD_ERR_FILE */
|
|
"This RRD was created on another architecture", /* RRD_ERR_FILE1 */
|
|
"can't handle RRD file version", /* RRD_ERR_FILE2 */
|
|
"live_head_t malloc", /* RRD_ERR_MALLOC9 */
|
|
"file is too small (should be ?? bytes)", /* RRD_ERR_FILE3 */
|
|
"msync rrd_file error", /* RRD_ERR_MSYNC */
|
|
"munmap rrd_file error", /* RRD_ERR_MUNMAP */
|
|
"closing rrd_file error", /* RRD_ERR_CLOSE */
|
|
"attempting to write beyond end of file", /* RRD_ERR_WRITE6 */
|
|
"update process_arg error", /* RRD_ERR_ARG9 */
|
|
"write changes to disk error", /* RRD_ERR_WRITE7 */
|
|
"Not enough arguments", /* RRD_ERR_ARG10 */
|
|
"could not lock RRD", /* RRD_ERR_LOCK */
|
|
"failed duplication argv entry", /* RRD_ERR_FAILED_STRDUP */
|
|
"allocating updvals pointer array.", /* RRD_ERR_MALLOC10 */
|
|
"allocating pdp_temp.", /* RRD_ERR_MALLOC11 */
|
|
"allocating skip_update.", /* RRD_ERR_MALLOC12 */
|
|
"allocating tmpl_idx.", /* RRD_ERR_MALLOC13 */
|
|
"allocating rra_step_cnt.", /* RRD_ERR_MALLOC14 */
|
|
"allocating pdp_new.", /* RRD_ERR_MALLOC15 */
|
|
"parse template error", /* RRD_ERR_PARSE */
|
|
"error copying tmplt ", /* RRD_ERR_FAILED_STRDUP1 */
|
|
"tmplt contains more DS definitions than RRD", /* RRD_ERR_MORE_DS */
|
|
"unknown DS name ", /* RRD_ERR_UNKNOWN_DS_NAME1 */
|
|
"expected timestamp not found in data source from ??", /* RRD_ERR_STR */
|
|
"found extra data on update argument: ??", /* RRD_ERR_ARG11 */
|
|
"expected ?? data source readings (got ??) from ??", /* RRD_ERR_EXPECTED */
|
|
"ds time: ??: ??", /* RRD_ERR_TIME1 */
|
|
"specifying time relative to the 'start' or 'end' makes no sense here: ??", /* RRD_ERR_TIME2 */
|
|
"strtod error: converting ?? to float: ??", /* RRD_ERR_STRTOD */
|
|
"illegal attempt to update using time ?? when last update time is ?? (minimum one second step)", /* RRD_ERR_TIME3 */
|
|
"not a simple ?? integer: '??'", /* RRD_ERR_INT */
|
|
"conversion of '??' to float not complete: tail '??'", /* RRD_ERR_DATA */
|
|
"rrd contains unknown DS type : '??'", /* RRD_ERR_UNKNOWN_DS_TYPE */
|
|
"seek error in rrd", /* RRD_ERR_SEEK5 */
|
|
"writing rrd: ??", /* RRD_ERR_WRITE8 */
|
|
"seek rrd for live header writeback", /* RRD_ERR_SEEK6 */
|
|
"rrd_write live_head to rrd", /* RRD_ERR_WRITE9 */
|
|
"rrd_write pdp_prep to rrd", /* RRD_ERR_WRITE10 */
|
|
"rrd_write cdp_prep to rrd", /* RRD_ERR_WRITE11 */
|
|
"rrd_write rra_ptr to rrd", /* RRD_ERR_WRITE12 */
|
|
"the start and end times cannot be specified relative to each other", /* RRD_ERR_TIME4 */
|
|
"the start time cannot be specified relative to itself", /* RRD_ERR_TIME5 */
|
|
"the end time cannot be specified relative to itself", /* RRD_ERR_TIME6 */
|
|
"failed to alloc memory in addop2str", /* RRD_ERR_MALLOC16 */
|
|
"failed to parse computed data source", /* RRD_ERR_PARSE1 */
|
|
"operators TIME, LTIME, PREV COUNT TREND TRENDNAN PREDICT PREDICTSIGMA are not supported with DS COMPUTE", /* RRD_ERR_DS */
|
|
"don't undestand expr", /* RRD_ERR_EXPR */
|
|
"RPN stack overflow", /* RRD_ERR_STACK */
|
|
"RPN stack underflow", /* RRD_ERR_STACK1 */
|
|
"VDEF made it into rpn_calc... aborting", /* RRD_ERR_ABORT */
|
|
"negative shift step not allowed: ??", /* RRD_ERR_ALLOW */
|
|
"malformed trend arguments", /* RRD_ERR_ARG12 */
|
|
"RPN final stack size != 1", /* RRD_ERR_STACK2 */
|
|
"Maximum ?? RPN nodes permitted. Got ?? RPN nodes at present.", /* RRD_ERR_DATA1 */
|
|
"constants must be integers in the interval (??, ??)", /* RRD_ERR_DATA2 */
|
|
"failed allocating rpnp array", /* RRD_ERR_MALLOC17 */
|
|
"unknown data acquisition function '??'", /* RRD_ERR_UNKNOWN_DATA */
|
|
"update_cdp_prep error", /* RRD_ERR_UPDATE_CDP */
|
|
"variable '??' not found", /* RRD_ERR_UNKNOWN_DATA1 */
|
|
};
|
|
|
|
|
|
|
|
const char *rrd_strerror(int err) {
|
|
int e;
|
|
e = abs(err);
|
|
if(e == 0){
|
|
return NULL;
|
|
}else{
|
|
if (e >= RRD_ERR_START && e <= RRD_ERR_END){
|
|
printf("errno: 0x%04x, str:%s\n", e, rrd_err_text[e-RRD_ERR_START]);
|
|
return rrd_err_text[e-RRD_ERR_START];
|
|
}else{
|
|
printf("errno: 0x%04x, str:%s\n", e, rrd_err_text[RRD_ERR_UNKNOWN_ERROR-RRD_ERR_START]);
|
|
return rrd_err_text[RRD_ERR_UNKNOWN_ERROR-RRD_ERR_START];
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
|