forked from premiere/premiere-libtorrent
improve print-out of fast extension test
This commit is contained in:
parent
8e8b0495e1
commit
d73f4f0c92
|
@ -64,10 +64,47 @@ int read_message(stream_socket& s, char* buffer)
|
||||||
return length;
|
return length;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void print_message(char const* buffer, int len)
|
||||||
|
{
|
||||||
char const* message_name[] = {"choke", "unchoke", "interested", "not_interested"
|
char const* message_name[] = {"choke", "unchoke", "interested", "not_interested"
|
||||||
, "have", "bitfield", "request", "piece", "cancel", "dht_port", "", "", ""
|
, "have", "bitfield", "request", "piece", "cancel", "dht_port", "", "", ""
|
||||||
, "suggest_piece", "have_all", "have_none", "reject_request", "allowed_fast"};
|
, "suggest_piece", "have_all", "have_none", "reject_request", "allowed_fast"};
|
||||||
|
|
||||||
|
char message[50];
|
||||||
|
char extra[300];
|
||||||
|
extra[0] = 0;
|
||||||
|
if (len == 0)
|
||||||
|
{
|
||||||
|
strcpy(message, "keepalive");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
int msg = buffer[0];
|
||||||
|
if (msg >= 0 && msg < int(sizeof(message_name)/sizeof(message_name[0])))
|
||||||
|
strcpy(message, message_name[msg]);
|
||||||
|
else
|
||||||
|
snprintf(message, sizeof(message), "unknown[%d]", msg);
|
||||||
|
|
||||||
|
if (msg == 0x6 && len == 13)
|
||||||
|
{
|
||||||
|
peer_request r;
|
||||||
|
const char* ptr = buffer + 1;
|
||||||
|
r.piece = detail::read_int32(ptr);
|
||||||
|
r.start = detail::read_int32(ptr);
|
||||||
|
r.length = detail::read_int32(ptr);
|
||||||
|
snprintf(extra, sizeof(extra), "p: %d s: %d l: %d", r.piece, r.start, r.length);
|
||||||
|
}
|
||||||
|
else if (msg == 0x11 && len == 5)
|
||||||
|
{
|
||||||
|
const char* ptr = buffer + 1;
|
||||||
|
int index = detail::read_int32(ptr);
|
||||||
|
snprintf(extra, sizeof(extra), "p: %d", index);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fprintf(stderr, "%s <== %s %s\n", time_now_string(), message, extra);
|
||||||
|
}
|
||||||
|
|
||||||
void send_allow_fast(stream_socket& s, int piece)
|
void send_allow_fast(stream_socket& s, int piece)
|
||||||
{
|
{
|
||||||
std::cout << time_now_string() << " ==> allow fast: " << piece << std::endl;
|
std::cout << time_now_string() << " ==> allow fast: " << piece << std::endl;
|
||||||
|
@ -188,12 +225,9 @@ void test_reject_fast()
|
||||||
|
|
||||||
while (!allowed_fast.empty())
|
while (!allowed_fast.empty())
|
||||||
{
|
{
|
||||||
read_message(s, recv_buffer);
|
int len = read_message(s, recv_buffer);
|
||||||
|
print_message(recv_buffer, len);
|
||||||
int msg = recv_buffer[0];
|
int msg = recv_buffer[0];
|
||||||
if (msg >= 0 && msg < int(sizeof(message_name)/sizeof(message_name[0])))
|
|
||||||
std::cerr << time_now_string() << " <== " << message_name[msg] << std::endl;
|
|
||||||
else
|
|
||||||
std::cerr << time_now_string() << " <== " << msg << std::endl;
|
|
||||||
if (recv_buffer[0] != 0x6) continue;
|
if (recv_buffer[0] != 0x6) continue;
|
||||||
|
|
||||||
using namespace libtorrent::detail;
|
using namespace libtorrent::detail;
|
||||||
|
@ -254,13 +288,9 @@ void test_respect_suggest()
|
||||||
int fail_counter = 100;
|
int fail_counter = 100;
|
||||||
while (!suggested.empty() && fail_counter > 0)
|
while (!suggested.empty() && fail_counter > 0)
|
||||||
{
|
{
|
||||||
read_message(s, recv_buffer);
|
int len = read_message(s, recv_buffer);
|
||||||
std::cerr << time_now_string() << " <== ";
|
print_message(recv_buffer, len);
|
||||||
int msg = recv_buffer[0];
|
int msg = recv_buffer[0];
|
||||||
if (msg >= 0 && msg < int(sizeof(message_name)/sizeof(message_name[0])))
|
|
||||||
std::cerr << message_name[msg] << std::endl;
|
|
||||||
else
|
|
||||||
std::cerr << msg << std::endl;
|
|
||||||
fail_counter--;
|
fail_counter--;
|
||||||
if (recv_buffer[0] != 0x6) continue;
|
if (recv_buffer[0] != 0x6) continue;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue