multimediacommsengine/mmcesrv/mmceserver/src/mcecsreceiverbase.cpp
changeset 0 1bce908db942
equal deleted inserted replaced
-1:000000000000 0:1bce908db942
       
     1 /*
       
     2 * Copyright (c) 2005 Nokia Corporation and/or its subsidiary(-ies).
       
     3 * All rights reserved.
       
     4 * This component and the accompanying materials are made available
       
     5 * under the terms of "Eclipse Public License v1.0"
       
     6 * which accompanies this distribution, and is available
       
     7 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
       
     8 *
       
     9 * Initial Contributors:
       
    10 * Nokia Corporation - initial contribution.
       
    11 *
       
    12 * Contributors:
       
    13 *
       
    14 * Description:  
       
    15 *
       
    16 */
       
    17 
       
    18 
       
    19 
       
    20 
       
    21 #include "mcecsreceiverbase.h"
       
    22 #include "mcecsreceivequeue.h"
       
    23 #include "mcecsserveritc.h"
       
    24 #include "mcesrvlogs.h"
       
    25 
       
    26 // -----------------------------------------------------------------------------
       
    27 // CMceCsReceiverBase::ConstructL
       
    28 // -----------------------------------------------------------------------------
       
    29 //
       
    30 void CMceCsReceiverBase::ConstructL ()
       
    31 	{
       
    32     iReceiveQueue = new (ELeave) CMceCsReceiveQueue;
       
    33 	}
       
    34 
       
    35 // -----------------------------------------------------------------------------
       
    36 // CMceCsReceiverBase::CMceCsReceiverBase
       
    37 // -----------------------------------------------------------------------------
       
    38 //
       
    39 CMceCsReceiverBase::CMceCsReceiverBase (CMceCsServerITC& aItc)
       
    40 :iITC (aItc), iClientReadyToReceive (EFalse)
       
    41 	{
       
    42 	}
       
    43 
       
    44 // -----------------------------------------------------------------------------
       
    45 // CMceCsReceiverBase::~CMceCsReceiverBase
       
    46 // -----------------------------------------------------------------------------
       
    47 //
       
    48 CMceCsReceiverBase::~CMceCsReceiverBase()
       
    49 	{
       
    50     delete iReceiveQueue;
       
    51 	}
       
    52 
       
    53 // -----------------------------------------------------------------------------
       
    54 // CMceCsReceiverBase::ClientReadyToReceiveL
       
    55 // -----------------------------------------------------------------------------
       
    56 //
       
    57 void CMceCsReceiverBase::ClientReadyToReceiveL (const RMessage2& aMessage)
       
    58 	{
       
    59     MCESRV_DEBUG("CMceCsReceiverBase::ClientReadyToReceiveL, Entry");
       
    60     
       
    61     __ASSERT_ALWAYS (!iClientReadyToReceive, User::Leave (KErrAlreadyExists));
       
    62     
       
    63     MCESRV_DEBUG("storing ids");
       
    64     
       
    65 	iIds = iITC.ReadMCEIdsL (aMessage);
       
    66 
       
    67     if (iReceiveQueue->IsEmpty())
       
    68 		{
       
    69         iClientReadyToReceive = ETrue;
       
    70         iReceiveRMessage = aMessage;
       
    71 		}
       
    72     else
       
    73 		{
       
    74     	MCESRV_DEBUG("queue not empty") 	
       
    75         const TMceCSReceiveItem& item = iReceiveQueue->First();
       
    76 		TMceMessageBufSizes bufSizes = item.BufSizes();
       
    77         iITC.WriteL (aMessage,item.Ids());
       
    78         iITC.WriteL (aMessage,bufSizes);
       
    79         if (bufSizes.iContentBufSize < 0 && bufSizes.iContextBufSize < 0)
       
    80         	{
       
    81     		MCESRV_DEBUG("removing stored data");
       
    82 			iReceiveQueue->RemoveFirst ();    
       
    83         	}
       
    84         iITC.Complete (aMessage, item.Error());
       
    85         iClientReadyToReceive = EFalse;
       
    86     	MCESRV_DEBUG("event written");
       
    87 		}
       
    88     MCESRV_DEBUG("CMceCsReceiverBase::ClientReadyToReceiveL, Exit");
       
    89 	}
       
    90 
       
    91 // -----------------------------------------------------------------------------
       
    92 // CMceCsReceiverBase::CancelClientReceiveL
       
    93 // -----------------------------------------------------------------------------
       
    94 //
       
    95 void CMceCsReceiverBase::CancelClientReceiveL ()
       
    96 	{
       
    97     __ASSERT_ALWAYS (iClientReadyToReceive, User::Leave (KErrNotFound));
       
    98 
       
    99     iClientReadyToReceive = EFalse;
       
   100     iITC.Complete (iReceiveRMessage, KErrCancel);
       
   101 	}
       
   102 
       
   103 // -----------------------------------------------------------------------------
       
   104 // CMceCsReceiverBase::SendToClientL
       
   105 // -----------------------------------------------------------------------------
       
   106 //       
       
   107 void CMceCsReceiverBase::SendToClientL( TMceIds& aId, TInt aError)
       
   108 	{
       
   109     MCESRV_DEBUG("CMceCsReceiverBase::SendToClientL( ids ), Entry");
       
   110     MCESRV_DEBUG_DVALUE("error", aError );
       
   111 	
       
   112     MCESRV_DEBUG_IDS("IDS", aId );
       
   113 	
       
   114 	TMceCSReceiveItem item(aId, NULL, NULL, aError);
       
   115 	HandleNewReceiveItemL( item );
       
   116 
       
   117     MCESRV_DEBUG("CMceCsReceiverBase::SendToClientL( ids ), Exit");
       
   118 	
       
   119 	}
       
   120 
       
   121 // -----------------------------------------------------------------------------
       
   122 // CMceCsReceiverBase::SendToClientL
       
   123 // -----------------------------------------------------------------------------
       
   124 //       
       
   125 void CMceCsReceiverBase::SendToClientL( TMceIds& aId, HBufC8* aContext )
       
   126 	{
       
   127     MCESRV_DEBUG("CMceCsReceiverBase::SendToClientL( ids, context), Entry");
       
   128 	
       
   129     __ASSERT_ALWAYS (aContext, User::Leave (KErrArgument));
       
   130 
       
   131 	TMceCSReceiveItem item(aId, aContext, NULL, KErrNone);
       
   132 	HandleNewReceiveItemL( item );
       
   133 
       
   134     MCESRV_DEBUG("CMceCsReceiverBase::SendToClientL( ids, context), Exit");
       
   135 	
       
   136 	}
       
   137 
       
   138 // -----------------------------------------------------------------------------
       
   139 // CMceCsReceiverBase::SendToClientL
       
   140 // -----------------------------------------------------------------------------
       
   141 //       
       
   142 void CMceCsReceiverBase::SendToClientL( TMceIds& aId, HBufC8* aContext, HBufC8* aContent )
       
   143 	{
       
   144     MCESRV_DEBUG("CMceCsReceiverBase::SendToClientL( ids, context, content ), Entry");
       
   145 	
       
   146     __ASSERT_ALWAYS (aContext, User::Leave (KErrArgument));
       
   147     __ASSERT_ALWAYS (aContent, User::Leave (KErrArgument));
       
   148 
       
   149 	TMceCSReceiveItem item(aId, aContext, aContent, KErrNone);
       
   150 	HandleNewReceiveItemL( item );
       
   151 	
       
   152     MCESRV_DEBUG("CMceCsReceiverBase::SendToClientL( ids, context, content ), Exit");
       
   153 	
       
   154 	}
       
   155 
       
   156 // -----------------------------------------------------------------------------
       
   157 // CMceCsReceiverBase::Ids
       
   158 // -----------------------------------------------------------------------------
       
   159 //       
       
   160 TMceIds CMceCsReceiverBase::Ids() const
       
   161 	{
       
   162 	return iIds;
       
   163 	}
       
   164 	
       
   165 // -----------------------------------------------------------------------------
       
   166 // CMceCsReceiverBase::ITC
       
   167 // -----------------------------------------------------------------------------
       
   168 //       
       
   169 CMceCsServerITC& CMceCsReceiverBase::ITC()
       
   170     {
       
   171     return iITC;
       
   172     }
       
   173 	
       
   174 
       
   175 // -----------------------------------------------------------------------------
       
   176 // CMceCsReceiverBase::HandleNewReceiveItemL
       
   177 // -----------------------------------------------------------------------------
       
   178 //       
       
   179 void CMceCsReceiverBase::HandleNewReceiveItemL (TMceCSReceiveItem& aItem)
       
   180     {
       
   181     MCESRV_DEBUG("CMceCsReceiverBase::HandleNewReceiveItemL, Entry");
       
   182     
       
   183     if ( iClientReadyToReceive )
       
   184         {
       
   185     	MCESRV_DEBUG("client ready, sending") 	
       
   186 		TMceMessageBufSizes bufSizes = aItem.BufSizes();
       
   187         iITC.WriteL( iReceiveRMessage, aItem.Ids() );
       
   188         iITC.WriteL( iReceiveRMessage, bufSizes );
       
   189         if ( bufSizes.iContentBufSize >= 0 || bufSizes.iContextBufSize >= 0 )
       
   190         	{
       
   191     		MCESRV_DEBUG("stored for receive");
       
   192         	User::LeaveIfError( iReceiveQueue->AddLast( aItem ) );        	
       
   193         	}
       
   194         iITC.Complete ( iReceiveRMessage, aItem.Error() );
       
   195         iClientReadyToReceive = EFalse;
       
   196         }
       
   197     else
       
   198         {
       
   199     	MCESRV_DEBUG("client not ready, storing");
       
   200         User::LeaveIfError( iReceiveQueue->AddLast( aItem ) );
       
   201         }     
       
   202     MCESRV_DEBUG("CMceCsReceiverBase::HandleNewReceiveItemL, Exit");
       
   203     }
       
   204 
       
   205 // -----------------------------------------------------------------------------
       
   206 // CMceCsReceiverBase::ReceiveL
       
   207 // -----------------------------------------------------------------------------
       
   208 //
       
   209 void CMceCsReceiverBase::ReceiveL (const RMessage2& aMessage)
       
   210 	{
       
   211     MCESRV_DEBUG("CMceCsReceiverBase::ReceiveL, Entry");
       
   212 
       
   213     __ASSERT_ALWAYS(!iReceiveQueue->IsEmpty(), User::Leave(KErrNotReady));
       
   214 
       
   215     TMceCSReceiveItem& item = iReceiveQueue->First();
       
   216 	TMceIds ids = iITC.ReadMCEIdsL( aMessage );
       
   217     (void)ids;
       
   218     if ( item.Content() )
       
   219         {
       
   220     	MCESRV_DEBUG_DVALUE("writing context. size", 
       
   221     	    item.Context() ? item.Context()->Length() : 0 );
       
   222     	    
       
   223     	iITC.WriteL( aMessage, *(item.Context()), EMceItcArgContext );
       
   224     	
       
   225     	MCESRV_DEBUG_DVALUE("writing content. size", 
       
   226     	    item.Context() ? item.Content()->Length() : 0 );
       
   227     	    
       
   228     	iITC.WriteL( aMessage, *(item.Content()), EMceItcArgMessageContent );
       
   229         }   
       
   230 	else
       
   231 		{
       
   232     	MCESRV_DEBUG_DVALUE("writing context. size", 
       
   233     	    item.Context() ? item.Context()->Length() : 0 );
       
   234     	iITC.WriteL( aMessage, *(item.Context()), EMceItcArgContext );
       
   235 		}
       
   236 						
       
   237     MCESRV_DEBUG("removing stored data");
       
   238 	iReceiveQueue->RemoveFirst ();
       
   239 	
       
   240     MCESRV_DEBUG("CMceCsReceiverBase::ReceiveL, Exit");
       
   241     
       
   242 	}