locationtriggering/ltclientlib/src/lbtgeohybrid.cpp
changeset 0 667063e416a2
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/locationtriggering/ltclientlib/src/lbtgeohybrid.cpp	Tue Feb 02 01:06:48 2010 +0200
@@ -0,0 +1,269 @@
+/*
+* Copyright (c) 2008 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:  Implementation of Geographical hybrid area class.
+*
+*/
+
+#include <lbtgeohybrid.h>
+#include <lbtgeocircle.h>
+#include <lbtgeorect.h>
+#include <lbtgeocell.h>
+#include <lbterrors.h>
+
+
+// ======== LOCAL FUNCTIONS ========
+
+// ---------------------------------------------------------------------------
+// CLbtGeoHybrid::NewL()
+//
+// (other items were commented in a header).
+// ---------------------------------------------------------------------------
+//
+EXPORT_C CLbtGeoHybrid* CLbtGeoHybrid::NewL()
+    {
+    CLbtGeoHybrid* self = CLbtGeoHybrid::NewLC();
+    CleanupStack::Pop( self );
+    return self;
+    }
+
+// ---------------------------------------------------------------------------
+// CLbtGeoHybrid::NewLC()
+//
+// (other items were commented in a header).
+// ---------------------------------------------------------------------------
+//
+EXPORT_C CLbtGeoHybrid* CLbtGeoHybrid::NewLC()
+    {
+    CLbtGeoHybrid* self = new( ELeave ) CLbtGeoHybrid;
+    CleanupStack::PushL( self );
+    self->ConstructL();
+    return self;
+    }
+    
+// ---------------------------------------------------------------------------
+// CLbtGeoHybrid::NewL()
+//
+// (other items were commented in a header).
+// ---------------------------------------------------------------------------
+//
+EXPORT_C CLbtGeoHybrid* CLbtGeoHybrid::NewL( RPointerArray<CLbtGeoAreaBase>& 
+                                             aHybridArea )
+    {
+    CLbtGeoHybrid* self = CLbtGeoHybrid::NewLC( aHybridArea );
+    CleanupStack::Pop( self );
+    return self;
+    }  
+    
+// ---------------------------------------------------------------------------
+// CLbtGeoHybrid::NewLC()
+//
+// (other items were commented in a header).
+// ---------------------------------------------------------------------------
+//
+EXPORT_C CLbtGeoHybrid* CLbtGeoHybrid::NewLC( RPointerArray<CLbtGeoAreaBase>&
+                                              aHybridArea )
+    {
+    CLbtGeoHybrid* self = new( ELeave ) CLbtGeoHybrid();
+    CleanupStack::PushL( self );
+    self->ConstructL( aHybridArea );
+    return self;
+    }      
+
+// ---------------------------------------------------------------------------
+// CLbtGeoHybrid::CLbtGeoHybrid()
+//
+// Default constructor
+// ---------------------------------------------------------------------------
+//
+CLbtGeoHybrid::CLbtGeoHybrid()
+    {
+                                 
+    }
+    
+// ---------------------------------------------------------------------------
+// CLbtGeoHybrid::ConstructL()
+//
+// ---------------------------------------------------------------------------
+//
+void CLbtGeoHybrid::ConstructL( RPointerArray<CLbtGeoAreaBase>&
+                                aHybridArea )
+    {
+    SetHybridArea( aHybridArea );
+    }
+    
+// ---------------------------------------------------------------------------
+// CLbtGeoHybrid::ConstructL()
+//
+// ---------------------------------------------------------------------------
+//
+void CLbtGeoHybrid::ConstructL()
+    {
+    
+    }      
+     
+
+
+// ---------------------------------------------------------------------------
+// CLbtGeoHybrid::~CLbtGeoHybrid()
+//
+// Destructor.
+// ---------------------------------------------------------------------------
+//
+EXPORT_C CLbtGeoHybrid::~CLbtGeoHybrid()
+    {
+    iHybridArea.ResetAndDestroy();
+    }
+    
+// ---------------------------------------------------------------------------
+// CLbtGeoHybrid::Type()
+//
+// (other items were commented in a header).
+// ---------------------------------------------------------------------------
+//
+CLbtGeoAreaBase::TGeoAreaType CLbtGeoHybrid::Type() const   
+    {
+    return CLbtGeoAreaBase::EHybrid;
+    } 
+    
+// ---------------------------------------------------------------------------
+// CLbtGeoHybrid::SetHybridArea()
+//
+// (other items were commented in a header).
+// ---------------------------------------------------------------------------
+//
+EXPORT_C void CLbtGeoHybrid::SetHybridArea( const RPointerArray<CLbtGeoAreaBase>& 
+                                            aHybridArea )
+    {
+    iHybridArea.ResetAndDestroy();
+    if( aHybridArea.Count() < 2 )
+        {
+        User::Panic( KLbtClientPanicCategory,ELbtErrArgument );
+        }
+    for( TInt i=0;i<aHybridArea.Count();i++ )
+        {
+        if( aHybridArea[i]->Type() != CLbtGeoAreaBase::ECellular )
+            {
+            User::Panic( KLbtClientPanicCategory,ELbtErrArgument );
+            }
+        iHybridArea.Append( aHybridArea[i] );
+        }
+    }
+
+// ---------------------------------------------------------------------------
+// CLbtGeoHybrid::HybridArea()
+//
+// (other items were commented in a header).
+// ---------------------------------------------------------------------------
+//
+EXPORT_C const RPointerArray<CLbtGeoAreaBase>& CLbtGeoHybrid::HybridArea()
+    {
+    return iHybridArea;
+    }
+    
+// ---------------------------------------------------------------------------
+// CLbtGeoHybrid::DoExternalizeL()
+//
+// (other items were commented in a header).
+// ---------------------------------------------------------------------------
+//
+void CLbtGeoHybrid::DoExternalizeL( RWriteStream& aStream ) const
+    {
+    aStream.WriteInt8L( iHybridArea.Count() );
+    for( TInt i=0;i<iHybridArea.Count();i++ )
+        {
+        CLbtGeoAreaBase::TGeoAreaType areaType= iHybridArea[i]->Type();
+        switch( areaType )
+            {
+            case CLbtGeoAreaBase::ECircle:
+                aStream.WriteInt8L(1);
+                break;
+            case CLbtGeoAreaBase::ERectangular:
+                aStream.WriteInt8L(2);
+                break;
+            case CLbtGeoAreaBase::ECellular:    
+                aStream.WriteInt8L(3);
+                break;
+            }
+        iHybridArea[i]->ExternalizeL( aStream );
+        }
+    }    
+    
+// ---------------------------------------------------------------------------
+// CLbtGeoHybrid::DoInternalizeL()
+//
+// (other items were commented in a header).
+// ---------------------------------------------------------------------------
+//
+void CLbtGeoHybrid::DoInternalizeL( RReadStream& aStream ) 
+    {
+    TInt count = aStream.ReadInt8L();
+    for( TInt i=0;i<count;i++ )
+        {
+        TInt areaType = aStream.ReadInt8L();
+        if( areaType == 1 )
+            {
+            CLbtGeoCircle* area= CLbtGeoCircle::NewL();
+            area->InternalizeL(aStream);
+            iHybridArea.Append( area );
+            }
+        else if( areaType == 2 )
+            {
+            CLbtGeoRect* area= CLbtGeoRect::NewL();
+            area->InternalizeL(aStream);
+            iHybridArea.Append( area );
+            }
+        else if( areaType == 3 )
+            {
+            CLbtGeoCell* area= CLbtGeoCell::NewL();
+            area->InternalizeL(aStream);
+            iHybridArea.Append( area );
+            }
+        }
+    }     
+
+// ---------------------------------------------------------------------------
+// CLbtGeoHybrid::ValidateHybridInformationL()
+//
+// (other items were commented in a header).
+// ---------------------------------------------------------------------------
+//
+void CLbtGeoHybrid::ValidateHybridInformationL()
+    {
+    if( iHybridArea.Count() < 2 )
+        {
+        User::Leave( KErrArgument );
+        }
+    for( TInt i=0;i<iHybridArea.Count();i++ )
+        {
+        switch( iHybridArea[i]->Type() )
+            {
+            case CLbtGeoAreaBase::ECircle:
+                {
+                CLbtGeoCircle* circle = static_cast<CLbtGeoCircle*> ( iHybridArea[i] );
+                circle->ValidateCircleInformationL();
+                break;
+                }
+            case CLbtGeoAreaBase::ECellular:    
+                {
+                CLbtGeoCell* cell = static_cast<CLbtGeoCell*> ( iHybridArea[i] );
+                cell->ValidateCellInformationL();
+                break;
+                }
+            }
+        }
+    }
+// end of file
+
+
+