3 *****************************************************************************
4 * Copyright (C) 2010 - 2011 Klagenfurt University
6 * Created on: Aug 10, 2010
7 * Authors: Christopher Mueller <christopher.mueller@itec.uni-klu.ac.at>
8 * Christian Timmerer <christian.timmerer@itec.uni-klu.ac.at>
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU Lesser General Public License as published
12 * by the Free Software Foundation; either version 2.1 of the License, or
13 * (at your option) any later version.
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
20 * You should have received a copy of the GNU Lesser General Public License
21 * along with this program; if not, write to the Free Software
22 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
23 *****************************************************************************/
25 #ifndef BASICCMMANAGER_H_
26 #define BASICCMMANAGER_H_
33 #include "mpd/Period.h"
34 #include "mpd/Group.h"
35 #include "mpd/Representation.h"
36 #include "mpd/SegmentInfo.h"
37 #include "mpd/Segment.h"
38 #include "mpd/IMPDManager.h"
39 #include "exceptions/AttributeNotPresentException.h"
45 class BasicCMManager : public IMPDManager
48 BasicCMManager (MPD *mpd);
49 virtual ~BasicCMManager ();
51 const std::vector<Period *>& getPeriods() const;
52 Period* getFirstPeriod();
53 Period* getNextPeriod( Period *period );
54 Representation* getBestRepresentation( Period *period );
55 std::vector<Segment *> getSegments( Representation *rep );
56 Representation* getRepresentation( Period *period, long bitrate );
57 const MPD* getMPD() const;
65 #endif /* BASICCMMANAGER_H_ */