mirror of
https://github.com/XRPLF/rippled.git
synced 2026-04-29 15:37:57 +00:00
Rearrange sources (#4997)
This commit is contained in:
committed by
John Freeman
parent
2e902dee53
commit
e416ee72ca
193
src/libxrpl/protocol/STArray.cpp
Normal file
193
src/libxrpl/protocol/STArray.cpp
Normal file
@@ -0,0 +1,193 @@
|
||||
//------------------------------------------------------------------------------
|
||||
/*
|
||||
This file is part of rippled: https://github.com/ripple/rippled
|
||||
Copyright (c) 2012, 2013 Ripple Labs Inc.
|
||||
|
||||
Permission to use, copy, modify, and/or distribute this software for any
|
||||
purpose with or without fee is hereby granted, provided that the above
|
||||
copyright notice and this permission notice appear in all copies.
|
||||
|
||||
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.
|
||||
*/
|
||||
//==============================================================================
|
||||
|
||||
#include <ripple/basics/Log.h>
|
||||
#include <ripple/basics/contract.h>
|
||||
#include <ripple/protocol/STArray.h>
|
||||
#include <ripple/protocol/STBase.h>
|
||||
|
||||
namespace ripple {
|
||||
|
||||
STArray::STArray(STArray&& other)
|
||||
: STBase(other.getFName()), v_(std::move(other.v_))
|
||||
{
|
||||
}
|
||||
|
||||
STArray&
|
||||
STArray::operator=(STArray&& other)
|
||||
{
|
||||
setFName(other.getFName());
|
||||
v_ = std::move(other.v_);
|
||||
return *this;
|
||||
}
|
||||
|
||||
STArray::STArray(int n)
|
||||
{
|
||||
v_.reserve(n);
|
||||
}
|
||||
|
||||
STArray::STArray(SField const& f) : STBase(f)
|
||||
{
|
||||
}
|
||||
|
||||
STArray::STArray(SField const& f, std::size_t n) : STBase(f)
|
||||
{
|
||||
v_.reserve(n);
|
||||
}
|
||||
|
||||
STArray::STArray(SerialIter& sit, SField const& f, int depth) : STBase(f)
|
||||
{
|
||||
while (!sit.empty())
|
||||
{
|
||||
int type, field;
|
||||
sit.getFieldID(type, field);
|
||||
|
||||
if ((type == STI_ARRAY) && (field == 1))
|
||||
break;
|
||||
|
||||
if ((type == STI_OBJECT) && (field == 1))
|
||||
{
|
||||
JLOG(debugLog().error())
|
||||
<< "Encountered array with end of object marker";
|
||||
Throw<std::runtime_error>("Illegal terminator in array");
|
||||
}
|
||||
|
||||
auto const& fn = SField::getField(type, field);
|
||||
|
||||
if (fn.isInvalid())
|
||||
{
|
||||
JLOG(debugLog().error())
|
||||
<< "Unknown field: " << type << "/" << field;
|
||||
Throw<std::runtime_error>("Unknown field");
|
||||
}
|
||||
|
||||
if (fn.fieldType != STI_OBJECT)
|
||||
{
|
||||
JLOG(debugLog().error()) << "Array contains non-object";
|
||||
Throw<std::runtime_error>("Non-object in array");
|
||||
}
|
||||
|
||||
v_.emplace_back(sit, fn, depth + 1);
|
||||
|
||||
v_.back().applyTemplateFromSField(fn); // May throw
|
||||
}
|
||||
}
|
||||
|
||||
STBase*
|
||||
STArray::copy(std::size_t n, void* buf) const
|
||||
{
|
||||
return emplace(n, buf, *this);
|
||||
}
|
||||
|
||||
STBase*
|
||||
STArray::move(std::size_t n, void* buf)
|
||||
{
|
||||
return emplace(n, buf, std::move(*this));
|
||||
}
|
||||
|
||||
std::string
|
||||
STArray::getFullText() const
|
||||
{
|
||||
std::string r = "[";
|
||||
|
||||
bool first = true;
|
||||
for (auto const& obj : v_)
|
||||
{
|
||||
if (!first)
|
||||
r += ",";
|
||||
|
||||
r += obj.getFullText();
|
||||
first = false;
|
||||
}
|
||||
|
||||
r += "]";
|
||||
return r;
|
||||
}
|
||||
|
||||
std::string
|
||||
STArray::getText() const
|
||||
{
|
||||
std::string r = "[";
|
||||
|
||||
bool first = true;
|
||||
for (STObject const& o : v_)
|
||||
{
|
||||
if (!first)
|
||||
r += ",";
|
||||
|
||||
r += o.getText();
|
||||
first = false;
|
||||
}
|
||||
|
||||
r += "]";
|
||||
return r;
|
||||
}
|
||||
|
||||
Json::Value
|
||||
STArray::getJson(JsonOptions p) const
|
||||
{
|
||||
Json::Value v = Json::arrayValue;
|
||||
for (auto const& object : v_)
|
||||
{
|
||||
if (object.getSType() != STI_NOTPRESENT)
|
||||
{
|
||||
Json::Value& inner = v.append(Json::objectValue);
|
||||
inner[object.getFName().getJsonName()] = object.getJson(p);
|
||||
}
|
||||
}
|
||||
return v;
|
||||
}
|
||||
|
||||
void
|
||||
STArray::add(Serializer& s) const
|
||||
{
|
||||
for (STObject const& object : v_)
|
||||
{
|
||||
object.addFieldID(s);
|
||||
object.add(s);
|
||||
s.addFieldID(STI_OBJECT, 1);
|
||||
}
|
||||
}
|
||||
|
||||
SerializedTypeID
|
||||
STArray::getSType() const
|
||||
{
|
||||
return STI_ARRAY;
|
||||
}
|
||||
|
||||
bool
|
||||
STArray::isEquivalent(const STBase& t) const
|
||||
{
|
||||
auto v = dynamic_cast<const STArray*>(&t);
|
||||
return v != nullptr && v_ == v->v_;
|
||||
}
|
||||
|
||||
bool
|
||||
STArray::isDefault() const
|
||||
{
|
||||
return v_.empty();
|
||||
}
|
||||
|
||||
void
|
||||
STArray::sort(bool (*compare)(const STObject&, const STObject&))
|
||||
{
|
||||
std::sort(v_.begin(), v_.end(), compare);
|
||||
}
|
||||
|
||||
} // namespace ripple
|
||||
Reference in New Issue
Block a user