From 83c048d1295b9df59d90a7513953c99a267eb1f5 Mon Sep 17 00:00:00 2001 From: Joel Grunbaum <joel.grunbaum@imc.com> Date: Tue, 11 Jan 2022 07:26:39 +0000 Subject: [PATCH] CYA Cmake, compiling on remote box --- click.cpp | 175 ++++++++++++++++++++++++++++++++++++++++----------------- 1 files changed, 122 insertions(+), 53 deletions(-) diff --git a/click.cpp b/click.cpp index 4b43885..749d649 100644 --- a/click.cpp +++ b/click.cpp @@ -7,71 +7,140 @@ #include <iostream> #include <unordered_map> -enum clickType { Buy, Sell, Flash }; +enum clickType { Buy, Sell, Flash, Delete }; static std::unordered_map<std::string, clickType> mapClick; void initialise() { - mapClick = {{"BUY", Buy}, {"SELL", Sell}, {"FLASH", Flash}, - {"b", Buy}, {"s", Sell}, {"f", Flash}, - {"B", Buy}, {"S", Sell}, {"F", Flash}}; + mapClick = {{"BUY", Buy}, {"SELL", Sell}, {"FLASH", Flash}, + {"b", Buy}, {"s", Sell}, {"f", Flash}, + {"B", Buy}, {"S", Sell}, {"F", Flash}, + {"DELETE", Delete}, {"D", Delete}, {"d", Delete}}; } void usage() { - std::cout << "DESCRIPTION" << std::endl - << "Click trader using same algs" << std::endl - << std::endl - << "USAGE" << std::endl - << "\t-a product" << std::endl - << "\t-t click type (buy, sell, flash)" << std::endl - << "\t-p price" << std::endl - << "\t-v volume" << std::endl - << "\t-i id" << std::endl - << "Always need product, need side, price and volume for " - "adding/flash, need id for deleting" - << std::endl; + std::cout << "DESCRIPTION" << std::endl + << "Click trader using same algs" << std::endl + << std::endl + << "USAGE" << std::endl + << "\t-a product" << std::endl + << "\t-t click type (buy, sell, flash, delete)" << std::endl + << "\t-p price" << std::endl + << "\t-v volume" << std::endl + << "\t-i id" << std::endl + << "Always need product, need side, price and volume for " + "adding/flash, need id for deleting" + << std::endl; +} + +void buy(std::string& product, double price, uint64_t volume) +{ + json::AddMessage a(json::ADD, product, price, book::Buy, volume); + json::AddedMessage* b = static_cast<json::AddedMessage*>(protocol::addOrder(a)); + std::cout << b->as_string() << std::endl; +} + +void sell(std::string& product, double price, uint64_t volume) +{ + json::AddMessage a(json::ADD, product, price, book::Sell, volume); + json::AddedMessage* b = static_cast<json::AddedMessage*>(protocol::addOrder(a)); + std::cout << b->as_string() << std::endl; + delete b; +} + +void flash(std::string& product, double price, uint64_t volume, book::OrderSideEnum side) +{ + json::AddMessage a(json::ADD, product, price, side, volume); + json::Message* b = static_cast<json::Message*>(protocol::addOrder(a)); + if (b->type == json::ERROR) { + std::cout << static_cast<json::ErrorMessage*>(b)->as_string() << std::endl; + return; + } + json::DeleteMessage c(json::DELETE, product, static_cast<json::AddedMessage*>(b)->id); + json::Message* d = protocol::deleteOrder(c); + std::cout << static_cast<json::AddedMessage*>(b)->as_string() << std::endl; + if (d->type == json::DELETED) { + std::cout << static_cast<json::DeletedMessage*>(d)->as_string() + << std::endl; + } else { + std::cout << static_cast<json::RejectMessage*>(d)->as_string() + << std::endl; + } + delete b; + delete d; +} + +void deleteOrder(std::string& product, std::string& id) +{ + json::DeleteMessage a(json::DELETE, product, id); + json::Message* b = protocol::deleteOrder(a); + if (b->type == json::DELETED) { + std::cout << static_cast<json::DeletedMessage*>(b)->as_string() + << std::endl; + } else if (b->type == json::REJECT) { + std::cout << static_cast<json::RejectMessage*>(b)->as_string() + << std::endl; + } else { + std::cout << static_cast<json::ErrorMessage*>(b)->as_string() << std::endl; + } } int main(int argc, char** argv) { - int c; - int index; - std::string product, id; - double price; - clickType click; - uint64_t volume; - initialise(); - if (argc == 1) { - usage(), exit(0); - } - while ((c = getopt(argc, argv, "a::t::p::v::i::")) != -1) { - switch (c) { - case 'a': - product = std::string(optarg); - break; - case 's': - click = mapClick[optarg]; - break; - case 'p': - price = std::stod(optarg); - break; - case 'v': - volume = std::stoll(optarg); - break; - case 'i': - id = std::string(optarg); - break; - case '?': - default: - usage(); - exit(0); + int c; + std::string product, id; + double price; + clickType click, side; + uint64_t volume; + initialise(); + if (argc == 1) { + usage(), exit(0); } - } - switch (click) { - case Buy: - case Sell: - case Flash:; - } + while ((c = getopt(argc, argv, "a::t::s::p::v::i::")) != -1) { + switch (c) { + case 'a': + product = std::string(optarg); + break; + case 't': + click = mapClick[optarg]; + break; + case 's': + side = mapClick[optarg]; + break; + case 'p': + price = std::stod(optarg); + break; + case 'v': + volume = std::stoll(optarg); + break; + case 'i': + id = std::string(optarg); + break; + case '?': + std::cout << "*1" << std::endl; + default: + std::cout << "*2 " << (char) c << std::endl; + usage(); + exit(0); + } + } + switch (click) { + case Buy: + buy(product, price, volume); + break; + case Sell: + sell(product, price, volume); + break; + case Flash: + if (side == clickType::Buy) + flash(product, price, volume, book::Buy); + else + flash(product, price, volume, book::Sell); + break; + case Delete: + deleteOrder(product, id); + break; + } } -- Gitblit v1.9.3