Commit 26921e30 authored by Francois Cartegnie's avatar Francois Cartegnie

stream_filter: dash: don't use global ref to log through libvlc

This reverts commit d073d3be.
parent 4bcf8bd7
...@@ -90,8 +90,6 @@ libdash_plugin_la_SOURCES = \ ...@@ -90,8 +90,6 @@ libdash_plugin_la_SOURCES = \
stream_filter/dash/DASHDownloader.h \ stream_filter/dash/DASHDownloader.h \
stream_filter/dash/DASHManager.cpp \ stream_filter/dash/DASHManager.cpp \
stream_filter/dash/DASHManager.h \ stream_filter/dash/DASHManager.h \
stream_filter/dash/Logger.cpp \
stream_filter/dash/Logger.h \
stream_filter/dash/Helper.cpp \ stream_filter/dash/Helper.cpp \
stream_filter/dash/Helper.h stream_filter/dash/Helper.h
libdash_plugin_la_CXXFLAGS = $(AM_CFLAGS) -I$(srcdir)/stream_filter/dash libdash_plugin_la_CXXFLAGS = $(AM_CFLAGS) -I$(srcdir)/stream_filter/dash
......
/*
* Logger.cpp
*****************************************************************************
* Copyright (C) 2014 - VideoLAN authors
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as published
* by the Free Software Foundation; either version 2.1 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program; if not, write to the Free Software Foundation,
* Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
*****************************************************************************/
#include "Logger.h"
#include <iostream>
using namespace dash;
vlc_object_t * Logger::p_object = NULL;
void Logger::Debug( const std::string &msg )
{
if ( Logger::p_object )
msg_Dbg( Logger::p_object, "%s", msg.c_str() );
else
std::cout << msg << std::endl;
}
void Logger::Error( const std::string &msg )
{
if ( Logger::p_object )
msg_Err( Logger::p_object, "%s", msg.c_str() );
else
std::cerr << msg << std::endl;
}
/*
* Logger.h
*****************************************************************************
* Copyright (C) 2014 - VideoLAN authors
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as published
* by the Free Software Foundation; either version 2.1 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program; if not, write to the Free Software Foundation,
* Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
*****************************************************************************/
#ifndef LOGGER_H
#define LOGGER_H
#ifdef HAVE_CONFIG_H
# include "config.h"
#endif
#include <vlc_common.h>
#include <string>
namespace dash {
class Logger
{
public:
static void Error( const std::string &msg );
static void Debug( const std::string &msg );
static void setObject( vlc_object_t *p_obj ) { Logger::p_object = p_obj; }
private:
static vlc_object_t *p_object;
};
}
#endif // LOGGER_H
...@@ -43,7 +43,6 @@ ...@@ -43,7 +43,6 @@
#include "http/HTTPConnectionManager.h" #include "http/HTTPConnectionManager.h"
#include "adaptationlogic/IAdaptationLogic.h" #include "adaptationlogic/IAdaptationLogic.h"
#include "mpd/MPDFactory.h" #include "mpd/MPDFactory.h"
#include "Logger.h"
#define SEEK 0 #define SEEK 0
...@@ -95,7 +94,6 @@ static int Control (stream_t *p_stream, int i_query, va_list args); ...@@ -95,7 +94,6 @@ static int Control (stream_t *p_stream, int i_query, va_list args);
static int Open(vlc_object_t *p_obj) static int Open(vlc_object_t *p_obj)
{ {
stream_t *p_stream = (stream_t*) p_obj; stream_t *p_stream = (stream_t*) p_obj;
dash::Logger::setObject(p_obj);
if(!dash::xml::DOMParser::isDash(p_stream->p_source)) if(!dash::xml::DOMParser::isDash(p_stream->p_source))
return VLC_EGENERIC; return VLC_EGENERIC;
......
...@@ -30,7 +30,6 @@ ...@@ -30,7 +30,6 @@
#include "mpd/SegmentInfoDefault.h" #include "mpd/SegmentInfoDefault.h"
#include "mpd/SegmentTemplate.h" #include "mpd/SegmentTemplate.h"
#include "mpd/SegmentTimeline.h" #include "mpd/SegmentTimeline.h"
#include "Logger.h"
#include <cstdlib> #include <cstdlib>
#include <sstream> #include <sstream>
...@@ -84,7 +83,7 @@ bool BasicCMParser::setMPD() ...@@ -84,7 +83,7 @@ bool BasicCMParser::setMPD()
it = attr.find( "availabilityStartTime" ); it = attr.find( "availabilityStartTime" );
if ( it == attr.end() && this->mpd->isLive() == true ) if ( it == attr.end() && this->mpd->isLive() == true )
{ {
Logger::Error( "An @availabilityStartTime attribute must be specified when" msg_Err( p_stream, "An @availabilityStartTime attribute must be specified when"
" the stream @type is Live" ); " the stream @type is Live" );
return false; return false;
} }
...@@ -97,8 +96,8 @@ bool BasicCMParser::setMPD() ...@@ -97,8 +96,8 @@ bool BasicCMParser::setMPD()
{ {
if ( this->mpd->isLive() == true ) if ( this->mpd->isLive() == true )
{ {
Logger::Error("An @availabilityStartTime attribute must be specified when" msg_Err( p_stream, "An @availabilityStartTime attribute must be specified when"
" the stream @type is Live"); " the stream @type is Live" );
return false; return false;
} }
} }
...@@ -179,7 +178,7 @@ void BasicCMParser::parseSegmentTimeline(Node *node, SegmentInfoCommon *segmentI ...@@ -179,7 +178,7 @@ void BasicCMParser::parseSegmentTimeline(Node *node, SegmentInfoCommon *segmentI
sIt = sAttr.find( "t" ); sIt = sAttr.find( "t" );
if ( sIt == sAttr.end() ) if ( sIt == sAttr.end() )
{ {
Logger::Error("'t' attribute is mandatory for every SegmentTimeline/S element"); msg_Err( p_stream, "'t' attribute is mandatory for every SegmentTimeline/S element" );
delete s; delete s;
++it; ++it;
continue ; continue ;
...@@ -188,7 +187,7 @@ void BasicCMParser::parseSegmentTimeline(Node *node, SegmentInfoCommon *segmentI ...@@ -188,7 +187,7 @@ void BasicCMParser::parseSegmentTimeline(Node *node, SegmentInfoCommon *segmentI
sIt = sAttr.find( "d" ); sIt = sAttr.find( "d" );
if ( sIt == sAttr.end() ) if ( sIt == sAttr.end() )
{ {
Logger::Error("'d' attribute is mandatory for every SegmentTimeline/S element"); msg_Err( p_stream, "'d' attribute is mandatory for every SegmentTimeline/S element" );
delete s; delete s;
++it; ++it;
continue ; continue ;
...@@ -275,7 +274,7 @@ void BasicCMParser::parseTrickMode(Node *node, Representation *repr) ...@@ -275,7 +274,7 @@ void BasicCMParser::parseTrickMode(Node *node, Representation *repr)
if ( trickModes.size() == 0 ) if ( trickModes.size() == 0 )
return ; return ;
if ( trickModes.size() > 1 ) if ( trickModes.size() > 1 )
Logger::Error("More than 1 TrickMode element. Only the first one will be used."); msg_Err( p_stream, "More than 1 TrickMode element. Only the first one will be used." );
Node* trickModeNode = trickModes[0]; Node* trickModeNode = trickModes[0];
TrickModeType *trickMode = new TrickModeType; TrickModeType *trickMode = new TrickModeType;
...@@ -307,14 +306,14 @@ void BasicCMParser::setRepresentations (Node *root, AdaptationSet *group) ...@@ -307,14 +306,14 @@ void BasicCMParser::setRepresentations (Node *root, AdaptationSet *group)
it = attributes.find( "id" ); it = attributes.find( "id" );
if ( it == attributes.end() ) if ( it == attributes.end() )
Logger::Error("Missing mandatory attribute for Representation: @id"); msg_Err( p_stream, "Missing mandatory attribute for Representation: @id" );
else else
rep->setId( it->second ); rep->setId( it->second );
it = attributes.find( "bandwidth" ); it = attributes.find( "bandwidth" );
if ( it == attributes.end() ) if ( it == attributes.end() )
{ {
Logger::Error("Missing mandatory attribute for Representation: @bandwidth"); msg_Err( p_stream, "Missing mandatory attribute for Representation: @bandwidth" );
delete rep; delete rep;
continue ; continue ;
} }
...@@ -369,7 +368,7 @@ bool BasicCMParser::setSegmentInfo (Node *root, Representation *rep) ...@@ -369,7 +368,7 @@ bool BasicCMParser::setSegmentInfo (Node *root, Representation *rep)
rep->setSegmentInfo( info ); rep->setSegmentInfo( info );
return true; return true;
} }
Logger::Error("Missing mandatory element: Representation/SegmentInfo"); msg_Err( p_stream, "Missing mandatory element: Representation/SegmentInfo" );
return false; return false;
} }
...@@ -394,7 +393,7 @@ Segment* BasicCMParser::parseSegment( Node* node ) ...@@ -394,7 +393,7 @@ Segment* BasicCMParser::parseSegment( Node* node )
{ {
if ( this->resolveUrlTemplates( url, runtimeToken ) == false ) if ( this->resolveUrlTemplates( url, runtimeToken ) == false )
{ {
Logger::Error("Failed to substitute URLTemplate identifier."); msg_Err( p_stream, "Failed to substitute URLTemplate identifier." );
return NULL; return NULL;
} }
seg = new SegmentTemplate( runtimeToken, this->currentRepresentation ); seg = new SegmentTemplate( runtimeToken, this->currentRepresentation );
...@@ -436,8 +435,8 @@ void BasicCMParser::setInitSegment (Node *root, SegmentInfoCommon *info ...@@ -436,8 +435,8 @@ void BasicCMParser::setInitSegment (Node *root, SegmentInfoCommon *info
const std::vector<Node *> initSeg = DOMHelper::getChildElementByTagName(root, "InitialisationSegmentURL"); const std::vector<Node *> initSeg = DOMHelper::getChildElementByTagName(root, "InitialisationSegmentURL");
if ( initSeg.size() > 1 ) if ( initSeg.size() > 1 )
Logger::Error("There could be at most one InitialisationSegmentURL per SegmentInfo" msg_Err( p_stream, "There could be at most one InitialisationSegmentURL per SegmentInfo"
" other InitialisationSegmentURL will be dropped."); " other InitialisationSegmentURL will be dropped." );
if ( initSeg.size() == 1 ) if ( initSeg.size() == 1 )
{ {
Segment *seg = parseSegment( initSeg.at(0) ); Segment *seg = parseSegment( initSeg.at(0) );
...@@ -475,7 +474,7 @@ bool BasicCMParser::resolveUrlTemplates( std::string &url, bool &containRunti ...@@ -475,7 +474,7 @@ bool BasicCMParser::resolveUrlTemplates( std::string &url, bool &containRunti
size_t closing = url.find( '$', it + 1 ); size_t closing = url.find( '$', it + 1 );
if ( closing == std::string::npos ) if ( closing == std::string::npos )
{ {
Logger::Error(std::string("Unmatched '$' in url template: ").append(url)); msg_Err( p_stream, "Unmatched '$' in url template: %s", url.c_str() );
return false; return false;
} }
std::string token = std::string( url, it, closing - it + 1 ); std::string token = std::string( url, it, closing - it + 1 );
...@@ -488,8 +487,8 @@ bool BasicCMParser::resolveUrlTemplates( std::string &url, bool &containRunti ...@@ -488,8 +487,8 @@ bool BasicCMParser::resolveUrlTemplates( std::string &url, bool &containRunti
{ {
if ( this->currentRepresentation->getId().empty() == false ) if ( this->currentRepresentation->getId().empty() == false )
{ {
Logger::Error("Representation doesn't have an ID. Can't substitute" msg_Err( p_stream, "Representation doesn't have an ID. Can't substitute"
" identifier $RepresentationID$"); " identifier $RepresentationID$" );
return false; return false;
} }
url.replace( it, token.length(), this->currentRepresentation->getId() ); url.replace( it, token.length(), this->currentRepresentation->getId() );
...@@ -511,7 +510,7 @@ bool BasicCMParser::resolveUrlTemplates( std::string &url, bool &containRunti ...@@ -511,7 +510,7 @@ bool BasicCMParser::resolveUrlTemplates( std::string &url, bool &containRunti
} }
else else
{ {
Logger::Error(std::string("Unhandled token ").append(token)); msg_Err( p_stream, "Unhandled token %s", token.c_str() );
return false; return false;
} }
} }
...@@ -564,7 +563,7 @@ bool BasicCMParser::parseCommonAttributesElements( Node *node, CommonAttribut ...@@ -564,7 +563,7 @@ bool BasicCMParser::parseCommonAttributesElements( Node *node, CommonAttribut
common->setMimeType( parent->getMimeType() ); common->setMimeType( parent->getMimeType() );
else if ( node->getName().find( "Representation" ) != std::string::npos ) else if ( node->getName().find( "Representation" ) != std::string::npos )
{ {
Logger::Error("Missing mandatory attribute: @mimeType"); msg_Err( p_stream, "Missing mandatory attribute: @mimeType" );
return false; return false;
} }
} }
......
...@@ -29,7 +29,6 @@ ...@@ -29,7 +29,6 @@
#include "Representation.h" #include "Representation.h"
#include "AdaptationSet.h" #include "AdaptationSet.h"
#include "SegmentInfoDefault.h" #include "SegmentInfoDefault.h"
#include "Logger.h"
#include <cassert> #include <cassert>
#include <cstring> #include <cstring>
...@@ -55,8 +54,8 @@ std::string SegmentTemplate::getSourceUrl() const ...@@ -55,8 +54,8 @@ std::string SegmentTemplate::getSourceUrl() const
if ( this->containRuntimeIdentifier == false ) if ( this->containRuntimeIdentifier == false )
return Segment::getSourceUrl(); return Segment::getSourceUrl();
if ( this->beginIndex != std::string::npos ) // if ( this->beginIndex != std::string::npos )
Logger::Error("Unhandled identifier \"$Index$\""); // std::cerr << "Unhandled identifier \"$Index$\"" << std::endl;
if ( this->beginTime != std::string::npos ) if ( this->beginTime != std::string::npos )
{ {
//FIXME: This should use the current representation SegmentInfo //FIXME: This should use the current representation SegmentInfo
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment