os/mm/devsoundextensions/effects/SrcLocation/SourceLocationProxy/Src/SourceLocationEventObserver.cpp
Update contrib.
2 * Copyright (c) 2004 Nokia Corporation and/or its subsidiary(-ies).
4 * This component and the accompanying materials are made available
5 * under the terms of "Eclipse Public License v1.0"
6 * which accompanies this distribution, and is available
7 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
9 * Initial Contributors:
10 * Nokia Corporation - initial contribution.
14 * Description: Implementation of the active event observer.
26 #include "SourceLocationEventObserver.h"
29 // ============================ MEMBER FUNCTIONS ===============================
31 // -----------------------------------------------------------------------------
32 // CSourceLocationEventObserver::CSourceLocationEventObserver
33 // C++ default constructor can NOT contain any code, that
35 // -----------------------------------------------------------------------------
37 CSourceLocationEventObserver::CSourceLocationEventObserver()
38 : CActive(CActive::EPriorityStandard),
43 // -----------------------------------------------------------------------------
44 // CSourceLocationEventObserver::ConstructL
45 // Symbian 2nd phase constructor can leave.
46 // -----------------------------------------------------------------------------
48 void CSourceLocationEventObserver::ConstructL(
49 TMMFMessageDestinationPckg aMessageHandler,
50 MCustomCommand& aCustomCommand,
51 MSourceLocationCallback& aCallback )
53 CActiveScheduler::Add(this);
54 iMessageHandler = aMessageHandler;
55 iCustomCommand = &aCustomCommand;
56 iCallback = &aCallback;
59 // -----------------------------------------------------------------------------
60 // CSourceLocationEventObserver::NewL
61 // Two-phased constructor.
62 // -----------------------------------------------------------------------------
64 CSourceLocationEventObserver* CSourceLocationEventObserver::NewL(
65 TMMFMessageDestinationPckg aMessageHandler,
66 MCustomCommand& aCustomCommand,
67 MSourceLocationCallback& aCallback )
69 CSourceLocationEventObserver* self = new(ELeave) CSourceLocationEventObserver();
70 CleanupStack::PushL(self);
71 self->ConstructL(aMessageHandler, aCustomCommand, aCallback);
72 CleanupStack::Pop(self);
77 // -----------------------------------------------------------------------------
78 // CSourceLocationEventObserver::~CSourceLocationEventObserver
80 // -----------------------------------------------------------------------------
82 CSourceLocationEventObserver::~CSourceLocationEventObserver()
84 // We should not have to cancel the outstanding request because the message
85 // handler will complete our request with KErrCancel in its destructor.
89 // -----------------------------------------------------------------------------
90 // CSourceLocationEventObserver::Start
91 // Kickoff the event observer by issuing the first observation message.
92 // -----------------------------------------------------------------------------
94 void CSourceLocationEventObserver::Start()
96 if( !iStopped && !IsActive() )
98 iCustomCommand->CustomCommandAsync(iMessageHandler, (TInt)ESlfObserve, KNullDesC8, KNullDesC8, iDataPckgFrom, iStatus);
104 // -----------------------------------------------------------------------------
105 // CSourceLocationEventObserver::Stop
106 // -----------------------------------------------------------------------------
108 void CSourceLocationEventObserver::Stop()
113 // -----------------------------------------------------------------------------
114 // CSourceLocationEventObserver::RunL
115 // Invoke by the active scheduler when a request completes, In this case, our
116 // observation message has completed.
117 // The proxy is notified. Afterwards, reissue the request to continue observation.
118 // -----------------------------------------------------------------------------
120 void CSourceLocationEventObserver::RunL()
123 RDebug::Print(_L("CSourceLocationEventObserver::RunL()\n"));
126 if( iStatus == KErrNone )
128 iCallback->SourceLocationEvent(iDataPckgFrom);
137 // -----------------------------------------------------------------------------
138 // CSourceLocationEventObserver::DoCancel
139 // Cancels the current and any on going requests/tasks.
140 // -----------------------------------------------------------------------------
142 void CSourceLocationEventObserver::DoCancel()
145 RDebug::Print(_L("CSourceLocationEventObserver::DoCancel()\n"));