X-Git-Url: http://developer.intra2net.com/git/?p=libt2n;a=blobdiff_plain;f=src%2Ft2n_exception.hxx;h=c81ba02199e994389c8d2a13871cf475e8e923fd;hp=c756b09b86698109e40be40472ea4f5c6770d1bb;hb=7087e18783f91d2b889e880462d1d1da24831c28;hpb=ac7fdc22899c0c493fda5fdb3a4cb67e77504a6b diff --git a/src/t2n_exception.hxx b/src/t2n_exception.hxx index c756b09..c81ba02 100644 --- a/src/t2n_exception.hxx +++ b/src/t2n_exception.hxx @@ -22,13 +22,13 @@ #include #include +#include #include -#include -// serialization for std::exception namespace boost { namespace serialization { +// make std::exception serializable template void serialize(Archive & ar, std::exception & g, const unsigned int version) { @@ -39,12 +39,11 @@ void serialize(Archive & ar, std::exception & g, const unsigned int version) namespace libt2n { - -// a generic exception that can be handeled with libt2n +/// a generic exception that can be handeled with libt2n class t2n_exception : public std::exception { private: - string message; + std::string message; friend class boost::serialization::access; template @@ -55,7 +54,7 @@ class t2n_exception : public std::exception } public: - t2n_exception(const string& _message) + t2n_exception(const std::string& _message) { message=_message; } t2n_exception() @@ -73,9 +72,8 @@ class t2n_exception : public std::exception virtual void do_throw() { throw *this; } }; -BOOST_CLASS_EXPORT(t2n_exception) -// a (unspecified) problem with libt2n communication +/// a (unspecified) problem with libt2n communication class t2n_communication_error : public t2n_exception { private: @@ -87,22 +85,21 @@ class t2n_communication_error : public t2n_exception } public: - t2n_communication_error(const string& _message) + t2n_communication_error(const std::string& _message) : t2n_exception(_message) { } t2n_communication_error() { } - ipc_exception* clone() const + t2n_exception* clone() const { return new t2n_communication_error(*this); } void do_throw() { throw *this; } }; -BOOST_CLASS_EXPORT(t2n_communication_error) -// can't connect to libt2n server +/// can't connect to libt2n server class t2n_connect_error : public t2n_communication_error { private: @@ -114,22 +111,21 @@ class t2n_connect_error : public t2n_communication_error } public: - t2n_connect_error(const string& _message) + t2n_connect_error(const std::string& _message) : t2n_communication_error(_message) { } t2n_connect_error() { } - ipc_exception* clone() const + t2n_exception* clone() const { return new t2n_connect_error(*this); } void do_throw() { throw *this; } }; -BOOST_CLASS_EXPORT(t2n_connect_error) -// error establishing a socket on the server (only thrown on the server-side) +/// error establishing a socket on the server (only thrown on the server-side) class t2n_server_error : public t2n_communication_error { private: @@ -141,22 +137,21 @@ class t2n_server_error : public t2n_communication_error } public: - t2n_server_error(const string& _message) + t2n_server_error(const std::string& _message) : t2n_communication_error(_message) { } t2n_server_error() { } - ipc_exception* clone() const + t2n_exception* clone() const { return new t2n_server_error(*this); } void do_throw() { throw *this; } }; -BOOST_CLASS_EXPORT(t2n_server_error) -// error transmitting or receiving libt2n messages +/// error transmitting or receiving libt2n messages class t2n_transfer_error : public t2n_communication_error { private: @@ -168,22 +163,21 @@ class t2n_transfer_error : public t2n_communication_error } public: - t2n_transfer_error(const string& _message) + t2n_transfer_error(const std::string& _message) : t2n_communication_error(_message) { } t2n_transfer_error() { } - ipc_exception* clone() const + t2n_exception* clone() const { return new t2n_transfer_error(*this); } void do_throw() { throw *this; } }; -BOOST_CLASS_EXPORT(t2n_transfer_error) -// tried to talk to an incompatible libt2n version +/// tried to talk to an incompatible libt2n version class t2n_version_mismatch : public t2n_communication_error { private: @@ -195,22 +189,21 @@ class t2n_version_mismatch : public t2n_communication_error } public: - t2n_version_mismatch(const string& _message) + t2n_version_mismatch(const std::string& _message) : t2n_communication_error(_message) { } t2n_version_mismatch() { } - ipc_exception* clone() const + t2n_exception* clone() const { return new t2n_version_mismatch(*this); } void do_throw() { throw *this; } }; -BOOST_CLASS_EXPORT(t2n_version_mismatch) -// illegal libt2n command received +/// illegal libt2n command received class t2n_command_error : public t2n_exception { private: @@ -222,22 +215,21 @@ class t2n_command_error : public t2n_exception } public: - t2n_command_error(const string& _message) + t2n_command_error(const std::string& _message) : t2n_exception(_message) { } t2n_command_error() { } - ipc_exception* clone() const + t2n_exception* clone() const { return new t2n_command_error(*this); } void do_throw() { throw *this; } }; -BOOST_CLASS_EXPORT(t2n_command_error) -// error serializing or deserializing a libt2n command packet +/// error serializing or deserializing a libt2n command packet class t2n_serialization_error : public t2n_exception { private: @@ -249,23 +241,23 @@ class t2n_serialization_error : public t2n_exception } public: - t2n_serialization_error(const string& _message) + t2n_serialization_error(const std::string& _message) : t2n_exception(_message) { } t2n_serialization_error() { } - ipc_exception* clone() const + t2n_exception* clone() const { return new t2n_serialization_error(*this); } void do_throw() { throw *this; } }; -BOOST_CLASS_EXPORT(t2n_serialization_error) -// a runtime error within the remote function -// derive your own custom exceptions from this one +/** @brief a runtime error within the remote function. + derive your own custom exceptions from this one +*/ class t2n_runtime_error : public t2n_exception { private: @@ -277,21 +269,20 @@ class t2n_runtime_error : public t2n_exception } public: - t2n_runtime_error(const string& _message) + t2n_runtime_error(const std::string& _message) : t2n_exception(_message) { } t2n_runtime_error() { } - ipc_exception* clone() const + t2n_exception* clone() const { return new t2n_runtime_error(*this); } void do_throw() { throw *this; } }; -BOOST_CLASS_EXPORT(t2n_runtime_error) -} +} // namespace libt2n #endif