mirror of
https://github.com/codex-storage/deluge.git
synced 2025-01-24 10:18:51 +00:00
lt sync 3253 - fix ssl trackers
This commit is contained in:
parent
f521795552
commit
7842ad5d3d
@ -34,6 +34,7 @@ POSSIBILITY OF SUCH DAMAGE.
|
||||
#define TORRENT_XML_PARSE_HPP
|
||||
|
||||
#include <cctype>
|
||||
#include <cstring>
|
||||
|
||||
namespace libtorrent
|
||||
{
|
||||
@ -49,6 +50,12 @@ namespace libtorrent
|
||||
xml_parse_error
|
||||
};
|
||||
|
||||
inline bool isspace(char c)
|
||||
{
|
||||
const static char* ws = " \t\n\r\f\v";
|
||||
return std::strchr(ws, c);
|
||||
}
|
||||
|
||||
// callback(int type, char const* name, char const* val)
|
||||
// str2 is only used for attributes. name is element or attribute
|
||||
// name and val is attribute value
|
||||
@ -82,7 +89,7 @@ namespace libtorrent
|
||||
++p;
|
||||
|
||||
// parse the name of the tag.
|
||||
for (start = p; p != end && *p != '>' && !std::isspace(*p); ++p);
|
||||
for (start = p; p != end && *p != '>' && !isspace(*p); ++p);
|
||||
|
||||
char* tag_name_end = p;
|
||||
|
||||
@ -149,11 +156,11 @@ namespace libtorrent
|
||||
for (char* i = tag_name_end; i < tag_end; ++i)
|
||||
{
|
||||
// find start of attribute name
|
||||
for (; i != tag_end && std::isspace(*i); ++i);
|
||||
for (; i != tag_end && isspace(*i); ++i);
|
||||
if (i == tag_end) break;
|
||||
start = i;
|
||||
// find end of attribute name
|
||||
for (; i != tag_end && *i != '=' && !std::isspace(*i); ++i);
|
||||
for (; i != tag_end && *i != '=' && !isspace(*i); ++i);
|
||||
char* name_end = i;
|
||||
|
||||
// look for equality sign
|
||||
@ -169,7 +176,7 @@ namespace libtorrent
|
||||
}
|
||||
|
||||
++i;
|
||||
for (; i != tag_end && std::isspace(*i); ++i);
|
||||
for (; i != tag_end && isspace(*i); ++i);
|
||||
// check for parse error (values must be quoted)
|
||||
if (i == tag_end || (*i != '\'' && *i != '\"'))
|
||||
{
|
||||
|
@ -399,8 +399,11 @@ void http_connection::on_read(error_code const& e
|
||||
TORRENT_ASSERT(m_download_quota >= 0);
|
||||
}
|
||||
|
||||
if (e == asio::error::eof)
|
||||
// when using the asio SSL wrapper, it seems like
|
||||
// we get the shut_down error instead of EOF
|
||||
if (e == asio::error::eof || e == asio::error::shut_down)
|
||||
{
|
||||
error_code ec = asio::error::eof;
|
||||
TORRENT_ASSERT(bytes_transferred == 0);
|
||||
char const* data = 0;
|
||||
std::size_t size = 0;
|
||||
@ -409,7 +412,7 @@ void http_connection::on_read(error_code const& e
|
||||
data = m_parser.get_body().begin;
|
||||
size = m_parser.get_body().left();
|
||||
}
|
||||
callback(e, data, size);
|
||||
callback(ec, data, size);
|
||||
close();
|
||||
return;
|
||||
}
|
||||
|
@ -2375,10 +2375,6 @@ namespace libtorrent
|
||||
}
|
||||
#endif
|
||||
|
||||
// add the newly connected peer to this torrent's peer list
|
||||
m_connections.insert(boost::get_pointer(c));
|
||||
m_ses.m_connections.insert(c);
|
||||
|
||||
#ifndef BOOST_NO_EXCEPTIONS
|
||||
try
|
||||
{
|
||||
|
Loading…
x
Reference in New Issue
Block a user