mirror of
https://github.com/tomahawk-player/tomahawk.git
synced 2025-08-06 14:16:32 +02:00
* JspfLoader now also uses our own NetworkReply to support HTTP redirects.
This commit is contained in:
@@ -19,19 +19,19 @@
|
|||||||
|
|
||||||
#include "JspfLoader.h"
|
#include "JspfLoader.h"
|
||||||
|
|
||||||
|
|
||||||
#include <QApplication>
|
#include <QApplication>
|
||||||
#include <QDomDocument>
|
#include <QDomDocument>
|
||||||
#include <QMessageBox>
|
#include <QMessageBox>
|
||||||
|
|
||||||
#include <qjson/parser.h>
|
#include <qjson/parser.h>
|
||||||
|
|
||||||
#include "utils/TomahawkUtils.h"
|
|
||||||
#include "utils/Logger.h"
|
|
||||||
|
|
||||||
#include "SourceList.h"
|
#include "SourceList.h"
|
||||||
#include "Playlist.h"
|
#include "Playlist.h"
|
||||||
|
|
||||||
|
#include "utils/NetworkReply.h"
|
||||||
|
#include "utils/TomahawkUtils.h"
|
||||||
|
#include "utils/Logger.h"
|
||||||
|
|
||||||
using namespace Tomahawk;
|
using namespace Tomahawk;
|
||||||
|
|
||||||
|
|
||||||
@@ -59,23 +59,19 @@ void
|
|||||||
JSPFLoader::load( const QUrl& url )
|
JSPFLoader::load( const QUrl& url )
|
||||||
{
|
{
|
||||||
QNetworkRequest request( url );
|
QNetworkRequest request( url );
|
||||||
|
|
||||||
Q_ASSERT( TomahawkUtils::nam() != 0 );
|
Q_ASSERT( TomahawkUtils::nam() != 0 );
|
||||||
QNetworkReply* reply = TomahawkUtils::nam()->get( request );
|
NetworkReply* reply = new NetworkReply( TomahawkUtils::nam()->get( request ) );
|
||||||
|
|
||||||
// isn't there a race condition here? something could happen before we connect()
|
connect( reply, SIGNAL( finished() ), SLOT( networkLoadFinished() ) );
|
||||||
// no---the event loop is needed to make the request, i think (leo)
|
connect( reply, SIGNAL( error( QNetworkReply::NetworkError ) ), SLOT( networkError( QNetworkReply::NetworkError ) ) );
|
||||||
connect( reply, SIGNAL( finished() ),
|
|
||||||
SLOT( networkLoadFinished() ) );
|
|
||||||
|
|
||||||
connect( reply, SIGNAL( error( QNetworkReply::NetworkError ) ),
|
|
||||||
SLOT( networkError( QNetworkReply::NetworkError ) ) );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
JSPFLoader::load( QFile& file )
|
JSPFLoader::load( QFile& file )
|
||||||
{
|
{
|
||||||
if( file.open( QFile::ReadOnly ) )
|
if ( file.open( QFile::ReadOnly ) )
|
||||||
{
|
{
|
||||||
m_body = file.readAll();
|
m_body = file.readAll();
|
||||||
gotBody();
|
gotBody();
|
||||||
@@ -101,17 +97,24 @@ JSPFLoader::reportError()
|
|||||||
void
|
void
|
||||||
JSPFLoader::networkLoadFinished()
|
JSPFLoader::networkLoadFinished()
|
||||||
{
|
{
|
||||||
QNetworkReply* reply = qobject_cast<QNetworkReply*>(sender());
|
NetworkReply* r = qobject_cast<NetworkReply*>( sender() );
|
||||||
m_body = reply->readAll();
|
if ( r->reply()->error() == QNetworkReply::NoError )
|
||||||
gotBody();
|
{
|
||||||
|
m_body = r->reply()->readAll();
|
||||||
|
gotBody();
|
||||||
|
}
|
||||||
|
|
||||||
|
r->deleteLater();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
JSPFLoader::networkError( QNetworkReply::NetworkError e )
|
JSPFLoader::networkError( QNetworkReply::NetworkError e )
|
||||||
{
|
{
|
||||||
tLog() << Q_FUNC_INFO << "Network error loading jspf" << e;
|
|
||||||
reportError();
|
reportError();
|
||||||
|
|
||||||
|
NetworkReply* r = qobject_cast<NetworkReply*>( sender() );
|
||||||
|
r->deleteLater();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -178,7 +181,7 @@ JSPFLoader::gotBody()
|
|||||||
continue;
|
continue;
|
||||||
|
|
||||||
q->setDuration( duration.toInt() / 1000 );
|
q->setDuration( duration.toInt() / 1000 );
|
||||||
if( !url.isEmpty() )
|
if ( !url.isEmpty() )
|
||||||
{
|
{
|
||||||
q->setResultHint( url );
|
q->setResultHint( url );
|
||||||
q->setSaveHTTPResultHint( true );
|
q->setSaveHTTPResultHint( true );
|
||||||
|
Reference in New Issue
Block a user