piprofiler/engine/src/ProfilerErrorChecker.cpp
author hgs
Thu, 13 May 2010 23:59:27 +0300
changeset 20 a71a3e32a2ae
permissions -rw-r--r--
201019
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
20
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). 
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description:  
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
#include <e32std.h>
hgs
parents:
diff changeset
    20
#include <e32base.h>
hgs
parents:
diff changeset
    21
#include <e32property.h>
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
#include <piprofiler/ProfilerTraces.h>
hgs
parents:
diff changeset
    24
hgs
parents:
diff changeset
    25
#include "ProfilerErrorChecker.h"
hgs
parents:
diff changeset
    26
hgs
parents:
diff changeset
    27
// properties
hgs
parents:
diff changeset
    28
const TUid KEngineStatusPropertyCat={0x2001E5AD};
hgs
parents:
diff changeset
    29
enum TEnginePropertyKeys
hgs
parents:
diff changeset
    30
    {
hgs
parents:
diff changeset
    31
    EProfilerEngineStatus = 8,
hgs
parents:
diff changeset
    32
    EProfilerErrorStatus
hgs
parents:
diff changeset
    33
    };
hgs
parents:
diff changeset
    34
hgs
parents:
diff changeset
    35
/*
hgs
parents:
diff changeset
    36
 *
hgs
parents:
diff changeset
    37
 *  CProfilerErrorChecker class implementation
hgs
parents:
diff changeset
    38
 *
hgs
parents:
diff changeset
    39
 */
hgs
parents:
diff changeset
    40
CProfilerErrorChecker* CProfilerErrorChecker::NewL()
hgs
parents:
diff changeset
    41
    {
hgs
parents:
diff changeset
    42
    CProfilerErrorChecker* self = new(ELeave) CProfilerErrorChecker;
hgs
parents:
diff changeset
    43
    CleanupStack::PushL(self);
hgs
parents:
diff changeset
    44
    self->ConstructL();
hgs
parents:
diff changeset
    45
    CleanupStack::Pop();
hgs
parents:
diff changeset
    46
    return self;
hgs
parents:
diff changeset
    47
    }
hgs
parents:
diff changeset
    48
hgs
parents:
diff changeset
    49
// --------------------------------------------------------------------------------------------
hgs
parents:
diff changeset
    50
CProfilerErrorChecker::CProfilerErrorChecker() :
hgs
parents:
diff changeset
    51
    CActive(EPriorityStandard)
hgs
parents:
diff changeset
    52
    {
hgs
parents:
diff changeset
    53
    }
hgs
parents:
diff changeset
    54
hgs
parents:
diff changeset
    55
CProfilerErrorChecker::~CProfilerErrorChecker()
hgs
parents:
diff changeset
    56
    {
hgs
parents:
diff changeset
    57
    Cancel();
hgs
parents:
diff changeset
    58
    iErrorStatus.Close();
hgs
parents:
diff changeset
    59
    }
hgs
parents:
diff changeset
    60
hgs
parents:
diff changeset
    61
// --------------------------------------------------------------------------------------------
hgs
parents:
diff changeset
    62
void CProfilerErrorChecker::ConstructL()
hgs
parents:
diff changeset
    63
    {
hgs
parents:
diff changeset
    64
    
hgs
parents:
diff changeset
    65
    LOGTEXT(_L("Trying to attach to profiler engine error status property"));
hgs
parents:
diff changeset
    66
    User::LeaveIfError(iErrorStatus.Attach(KEngineStatusPropertyCat, EProfilerErrorStatus));
hgs
parents:
diff changeset
    67
    CActiveScheduler::Add(this);
hgs
parents:
diff changeset
    68
hgs
parents:
diff changeset
    69
    // subscribe to P&S status property
hgs
parents:
diff changeset
    70
    iErrorStatus.Subscribe(iStatus);
hgs
parents:
diff changeset
    71
    SetActive();
hgs
parents:
diff changeset
    72
    }
hgs
parents:
diff changeset
    73
hgs
parents:
diff changeset
    74
// --------------------------------------------------------------------------------------------
hgs
parents:
diff changeset
    75
void CProfilerErrorChecker::SetObserver(MProfilerErrorObserver* aObserver)
hgs
parents:
diff changeset
    76
    {
hgs
parents:
diff changeset
    77
    iObserver = aObserver;
hgs
parents:
diff changeset
    78
    }
hgs
parents:
diff changeset
    79
hgs
parents:
diff changeset
    80
// --------------------------------------------------------------------------------------------
hgs
parents:
diff changeset
    81
TInt CProfilerErrorChecker::RunError(TInt aError)
hgs
parents:
diff changeset
    82
    {
hgs
parents:
diff changeset
    83
    iErrorStatus.Close();
hgs
parents:
diff changeset
    84
    return aError;
hgs
parents:
diff changeset
    85
    }
hgs
parents:
diff changeset
    86
// --------------------------------------------------------------------------------------------
hgs
parents:
diff changeset
    87
void CProfilerErrorChecker::RunL()
hgs
parents:
diff changeset
    88
    {
hgs
parents:
diff changeset
    89
    // resubscribe before processing new value to prevent missing updates
hgs
parents:
diff changeset
    90
    iErrorStatus.Subscribe(iStatus);
hgs
parents:
diff changeset
    91
    SetActive();
hgs
parents:
diff changeset
    92
hgs
parents:
diff changeset
    93
    TInt stat(0);
hgs
parents:
diff changeset
    94
    if(iErrorStatus.Get(stat) != KErrNone)
hgs
parents:
diff changeset
    95
        {
hgs
parents:
diff changeset
    96
        // check if error status != KErrNone
hgs
parents:
diff changeset
    97
        if(stat != 0)
hgs
parents:
diff changeset
    98
            {
hgs
parents:
diff changeset
    99
            iObserver->HandleProfilerErrorChangeL(stat);
hgs
parents:
diff changeset
   100
            }
hgs
parents:
diff changeset
   101
        
hgs
parents:
diff changeset
   102
        // reset error code
hgs
parents:
diff changeset
   103
        iErrorStatus.Set(KErrNone);
hgs
parents:
diff changeset
   104
        }
hgs
parents:
diff changeset
   105
    }
hgs
parents:
diff changeset
   106
hgs
parents:
diff changeset
   107
// --------------------------------------------------------------------------------------------
hgs
parents:
diff changeset
   108
 
hgs
parents:
diff changeset
   109
void CProfilerErrorChecker::DoCancel()
hgs
parents:
diff changeset
   110
    {
hgs
parents:
diff changeset
   111
    iErrorStatus.Cancel();
hgs
parents:
diff changeset
   112
    }
hgs
parents:
diff changeset
   113
hgs
parents:
diff changeset
   114
// end of file
hgs
parents:
diff changeset
   115