hxsockcallback.cpp
上传用户:dangjiwu
上传日期:2013-07-19
资源大小:42019k
文件大小:5k
源码类别:

Symbian

开发平台:

Visual C++

  1. /* ***** BEGIN LICENSE BLOCK *****
  2.  * Source last modified: $Id: hxsockcallback.cpp,v 1.3.20.1 2004/07/09 02:09:08 hubbe Exp $
  3.  * 
  4.  * Portions Copyright (c) 1995-2004 RealNetworks, Inc. All Rights Reserved.
  5.  * 
  6.  * The contents of this file, and the files included with this file,
  7.  * are subject to the current version of the RealNetworks Public
  8.  * Source License (the "RPSL") available at
  9.  * http://www.helixcommunity.org/content/rpsl unless you have licensed
  10.  * the file under the current version of the RealNetworks Community
  11.  * Source License (the "RCSL") available at
  12.  * http://www.helixcommunity.org/content/rcsl, in which case the RCSL
  13.  * will apply. You may also obtain the license terms directly from
  14.  * RealNetworks.  You may not use this file except in compliance with
  15.  * the RPSL or, if you have a valid RCSL with RealNetworks applicable
  16.  * to this file, the RCSL.  Please see the applicable RPSL or RCSL for
  17.  * the rights, obligations and limitations governing use of the
  18.  * contents of the file.
  19.  * 
  20.  * Alternatively, the contents of this file may be used under the
  21.  * terms of the GNU General Public License Version 2 or later (the
  22.  * "GPL") in which case the provisions of the GPL are applicable
  23.  * instead of those above. If you wish to allow use of your version of
  24.  * this file only under the terms of the GPL, and not to allow others
  25.  * to use your version of this file under the terms of either the RPSL
  26.  * or RCSL, indicate your decision by deleting the provisions above
  27.  * and replace them with the notice and other provisions required by
  28.  * the GPL. If you do not delete the provisions above, a recipient may
  29.  * use your version of this file under the terms of any one of the
  30.  * RPSL, the RCSL or the GPL.
  31.  * 
  32.  * This file is part of the Helix DNA Technology. RealNetworks is the
  33.  * developer of the Original Code and owns the copyrights in the
  34.  * portions it created.
  35.  * 
  36.  * This file, and the files included with this file, is distributed
  37.  * and made available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY
  38.  * KIND, EITHER EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS
  39.  * ALL SUCH WARRANTIES, INCLUDING WITHOUT LIMITATION, ANY WARRANTIES
  40.  * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, QUIET
  41.  * ENJOYMENT OR NON-INFRINGEMENT.
  42.  * 
  43.  * Technology Compatibility Kit Test Suite(s) Location:
  44.  *    http://www.helixcommunity.org/content/tck
  45.  * 
  46.  * Contributor(s):
  47.  * 
  48.  * ***** END LICENSE BLOCK ***** */
  49. #include "hxsockcallback.h"
  50. ScheduledSocketCallback::ScheduledSocketCallback(
  51. SocketCallbackInterface *owner,
  52. BOOL interruptSafe) :
  53.      m_lRefCount (0)
  54.     ,m_pSocket (owner)
  55.     ,m_Handle (0)
  56.     ,m_Error(HXR_OK)
  57.     ,m_bIsCallbackPending(FALSE)
  58.     ,m_bInterruptSafe(interruptSafe)
  59. {
  60. }
  61. ScheduledSocketCallback::~ScheduledSocketCallback()
  62. {
  63. }
  64. /*
  65.  * IUnknown methods
  66.  */
  67. /////////////////////////////////////////////////////////////////////////
  68. // Method:
  69. // IUnknown::QueryInterface
  70. // Purpose:
  71. // Implement this to export the interfaces supported by your 
  72. // object.
  73. //
  74. STDMETHODIMP ScheduledSocketCallback::QueryInterface(REFIID riid, void** ppvObj)
  75. {
  76.     QInterfaceList qiList[] =
  77.         {
  78.             { GET_IIDHANDLE(IID_IHXCallback), (IHXCallback*)this },
  79.             { GET_IIDHANDLE(IID_IHXInterruptSafe), (IHXInterruptSafe*)this },
  80.             { GET_IIDHANDLE(IID_IUnknown), (IUnknown*)(IHXCallback*)this },
  81.         };
  82.     
  83.     return ::QIFind(qiList, QILISTSIZE(qiList), riid, ppvObj);
  84. }
  85. /////////////////////////////////////////////////////////////////////////
  86. // Method:
  87. // IUnknown::AddRef
  88. // Purpose:
  89. // Everyone usually implements this the same... feel free to use
  90. // this implementation.
  91. //
  92. STDMETHODIMP_(ULONG32) ScheduledSocketCallback::AddRef()
  93. {
  94.     return InterlockedIncrement(&m_lRefCount);
  95. }
  96. /////////////////////////////////////////////////////////////////////////
  97. // Method:
  98. // IUnknown::Release
  99. // Purpose:
  100. // Everyone usually implements this the same... feel free to use
  101. // this implementation.
  102. //
  103. STDMETHODIMP_(ULONG32) ScheduledSocketCallback::Release()
  104. {
  105.     if (InterlockedDecrement(&m_lRefCount) > 0)
  106.     {
  107. return m_lRefCount;
  108.     }
  109.     delete this;
  110.     return 0;
  111. }
  112. /*
  113.  * UDPSchedulerCallback methods
  114.  */
  115. STDMETHODIMP_(BOOL) ScheduledSocketCallback::ScheduleCallback(
  116. INT32  theCommand,
  117. IHXScheduler* theScheduler,
  118. ULONG32 theTime,
  119. HX_RESULT theError)
  120. {
  121. if (m_pSocket && theScheduler && !m_bIsCallbackPending)
  122. {
  123.   m_bIsCallbackPending = TRUE;
  124.    m_Command = theCommand;
  125.    m_Error = theError;
  126. m_Handle = theScheduler->RelativeEnter(this, theTime);
  127. return TRUE;
  128. }
  129.     return FALSE;
  130. }
  131. /*
  132.  * UDPSchedulerCallback methods
  133.  */
  134. void ScheduledSocketCallback::Unschedule(
  135. IHXScheduler* theScheduler)
  136. {
  137. if (m_bIsCallbackPending && theScheduler)
  138. {
  139. theScheduler->Remove(m_Handle);
  140. m_bIsCallbackPending = FALSE;
  141. m_Handle = 0;
  142.     }
  143. }
  144. STDMETHODIMP ScheduledSocketCallback::Func(void)
  145. {
  146.     HX_RESULT theErr = HXR_OK;
  147.     m_Handle = 0;
  148.     m_bIsCallbackPending = FALSE;
  149.     if (m_pSocket)
  150.      theErr = m_pSocket->HandleCallback(m_Command, m_Error);
  151.     return theErr;
  152. }
  153. /*
  154.  *  IHXInterruptSafe methods 
  155.  */
  156. STDMETHODIMP_(BOOL)
  157. ScheduledSocketCallback::IsInterruptSafe(void) 
  158. {
  159.     return m_bInterruptSafe; 
  160. }