code: конечный вариант

main
SneguraDS 11 месяцев назад
Родитель 3becba6c29
Сommit 464ddc310f

@ -1,3 +1,5 @@
#include <sstream>
#include <string>
#include <curl/curl.h> #include <curl/curl.h>
#include <iostream> #include <iostream>
#include <vector> #include <vector>
@ -5,70 +7,105 @@
#include "text.h" #include "text.h"
#include "svg.h" #include "svg.h"
using namespace std; using namespace std;
struct Input { struct Input
{
vector<double> numbers; vector<double> numbers;
size_t bin_count{}; size_t bin_count{};
size_t number_count{}; size_t number_count{};
size_t max_count{}; size_t max_count{};
}; };
Input Input
input_data(istream& cin, bool prompt) { input_data(istream& cin, bool prompt)
if (prompt==true){ {
Input in; if (prompt==true)
cerr << "Enter number count: "; {
cin >> in.number_count; Input in;
vector<double> numbers(in.number_count); cerr << "Enter number count: ";
in.numbers.resize(in.number_count); cin >> in.number_count;
for (size_t i = 0; i < in.number_count; i++) { vector<double> numbers(in.number_count);
cin >> in.numbers[i]; in.numbers.resize(in.number_count);
} for (size_t i = 0; i < in.number_count; i++)
size_t bin_count; {
cerr << "Enter bin count: "; cin >> in.numbers[i];
cin >> in.bin_count; }
size_t bin_count;
cerr << "Enter bin count: ";
cin >> in.bin_count;
size_t max_count; size_t max_count;
in.max_count = 0; in.max_count = 0;
return in; return in;
} }
if (prompt==false){ if (prompt==false)
Input in; {
cin >> in.number_count; Input in;
vector<double> numbers(in.number_count); cin >> in.number_count;
in.numbers.resize(in.number_count); vector<double> numbers(in.number_count);
for (size_t i = 0; i < in.number_count; i++) { in.numbers.resize(in.number_count);
cin >> in.numbers[i]; for (size_t i = 0; i < in.number_count; i++)
} {
size_t bin_count; cin >> in.numbers[i];
cin >> in.bin_count; }
size_t bin_count;
cin >> in.bin_count;
size_t max_count; size_t max_count;
in.max_count = 0; in.max_count = 0;
return in; return in;
} }
} }
int main(int argc, char* argv[]) 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<stringstream*>(ctx);
buffer->write(reinterpret_cast<const char*>(items), data_size);
return data_size;
}
Input
download(const string& address)
{ {
stringstream buffer;
if (argc>1){ CURL* curl = curl_easy_init();
CURL* curl = curl_easy_init(); if(curl)
if(curl) { {
CURLcode res; CURLcode res;
const char* res2; const char* res2;
curl_easy_setopt(curl, CURLOPT_URL, argv[1]); double connect;
res = curl_easy_perform(curl); curl_easy_setopt(curl, CURLOPT_URL, address.c_str());
if (res!=0){ curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, write_data);
res2=curl_easy_strerror(res); curl_easy_setopt(curl, CURLOPT_WRITEDATA, &buffer);
cout<<res2<<endl; res = curl_easy_perform(curl);
exit(1); if (res!=0)
} {
curl_easy_cleanup(curl); res2=curl_easy_strerror(res);
cout<<res2<<endl;
exit(1);
} }
return 0;
if(CURLE_OK == res) {
res = curl_easy_getinfo(curl, CURLINFO_CONNECT_TIME, &connect);
if(CURLE_OK == res) {
cerr<<("Time: %.1f", connect)<<endl;
}
}
curl_easy_cleanup(curl);
} }
curl_global_init(CURL_GLOBAL_ALL);
return input_data(buffer, false);
}
int main(int argc, char* argv[])
{
Input in;
if (argc > 1)
{
in = download(argv[1]);
}
else
{
in = input_data(cin, true);
}
curl_global_init(CURL_GLOBAL_ALL);
auto in = input_data(cin, true);
auto bins = make_histogram(in.numbers, in.bin_count, in.number_count, in.max_count); auto bins = make_histogram(in.numbers, in.bin_count, in.number_count, in.max_count);
show_histogram_svg(bins, in.max_count, in.bin_count); show_histogram_svg(bins, in.max_count, in.bin_count);
return 0; return 0;

Загрузка…
Отмена
Сохранить