2004-04-14 10:53:21 +02:00
|
|
|
/* Copyright (C) 2003 MySQL AB
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program 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 this program; if not, write to the Free Software
|
|
|
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
|
|
|
|
|
|
|
|
#ifndef NDB_ERROR_HPP
|
|
|
|
#define NDB_ERROR_HPP
|
|
|
|
|
2004-05-05 11:29:56 +02:00
|
|
|
#include <ndberror.h>
|
|
|
|
|
2004-04-14 10:53:21 +02:00
|
|
|
/**
|
|
|
|
* @struct NdbError
|
|
|
|
* @brief Contains error information
|
|
|
|
*
|
|
|
|
* A NdbError consists of five parts:
|
|
|
|
* -# Error status : Application impact
|
|
|
|
* -# Error classification : Logical error group
|
|
|
|
* -# Error code : Internal error code
|
|
|
|
* -# Error message : Context independent description of error
|
|
|
|
* -# Error details : Context dependent information
|
|
|
|
* (not always available)
|
|
|
|
*
|
|
|
|
* <em>Error status</em> is usually used for programming against errors.
|
|
|
|
* If more detailed error control is needed, it is possible to
|
|
|
|
* use the <em>error classification</em>.
|
|
|
|
*
|
|
|
|
* It is not recommended to write application programs dependent on
|
|
|
|
* specific <em>error codes</em>.
|
|
|
|
*
|
|
|
|
* The <em>error messages</em> and <em>error details</em> may
|
|
|
|
* change without notice.
|
|
|
|
*
|
2005-01-04 16:15:15 +01:00
|
|
|
* For example of use, see @ref ndbapi_retries.cpp.
|
2004-04-14 10:53:21 +02:00
|
|
|
*/
|
|
|
|
struct NdbError {
|
|
|
|
/**
|
|
|
|
* Status categorizes error codes into status values reflecting
|
|
|
|
* what the application should do when encountering errors
|
|
|
|
*/
|
|
|
|
enum Status {
|
|
|
|
/**
|
|
|
|
* The error code indicate success<br>
|
|
|
|
* (Includes classification: NdbError::NoError)
|
|
|
|
*/
|
2004-05-05 11:29:56 +02:00
|
|
|
Success = ndberror_st_success,
|
2004-04-14 10:53:21 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The error code indicates a temporary error.
|
|
|
|
* The application should typically retry.<br>
|
|
|
|
* (Includes classifications: NdbError::InsufficientSpace,
|
|
|
|
* NdbError::TemporaryResourceError, NdbError::NodeRecoveryError,
|
|
|
|
* NdbError::OverloadError, NdbError::NodeShutdown
|
|
|
|
* and NdbError::TimeoutExpired.)
|
|
|
|
*/
|
2004-05-05 11:29:56 +02:00
|
|
|
TemporaryError = ndberror_st_temporary,
|
2004-04-14 10:53:21 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The error code indicates a permanent error.<br>
|
|
|
|
* (Includes classificatons: NdbError::PermanentError,
|
|
|
|
* NdbError::ApplicationError, NdbError::NoDataFound,
|
|
|
|
* NdbError::ConstraintViolation, NdbError::SchemaError,
|
|
|
|
* NdbError::UserDefinedError, NdbError::InternalError, and,
|
|
|
|
* NdbError::FunctionNotImplemented.)
|
|
|
|
*/
|
2004-05-05 11:29:56 +02:00
|
|
|
PermanentError = ndberror_st_permanent,
|
2004-04-14 10:53:21 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The result/status is unknown.<br>
|
|
|
|
* (Includes classifications: NdbError::UnknownResultError, and
|
|
|
|
* NdbError::UnknownErrorCode.)
|
|
|
|
*/
|
2004-05-05 11:29:56 +02:00
|
|
|
UnknownResult = ndberror_st_unknown
|
2004-04-14 10:53:21 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Type of error
|
|
|
|
*/
|
|
|
|
enum Classification {
|
|
|
|
/**
|
|
|
|
* Success. No error occurred.
|
|
|
|
*/
|
2004-05-05 11:29:56 +02:00
|
|
|
NoError = ndberror_cl_none,
|
2004-04-14 10:53:21 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Error in application program.
|
|
|
|
*/
|
2004-05-05 11:29:56 +02:00
|
|
|
ApplicationError = ndberror_cl_application,
|
2004-04-14 10:53:21 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Read operation failed due to missing record.
|
|
|
|
*/
|
2004-05-05 11:29:56 +02:00
|
|
|
NoDataFound = ndberror_cl_no_data_found,
|
2004-04-14 10:53:21 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* E.g. inserting a tuple with a primary key already existing
|
|
|
|
* in the table.
|
|
|
|
*/
|
2004-05-05 11:29:56 +02:00
|
|
|
ConstraintViolation = ndberror_cl_constraint_violation,
|
2004-04-14 10:53:21 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Error in creating table or usage of table.
|
|
|
|
*/
|
2004-05-05 11:29:56 +02:00
|
|
|
SchemaError = ndberror_cl_schema_error,
|
2004-04-14 10:53:21 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Error occurred in interpreted program.
|
|
|
|
*/
|
2004-05-05 11:29:56 +02:00
|
|
|
UserDefinedError = ndberror_cl_user_defined,
|
2004-04-14 10:53:21 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* E.g. insufficient memory for data or indexes.
|
|
|
|
*/
|
2004-05-05 11:29:56 +02:00
|
|
|
InsufficientSpace = ndberror_cl_insufficient_space,
|
2004-04-14 10:53:21 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* E.g. too many active transactions.
|
|
|
|
*/
|
2004-05-05 11:29:56 +02:00
|
|
|
TemporaryResourceError = ndberror_cl_temporary_resource,
|
2004-04-14 10:53:21 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Temporary failures which are probably inflicted by a node
|
|
|
|
* recovery in progress. Examples: information sent between
|
|
|
|
* application and NDB lost, distribution change.
|
|
|
|
*/
|
2004-05-05 11:29:56 +02:00
|
|
|
NodeRecoveryError = ndberror_cl_node_recovery,
|
2004-04-14 10:53:21 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* E.g. out of log file space.
|
|
|
|
*/
|
2004-05-05 11:29:56 +02:00
|
|
|
OverloadError = ndberror_cl_overload,
|
2004-04-14 10:53:21 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Timeouts, often inflicted by deadlocks in NDB.
|
|
|
|
*/
|
2004-05-05 11:29:56 +02:00
|
|
|
TimeoutExpired = ndberror_cl_timeout_expired,
|
2004-04-14 10:53:21 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Is is unknown whether the transaction was committed or not.
|
|
|
|
*/
|
2004-05-05 11:29:56 +02:00
|
|
|
UnknownResultError = ndberror_cl_unknown_result,
|
2004-04-14 10:53:21 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* A serious error in NDB has occurred.
|
|
|
|
*/
|
2004-05-05 11:29:56 +02:00
|
|
|
InternalError = ndberror_cl_internal_error,
|
2004-04-14 10:53:21 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* A function used is not yet implemented.
|
|
|
|
*/
|
2004-05-05 11:29:56 +02:00
|
|
|
FunctionNotImplemented = ndberror_cl_function_not_implemented,
|
2004-04-14 10:53:21 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Error handler could not determine correct error code.
|
|
|
|
*/
|
2004-05-05 11:29:56 +02:00
|
|
|
UnknownErrorCode = ndberror_cl_unknown_error_code,
|
2004-04-14 10:53:21 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Node shutdown
|
|
|
|
*/
|
2005-01-07 10:48:13 +01:00
|
|
|
NodeShutdown = ndberror_cl_node_shutdown,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Schema object already exists
|
|
|
|
*/
|
|
|
|
SchemaObjectExists = ndberror_cl_schema_object_already_exists
|
2004-04-14 10:53:21 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Error status.
|
|
|
|
*/
|
|
|
|
Status status;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Error type
|
|
|
|
*/
|
|
|
|
Classification classification;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Error code
|
|
|
|
*/
|
|
|
|
int code;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Error message
|
|
|
|
*/
|
|
|
|
const char * message;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The detailed description. This is extra information regarding the
|
|
|
|
* error which is not included in the error message.
|
|
|
|
*
|
|
|
|
* @note Is NULL when no details specified
|
|
|
|
*/
|
|
|
|
char * details;
|
|
|
|
|
2005-01-10 01:25:20 +01:00
|
|
|
#ifndef DOXYGEN_SHOULD_SKIP_INTERNAL
|
2004-04-14 10:53:21 +02:00
|
|
|
NdbError(){
|
|
|
|
status = UnknownResult;
|
|
|
|
classification = NoError;
|
|
|
|
code = 0;
|
|
|
|
message = 0;
|
|
|
|
details = 0;
|
|
|
|
}
|
2004-05-05 12:42:00 +02:00
|
|
|
NdbError(const ndberror_struct & ndberror){
|
2004-05-05 11:29:56 +02:00
|
|
|
status = (NdbError::Status) ndberror.status;
|
|
|
|
classification = (NdbError::Classification) ndberror.classification;
|
|
|
|
code = ndberror.code;
|
|
|
|
message = ndberror.message;
|
|
|
|
details = ndberror.details;
|
|
|
|
}
|
|
|
|
operator ndberror_struct() const {
|
|
|
|
ndberror_struct ndberror;
|
|
|
|
ndberror.status = (ndberror_status_enum) status;
|
|
|
|
ndberror.classification = (ndberror_classification_enum) classification;
|
|
|
|
ndberror.code = code;
|
|
|
|
ndberror.message = message;
|
|
|
|
ndberror.details = details;
|
|
|
|
return ndberror;
|
|
|
|
}
|
2005-01-10 01:25:20 +01:00
|
|
|
#endif
|
2004-04-14 10:53:21 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
class NdbOut& operator <<(class NdbOut&, const NdbError &);
|
|
|
|
class NdbOut& operator <<(class NdbOut&, const NdbError::Status&);
|
|
|
|
class NdbOut& operator <<(class NdbOut&, const NdbError::Classification&);
|
|
|
|
#endif
|