From 5d6ad60d3bfefe42e102b52fecebd9c2fb873350 Mon Sep 17 00:00:00 2001 From: tastytea Date: Mon, 6 Jan 2020 09:43:08 +0100 Subject: [PATCH] Add simple example. --- examples/example01_instance_info.cpp | 83 ++++++++++++++++++++++++++++ 1 file changed, 83 insertions(+) create mode 100644 examples/example01_instance_info.cpp diff --git a/examples/example01_instance_info.cpp b/examples/example01_instance_info.cpp new file mode 100644 index 0000000..6d371f3 --- /dev/null +++ b/examples/example01_instance_info.cpp @@ -0,0 +1,83 @@ +/* This file is part of mastodonpp. + * Copyright © 2020 tastytea + * + * Permission to use, copy, modify, and/or distribute this software for any + * purpose with or without fee is hereby granted. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY + * SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION + * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN + * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + */ + +// Print information about an instance (/api/v1/instance). + +#include + +#include +#include +#include +#include + +namespace masto = mastodonpp; +using std::cout; +using std::cerr; +using std::endl; +using std::to_string; +using std::string_view; +using std::vector; + +int main(int argc, char *argv[]) +{ + const vector args(argv, argv + argc); + if (args.size() <= 1) + { + cerr << "Usage: " << args[0] << " \n"; + return 1; + } + + try + { + // Initialize an Instance. + masto::Instance instance{args[1], {}}; + + // Get maximum allowed characters per post. + const auto max_chars{instance.get_max_chars()}; + cout << "Maximum characters per post: " << max_chars << "\n\n"; + + // Initialize a Connection. + masto::Connection connection{instance}; + + // Get information about the instance. + masto::answer_type answer{connection.get(masto::API::v1::instance)}; + if (answer) + { + cout << answer << endl; + } + else + { + if (answer.curl_error_code == 0) + { + // If it is no libcurl error, it must be an HTTP error. + cerr << "HTTP status: " << answer.http_status << endl; + } + else + { + // Network errors like “Couldn't resolve host.”. + cerr << "libcurl error " << to_string(answer.curl_error_code) + << ": " << answer.error_message << endl; + } + } + } + catch (const masto::CURLException &e) + { + // Only libcurl errors that are not network errors will be thrown. + // There went probably something wrong with the initialization. + cerr << e.what() << endl; + } + + return 0; +}