X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Socket%2FProtocols%2FINet%2FINet4Address.cci;h=5cdc88728a45d9d733220189397221ba98a5298a;hb=d001b1fe2a8fb121145d2a111d737219abae20d7;hp=61b328f0e934ecd1436244c1a8aaf847ee2e003a;hpb=ced8f321adf904c31149162de5f6258c971c7466;p=senf.git diff --git a/Socket/Protocols/INet/INet4Address.cci b/Socket/Protocols/INet/INet4Address.cci index 61b328f..5cdc887 100644 --- a/Socket/Protocols/INet/INet4Address.cci +++ b/Socket/Protocols/INet/INet4Address.cci @@ -1,8 +1,8 @@ // $Id$ // -// Copyright (C) 2007 -// Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS) -// Kompetenzzentrum fuer Satelitenkommunikation (SatCom) +// Copyright (C) 2007 +// Fraunhofer Institute for Open Communication Systems (FOKUS) +// Competence Center NETwork research (NET), St. Augustin, GERMANY // Stefan Bund // // This program is free software; you can redistribute it and/or modify @@ -36,7 +36,7 @@ prefix_ senf::INet4Address::INet4Address() std::fill(begin(), end(), 0u); } -prefix_ senf::INet4Address::INet4Address(NoInit_t) +prefix_ senf::INet4Address::INet4Address(senf::NoInit_t) {} prefix_ senf::INet4Address senf::INet4Address::from_inaddr(inaddr_type v) @@ -44,6 +44,23 @@ prefix_ senf::INet4Address senf::INet4Address::from_inaddr(inaddr_type v) return INet4Address(v,IsInAddr); } +prefix_ senf::INet4Address::inaddr_type & senf::INet4Address::iref() +{ + return *reinterpret_cast(&(*this)[0]); +} + +prefix_ senf::INet4Address::inaddr_type senf::INet4Address::iref() + const +{ + return *reinterpret_cast(&(*this)[0]); +} + +prefix_ senf::INet4Address::inaddr_type senf::INet4Address::inaddr() + const +{ + return iref(); +} + prefix_ senf::INet4Address::INet4Address(inaddr_type addr, InAddr_t) { iref() = addr; @@ -61,27 +78,89 @@ prefix_ bool senf::INet4Address::boolean_test() return inaddr(); } -prefix_ senf::INet4Address::inaddr_type senf::INet4Address::inaddr() +/////////////////////////////////////////////////////////////////////////// +// senf::INet4Network + +prefix_ unsigned senf::INet4Network::prefix_len() const { - return iref(); + return prefix_len_; } -prefix_ senf::INet4Address::inaddr_type & senf::INet4Address::iref() +//////////////////////////////////////// +// private members + +prefix_ boost::uint32_t senf::INet4Network::mask() + const { - return *reinterpret_cast(&(*this)[0]); + // This is correct as long as the system is using 2-complement arithmetic ... + return (~((boost::uint32_t(1u)<<(32u-prefix_len()))-1u)) & 0xFFFFFFFFu; } -prefix_ senf::INet4Address::inaddr_type senf::INet4Address::iref() +//////////////////////////////////////// +// public members + +prefix_ senf::INet4Network::INet4Network() + : prefix_len_(), address_() +{} + +prefix_ senf::INet4Network::INet4Network(INet4Address const & address, unsigned prefix_len) + : prefix_len_(prefix_len), address_(INet4Address(address.address() & mask())) +{} + +prefix_ senf::INet4Address const & senf::INet4Network::address() const { - return *reinterpret_cast(&(*this)[0]); + return address_; +} + +prefix_ bool senf::INet4Network::boolean_test() + const +{ + return address() || prefix_len(); +} + +prefix_ bool senf::INet4Network::operator==(INet4Network const & other) + const +{ + return address() == other.address() && prefix_len() == other.prefix_len(); +} + +prefix_ bool senf::INet4Network::match(INet4Address const & addr) + const +{ + return (addr.address() & mask()) == address_.address(); +} + +prefix_ bool senf::INet4Network::match(INet4Network const & net) + const +{ + return net.prefix_len() >= prefix_len() && match(net.address()); +} + +prefix_ senf::INet4Address senf::INet4Network::host(boost::uint32_t number) +{ + return INet4Address(address_.address() | (number & ~mask())); +} + +prefix_ senf::INet4Network senf::INet4Network::subnet(boost::uint32_t net, unsigned prefix_len) +{ + return INet4Network(host(net << (32-prefix_len)),prefix_len); +} + +/////////////////////////////////////////////////////////////////////////// +// namespace members + +prefix_ std::ostream & senf::operator<<(std::ostream & os, INet4Network const & addr) +{ + os << addr.address() << '/' << addr.prefix_len(); + return os; } ///////////////////////////////cci.e/////////////////////////////////////// #undef prefix_ - + // Local Variables: // mode: c++ // fill-column: 100