diff options
author | Thiago Macieira <thiago.macieira@intel.com> | 2018-05-19 14:58:43 -0700 |
---|---|---|
committer | Thiago Macieira <thiago.macieira@intel.com> | 2018-07-04 03:04:21 +0000 |
commit | 2bb44414ff456873c885391e4a03afb67e7306da (patch) | |
tree | 9d6f7d1b2912cd494073c10e23fd61543535a022 /src/corelib/serialization/qcborvalue.cpp | |
parent | fcb0f68e77bb69544f0ae310baffd3ceff8a9e5d (diff) |
QCborArray & Map: implement efficient take() / extract()
Questions:
1) should QCborMap::extract return value_type (a pair) instead of just
the value?
2) should the both return the iterator to the next element too, like
erase()?
Change-Id: I052407b777ec43f78378fffd15302a9c14468db3
Reviewed-by: Edward Welbourne <edward.welbourne@qt.io>
Reviewed-by: Thiago Macieira <thiago.macieira@intel.com>
Diffstat (limited to 'src/corelib/serialization/qcborvalue.cpp')
-rw-r--r-- | src/corelib/serialization/qcborvalue.cpp | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/src/corelib/serialization/qcborvalue.cpp b/src/corelib/serialization/qcborvalue.cpp index db5dc938df..d4b7764b49 100644 --- a/src/corelib/serialization/qcborvalue.cpp +++ b/src/corelib/serialization/qcborvalue.cpp @@ -1101,6 +1101,29 @@ Q_NEVER_INLINE void QCborContainerPrivate::appendAsciiString(const QString &s) qt_to_latin1_unchecked(l, uc, len); } +QCborValue QCborContainerPrivate::extractAt_complex(Element e) +{ + // create a new container for the returned value, containing the byte data + // from this element, if it's worth it + Q_ASSERT(e.flags & Element::HasByteData); + auto b = byteData(e); + auto container = new QCborContainerPrivate; + + if (b->len + qsizetype(sizeof(*b)) < data.size() / 4) { + // make a shallow copy of the byte data + container->appendByteData(b->byte(), b->len, e.type, e.flags); + usedData -= b->len + qsizetype(sizeof(*b)); + compact(elements.size()); + } else { + // just share with the original byte data + container->data = data; + container->elements.reserve(1); + container->elements.append(e); + } + + return makeValue(e.type, 0, container); +} + QT_WARNING_DISABLE_MSVC(4146) // unary minus operator applied to unsigned type, result still unsigned static int compareContainer(const QCborContainerPrivate *c1, const QCborContainerPrivate *c2); static int compareElementNoData(const Element &e1, const Element &e2) |