EMIPLIB

miprtppacketgrouper.h

Go to the documentation of this file.
00001 /*
00002     
00003   This file is a part of EMIPLIB, the EDM Media over IP Library.
00004   
00005   Copyright (C) 2006-2011  Hasselt University - Expertise Centre for
00006                       Digital Media (EDM) (http://www.edm.uhasselt.be)
00007 
00008   This library is free software; you can redistribute it and/or
00009   modify it under the terms of the GNU Lesser General Public
00010   License as published by the Free Software Foundation; either
00011   version 2.1 of the License, or (at your option) any later version.
00012 
00013   This library is distributed in the hope that it will be useful,
00014   but WITHOUT ANY WARRANTY; without even the implied warranty of
00015   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00016   Lesser General Public License for more details.
00017 
00018   You should have received a copy of the GNU Lesser General Public
00019   License along with this library; if not, write to the Free Software
00020   Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  
00021   USA
00022 
00023 */
00024 
00029 #ifndef MIPRTPPACKETGROUPER_H
00030 
00031 #define MIPRTPPACKETGROUPER_H
00032 
00033 #include "mipconfig.h"
00034 #include "miperrorbase.h"
00035 #include "miptypes.h"
00036 #include <vector>
00037 #include <list>
00038 
00039 namespace jrtplib
00040 {
00041         class RTPPacket;
00042 }
00043 
00056 class EMIPLIB_IMPORTEXPORT MIPRTPPacketGrouper : public MIPErrorBase
00057 {
00058 public:
00059         MIPRTPPacketGrouper();
00060         ~MIPRTPPacketGrouper();
00061 
00068         bool init(uint32_t ssrc, int bufSize = 128);
00069 
00071         void clear();
00072 
00079         bool processPacket(const jrtplib::RTPPacket *pPack, bool isFirstFramePart);
00080 
00089         void getNextQueuedPacket(std::vector<uint8_t *> &parts, std::vector<size_t> &partSizes, uint32_t &timestamp);
00090 private:
00091         //void printTable();
00092         void checkCompletePacket(int index, std::vector<uint8_t *> &parts, std::vector<size_t> &partSizes, uint32_t &packetTimestamp);
00093         void checkMaximumQueueLength();
00094 
00095         std::vector<uint32_t> m_extendedSequenceNumbers;
00096         std::vector<uint32_t> m_timestamps;
00097         std::vector<bool> m_skipFlags;
00098         std::vector<uint8_t *> m_packetParts;
00099         std::vector<size_t> m_partSizes;
00100         std::vector<bool> m_markers;
00101         std::vector<bool> m_firstPartMarkers;
00102         int m_startPosition;
00103         uint32_t m_ssrc;
00104 
00105         std::list<std::vector<uint8_t *> > m_partQueue;
00106         std::list<std::vector<size_t> > m_partSizeQueue;
00107         std::list<uint32_t> m_timestampQueue;
00108 };
00109 
00110 #endif // MIPRTPPACKETGROUPER_H