mirror of
https://github.com/tomahawk-player/tomahawk.git
synced 2025-08-06 22:26:32 +02:00
* Fixed TWK-856: XSPFLoader now follows HTTP redirects (by using our own NetworkReply).
This commit is contained in:
@@ -24,9 +24,6 @@
|
||||
|
||||
#include <QDomDocument>
|
||||
|
||||
#include "utils/TomahawkUtils.h"
|
||||
#include "utils/Logger.h"
|
||||
|
||||
#ifndef ENABLE_HEADLESS
|
||||
#include "jobview/JobStatusView.h"
|
||||
#include "jobview/JobStatusModel.h"
|
||||
@@ -38,6 +35,10 @@
|
||||
#include <XspfUpdater.h>
|
||||
#include <Pipeline.h>
|
||||
|
||||
#include "utils/NetworkReply.h"
|
||||
#include "utils/TomahawkUtils.h"
|
||||
#include "utils/Logger.h"
|
||||
|
||||
using namespace Tomahawk;
|
||||
|
||||
|
||||
@@ -99,17 +100,14 @@ XSPFLoader::title() const
|
||||
void
|
||||
XSPFLoader::load( const QUrl& url )
|
||||
{
|
||||
QNetworkRequest request( url );
|
||||
m_url = url;
|
||||
QNetworkRequest request( url );
|
||||
|
||||
Q_ASSERT( TomahawkUtils::nam() != 0 );
|
||||
QNetworkReply* reply = TomahawkUtils::nam()->get( request );
|
||||
NetworkReply* reply = new NetworkReply( TomahawkUtils::nam()->get( request ) );
|
||||
|
||||
connect( reply, SIGNAL( finished() ),
|
||||
SLOT( networkLoadFinished() ) );
|
||||
|
||||
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 ) ) );
|
||||
}
|
||||
|
||||
|
||||
@@ -146,19 +144,24 @@ XSPFLoader::reportError()
|
||||
void
|
||||
XSPFLoader::networkLoadFinished()
|
||||
{
|
||||
QNetworkReply* reply = qobject_cast<QNetworkReply*>(sender());
|
||||
if ( reply->error() != QNetworkReply::NoError )
|
||||
return;
|
||||
|
||||
m_body = reply->readAll();
|
||||
NetworkReply* r = qobject_cast<NetworkReply*>( sender() );
|
||||
if ( r->reply()->error() == QNetworkReply::NoError )
|
||||
{
|
||||
m_body = r->reply()->readAll();
|
||||
gotBody();
|
||||
}
|
||||
|
||||
r->deleteLater();
|
||||
}
|
||||
|
||||
|
||||
void
|
||||
XSPFLoader::networkError( QNetworkReply::NetworkError /* error */ )
|
||||
{
|
||||
reportError();
|
||||
|
||||
NetworkReply* r = qobject_cast<NetworkReply*>( sender() );
|
||||
r->deleteLater();
|
||||
}
|
||||
|
||||
|
||||
|
Reference in New Issue
Block a user