/*************************************************************************** * This file is part of libmygpo-qt * * Copyright (c) 2010 - 2013 Stefan Derkits * * Copyright (c) 2010 - 2011 Christian Wagner * * Copyright (c) 2010 - 2011 Felix Winter * * * * This library 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 library 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 library; if not, write to the Free Software * * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 * * USA * ***************************************************************************/ #include "EpisodeList_p.h" #include using namespace mygpo; EpisodeListPrivate::EpisodeListPrivate( EpisodeList* qq, QNetworkReply* reply ): m_reply( reply ), q( qq ), m_error( QNetworkReply::NoError ) { QObject::connect( m_reply, SIGNAL( finished() ), this, SLOT( parseData() ) ); QObject::connect( m_reply, SIGNAL( error( QNetworkReply::NetworkError ) ), this, SLOT( error( QNetworkReply::NetworkError ) ) ); } EpisodeListPrivate::~EpisodeListPrivate() { } QList EpisodeListPrivate::list() const { QList list; QVariantList varList = m_episodes.toList(); foreach( QVariant var, varList ) { list.append( var.value() ); } return list; } QVariant EpisodeListPrivate::episodes() const { return m_episodes; } bool EpisodeListPrivate::parse( const QVariant& data ) { if( !data.canConvert( QVariant::List ) ) return false; QVariantList varList = data.toList(); QVariantList episodeList; foreach( QVariant var, varList ) { QVariant v; v.setValue ( EpisodePtr( new Episode( var ) ) ); episodeList.append( v ); } m_episodes = QVariant( episodeList ); return true; } bool EpisodeListPrivate::parse( const QByteArray& data ) { QJson::Parser parser; bool ok; QVariant variant = parser.parse( data, &ok ); if( ok ) { ok = ( parse( variant ) ); } return ok; } void EpisodeListPrivate::parseData() { if( m_reply->error() == QNetworkReply::NoError ) { if( parse( m_reply->readAll() ) ) { emit q->finished(); } else { emit q->parseError(); } } m_reply->deleteLater(); } void EpisodeListPrivate::error( QNetworkReply::NetworkError error ) { this->m_error = error; emit q->requestError( error ); } EpisodeList::EpisodeList( QNetworkReply* reply, QObject* parent ) : QObject( parent ), d( new EpisodeListPrivate( this, reply ) ) { } QVariant EpisodeList::episodes() const { return d->episodes(); } QList< EpisodePtr > EpisodeList::list() const { return d->list(); } EpisodeList::~EpisodeList() { delete d; }