mirror of
https://github.com/tomahawk-player/tomahawk.git
synced 2025-08-05 13:47:26 +02:00
Let Phonon delete QNR_IODeviceStream but do all QIODevices still by ourselves
This commit is contained in:
@@ -664,6 +664,7 @@ AudioEngine::performLoadTrack( const Tomahawk::result_ptr& result, QSharedPointe
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
tDebug( LOGEXTRA ) << Q_FUNC_INFO << ( result.isNull() ? QString() : result->url() );
|
tDebug( LOGEXTRA ) << Q_FUNC_INFO << ( result.isNull() ? QString() : result->url() );
|
||||||
|
QSharedPointer< QIODevice > ioToKeep = io;
|
||||||
|
|
||||||
bool err = false;
|
bool err = false;
|
||||||
{
|
{
|
||||||
@@ -681,12 +682,23 @@ AudioEngine::performLoadTrack( const Tomahawk::result_ptr& result, QSharedPointe
|
|||||||
|
|
||||||
if ( !TomahawkUtils::isLocalResult( d->currentTrack->url() ) )
|
if ( !TomahawkUtils::isLocalResult( d->currentTrack->url() ) )
|
||||||
{
|
{
|
||||||
if ( QNetworkReply* qnr_io = qobject_cast< QNetworkReply* >( io.data() ) )
|
QSharedPointer<QNetworkReply> qnr = io.objectCast<QNetworkReply>();
|
||||||
d->mediaObject->setCurrentSource( new QNR_IODeviceStream( qnr_io, this ) );
|
if ( !qnr.isNull() )
|
||||||
|
{
|
||||||
|
d->mediaObject->setCurrentSource( new QNR_IODeviceStream( qnr, this ) );
|
||||||
|
// We keep track of the QNetworkReply in QNR_IODeviceStream
|
||||||
|
// and Phonon handles the deletion of the
|
||||||
|
// QNR_IODeviceStream object
|
||||||
|
ioToKeep.clear();
|
||||||
|
d->mediaObject->currentSource().setAutoDelete( true );
|
||||||
|
}
|
||||||
else
|
else
|
||||||
|
{
|
||||||
d->mediaObject->setCurrentSource( io.data() );
|
d->mediaObject->setCurrentSource( io.data() );
|
||||||
|
// We handle the deletion via tracking in d->input
|
||||||
d->mediaObject->currentSource().setAutoDelete( false );
|
d->mediaObject->currentSource().setAutoDelete( false );
|
||||||
}
|
}
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
@@ -722,7 +734,7 @@ AudioEngine::performLoadTrack( const Tomahawk::result_ptr& result, QSharedPointe
|
|||||||
d->input->close();
|
d->input->close();
|
||||||
d->input.clear();
|
d->input.clear();
|
||||||
}
|
}
|
||||||
d->input = io;
|
d->input = ioToKeep;
|
||||||
queueState( Playing );
|
queueState( Playing );
|
||||||
|
|
||||||
if ( TomahawkSettings::instance()->privateListeningMode() != TomahawkSettings::FullyPrivate )
|
if ( TomahawkSettings::instance()->privateListeningMode() != TomahawkSettings::FullyPrivate )
|
||||||
|
@@ -32,7 +32,7 @@ using namespace Tomahawk;
|
|||||||
// Feed Phonon in 1MiB blocks
|
// Feed Phonon in 1MiB blocks
|
||||||
#define BLOCK_SIZE 1048576
|
#define BLOCK_SIZE 1048576
|
||||||
|
|
||||||
QNR_IODeviceStream::QNR_IODeviceStream( QNetworkReply* reply, QObject* parent )
|
QNR_IODeviceStream::QNR_IODeviceStream( const QSharedPointer<QNetworkReply>& reply, QObject* parent )
|
||||||
: Phonon::AbstractMediaStream( parent )
|
: Phonon::AbstractMediaStream( parent )
|
||||||
, m_networkReply( reply )
|
, m_networkReply( reply )
|
||||||
, m_pos( 0 )
|
, m_pos( 0 )
|
||||||
@@ -63,7 +63,7 @@ QNR_IODeviceStream::QNR_IODeviceStream( QNetworkReply* reply, QObject* parent )
|
|||||||
}
|
}
|
||||||
// Just consume all data that is already available.
|
// Just consume all data that is already available.
|
||||||
m_data = m_networkReply->readAll();
|
m_data = m_networkReply->readAll();
|
||||||
connect( m_networkReply, SIGNAL( readyRead() ), SLOT( readyRead() ) );
|
connect( m_networkReply.data(), SIGNAL( readyRead() ), SLOT( readyRead() ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
m_timer->setInterval( 0 );
|
m_timer->setInterval( 0 );
|
||||||
|
@@ -27,8 +27,9 @@
|
|||||||
|
|
||||||
#include <phonon/abstractmediastream.h>
|
#include <phonon/abstractmediastream.h>
|
||||||
#include <QByteArray>
|
#include <QByteArray>
|
||||||
|
#include <QNetworkReply>
|
||||||
|
#include <QSharedPointer>
|
||||||
|
|
||||||
class QNetworkReply;
|
|
||||||
class QIODevice;
|
class QIODevice;
|
||||||
class QTimer;
|
class QTimer;
|
||||||
|
|
||||||
@@ -39,7 +40,7 @@ class DLLEXPORT QNR_IODeviceStream : public Phonon::AbstractMediaStream
|
|||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
public:
|
public:
|
||||||
explicit QNR_IODeviceStream( QNetworkReply* reply, QObject *parent = 0 );
|
explicit QNR_IODeviceStream( const QSharedPointer<QNetworkReply>& reply, QObject *parent = 0 );
|
||||||
~QNR_IODeviceStream();
|
~QNR_IODeviceStream();
|
||||||
|
|
||||||
virtual void enoughData();
|
virtual void enoughData();
|
||||||
@@ -53,7 +54,7 @@ private slots:
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
QByteArray m_data;
|
QByteArray m_data;
|
||||||
QNetworkReply *m_networkReply;
|
QSharedPointer<QNetworkReply> m_networkReply;
|
||||||
qint64 m_pos;
|
qint64 m_pos;
|
||||||
QTimer* m_timer;
|
QTimer* m_timer;
|
||||||
};
|
};
|
||||||
|
Reference in New Issue
Block a user