#include #include #include #include "histogram.h" #include "text.h" #include "svg.h" #include #include #include using namespace std; struct Input { vector numbers; size_t bin_count{}; }; Input input_data(istream& in, bool promt) { size_t number_count; if (promt) { cerr << "Enter number count: "; } in >> number_count; Input ik; ik.numbers.resize(number_count); for (size_t i = 0; i < number_count; i++) { in >> ik.numbers[i]; } if (promt) { cerr << "Enter bin count: "; } in>> ik.bin_count; return ik; } size_t write_data(void* items, size_t item_size, size_t item_count, void* ctx) { size_t data_size = item_size * item_count; stringstream* buffer = reinterpret_cast(ctx); buffer->write(reinterpret_cast(items), data_size); return data_size; } Input download(const string& address) { stringstream buffer; CURL *curl = curl_easy_init(); if(curl) { CURLcode res; double file_size; curl_easy_setopt(curl, CURLOPT_URL, address.c_str()); curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, write_data); curl_easy_setopt(curl, CURLOPT_WRITEDATA, &buffer); res = curl_easy_perform(curl); if (res != CURLE_OK) { fprintf(stderr, "curl_easy_perform() failed: %s\n",curl_easy_strerror(res)); exit(1); } else { res = curl_easy_getinfo(curl, CURLINFO_CONTENT_LENGTH_DOWNLOAD, &file_size); cerr<<"File size: "< 1) { input = download(argv[1]); } else { input = input_data(cin, true); } const auto bins = make_histogram(input.numbers, input.bin_count); show_histogram_svg(bins); }