emailservices/nmclientapi/src/nmapienvelopelisting.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Fri, 16 Apr 2010 14:51:52 +0300
changeset 18 578830873419
child 20 ecc8def7944a
permissions -rw-r--r--
Revision: 201011 Kit: 201015

/*
 * Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
 * All rights reserved.
 * This component and the accompanying materials are made available
 * under the terms of "Eclipse Public License v1.0"
 * which accompanies this distribution, and is available
 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
 *
 * Initial Contributors:
 * Nokia Corporation - initial contribution.
 *
 * Contributors:
 *
 * Description:
 *
 */

#include "nmapienvelopelisting_p.h"
#include "nmapienvelopelisting.h"
#include "nmapiengine.h"

namespace EmailClientApi
{
/*!
 * Constructor of class. It set start values.
 */
NmEnvelopeListing::NmEnvelopeListing(
    QObject *parent,
    const quint64 folderId,
    const quint64 mailboxId) :
    NmMessageTask(parent)
{
    mListingPrivate = new NmEnvelopeListingPrivate(this);
    mListingPrivate->mailboxId = mailboxId;
    mListingPrivate->folderId = folderId;
    mListingPrivate->mIsRunning = false;
}

/*!
 * Destructor of class. It release engine to be safe if manual releasing won't work.
 */
NmEnvelopeListing::~NmEnvelopeListing()
{
    if (mListingPrivate->mIsRunning) {
        mListingPrivate->releaseEngine();
    }
}

/*!
 * \brief Starts gathering envelopes list.
 * 
 * In first turn it will get whole folderlist. 
 * If start works, it do nothing.
 * 
 * To asynchronous operation ce be used \sa QTimer::singleShot on this method.
 * Example:
 * <code> 
 * QTimer::singleShot(0,nmEnvelopeListing,SLOT(start());
 * </code>
 * 
 */
bool NmEnvelopeListing::start()
{
    bool result = false;

    if (mListingPrivate->mIsRunning) {
        result = true;
    }
    else {

        bool started = mListingPrivate->initializeEngine();
        if (!started) {
            QMetaObject::invokeMethod(this, "envelopesListed", Qt::QueuedConnection, Q_ARG(qint32,
                (qint32) EnvelopeListingFailed));
            result = false;
        }
        else {
            qint32 envelopesCount = mListingPrivate->grabEnvelopes();

            mListingPrivate->mIsRunning = true;
            QMetaObject::invokeMethod(this, "envelopesListed", Qt::QueuedConnection, Q_ARG(qint32,
                envelopesCount));
            result = true;
        }
    }
    return result;
}

/*!
 * \brief Stop gathering envelope list.
 * 
 * In first it change state of listing.
 * Then it release engine.
 * On end it clears list of envelopes and emits \sa NmMessageTask::canceled() signal.
 */
void NmEnvelopeListing::cancel()
{
    if (mListingPrivate->mIsRunning) {
        mListingPrivate->mIsRunning = false;
        mListingPrivate->releaseEngine();
        mListingPrivate->mEnvelopes.clear();

        emit canceled();
    }
}

/*! 
 * \brief Returns results after envelopesListed signal is received.
 * 
 *  Caller gets ownership of envelopes. Returns true if results were available.
 *  It clears list of envelopes after be called.
 *  It also at start clear inputlist of NmMessageEnvelope.
 */
bool NmEnvelopeListing::envelopes(QList<EmailClientApi::NmMessageEnvelope> &envelopes)
{
    envelopes.clear();

    bool result = false;

    if (!mListingPrivate->mIsRunning) {
        result = false;
    }
    else {
        envelopes = mListingPrivate->mEnvelopes;
        mListingPrivate->mEnvelopes.clear();
        result = true;
    }
    return result;
}

/*!
 * \brief Return info if listing is running
 */
bool NmEnvelopeListing::isRunning() const
{
    return mListingPrivate->mIsRunning;
}
}

#include "moc_nmapienvelopelisting.cpp"