1 // ANNA - Anna is Not Nothingness Anymore //
3 // (c) Copyright 2005-2015 Eduardo Ramos Testillano & Francisco Ruiz Rayo //
5 // See project site at http://redmine.teslayout.com/projects/anna-suite //
6 // See accompanying file LICENSE or copy at http://www.teslayout.com/projects/public/anna.LICENSE //
9 #ifndef anna_comm_Application_hpp
10 #define anna_comm_Application_hpp
14 #include <anna/app/Application.hpp>
16 #include <anna/comm/functions.hpp>
27 class TransportFactory;
30 Clase que modela el cargador de configuracin de gestor de comunicaciones.
32 Esta clase realiza dos operaciones primordiales para el comunicador:
33 \li Establece las direcciones en las que el comunicador de nuestra aplicacion atiende peticiones
34 de los procesos clientes. Este paso slo sera necesario si nuestro proceso acta como servidor
36 \li Establece las direcciones de los servidores de nuestra aplicacion. Este paso slo sera necesario
37 si nuestra aplicacion acta como cliente de algn otro servidor.
39 Hay que destacar que nuestra aplicacion puede actuar simultaneamente como cliente y/o servidor por
40 lo que puede haber ocasiones en que sea requieran las dos operaciones.
42 \see Communicator::setup
44 class Application : public app::Application {
47 Devuelve la instancia de la factoria de protocolos a usar por defecto en esta
49 \return La instancia de la factoria de protocolos a usar por defecto en esta
52 virtual TransportFactory& getDefaultTransportFactory() throw();
58 @param shortName Nombre lgico de esta instancia. Ver Runnable.
59 @param title titulo de la aplicacion que aparecera al arrancar.
60 @param version Version de este programa. Aconsejamos el forma X.YRZZ. Donde X es la
61 version principal, Y la version secundaria y ZZ es el nmero de entrega realizada.
62 \param date Fecha de realizacion del componente. Normalmente sera el contenido de la macro __DATE__.
63 \param time Hora de realizacion del componente. Normalmente sera el contenido de la macro __TIME__.
65 Application(const char *shortName, const char *title, const char *version, const char* date = NULL, const char* time = NULL);
68 Metodo manejador que podemos re-escribir para tratar la recepcion de la senhal SIGTERM.
70 virtual void signalTerminate() throw(RuntimeException);
73 Application(const Application&);
74 bool supportCommunication() const throw() { return true; }
76 friend class Communicator;
77 friend anna::comm::Application& comm::functions::getApp() throw(RuntimeException);