// Extremely rudimentary URL parsing.
bool parse_url(const string &url, string *protocol, string *user, string *host, string *port, string *path)
{
+ // pipe:foo (or pipe:"foo").
+ if (url.find("pipe:") == 0) {
+ *protocol = "pipe";
+ *path = string(url.begin() + 5, url.end());
+ return true;
+ }
+
size_t split = url.find("://");
if (split == string::npos) {
return false;
if (split == rest.size()) {
// http://foo
split_user_host(rest, user, host);
- fprintf(stderr, "ooo user='%s' host='%s'\n", user->c_str(), host->c_str());
*port = *protocol;
*path = "/";
return true;
return true;
}
-Input *create_input(const std::string &url)
+Input *create_input(const string &url, Input::Encoding encoding)
{
string protocol, user, host, port, path;
if (!parse_url(url, &protocol, &user, &host, &port, &path)) {
- return NULL;
+ return nullptr;
}
- if (protocol == "http") {
- return new HTTPInput(url);
+ if (protocol == "http" || protocol == "pipe") {
+ return new HTTPInput(url, encoding);
}
if (protocol == "udp") {
+ assert(encoding == Input::INPUT_ENCODING_RAW);
return new UDPInput(url);
}
- return NULL;
+ return nullptr;
}
Input *create_input(const InputProto &serialized)
{
string protocol, user, host, port, path;
if (!parse_url(serialized.url(), &protocol, &user, &host, &port, &path)) {
- return NULL;
+ return nullptr;
}
- if (protocol == "http") {
+ if (protocol == "http" || protocol == "pipe") {
return new HTTPInput(serialized);
}
if (protocol == "udp") {
return new UDPInput(serialized);
}
- return NULL;
+ return nullptr;
}
Input::~Input() {}