2018-09-25 01:54:07 +02:00
|
|
|
#ifndef HEADER_VOXEL_UTILITY_H
|
|
|
|
#define HEADER_VOXEL_UTILITY_H
|
|
|
|
|
|
|
|
#include "vector3i.h"
|
2019-04-13 19:47:35 +02:00
|
|
|
#include <core/ustring.h>
|
|
|
|
#include <core/vector.h>
|
2019-04-20 22:21:45 +02:00
|
|
|
#include <vector>
|
2018-09-25 01:54:07 +02:00
|
|
|
|
|
|
|
// Takes elements starting from a given position and moves them at the beginning,
|
|
|
|
// then shrink the array to fit them. Other elements are discarded.
|
|
|
|
template <typename T>
|
|
|
|
void shift_up(Vector<T> &v, int pos) {
|
|
|
|
|
|
|
|
int j = 0;
|
|
|
|
for (int i = pos; i < v.size(); ++i, ++j) {
|
|
|
|
v.write[j] = v[i];
|
|
|
|
}
|
|
|
|
|
|
|
|
int remaining = v.size() - pos;
|
|
|
|
v.resize(remaining);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Pops the last element of the vector and place it at the given position.
|
|
|
|
// (The element that was at this position is the one removed).
|
|
|
|
template <typename T>
|
|
|
|
void unordered_remove(Vector<T> &v, int pos) {
|
|
|
|
int last = v.size() - 1;
|
|
|
|
v.write[pos] = v[last];
|
|
|
|
v.resize(last);
|
|
|
|
}
|
|
|
|
|
|
|
|
template <typename T>
|
|
|
|
void copy_to(PoolVector<T> &to, const Vector<T> &from) {
|
|
|
|
|
|
|
|
to.resize(from.size());
|
|
|
|
|
|
|
|
typename PoolVector<T>::Write w = to.write();
|
|
|
|
|
|
|
|
for (unsigned int i = 0; i < from.size(); ++i) {
|
|
|
|
w[i] = from[i];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-09-27 01:31:09 +02:00
|
|
|
inline String ptr2s(const void *p) {
|
|
|
|
return String::num_uint64((uint64_t)p, 16);
|
|
|
|
}
|
|
|
|
|
2019-04-20 22:21:45 +02:00
|
|
|
template <typename T>
|
|
|
|
void raw_copy_to(PoolVector<T> &to, const std::vector<T> &from) {
|
|
|
|
to.resize(from.size());
|
|
|
|
typename PoolVector<T>::Write w = to.write();
|
|
|
|
memcpy(w.ptr(), from.data(), from.size() * sizeof(T));
|
|
|
|
}
|
|
|
|
|
2018-09-25 01:54:07 +02:00
|
|
|
#endif // HEADER_VOXEL_UTILITY_H
|