Menu

Defragmenter.h

Go to the documentation of this file.
00001 /*******************************************************************************
00002  *
00003  * Copyright (c) 2009-2010 Philipp Werner <philipp.werner@st.ovgu.de>
00004  * All rights reserved.
00005  *
00006  *    Redistribution and use in source and binary forms, with or without
00007  *    modification, are permitted provided that the following conditions
00008  *    are met:
00009  *
00010  *    * Redistributions of source code must retain the above copyright
00011  *      notice, this list of conditions and the following disclaimer.
00012  *
00013  *    * Redistributions in binary form must reproduce the above copyright
00014  *      notice, this list of conditions and the following disclaimer in
00015  *      the documentation and/or other materials provided with the
00016  *      distribution.
00017  *
00018  *    * Neither the name of the copyright holders nor the names of
00019  *      contributors may be used to endorse or promote products derived
00020  *      from this software without specific prior written permission.
00021  *
00022  *
00023  *    THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
00024  *    IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
00025  *    TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
00026  *    PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
00027  *    OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
00028  *    SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
00029  *    LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
00030  *    DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
00031  *    THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
00032  *    (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
00033  *    OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00034  *
00035  *
00036  * $Id$
00037  *
00038  ******************************************************************************/
00039 
00040 
00041 #ifndef __DEFRAGMENTER_H_B2FF50B5F3CB6D__
00042 #define __DEFRAGMENTER_H_B2FF50B5F3CB6D__
00043 
00044 
00045 #include "debug.h"
00046 
00047 
00048 namespace famouso {
00049     namespace mw {
00050         namespace afp {
00051             namespace defrag {
00052 
00053 
00054                 template <class DCP> class Headers;
00055 
00056 
00062                 template <class DCP>
00063                 class Defragmenter {
00064 
00065                         typedef typename DCP::SizeProp::elen_t elen_t;
00066                         typedef typename DCP::SizeProp::flen_t flen_t;
00067                         typedef typename DCP::SizeProp::fcount_t fcount_t;
00068 
00069                         typedef class DCP::EventDataReconstructionPolicy EventDataReconstructionPolicy;
00070                         typedef class DCP::DuplicateCheckingPolicy DuplicateCheckingPolicy;
00071 
00072                         typedef class DCP::DefragStatistics Statistics;
00073 
00074                     private:
00075 
00077                         EventDataReconstructionPolicy event_reconst;
00078 
00080                         DuplicateCheckingPolicy dup_check;
00081 
00082                     public:
00083 
00088                         Defragmenter(flen_t max_chunk_length)
00089                                 : event_reconst(max_chunk_length) {
00090                         }
00091 
00100                         void put_fragment(const Headers<DCP> & header, const uint8_t * data, flen_t length) {
00101                             // Is this fragment a duplicate?
00102                             if (!dup_check.new_fragment(header)) {
00103                                 Statistics::fragment_duplicate();
00104                                 ::logging::log::emit< ::logging::Info>()
00105                                     << PROGMEMSTRING("AFP: Dropped duplicate fragment")
00106                                     << ::logging::log::endl;
00107                                 return;
00108                             }
00109 
00110                             event_reconst.put_fragment(header, data, length);
00111                         }
00112 
00116                         bool is_event_complete() {
00117                             return event_reconst.is_complete();
00118                         }
00119 
00124                         uint8_t * get_event_data() {
00125                             return event_reconst.get_data();
00126                         }
00127 
00132                         elen_t get_event_length() {
00133                             return event_reconst.get_length();
00134                         }
00135 
00139                         bool error() {
00140                             return event_reconst.error();
00141                         }
00142                 };
00143 
00144 
00145             } // namespace defrag
00146         } // namespace afp
00147     } // namespace mw
00148 } // namespace famouso
00149 
00150 
00151 #endif // __DEFRAGMENTER_H_B2FF50B5F3CB6D__
00152