1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
|
/* -*- mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*- */
// vim: ft=cpp:expandtab:ts=8:sw=4:softtabstop=4:
#ident "$Id$"
/*======
This file is part of PerconaFT.
Copyright (c) 2006, 2015, Percona and/or its affiliates. All rights reserved.
PerconaFT is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License, version 2,
as published by the Free Software Foundation.
PerconaFT is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with PerconaFT. If not, see <http://www.gnu.org/licenses/>.
----------------------------------------
PerconaFT is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License, version 3,
as published by the Free Software Foundation.
PerconaFT is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with PerconaFT. If not, see <http://www.gnu.org/licenses/>.
======= */
#ident "Copyright (c) 2006, 2015, Percona and/or its affiliates. All rights reserved."
/**
\file errors.c
\brief Error handling
The error handling routines for ydb
*/
#include <toku_portability.h>
#include <stdio.h>
#include <stdarg.h>
#include "ydb-internal.h"
/** Checks whether the environment has panicked */
int toku_env_is_panicked(DB_ENV *dbenv /**< The environment to check */) {
if (dbenv==0) return 0;
return dbenv->i->is_panicked;
}
/* Prints an error message to a file specified by env (or stderr),
preceded by the environment's error prefix. */
static void toku__ydb_error_file(const DB_ENV *env, bool use_stderr,
char errmsg[]) {
/* Determine the error file to use */
FILE *CAST_FROM_VOIDP(efile, env->i->errfile);
if (efile==NULL && env->i->errcall==0 && use_stderr) efile = stderr;
/* Print out on a file */
if (efile) {
if (env->i->errpfx) fprintf(efile, "%s: ", env->i->errpfx);
fprintf(efile, "%s", errmsg);
}
}
/**
Prints out environment errors, adjusting to a variety of options
and formats.
The printout format can be controlled to print the following optional
messages:
- The environment error message prefix
- User-supplied prefix obtained by printing ap with the
fmt string
- The standard db error string
The print out takes place via errcall (if set), errfile (if set),
or stderr if neither is set (and the user so toggles the printout).
Both errcall and errfile can be set.
The error message is truncated to approximately 4,000 characters.
\param env The environment that the error refers to.
\param error The error code
\param include_stderrstring Controls whether the standard db error
string should be included in the print out
\param use_stderr_if_nothing_else Toggles the use of stderr.
\param fmt Output format for optional prefix arguments (must be NULL
if the prefix is empty)
\param ap Optional prefix
*/
void toku_ydb_error_all_cases(const DB_ENV * env,
int error,
bool include_stderrstring,
bool use_stderr_if_nothing_else,
const char *fmt, va_list ap) {
/* Construct the error message */
char buf [4000];
int count=0;
if (fmt) count=vsnprintf(buf, sizeof(buf), fmt, ap);
if (include_stderrstring) {
count+=snprintf(&buf[count], sizeof(buf)-count, ": %s",
db_strerror(error));
}
/* Print via errcall */
if (env->i->errcall) env->i->errcall(env, env->i->errpfx, buf);
/* Print out on a file */
toku__ydb_error_file(env, use_stderr_if_nothing_else, buf);
}
/** Handle all the error cases (but don't do the default thing.)
\param dbenv The environment that is subject to errors
\param error The error code
\param fmt The format string for additional variable arguments to
be printed */
int toku_ydb_do_error (const DB_ENV *dbenv, int error, const char *fmt, ...) {
va_list ap;
va_start(ap, fmt);
toku_ydb_error_all_cases(dbenv, error, false, false, fmt, ap);
va_end(ap);
return error;
}
/** Handle errors on an environment,
\param dbenv The environment that is subject to errors
\param error The error code
\param fmt The format string for additional variable arguments to
be printed */
void toku_env_err(const DB_ENV * env, int error, const char *fmt, ...) {
va_list ap;
va_start(ap, fmt);
toku_ydb_error_all_cases(env, error, false, true, fmt, ap);
va_end(ap);
}
|