#ifndef LLARP_MEM_HPP #define LLARP_MEM_HPP #include #include #include #include #include namespace llarp { void Zero(void *ptr, size_t sz); template < typename T > void dumphex(const uint8_t *t) { size_t idx = 0; while(idx < sizeof(T)) { printf("%.2x ", t[idx++]); if(idx % 8 == 0) printf("\n"); } } template < typename T, size_t align = 128 > void DumpBufferHex(const T &buff) { size_t idx = 0; printf("buffer of size %zu\n", buff.sz); while(idx < buff.sz) { if(buff.base + idx == buff.cur) { #ifndef _WIN32 printf("%c[1;31m", 27); #endif } printf("%.2x", buff.base[idx]); if(buff.base + idx == buff.cur) { #ifndef _WIN32 printf("%c[0;0m", 27); #endif } ++idx; if(idx % align == 0) printf("\n"); } printf("\n"); fflush(stdout); } template < typename T, size_t align = 128 > void DumpBuffer(const T &buff) { size_t idx = 0; printf("buffer of size %zu\n", buff.sz); while(idx < buff.sz) { if(buff.base + idx == buff.cur) { #ifndef _WIN32 printf("%c[1;31m", 27); #endif } if(std::isprint(buff.base[idx])) { printf("%c", buff.base[idx]); } else { printf("."); } if(buff.base + idx == buff.cur) { #ifndef _WIN32 printf("%c[0;0m", 27); #endif } ++idx; if(idx % align == 0) printf("\n"); } printf("\n"); fflush(stdout); } } // namespace llarp #if __cplusplus < 201402L namespace std { template < typename T, typename... Args > std::unique_ptr< T > make_unique(Args &&... args) { return std::unique_ptr< T >(new T(std::forward< Args >(args)...)); } } // namespace std #endif #endif