diff --git a/lab01.cbp b/lab01.cbp
index 247aa25..a6864f6 100644
--- a/lab01.cbp
+++ b/lab01.cbp
@@ -31,9 +31,27 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/main.cpp b/main.cpp
index e48cec4..7e9e957 100644
--- a/main.cpp
+++ b/main.cpp
@@ -3,6 +3,9 @@
#include "histogram.h"
#include "text.h"
#include "svg.h"
+#include
+#include
+#include
using namespace std;
@@ -13,28 +16,81 @@ struct Input
};
Input
-input_data()
+input_data(istream& in, bool prompt)
{
- Input in;
+ Input cin;
+ string numbCntPrmt, numbsPrmt, binCntPrmt;
+ if (prompt == true) {
+ numbCntPrmt = "Enter number count: ";
+ numbsPrmt = "Enter numbers: ";
+ binCntPrmt = "Enter bin count: ";
+ }
size_t number_count;
- cin >> number_count;
- in.numbers.resize(number_count);
+ cerr << numbCntPrmt;
+ in >> number_count;
+ cin.numbers.resize(number_count);
vector numbers(number_count);
+ cerr << numbsPrmt;
for (size_t i = 0; i < number_count; i++)
{
- cin >> in.numbers[i];
+ in >> cin.numbers[i];
}
- cin >> in.bin_count;
- return in;
+ cerr << binCntPrmt;
+ in >> cin.bin_count;
+ return cin;
+}
+
+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;
+ 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) {
+ curl_off_t ul;
+ res = curl_easy_getinfo(curl, CURLINFO_SIZE_DOWNLOAD_T, &ul);
+ if(!res) {
+ cerr<<"Uploaded bytes" << ul << endl;
+ }
+ }
+
+ if (res != 0){
+ cerr << curl_easy_strerror(res);
+ exit(1);
+ }
+ curl_easy_cleanup(curl);
+ }
+ return input_data(buffer, false);
}
-int main()
+int main(int argc, char* argv[])
{
- size_t max_count;
- auto in = input_data();
- auto bins = make_histogram(in.numbers, in.bin_count);
+ CURL* curl = curl_easy_init();
+ Input input;
+ if (argc > 1) {
+ input = download(argv[1]);
+ } else {
+
+ input = input_data(cin, true);
+ }
+
+ auto bins = make_histogram(input.numbers, input.bin_count);
show_histogram_svg(bins);
}
diff --git a/svg.cpp b/svg.cpp
index 1036f55..e8c71ce 100644
--- a/svg.cpp
+++ b/svg.cpp
@@ -2,7 +2,7 @@
#include
using namespace std;
-svg_begin(double width, double height) {
+void svg_begin(double width, double height) {
cout << "\n";
cout << "