satengine/satserver/Engine/src/CSatSScheduler.cpp
author hgs
Fri, 17 Sep 2010 17:09:13 +0300
changeset 48 78df25012fda
parent 33 8d5d7fcf9b59
permissions -rw-r--r--
201037
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
33
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2002-2007 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:  This is the active scheduler of the SAT Server.
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
hgs
parents:
diff changeset
    20
//  INCLUDES
hgs
parents:
diff changeset
    21
#include    <e32svr.h>             // RDebug
hgs
parents:
diff changeset
    22
#include    "CSatSScheduler.h"
hgs
parents:
diff changeset
    23
#include    "CSatSServer.h"
hgs
parents:
diff changeset
    24
#include    "SatLog.h"
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
// ================= MEMBER FUNCTIONS ==========================================
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
// The class constructor.
hgs
parents:
diff changeset
    29
EXPORT_C CSatSScheduler::CSatSScheduler()
hgs
parents:
diff changeset
    30
    {
hgs
parents:
diff changeset
    31
    LOG( SIMPLE, "SATENGINE: CSatSScheduler::SetServer calling - exiting" )
hgs
parents:
diff changeset
    32
    }
hgs
parents:
diff changeset
    33
hgs
parents:
diff changeset
    34
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    35
// CSatSScheduler::SetServer
hgs
parents:
diff changeset
    36
// Gives a pointer of the current CSatSServer instance to the scheduler.
hgs
parents:
diff changeset
    37
// (other items were commented in a header).
hgs
parents:
diff changeset
    38
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    39
//
hgs
parents:
diff changeset
    40
EXPORT_C void CSatSScheduler::SetServer( CSatSServer* aServer )
hgs
parents:
diff changeset
    41
    {
hgs
parents:
diff changeset
    42
    LOG( SIMPLE, "SATENGINE: CSatSScheduler::SetServer calling" )
hgs
parents:
diff changeset
    43
    iServer = aServer;
hgs
parents:
diff changeset
    44
    LOG( SIMPLE, "SATENGINE: CSatSScheduler::SetServer exiting" )
hgs
parents:
diff changeset
    45
    }
hgs
parents:
diff changeset
    46
hgs
parents:
diff changeset
    47
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    48
// CSatSScheduler::Error
hgs
parents:
diff changeset
    49
// Overridden to handle leaves in request functions and unexpected situations.
hgs
parents:
diff changeset
    50
// (other items were commented in a header).
hgs
parents:
diff changeset
    51
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    52
//
hgs
parents:
diff changeset
    53
void CSatSScheduler::Error( TInt aError ) const
hgs
parents:
diff changeset
    54
    {
hgs
parents:
diff changeset
    55
    LOG( SIMPLE, "SATENGINE: CSatSScheduler::Error calling" )
hgs
parents:
diff changeset
    56
    LOG2( SIMPLE, "SATENGINE: CSatSScheduler::Error aError=%d", aError )
hgs
parents:
diff changeset
    57
hgs
parents:
diff changeset
    58
    if ( iServer )
hgs
parents:
diff changeset
    59
        {
hgs
parents:
diff changeset
    60
        if ( iServer->IsActive() )
hgs
parents:
diff changeset
    61
            {
hgs
parents:
diff changeset
    62
            LOG( SIMPLE, "SATENGINE: CSatSScheduler::Error iServer active" )
hgs
parents:
diff changeset
    63
            __DEBUGGER()
hgs
parents:
diff changeset
    64
            }
hgs
parents:
diff changeset
    65
        else
hgs
parents:
diff changeset
    66
            {
hgs
parents:
diff changeset
    67
            // Relay the error code to the client and restart the server.
hgs
parents:
diff changeset
    68
            LOG( SIMPLE, "SATENGINE: CSatSScheduler::Error iServer not active" )
hgs
parents:
diff changeset
    69
            iServer->CompleteMessage( aError );
hgs
parents:
diff changeset
    70
            iServer->ReStart();
hgs
parents:
diff changeset
    71
            }        
hgs
parents:
diff changeset
    72
        }
hgs
parents:
diff changeset
    73
   
hgs
parents:
diff changeset
    74
    LOG( SIMPLE, "SATENGINE: CSatSScheduler::Error exiting" )
hgs
parents:
diff changeset
    75
    }
hgs
parents:
diff changeset
    76
hgs
parents:
diff changeset
    77
//  End of File