mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Cleanup of vector_ref.h
This commit is contained in:
parent
6475bd9a72
commit
6951a371ec
@ -23,6 +23,8 @@ public:
|
|||||||
using value_type = _T;
|
using value_type = _T;
|
||||||
using element_type = _T;
|
using element_type = _T;
|
||||||
using mutable_value_type = typename std::conditional<std::is_const<_T>::value, typename std::remove_const<_T>::type, _T>::type;
|
using mutable_value_type = typename std::conditional<std::is_const<_T>::value, typename std::remove_const<_T>::type, _T>::type;
|
||||||
|
using string_type = typename std::conditional<std::is_const<_T>::value, std::string const, std::string>::type;
|
||||||
|
using vector_type = typename std::conditional<std::is_const<_T>::value, std::vector<typename std::remove_const<_T>::type> const, std::vector<_T>>::type;
|
||||||
|
|
||||||
static_assert(std::is_pod<value_type>::value, "vector_ref can only be used with PODs due to its low-level treatment of data.");
|
static_assert(std::is_pod<value_type>::value, "vector_ref can only be used with PODs due to its low-level treatment of data.");
|
||||||
|
|
||||||
@ -30,18 +32,13 @@ public:
|
|||||||
/// Creates a new vector_ref to point to @a _count elements starting at @a _data.
|
/// Creates a new vector_ref to point to @a _count elements starting at @a _data.
|
||||||
vector_ref(_T* _data, size_t _count): m_data(_data), m_count(_count) {}
|
vector_ref(_T* _data, size_t _count): m_data(_data), m_count(_count) {}
|
||||||
/// Creates a new vector_ref pointing to the data part of a string (given as pointer).
|
/// Creates a new vector_ref pointing to the data part of a string (given as pointer).
|
||||||
vector_ref(typename std::conditional<std::is_const<_T>::value, std::string const*, std::string*>::type _data): m_data(reinterpret_cast<_T*>(_data->data())), m_count(_data->size() / sizeof(_T)) {}
|
vector_ref(string_type* _data): m_data(reinterpret_cast<_T*>(_data->data())), m_count(_data->size() / sizeof(_T)) {}
|
||||||
/// Creates a new vector_ref pointing to the data part of a vector (given as pointer).
|
|
||||||
vector_ref(typename std::conditional<std::is_const<_T>::value, std::vector<typename std::remove_const<_T>::type> const*, std::vector<_T>*>::type _data): m_data(_data->data()), m_count(_data->size()) {}
|
|
||||||
/// Creates a new vector_ref pointing to the data part of a string (given as reference).
|
/// Creates a new vector_ref pointing to the data part of a string (given as reference).
|
||||||
vector_ref(typename std::conditional<std::is_const<_T>::value, std::string const&, std::string&>::type _data): m_data(reinterpret_cast<_T*>(_data.data())), m_count(_data.size() / sizeof(_T)) {}
|
vector_ref(string_type& _data): vector_ref(&_data) {}
|
||||||
#if DEV_LDB
|
/// Creates a new vector_ref pointing to the data part of a vector (given as pointer).
|
||||||
vector_ref(ldb::Slice const& _s): m_data(reinterpret_cast<_T*>(_s.data())), m_count(_s.size() / sizeof(_T)) {}
|
vector_ref(vector_type* _data): m_data(_data->data()), m_count(_data->size()) {}
|
||||||
#endif
|
|
||||||
explicit operator bool() const { return m_data && m_count; }
|
explicit operator bool() const { return m_data && m_count; }
|
||||||
|
|
||||||
bool contentsEqual(std::vector<mutable_value_type> const& _c) const { if (!m_data || m_count == 0) return _c.empty(); else return _c.size() == m_count && !memcmp(_c.data(), m_data, m_count * sizeof(_T)); }
|
|
||||||
std::vector<mutable_value_type> toVector() const { return std::vector<mutable_value_type>(m_data, m_data + m_count); }
|
|
||||||
std::vector<unsigned char> toBytes() const { return std::vector<unsigned char>(reinterpret_cast<unsigned char const*>(m_data), reinterpret_cast<unsigned char const*>(m_data) + m_count * sizeof(_T)); }
|
std::vector<unsigned char> toBytes() const { return std::vector<unsigned char>(reinterpret_cast<unsigned char const*>(m_data), reinterpret_cast<unsigned char const*>(m_data) + m_count * sizeof(_T)); }
|
||||||
std::string toString() const { return std::string((char const*)m_data, ((char const*)m_data) + m_count * sizeof(_T)); }
|
std::string toString() const { return std::string((char const*)m_data, ((char const*)m_data) + m_count * sizeof(_T)); }
|
||||||
|
|
||||||
@ -50,25 +47,14 @@ public:
|
|||||||
|
|
||||||
_T* data() const { return m_data; }
|
_T* data() const { return m_data; }
|
||||||
/// @returns the number of elements referenced (not necessarily number of bytes).
|
/// @returns the number of elements referenced (not necessarily number of bytes).
|
||||||
size_t count() const { return m_count; }
|
|
||||||
/// @returns the number of elements referenced (not necessarily number of bytes).
|
|
||||||
size_t size() const { return m_count; }
|
size_t size() const { return m_count; }
|
||||||
bool empty() const { return !m_count; }
|
bool empty() const { return !m_count; }
|
||||||
/// @returns a new vector_ref pointing at the next chunk of @a size() elements.
|
|
||||||
vector_ref<_T> next() const { if (!m_data) return *this; else return vector_ref<_T>(m_data + m_count, m_count); }
|
|
||||||
/// @returns a new vector_ref which is a shifted and shortened view of the original data.
|
/// @returns a new vector_ref which is a shifted and shortened view of the original data.
|
||||||
/// If this goes out of bounds in any way, returns an empty vector_ref.
|
/// If this goes out of bounds in any way, returns an empty vector_ref.
|
||||||
/// If @a _count is ~size_t(0), extends the view to the end of the data.
|
/// If @a _count is ~size_t(0), extends the view to the end of the data.
|
||||||
vector_ref<_T> cropped(size_t _begin, size_t _count) const { if (m_data && _begin <= m_count && _count <= m_count && _begin + _count <= m_count) return vector_ref<_T>(m_data + _begin, _count == ~size_t(0) ? m_count - _begin : _count); else return vector_ref<_T>(); }
|
vector_ref<_T> cropped(size_t _begin, size_t _count) const { if (m_data && _begin <= m_count && _count <= m_count && _begin + _count <= m_count) return vector_ref<_T>(m_data + _begin, _count == ~size_t(0) ? m_count - _begin : _count); else return vector_ref<_T>(); }
|
||||||
/// @returns a new vector_ref which is a shifted view of the original data (not going beyond it).
|
/// @returns a new vector_ref which is a shifted view of the original data (not going beyond it).
|
||||||
vector_ref<_T> cropped(size_t _begin) const { if (m_data && _begin <= m_count) return vector_ref<_T>(m_data + _begin, m_count - _begin); else return vector_ref<_T>(); }
|
vector_ref<_T> cropped(size_t _begin) const { if (m_data && _begin <= m_count) return vector_ref<_T>(m_data + _begin, m_count - _begin); else return vector_ref<_T>(); }
|
||||||
void retarget(_T* _d, size_t _s) { m_data = _d; m_count = _s; }
|
|
||||||
void retarget(std::vector<_T> const& _t) { m_data = _t.data(); m_count = _t.size(); }
|
|
||||||
template <class T> bool overlapsWith(vector_ref<T> _t) const { void const* f1 = data(); void const* t1 = data() + size(); void const* f2 = _t.data(); void const* t2 = _t.data() + _t.size(); return f1 < t2 && t1 > f2; }
|
|
||||||
/// Copies the contents of this vector_ref to the contents of @a _t, up to the max size of @a _t.
|
|
||||||
void copyTo(vector_ref<typename std::remove_const<_T>::type> _t) const { if (overlapsWith(_t)) memmove(_t.data(), m_data, std::min(_t.size(), m_count) * sizeof(_T)); else memcpy(_t.data(), m_data, std::min(_t.size(), m_count) * sizeof(_T)); }
|
|
||||||
/// Copies the contents of this vector_ref to the contents of @a _t, and zeros further trailing elements in @a _t.
|
|
||||||
void populate(vector_ref<typename std::remove_const<_T>::type> _t) const { copyTo(_t); memset(_t.data() + m_count, 0, std::max(_t.size(), m_count) - m_count); }
|
|
||||||
|
|
||||||
_T* begin() { return m_data; }
|
_T* begin() { return m_data; }
|
||||||
_T* end() { return m_data + m_count; }
|
_T* end() { return m_data + m_count; }
|
||||||
@ -81,20 +67,11 @@ public:
|
|||||||
bool operator==(vector_ref<_T> const& _cmp) const { return m_data == _cmp.m_data && m_count == _cmp.m_count; }
|
bool operator==(vector_ref<_T> const& _cmp) const { return m_data == _cmp.m_data && m_count == _cmp.m_count; }
|
||||||
bool operator!=(vector_ref<_T> const& _cmp) const { return !operator==(_cmp); }
|
bool operator!=(vector_ref<_T> const& _cmp) const { return !operator==(_cmp); }
|
||||||
|
|
||||||
#if DEV_LDB
|
|
||||||
operator ldb::Slice() const { return ldb::Slice((char const*)m_data, m_count * sizeof(_T)); }
|
|
||||||
#endif
|
|
||||||
|
|
||||||
void reset() { m_data = nullptr; m_count = 0; }
|
void reset() { m_data = nullptr; m_count = 0; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
_T* m_data;
|
_T* m_data = nullptr;
|
||||||
size_t m_count;
|
size_t m_count = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
template<class _T> vector_ref<_T const> ref(_T const& _t) { return vector_ref<_T const>(&_t, 1); }
|
|
||||||
template<class _T> vector_ref<_T> ref(_T& _t) { return vector_ref<_T>(&_t, 1); }
|
|
||||||
template<class _T> vector_ref<_T const> ref(std::vector<_T> const& _t) { return vector_ref<_T const>(&_t); }
|
|
||||||
template<class _T> vector_ref<_T> ref(std::vector<_T>& _t) { return vector_ref<_T>(&_t); }
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -38,7 +38,7 @@ void LinkerObject::link(map<string, h160> const& _libraryAddresses)
|
|||||||
std::map<size_t, std::string> remainingRefs;
|
std::map<size_t, std::string> remainingRefs;
|
||||||
for (auto const& linkRef: linkReferences)
|
for (auto const& linkRef: linkReferences)
|
||||||
if (h160 const* address = matchLibrary(linkRef.second, _libraryAddresses))
|
if (h160 const* address = matchLibrary(linkRef.second, _libraryAddresses))
|
||||||
address->ref().copyTo(ref(bytecode).cropped(linkRef.first, 20));
|
copy(address->data(), address->data() + 20, bytecode.begin() + linkRef.first);
|
||||||
else
|
else
|
||||||
remainingRefs.insert(linkRef);
|
remainingRefs.insert(linkRef);
|
||||||
linkReferences.swap(remainingRefs);
|
linkReferences.swap(remainingRefs);
|
||||||
|
Loading…
Reference in New Issue
Block a user