sapi_location/src/locationcallBack.cpp
changeset 0 14df0fbfcc4e
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/sapi_location/src/locationcallBack.cpp	Mon Mar 30 12:51:10 2009 +0300
@@ -0,0 +1,322 @@
+/*
+* Copyright (c) 2006-2007 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of the License "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:  Implements callback methods which is called my core dll call
+*									callback methods.
+*
+*/
+
+#include <liwserviceifbase.h>
+#include <LiwCommon.h>
+#include "locationinterface.h"
+#include "locationservice.h"
+#include "locationcb.h"
+
+using namespace LIW;
+
+/**
+ * Default constructor
+ */
+ 
+LocationInterfaceCB ::LocationInterfaceCB()
+    {
+    iCallBack = NULL	; 
+    iOutParmList = NULL ;
+    iInParmList = NULL ;
+    iTransactionId = 0 ;
+    }
+
+/**
+ * OverLoaded constructor which accepts the callback adderss 
+ * and registers it 
+ */
+ 
+LocationInterfaceCB :: LocationInterfaceCB( MLiwNotifyCallback* aCallBack ,
+										const CLiwGenericParamList* aInParmList ,	
+     				      				TPositionModuleInfo* aPositionModuleInfo ,
+     				      				TInt32 aTransactionId ) : iCallBack(aCallBack), 
+     				      										 iTransactionId(aTransactionId)
+    {
+    iModuleInfo = aPositionModuleInfo	;
+    
+    //Store the outparam and in param list
+    
+    iOutParmList = CLiwGenericParamList :: NewL(); //(*aOutParmList) ;
+     
+    
+    //Currently we dont use inputparam list, but when need it has to be 
+    //initalised as done above for iOutParamList
+    iInParmList = iOutParmList ;
+    //Extract the location info category from inputparamlist
+    TInt index = 0;
+    const TLiwGenericParam *smapparam = aInParmList->FindFirst(index , KLocationInfoCategory) ;
+    TPtrC argposInfoCategory(KLocationBasicinfo) ;
+    
+    if(index != KErrNotFound)
+        {
+         
+        //posInfoCategory =  (smapparam->Value()).AsDes() ; 
+        argposInfoCategory.Set( (smapparam->Value()).AsDes() );           
+        }
+    
+    
+    iLocinfoCategory = EBasicInfo;
+    if ( argposInfoCategory == KLocationGenericInfo )
+        {
+            iLocinfoCategory = EGenericInfo;
+        }
+    }
+
+/**
+ * overloaded NewL function for creating local call back objects
+ * as required by locationinterface.cpp 
+ */
+ 
+LocationInterfaceCB *LocationInterfaceCB :: NewL(MLiwNotifyCallback* aCallBack  ,
+												const CLiwGenericParamList* aInParmList ,  
+												TPositionModuleInfo* aPositionModuleInfo,
+												TInt32 aTransactionid  ) 
+    {
+    LocationInterfaceCB *self = new(ELeave) LocationInterfaceCB(aCallBack , aInParmList ,
+    															aPositionModuleInfo, aTransactionid) ;
+
+     return self ;
+    }
+
+/**
+ * implementation of HandleNotifyL function derived from LocationInterfaceCB
+ */
+ 
+ TInt LocationInterfaceCB :: HandleNotifyL(HPositionGenericInfo* aGenericInfo , TInt aError) 
+    {
+
+   	iOutParmList->Reset() ;
+    TInt err = CLocationInterface :: ConvertToSapiError(aError) ;
+    
+    TLiwGenericParam errorParm(KErrorCode , TLiwVariant((TInt32)err)) ;
+    iOutParmList->AppendL(errorParm) ;
+
+    if(aError) //if Error then return the error code to user
+        {
+
+        iCallBack->HandleNotifyL(iTransactionId , KLiwEventError , *iOutParmList , *iInParmList) ;
+        iOutParmList = NULL ;
+        //delete this ;
+        return KErrGeneral ;
+        }
+        
+   
+   	TRAPD(error , HandleL(aGenericInfo , aError))
+    
+    if(error != KErrNone)
+    	{
+    	 iCallBack->HandleNotifyL(iTransactionId , KLiwEventError , *iOutParmList , *iInParmList) ;
+    	 iOutParmList = NULL ;
+         //delete this ;
+         return KErrGeneral ;
+    	}
+    
+     	
+  
+   //For GetLocation notify user with EventCompleted Notification and for trace
+   //Notify user with Event in progress notification
+    if(iRequestType == KGetLocationCB)
+        {
+        iCallBack->HandleNotifyL(iTransactionId , KLiwEventCompleted , *iOutParmList , *iInParmList ) ;
+        }
+    else
+        {
+        iCallBack->HandleNotifyL(iTransactionId , KLiwEventInProgress , *iOutParmList , *iInParmList ) ; 
+        }    
+
+   
+
+    return KErrNone ;
+    }
+ 
+ /**
+  * LocationInterfaceCB :: HandleL(): An internal utility function that encapsulates 
+  * all the leaving methods. This function is called by HandleNotifyL method
+  */  
+    
+void LocationInterfaceCB :: HandleL(HPositionGenericInfo* aGenericInfo , TInt /*aError*/)  
+	{
+    CLiwDefaultMap *result = CLiwDefaultMap::NewL() ;
+    CleanupStack :: PushL(result) ;
+    //Now insert the collected position informaiton(latitude, longitude , and altitude into a default map 
+    TPosition pos ;
+
+    aGenericInfo->GetPosition(pos) ;
+
+    TReal32 Val = pos.Longitude() ;
+
+    result->InsertL(KLongitudeKey , TLiwVariant((TReal)Val)) ; //Inserting longitude 
+
+
+    Val = pos.Latitude() ;
+    result->InsertL(KLatitudeKey , TLiwVariant((TReal)Val)) ; //Inserting latitude into map    
+
+    Val = pos.Altitude() ;
+
+    result->InsertL(KAltitudeKey , TLiwVariant((TReal)Val))   ;  //Inserting altitude into map 
+    //TLiwVariant resVar(result) ;
+
+    
+    TPositionModuleInfo :: TCapabilities  currCapability  = iModuleInfo->Capabilities() ;
+    
+    if ( iLocinfoCategory == EGenericInfo )
+	    {
+	    if(currCapability & TPositionModuleInfo :: ECapabilitySpeed) //Populate output param with speed info
+        {
+        TReal32 speedinfo = 0 ;
+
+        if(!aGenericInfo->GetValue(EPositionFieldHorizontalSpeed , speedinfo) ) //Extract speed 
+            {
+            result->InsertL(KPositionFieldHorizontalSpeed,TLiwVariant((TReal)speedinfo));
+            
+            }
+
+        if(!aGenericInfo->GetValue(EPositionFieldHorizontalSpeedError , speedinfo))
+            {
+            result->InsertL(KPositionFieldHorizontalSpeedError,TLiwVariant((TReal)speedinfo));	
+            }
+
+
+
+        }   //End of EcapabilitySpeed 
+
+
+	    if(currCapability & TPositionModuleInfo :: ECapabilitySatellite) //Extract satellitinfo if any and append it
+	        {																//as part of out parm list
+	        TInt8 satinfo  = 0;
+
+	        if(!aGenericInfo->GetValue(EPositionFieldSatelliteNumInView , satinfo))
+	            {
+	            result->InsertL(KPositionFieldSatelliteNumInView,TLiwVariant((TReal)satinfo));	
+	            }
+	        if(!aGenericInfo->GetValue(EPositionFieldSatelliteNumUsed , satinfo))
+		        {
+		        result->InsertL(KPositionFieldSatelliteNumUsed ,TLiwVariant((TReal) satinfo)) ;
+		        }
+
+
+	        }
+
+	    if(currCapability & TPositionModuleInfo :: ECapabilityDirection) //Extract direction info if any and append it 
+	        {                                                               // as part of out parm list
+	        TReal direcinfo = 0;
+
+	        if(!aGenericInfo->GetValue(EPositionFieldTrueCourse , direcinfo) )
+	            {
+	            result->InsertL(KPositionFieldTrueCourse,TLiwVariant((TReal)direcinfo));
+	            //iOutParmList->AppendL(TLiwGenericParam(KPositionFieldTrueCourse , TLiwVariant((TInt32)direcinfo))) ;	
+	            }
+
+
+	        if(!aGenericInfo->GetValue(EPositionFieldTrueCourseError , direcinfo) )
+	            {
+	            result->InsertL(KPositionFieldTrueCourseError,TLiwVariant((TReal)direcinfo));
+	            //iOutParmList->AppendL(TLiwGenericParam(KPositionFieldTrueCourseError , TLiwVariant((TInt32)direcinfo))) ;
+	            }
+
+
+	        if(!aGenericInfo->GetValue(EPositionFieldMagneticCourseError , direcinfo) )
+	            {
+	            result->InsertL(KPositionFieldTrueCourseError,TLiwVariant((TReal)direcinfo));
+	            //iOutParmList->AppendL(TLiwGenericParam(KPositionFieldMagneticCourseError , TLiwVariant((TInt32)direcinfo))) ;
+	            }
+
+	        if(!aGenericInfo->GetValue(EPositionFieldMagneticCourse , direcinfo) )
+	            {
+	            result->InsertL(KPositionFieldMagneticCourse,TLiwVariant((TReal)direcinfo));
+	            	
+	            }
+
+	        }
+
+
+	    if(currCapability & TPositionModuleInfo :: ECapabilityCompass) //Extract compass info if any and append it 
+	        {                                                               // as part of out parm list
+	        TReal compassinfo ;
+
+	        if(!aGenericInfo->GetValue(EPositionFieldHeading , compassinfo) )
+	            {
+	            result->InsertL(KPositionFieldHeading,TLiwVariant((TReal)compassinfo));
+	            ;
+	            }
+
+
+	        if(!aGenericInfo->GetValue(EPositionFieldHeadingError , compassinfo) )
+	            {
+	            result->InsertL(KPositionFieldHeadingError,TLiwVariant((TReal)compassinfo));
+	            
+	            }
+
+	        if(!aGenericInfo->GetValue(EPositionFieldMagneticHeading , compassinfo) )
+	            {
+	            result->InsertL(KPositionFieldMagneticHeading,TLiwVariant((TReal)compassinfo));
+	            
+	            }
+
+
+
+	        if(!aGenericInfo->GetValue(EPositionFieldMagneticHeadingError , compassinfo) )
+	            {
+	            result->InsertL(KPositionFieldMagneticHeadingError,TLiwVariant((TReal)compassinfo));
+	            	
+	            }
+
+
+
+	        }
+
+	    /*if( currCapability & TPositionModuleInfo :: ECapabilityNmea ) //Extract Nmea info if any and append it 	
+	        {                                                             //as part of out param list  
+	        TUint8 numSentences ;
+
+	        if(!aGenericInfo->GetValue(EPositionFieldNMEASentences , numSentences) )
+	            {
+	            result->InsertL(KPositionFieldNMEASentences,TLiwVariant((TReal)numSentences));
+	            	
+	            }
+
+
+	        TBuf8 <20> nmeaSentences ;
+
+	        if(!aGenericInfo->GetValue(EPositionFieldNMEASentencesStart , nmeaSentences) )
+	            {
+	            result->InsertL(KPositionFieldNMEASentencesStart,TLiwVariant(nmeaSentences));
+	            	
+	            }
+	        }*/
+	    
+	    }
+	TLiwGenericParam outParm(KLocationMap , TLiwVariant(result)) ;
+
+    iOutParmList->AppendL(outParm) ;
+    CleanupStack :: Pop(result) ;
+    result->DecRef() ;
+
+
+	}
+    
+/**
+ * Default destructor 
+ */
+ 
+ LocationInterfaceCB :: ~LocationInterfaceCB()
+ {
+ 	
+ 	delete iOutParmList;
+ 
+ }