datasourcemodules/gpspositioningmodule/lbsagpspsy/src/cagpspositioner.cpp
changeset 36 b47902b73a93
parent 0 9cfd9a3ee49c
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/datasourcemodules/gpspositioningmodule/lbsagpspsy/src/cagpspositioner.cpp	Fri Jun 04 10:34:15 2010 +0100
@@ -0,0 +1,312 @@
+// Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies).
+// All rights reserved.
+// This component and the accompanying materials are made available
+// under the terms of "Eclipse Public License v1.0"
+// which accompanies this distribution, and is available
+// at the URL "http://www.eclipse.org/legal/epl-v10.html".
+//
+// Initial Contributors:
+// Nokia Corporation - initial contribution.
+//
+// Contributors:
+//
+// Description:
+//
+
+/**
+ @file
+ @InternalComponent
+*/
+
+#include <e32base.h>
+#include <lbs/epos_mpositionerstatus.h>
+#include <ecom/implementationproxy.h>
+#include <lbssatellite.h>
+#include <lbs/lbsadmin.h>
+
+#include "cagpspositioner.h"
+#include "agpspsy.hrh"
+#include "agpspsypanic.h"
+#include "cpositionerq.h"
+#include "crequesthandler.h"
+#include "cagpsenvironment.h"
+#include "utilfunctions.h"
+#include "tagpsrequestparameters.h"
+#include "agpsrequestconstants.h"
+#include "psylogging.h"
+#include "psypanic.h"
+
+/*
+* 
+*/
+CAgpsPositioner::CAgpsPositioner()
+    {
+	iState = ERequestStateInitial;
+	iTerminalAssisted = EFalse;
+    }
+
+// -----------------------------------------------------------------------------
+// Destructor
+// -----------------------------------------------------------------------------
+//
+CAgpsPositioner::~CAgpsPositioner()
+    {
+	TRACESTRING("CAgpsPositioner::~CAgpsPositioner")
+
+	if(iEnvironment)
+		{
+		iEnvironment->UnregisterPSY(this);
+		}
+	
+	iNetRegStatus.Close();
+    }
+
+/**
+ * Creates a new instance of a CPositioner implementation.
+ *
+ * @param aConstructionParameters Construction parameters for CPositioner.
+ * @return The positioner implementation.
+ */
+CAgpsPositioner* CAgpsPositioner::NewL(TAny* aConstructionParameters)
+    {
+    CAgpsPositioner* self = new( ELeave ) CAgpsPositioner;
+
+    CleanupStack::PushL( self );
+    self->ConstructL(aConstructionParameters);
+    CleanupStack::Pop(self);
+
+    return self;
+    }
+
+/**
+ * 2nd phase constructor
+ *
+ * @param aConstructionParameters Construction parameters for CPositioner.
+ */
+void CAgpsPositioner::ConstructL(TAny* aConstructionParameters)
+	{
+	TRACESTRING("CAgpsPositioner::ConstructL")
+
+	// Must call BaseConstructL first thing during construction.
+	BaseConstructL(aConstructionParameters);
+
+	iEnvironment = CAgpsEnvironment::NewL();
+	iEnvironment->RegisterPSYL(this);
+	iEnvironment->GetEnvCriteriaL(iCriteria, TUid::Uid(KPosAGPSPSYImplUid));
+	iInactivityTimeout = iEnvironment->GetInactivityTimeoutL(TUid::Uid(KPosAGPSPSYImplUid));
+	iRequestHandler = iEnvironment->GetRequestHandler();
+
+	// Get the request timeout from the LS:
+	if(iEnvironment->ProfileInUse())	// default timeout was taken from profile, so let LS know
+		{
+		TPositionQuality quality;
+		iCriteria.GetRequiredQuality(quality);
+		iTimeOutInterval = quality.TimeToFirstFix();	
+		SetPsyDefaultUpdateTimeOut(iTimeOutInterval);
+		}	    
+
+	iNetRegStatus.OpenL();
+	}
+
+/**
+* Initiate a tracking session.
+*
+* @param aInterval Interval for position requests.
+*/
+void CAgpsPositioner::StartTrackingL(const TTimeIntervalMicroSeconds& aInterval)
+    {
+	TRACESTRING2("CAdaptationPositioner::StartTrackingL, interval = %d", aInterval)
+
+	TTime timeNow;
+    
+    TTime trackingTime = LbsTimerUtils::AddUpInt64TimersWithOverflowCheck(iTargetTime, aInterval);
+	timeNow.UniversalTime();
+    
+	iTrackingInterval = aInterval;
+	    
+    if(! (trackingTime < timeNow)) // if this is not a default proxy call to StartTracking
+	    {
+    	TRACESTRING("Non-DefProxy Start")
+	    SetupTrackingRequestL();
+        SetAGPSMode();
+		iRequestHandler->SubmitNewRequestL(this);
+	    }
+    }
+    
+/**
+* Requests position info asynchronously. 
+*
+* @param aPosInfo A reference to a position info object. This object
+*                 must be in scope until the request has completed.
+*                 The position (TPosition) of this position info object
+*                 must be in WGS84 geodetic datum.
+* @param aClientStatus The request status
+*
+*/
+void CAgpsPositioner::NotifyPositionUpdate(TPositionInfoBase& aPosInfo, TRequestStatus& aClientStatus)
+    {
+    TRACESTRING("CAdaptationPositioner::NotifyPositionUpdate")
+
+	// we're about to submit a new request, so stop warmdown timer if running: 
+	StopMaxFixTimer();
+    StopWarmDownTimer();
+	
+    // Clear position info
+    ClearPositionInfo(aPosInfo);
+    
+    aClientStatus = KRequestPending;
+    iPosInfo = &aPosInfo;
+    iClientStatus = &aClientStatus;
+    
+    if(!UseLastLocation(aPosInfo)) // Attempt to complete the client immediately with an old position
+		{
+		TTime timeNow;
+		timeNow.UniversalTime();
+	    iActive = ETrue;
+	
+		GetUpdateTimeOut(iTimeOutInterval);
+
+		TDateTime debugTime = timeNow.DateTime();
+		TRACESTRING38("Time Now = %d.%d", debugTime.Second(), debugTime.MicroSecond());
+		
+		// Add on the lag time
+		if(iTerminalAssisted)
+			{
+        	CAgpsEnvironment* agpsEnvironment = static_cast<CAgpsEnvironment*>(iEnvironment);
+        	ExtendUpdateTimeOut(agpsEnvironment->GetFinalNetPositionLag());
+			}
+				
+		if( !IsTracking() ||
+			(IsTracking() && (iTargetTime <= timeNow)) )
+			{
+			iTargetTime.UniversalTime();
+	        TRACESTRING("CAdaptationPositioner::NotifyPositionUpdate submitting new request")
+
+	        SetAGPSMode();
+	        
+	        // (re)start maxfix timer so that we know when the module has stopped trying	        
+	        TRAPD(error,StartMaxFixTimerL());	 
+	        if(!error)
+	        	{
+	        	TRAP(error, iRequestHandler->SubmitNewRequestL(this));
+	        	}
+	        if(error)
+		        {
+				UpdateFailed(error);
+		        }
+			}
+			
+		debugTime = iTargetTime.DateTime();
+		TRACESTRING38("Target Time = %d.%d", debugTime.Second(), debugTime.MicroSecond());
+		}
+    }
+
+
+void CAgpsPositioner::SetModuleId(TPositionInfoBase* aPosInfo)
+	{
+	if(aPosInfo)
+		{
+		aPosInfo->SetModuleId(TUid::Uid(KPosAGPSPSYImplUid)); // Use the PSY module Id rather than the AGPS managers
+		}
+	}
+
+const TRequestParameters* CAgpsPositioner::PositionRequestParams()
+	{
+	TBool state = (iState == ERequestStateInitial);
+	
+	iRequestParameters.iTargetTime = iTargetTime;
+	iRequestParameters.iTimeForFix = iTimeOutInterval;
+	iRequestParameters.iCriteria = iCriteria;
+	iRequestParameters.iNewClient = state;
+	iRequestParameters.iTracking = IsTracking();
+	iRequestParameters.iAGPSMode = iAGPSMode;
+	
+	return &iRequestParameters;
+	}
+	
+/**
+* Checks for a transition into TA mode and extends the max fix time to allow for 
+* the final network position arriving  
+*
+* @param aMode The mode of the last update.
+*
+*/
+void CAgpsPositioner::ModeUpdate(TUint aMode)
+	{
+    TRACESTRING("CPositionerSubSession::CheckMode()")
+
+	if ( ((aMode & RLbsPositionUpdates::EGpsModeTerminalAssisted) == RLbsPositionUpdates::EGpsModeTerminalAssisted) 
+		&& !iTerminalAssisted )
+		{
+		iTerminalAssisted = ETrue;
+		CAgpsEnvironment* agpsEnvironment = static_cast<CAgpsEnvironment*>(iEnvironment);
+		ExtendUpdateTimeOut(agpsEnvironment->GetFinalNetPositionLag());
+		}
+	else if (((aMode & RLbsPositionUpdates::EGpsModeTerminalAssisted) != RLbsPositionUpdates::EGpsModeTerminalAssisted))
+		{
+		iTerminalAssisted = EFalse;
+		}
+	}
+
+void CAgpsPositioner::SetAGPSMode()
+	{
+    TRACESTRING("CPositionerSubSession::GpsMode()")
+	
+    CLbsAdmin::TGpsMode mode = CLbsAdmin::EGpsModeUnknown;
+	iAGPSMode = KAutonomousMode;
+	
+	RLbsNetworkRegistrationStatus::TLbsNetworkRegistrationStatus netRegStatus(RLbsNetworkRegistrationStatus::ENetworkRegistrationUnknown);
+	
+	// Read the current network registration status
+	TInt err = iNetRegStatus.GetNetworkRegistrationStatus(netRegStatus);
+
+	if (err == KErrNone)
+		{
+		// Read the admin setting
+		switch (netRegStatus)
+			{
+			case RLbsNetworkRegistrationStatus::ERegisteredHomeNetwork:
+				{
+				err = iEnvironment->Admin().Get(KLbsSettingHomeGpsMode, mode);
+				break;
+				}
+			case RLbsNetworkRegistrationStatus::ERegisteredRoamingNetwork:
+			case RLbsNetworkRegistrationStatus::ENotRegistered:
+				{
+				err = iEnvironment->Admin().Get(KLbsSettingRoamingGpsMode, mode);
+				break;
+				}		
+			case RLbsNetworkRegistrationStatus::ENetworkRegistrationUnknown:
+			default:
+				{
+				TRACESTRING("Unrecognised TLbsNetworkRegistrationStatus")
+				break;
+				}
+			}
+		
+		// Convert to internal mode
+		switch (mode)
+			{
+			case CLbsAdmin::EGpsPreferTerminalBased:
+			case CLbsAdmin::EGpsAlwaysTerminalBased:
+				iAGPSMode = KTerminalBasedMode;
+			break;
+			
+			case CLbsAdmin::EGpsPreferTerminalAssisted:
+			case CLbsAdmin::EGpsAlwaysTerminalAssisted:
+				iAGPSMode = KTerminalAssistedMode;
+			break;
+			
+			case CLbsAdmin::EGpsModeUnknown:
+				__ASSERT_DEBUG(EFalse,User::Panic(KAdaptationPanicCategory, KErrArgument));
+			break;
+			
+			case CLbsAdmin::EGpsAutonomous:
+			default:
+				iAGPSMode = KAutonomousMode;
+			break;
+			}
+		}
+	}
+
+//  End of File