camerauis/cameraxui/cxengine/src/cxediskmonitorprivate.cpp
author hgs
Thu, 15 Jul 2010 01:44:30 +0300
changeset 38 0f0b4c1d7744
parent 28 3075d9b614e6
permissions -rw-r--r--
201019
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
    // If space has changed during monitoring, signal it now.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    76
    if (previousFree != mLatestFreeBytes && isMonitoring()) {
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    77
        CX_DEBUG(("CxeDiskMonitorPrivate - Disk space changed %d -> %d bytes", previousFree, mLatestFreeBytes));
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    78
        emit diskSpaceChanged();
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    79
    }
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    80
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    81
    // Only emit warning if trigger level is set to some positive value.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    82
    // Otherwise updating cached free space value is enough.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    83
    if (mTriggerLevelBytes != UNKNOWN && mLatestFreeBytes < mTriggerLevelBytes) {
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    84
        CX_DEBUG(("[WARNING] CxeDiskMonitorPrivate - Disk space low!"));
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    85
        emit diskSpaceLow();
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    86
    }
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    87
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    88
    CX_DEBUG_EXIT_FUNCTION();
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    89
}
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    90
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    91
/*!
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    92
* Set the warning level of free disk space.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    93
* When free disk space falls below this limit, diskSpaceLow() signal is emitted.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    94
* @param bytes Limit in bytes.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    95
*/
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    96
void CxeDiskMonitorPrivate::setLowWarningLevel(qint64 bytes)
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    97
{
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    98
    mTriggerLevelBytes = bytes;
3075d9b614e6 201017_1
hgs
parents:
diff changeset
    99
}
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   100
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   101
/*!
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   102
* Start monitoring disk space.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   103
*/
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   104
void CxeDiskMonitorPrivate::start()
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   105
{
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   106
    if (!mTimer.isActive()) {
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   107
        connect(&mTimer, SIGNAL(timeout()), this, SLOT(checkSpace()), Qt::UniqueConnection);
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   108
        mTimer.start(MONITORING_INTERVAL);
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   109
    }
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   110
}
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   111
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   112
/*!
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   113
* Stop monitoring disk space.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   114
*/
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   115
void CxeDiskMonitorPrivate::stop()
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   116
{
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   117
    mTimer.stop();
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   118
    mLatestFreeBytes = UNKNOWN;
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   119
}
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   120
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   121
/*!
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   122
* Is monitoring ongoing at the moment.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   123
*/
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   124
bool CxeDiskMonitorPrivate::isMonitoring() const
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   125
{
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   126
    return mTimer.isActive();
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
* Get free disk space for Camera use in bytes.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   131
* @param cached Can cached value be used.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   132
* If true (default value), value of last constant-interval-check is used (if it exists).
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   133
* If false (or there's no cached value), forced reading of free space is done now.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   134
* This may cause significant delay compared to returning cached value.
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   135
*/
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   136
qint64 CxeDiskMonitorPrivate::free(bool cached) const
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   137
{
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   138
    qint64 value(0);
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   139
    if (cached && mLatestFreeBytes != UNKNOWN) {
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   140
        value = mLatestFreeBytes;
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   141
    } else {
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   142
        value = CxeSysUtil::spaceAvailable(mFs, mCameraDrive, mSettings);
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   143
    }
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   144
    return value;
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   145
}
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   146
3075d9b614e6 201017_1
hgs
parents:
diff changeset
   147
// end of file