* anna::Recycler<MyAvp> a_avps;
* anna::Recycler<MyMessage> a_messages;
*
- * anna::diameter::codec::Avp* allocateAvp () throw () { return a_avps.create (); }
+ * anna::diameter::codec::Avp* allocateAvp () { return a_avps.create (); }
*
- * void releaseAvp (anna::diameter::codec::Avp* avp) throw () {
+ * void releaseAvp (anna::diameter::codec::Avp* avp) {
* if (avp == NULL) return;
* MyAvp* aux = static_cast <MyAvp*> (avp);
* aux->clear(); // free internal data-part storage specially for grouped avps which will release its childrens
* a_avps.release (aux);
* }
*
- * anna::diameter::codec::Message* allocateMessage () throw () { return a_messages.create (); }
+ * anna::diameter::codec::Message* allocateMessage () { return a_messages.create (); }
*
- * void releaseMessage (anna::diameter::codec::Message* message) throw () {
+ * void releaseMessage (anna::diameter::codec::Message* message) {
* if (message == NULL) return;
* MyMessage* aux = static_cast <MyMessage*> (message);
* aux->clear(); // free internal data-part storage specially for childrens releasing
// Creators
- Avp* createAvp(const AvpId *id) throw(anna::RuntimeException);
- Message* createMessage(const CommandId *id) throw(anna::RuntimeException);
+ Avp* createAvp(const AvpId *id) noexcept(false);
+ Message* createMessage(const CommandId *id) noexcept(false);
private:
const stack::Dictionary * a_dictionary;
// helpers
- static const char* asText(const ValidationDepth::_v) throw();
- static const char* asText(const ValidationMode::_v) throw();
- static const char* asText(const FixMode::_v) throw();
+ static const char* asText(const ValidationDepth::_v) ;
+ static const char* asText(const ValidationMode::_v) ;
+ static const char* asText(const FixMode::_v) ;
public:
@return Returns currently configured engine dictionary
*/
- const stack::Dictionary *getDictionary() const throw() { return a_dictionary; }
+ const stack::Dictionary *getDictionary() const { return a_dictionary; }
/**
* Sets behaviour on validation procedure.
* \param validationDepth Behaviour on validation procedure: complete analysis or stop at first validation error over the message.
*/
- void setValidationDepth(const ValidationDepth::_v validationDepth) throw() { a_validationDepth = validationDepth; }
+ void setValidationDepth(const ValidationDepth::_v validationDepth) { a_validationDepth = validationDepth; }
/**
* Returns behaviour on on validation procedure.
*
* \return Behaviour on validation procedure: complete analysis or stop at first validation error over the message (by default).
*/
- ValidationDepth::_v getValidationDepth() const throw() { return a_validationDepth; }
+ ValidationDepth::_v getValidationDepth() const { return a_validationDepth; }
/**
* Sets behaviour on validation procedure regarding stack flags. Actually, only AVP flags M & P are affected. The vendor bit is
* \param ignoreFlags Validation will ignore flags.
*/
- void ignoreFlagsOnValidation(bool ignoreFlags) throw() { a_ignoreFlags = ignoreFlags; }
+ void ignoreFlagsOnValidation(bool ignoreFlags) { a_ignoreFlags = ignoreFlags; }
/**
* Gets behaviour on validation procedure regarding stack flags. Actually, only AVP flags M & P are affected. The vendor bit is
* By default (at engine start), flags are verified.
* \return Validation ignore flags indicator.
*/
- bool ignoreFlagsOnValidation() const throw() { return a_ignoreFlags; }
+ bool ignoreFlagsOnValidation() const { return a_ignoreFlags; }
/**
* Sets validation mode.
* \param validationMode Validation mode: before encoding, after decoding, always or never.
*/
- void setValidationMode(const ValidationMode::_v validationMode) throw() { a_validationMode = validationMode; }
+ void setValidationMode(const ValidationMode::_v validationMode) { a_validationMode = validationMode; }
/**
* Returns validation mode.
* during development phase.
* \return Validation mode: before encoding, after decoding (by default), always or never.
*/
- ValidationMode::_v getValidationMode() const throw() { return a_validationMode; }
+ ValidationMode::_v getValidationMode() const { return a_validationMode; }
* Sets fix mode.
* \param fixMode Fix mode: before encoding, after decoding, always or never.
*/
- void setFixMode(const FixMode::_v fixMode) throw() { a_fixMode = fixMode; }
+ void setFixMode(const FixMode::_v fixMode) { a_fixMode = fixMode; }
/**
* Returns fix mode.
* \return Fix mode: before encoding (by default), after decoding, always or never.
*/
- FixMode::_v getFixMode() const throw() { return a_fixMode; }
+ FixMode::_v getFixMode() const { return a_fixMode; }
/**
* Sets single FailedAVP. True by default. If false, and more than one wrong avp are found during message
*
* \param single Single Failed-AVP boolean.
*/
- void setSingleFailedAVP(bool single = true) throw() { a_singleFailedAVP = single; }
+ void setSingleFailedAVP(bool single = true) { a_singleFailedAVP = single; }
/**
* Returns single Failed-AVP boolean.
* \return Failed-AVP could be one (true) or more (false) in answer message.
*/
- bool getSingleFailedAVP() const throw() { return a_singleFailedAVP; }
+ bool getSingleFailedAVP() const { return a_singleFailedAVP; }
/**
* Creates a new diameter avp assigning its identifier, using engine resources to allocate memory (recommended
*
* @return Created avp ready to be used
*/
- Avp* createAvp(AvpId id) throw(anna::RuntimeException) { return createAvp(&id); }
+ Avp* createAvp(AvpId id) noexcept(false) { return createAvp(&id); }
/**
* Creates a new diameter avp, using engine resources to allocate memory (recommended recycler allocation at
*
* @return Created avp ready to be used
*/
- Avp* createAvp() throw(anna::RuntimeException) { return createAvp(NULL); }
+ Avp* createAvp() noexcept(false) { return createAvp(NULL); }
/**
* Creates a new diameter Message assigning its identifier, using engine resources to allocate memory (recommended
*
* @return Created message ready to be used
*/
- Message* createMessage(CommandId id) throw(anna::RuntimeException) { return createMessage(&id); }
+ Message* createMessage(CommandId id) noexcept(false) { return createMessage(&id); }
/**
* Creates a new diameter message, using engine resources to allocate memory (recommended recycler allocation
*
* @return Created message ready to be used
*/
- Message* createMessage() throw(anna::RuntimeException) { return createMessage(NULL); }
+ Message* createMessage() noexcept(false) { return createMessage(NULL); }
/**
@param xmlPathFile_or_string Complete path file or string representation for the xml document which represents the diameter message
@param pathfile_or_string boolean about the interpretation of the previous argument
*/
- Message *createMessage(const std::string & xmlPathFile_or_string, bool pathfile_or_string = true) throw(anna::RuntimeException);
+ Message *createMessage(const std::string & xmlPathFile_or_string, bool pathfile_or_string = true) noexcept(false);
/**
Invoked to free Avps.
\see anna::Recycler
*/
- virtual void releaseAvp(Avp*) throw() = 0;
+ virtual void releaseAvp(Avp*) = 0;
/**
Invoked to free Messages.
\see anna::Recycler
*/
- virtual void releaseMessage(Message*) throw() = 0;
+ virtual void releaseMessage(Message*) = 0;
/**
*
* @return String with class content
*/
- virtual std::string asString(void) const throw();
+ virtual std::string asString(void) const ;
/**
Class XML representation.
\param parent XML node over which we will put instance information.
\return XML documentcon with class content.
*/
- virtual anna::xml::Node* asXML(anna::xml::Node* parent) const throw();
+ virtual anna::xml::Node* asXML(anna::xml::Node* parent) const ;
/**
@return Avp identifier as pair (code,vendor-id)
*/
- AvpId avpIdForName(const char * name) throw(anna::RuntimeException);
+ AvpId avpIdForName(const char * name) noexcept(false);
/**
@return Command identifier as pair (code,request-indicator)
*/
- CommandId commandIdForName(const char * name) throw(anna::RuntimeException);
+ CommandId commandIdForName(const char * name) noexcept(false);
protected:
\see anna::Recycler
*/
- virtual Avp* allocateAvp() throw() = 0;
+ virtual Avp* allocateAvp() = 0;
/**
\see anna::Recycler
*/
- virtual Message* allocateMessage() throw() = 0;
+ virtual Message* allocateMessage() = 0;
/**
@see setValidationDepth
@see getValidationDepth
*/
- void validationAnomaly(const std::string & description) const throw(anna::RuntimeException);
+ void validationAnomaly(const std::string & description) const noexcept(false);
};
}