#include <stdio.h>
#include <stdlib.h>
#include <string.h>
+#include <net/if.h>
#include <sys/socket.h>
#include <map>
#include <string>
using namespace std;
-#define DEFAULT_BACKLOG_SIZE 1048576
+#define DEFAULT_BACKLOG_SIZE 10485760
struct ConfigLine {
string keyword;
lines->push_back(line);
}
- fclose(fp);
+ if (fclose(fp) == EOF) {
+ log_perror(filename.c_str());
+ return false;
+ }
return true;
}
}
AcceptorConfig acceptor;
- acceptor.addr = CreateAnyAddress(port);
+ acceptor.addr = create_any_address(port);
config->acceptors.push_back(acceptor);
return true;
stream.backlog_size = atoi(backlog_it->second.c_str());
}
+ map<string, string>::const_iterator prebuffer_it = line.parameters.find("force_prebuffer");
+ if (prebuffer_it == line.parameters.end()) {
+ stream.prebuffering_bytes = 0;
+ } else {
+ stream.prebuffering_bytes = atoi(prebuffer_it->second.c_str());
+ }
+
// Parse encoding.
map<string, string>::const_iterator encoding_parm_it = line.parameters.find("encoding");
if (encoding_parm_it == line.parameters.end() ||
udpstream.pacing_rate = atoi(pacing_rate_it->second.c_str()) * 1024 / 8;
}
+ // Parse the TTL. The same value is used for unicast and multicast.
+ map<string, string>::const_iterator ttl_it = line.parameters.find("ttl");
+ if (ttl_it == line.parameters.end()) {
+ udpstream.ttl = -1;
+ } else {
+ udpstream.ttl = atoi(ttl_it->second.c_str());
+ }
+
+ // Parse the multicast interface index.
+ map<string, string>::const_iterator multicast_iface_it = line.parameters.find("multicast_output_interface");
+ if (multicast_iface_it == line.parameters.end()) {
+ udpstream.multicast_iface_index = -1;
+ } else {
+ udpstream.multicast_iface_index = if_nametoindex(multicast_iface_it->second.c_str());
+ if (udpstream.multicast_iface_index == 0) {
+ log(ERROR, "Interface '%s' does not exist", multicast_iface_it->second.c_str());
+ return false;
+ }
+ }
+
config->udpstreams.push_back(udpstream);
return true;
}