-
Notifications
You must be signed in to change notification settings - Fork 863
/
Copy pathrecvfile.cpp
113 lines (89 loc) · 2.85 KB
/
recvfile.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
#ifndef _WIN32
#include <arpa/inet.h>
#include <netdb.h>
#else
#include <winsock2.h>
#include <ws2tcpip.h>
#endif
#include <fstream>
#include <iostream>
#include <cstdlib>
#include <cstring>
#include <srt.h>
using namespace std;
int main(int argc, char* argv[])
{
if ((argc != 5) || (0 == atoi(argv[2])))
{
cout << "usage: recvfile server_ip server_port remote_filename local_filename" << endl;
return -1;
}
// Use this function to initialize the UDT library
srt_startup();
srt_setloglevel(srt_logging::LogLevel::debug);
struct addrinfo hints, *peer;
memset(&hints, 0, sizeof(struct addrinfo));
hints.ai_flags = AI_PASSIVE;
hints.ai_family = AF_INET;
hints.ai_socktype = SOCK_DGRAM;
SRTSOCKET fhandle = srt_create_socket();
// SRT requires that third argument is always SOCK_DGRAM. The Stream API is set by an option,
// although there's also lots of other options to be set, for which there's a convenience option,
// SRTO_TRANSTYPE.
SRT_TRANSTYPE tt = SRTT_FILE;
srt_setsockopt(fhandle, 0, SRTO_TRANSTYPE, &tt, sizeof tt);
if (0 != getaddrinfo(argv[1], argv[2], &hints, &peer))
{
cout << "incorrect server/peer address. " << argv[1] << ":" << argv[2] << endl;
return -1;
}
// Connect to the server, implicit bind.
if (SRT_ERROR == srt_connect(fhandle, peer->ai_addr, peer->ai_addrlen))
{
cout << "connect: " << srt_getlasterror_str() << endl;
return -1;
}
freeaddrinfo(peer);
// Send name information of the requested file.
int len = strlen(argv[3]);
if (SRT_ERROR == srt_send(fhandle, (char*)&len, sizeof(int)))
{
cout << "send: " << srt_getlasterror_str() << endl;
return -1;
}
if (SRT_ERROR == srt_send(fhandle, argv[3], len))
{
cout << "send: " << srt_getlasterror_str() << endl;
return -1;
}
// Get size information.
int64_t size;
if (SRT_ERROR == srt_recv(fhandle, (char*)&size, sizeof(int64_t)))
{
cout << "send: " << srt_getlasterror_str() << endl;
return -1;
}
if (size < 0)
{
cout << "no such file " << argv[3] << " on the server\n";
return -1;
}
// Receive the file.
int64_t recvsize;
int64_t offset = 0;
SRT_TRACEBSTATS trace;
srt_bstats(fhandle, &trace, true);
if (SRT_ERROR == (recvsize = srt_recvfile(fhandle, argv[4], &offset, size, SRT_DEFAULT_RECVFILE_BLOCK)))
{
cout << "recvfile: " << srt_getlasterror_str() << endl;
return -1;
}
srt_bstats(fhandle, &trace, true);
cout << "speed = " << trace.mbpsRecvRate << "Mbits/sec" << endl;
int losspercent = 100*trace.pktRcvLossTotal/trace.pktRecv;
cout << "loss = " << trace.pktRcvLossTotal << "pkt (" << losspercent << "%)\n";
srt_close(fhandle);
// Signal to the SRT library to clean up all allocated sockets and resources.
srt_cleanup();
return 0;
}