4 // Fraunhofer Institute for Open Communication Systems (FOKUS)
5 // Competence Center NETwork research (NET), St. Augustin, GERMANY
6 // Stefan Bund <g0dil@berlios.de>
8 // This program is free software; you can redistribute it and/or modify
9 // it under the terms of the GNU General Public License as published by
10 // the Free Software Foundation; either version 2 of the License, or
11 // (at your option) any later version.
13 // This program is distributed in the hope that it will be useful,
14 // but WITHOUT ANY WARRANTY; without even the implied warranty of
15 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 // GNU General Public License for more details.
18 // You should have received a copy of the GNU General Public License
19 // along with this program; if not, write to the
20 // Free Software Foundation, Inc.,
21 // 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
24 \brief INet6Address non-inline template implementation */
26 #include "INet6Address.ih"
31 ///////////////////////////////ct.p////////////////////////////////////////
33 ///////////////////////////////////////////////////////////////////////////
36 template <class InputIterator>
37 prefix_ senf::INet6Address senf::INet6Address::from_data(InputIterator i)
39 INet6Address addr (senf::noinit);
40 iterator j (addr.begin());
41 iterator const j_end (addr.end());
42 for (;j!=j_end;++j,++i)
47 ///////////////////////////////////////////////////////////////////////////
48 // namespace senf::detail members
50 template <class ForwardIterator, class Function>
51 prefix_ void senf::detail::apply_mask(unsigned bits, ForwardIterator b, ForwardIterator e,
54 for(; bits>8 && b != e; bits -= 8, ++b)
55 fn(*b, boost::lambda::make_const(0xFFu));
56 if (bits > 0 && b != e)
57 fn( *(b++), boost::lambda::make_const(~ low_bits_mask(8-bits)));
59 fn(*b, boost::lambda::make_const(0u));
62 template <class ForwardIterator1, class ForwardIterator2, class Function>
63 prefix_ ForwardIterator1 senf::detail::find_if_mask(unsigned bits, ForwardIterator1 b1,
64 ForwardIterator1 e1, ForwardIterator2 b2,
67 for(; bits>8 && b1 != e1; bits -= 8, ++b1, ++b2)
68 if (fn(*b1, *b2, boost::lambda::make_const(0xFFu)))
70 if (bits > 0 && b1 != e1)
71 if (fn(*b1, *b2, boost::lambda::make_const(~ low_bits_mask(8-bits))))
73 for(++b1, ++b2; b1 != e1; ++b1, ++b2)
74 if (fn(*b1, *b2, boost::lambda::make_const(0u)))
79 ///////////////////////////////ct.e////////////////////////////////////////
87 // c-file-style: "senf"
88 // indent-tabs-mode: nil
89 // ispell-local-dictionary: "american"
90 // compile-command: "scons -u test"