mirror of
https://github.com/PurpleI2P/i2pd.git
synced 2025-05-01 05:02:29 +02:00
Reformat code
This commit is contained in:
parent
3ddb370718
commit
55534ea002
140 changed files with 46068 additions and 48277 deletions
135
libi2pd/Tag.h
135
libi2pd/Tag.h
|
@ -15,92 +15,89 @@
|
|||
#include "Base.h"
|
||||
|
||||
namespace i2p {
|
||||
namespace data {
|
||||
template<size_t sz>
|
||||
class Tag
|
||||
{
|
||||
BOOST_STATIC_ASSERT_MSG(sz % 8 == 0, "Tag size must be multiple of 8 bytes");
|
||||
namespace data {
|
||||
template<size_t sz>
|
||||
class Tag {
|
||||
BOOST_STATIC_ASSERT_MSG(sz
|
||||
% 8 == 0, "Tag size must be multiple of 8 bytes");
|
||||
|
||||
public:
|
||||
public:
|
||||
|
||||
Tag () = default;
|
||||
Tag (const uint8_t * buf) { memcpy (m_Buf, buf, sz); }
|
||||
Tag() = default;
|
||||
|
||||
bool operator== (const Tag& other) const { return !memcmp (m_Buf, other.m_Buf, sz); }
|
||||
bool operator!= (const Tag& other) const { return !(*this == other); }
|
||||
bool operator< (const Tag& other) const { return memcmp (m_Buf, other.m_Buf, sz) < 0; }
|
||||
Tag(const uint8_t *buf) { memcpy(m_Buf, buf, sz); }
|
||||
|
||||
uint8_t * operator()() { return m_Buf; }
|
||||
const uint8_t * operator()() const { return m_Buf; }
|
||||
bool operator==(const Tag &other) const { return !memcmp(m_Buf, other.m_Buf, sz); }
|
||||
|
||||
operator uint8_t * () { return m_Buf; }
|
||||
operator const uint8_t * () const { return m_Buf; }
|
||||
bool operator!=(const Tag &other) const { return !(*this == other); }
|
||||
|
||||
const uint8_t * data() const { return m_Buf; }
|
||||
const uint64_t * GetLL () const { return ll; }
|
||||
bool operator<(const Tag &other) const { return memcmp(m_Buf, other.m_Buf, sz) < 0; }
|
||||
|
||||
bool IsZero () const
|
||||
{
|
||||
for (size_t i = 0; i < sz/8; ++i)
|
||||
if (ll[i]) return false;
|
||||
return true;
|
||||
}
|
||||
uint8_t *operator()() { return m_Buf; }
|
||||
|
||||
void Fill(uint8_t c)
|
||||
{
|
||||
memset(m_Buf, c, sz);
|
||||
}
|
||||
const uint8_t *operator()() const { return m_Buf; }
|
||||
|
||||
void Randomize()
|
||||
{
|
||||
RAND_bytes(m_Buf, sz);
|
||||
}
|
||||
operator uint8_t *() { return m_Buf; }
|
||||
|
||||
std::string ToBase64 (size_t len = sz) const
|
||||
{
|
||||
char str[sz*2];
|
||||
size_t l = i2p::data::ByteStreamToBase64 (m_Buf, len, str, sz*2);
|
||||
return std::string (str, str + l);
|
||||
}
|
||||
operator const uint8_t *() const { return m_Buf; }
|
||||
|
||||
std::string ToBase32 (size_t len = sz) const
|
||||
{
|
||||
char str[sz*2];
|
||||
size_t l = i2p::data::ByteStreamToBase32 (m_Buf, len, str, sz*2);
|
||||
return std::string (str, str + l);
|
||||
}
|
||||
const uint8_t *data() const { return m_Buf; }
|
||||
|
||||
size_t FromBase32 (const std::string& s)
|
||||
{
|
||||
return i2p::data::Base32ToByteStream (s.c_str (), s.length (), m_Buf, sz);
|
||||
}
|
||||
const uint64_t *GetLL() const { return ll; }
|
||||
|
||||
size_t FromBase64 (const std::string& s)
|
||||
{
|
||||
return i2p::data::Base64ToByteStream (s.c_str (), s.length (), m_Buf, sz);
|
||||
}
|
||||
bool IsZero() const {
|
||||
for (size_t i = 0; i < sz / 8; ++i)
|
||||
if (ll[i]) return false;
|
||||
return true;
|
||||
}
|
||||
|
||||
private:
|
||||
void Fill(uint8_t c) {
|
||||
memset(m_Buf, c, sz);
|
||||
}
|
||||
|
||||
union // 8 bytes aligned
|
||||
{
|
||||
uint8_t m_Buf[sz];
|
||||
uint64_t ll[sz/8];
|
||||
};
|
||||
};
|
||||
} // data
|
||||
void Randomize() {
|
||||
RAND_bytes(m_Buf, sz);
|
||||
}
|
||||
|
||||
std::string ToBase64(size_t len = sz) const {
|
||||
char str[sz * 2];
|
||||
size_t l = i2p::data::ByteStreamToBase64(m_Buf, len, str, sz * 2);
|
||||
return std::string(str, str + l);
|
||||
}
|
||||
|
||||
std::string ToBase32(size_t len = sz) const {
|
||||
char str[sz * 2];
|
||||
size_t l = i2p::data::ByteStreamToBase32(m_Buf, len, str, sz * 2);
|
||||
return std::string(str, str + l);
|
||||
}
|
||||
|
||||
size_t FromBase32(const std::string &s) {
|
||||
return i2p::data::Base32ToByteStream(s.c_str(), s.length(), m_Buf, sz);
|
||||
}
|
||||
|
||||
size_t FromBase64(const std::string &s) {
|
||||
return i2p::data::Base64ToByteStream(s.c_str(), s.length(), m_Buf, sz);
|
||||
}
|
||||
|
||||
private:
|
||||
|
||||
union // 8 bytes aligned
|
||||
{
|
||||
uint8_t m_Buf[sz];
|
||||
uint64_t ll[sz / 8];
|
||||
};
|
||||
};
|
||||
} // data
|
||||
} // i2p
|
||||
|
||||
namespace std
|
||||
{
|
||||
// hash for std::unordered_map
|
||||
template<size_t sz> struct hash<i2p::data::Tag<sz> >
|
||||
{
|
||||
size_t operator()(const i2p::data::Tag<sz>& s) const
|
||||
{
|
||||
return s.GetLL ()[0];
|
||||
}
|
||||
};
|
||||
namespace std {
|
||||
// hash for std::unordered_map
|
||||
template<size_t sz>
|
||||
struct hash<i2p::data::Tag<sz> > {
|
||||
size_t operator()(const i2p::data::Tag<sz> &s) const {
|
||||
return s.GetLL()[0];
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
#endif /* TAG_H__ */
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue