imagehandlingutilities/thumbnailmanager/thumbnailclient/src/thumbnailrequestqueue.cpp
changeset 0 2014ca87e772
child 1 235a7fc86938
equal deleted inserted replaced
-1:000000000000 0:2014ca87e772
       
     1 /*
       
     2 * Copyright (c) 2006-2007 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:  Processor object for running thumbnail requests
       
    15 *
       
    16 */
       
    17 
       
    18 
       
    19 #include "thumbnailrequestqueue.h"
       
    20 #include "thumbnailrequestactive.h"
       
    21 #include "thumbnaillog.h"
       
    22 
       
    23 
       
    24 // ======== MEMBER FUNCTIONS ========
       
    25 
       
    26 // ---------------------------------------------------------------------------
       
    27 // CThumbnailRequestQueue::NewL()
       
    28 // Two-phased constructor.
       
    29 // ---------------------------------------------------------------------------
       
    30 //
       
    31 CThumbnailRequestQueue* CThumbnailRequestQueue::NewL()
       
    32     {
       
    33     CThumbnailRequestQueue* self = new( ELeave )CThumbnailRequestQueue();
       
    34     CleanupStack::PushL( self );
       
    35     self->ConstructL();
       
    36     CleanupStack::Pop( self );
       
    37     return self;
       
    38     }
       
    39 
       
    40 
       
    41 // ---------------------------------------------------------------------------
       
    42 // CThumbnailRequestQueue::CThumbnailRequestQueue()
       
    43 // C++ default constructor can NOT contain any code, that might leave.
       
    44 // ---------------------------------------------------------------------------
       
    45 //
       
    46 CThumbnailRequestQueue::CThumbnailRequestQueue()
       
    47     {
       
    48     }
       
    49 
       
    50 
       
    51 // ---------------------------------------------------------------------------
       
    52 // CThumbnailRequestQueue::ConstructL()
       
    53 // Symbian 2nd phase constructor can leave.
       
    54 // ---------------------------------------------------------------------------
       
    55 //
       
    56 void CThumbnailRequestQueue::ConstructL()
       
    57     {
       
    58     iActiveRequests = 0;
       
    59     }
       
    60 
       
    61 
       
    62 // ---------------------------------------------------------------------------
       
    63 // CThumbnailRequestQueue::~CThumbnailRequestQueue()
       
    64 // Destructor.
       
    65 // ---------------------------------------------------------------------------
       
    66 //
       
    67 CThumbnailRequestQueue::~CThumbnailRequestQueue()
       
    68     {
       
    69     TN_DEBUG1( "CThumbnailRequestQueue::~CThumbnailRequestQueue()");
       
    70     
       
    71     iRequests.ResetAndDestroy();
       
    72     
       
    73     TN_DEBUG1( "CThumbnailRequestQueue::~CThumbnailRequestQueue() - All requests deleted");
       
    74     }
       
    75 
       
    76 
       
    77 // ---------------------------------------------------------------------------
       
    78 // CThumbnailRequestQueue::Process()
       
    79 // Activates next request if possible.
       
    80 // ---------------------------------------------------------------------------
       
    81 //
       
    82 void CThumbnailRequestQueue::Process()
       
    83     {
       
    84     TN_DEBUG1( "CThumbnailRequestQueue::Process()");
       
    85     
       
    86     while ( (iActiveRequests < KMaxClientRequests) &&
       
    87             (iRequests.Count() > iActiveRequests) )
       
    88         {             
       
    89         CThumbnailRequestActive* selectedRequest = NULL;
       
    90         TInt priority( KMinTInt );
       
    91         TInt reqPriority;
       
    92         CThumbnailRequestActive* request = NULL;
       
    93         
       
    94         for ( TInt i = 0; i < iRequests.Count(); i++ )
       
    95            {
       
    96            request = iRequests[i];
       
    97 
       
    98            // this task is not yet activated or processed
       
    99            if( request && !request->RequestCompleted() && !request->IsRequestActive()  )
       
   100                {
       
   101                TN_DEBUG4( "CThumbnailRequestQueue::Process() - candidate at %d, id = %d, (0x%08x)", i, 
       
   102                        request->RequestId(), 
       
   103                        request);
       
   104                reqPriority = request->Priority();
       
   105                if ( reqPriority > priority )
       
   106                    {
       
   107                    priority = reqPriority;
       
   108                    selectedRequest = request;
       
   109                    }
       
   110                }
       
   111            }
       
   112         
       
   113         // activate selected
       
   114         if ( selectedRequest )
       
   115            {
       
   116            TN_DEBUG1( "CThumbnailRequestQueue::Process() - starting next request");
       
   117                     
       
   118            TRAPD(err, selectedRequest->StartL());
       
   119            if (err != KErrNone)
       
   120                {
       
   121                iActiveRequests++;
       
   122                }
       
   123            }
       
   124          else
       
   125             {
       
   126             break;
       
   127             }
       
   128         }
       
   129     
       
   130     TN_DEBUG3( "CThumbnailRequestQueue::Process() end - requests: %d, active requests: %d",
       
   131                iRequests.Count(), iActiveRequests );
       
   132     }
       
   133 
       
   134 
       
   135 // ---------------------------------------------------------------------------
       
   136 // CThumbnailRequestQueue::AddRequestL()
       
   137 // Adds new request to the queue.
       
   138 // ---------------------------------------------------------------------------
       
   139 //
       
   140 void CThumbnailRequestQueue::AddRequestL( CThumbnailRequestActive* aRequest )
       
   141     {
       
   142     TN_DEBUG3( "CThumbnailRequestQueue::AddRequestL() - requests: %d, active requests: %d",
       
   143                iRequests.Count(), iActiveRequests );
       
   144     
       
   145     RemoveCompleted(NULL);
       
   146     iRequests.AppendL( aRequest );
       
   147     }
       
   148 
       
   149 void CThumbnailRequestQueue::RemoveCompleted( CThumbnailRequestActive* aRequestAO)
       
   150     {
       
   151     TN_DEBUG3( "CThumbnailRequestQueue::RemoveCompleted() - begin - requests: %d, active requests: %d",
       
   152                iRequests.Count(), iActiveRequests );
       
   153             
       
   154     //process completed queue and remove finished tasks
       
   155     for ( TInt i = iRequests.Count() -1; i >= 0 && iRequests.Count(); i-- )
       
   156          {
       
   157          CThumbnailRequestActive* request = iRequests[i];
       
   158          
       
   159          // remove completed task if it's not active anymore and not this
       
   160          if ( request->RequestCompleted() && !request->IsRequestActive() && aRequestAO != request)
       
   161              {
       
   162              // delete completed task
       
   163              TN_DEBUG3( "CThumbnailRequestQueue::RemoveCompleted() - deleted id = %d (0x%08x)", request->RequestId(), request);
       
   164              delete request;
       
   165              iRequests.Remove( i );
       
   166              }
       
   167          }
       
   168      
       
   169      TN_DEBUG3( "CThumbnailRequestQueue::RemoveCompleted() end - requests: %d, active requests: %d",
       
   170                     iRequests.Count(), iActiveRequests );
       
   171     }
       
   172 
       
   173 
       
   174 // ---------------------------------------------------------------------------
       
   175 // CThumbnailRequestQueue::CancelRequest()
       
   176 // Removes specific request from the queue.
       
   177 // ---------------------------------------------------------------------------
       
   178 //
       
   179 TInt CThumbnailRequestQueue::CancelRequest( const TThumbnailRequestId aRequestId )
       
   180     {
       
   181     TN_DEBUG2( "CThumbnailRequestQueue::CancelRequest() - request ID: %d", aRequestId);
       
   182     
       
   183     TInt res = KErrNotFound;
       
   184 
       
   185     for ( TInt i = iRequests.Count(); --i >= 0; )
       
   186         {
       
   187         CThumbnailRequestActive* request = iRequests[i];
       
   188         if ( request->RequestId() == aRequestId )
       
   189             {
       
   190             // Cancel and remove from queue
       
   191             if (iRequests[i]->IsActive()) 
       
   192                 {
       
   193                 iRequests[i]->Cancel();
       
   194                 
       
   195                 iActiveRequests--;
       
   196                 if(iActiveRequests <= -1)
       
   197                     {
       
   198                     iActiveRequests = 0;
       
   199                     }
       
   200                 
       
   201                 delete request;
       
   202                 iRequests.Remove( i );
       
   203                 
       
   204                 TN_DEBUG2( "CThumbnailRequestQueue::CancelRequest() - canceled request ID: %d", aRequestId);
       
   205                 }
       
   206             else
       
   207                 {
       
   208                 delete request;
       
   209                 iRequests.Remove( i );
       
   210                           
       
   211                 TN_DEBUG2( "CThumbnailRequestQueue::CancelRequest() - removed request ID: %d", aRequestId);
       
   212                 }
       
   213 
       
   214             res = KErrNone;
       
   215             break;
       
   216             }
       
   217         }
       
   218     
       
   219 	RemoveCompleted(NULL);
       
   220 	
       
   221     Process();
       
   222     
       
   223     return res;
       
   224     }
       
   225 
       
   226 
       
   227 // ---------------------------------------------------------------------------
       
   228 // CThumbnailRequestQueue::ChangeReqPriority()
       
   229 // Changes priority of a request.
       
   230 // ---------------------------------------------------------------------------
       
   231 //
       
   232 TInt CThumbnailRequestQueue::ChangePriority( const TThumbnailRequestId aRequestId,
       
   233                                              const TInt aNewPriority )
       
   234     {
       
   235     TN_DEBUG1( "CThumbnailRequestQueue::ChangePriority()");
       
   236     
       
   237     TInt err = KErrNotFound;
       
   238     const TInt count = iRequests.Count();
       
   239     
       
   240     for ( TInt i( 0 ); i < count; i++ )
       
   241         {
       
   242         if ( iRequests[i]->RequestId() == aRequestId )
       
   243             {
       
   244             iRequests[i]->ChangePriority( aNewPriority );
       
   245             
       
   246             err = KErrNone;
       
   247             break;
       
   248             }
       
   249         }
       
   250     
       
   251     return err;
       
   252     }
       
   253 
       
   254 
       
   255 // ---------------------------------------------------------------------------
       
   256 // CThumbnailRequestQueue::RequestComplete()
       
   257 // Completes the request
       
   258 // ---------------------------------------------------------------------------
       
   259 //
       
   260 void CThumbnailRequestQueue::RequestComplete(CThumbnailRequestActive* aRequestAO)
       
   261     {
       
   262     TN_DEBUG2( "CThumbnailRequestQueue::RequestComplete(0x%08x)", aRequestAO);
       
   263     
       
   264     iActiveRequests--;
       
   265     if(iActiveRequests <= -1)
       
   266         {
       
   267         iActiveRequests = 0;
       
   268         }
       
   269     
       
   270     RemoveCompleted( aRequestAO );
       
   271     
       
   272     Process();
       
   273     
       
   274     TN_DEBUG2( "CThumbnailRequestQueue::RequestComplete() end - active requests: %d", iActiveRequests );
       
   275     }
       
   276 
       
   277 
       
   278 // End of file