1 /*****************************************************************************
3 *****************************************************************************
4 * Copyright © 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 Lesser 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 *****************************************************************************/
28 #include "DASHManager.h"
31 using namespace dash::http;
32 using namespace dash::xml;
33 using namespace dash::logic;
34 using namespace dash::mpd;
35 using namespace dash::exception;
37 DASHManager::DASHManager (HTTPConnectionManager *conManager, Node *node, IAdaptationLogic::LogicType type, Profile profile)
39 this->conManager = conManager;
41 this->logicType = type;
42 this->profile = profile;
43 this->mpdManager = mpd::MPDManagerFactory::create(this->profile, this->node);
44 this->adaptationLogic = AdaptationLogicFactory::create( this->logicType, this->mpdManager );
45 this->currentChunk = NULL;
47 this->conManager->attach(this->adaptationLogic);
49 DASHManager::~DASHManager ()
51 delete this->adaptationLogic;
52 delete this->mpdManager;
55 int DASHManager::read (void *p_buffer, size_t len)
57 if(this->currentChunk == NULL)
61 this->currentChunk = this->adaptationLogic->getNextChunk();
63 catch(EOFException &e)
65 this->currentChunk = NULL;
70 int ret = this->conManager->read(this->currentChunk, p_buffer, len);
74 this->currentChunk = NULL;
75 return this->read(p_buffer, len);
80 int DASHManager::peek (const uint8_t **pp_peek, size_t i_peek)
82 if(this->currentChunk == NULL)
86 this->currentChunk = this->adaptationLogic->getNextChunk();
88 catch(EOFException &e)
94 int ret = this->conManager->peek(this->currentChunk, pp_peek, i_peek);
98 const mpd::IMPDManager* DASHManager::getMpdManager() const
100 return this->mpdManager;