vtk-m/vtkm/cont/Error.h

91 lines
2.7 KiB
C
Raw Normal View History

//============================================================================
// Copyright (c) Kitware, Inc.
// All rights reserved.
// See LICENSE.txt for details.
2019-04-15 23:24:21 +00:00
//
// This software is distributed WITHOUT ANY WARRANTY; without even
// the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
// PURPOSE. See the above copyright notice for more information.
//============================================================================
#ifndef vtk_m_cont_Error_h
#define vtk_m_cont_Error_h
// Note that this class and (most likely) all of its subclasses are not
// templated. If there is any reason to create a VTKm control library,
// this class and its subclasses should probably go there.
#include <exception>
#include <string>
#include <vtkm/cont/Logging.h>
2018-02-22 16:34:08 +00:00
#include <vtkm/internal/ExportMacros.h>
2017-05-18 14:29:41 +00:00
namespace vtkm
{
namespace cont
{
VTKM_SILENCE_WEAK_VTABLE_WARNING_START
/// The superclass of all exceptions thrown by any VTKm function or method.
///
class VTKM_ALWAYS_EXPORT Error : public std::exception
{
public:
//See note about GetMessage macro below.
#ifndef GetMessage
2017-05-18 14:29:41 +00:00
const std::string& GetMessage() const { return this->Message; }
#endif
2019-07-31 21:51:35 +00:00
const std::string& GetStackTrace() const { return this->StackTrace; }
//GetMessage is a macro defined by <windows.h> to redirrect to
//GetMessageA or W depending on if you are using ansi or unicode.
//To get around this we make our own A/W variants on windows.
#ifdef _WIN32
2017-05-18 14:29:41 +00:00
const std::string& GetMessageA() const { return this->Message; }
const std::string& GetMessageW() const { return this->Message; }
#endif
// For std::exception compatibility:
2019-09-04 19:03:30 +00:00
const char* what() const noexcept override { return this->What.c_str(); }
/// Returns true if this exception is device independent. For exceptions that
/// are not device independent, `vtkm::TryExecute`, for example, may try
/// executing the code on other available devices.
bool GetIsDeviceIndependent() const { return this->IsDeviceIndependent; }
protected:
Error()
: StackTrace(vtkm::cont::GetStackTrace(1))
, What("Undescribed error\n" + StackTrace)
, IsDeviceIndependent(false)
{
}
Error(const std::string& message, bool is_device_independent = false)
2017-05-18 14:29:41 +00:00
: Message(message)
2019-07-31 21:51:35 +00:00
, StackTrace(vtkm::cont::GetStackTrace(1))
2019-09-04 19:03:30 +00:00
, What(Message + "\n" + StackTrace)
, IsDeviceIndependent(is_device_independent)
{
}
void SetMessage(const std::string& message)
{
this->Message = message;
this->What = this->Message + "\n" + this->StackTrace;
}
2017-05-18 14:29:41 +00:00
private:
std::string Message;
2019-07-31 21:51:35 +00:00
std::string StackTrace;
2019-09-04 19:03:30 +00:00
std::string What;
bool IsDeviceIndependent;
};
VTKM_SILENCE_WEAK_VTABLE_WARNING_END
}
} // namespace vtkm::cont
#endif //vtk_m_cont_Error_h