cihx2chxdataf.cpp
Upload User: zhongxx05
Upload Date: 2007-06-06
Package Size: 33641k
Code Size: 8k
Category:

Symbian

Development Platform:

C/C++

  1. /* ***** BEGIN LICENSE BLOCK ***** 
  2.  * Version: RCSL 1.0/RPSL 1.0 
  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, are 
  7.  * subject to the current version of the RealNetworks Public Source License 
  8.  * Version 1.0 (the "RPSL") available at 
  9.  * http://www.helixcommunity.org/content/rpsl unless you have licensed 
  10.  * the file under the RealNetworks Community Source License Version 1.0 
  11.  * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl, 
  12.  * in which case the RCSL will apply. You may also obtain the license terms 
  13.  * directly from RealNetworks.  You may not use this file except in 
  14.  * compliance with the RPSL or, if you have a valid RCSL with RealNetworks 
  15.  * applicable to this file, the RCSL.  Please see the applicable RPSL or 
  16.  * RCSL for the rights, obligations and limitations governing use of the 
  17.  * contents of the file.  
  18.  *  
  19.  * This file is part of the Helix DNA Technology. RealNetworks is the 
  20.  * developer of the Original Code and owns the copyrights in the portions 
  21.  * it created. 
  22.  *  
  23.  * This file, and the files included with this file, is distributed and made 
  24.  * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER 
  25.  * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES, 
  26.  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS 
  27.  * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. 
  28.  * 
  29.  * Technology Compatibility Kit Test Suite(s) Location: 
  30.  *    http://www.helixcommunity.org/content/tck 
  31.  * 
  32.  * Contributor(s): 
  33.  *  
  34.  * ***** END LICENSE BLOCK ***** */ 
  35. /****************************************************************************
  36.  *  Includes
  37.  */
  38. #include "hlxclib/string.h"
  39. #include "hlxclib/fcntl.h"
  40. #include "hlxclib/sys/stat.h"
  41. #include "hxbuffer.h"
  42. #include "hxassert.h"
  43. #include "chxdataf.h"
  44. #include "cihx2chxdataf.h"
  45. /****************************************************************************
  46.  *  CIHX2CHXDataFile
  47.  */
  48. /****************************************************************************
  49.  *  Constructor/Destructor
  50.  */
  51. CIHX2CHXDataFile::CIHX2CHXDataFile(UINT32 ulFlags, IUnknown** ppCommonObj)
  52.     : m_pCHXFile(CHXDataFile::Construct(ulFlags, ppCommonObj))
  53.     , m_pFileName(NULL)
  54.     , m_bOpen(FALSE)
  55.     , m_lRefCount(0)
  56. {
  57.     ;
  58. }
  59. CIHX2CHXDataFile::~CIHX2CHXDataFile(void)
  60. {
  61.     HX_DELETE(m_pCHXFile);
  62.     HX_RELEASE(m_pFileName);
  63. }
  64. /****************************************************************************
  65.  *  IHXDataFile methods
  66.  */
  67. STDMETHODIMP_(void) CIHX2CHXDataFile::Bind(const char* pFileName)
  68. {
  69.     if (!m_pFileName)
  70.     {
  71. m_pFileName = new CHXBuffer;
  72. if (m_pFileName)
  73. {
  74.          m_pFileName->AddRef();
  75. }
  76.     }
  77.     if (m_bOpen)
  78.     {
  79. Close();
  80.     }
  81.     if (m_pFileName && pFileName)
  82.     {
  83. if (m_pFileName->Set((UINT8*)pFileName, ::strlen(pFileName) + 1) != HXR_OK)
  84. {
  85.     HX_RELEASE(m_pFileName);
  86. }
  87.     }
  88. }
  89. STDMETHODIMP CIHX2CHXDataFile::Create(UINT16 uOpenMode)
  90. {
  91.     HX_RESULT retVal = HXR_FAIL;
  92.     if (m_pCHXFile)
  93.     {
  94. if (m_pFileName && (m_pFileName->GetSize() != 0))
  95. {
  96.     retVal = HXR_OK;
  97.     if (uOpenMode & HX_FILEFLAG_NOTRUNC)
  98.     {
  99. if (m_pCHXFile->Open((char*) m_pFileName->GetBuffer(),
  100.      HX_FILEFLAG_READ | HX_FILEFLAG_BINARY)
  101.     == HXR_OK)
  102. {
  103.     m_pCHXFile->Close();
  104.     retVal = HXR_FAIL; // file exists - cannot destroy
  105. }
  106.     }
  107.     
  108.     if (retVal == HXR_OK)
  109.     {
  110. retVal = m_pCHXFile->Create((char*) m_pFileName->GetBuffer(), 
  111.     TranslateMode(uOpenMode));
  112.     }
  113.     
  114.     m_bOpen = (retVal == HXR_OK);
  115. }
  116.     }
  117.     return retVal;
  118. }
  119. STDMETHODIMP CIHX2CHXDataFile::Open(UINT16 uOpenMode)
  120. {
  121.     HX_RESULT retVal = HXR_FAIL;
  122.     if (m_pCHXFile)
  123.     {
  124. if (m_pFileName && (m_pFileName->GetSize() != 0))
  125. {
  126.     retVal = m_pCHXFile->Open((char*) m_pFileName->GetBuffer(), 
  127.       TranslateMode(uOpenMode));
  128.     m_bOpen = SUCCEEDED(retVal);
  129. }
  130.     }
  131.     return retVal;
  132. }
  133. STDMETHODIMP CIHX2CHXDataFile::Close()
  134. {
  135.     HX_RESULT retVal = HXR_OK;
  136.     if (m_pCHXFile)
  137.     {
  138. retVal = m_pCHXFile->Close();
  139. m_bOpen = (m_bOpen && FAILED(retVal));
  140.     }
  141.     return retVal;
  142. }
  143. STDMETHODIMP_(BOOL) CIHX2CHXDataFile::Name(REF(IHXBuffer*) pFileName)
  144. {
  145.     if (m_pFileName && (m_pFileName->GetSize() != 0))
  146.     {
  147. pFileName = m_pFileName;
  148. pFileName->AddRef();
  149. return TRUE;
  150.     }
  151.     return FALSE;
  152. }
  153. STDMETHODIMP_(BOOL) CIHX2CHXDataFile::IsOpen()
  154. {
  155.     return m_bOpen;
  156. }
  157. STDMETHODIMP CIHX2CHXDataFile::Seek(ULONG32 offset, UINT16 fromWhere)
  158. {
  159.     HX_RESULT retVal = HXR_FAIL;
  160.     if (m_pCHXFile)
  161.     {
  162. retVal = m_pCHXFile->Seek(offset, fromWhere);
  163.     }
  164.     return retVal;
  165. }
  166. STDMETHODIMP_(ULONG32) CIHX2CHXDataFile::Tell()
  167. {
  168.     ULONG32 ulPos = 0;
  169.     if (m_pCHXFile)
  170.     {
  171. ulPos = m_pCHXFile->Tell();
  172.     }
  173.     return ulPos;
  174. }
  175. STDMETHODIMP_(ULONG32) CIHX2CHXDataFile::Read(REF(IHXBuffer*) pBuf,
  176.       ULONG32 ulSize)
  177. {
  178.     ULONG32 ulBytesRead = 0;
  179.     if (m_pCHXFile)
  180.     {
  181. if (SUCCEEDED(m_pCHXFile->ReadToBuffer(ulSize, &pBuf)))
  182. {
  183.     ulBytesRead = pBuf->GetSize();
  184. }
  185.     }
  186.     return ulBytesRead;
  187. }
  188. STDMETHODIMP_(ULONG32) CIHX2CHXDataFile::Write(REF(IHXBuffer*) pBuf)
  189. {
  190.     ULONG32 ulBytesWritten = 0;
  191.     if (m_pCHXFile)
  192.     {
  193. UINT8* pData = NULL;
  194. ULONG32 ulSize = 0;
  195. if (pBuf->Get(pData, ulSize) == HXR_OK)
  196. {
  197.     ulBytesWritten = m_pCHXFile->Write((const char*) pData, ulSize);
  198. }
  199.     }
  200.     return ulBytesWritten;
  201. }
  202. STDMETHODIMP CIHX2CHXDataFile::Flush()
  203. {
  204.     HX_RESULT retVal = HXR_FAIL;
  205.     if (m_bOpen)
  206.     {
  207. retVal = HXR_OK;
  208.     }
  209.     return retVal;
  210. }
  211. STDMETHODIMP CIHX2CHXDataFile::Stat(struct stat* pStatBuffer)
  212. {
  213.     HX_RESULT retVal = HXR_FAIL;
  214.     if (m_pFileName && (m_pFileName->GetSize() != 0))
  215.     {
  216. retVal = HXR_OK;
  217. if (stat((char*) m_pFileName->GetBuffer(), pStatBuffer) != 0)
  218. {
  219.     retVal = HXR_FAIL;
  220.     if (m_pCHXFile && m_bOpen)
  221.     {
  222. ULONG32 ulSize = m_pCHXFile->GetSize();
  223. retVal = HXR_OK;
  224. if (ulSize == 0)
  225. {
  226.     retVal = m_pCHXFile->GetLastError();
  227. }
  228. if (retVal == HXR_OK)
  229. {
  230.     pStatBuffer->st_mode = 0;
  231.     pStatBuffer->st_size = ulSize;
  232.     pStatBuffer->st_atime = 0;
  233.     pStatBuffer->st_ctime = 0;
  234.     pStatBuffer->st_mtime = 0;
  235.     retVal = HXR_INCOMPLETE;
  236. }
  237.     }
  238. }
  239.     }
  240.     return retVal;
  241. }
  242. STDMETHODIMP CIHX2CHXDataFile::Delete()
  243. {
  244.     HX_RESULT retVal = HXR_FAIL;
  245.     if (m_pCHXFile)
  246.     {
  247. if (m_bOpen)
  248. {
  249.     Close();
  250. }
  251. if (m_pFileName && (m_pFileName->GetSize() != 0))
  252. {
  253.     retVal = m_pCHXFile->Delete((const char*) m_pFileName->GetBuffer());
  254. }
  255.     }
  256.     return retVal;
  257. }
  258. STDMETHODIMP_(INT16) CIHX2CHXDataFile::GetFd()
  259. {
  260.     INT16 iFd = -1;
  261.     if (m_pCHXFile)
  262.     {
  263. iFd = m_pCHXFile->GetFd();
  264.     }
  265.     return iFd;
  266. }
  267. STDMETHODIMP CIHX2CHXDataFile::GetLastError(void)
  268. {
  269.     HX_RESULT retVal = HXR_OK;
  270.     if (m_pCHXFile)
  271.     {
  272. retVal = m_pCHXFile->GetLastError();
  273.     }
  274.     return retVal;
  275. }
  276. STDMETHODIMP_(void) CIHX2CHXDataFile::GetLastError(REF(IHXBuffer*) err)
  277. {
  278.     ;
  279. }
  280. /************************************************************************
  281.  *  Private methods
  282.  */
  283. UINT16 CIHX2CHXDataFile::TranslateMode(UINT16 uOpenMode)
  284. {
  285.     UINT16 uMode = 0;
  286.     
  287.     if ((uOpenMode & HX_FILEFLAG_READ) && (uOpenMode & HX_FILEFLAG_WRITE))
  288.     {
  289. uMode |= O_RDWR;
  290.     }
  291.     else if (uOpenMode & HX_FILEFLAG_READ)
  292.     {
  293. uMode |= O_RDONLY;
  294.     }
  295.     else if (uOpenMode & HX_FILEFLAG_WRITE)
  296.     {
  297. uMode |= O_WRONLY;
  298.     }
  299.     
  300.     if (uOpenMode & HX_FILEFLAG_BINARY)
  301.     {
  302. uMode |= O_BINARY;
  303.     }
  304.     return uMode;
  305. }
  306. /************************************************************************
  307.  *  IUnknown methods
  308.  */
  309. STDMETHODIMP CIHX2CHXDataFile::QueryInterface(REFIID riid, void** ppvObj)
  310. {
  311. QInterfaceList qiList[] =
  312. {
  313. { GET_IIDHANDLE(IID_IUnknown), this },
  314. { GET_IIDHANDLE(IID_IHXDataFile), (IHXDataFile*) this },
  315. };
  316.     return QIFind(qiList, QILISTSIZE(qiList), riid, ppvObj);   
  317. }
  318. STDMETHODIMP_(ULONG32) CIHX2CHXDataFile::AddRef()
  319. {
  320.     return InterlockedIncrement(&m_lRefCount);
  321. }
  322. STDMETHODIMP_(ULONG32) CIHX2CHXDataFile::Release()
  323. {
  324.     if (InterlockedDecrement(&m_lRefCount) > 0)
  325.     {
  326.         return m_lRefCount;
  327.     }
  328.     delete this;
  329.     return 0;
  330. }