Utils: moved range.hh .cti into Range.hh .cti
[senf.git] / senf / Packets / DefaultBundle / IPv6ExtOptionType.ct
index 2b2d79a..ca43a48 100644 (file)
@@ -37,7 +37,8 @@ prefix_ void senf::IPv6GenericOptionTLVParser::value(ForwardReadableRange const
     
     if ( (rangeSize-2) != optionLength() )
         resize(optionLength()+2, rangeSize);
-    std::copy(boost::next(boost::begin(range), 2), boost::next(boost::end(range)), boost::next(i(), 2 + optionLength() ));
+    std::copy(boost::next(boost::begin(range), 2), boost::next(boost::end(range)), 
+            boost::next(i(), 2 + optionLength() ));
     unsigned int val = *(boost::begin(range));
     unsigned int mask = 192u;
     altAction() = (val & mask) >> 6;
@@ -58,32 +59,30 @@ prefix_ void senf::IPv6GenericOptionTLVParser::setPayload(ForwardReadableRange c
     optionLength() = rangeSize;
 }
 
+template <class Parser>
+prefix_ Parser senf::IPv6GenericOptionTLVParser::init()
+{  
+    size_type oldSize (bytes() );
+    size_type newParserSize ( senf::init_bytes<Parser>::value );
+    resize(  oldSize, newParserSize);
+    std::fill(i(),boost::next(i(), newParserSize), 0u);
+    Parser concreteParser = Parser(i(), state() );
+    concreteParser.init();
+    concreteParser.optionLength() = (newParserSize-2);
+    return concreteParser;
+}
 
 template <class Parser>
-prefix_ Parser& senf::IPv6GenericOptionTLVParser::init()
+prefix_ Parser senf::IPv6GenericOptionTLVParser::as()
 {
-    size_type oldSize ( bytes() );
-    resize( oldSize, senf::init_bytes<Parser>::value);
-    data_iterator j = i();
-    std::advance(j, senf::init_bytes<Parser>::value);
-    std::fill(i() , j, 0u);
-    Parser::init();
-    Parser::optionType() = Parser::typeCode;
-    return *(this);
+    return Parser(i(), state() );
 }
 
-// template <class Parser>
-// prefix_ Parser& senf::GenericOptTypeTLVParser::get()
-// {
-//     SENF_ASSERT (optionType() == typeCode);
-//     return *(this);
-// }
-
 
 ///////////////////////////////ct.e////////////////////////////////////////
 #undef prefix_
 
-
+\f
 // Local Variables:
 // mode: c++
 // fill-column: 100