mirror of
https://github.com/Expand-sys/CCash
synced 2025-12-16 00:02:14 +11:00
🐎⚡🔥 removed jsoncpp from GetLogs() solution
This commit is contained in:
parent
36e2f6301f
commit
8063a344aa
2 changed files with 21 additions and 17 deletions
|
|
@ -5,6 +5,9 @@
|
|||
#include "ccash_config.hpp"
|
||||
#include "change_flag.h"
|
||||
#include "transaction.h"
|
||||
#include "simdjson.h"
|
||||
|
||||
using namespace simdjson;
|
||||
|
||||
struct Log
|
||||
{
|
||||
|
|
|
|||
35
src/log.cpp
35
src/log.cpp
|
|
@ -24,25 +24,26 @@ const std::string &Log::GetLogs() noexcept
|
|||
if (log_flag.GetChangeState()) //if there are changes
|
||||
{
|
||||
//re-generate snapshot
|
||||
Json::Value res;
|
||||
#if MAX_LOG_SIZE == 1
|
||||
res[0]["to"] = data.to;
|
||||
res[0]["from"] = data.from;
|
||||
#ifdef _USE_32BIT_TIME_T
|
||||
res[0]["time"] = (Json::UInt)data.time;
|
||||
#else
|
||||
res[0]["time"] = (Json::UInt64)data.time;
|
||||
#endif
|
||||
#else
|
||||
for (uint32_t i = data.size(); i > 0; --i)
|
||||
//({\"amount\":1,\"from\":\"\",\"time\":1625943626,\"to\":\"\"}, + (2*max_name_size)+10+10) * # of logs) + 1
|
||||
size_t predicted_size = ((58 + (2 * max_name_size)) * data.size()) + 1;
|
||||
if (log_snapshot.capacity() < predicted_size)
|
||||
{
|
||||
res[i - 1]["to"] = data[data.size() - i].to;
|
||||
res[i - 1]["from"] = data[data.size() - i].from;
|
||||
res[i - 1]["amount"] = (Json::UInt)data[data.size() - i].amount;
|
||||
res[i - 1]["time"] = (Json::Int64)data[data.size() - i].time;
|
||||
log_snapshot.reserve(predicted_size);
|
||||
}
|
||||
#endif
|
||||
log_snapshot = res.toStyledString();
|
||||
log_snapshot = '[';
|
||||
for (size_t i = 0; i < data.size(); ++i)
|
||||
{
|
||||
log_snapshot += "{\"to\":\"";
|
||||
log_snapshot += data[i].to;
|
||||
log_snapshot += "\",\"from\":\"";
|
||||
log_snapshot += data[i].from;
|
||||
log_snapshot += "\",\"amount\":";
|
||||
log_snapshot += std::to_string(data[i].amount);
|
||||
log_snapshot += ",\"time\":";
|
||||
log_snapshot += std::to_string(data[i].time);
|
||||
log_snapshot += "},";
|
||||
}
|
||||
log_snapshot[log_snapshot.size() - 1] = ']';
|
||||
log_flag.SetChangesOff();
|
||||
}
|
||||
return log_snapshot;
|
||||
|
|
|
|||
Loading…
Reference in a new issue