Devuelve el tipo de controlador.
\return el tipo de controlador.
*/
- Type::_v getType() const throw() { return a_type; }
+ Type::_v getType() const { return a_type; }
/**
Devuelve el descriptor de fichero asociado a este controlador.
\return el descriptor de fichero asociado a este controlador.
*/
- int getfd() const throw() { return a_fd; }
+ int getfd() const { return a_fd; }
/**
Devuelve \em true si el descriptor de fichero asociado a este controlador soporta
\return \em true si el descriptor de fichero asociado a este controlador soporta
control de congestion o \em false en otro caso.
*/
- bool supportCongestionControl() const throw() { return (a_support & Support::CongestionControl) != 0; }
+ bool supportCongestionControl() const { return (a_support & Support::CongestionControl) != 0; }
/**
Devuelve \em true si este manejador soporta control de temporizacion o \em false en otro
\return \em true si este manejador soporta control de temporizacion o \em false en otro
caso.
*/
- bool supportTimeout() const throw() { return a_timeout > 0; }
+ bool supportTimeout() const { return a_timeout > 0; }
/**
Operador de comparacion.
\param fd Descriptor de fichero con el que comparar.
\return \em true si el fd recibido es igual al establecido con #setfd o \em false en caso contrario.
*/
- bool operator == (const int fd) const throw() { return a_fd == fd; }
+ bool operator == (const int fd) const { return a_fd == fd; }
/**
Metodo invocado por el comunicador cuando detectado actividad en el descriptor de
fichero asociado a este controlador.
*/
- virtual void apply() throw(RuntimeException) = 0;
+ virtual void apply() noexcept(false) = 0;
/**
Devuelve el ClientSocket asociado a este manejador de conexiones.
\return El ClientSocket asociado a este manejador de conexiones. Puede ser NULL.
\warning Uso interno. Se necesita para poder cooperar con el anna::comm::CongestionController.
*/
- virtual ClientSocket* getClientSocket() throw() { return NULL; }
+ virtual ClientSocket* getClientSocket() { return NULL; }
/**
Devuelve una cadena con la informacion referente a esta instancia.
\return una cadena con la informacion referente a esta instancia.
*/
- virtual std::string asString() const throw();
+ virtual std::string asString() const ;
/**
Devuelve un documento XML con la informacion referente a esta instancia.
\return un documento XML con la informacion referente a esta instancia.
*/
- virtual xml::Node* asXML(xml::Node* parent) const throw(RuntimeException);
+ virtual xml::Node* asXML(xml::Node* parent) const noexcept(false);
/**
Amplia la informacion XML del nodo recibido como parametro.
\param node Nodo XML en el que incorporar los atributos.
*/
- void asAttribute(xml::Node* node) const throw(RuntimeException);
+ void asAttribute(xml::Node* node) const noexcept(false);
protected:
/**
\warning La implementacion del metodo initialize debe invocar a este metodo
con descriptor de fichero valido.
*/
- void setfd(const int fd) throw() { setId(anna::functions::asText("Handler", a_fd = fd)); }
+ void setfd(const int fd) { setId(anna::functions::asText("Handler", a_fd = fd)); }
/**
Establece el numero de milisegundos maximo que puede estar este manejador sin
recibir mensajes antes de ser cerrado por el nucleo.
\param timeout Numero de milisegundos maximo sin recibir mensajes.
*/
- void setTimeout(const Millisecond &timeout) throw() {
+ void setTimeout(const Millisecond &timeout) {
a_timeout = timeout;
a_maxTime = functions::hardwareClock() + a_timeout;
}
En los manejadores que pueden recibir mas de una peticion en cada llamada a apply este
metodo debe ser invocado para saber si debe dejar de procesar mensajes.
*/
- bool canContinue() const throw() { return hasRequestedStop() == false; }
+ bool canContinue() const { return hasRequestedStop() == false; }
/**
Metodo con el que podemos redefinir el comportamiento cuando recibe la notificacion de
\param address Direccion IP que ha dejado de estar disponible.
\warning Se invoca automaticamente desde el comunicador.
*/
- virtual void breakAddress(const in_addr_t& address) throw() {;}
+ virtual void breakAddress(const in_addr_t& address) {;}
/**
Metodo con el que podemos redefinir el comportamiento cuando recibe la notificacion de
\param address Direccion IP que ha pasado a estar disponible.
\warning Se invoca automaticamente desde el comunicador.
*/
- virtual void recoverAddress(const in_addr_t& address) throw() {;}
+ virtual void recoverAddress(const in_addr_t& address) {;}
/**
* Método que se invoca periódicamente para comprobar si tenemos pendiente el cierre de la conexión
*
* \return \em true Si termina la conexión o \em false en otro caso.
*/
- virtual bool testClose() throw(RuntimeException) { return false;}
+ virtual bool testClose() noexcept(false) { return false;}
/**
Metodo con el que podemos redefinir el comportamiento cuando recibe la notificacion de
\warning Se invoca automaticamente desde el comunicador al invocar al metodo
\em detach correspondiente.
*/
- virtual void finalize() throw() {;}
+ virtual void finalize() {;}
/**
* Metodo con el que podemos redefinir el comportamiento cuando recibe la notificacion de
* que el componente asociado a este controlador ha sido duplicado en un proceso hijo.
* \warning Exclusivamente uso interno.
*/
- virtual void clone() throw(RuntimeException) {;}
+ virtual void clone() noexcept(false) {;}
private:
const Type::_v a_type;
int a_loop;
Handler(const Handler&);
- void do_action() throw(RuntimeException);
- void beat(const Microsecond& now) throw() { a_maxTime = now + a_timeout; }
+ void do_action() noexcept(false);
+ void beat(const Microsecond& now) { a_maxTime = now + a_timeout; }
bool isTimeout(const Microsecond& now) { return a_maxTime > 0 && a_maxTime <= now; }
friend class Communicator;