Green Sky
8eb4892b49
6d634674a9 cleanup: Remove old type-ordered event getters. d1d48d1dfc feat: add ngc events 994ffecc6b refactor: Make event dispatch ordered by receive time. 812f931d5f fix: Make sure there's enough space for CONSUME1 in fuzzers. 50f1b30fa9 test: Add fuzz tests to the coverage run. df76f5cf47 chore: Move from gcov to llvm source-based coverage. 072e3beb3f fix: issues with packet broadcast error reporting 6b6718e4d2 cleanup: Make group packet entry creation less error-prone 5b9c420ce1 refactor: packet broadcast functions now return errors af4cb31028 refactor: Use `operator==` for equality tests of `Node_format`. 9592d590cf refactor(test): Slightly nicer C++ interface to tox Random. c66e10fb7a refactor: Minor refactoring of get_close_nodes functions. ebc9643862 fix: don't pass garbage data buffer to packet send functions 32b68cffca cleanup: Some more test cleanups, removing overly smart code. 0426624dcb refactor: Assign malloc return to a local variable first. afc38f2458 test: Add more unit tests for `add_to_list`. 05ce5c1ab9 test: Add "infer" CI check to github, remove from circle. REVERT: 8f0d505f9a feat: add ngc events REVERT: 9b8216e70c refactor: Make event dispatch ordered by receive time. git-subtree-dir: external/toxcore/c-toxcore git-subtree-split: 6d634674a929edb0ab70689dcbcb195b3547be13
69 lines
1.6 KiB
C++
69 lines
1.6 KiB
C++
#ifndef C_TOXCORE_TOXCORE_TEST_UTIL_H
|
|
#define C_TOXCORE_TOXCORE_TEST_UTIL_H
|
|
|
|
#include <algorithm>
|
|
#include <array>
|
|
#include <memory>
|
|
#include <vector>
|
|
|
|
template <typename T, void (*Delete)(T *)>
|
|
struct Function_Deleter {
|
|
void operator()(T *ptr) const { Delete(ptr); }
|
|
};
|
|
|
|
// No default deleter, because we want to catch when we forget to specialise this one.
|
|
template <typename T>
|
|
struct Deleter;
|
|
|
|
template <typename T>
|
|
using Ptr = std::unique_ptr<T, Deleter<T>>;
|
|
|
|
template <typename Func, typename Class>
|
|
struct Method;
|
|
|
|
template <typename R, typename Class, typename... Args>
|
|
struct Method<R(void *, Args...), Class> {
|
|
template <R (Class::*M)(void *, Args...)>
|
|
static R invoke(void *self, Args... args)
|
|
{
|
|
return (static_cast<Class *>(self)->*M)(self, args...);
|
|
}
|
|
};
|
|
|
|
template <typename T, std::size_t N>
|
|
std::array<T, N> to_array(T const (&arr)[N])
|
|
{
|
|
std::array<T, N> stdarr;
|
|
std::copy(arr, arr + N, stdarr.begin());
|
|
return stdarr;
|
|
}
|
|
|
|
template <std::size_t N, typename T, typename... Args>
|
|
auto array_of(T &&make, Args... args)
|
|
{
|
|
std::array<typename std::result_of<T(Args...)>::type, N> arr;
|
|
for (auto &elem : arr) {
|
|
elem = make(args...);
|
|
}
|
|
return arr;
|
|
}
|
|
|
|
template <typename T, typename... Args>
|
|
auto vector_of(std::size_t n, T &&make, Args... args)
|
|
{
|
|
std::vector<typename std::result_of<T(Args...)>::type> vec;
|
|
for (std::size_t i = 0; i < n; ++i) {
|
|
vec.push_back(make(args...));
|
|
}
|
|
return vec;
|
|
}
|
|
|
|
template <typename Container, typename Less>
|
|
Container sorted(Container arr, Less less)
|
|
{
|
|
std::sort(arr.begin(), arr.end(), less);
|
|
return arr;
|
|
}
|
|
|
|
#endif // C_TOXCORE_TOXCORE_TEST_UTIL_H
|