refactor to use unique_ptr with session_impl::m_work (#1063)

This commit is contained in:
Alden Torres 2016-09-04 21:49:11 -04:00 committed by Arvid Norberg
parent e11f233086
commit 0d64bda8d3
2 changed files with 9 additions and 15 deletions

View File

@ -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

View File

@ -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();