/* * runMerger.cxx * * Created on: Dec 6, 2012 * Author: dklein */ #include "StandaloneMerger.h" #include #include #include "Logger.h" #include #include using namespace Highway; int main(int argc, char** argv) { pid_t pid = getpid(); std::stringstream logmsg; logmsg << "PID: " << pid; Logger::GetInstance()->Log(Logger::INFO, logmsg.str()); int i = 1; StandaloneMerger* merger = new StandaloneMerger(); merger->SetProperty(StandaloneMerger::Id, argv[i]); ++i; int numIoThreads; std::stringstream(argv[i]) >> numIoThreads; merger->SetProperty(StandaloneMerger::NumIoThreads, numIoThreads); ++i; int connectSocketType = ZMQ_SUB; if (strcmp(argv[i], "pull") == 0) { connectSocketType = ZMQ_PULL; } merger->SetProperty(StandaloneMerger::ConnectSocketType, connectSocketType, 0); ++i; int connectRcvBufferSize; std::stringstream(argv[i]) >> connectRcvBufferSize; merger->SetProperty(StandaloneMerger::ConnectRcvBufferSize, connectRcvBufferSize, 0); ++i; merger->SetProperty(StandaloneMerger::ConnectAddress, argv[i], 0); ++i; connectSocketType = ZMQ_SUB; if (strcmp(argv[i], "pull") == 0) { connectSocketType = ZMQ_PULL; } merger->SetProperty(StandaloneMerger::ConnectSocketType, connectSocketType, 1); ++i; std::stringstream(argv[i]) >> connectRcvBufferSize; merger->SetProperty(StandaloneMerger::ConnectRcvBufferSize, connectRcvBufferSize, 1); ++i; merger->SetProperty(StandaloneMerger::ConnectAddress, argv[i], 1); ++i; int bindSocketType = ZMQ_PUB; if (strcmp(argv[i], "push") == 0) { bindSocketType = ZMQ_PUSH; } merger->SetProperty(StandaloneMerger::BindSocketType, bindSocketType, 0); ++i; int bindSndBufferSize; std::stringstream(argv[i]) >> bindSndBufferSize; merger->SetProperty(StandaloneMerger::BindSndBufferSize, bindSndBufferSize, 0); ++i; merger->SetProperty(StandaloneMerger::BindAddress, argv[i], 0); ++i; merger->Init(); merger->Bind(); merger->Connect(); merger->Run(); exit(0); }