diff options
author | Stephen D. Huston <shuston@apache.org> | 2011-10-21 01:19:00 +0000 |
---|---|---|
committer | Stephen D. Huston <shuston@apache.org> | 2011-10-21 01:19:00 +0000 |
commit | ebfd9ff053b04ab379acfc0fefedee5a31b6d8a5 (patch) | |
tree | dcfb94e75656c6c239fc3dcb754cd2015126424d /cpp/include/qpid/messaging/exceptions.h | |
parent | 5eb354b338bb8d8fcd35b6ac3fb33f8103e757c3 (diff) | |
download | qpid-python-ebfd9ff053b04ab379acfc0fefedee5a31b6d8a5.tar.gz |
Undo bad merge from trunk - merged at wrong level.
git-svn-id: https://svn.apache.org/repos/asf/qpid/branches/QPID-2519@1187150 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/include/qpid/messaging/exceptions.h')
-rw-r--r-- | cpp/include/qpid/messaging/exceptions.h | 98 |
1 files changed, 26 insertions, 72 deletions
diff --git a/cpp/include/qpid/messaging/exceptions.h b/cpp/include/qpid/messaging/exceptions.h index 31e2488d91..0ff608b343 100644 --- a/cpp/include/qpid/messaging/exceptions.h +++ b/cpp/include/qpid/messaging/exceptions.h @@ -10,9 +10,9 @@ * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at - * + * * http://www.apache.org/licenses/LICENSE-2.0 - * + * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY @@ -29,47 +29,34 @@ namespace qpid { namespace messaging { -/** \ingroup messaging +/** \ingroup messaging */ -/** - * This is the base class for all messaging related exceptions thrown - * by this API. - */ -struct QPID_MESSAGING_CLASS_EXTERN MessagingException : public qpid::types::Exception +struct MessagingException : public qpid::types::Exception { QPID_MESSAGING_EXTERN MessagingException(const std::string& msg); QPID_MESSAGING_EXTERN virtual ~MessagingException() throw(); - + qpid::types::Variant::Map detail; //TODO: override what() to include detail if present }; -/** - * Thrown when the syntax of the option string used to configure a - * connection in not valid - */ -struct QPID_MESSAGING_CLASS_EXTERN InvalidOptionString : public MessagingException +struct InvalidOptionString : public MessagingException { QPID_MESSAGING_EXTERN InvalidOptionString(const std::string& msg); }; -/** - * Thrown to indicate a failed lookup of some local object. For - * example when attempting to retrieve a session, sender or receiver - * by name. - */ -struct QPID_MESSAGING_CLASS_EXTERN KeyError : public MessagingException +struct KeyError : public MessagingException { QPID_MESSAGING_EXTERN KeyError(const std::string&); }; -struct QPID_MESSAGING_CLASS_EXTERN LinkError : public MessagingException +struct LinkError : public MessagingException { QPID_MESSAGING_EXTERN LinkError(const std::string&); }; -struct QPID_MESSAGING_CLASS_EXTERN AddressError : public LinkError +struct AddressError : public LinkError { QPID_MESSAGING_EXTERN AddressError(const std::string&); }; @@ -78,118 +65,85 @@ struct QPID_MESSAGING_CLASS_EXTERN AddressError : public LinkError * Thrown when a syntactically correct address cannot be resolved or * used. */ -struct QPID_MESSAGING_CLASS_EXTERN ResolutionError : public AddressError +struct ResolutionError : public AddressError { QPID_MESSAGING_EXTERN ResolutionError(const std::string& msg); }; -/** - * Thrown when creating a sender or receiver for an address for which - * some asserted property of the node is not matched. - */ -struct QPID_MESSAGING_CLASS_EXTERN AssertionFailed : public ResolutionError +struct AssertionFailed : public ResolutionError { QPID_MESSAGING_EXTERN AssertionFailed(const std::string& msg); }; -/** - * Thrown on attempts to create a sender or receiver to a non-existent - * node. - */ -struct QPID_MESSAGING_CLASS_EXTERN NotFound : public ResolutionError +struct NotFound : public ResolutionError { QPID_MESSAGING_EXTERN NotFound(const std::string& msg); }; /** - * Thrown when an address string with invalid syntax is used. + * Thrown when an address string with inalid sytanx is used. */ -struct QPID_MESSAGING_CLASS_EXTERN MalformedAddress : public AddressError +struct MalformedAddress : public AddressError { QPID_MESSAGING_EXTERN MalformedAddress(const std::string& msg); }; -struct QPID_MESSAGING_CLASS_EXTERN ReceiverError : public LinkError +struct ReceiverError : public LinkError { QPID_MESSAGING_EXTERN ReceiverError(const std::string&); }; -struct QPID_MESSAGING_CLASS_EXTERN FetchError : public ReceiverError +struct FetchError : public ReceiverError { QPID_MESSAGING_EXTERN FetchError(const std::string&); }; -/** - * Thrown by Receiver::fetch(), Receiver::get() and - * Session::nextReceiver() to indicate that there no message was - * available before the timeout specified. - */ -struct QPID_MESSAGING_CLASS_EXTERN NoMessageAvailable : public FetchError +struct NoMessageAvailable : public FetchError { QPID_MESSAGING_EXTERN NoMessageAvailable(); }; -struct QPID_MESSAGING_CLASS_EXTERN SenderError : public LinkError +struct SenderError : public LinkError { QPID_MESSAGING_EXTERN SenderError(const std::string&); }; -struct QPID_MESSAGING_CLASS_EXTERN SendError : public SenderError +struct SendError : public SenderError { QPID_MESSAGING_EXTERN SendError(const std::string&); }; -/** - * Thrown to indicate that the sender attempted to send a message that - * would result in the target node on the peer exceeding a - * preconfigured capacity. - */ -struct QPID_MESSAGING_CLASS_EXTERN TargetCapacityExceeded : public SendError +struct TargetCapacityExceeded : public SendError { QPID_MESSAGING_EXTERN TargetCapacityExceeded(const std::string&); }; -struct QPID_MESSAGING_CLASS_EXTERN SessionError : public MessagingException +struct SessionError : public MessagingException { QPID_MESSAGING_EXTERN SessionError(const std::string&); }; -struct QPID_MESSAGING_CLASS_EXTERN TransactionError : public SessionError +struct TransactionError : public SessionError { QPID_MESSAGING_EXTERN TransactionError(const std::string&); }; -/** - * Thrown on Session::commit() if reconnection results in the - * transaction being automatically aborted. - */ -struct QPID_MESSAGING_CLASS_EXTERN TransactionAborted : public TransactionError +struct TransactionAborted : public TransactionError { QPID_MESSAGING_EXTERN TransactionAborted(const std::string&); }; -/** - * Thrown to indicate that the application attempted to do something - * for which it was not authorised by its peer. - */ -struct QPID_MESSAGING_CLASS_EXTERN UnauthorizedAccess : public SessionError +struct UnauthorizedAccess : public SessionError { QPID_MESSAGING_EXTERN UnauthorizedAccess(const std::string&); }; -struct QPID_MESSAGING_CLASS_EXTERN ConnectionError : public MessagingException +struct ConnectionError : public MessagingException { QPID_MESSAGING_EXTERN ConnectionError(const std::string&); }; -/** - * Thrown to indicate loss of underlying connection. When - * auto-reconnect is used this will be caught by the library and used - * to trigger reconnection attempts. If reconnection fails (according - * to whatever settings have been configured), then an instnace of - * this class will be thrown to signal that. - */ -struct QPID_MESSAGING_CLASS_EXTERN TransportFailure : public MessagingException +struct TransportFailure : public MessagingException { QPID_MESSAGING_EXTERN TransportFailure(const std::string&); }; |