javamanager/javacaptain/src/tickerproviderinterface.h
author Pat Downey <patd@symbian.org>
Wed, 01 Sep 2010 12:33:18 +0100
branchRCL_3
changeset 26 2455ef1f5bbc
parent 24 6c158198356e
permissions -rw-r--r--
Revert incorrect RCL_3 drop: Revision: v2.2.11 Kit: 201035

/*
* Copyright (c) 2008 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:  TickerProviderInterface
*
*/

#ifndef TICKERPROVIDERINTERFACE_H
#define TICKERPROVIDERINTERFACE_H

#include <time.h>
#include <sys/time.h>

namespace java
{
namespace captain
{

class TickerProviderEventsInterface
{
public:
    virtual void tick() = 0;
};

class TickerProviderInterface
{
    TickerProviderInterface(); // Cannot be used
public:
    TickerProviderInterface(TickerProviderEventsInterface* aEvents)
            :mEvents(aEvents)
    {}
    virtual ~TickerProviderInterface()
    {}

    /**
    * Starts the ticker.
    * @param[in] aPeriod - delay in seconds
    * @return -
    */
    virtual void nextTickAt(const long long& aJavaTime) = 0;
    /**
    * Returns current tick time if set.
    * @param[in]
    * @return - 0 if not set otherwise the set time
    */
    virtual long long getNextTickAt() = 0;
    /**
    * Stops the ticker.
    * @param -
    * @return -
    */
    virtual void cancel() = 0;

    // Helpers
    /**
    * Returns milliseconds from EPOCH.
    * This can be overridden with the platform specific implementation. Use case for
    * overriding is that in some platforms gettimeofday implementation can't handle
    * correctly times after 2038.
    * @param[in]  -
    * @return - milliseconds from EPOCH in success, -1 if fails
    */
    virtual long long getPlatformCurrentJavaTime()
    {
        return -1LL;
    }

    /**
    * Returns milliseconds from EPOCH.
    * @param[in]  -
    * @return - milliseconds from EPOCH in success, -1 if fails
    */
    virtual long long getCurrentJavaTime()
    {
        timeval tim;
        int err = gettimeofday(&tim, NULL);
        if (-1 == err)
        {
            WLOG(EJavaCaptain, "getCurrentJavaTime: gettimeofday returned -1");
            return getPlatformCurrentJavaTime();
        }

        return (tim.tv_sec * 1000LL) +
               (tim.tv_usec / 1000LL);
    }

protected:
    TickerProviderEventsInterface*  mEvents;
};

} // namespace captain
} // namespace java

#endif // TICKERPROVIDERINTERFACE_H