/* * Copyright (C) 2001-2008 Jacek Sieka, arnetheduck on gmail point com * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #ifndef DCPLUSPLUS_DCPP_HASH_VALUE_H #define DCPLUSPLUS_DCPP_HASH_VALUE_H #include "FastAlloc.h" #include "Encoder.h" namespace dcpp { template struct HashValue : FastAlloc >{ static const size_t BITS = Hasher::BITS; static const size_t BYTES = Hasher::BYTES; HashValue() { } explicit HashValue(uint8_t* aData) { memcpy(data, aData, BYTES); } explicit HashValue(const std::string& base32) { Encoder::fromBase32(base32.c_str(), data, BYTES); } HashValue(const HashValue& rhs) { memcpy(data, rhs.data, BYTES); } HashValue& operator=(const HashValue& rhs) { memcpy(data, rhs.data, BYTES); return *this; } bool operator!=(const HashValue& rhs) const { return !(*this == rhs); } bool operator==(const HashValue& rhs) const { return memcmp(data, rhs.data, BYTES) == 0; } bool operator<(const HashValue& rhs) const { return memcmp(data, rhs.data, BYTES) < 0; } std::string toBase32() const { return Encoder::toBase32(data, BYTES); } std::string& toBase32(std::string& tmp) const { return Encoder::toBase32(data, BYTES, tmp); } uint8_t data[BYTES]; }; } // namespace dcpp namespace std { namespace tr1 { template<> template struct hash > { size_t operator()(const dcpp::HashValue& rhs) const { return *(size_t*)rhs.data; } }; } } #endif // !defined(HASH_VALUE_H)