summaryrefslogtreecommitdiff
path: root/node
diff options
context:
space:
mode:
authorAdam Ierymenko <adam.ierymenko@gmail.com>2017-02-04 00:23:31 -0800
committerAdam Ierymenko <adam.ierymenko@gmail.com>2017-02-04 00:23:31 -0800
commit31db768e4d4c2815d2be0493b2c76ea5f5edbffa (patch)
treeae76b2153c5a6d58dd4b887c54626ee9e93b6601 /node
parentd9e4ba1280bc5aec5d4cc04c4c495ac9c923563d (diff)
downloadinfinitytier-31db768e4d4c2815d2be0493b2c76ea5f5edbffa.tar.gz
infinitytier-31db768e4d4c2815d2be0493b2c76ea5f5edbffa.zip
A bit of code cleanup.
Diffstat (limited to 'node')
-rw-r--r--node/Address.hpp77
-rw-r--r--node/Identity.cpp2
-rw-r--r--node/NetworkConfig.cpp2
-rw-r--r--node/Switch.cpp3
4 files changed, 23 insertions, 61 deletions
diff --git a/node/Address.hpp b/node/Address.hpp
index 9bf5605a..4a5883b0 100644
--- a/node/Address.hpp
+++ b/node/Address.hpp
@@ -38,57 +38,26 @@ namespace ZeroTier {
class Address
{
public:
- Address()
- throw() :
- _a(0)
- {
- }
-
- Address(const Address &a)
- throw() :
- _a(a._a)
- {
- }
-
- Address(uint64_t a)
- throw() :
- _a(a & 0xffffffffffULL)
- {
- }
-
- Address(const char *s)
- throw()
- {
- unsigned char foo[ZT_ADDRESS_LENGTH];
- setTo(foo,Utils::unhex(s,foo,ZT_ADDRESS_LENGTH));
- }
-
- Address(const std::string &s)
- throw()
- {
- unsigned char foo[ZT_ADDRESS_LENGTH];
- setTo(foo,Utils::unhex(s.c_str(),foo,ZT_ADDRESS_LENGTH));
- }
+ Address() : _a(0) {}
+ Address(const Address &a) : _a(a._a) {}
+ Address(uint64_t a) : _a(a & 0xffffffffffULL) {}
/**
* @param bits Raw address -- 5 bytes, big-endian byte order
* @param len Length of array
*/
Address(const void *bits,unsigned int len)
- throw()
{
setTo(bits,len);
}
inline Address &operator=(const Address &a)
- throw()
{
_a = a._a;
return *this;
}
inline Address &operator=(const uint64_t a)
- throw()
{
_a = (a & 0xffffffffffULL);
return *this;
@@ -99,7 +68,6 @@ public:
* @param len Length of array
*/
inline void setTo(const void *bits,unsigned int len)
- throw()
{
if (len < ZT_ADDRESS_LENGTH) {
_a = 0;
@@ -119,7 +87,6 @@ public:
* @param len Length of array
*/
inline void copyTo(void *bits,unsigned int len) const
- throw()
{
if (len < ZT_ADDRESS_LENGTH)
return;
@@ -138,7 +105,6 @@ public:
*/
template<unsigned int C>
inline void appendTo(Buffer<C> &b) const
- throw(std::out_of_range)
{
unsigned char *p = (unsigned char *)b.appendField(ZT_ADDRESS_LENGTH);
*(p++) = (unsigned char)((_a >> 32) & 0xff);
@@ -152,7 +118,6 @@ public:
* @return Integer containing address (0 to 2^40)
*/
inline uint64_t toInt() const
- throw()
{
return _a;
}
@@ -161,7 +126,6 @@ public:
* @return Hash code for use with Hashtable
*/
inline unsigned long hashCode() const
- throw()
{
return (unsigned long)_a;
}
@@ -188,12 +152,12 @@ public:
/**
* @return True if this address is not zero
*/
- inline operator bool() const throw() { return (_a != 0); }
+ inline operator bool() const { return (_a != 0); }
/**
* Set to null/zero
*/
- inline void zero() throw() { _a = 0; }
+ inline void zero() { _a = 0; }
/**
* Check if this address is reserved
@@ -205,7 +169,6 @@ public:
* @return True if address is reserved and may not be used
*/
inline bool isReserved() const
- throw()
{
return ((!_a)||((_a >> 32) == ZT_ADDRESS_RESERVED_PREFIX));
}
@@ -214,21 +177,21 @@ public:
* @param i Value from 0 to 4 (inclusive)
* @return Byte at said position (address interpreted in big-endian order)
*/
- inline unsigned char operator[](unsigned int i) const throw() { return (unsigned char)((_a >> (32 - (i * 8))) & 0xff); }
-
- inline bool operator==(const uint64_t &a) const throw() { return (_a == (a & 0xffffffffffULL)); }
- inline bool operator!=(const uint64_t &a) const throw() { return (_a != (a & 0xffffffffffULL)); }
- inline bool operator>(const uint64_t &a) const throw() { return (_a > (a & 0xffffffffffULL)); }
- inline bool operator<(const uint64_t &a) const throw() { return (_a < (a & 0xffffffffffULL)); }
- inline bool operator>=(const uint64_t &a) const throw() { return (_a >= (a & 0xffffffffffULL)); }
- inline bool operator<=(const uint64_t &a) const throw() { return (_a <= (a & 0xffffffffffULL)); }
-
- inline bool operator==(const Address &a) const throw() { return (_a == a._a); }
- inline bool operator!=(const Address &a) const throw() { return (_a != a._a); }
- inline bool operator>(const Address &a) const throw() { return (_a > a._a); }
- inline bool operator<(const Address &a) const throw() { return (_a < a._a); }
- inline bool operator>=(const Address &a) const throw() { return (_a >= a._a); }
- inline bool operator<=(const Address &a) const throw() { return (_a <= a._a); }
+ inline unsigned char operator[](unsigned int i) const { return (unsigned char)((_a >> (32 - (i * 8))) & 0xff); }
+
+ inline bool operator==(const uint64_t &a) const { return (_a == (a & 0xffffffffffULL)); }
+ inline bool operator!=(const uint64_t &a) const { return (_a != (a & 0xffffffffffULL)); }
+ inline bool operator>(const uint64_t &a) const { return (_a > (a & 0xffffffffffULL)); }
+ inline bool operator<(const uint64_t &a) const { return (_a < (a & 0xffffffffffULL)); }
+ inline bool operator>=(const uint64_t &a) const { return (_a >= (a & 0xffffffffffULL)); }
+ inline bool operator<=(const uint64_t &a) const { return (_a <= (a & 0xffffffffffULL)); }
+
+ inline bool operator==(const Address &a) const { return (_a == a._a); }
+ inline bool operator!=(const Address &a) const { return (_a != a._a); }
+ inline bool operator>(const Address &a) const { return (_a > a._a); }
+ inline bool operator<(const Address &a) const { return (_a < a._a); }
+ inline bool operator>=(const Address &a) const { return (_a >= a._a); }
+ inline bool operator<=(const Address &a) const { return (_a <= a._a); }
private:
uint64_t _a;
diff --git a/node/Identity.cpp b/node/Identity.cpp
index c47805d9..05b70873 100644
--- a/node/Identity.cpp
+++ b/node/Identity.cpp
@@ -160,7 +160,7 @@ bool Identity::fromString(const char *str)
for(char *f=Utils::stok(tmp,":",&saveptr);(f);f=Utils::stok((char *)0,":",&saveptr)) {
switch(fno++) {
case 0:
- _address = Address(f);
+ _address = Address(Utils::hexStrToU64(f));
if (_address.isReserved())
return false;
break;
diff --git a/node/NetworkConfig.cpp b/node/NetworkConfig.cpp
index 6acc48ea..2f356b15 100644
--- a/node/NetworkConfig.cpp
+++ b/node/NetworkConfig.cpp
@@ -258,7 +258,7 @@ bool NetworkConfig::fromDictionary(const Dictionary<ZT_NETWORKCONFIG_DICT_CAPACI
if (d.get(ZT_NETWORKCONFIG_DICT_KEY_ACTIVE_BRIDGES_OLD,tmp2,sizeof(tmp2)) > 0) {
char *saveptr = (char *)0;
for(char *f=Utils::stok(tmp2,",",&saveptr);(f);f=Utils::stok((char *)0,",",&saveptr)) {
- this->addSpecialist(Address(f),ZT_NETWORKCONFIG_SPECIALIST_TYPE_ACTIVE_BRIDGE);
+ this->addSpecialist(Address(Utils::hexStrToU64(f)),ZT_NETWORKCONFIG_SPECIALIST_TYPE_ACTIVE_BRIDGE);
}
}
#else
diff --git a/node/Switch.cpp b/node/Switch.cpp
index 9fcd379f..a769faea 100644
--- a/node/Switch.cpp
+++ b/node/Switch.cpp
@@ -224,7 +224,7 @@ void Switch::onRemotePacket(const InetAddress &localAddr,const InetAddress &from
#endif
SharedPtr<Peer> relayTo = RR->topology->getPeer(destination);
- if ((relayTo)&&((relayTo->sendDirect(packet.data(),packet.size(),now,false)))) {
+ if ((relayTo)&&(relayTo->sendDirect(packet.data(),packet.size(),now,false))) {
if ((source != RR->identity.address())&&(_shouldUnite(now,source,destination))) { // don't send RENDEZVOUS for cluster frontplane relays
const InetAddress *hintToSource = (InetAddress *)0;
const InetAddress *hintToDest = (InetAddress *)0;
@@ -245,7 +245,6 @@ void Switch::onRemotePacket(const InetAddress &localAddr,const InetAddress &from
}
if ((hintToSource)&&(hintToDest)) {
- TRACE(">> RENDEZVOUS: %s(%s) <> %s(%s)",p1.toString().c_str(),p1a->toString().c_str(),p2.toString().c_str(),p2a->toString().c_str());
unsigned int alt = (unsigned int)RR->node->prng() & 1; // randomize which hint we send first for obscure NAT-t reasons
const unsigned int completed = alt + 2;
while (alt != completed) {