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

Symbian

开发平台:

Visual C++

  1. /* ***** BEGIN LICENSE BLOCK *****
  2.  * Source last modified: $Id: symbian_dll_map.cpp,v 1.1.2.3 2004/07/09 01:43:27 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 "platform/symbian/symbian_dll_map.h"
  50. #include "hxassert.h"
  51. class DLLMapInfo
  52. {
  53. public:
  54.     DLLMapInfo(void* pEntryPoint);
  55.     ~DLLMapInfo();
  56.     void* EntryPoint() const { return m_pEntryPoint;}
  57.     void OnLoad() {m_ulCount++;}
  58.     BOOL OnUnload();
  59. private:
  60.     void DoCleanup();
  61.     void* m_pEntryPoint;
  62.     UINT32 m_ulCount;
  63. };
  64. DLLMapInfo::DLLMapInfo(void* pEntryPoint) :
  65.     m_pEntryPoint(pEntryPoint),
  66.     m_ulCount(0)
  67. {}
  68. DLLMapInfo::~DLLMapInfo()
  69. {
  70.     if (m_ulCount != 0)
  71.     {
  72. DoCleanup();
  73.     }
  74. }
  75. BOOL DLLMapInfo::OnUnload()
  76. {
  77.     BOOL bRet = FALSE;
  78.     HX_ASSERT(m_ulCount);
  79.     if (m_ulCount > 0)
  80.     {
  81. m_ulCount--;
  82. if (m_ulCount == 0)
  83. {
  84.     DoCleanup();
  85.     bRet = TRUE;
  86. }
  87.     }
  88.     return bRet;
  89. }
  90. void DLLMapInfo::DoCleanup()
  91. {
  92. #ifdef _ARM
  93.     // Make the device behave like the emulator.
  94.     // The emulator calls E32Dll(EDllProcessDetach) when 
  95.     // Close() is called on the library handle. This does
  96.     // not occur on the device so we've added this code
  97.     // to do it.
  98.     TLibraryEntry pEntry = (TLibraryEntry)m_pEntryPoint;
  99.     
  100.     if (pEntry)
  101.     {
  102. pEntry(EDllProcessDetach);
  103.     }
  104. #endif
  105. }
  106. SymbianDLLMapImp::SymbianDLLMapImp()
  107. {}
  108. SymbianDLLMapImp::~SymbianDLLMapImp()
  109. {
  110.     HX_ASSERT(m_libList.IsEmpty());
  111.     while(!m_libList.IsEmpty())
  112.     {
  113. DLLMapInfo* pTmp = (DLLMapInfo*)m_libList.RemoveHead();
  114. HX_DELETE(pTmp);
  115.     }
  116. }
  117. void SymbianDLLMapImp::OnLoad(void* pDLLEntryPoint)
  118. {
  119.     DLLMapInfo* pInfo = FindInfo(pDLLEntryPoint);
  120.     if (!pInfo)
  121.     {
  122. pInfo = new DLLMapInfo(pDLLEntryPoint);
  123. if (pInfo && !m_libList.AddHead(pInfo))
  124. {
  125.     // The AddHead() failed
  126.     HX_DELETE(pInfo);
  127. }
  128.     }
  129.     if (pInfo)
  130.     {
  131. pInfo->OnLoad();
  132.     }
  133. }
  134. void SymbianDLLMapImp::OnUnload(void* pDLLEntryPoint)
  135. {
  136.     DLLMapInfo* pInfo = FindInfo(pDLLEntryPoint);
  137.     HX_ASSERT(pInfo);
  138.     if (pInfo)
  139.     {
  140. if (pInfo->OnUnload())
  141. {
  142.     // This was the last unload for this DLL.
  143.     // Remove it from our list and destroy the info
  144.     
  145.     LISTPOSITION pos = m_libList.GetHeadPosition();
  146.     while(pInfo && pos)
  147.     {
  148. if (pInfo == (DLLMapInfo*)m_libList.GetAt(pos))
  149. {
  150.     m_libList.RemoveAt(pos);
  151.     HX_DELETE(pInfo);
  152. }
  153. else
  154. {
  155.     m_libList.GetNext(pos);
  156. }
  157.     }
  158. }
  159.     }
  160. }
  161. DLLMapInfo* SymbianDLLMapImp::FindInfo(void* pDLLEntryPoint)
  162. {
  163.     DLLMapInfo* pRet = NULL;
  164.     CHXSimpleList::Iterator itr = m_libList.Begin();
  165.     for(; !pRet && (itr != m_libList.End()); ++itr)
  166.     {
  167. DLLMapInfo* pTmp = (DLLMapInfo*)*itr;
  168. if (pTmp && (pTmp->EntryPoint() == pDLLEntryPoint))
  169. {
  170.     pRet = pTmp;
  171. }
  172.     }
  173.     return pRet;
  174. }