mirror of
https://github.com/boostorg/beast.git
synced 2025-07-31 21:34:46 +02:00
Tidy up websocket service
This commit is contained in:
@@ -46,6 +46,7 @@ the program, with the macro BOOST_BEAST_SPLIT_COMPILATION defined.
|
||||
#include <boost/beast/http/impl/verb.ipp>
|
||||
|
||||
#include <boost/beast/websocket/detail/prng.ipp>
|
||||
#include <boost/beast/websocket/detail/service.ipp>
|
||||
#include <boost/beast/websocket/impl/error.ipp>
|
||||
|
||||
#include <boost/beast/zlib/detail/deflate_stream.ipp>
|
||||
|
@@ -36,25 +36,13 @@ public:
|
||||
public:
|
||||
virtual ~impl_type() = default;
|
||||
|
||||
BOOST_BEAST_DECL
|
||||
explicit
|
||||
impl_type(net::execution_context& ctx)
|
||||
: svc_(net::use_service<service>(ctx))
|
||||
{
|
||||
std::lock_guard<std::mutex> g(svc_.m_);
|
||||
index_ = svc_.v_.size();
|
||||
svc_.v_.push_back(this);
|
||||
}
|
||||
impl_type(net::execution_context& ctx);
|
||||
|
||||
BOOST_BEAST_DECL
|
||||
void
|
||||
remove()
|
||||
{
|
||||
std::lock_guard<std::mutex> g(svc_.m_);
|
||||
auto& other = *svc_.v_.back();
|
||||
other.index_ = index_;
|
||||
svc_.v_[index_] = &other;
|
||||
svc_.v_.pop_back();
|
||||
}
|
||||
remove();
|
||||
|
||||
virtual
|
||||
void
|
||||
@@ -67,19 +55,7 @@ private:
|
||||
|
||||
BOOST_BEAST_DECL
|
||||
void
|
||||
shutdown() override
|
||||
{
|
||||
std::vector<boost::weak_ptr<impl_type>> v;
|
||||
{
|
||||
std::lock_guard<std::mutex> g(m_);
|
||||
v.reserve(v_.size());
|
||||
for(auto p : v_)
|
||||
v.emplace_back(p->weak_from_this());
|
||||
}
|
||||
for(auto wp : v)
|
||||
if(auto sp = wp.lock())
|
||||
sp->shutdown();
|
||||
}
|
||||
shutdown() override;
|
||||
|
||||
public:
|
||||
BOOST_BEAST_DECL
|
||||
@@ -95,4 +71,8 @@ public:
|
||||
} // beast
|
||||
} // boost
|
||||
|
||||
#if BOOST_BEAST_HEADER_ONLY
|
||||
#include <boost/beast/websocket/detail/service.ipp>
|
||||
#endif
|
||||
|
||||
#endif
|
||||
|
65
include/boost/beast/websocket/detail/service.ipp
Normal file
65
include/boost/beast/websocket/detail/service.ipp
Normal file
@@ -0,0 +1,65 @@
|
||||
//
|
||||
// Copyright (c) 2016-2019 Vinnie Falco (vinnie dot falco at gmail dot com)
|
||||
//
|
||||
// Distributed under the Boost Software License, Version 1.0. (See accompanying
|
||||
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
||||
//
|
||||
// Official repository: https://github.com/boostorg/beast
|
||||
//
|
||||
|
||||
#ifndef BOOST_BEAST_WEBSOCKET_DETAIL_SERVICE_IPP
|
||||
#define BOOST_BEAST_WEBSOCKET_DETAIL_SERVICE_IPP
|
||||
|
||||
#include <boost/beast/websocket/detail/service.hpp>
|
||||
|
||||
namespace boost {
|
||||
namespace beast {
|
||||
namespace websocket {
|
||||
namespace detail {
|
||||
|
||||
service::
|
||||
impl_type::
|
||||
impl_type(net::execution_context& ctx)
|
||||
: svc_(net::use_service<service>(ctx))
|
||||
{
|
||||
std::lock_guard<std::mutex> g(svc_.m_);
|
||||
index_ = svc_.v_.size();
|
||||
svc_.v_.push_back(this);
|
||||
}
|
||||
|
||||
void
|
||||
service::
|
||||
impl_type::
|
||||
remove()
|
||||
{
|
||||
std::lock_guard<std::mutex> g(svc_.m_);
|
||||
auto& other = *svc_.v_.back();
|
||||
other.index_ = index_;
|
||||
svc_.v_[index_] = &other;
|
||||
svc_.v_.pop_back();
|
||||
}
|
||||
|
||||
//---
|
||||
|
||||
void
|
||||
service::
|
||||
shutdown()
|
||||
{
|
||||
std::vector<boost::weak_ptr<impl_type>> v;
|
||||
{
|
||||
std::lock_guard<std::mutex> g(m_);
|
||||
v.reserve(v_.size());
|
||||
for(auto p : v_)
|
||||
v.emplace_back(p->weak_from_this());
|
||||
}
|
||||
for(auto wp : v)
|
||||
if(auto sp = wp.lock())
|
||||
sp->shutdown();
|
||||
}
|
||||
|
||||
} // detail
|
||||
} // websocket
|
||||
} // beast
|
||||
} // boost
|
||||
|
||||
#endif
|
Reference in New Issue
Block a user