forked from premiere/premiere-libtorrent
refactor to use unique_ptr with session_impl::m_work (#1063)
This commit is contained in:
parent
e11f233086
commit
0d64bda8d3
|
@ -93,10 +93,6 @@ POSSIBILITY OF SUCH DAMAGE.
|
||||||
#include <cstdarg> // for va_start, va_end
|
#include <cstdarg> // for va_start, va_end
|
||||||
#include <unordered_map>
|
#include <unordered_map>
|
||||||
|
|
||||||
#include "libtorrent/aux_/disable_warnings_push.hpp"
|
|
||||||
#include <boost/optional.hpp>
|
|
||||||
#include "libtorrent/aux_/disable_warnings_pop.hpp"
|
|
||||||
|
|
||||||
namespace libtorrent
|
namespace libtorrent
|
||||||
{
|
{
|
||||||
|
|
||||||
|
@ -835,7 +831,7 @@ namespace libtorrent
|
||||||
|
|
||||||
// keep the io_service alive until we have posted the job
|
// keep the io_service alive until we have posted the job
|
||||||
// to clear the undead peers
|
// to clear the undead peers
|
||||||
boost::optional<io_service::work> m_work;
|
std::unique_ptr<io_service::work> m_work;
|
||||||
|
|
||||||
// this maps sockets to their peer_connection
|
// this maps sockets to their peer_connection
|
||||||
// object. It is the complete list of all connected
|
// object. It is the complete list of all connected
|
||||||
|
|
|
@ -320,7 +320,7 @@ namespace aux {
|
||||||
, *this
|
, *this
|
||||||
#endif
|
#endif
|
||||||
)
|
)
|
||||||
, m_work(io_service::work(m_io_service))
|
, m_work(new io_service::work(m_io_service))
|
||||||
#if TORRENT_USE_I2P
|
#if TORRENT_USE_I2P
|
||||||
, m_i2p_conn(m_io_service)
|
, m_i2p_conn(m_io_service)
|
||||||
#endif
|
#endif
|
||||||
|
@ -821,20 +821,19 @@ namespace aux {
|
||||||
m_incoming_sockets.clear();
|
m_incoming_sockets.clear();
|
||||||
|
|
||||||
// close the listen sockets
|
// close the listen sockets
|
||||||
for (std::list<listen_socket_t>::iterator i = m_listen_sockets.begin()
|
for (auto const& l : m_listen_sockets)
|
||||||
, end(m_listen_sockets.end()); i != end; ++i)
|
|
||||||
{
|
{
|
||||||
if (i->sock)
|
if (l.sock)
|
||||||
{
|
{
|
||||||
i->sock->close(ec);
|
l.sock->close(ec);
|
||||||
TORRENT_ASSERT(!ec);
|
TORRENT_ASSERT(!ec);
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: 3 closing the udp sockets here means that
|
// TODO: 3 closing the udp sockets here means that
|
||||||
// the uTP connections cannot be closed gracefully
|
// the uTP connections cannot be closed gracefully
|
||||||
if (i->udp_sock)
|
if (l.udp_sock)
|
||||||
{
|
{
|
||||||
i->udp_sock->close();
|
l.udp_sock->close();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (m_socks_listen_socket && m_socks_listen_socket->is_open())
|
if (m_socks_listen_socket && m_socks_listen_socket->is_open())
|
||||||
|
@ -857,10 +856,9 @@ namespace aux {
|
||||||
session_log(" aborting all torrents (%d)", int(m_torrents.size()));
|
session_log(" aborting all torrents (%d)", int(m_torrents.size()));
|
||||||
#endif
|
#endif
|
||||||
// abort all torrents
|
// abort all torrents
|
||||||
for (torrent_map::iterator i = m_torrents.begin()
|
for (auto const& te : m_torrents)
|
||||||
, end(m_torrents.end()); i != end; ++i)
|
|
||||||
{
|
{
|
||||||
i->second->abort();
|
te.second->abort();
|
||||||
}
|
}
|
||||||
m_torrents.clear();
|
m_torrents.clear();
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue