summaryrefslogtreecommitdiffstats
path: root/src/instance.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/instance.cpp')
-rw-r--r--src/instance.cpp26
1 files changed, 15 insertions, 11 deletions
diff --git a/src/instance.cpp b/src/instance.cpp
index fc56aa8..5d585d9 100644
--- a/src/instance.cpp
+++ b/src/instance.cpp
@@ -23,6 +23,7 @@
namespace mastodonpp
{
+using std::stoull;
using std::move;
Instance::Instance(string hostname, string access_token)
@@ -38,19 +39,22 @@ Instance::Instance(string hostname, string access_token)
if (answer)
{
debuglog << "Querying instance for max_toot_chars…\n";
- auto &body{answer.body};
- size_t pos_start{body.find("max_toot_chars")};
- if (pos_start == string::npos)
+ _max_chars = [&answer]
{
- debuglog << "max_toot_chars not found.";
- return;
- }
- pos_start = body.find(':', pos_start) + 1;
- const size_t pos_end{body.find(',', pos_start)};
+ auto &body{answer.body};
+ size_t pos_start{body.find("max_toot_chars")};
+ if (pos_start == string::npos)
+ {
+ debuglog << "max_toot_chars not found.\n";
+ return static_cast<uint64_t>(500);
+ }
+ pos_start = body.find(':', pos_start) + 1;
+ const size_t pos_end{body.find(',', pos_start)};
- const auto max_toot_chars{body.substr(pos_start,
- pos_end - pos_start)};
- _max_chars = std::stoull(max_toot_chars);
+ const auto max_toot_chars{body.substr(pos_start,
+ pos_end - pos_start)};
+ return static_cast<uint64_t>(stoull(max_toot_chars));
+ }();
debuglog << "Set _max_chars to: " << _max_chars << '\n';
}
}