#ifndef _TOX_ADDRESS_H_ #define _TOX_ADDRESS_H_ class ToxHexAddress; class ToxBinAddress; class ToxHexAddress { private: std::string hexData; public: ToxHexAddress(const char *hex) : hexData(hex) { } ToxHexAddress(const std::string &hex) : hexData(hex) { } ToxHexAddress(const ToxHexAddress &address) : hexData(address.hexData) { } ToxHexAddress(const std::vector &bin) { this->ToxHexAddress::ToxHexAddress(bin.data(), bin.size()); } ToxHexAddress(const uint8_t *bin, int size = TOX_FRIEND_ADDRESS_SIZE) { char *hex = (char*)mir_alloc(size * 2 + 1); hexData = bin2hex(bin, size, hex); std::transform(hexData.begin(), hexData.end(), hexData.begin(), ::toupper); mir_free(hex); } const size_t GetLength() const { return hexData.length(); } const ToxHexAddress GetPubKey() const { ToxHexAddress pubKey = hexData.substr(0, TOX_PUBLIC_KEY_SIZE * 2).c_str(); return pubKey; } operator const char*() const { return hexData.c_str(); } ToxBinAddress ToBin() const; }; class ToxBinAddress { private: std::vector binData; public: ToxBinAddress(const ToxBinAddress &address) : binData(address.binData) { } ToxBinAddress(const std::vector &bin) : binData(bin) { } ToxBinAddress(const uint8_t *bin, int size = TOX_FRIEND_ADDRESS_SIZE) : binData(bin, bin + size) { } ToxBinAddress(const std::string &hex) { this->ToxBinAddress::ToxBinAddress(hex.c_str()); } ToxBinAddress(const char *hex) { char *endptr; const char *pos = hex; int size = mir_strlen(hex) / 2; uint8_t *result = (uint8_t*)mir_alloc(size); for (int i = 0; i < size; i++) { char buf[5] = { '0', 'x', pos[0], pos[1], 0 }; binData.push_back((uint8_t)strtol(buf, &endptr, 0)); pos += 2; } } const ToxBinAddress GetPubKey() const { ToxBinAddress pubKey(binData.data(), TOX_PUBLIC_KEY_SIZE); return pubKey; } operator const uint8_t*() const { return binData.data(); } ToxHexAddress ToHex() const { ToxHexAddress hex(binData.data(), binData.size()); return hex; } }; ToxBinAddress ToxHexAddress::ToBin() const { ToxBinAddress bin(hexData.c_str()); return bin; } /*class ToxAddress { private: std::string hexData; class ToxBytes { private: uint8_t *bytes; public: ToxBytes(uint8_t *bytes) : bytes(bytes) { } ~ToxBytes() { if (bytes) mir_free(bytes); } operator const uint8_t*() { return bytes; } }; public: ToxAddress(const char *hex) : hexData(hex) { } ToxAddress(const std::string &hex) : hexData(hex) { } ToxAddress(const ToxAddress &address) : hexData(address.hexData) { } ToxAddress(const uint8_t *bin, int size = TOX_FRIEND_ADDRESS_SIZE) //: binData(bin, bin + size) { char *hex = (char*)mir_alloc(size * 2 + 1); std::string hexData = bin2hex(bin, size, hex); std::transform(hexData.begin(), hexData.end(), hexData.begin(), ::toupper); //mir_free(hex); } ~ToxAddress() { int i = 0; } operator const char*() const { return hexData.c_str(); } ToxBytes AsBytes() const { char *endptr; const char *pos = hexData.c_str(); int size = hexData.length() / 2; uint8_t *result = (uint8_t*)mir_alloc(size); for (int i = 0; i < size; i++) { char buf[5] = { '0', 'x', pos[0], pos[1], 0 }; result[i] = (uint8_t)strtol(buf, &endptr, 0); pos += 2; } return ToxBytes(result); } std::string AsPubKey() const { return hexData.substr(0, TOX_PUBLIC_KEY_SIZE * 2).c_str(); } };*/ #endif //_TOX_ADDRESS_H_