-// ANNA - Anna is Not 'N' Anymore
-//
-// (c) Copyright 2005-2014 Eduardo Ramos Testillano & Francisco Ruiz Rayo
-//
-// https://bitbucket.org/testillano/anna
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions
-// are met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the names of its
-// contributors may be used to endorse or promote products derived from
-// this software without specific prior written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-//
-// Authors: eduardo.ramos.testillano@gmail.com
-// cisco.tierra@gmail.com
+// ANNA - Anna is Not Nothingness Anymore //
+// //
+// (c) Copyright 2005-2015 Eduardo Ramos Testillano & Francisco Ruiz Rayo //
+// //
+// See project site at http://redmine.teslayout.com/projects/anna-suite //
+// See accompanying file LICENSE or copy at http://www.teslayout.com/projects/public/anna.LICENSE //
#ifndef anna_comm_ReceiverFactory_hpp
class Receiver;
/**
- Interfaz que deben cumplir las factorias de receptores.
+ Interface for receivers factories.
- Es muy aconsejable que la implementacion particular de esta clase que use nuestra
- aplicacion este basada en el uso de #Recycler<T>. Como muestra el siguiente ejemplo:
+ Is recommended (performance issues) to use #Recycler<T> as in the following example:
\code
private:
anna::Recycler<MyReceiver> a_receivers;
- Receiver* do_create () throw () { return a_receivers.create (); }
- void do_release (Receiver* receiver) throw () { a_receivers.release (static_cast <MyReceiver*> (receiver)); }
+ Receiver* do_create () { return a_receivers.create (); }
+ void do_release (Receiver* receiver) { a_receivers.release (static_cast <MyReceiver*> (receiver)); }
};
\endcode
- En la mayoria de los casos seria aconsejable usar un instancia de comm::ReceiverFactoryImpl
- instanciado con el tipo de receptor usado por nuestra aplicacion.
+ In most of cases, is recommended to use an comm::ReceiverFactoryImpl instance with the receiver type used in our application.
\see Receiver
\see ReceiverFactoryImpl
class ReceiverFactory : public Mutex {
public:
/**
- Devuelve el nombre logico de este gestor de receptores.
- \return el nombre logico de este gestor de receptores.
+ Returns the logical name for this receiver factory.
+ @return logical name for this receiver factory.
*/
- const std::string& getName() const throw() { return a_name; }
+ const std::string& getName() const { return a_name; }
/**
- Crea una instancia del receptor asociado a esta factoria, realiza las comprobaciones
- necesarias para optimizar el reuso de instancias de la clase Receiver.
+ Creates a receiver instance for this factory. Reuse resources when needed.
- \return La instancia de un nuevo receiver.
- \warning Cada uno de los receptores obtenidos debera ser liberado invocando a #release.
+ \return The new receiver instance.
+ \warning All the receivers obtained shall be released by mean #release.
*/
- Receiver* create() throw(RuntimeException);
+ Receiver* create() noexcept(false);
/**
- Libera la instancia del receptor recibido como parametro. Realiza las comprobaciones
- necesarias para optimizar el reuso de instancias de la clase Receiver.
+ Release the receiver instance provided.
- \param receiver Instancia del receiver a liberar.
- \warning El transporte recibido como parametro debera haberse obtenido mediante #create.
+ \return The receiver instance to be released.
+ \warning The parameter should have been obtained by mean #create.
*/
- void release(Receiver* receiver) throw();
+ void release(Receiver* receiver) ;
/**
- Devuelve una cadena con la informacion relevante sobre esta instancia.
- \return una cadena con la informacion relevante sobre esta instancia.
+ Returns a string with relevant information for this instance.
+ @return string with relevant information for this instance.
*/
std::string asString() const
- throw() {
+ {
std::string msg("anna::comm::ReceiverFactory { Name: ");
msg += a_name;
return msg += " }";
}
/**
- Devuelve un documento XML con la informacion relevante sobre esta instancia.
- \param parent Nodo XML del que debe depender el documento generado.
- \return un documento XML con la informacion relevante sobre esta instancia.
+ Returns a XML document with relevant information for this instance.
+ \param parent XML node from which created data will depend on.
+ @return a XML document with relevant information for this instance.
*/
- xml::Node* asXML(xml::Node* parent) const throw();
+ xml::Node* asXML(xml::Node* parent) const ;
protected:
/**
- Constructor
- \param name Nombre logico de esta factoria de receptores.
+ Constructor.
+ \param name Logical name for this receivers factory.
*/
ReceiverFactory(const char* name);
/**
- Crea realmente la instancia del receptor asociado a esta factoria, solo sera invocado
- en caso de que no haya ninguna otra instancia disponible que pueda ser reusada.
+ Creates the receiver instance if no other reusable instance is found. This method is
+ called from a critical section activated for this instance.
- La invocacion a este metodo se realiza desde una seccion critica activada sobre esta
- instancia.
-
- Es muy aconsejable que la implementacion particular de este metodo este basada en el
- uso de #Recycler<T>.
-
- \return La instancia de un nuevo receiver.
- \warning Cada uno de los receptores obtenidos debera ser liberado invocando a #release.
+ \return The new receiver instance.
+ \warning All the receivers obtained shall be released by mean #release.
*/
- virtual Receiver* do_create() throw() = 0;
+ virtual Receiver* do_create() = 0;
/**
- Libera realmente la instancia del receptor recibido como parametro.
-
- Es muy aconsejable que la implementacion particular de este metodo este basada en el
- uso de #Recycler<T>.
-
- La invocacion a este metodo se realiza desde una seccion critica activada sobre esta
- instancia.
+ Release the receiver provided. This method is called from a critical section activated
+ for this instance.
- \param receiver Instancia del receiver a liberar.
+ \param The receiver instance to be released.
*/
- virtual void do_release(Receiver* receiver) throw() = 0;
+ virtual void do_release(Receiver* receiver) = 0;
private:
const std::string a_name;