...
This commit is contained in:
parent
8c1410ec90
commit
02811a92b5
@ -20,15 +20,18 @@ namespace adc
|
|||||||
{
|
{
|
||||||
|
|
||||||
template <traits::adc_netserver_session_c SessionT>
|
template <traits::adc_netserver_session_c SessionT>
|
||||||
class AdcNetServerSessionSpdlogDecorator : public SessionT
|
class AdcNetServerSessionSpdlogDecorator : public AdcSpdlogGenericMarkDecorator<SessionT>
|
||||||
{
|
{
|
||||||
protected:
|
protected:
|
||||||
std::shared_ptr<spdlog::logger> _logger;
|
using base_t = AdcSpdlogGenericMarkDecorator<SessionT>;
|
||||||
|
|
||||||
void* _thisAddress;
|
|
||||||
std::string _sessionID;
|
std::string _sessionID;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
using base_t::logDebug;
|
||||||
|
using base_t::logInfo;
|
||||||
|
using base_t::logMethodCalling;
|
||||||
|
|
||||||
// using SessionT::sessionIdent;
|
// using SessionT::sessionIdent;
|
||||||
using typename SessionT::session_ident_t;
|
using typename SessionT::session_ident_t;
|
||||||
|
|
||||||
@ -36,63 +39,62 @@ public:
|
|||||||
|
|
||||||
template <typename... ImplCtorArgTs>
|
template <typename... ImplCtorArgTs>
|
||||||
AdcNetServerSessionSpdlogDecorator(std::shared_ptr<spdlog::logger> logger, ImplCtorArgTs&&... ctor_args)
|
AdcNetServerSessionSpdlogDecorator(std::shared_ptr<spdlog::logger> logger, ImplCtorArgTs&&... ctor_args)
|
||||||
: SessionT(std::forward<ImplCtorArgTs>(ctor_args)...),
|
: base_t("ADC NETSERVER SESSION", logger, std::forward<ImplCtorArgTs>(ctor_args)...)
|
||||||
_logger(logger),
|
|
||||||
_thisAddress((void*)std::addressof(this))
|
|
||||||
{
|
{
|
||||||
|
logMethodCalling(__PRETTY_FUNCTION__);
|
||||||
|
|
||||||
fmt::format_to(std::back_inserter(_sessionID), "{}", SessionT::sessionIdent());
|
fmt::format_to(std::back_inserter(_sessionID), "{}", SessionT::sessionIdent());
|
||||||
|
|
||||||
_logger->trace("Call AdcNetServerSessionSpdlogDecorator::AdcNetServerSessionSpdlogDecorator (this: {})",
|
this->setPattern(base_t::constructPattern(_sessionID));
|
||||||
_thisAddress);
|
|
||||||
|
|
||||||
_logger->debug("Creating network server session with ID = [{}] (ADDR = {})", _sessionID, _thisAddress);
|
logDebug("Creating network server session with ID = [{}] (ADDR = {})", _sessionID, this->_thisAddress);
|
||||||
_logger->debug("use logger with name [{}] and level [{}]", _logger->name(),
|
logDebug("Use logger with ", this->loggerInfo());
|
||||||
spdlog::level::to_string_view(_logger->level()));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual ~AdcNetServerSessionSpdlogDecorator()
|
virtual ~AdcNetServerSessionSpdlogDecorator()
|
||||||
{
|
{
|
||||||
_logger->trace("Call AdcNetServerSessionSpdlogDecorator::~AdcNetServerSessionSpdlogDecorator (this: {})",
|
logMethodCalling(__PRETTY_FUNCTION__);
|
||||||
_thisAddress);
|
|
||||||
|
|
||||||
_logger->debug("Deleting network server session with ID = [{}] (ADDR = {})", _sessionID, _thisAddress);
|
logDebug("Deleting network server session with ID = [{}] (ADDR = {})", _sessionID, this->_thisAddress);
|
||||||
|
|
||||||
_logger->flush();
|
|
||||||
};
|
};
|
||||||
|
|
||||||
virtual session_ident_t sessionIdent() const override
|
virtual session_ident_t sessionIdent() const override
|
||||||
{
|
{
|
||||||
_logger->trace("Call AdcNetServerSessionSpdlogDecorator::sessionIdent (this: {})", _thisAddress);
|
logMethodCalling(__PRETTY_FUNCTION__);
|
||||||
|
|
||||||
return SessionT::sessionIdent();
|
return SessionT::sessionIdent();
|
||||||
};
|
};
|
||||||
|
|
||||||
virtual void start() override
|
virtual void start() override
|
||||||
{
|
{
|
||||||
_logger->trace("Call AdcNetServerSessionSpdlogDecorator::start (this: {})", _thisAddress);
|
logMethodCalling(__PRETTY_FUNCTION__);
|
||||||
|
|
||||||
_logger->info("Starting network server session with ID = [{}] (ADDR = {})", _sessionID, _thisAddress);
|
logInfo("Starting network server session with ID = [{}]", _sessionID);
|
||||||
|
|
||||||
SessionT::start();
|
SessionT::start();
|
||||||
|
|
||||||
|
logInfo("Network server session [{}] is started", _sessionID);
|
||||||
};
|
};
|
||||||
|
|
||||||
virtual void stop() override
|
virtual void stop() override
|
||||||
{
|
{
|
||||||
_logger->trace("Call AdcNetServerSessionSpdlogDecorator::stop (this: {})", _thisAddress);
|
logMethodCalling(__PRETTY_FUNCTION__);
|
||||||
|
|
||||||
_logger->info("Stopping network server session with ID = [{}] (ADDR = {})", _sessionID, _thisAddress);
|
logInfo("Stopping network server session with ID = [{}]", _sessionID);
|
||||||
|
|
||||||
SessionT::stop();
|
SessionT::stop();
|
||||||
|
|
||||||
|
logInfo("Network server session [{}] is stopped", _sessionID);
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
template <traits::adc_netserver_c ServerT>
|
template <traits::adc_netserver_c ServerT>
|
||||||
class AdcNetServerSpdlogDecorator : public AdcSpdlogGenericDecorator<ServerT>
|
class AdcNetServerSpdlogDecorator : public AdcSpdlogGenericMarkDecorator<ServerT>
|
||||||
{
|
{
|
||||||
protected:
|
protected:
|
||||||
using base_t = AdcSpdlogGenericDecorator<ServerT>;
|
using base_t = AdcSpdlogGenericMarkDecorator<ServerT>;
|
||||||
|
|
||||||
std::string _serverID;
|
std::string _serverID;
|
||||||
|
|
||||||
@ -106,19 +108,26 @@ public:
|
|||||||
|
|
||||||
using typename ServerT::server_ident_t;
|
using typename ServerT::server_ident_t;
|
||||||
|
|
||||||
|
static_assert(traits::formattable<server_ident_t>, "NETWORK SERVER IDENT TYPE MUST BE A FORMATTABLE ONE!!!");
|
||||||
|
|
||||||
template <typename... ImplCtorArgTs>
|
template <typename... ImplCtorArgTs>
|
||||||
AdcNetServerSpdlogDecorator(std::shared_ptr<spdlog::logger> logger, ImplCtorArgTs&&... ctor_args)
|
AdcNetServerSpdlogDecorator(std::shared_ptr<spdlog::logger> logger, ImplCtorArgTs&&... ctor_args)
|
||||||
: base_t(logger, std::forward<ImplCtorArgTs>(ctor_args)...)
|
: base_t("ADC NETSERVER", logger, std::forward<ImplCtorArgTs>(ctor_args)...)
|
||||||
{
|
{
|
||||||
|
this->logMethodCalling(__PRETTY_FUNCTION__);
|
||||||
|
|
||||||
fmt::format_to(std::back_inserter(_serverID), "{}", ServerT::serverIdent());
|
fmt::format_to(std::back_inserter(_serverID), "{}", ServerT::serverIdent());
|
||||||
|
|
||||||
|
this->setPattern(base_t::constructPattern(_serverID));
|
||||||
|
|
||||||
logDebug("Creating network server with ID = [{}] (ADDR = {})", _serverID, this->_thisAddress);
|
logDebug("Creating network server with ID = [{}] (ADDR = {})", _serverID, this->_thisAddress);
|
||||||
|
logDebug("Use logger with ", this->loggerInfo());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
virtual ~AdcNetServerSpdlogDecorator()
|
virtual ~AdcNetServerSpdlogDecorator()
|
||||||
{
|
{
|
||||||
this->logMethodCalling();
|
this->logMethodCalling(__PRETTY_FUNCTION__);
|
||||||
|
|
||||||
logDebug("Deleting network server with ID = [{}] (ADDR = {})", _serverID, this->_thisAddress);
|
logDebug("Deleting network server with ID = [{}] (ADDR = {})", _serverID, this->_thisAddress);
|
||||||
}
|
}
|
||||||
@ -126,26 +135,31 @@ public:
|
|||||||
|
|
||||||
virtual server_ident_t serverIdent() const
|
virtual server_ident_t serverIdent() const
|
||||||
{
|
{
|
||||||
//
|
this->logMethodCalling(__PRETTY_FUNCTION__);
|
||||||
|
|
||||||
return ServerT::serverIdent();
|
return ServerT::serverIdent();
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void start()
|
virtual void start()
|
||||||
{
|
{
|
||||||
this->logMethodCalling();
|
this->logMethodCalling(__PRETTY_FUNCTION__);
|
||||||
|
|
||||||
logInfo("Starting network server");
|
logInfo("Starting network server");
|
||||||
|
|
||||||
ServerT::start();
|
ServerT::start();
|
||||||
|
|
||||||
|
logInfo("Network server is started");
|
||||||
};
|
};
|
||||||
|
|
||||||
virtual void stop()
|
virtual void stop()
|
||||||
{
|
{
|
||||||
this->logMethodCalling();
|
this->logMethodCalling(__PRETTY_FUNCTION__);
|
||||||
|
|
||||||
logInfo("Stopping network server");
|
logInfo("Stopping network server ...");
|
||||||
|
|
||||||
ServerT::stop();
|
ServerT::stop();
|
||||||
|
|
||||||
|
logInfo("Network server is stopped");
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user