X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Packets%2FPacketData.cci;h=73719c55bee2becbdbeafc2356d7283958fe5b76;hb=a1fdb7bb122f0b05be809a922d4b7ef5e125fa67;hp=6a62bb08f96476420d802db578e8c791e905c62c;hpb=47368f306a577d1e46df69a7f729bd3893cbe5e7;p=senf.git diff --git a/Packets/PacketData.cci b/Packets/PacketData.cci index 6a62bb0..73719c5 100644 --- a/Packets/PacketData.cci +++ b/Packets/PacketData.cci @@ -1,6 +1,8 @@ -// Copyright (C) 2007 -// Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS) -// Kompetenzzentrum fuer Satelitenkommunikation (SatCom) +// $Id$ +// +// 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 @@ -22,9 +24,10 @@ \brief PacketData inline non-template implementation */ // Custom includes +#include "../Utils/senfassert.hh" #include #include "PacketImpl.hh" -#include "PacketParser.hh" +// #include "PacketParser.hh" #define prefix_ inline ///////////////////////////////cci.p/////////////////////////////////////// @@ -32,17 +35,24 @@ /////////////////////////////////////////////////////////////////////////// // senf::PacketData +prefix_ senf::detail::PacketImpl & senf::PacketData::impl() + const +{ + SENF_ASSERT( impl_ ); + return *impl_; +} + prefix_ senf::PacketData::iterator senf::PacketData::begin() const { - BOOST_ASSERT(begin_ <= impl().size()); + SENF_ASSERT(begin_ <= impl().size()); return boost::next(impl().begin(),begin_); } prefix_ senf::PacketData::iterator senf::PacketData::end() const { - BOOST_ASSERT(end_ <= impl().size()); + SENF_ASSERT(end_ <= impl().size()); return boost::next(impl().begin(),end_); } @@ -61,13 +71,13 @@ prefix_ bool senf::PacketData::empty() prefix_ senf::PacketData::byte senf::PacketData::operator[](size_type n) const { - BOOST_ASSERT( n < size() ); + SENF_ASSERT( n < size() ); return *( boost::next(begin(),n) ); } prefix_ senf::PacketData::byte & senf::PacketData::operator[](size_type n) { - BOOST_ASSERT( n < size() ); + SENF_ASSERT( n < size() ); return *( boost::next(begin(),n) ); } @@ -98,121 +108,27 @@ prefix_ void senf::PacketData::clear() impl().clear(this); } -prefix_ bool senf::PacketData::valid() +prefix_ void senf::PacketData::reserve(size_type n) { - return impl_; + impl().reserve(n + size() - impl().size()); } -// protected members - -prefix_ senf::PacketData::PacketData(size_type b, size_type e) - : impl_(), begin_(b), end_(e) -{} - -prefix_ senf::detail::PacketImpl & senf::PacketData::impl() +prefix_ senf::PacketData::size_type senf::PacketData::capacity() const { - BOOST_ASSERT( impl_ ); - return *impl_; -} - -/////////////////////////////////////////////////////////////////////////// -// senf::safe_data_iterator - -prefix_ senf::safe_data_iterator::safe_data_iterator() - : data_(0), i_(0) -{} - -prefix_ senf::safe_data_iterator::safe_data_iterator(PacketData & data) - : data_(&data), i_(0) -{} - -prefix_ senf::safe_data_iterator::safe_data_iterator(PacketData & data, PacketData::iterator i) - : data_(&data), i_(std::distance(data.begin(),i)) -{} - -prefix_ senf::safe_data_iterator::safe_data_iterator(PacketParserBase const & parser) - : data_(&parser.data()), i_(std::distance(data_->begin(),parser.i())) -{} - -prefix_ senf::safe_data_iterator & senf::safe_data_iterator::operator=(PacketData::iterator i) -{ - BOOST_ASSERT(data_); - i_ = std::distance(data_->begin(),i); - return *this; + return impl().capacity() - (impl().size() - size()); } -prefix_ senf::safe_data_iterator & -senf::safe_data_iterator::operator=(PacketParserBase const & parser) -{ - data_ = &parser.data(); - i_ = std::distance(data_->begin(),parser.i()); - return *this; -} - -prefix_ senf::safe_data_iterator::operator senf::PacketData::iterator() - const -{ - return i(); -} - -prefix_ bool senf::safe_data_iterator::boolean_test() - const -{ - return data_; -} - -prefix_ senf::PacketData & senf::safe_data_iterator::data() - const -{ - BOOST_ASSERT(data_); - return *data_; -} - -prefix_ senf::safe_data_iterator::value_type & senf::safe_data_iterator::dereference() - const -{ - return *i(); -} - -prefix_ bool senf::safe_data_iterator::equal(safe_data_iterator const & other) - const -{ - BOOST_ASSERT(data_ == other.data_); - return i_ == other.i_; -} - -prefix_ senf::safe_data_iterator::difference_type -senf::safe_data_iterator::distance_to(safe_data_iterator const & other) - const -{ - BOOST_ASSERT(data_ == other.data_); - return other.i_ - i_; -} - -prefix_ void senf::safe_data_iterator::increment() -{ - ++i_; -} - -prefix_ void senf::safe_data_iterator::decrement() +prefix_ bool senf::PacketData::valid() { - BOOST_ASSERT(i_>0); - --i_; + return impl_; } -prefix_ void senf::safe_data_iterator::advance(difference_type n) -{ - BOOST_ASSERT( -n < difference_type(i_) ); - i_ += n; -} +// protected members -prefix_ senf::PacketData::iterator senf::safe_data_iterator::i() - const -{ - BOOST_ASSERT(data_); - return boost::next(data_->begin(),i_); -} +prefix_ senf::PacketData::PacketData(size_type b, size_type e) + : impl_(), begin_(b), end_(e) +{} ///////////////////////////////cci.e/////////////////////////////////////// #undef prefix_ @@ -224,4 +140,6 @@ prefix_ senf::PacketData::iterator senf::safe_data_iterator::i() // c-file-style: "senf" // indent-tabs-mode: nil // ispell-local-dictionary: "american" +// compile-command: "scons -u test" +// comment-column: 40 // End: