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

Symbian

开发平台:

Visual C++

  1. /* ***** BEGIN LICENSE BLOCK *****
  2.  * Source last modified: $Id: hxopwaveresolv.cpp,v 1.4.18.1 2004/07/09 02:08:44 hubbe Exp $
  3.  * 
  4.  * * Portions Copyright (c) 1995-2002 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 "hxopwaveresolv.h"
  50. #include "debug.h"
  51. #include "smartptr.h"
  52. #define D_RESOLVER 0x10000000
  53. //#define NO_OPENWAVE_DNS
  54. UINT32 HXOpwaveResolver::ubMaxHostNameLen = 256L;
  55. HXOpwaveResolver::HXOpwaveResolver() 
  56. : OpDNSRequest()
  57. , m_lRefCount(0)
  58. , m_pResponse(0)
  59. , m_psHostname(NULL)
  60. , m_bInitialized(FALSE)
  61. , m_nNumAddr(0)
  62. , m_nCurAddrIndex(0)
  63. , m_dnsStatus(HXR_OK)
  64. {
  65. }
  66. HXOpwaveResolver::~HXOpwaveResolver()
  67. {
  68.     
  69.     HX_RELEASE(m_pResponse);
  70.     HX_DELETE(m_psHostname);
  71. }
  72. /*
  73. *  IUnknown methods
  74. */
  75. STDMETHODIMP HXOpwaveResolver::QueryInterface(THIS_
  76.                                               REFIID riid,
  77.                                               void** ppvObj)
  78. {
  79.     
  80.     if (IsEqualIID(riid, IID_IHXResolver))
  81.     {
  82.         
  83.         AddRef();
  84.         *ppvObj = (IHXResolver*)this;
  85.         return HXR_OK;
  86.     }
  87.     else if (IsEqualIID(riid, IID_IUnknown))
  88.     {
  89.         AddRef();
  90.         *ppvObj = (IUnknown*)(IHXResolver*)this;
  91.         return HXR_OK;
  92.     }
  93.     
  94.     
  95.     *ppvObj = NULL;
  96.     return HXR_NOINTERFACE;
  97.     
  98. }
  99. STDMETHODIMP_(ULONG32) HXOpwaveResolver::AddRef(THIS)
  100. {
  101.     
  102.     return InterlockedIncrement(&m_lRefCount);
  103.     
  104. }
  105. STDMETHODIMP_(ULONG32)HXOpwaveResolver::Release(THIS)
  106. {
  107.     
  108.     if (InterlockedDecrement(&m_lRefCount) > 0)
  109.     {
  110.         return m_lRefCount;
  111.     }
  112.     
  113.     delete this;
  114.     return 0;
  115. }
  116. /*
  117. * IHXResolver methods
  118. */
  119. STDMETHODIMP HXOpwaveResolver::Init(THIS_ IHXResolverResponse*  pResponse)
  120. {
  121.     
  122.     DPRINTF(D_RESOLVER, ("HXOpwaveResolver::Init()n"));
  123.     
  124.     HX_RELEASE(m_pResponse);
  125.     m_pResponse = pResponse;
  126.     
  127.     if (m_pResponse)
  128.     {
  129.         m_pResponse->AddRef();
  130.     }
  131.     
  132.     m_bInitialized = TRUE;
  133.     return  HXR_OK;
  134.     
  135. }
  136. STDMETHODIMP HXOpwaveResolver::GetHostByName(THIS_ const char* pHostName)
  137. {
  138.     
  139.     DPRINTF(D_RESOLVER, ("HXOpwaveResolver::GetHostByName(%s)n", pHostName));
  140.     
  141.     HX_RESULT res = HXR_OK;
  142.     
  143.     if (!pHostName)
  144.     {
  145.         res = HXR_INVALID_PARAMETER;
  146.     }
  147.     
  148.     if (SUCCEEDED(res))
  149.     {
  150.         if (!m_psHostname)
  151.         {
  152.             m_psHostname = new char[ubMaxHostNameLen];
  153.             if (!m_psHostname)
  154.             {
  155.                 res = HXR_OUTOFMEMORY;
  156.             }
  157.         }
  158.     }
  159.     if (SUCCEEDED(res))
  160.     {
  161.         strncpy(m_psHostname, pHostName, ubMaxHostNameLen);
  162.         lookupAddr(m_psHostname);
  163.     }
  164. #ifdef NO_OPENWAVE_DNS
  165. /// Suppose the pHostName is in decimal form like
  166. /// 207.188.30.91, we convert it here manually into a UINT32
  167.     UINT32 ipv4Host = 0;
  168.     char* pStop = pHostName;
  169.     char* pHead = pHostName;
  170.     INT32 nShift = 24;
  171.     while (nShift >= 0)
  172.     {
  173.         UINT32 ulTemp = strtoul(pHead, &pStop, 10);
  174.         ipv4Host += ulTemp << nShift;
  175.         pHead = pStop + 1;
  176.         nShift -= 8;
  177.     }
  178.     m_pResponse->GetHostByNameDone(m_dnsStatus, ipv4Host);
  179. #endif
  180.     return res;
  181.     
  182. }
  183. /// OpDNSRequest callback to notify requests
  184. void 
  185. HXOpwaveResolver::onAddrResult(const ipv4_t *addrs, unsigned numAddrs)
  186. {
  187.     m_nNumAddr = numAddrs;
  188.     if (addrs && m_nNumAddr > 0)
  189.     {
  190.         m_nCurAddrIndex = 0;
  191.         m_pResponse->GetHostByNameDone(m_dnsStatus, addrs[m_nCurAddrIndex]);
  192.     }
  193. }
  194. void
  195. HXOpwaveResolver::onErrorResult()
  196. {
  197.     m_dnsStatus = HXR_FAIL;
  198. }