switch to new MPL based Fraunhofer FOKUS Public License
[senf.git] / senf / Socket / Protocols / INet / INet6Address.ct
1 // $Id$
2 //
3 // Copyright (C) 2007
4 // Fraunhofer Institute for Open Communication Systems (FOKUS)
5 //
6 // The contents of this file are subject to the Fraunhofer FOKUS Public License
7 // Version 1.0 (the "License"); you may not use this file except in compliance
8 // with the License. You may obtain a copy of the License at 
9 // http://senf.berlios.de/license.html
10 //
11 // The Fraunhofer FOKUS Public License Version 1.0 is based on, 
12 // but modifies the Mozilla Public License Version 1.1.
13 // See the full license text for the amendments.
14 //
15 // Software distributed under the License is distributed on an "AS IS" basis, 
16 // WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License 
17 // for the specific language governing rights and limitations under the License.
18 //
19 // The Original Code is Fraunhofer FOKUS code.
20 //
21 // The Initial Developer of the Original Code is Fraunhofer-Gesellschaft e.V. 
22 // (registered association), Hansastraße 27 c, 80686 Munich, Germany.
23 // All Rights Reserved.
24 //
25 // Contributor(s):
26 //   Stefan Bund <g0dil@berlios.de>
27
28 /** \file
29     \brief INet6Address non-inline template implementation  */
30
31 #include "INet6Address.ih"
32
33 // Custom includes
34
35 #define prefix_
36 //-/////////////////////////////////////////////////////////////////////////////////////////////////
37
38 //-/////////////////////////////////////////////////////////////////////////////////////////////////
39 // senf::INet6Address
40
41 template <class InputIterator>
42 prefix_ senf::INet6Address senf::INet6Address::from_data(InputIterator i)
43 {
44     INet6Address addr (senf::noinit);
45     iterator j (addr.begin());
46     iterator const j_end (addr.end());
47     for (;j!=j_end;++j,++i)
48         *j = *i;
49     return addr;
50 }
51
52 //-/////////////////////////////////////////////////////////////////////////////////////////////////
53 // namespace senf::detail members
54
55 template <class ForwardIterator, class Function>
56 prefix_ void senf::detail::apply_mask(unsigned bits, ForwardIterator b, ForwardIterator e,
57                                       Function fn)
58 {
59     for (; bits>8 && b != e; bits -= 8, ++b)
60         fn(*b, boost::lambda::make_const(0xFFu));
61     if (bits > 0 && b != e)
62         fn( *(b++), boost::lambda::make_const(~ low_bits_mask(8-bits)));
63     for (; b != e; ++b)
64         fn(*b, boost::lambda::make_const(0u));
65 }
66
67 template <class ForwardIterator1, class ForwardIterator2, class Function>
68 prefix_ ForwardIterator1 senf::detail::find_if_mask(unsigned bits, ForwardIterator1 b1,
69                                                     ForwardIterator1 e1, ForwardIterator2 b2,
70                                                     Function fn)
71 {
72     for (; bits>8 && b1 != e1; bits -= 8, ++b1, ++b2)
73         if (fn(*b1, *b2, boost::lambda::make_const(0xFFu)))
74             return b1;
75     if (bits > 0 && b1 != e1)
76         if (fn(*b1, *b2, boost::lambda::make_const(~ low_bits_mask(8-bits))))
77             return b1;
78     for (++b1, ++b2; b1 != e1; ++b1, ++b2)
79         if (fn(*b1, *b2, boost::lambda::make_const(0u)))
80             return b1;
81     return e1;
82 }
83
84 //-/////////////////////////////////////////////////////////////////////////////////////////////////
85 #undef prefix_
86
87 \f
88 // Local Variables:
89 // mode: c++
90 // fill-column: 100
91 // comment-column: 40
92 // c-file-style: "senf"
93 // indent-tabs-mode: nil
94 // ispell-local-dictionary: "american"
95 // compile-command: "scons -u test"
96 // End: