#include #include namespace amy { namespace utils { ui fastHash(cstr& s) { ui hash = 5381; for (auto& it : s) { hash = (hash * 33) + static_cast(it); } return hash; } vec loadFile2Mem(cstr& path) { std::ifstream iff(path, std::ios::binary); if (!iff) { return vec(); } iff.seekg(0, std::ios::end); size_t szs = iff.tellg(); iff.seekg(0, std::ios::beg); vec res(szs, 0); iff.read(reinterpret_cast(res.data()), res.size()); iff.close(); return res; } ui hashMemory(cvec& data) { ui hash = 4477; for (auto& it : data) { hash = (hash * 33) + it; } return hash; } ui nextPow2(ui v) { v--; v |= v >> 1; v |= v >> 2; v |= v >> 4; v |= v >> 8; v |= v >> 16; v++; return (v >= 64 ? v : 64); } bool isSingleBitNum(ui v) { return v && !(v & (v - 1)); } namespace image { void reverseBuf(vec& buf, int w, int h, int c) { vec cpy = buf; for (int x = 0; x < w; x++) { for (int y = 0; y < h; y++) { int pos = (y * w + x) * c; for (size_t i = 0; i < c; i++) { buf[pos + c - 1 - i] = cpy[pos + i]; } } } } void removeAlphaChannel(vec& buf, int w, int h) { vec cpy = buf; buf.resize(w * h * 3); for (int y = 0; y < h; y++) { for (int x = 0; x < w; x++) { int src = (y * w + x) * 4; int dst = (y * w + x) * 3; buf[dst + 0] = cpy[src + 0]; buf[dst + 1] = cpy[src + 1]; buf[dst + 2] = cpy[src + 2]; } } } void addAlphaChannel(vec& buf, int w, int h) { vec cpy = buf; buf.resize(w * h * 4); for (int y = 0; y < h; y++) { for (int x = 0; x < w; x++) { int src = (y * w + x) * 3; int dst = (y * w + x) * 4; buf[dst + 0] = cpy[src + 0]; buf[dst + 1] = cpy[src + 1]; buf[dst + 2] = cpy[src + 2]; buf[dst + 3] = 255; } } } } // namespace image } // namespace utils } // namespace amy