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

Symbian

开发平台:

Visual C++

  1. /* ***** BEGIN LICENSE BLOCK *****
  2.  * Source last modified: $Id: shadvsrc.h,v 1.1.26.1 2004/07/09 01:57:20 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. #ifndef _SHADVSRC_H_
  50. #define _SHADVSRC_H_
  51. class CShadowViewSource :   public IHXFileResponse,
  52.     public IHXFileStatResponse,
  53.     public IHXFileViewSource
  54. {
  55. private:
  56.     IHXFileViewSourceResponse* m_pViewSourceResponse;
  57.     SOURCE_TYPE m_type;
  58.     
  59.     IHXFileObject* m_pFileObject;
  60.     IUnknown* m_pContext;
  61.     IHXCommonClassFactory* m_pCommonClassFactory;
  62.     CHXFragmentedBuffer* m_pBuffer;
  63.     LONG32 m_lRefCount;
  64.     IUnknown* m_pContainer;
  65.     IHXValues* m_pOptions;
  66.     ~CShadowViewSource();
  67.     PRIVATE_DESTRUCTORS_ARE_NOT_A_CRIME
  68. public:
  69.     CShadowViewSource(IUnknown* pContext, IUnknown* pContainer);
  70.         // *** IUnknown methods ***
  71.     STDMETHOD(QueryInterface) (THIS_
  72. REFIID riid,
  73. void** ppvObj);
  74.     STDMETHOD_(ULONG32,AddRef) (THIS);
  75.     STDMETHOD_(ULONG32,Release) (THIS);
  76.     /************************************************************************
  77.      * Method:
  78.      *     IHXFileViewSource::InitViewSource
  79.      * Purpose:
  80.      *     Called by the user to init before a viewsource.
  81.      */
  82.     STDMETHOD(InitViewSource) (THIS_
  83. IHXFileObject* pFileObject,
  84. IHXFileViewSourceResponse* pResp,
  85. SOURCE_TYPE sourceType,
  86. IHXValues* pOptions);
  87.     /************************************************************************
  88.      * Method:
  89.      *     IHXFileViewSource::GetHTMLSource
  90.      * Purpose:
  91.      *     Called to get source html source.  Return the source
  92.      * through m_pViewSourceResoponse
  93.      */
  94.     STDMETHOD(GetSource)(THIS);
  95.     /************************************************************************
  96.      * Method:
  97.      *     IHXFileViewSource::Close()
  98.      * Purpose:
  99.      *     Called to shut things down
  100.      * Shared with IHXFileFormatObject
  101.      */
  102.     STDMETHOD(Close) (THIS);
  103.     /************************************************************************
  104.      * Method:
  105.      *     IHXFileStatResponse::StatDone(...)
  106.      * Purpose:
  107.      *     Called in response to our request for a stat.
  108.      */
  109.     STDMETHOD(StatDone) (THIS_
  110.  HX_RESULT status,
  111.  UINT32 ulSize,
  112.  UINT32 ulCreationTime,
  113.  UINT32 ulAccessTime,
  114.  UINT32 ulModificationTime,
  115.  UINT32 ulMode);
  116.     /************************************************************************
  117.     *  Method:
  118.     *    IHXFileResponse::InitDone
  119.     *  Purpose:
  120.     *    Notification interface provided by users of the IHXFileObject
  121.     *    interface. This method is called by the IHXFileObject when the
  122.     *    initialization of the file is complete, and the Mime type is
  123.     *    available for the request file. If the URL is not valid for the
  124.     *    file system, the status HXR_FAILED should be returned,
  125.     *    with a mime type of NULL. If the URL is valid but the mime type
  126.     *    is unknown, then the status HXR_OK should be returned with
  127.     *    a mime type of NULL.
  128.     */
  129.     STDMETHOD(InitDone)     (THIS_
  130.     HX_RESULT     status);
  131.     /************************************************************************
  132.     *  Method:
  133.     *   IHXFileResponse::CloseDone
  134.     *  Purpose:
  135.     *   Notification interface provided by users of the IHXFileObject
  136.     *   interface. This method is called by the IHXFileObject when the
  137.     *   close of the file is complete.
  138.     */
  139.     STDMETHOD(CloseDone) (THIS_
  140. HX_RESULT status);
  141.     /************************************************************************
  142.     *  Method:
  143.     *   IHXFileResponse::ReadDone
  144.     *  Purpose:
  145.     *   Notification interface provided by users of the IHXFileObject
  146.     *   interface. This method is called by the IHXFileObject when the
  147.     *   last read from the file is complete and a buffer is available.
  148.     */
  149.     STDMETHOD(ReadDone) (THIS_ 
  150. HX_RESULT     status,
  151. IHXBuffer*     pBuffer);
  152.     /************************************************************************
  153.     *  Method:
  154.     *   IHXFileResponse::WriteDone
  155.     *  Purpose:
  156.     *   Notification interface provided by users of the IHXFileObject
  157.     *   interface. This method is called by the IHXFileObject when the
  158.     *   last write to the file is complete.
  159.     */
  160.     STDMETHOD(WriteDone) (THIS_ 
  161. HX_RESULT     status);
  162.     /************************************************************************
  163.     *  Method:
  164.     *   IHXFileResponse::SeekDone
  165.     *  Purpose:
  166.     *   Notification interface provided by users of the IHXFileObject
  167.     *   interface. This method is called by the IHXFileObject when the
  168.     *   last seek in the file is complete.
  169.     */
  170.     STDMETHOD(SeekDone) (THIS_ 
  171. HX_RESULT     status);
  172. };
  173. #endif // _SHADVSRC_H_