wlanutilities/wlansniffer/engine/server/src/wsfservercloser.cpp
branchRCL_3
changeset 25 f28ada11abbf
parent 0 56b72877c1cb
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/wlanutilities/wlansniffer/engine/server/src/wsfservercloser.cpp	Wed Sep 01 12:20:32 2010 +0100
@@ -0,0 +1,141 @@
+/*
+* Copyright (c) 2007-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 CWsfServerCloser
+*
+*/
+
+
+//  CLASS HEADER
+#include "wsfserver.h"
+
+
+/**
+* Timeout after all closing requirements are met (in microseconds)
+*/
+static const TInt KServerClosureWaitTimer = 2 * 1000 * 1000; 
+
+
+// ---------------------------------------------------------------------------
+// CWsfServer::CWsfServerCloser::NewL
+// ---------------------------------------------------------------------------
+//		
+CWsfServer::CWsfServerCloser* CWsfServer::CWsfServerCloser::NewL()
+	{
+	CWsfServer::CWsfServerCloser* thisPtr = new (ELeave) CWsfServerCloser();
+	CleanupStack::PushL( thisPtr );
+	thisPtr->ConstructL();
+	CleanupStack::Pop( thisPtr );
+	return thisPtr;
+	}
+
+
+// ---------------------------------------------------------------------------
+// CWsfServer::CWsfServerCloser::~CWsfServerCloser
+// ---------------------------------------------------------------------------
+//		
+CWsfServer::CWsfServerCloser::~CWsfServerCloser()
+	{
+	Cancel();
+	}
+
+
+// ---------------------------------------------------------------------------
+// CWsfServer::CWsfServerCloser::CWsfServerCloser
+// ---------------------------------------------------------------------------
+//		
+CWsfServer::CWsfServerCloser::CWsfServerCloser(): 
+    CTimer( CActive::EPriorityStandard ),
+    iWaitForOwnedConnection( EFalse ),
+    iWaitForBrowserExit( EFalse ),
+    iWaitForClients( EFalse )
+    {
+	CActiveScheduler::Add( this );
+	}
+
+
+// ---------------------------------------------------------------------------
+// CWsfServer::CWsfServerCloser::ConstructL
+// ---------------------------------------------------------------------------
+//		
+void CWsfServer::CWsfServerCloser::ConstructL()
+	{
+	CTimer::ConstructL();
+	}
+
+
+// ---------------------------------------------------------------------------
+// CWsfServer::CWsfServerCloser::RunL
+// ---------------------------------------------------------------------------
+//		
+void CWsfServer::CWsfServerCloser::RunL()
+	{
+	CActiveScheduler::Stop();
+	}
+
+
+// ---------------------------------------------------------------------------
+// CWsfServer::CWsfServerCloser::StartClosureWait
+// ---------------------------------------------------------------------------
+//		
+void CWsfServer::CWsfServerCloser::StartClosureWait()
+	{
+	Cancel();
+	
+	if ( !iWaitForClients && !iWaitForBrowserExit && !iWaitForOwnedConnection )
+	    {
+	    After( TTimeIntervalMicroSeconds32( KServerClosureWaitTimer ) );
+	    }	
+	}
+
+
+// ---------------------------------------------------------------------------
+// CWsfServer::CWsfServerCloser::WaitForClients
+// ---------------------------------------------------------------------------
+//		
+void CWsfServer::CWsfServerCloser::WaitForClients( TBool aWait )
+    {
+    iWaitForClients = aWait;
+    if ( !aWait )
+        {
+        StartClosureWait();
+        }
+    }
+
+// ---------------------------------------------------------------------------
+// CWsfServer::CWsfServerCloser::WaitForOwnedConnection
+// ---------------------------------------------------------------------------
+//		
+void CWsfServer::CWsfServerCloser::WaitForOwnedConnection( TBool aWait )
+    {
+    iWaitForOwnedConnection = aWait;
+    if ( !aWait )
+        {
+        StartClosureWait();
+        }
+    }
+    
+    
+// ---------------------------------------------------------------------------
+// CWsfServer::CWsfServerCloser::WaitForBrowserExit
+// ---------------------------------------------------------------------------
+//		
+void CWsfServer::CWsfServerCloser::WaitForBrowserExit( TBool aWait )
+    {
+    iWaitForBrowserExit = aWait;
+    if ( !aWait )
+        {
+        StartClosureWait();
+        }
+    }
+