This commit is contained in:
EntireTwix 2021-06-06 17:31:14 -07:00
commit 037bb2ea4d
3 changed files with 15 additions and 26 deletions

View file

@ -7,31 +7,23 @@
struct Log
{
std::vector<Transaction> data;
void AddTrans(Transaction &&v)
void AddTrans(Transaction &&t)
{
if (data.capacity() == data.size() && data.size() < max_log_size) //if memory reserved is full and max isnt reached
if (data.size() == max_log_size) // If we hit the max size
{
if (data.size() + pre_log_size > max_log_size) //if prefetched memory is larger then max
for (uint32_t i = 1; i < data.size(); i++) // Make room at the back
{
data.reserve(max_log_size); //just allocate max
}
else
{
data.reserve(data.size() + pre_log_size); //prefetching memory
std::cout << i << '\n';
data[i - 1] = std::move(data[i]); // Shifts everything left
}
data[data.size() - 1] = std::move(t); // Place new in opened spot
return;
}
if (data.size() == max_log_size)
else if (data.size() == data.capacity()) // If we haven't hit the max but hit capacity
{
for (size_t i = 0; i < data.size() - 1; ++i)
{
data[i] = std::move(data[i + 1]);
}
data[data.size() - 1] = std::move(v);
}
else
{
data.push_back(std::move(v));
data.reserve(data.capacity() + pre_log_size); // Reserve more memory
}
data.push_back(std::move(t)); // In either case we have space under max length, move to new spot
}
Json::Value Serialize() const
{

View file

@ -36,17 +36,14 @@ struct User
{
if (log_j.size())
{
unsigned size = ((log_j.size() / pre_log_size) + 1) * pre_log_size; // Ensures that we have a log size aligned on a multiple of `pre_log_size`
log.data.reserve(size); // Ensures that the log size is under `max_log_size`
size = std::min(log_j.size(), max_log_size);
log.data.resize(size);
for (uint32_t i = 0; i < size; ++i)
log.data.reserve(std::min(pre_log_size * ((log_j.size() / pre_log_size) + 1), max_log_size));
for (uint32_t i = (log_j.size() - max_log_size) * (log_j.size() > max_log_size); i < log_j.size(); i++)
{
log.data[i] = std::move(Transaction(
log.data.push_back(std::move(Transaction(
log_j[i]["from"].asCString(),
log_j[i]["to"].asCString(),
log_j[i]["amount"].asUInt(),
log_j[i]["time"].asUInt64()));
log_j[i]["time"].asUInt64())));
}
}
}

View file

@ -23,7 +23,7 @@ void SaveSig(int s)
int main(int argc, char **argv)
{
static_assert(pre_log_size <= max_log_size, "`max_log_size` must be larger than `pre_log_size`.");
if constexpr (max_log_size)
if constexpr (max_log_size && pre_log_size)
{
if (max_log_size % pre_log_size)
{