You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
116 lines
3.2 KiB
116 lines
3.2 KiB
///////////////////////////////////////////////////////////////////////////////
|
|
/// \file regex_error.hpp
|
|
/// Contains the definition of the regex_error exception class.
|
|
//
|
|
// Copyright 2008 Eric Niebler. Distributed under the Boost
|
|
// Software License, Version 1.0. (See accompanying file
|
|
// LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
#ifndef BOOST_XPRESSIVE_REGEX_ERROR_HPP_EAN_10_04_2005
|
|
#define BOOST_XPRESSIVE_REGEX_ERROR_HPP_EAN_10_04_2005
|
|
|
|
// MS compatible compilers support #pragma once
|
|
#if defined(_MSC_VER)
|
|
# pragma once
|
|
#endif
|
|
|
|
#include <string>
|
|
#include <stdexcept>
|
|
#include <boost/throw_exception.hpp>
|
|
#include <boost/current_function.hpp>
|
|
#include <boost/exception/exception.hpp>
|
|
#include <boost/exception/info.hpp>
|
|
#include <boost/xpressive/regex_constants.hpp>
|
|
|
|
//{{AFX_DOC_COMMENT
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
// This is a hack to get Doxygen to show the inheritance relation between
|
|
// regex_error and std::runtime_error.
|
|
#ifdef BOOST_XPRESSIVE_DOXYGEN_INVOKED
|
|
/// INTERNAL ONLY
|
|
namespace std
|
|
{
|
|
/// INTERNAL ONLY
|
|
struct runtime_error {};
|
|
}
|
|
#endif
|
|
//}}AFX_DOC_COMMENT
|
|
|
|
namespace boost { namespace xpressive
|
|
{
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
// regex_error
|
|
//
|
|
/// \brief The class regex_error defines the type of objects thrown as
|
|
/// exceptions to report errors during the conversion from a string representing
|
|
/// a regular expression to a finite state machine.
|
|
struct regex_error
|
|
: std::runtime_error
|
|
, boost::exception
|
|
{
|
|
/// Constructs an object of class regex_error.
|
|
/// \param code The error_type this regex_error represents.
|
|
/// \param str The message string of this regex_error.
|
|
/// \post code() == code
|
|
explicit regex_error(regex_constants::error_type code, char const *str = "")
|
|
: std::runtime_error(str)
|
|
, boost::exception()
|
|
, code_(code)
|
|
{
|
|
}
|
|
|
|
/// Accessor for the error_type value
|
|
/// \return the error_type code passed to the constructor
|
|
/// \throw nothrow
|
|
regex_constants::error_type code() const
|
|
{
|
|
return this->code_;
|
|
}
|
|
|
|
/// Destructor for class regex_error
|
|
/// \throw nothrow
|
|
virtual ~regex_error() throw()
|
|
{}
|
|
|
|
private:
|
|
|
|
regex_constants::error_type code_;
|
|
};
|
|
|
|
namespace detail
|
|
{
|
|
inline bool ensure_(
|
|
bool cond
|
|
, regex_constants::error_type code
|
|
, char const *msg
|
|
, char const *fun
|
|
, char const *file
|
|
, unsigned long line
|
|
)
|
|
{
|
|
if(!cond)
|
|
{
|
|
#ifndef BOOST_EXCEPTION_DISABLE
|
|
boost::throw_exception(
|
|
boost::xpressive::regex_error(code, msg)
|
|
<< boost::throw_function(fun)
|
|
<< boost::throw_file(file)
|
|
<< boost::throw_line((int)line)
|
|
);
|
|
#else
|
|
boost::throw_exception(boost::xpressive::regex_error(code, msg));
|
|
#endif
|
|
}
|
|
return true;
|
|
}
|
|
}
|
|
|
|
#define BOOST_XPR_ENSURE_(pred, code, msg) \
|
|
boost::xpressive::detail::ensure_(!!(pred), code, msg, BOOST_CURRENT_FUNCTION, __FILE__, __LINE__) \
|
|
/**/
|
|
|
|
}} // namespace boost::xpressive
|
|
|
|
#endif
|