camerauis/cameraxui/cxengine/src/cxediskmonitorprivate.cpp
author hgs
Thu, 13 May 2010 21:30:19 +0300
changeset 28 3075d9b614e6
child 29 699651f2666f
permissions -rw-r--r--
201017_1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
28
3075d9b614e6 201017_1
hgs
parents:
diff changeset
     1
/*
3075d9b614e6 201017_1
hgs
parents:
diff changeset
     2
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
3075d9b614e6 201017_1
hgs
parents:
diff changeset
     3
* All rights reserved.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
3075d9b614e6 201017_1
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
3075d9b614e6 201017_1
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
3075d9b614e6 201017_1
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
3075d9b614e6 201017_1
hgs
parents:
diff changeset
     8
*
3075d9b614e6 201017_1
hgs
parents:
diff changeset
     9
* Initial Contributors:
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    11
*
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    12
* Contributors:
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    13
*
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    14
* Description:
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    15
*
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    16
*/
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    17
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    18
#include <QObject> // Compiler flags, keep first
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    19
#ifdef Q_OS_SYMBIAN
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    20
#include <coemain.h>
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    21
#endif // Q_OS_SYMBIAN
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    22
#include "cxutils.h"
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    23
#include "cxesysutil.h"
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    24
#include "cxesettings.h"
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    25
#include "cxediskmonitor.h"
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    26
#include "cxediskmonitorprivate.h"
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    27
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    28
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    29
namespace
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    30
{
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    31
    const int MONITORING_INTERVAL = 2*1000; // in milliseconds
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    32
    const int UNKNOWN = -1;
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    33
}
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    34
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    35
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    36
/*!
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    37
* Constructor.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    38
*/
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    39
CxeDiskMonitorPrivate::CxeDiskMonitorPrivate(CxeSettings &settings)
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    40
    : mSettings(settings),
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    41
      mTimer(),
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    42
#ifdef Q_OS_SYMBIAN
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    43
      mFs(CCoeEnv::Static()->FsSession()),
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    44
      mCameraDrive(CxeSysUtil::getCameraDrive(mFs)),
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    45
#endif // Q_OS_SYMBIAN
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    46
      mTriggerLevelBytes(UNKNOWN),
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    47
      mLatestFreeBytes(UNKNOWN)
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    48
{
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    49
    CX_DEBUG_ENTER_FUNCTION();
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    50
    CX_DEBUG_EXIT_FUNCTION();
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    51
}
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    52
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    53
/*!
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    54
* Destructor.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    55
*/
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    56
CxeDiskMonitorPrivate::~CxeDiskMonitorPrivate()
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    57
{
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    58
    CX_DEBUG_ENTER_FUNCTION();
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    59
    stop();
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    60
    CX_DEBUG_EXIT_FUNCTION();
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    61
}
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    62
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    63
/*!
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    64
* Slot for checking if the available disk space is below warning trigger level.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    65
*/
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    66
void CxeDiskMonitorPrivate::checkSpace()
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    67
{
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    68
    CX_DEBUG_ENTER_FUNCTION();
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    69
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    70
    qint64 previousFree(mLatestFreeBytes);
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    71
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    72
    // Get the current free space.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    73
    mLatestFreeBytes = free(false);
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    74
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    75
    // TESTING >>>
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    76
    /*
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    77
    static qint64 TEST = 20*1000*1000;
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    78
    TEST /= 2;
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    79
    mLatestFreeBytes = TEST;
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    80
    */
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    81
    // <<< TESTING
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    82
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    83
    // If space has changed during monitoring, signal it now.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    84
    if (previousFree != mLatestFreeBytes && isMonitoring()) {
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    85
        CX_DEBUG(("CxeDiskMonitorPrivate - Disk space changed %d -> %d bytes", previousFree, mLatestFreeBytes));
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    86
        emit diskSpaceChanged();
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    87
    }
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    88
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    89
    // Only emit warning if trigger level is set to some positive value.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    90
    // Otherwise updating cached free space value is enough.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    91
    if (mTriggerLevelBytes != UNKNOWN && mLatestFreeBytes < mTriggerLevelBytes) {
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    92
        CX_DEBUG(("[WARNING] CxeDiskMonitorPrivate - Disk space low!"));
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    93
        emit diskSpaceLow();
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    94
    }
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    95
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    96
    CX_DEBUG_EXIT_FUNCTION();
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    97
}
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    98
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    99
/*!
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   100
* Set the warning level of free disk space.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   101
* When free disk space falls below this limit, diskSpaceLow() signal is emitted.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   102
* @param bytes Limit in bytes.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   103
*/
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   104
void CxeDiskMonitorPrivate::setLowWarningLevel(qint64 bytes)
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   105
{
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   106
    mTriggerLevelBytes = bytes;
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   107
}
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   108
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   109
/*!
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   110
* Start monitoring disk space.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   111
*/
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   112
void CxeDiskMonitorPrivate::start()
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   113
{
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   114
    if (!mTimer.isActive()) {
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   115
        connect(&mTimer, SIGNAL(timeout()), this, SLOT(checkSpace()), Qt::UniqueConnection);
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   116
        mTimer.start(MONITORING_INTERVAL);
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   117
    }
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   118
}
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   119
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   120
/*!
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   121
* Stop monitoring disk space.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   122
*/
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   123
void CxeDiskMonitorPrivate::stop()
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   124
{
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   125
    mTimer.stop();
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   126
    mLatestFreeBytes = UNKNOWN;
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   127
}
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   128
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   129
/*!
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   130
* Is monitoring ongoing at the moment.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   131
*/
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   132
bool CxeDiskMonitorPrivate::isMonitoring() const
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   133
{
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   134
    return mTimer.isActive();
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   135
}
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   136
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   137
/*!
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   138
* Get free disk space for Camera use in bytes.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   139
* @param cached Can cached value be used.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   140
* If true (default value), value of last constant-interval-check is used (if it exists).
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   141
* If false (or there's no cached value), forced reading of free space is done now.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   142
* This may cause significant delay compared to returning cached value.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   143
*/
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   144
qint64 CxeDiskMonitorPrivate::free(bool cached) const
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   145
{
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   146
    qint64 value(0);
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   147
    if (cached && mLatestFreeBytes != UNKNOWN) {
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   148
        value = mLatestFreeBytes;
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   149
    } else {
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   150
        value = CxeSysUtil::spaceAvailable(mFs, mCameraDrive, mSettings);
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   151
    }
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   152
    return value;
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   153
}
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   154
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   155
// end of file