telephonyprotocols/umtsgprsscpr/spudfsm/src/tpdpstateopen.cpp
changeset 42 3adadc800673
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/telephonyprotocols/umtsgprsscpr/spudfsm/src/tpdpstateopen.cpp	Fri Jun 11 14:49:29 2010 +0300
@@ -0,0 +1,89 @@
+// Copyright (c) 2004-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:
+// Open state
+// 
+//
+
+/**
+ @file 
+ @internalComponent
+*/
+
+#include <etelpckt.h>
+#include <networking/umtsnifcontrolif.h>
+#include "tpdpstates.h"
+#include "spudfsmdebuglogger.h"
+#include "pdpfsmnmspace.h"
+#include "PDPFSM.h"
+#include "cpdpfsm.h"
+
+TInt TPdpStateOpen::Input (CPdpFsm& aFsm, const TInt aOperation, const TInt aErrorCode)
+{
+	SPUDFSMVERBOSE_FNLOG("TPdpStateOpen::Input()");
+	SPUDFSMVERBOSE_LOG2(_L("aOperation : %S(%d)"), LogOperation(aFsm, aOperation), aOperation);
+
+	switch (aOperation)
+	{
+	case PdpFsm::EQoSProfileChangeNetwork:
+//		//RPacketQoS::TQoSR99_R4Negotiated
+		SpudManNotify (aFsm, KContextParametersChangeEvent, KErrNone);
+		return KErrNone;
+	case PdpFsm::EConfigGPRSChangeNetwork:
+//		//RPacketContext::TContextConfigGPRS
+		SpudManNotify (aFsm, KContextParametersChangeEvent, KErrNone);
+		return KErrNone;
+	case PdpFsm::EContextStatusChangeNetwork:
+		if (aFsm.iContextStatus == RPacketContext::EStatusSuspended)
+    		{
+			aFsm.ChangeStateToSuspended();
+			SpudManNotify(aFsm, KContextBlockedEvent, KErrNone); 
+    		}
+		else if (aFsm.iContextStatus == RPacketContext::EStatusDeleted)
+    		{
+			aFsm.ChangeStateToClosing();
+			EtelDriverInput(aFsm, EtelDriver::EContextDelete);
+    		}
+		else
+    		{
+			// no change in state - the upper layer must change the state if it needs to
+			SpudManNotify (aFsm, KContextParametersChangeEvent, aErrorCode);
+    		}
+		return KErrNone;
+	case SpudMan::EContextDelete:
+		aFsm.ChangeStateToClosing();
+		EtelDriverInput(aFsm, EtelDriver::EContextDelete);
+		return KErrNone;
+	case SpudMan::EContextQoSSet:
+		aFsm.ChangeStateToChangingQoS();
+		EtelDriverInput(aFsm, EtelDriver::ESetQoS);
+		return KErrNone;
+	case SpudMan::EContextModifyActive:
+		aFsm.ChangeStateToModifingActive();
+		EtelDriverInput(aFsm, EtelDriver::EModifyActive);
+		return KErrNone;
+	case SpudMan::EContextTFTModify:
+		aFsm.ChangeStateToChangingTFT();
+		EtelDriverInput(aFsm, EtelDriver::EChangeTft);
+		return KErrNone;
+	case SpudMan::ESuspend: // think this is superfluous - DAN will see at review :)
+		aFsm.ChangeStateToSuspended();
+		SpudManNotify(aFsm, KContextBlockedEvent, KErrNone);
+		return KErrNone;
+	}
+	
+	// default error handling
+	return TPdpState::Input(aFsm, aOperation, aErrorCode);
+}
+
+