/*! * Copyright (c) 2015 by Contributors * \file c_api_error.h * \brief Error handling for C API. */ #ifndef XGBOOST_C_API_C_API_ERROR_H_ #define XGBOOST_C_API_C_API_ERROR_H_ #include #include /*! \brief macro to guard beginning and end section of all functions */ #ifdef LOG_CAPI_INVOCATION #define API_BEGIN() \ LOG(CONSOLE) << "[XGBoost C API invocation] " << __PRETTY_FUNCTION__; try { #else // LOG_CAPI_INVOCATION #define API_BEGIN() try { #endif // LOG_CAPI_INVOCATION /*! \brief every function starts with API_BEGIN(); and finishes with API_END() or API_END_HANDLE_ERROR */ #define API_END() } catch(dmlc::Error &_except_) { return XGBAPIHandleException(_except_); } return 0; // NOLINT(*) #define CHECK_HANDLE() if (handle == nullptr) \ LOG(FATAL) << "DMatrix/Booster has not been intialized or has already been disposed."; /*! * \brief every function starts with API_BEGIN(); * and finishes with API_END() or API_END_HANDLE_ERROR * The finally clause contains procedure to cleanup states when an error happens. */ #define API_END_HANDLE_ERROR(Finalize) } catch(dmlc::Error &_except_) { Finalize; return XGBAPIHandleException(_except_); } return 0; // NOLINT(*) /*! * \brief Set the last error message needed by C API * \param msg The error message to set. */ void XGBAPISetLastError(const char* msg); /*! * \brief handle exception thrown out * \param e the exception * \return the return value of API after exception is handled */ inline int XGBAPIHandleException(const dmlc::Error &e) { XGBAPISetLastError(e.what()); return -1; } #endif // XGBOOST_C_API_C_API_ERROR_H_