7a403201c0235ba53212089c1a5531bd175fdbe8
[senf.git] / senf / Packets / Packet.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 Packet non-inline template implementation  */
30
31 //#include "Packet.ih"
32
33 // Custom includes
34
35 #define prefix_
36 //-/////////////////////////////////////////////////////////////////////////////////////////////////
37
38 //-/////////////////////////////////////////////////////////////////////////////////////////////////
39 // senf::Packet
40
41 template <class OtherPacket>
42 prefix_ OtherPacket senf::Packet::find(NoThrow_t)
43     const
44 {
45     Packet p (*this);
46     while (p && ! p.is<OtherPacket>())
47         p = p.next(nothrow);
48     if (p)
49         return p.as<OtherPacket>();
50     else
51         return OtherPacket();
52 }
53
54 template <class OtherPacket>
55 prefix_ OtherPacket senf::Packet::rfind(NoThrow_t)
56     const
57 {
58     Packet p (*this);
59     while (p && ! p.is<OtherPacket>())
60         p = p.prev(nothrow);
61     if (p)
62         return p.as<OtherPacket>();
63     else
64         return OtherPacket();
65 }
66
67 //-/////////////////////////////////////////////////////////////////////////////////////////////////
68 // senf::ConcretePacket<PacketType>
69
70 template <class PacketType>
71 template <class OtherPacket>
72 prefix_ OtherPacket senf::ConcretePacket<PacketType>::next(NoThrow_t)
73     const
74 {
75     PacketInterpreterBase::ptr p (Packet::ptr()->next());
76     if (p)
77         return (p->typeId() == typeIdValue<OtherPacket>()) ?
78                 OtherPacket(p->as<typename OtherPacket::type>()) : OtherPacket();
79     PacketInterpreterBase::optional_range r (type::nextPacketRange(*this));
80     if (r && ! r->empty()) {
81         PacketInterpreterBase::ptr nxt (getNext(r));
82         if (nxt && nxt->typeId() == typeIdValue<OtherPacket>())
83             return OtherPacket(nxt->as<typename OtherPacket::type>());
84     }
85     return OtherPacket();
86 }
87
88 //-/////////////////////////////////////////////////////////////////////////////////////////////////
89 #undef prefix_
90
91 \f
92 // Local Variables:
93 // mode: c++
94 // fill-column: 100
95 // c-file-style: "senf"
96 // indent-tabs-mode: nil
97 // ispell-local-dictionary: "american"
98 // compile-command: "scons -u test"
99 // comment-column: 40
100 // End: