📄 basehand.h
字号:
/* ***** BEGIN LICENSE BLOCK *****
* Version: RCSL 1.0/RPSL 1.0
*
* Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved.
*
* The contents of this file, and the files included with this file, are
* subject to the current version of the RealNetworks Public Source License
* Version 1.0 (the "RPSL") available at
* http://www.helixcommunity.org/content/rpsl unless you have licensed
* the file under the RealNetworks Community Source License Version 1.0
* (the "RCSL") available at http://www.helixcommunity.org/content/rcsl,
* in which case the RCSL will apply. You may also obtain the license terms
* directly from RealNetworks. You may not use this file except in
* compliance with the RPSL or, if you have a valid RCSL with RealNetworks
* applicable to this file, the RCSL. Please see the applicable RPSL or
* RCSL for the rights, obligations and limitations governing use of the
* contents of the file.
*
* This file is part of the Helix DNA Technology. RealNetworks is the
* developer of the Original Code and owns the copyrights in the portions
* it created.
*
* This file, and the files included with this file, is distributed and made
* available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
* EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES,
* INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS
* FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
*
* Technology Compatibility Kit Test Suite(s) Location:
* http://www.helixcommunity.org/content/tck
*
* Contributor(s):
*
* ***** END LICENSE BLOCK ***** */
#ifndef _BASEHAND_H_
#define _BASEHAND_H_
#include "hxphand.h"
#include "unkimp.h"
#include "hxslist.h"
#include "hxmap.h"
// Plugin Types.
#define PLUGIN_FILESYSTEM_TYPE "PLUGIN_FILE_SYSTEM"
#define PLUGIN_FILEFORMAT_TYPE "PLUGIN_FILE_FORMAT"
#define PLUGIN_FILEWRITER_TYPE "PLUGIN_FILE_WRITER"
#define PLUGIN_METAFILEFORMAT_TYPE "PLUGIN_METAFILE_FORMAT"
#define PLUGIN_RENDERER_TYPE "PLUGIN_RENDERER"
#define PLUGIN_STREAM_DESC_TYPE "PLUGIN_STREAM_DESC"
#define PLUGIN_CLASS_FACTORY_TYPE "PLUGIN_CLASS_FACT"
#define PLUGIN_PAC_TYPE "PLUGIN_PAC"
#define PLUGIN_CLASS "PluginType"
#define PLUGIN_FILENAME "PluginFilename"
#define PLUGIN_REGKEY_ROOT "PluginHandlerData"
#define PLUGIN_PLUGININFO "PluginInfo"
#define PLUGIN_GUIDINFO "GUIDInfo"
#define PLUGIN_NONHXINFO "NonHXDLLs"
#define PLUGIN_DESCRIPTION2 "Description"
#define PLUGIN_FILE_HASH "FileHash"
#define PLUGIN_INDEX "IndexNumber"
#define PLUGIN_FILENAMES "FileInfo"
#define PLUGIN_COPYRIGHT2 "Copyright"
#define PLUGIN_LOADMULTIPLE "LoadMultiple"
#define PLUGIN_VERSION "Version"
#define PLUGIN_FILESYSTEMSHORT "FileShort"
#define PLUGIN_FILESYSTEMPROTOCOL "FileProtocol"
#define PLUGIN_FILEMIMETYPES "FileMime"
#define PLUGIN_FILEEXTENSIONS "FileExtensions"
#define PLUGIN_FILEOPENNAMES "FileOpenNames"
#define PLUGIN_RENDERER_MIME "RendererMime"
#define PLUGIN_RENDERER_GRANULARITY "Renderer_Granularity"
#define PLUGIN_STREAMDESCRIPTION "StreamDescription"
#define PLUGIN_NUM_PLUGINS "NumPlugins"
#define PLUGIN_FILE_CHECKSUM "DLLCheckSum"
#define PLUGIN_DLL_SIZE "DLLSize"
#define PLUGIN_HAS_FACTORY "DLLHasFactory"
typedef HX_RESULT (HXEXPORT_PTR FPCREATEINSTANCE) (IUnknown** /*OUT*/ ppIUnknown);
typedef HX_RESULT (HXEXPORT_PTR FPSHUTDOWN) ();
typedef HX_RESULT (HXEXPORT_PTR FPCANUNLOAD2) ();
class DLLAccess;
class CFindFile;
class BaseHandler : public CUnknownIMP,
public IHXPluginEnumerator,
public IHXPlugin2Handler,
public IHXPluginHandler3
{
class PluginMountPoint;
class PluginDLL;
class Plugin;
class OtherDLL;
friend class CPluginEnumerator;
friend class PluginDLL;
friend class Plugin;
friend class OtherDLL;
public:
enum Errors
{
NO_ERRORS = 0,
PLUGIN_NOT_FOUND,
MEMORY_ERROR,
CANT_OPEN_DLL,
BAD_DLL,
CREATE_INSTANCHXR_FAILURE,
CANT_DETERMINE_PLUGIN_DIR,
CANT_OPEN_PLUGIN_DIR,
BAD_PLUGIN,
INVALID_CONTEXT,
CANT_GET_FILE_FORMAT_INFO,
CANT_GET_RENDERER_INFO,
CANT_GET_FILE_SYSTEM_INFO,
CANT_LOAD_INTERFACE,
SHORT_NAME_NOT_FOUND,
PLUGIN_ALREADY_HAS_MOUNT_POINT,
INVALID_SHORT_NAME,
BAD_REGISTRY_HANDLE,
PLUGIN_DIR_NOT_SAME,
REQUIRED_PLUGIN_NOT_LOADED,
NO_HX_CREATE_INSTANCE,
AGGREGATION_NOT_SUPPORTED
};
enum eValueTypes
{
eString,
eBuffer,
eInt
};
DECLARE_UNKNOWN_NOCREATE( BaseHandler )
DECLARE_COM_CREATE_FUNCS( BaseHandler )
BaseHandler();
~BaseHandler();
/*
* IHXPluginEnumerator methods
*/
/************************************************************************
* Method:
* IHXPluginEnumerator::GetNumOfPlugins
*
* Purpose:
* return the number of plugins available
*
*/
STDMETHOD_(ULONG32,GetNumOfPlugins) (THIS);
/************************************************************************
* Method:
* IHXPluginEnumerator::GetPlugin
* Purpose:
* return an instance(IUnknown) of the plugin
*
*/
STDMETHOD(GetPlugin) (THIS_
ULONG32 /*IN*/ ulIndex,
REF(IUnknown*) /*OUT*/ pPlugin);
/*
* IHXPlugin2Handler
*/
/************************************************************************
* Method:
* IHXPlugin2Handler::Init
*
* Purpose:
* Specifies the context and sets the BaseHandler in motion.
*
*/
STDMETHOD(Init) (THIS_ IUnknown* pContext);
/************************************************************************
* Method:
* IHXPlugin2Handler::GetNumPlugins2
*
* Purpose:
* Gets the info of a particular plugin.
*
*/
STDMETHOD_(ULONG32,GetNumOfPlugins2) (THIS);
/************************************************************************
* Method:
* IHXPlugin2Handler::GetPluginInfo
*
* Purpose:
* Gets the info of a particular plugin.
*
*/
STDMETHOD(GetPluginInfo) (THIS_
UINT32 unIndex,
REF(IHXValues*) /*OUT*/ Values) ;
/************************************************************************
* Method:
* IHXPlugin2Handler::FlushCache()
*
* Purpose:
* Flushes the LRU cache -- Unloads all DLLs from memory
* which currenltly have a refcount of 0.
*/
STDMETHOD(FlushCache) (THIS);
/************************************************************************
* Method:
* IHXPlugin2Handler::SetCacheSize
*
* Purpose:
* This function sets the size of the Cache. The cache is
* initally set to 1000KB. To disable the cache simply set
* the size to 0.If the cache is disabled a DLL will be
* unloaded whenever it's refcount becomes zero. Which MAY
* cause performance problems.
*/
STDMETHOD(SetCacheSize) (THIS_ ULONG32 nSizeKB);
/************************************************************************
* Method:
* IHXPlugin2Handler::ReadFromRegistry
*
* Purpose:
* Reload the DLL information from the registery. It will also
* Check to see if this information is valid, and if
*/
STDMETHOD(ReadFromRegistry)(THIS);
/************************************************************************
* Method:
* IHXPlugin2Handler::GetInstance
*
* Purpose:
*
* This function will return a plugin instance given a plugin index.
*
*/
STDMETHOD(GetInstance) (THIS_ UINT32 index, REF(IUnknown*) ppUnknown);
/************************************************************************
* Method:
* IHXPlugin2Handler::FindReturnIndexUsingValues
*
* Purpose:
* Finds a plugin which matches the set of values given. An index
* is returned which can be used to either get the values (using
* GetPluginInfo) or an instance can be created using GetPluing().
*
*/
STDMETHOD(FindIndexUsingValues) (THIS_ IHXValues*,
REF(UINT32) unIndex);
/************************************************************************
* Method:
* IHXPlugin2Handler::FindReturnPluginUsingValues
*
* Purpose:
* Finds a plugin which matches the set of values given. A Plugin
* instance is returned.
*
*/
STDMETHOD(FindPluginUsingValues) (THIS_ IHXValues*,
REF(IUnknown*) pUnk);
/************************************************************************
* Method:
* IHXPlugin2Handler::FindReturnIndexUsingStrings
*
* Purpose:
* Finds a plugin which matches the set of values given. An index
* is returned which can be used to either get the values (using
* GetPluginInfo) or an instance can be created using GetPluing().
* NOTE: that a max of two values may be given.
*/
STDMETHOD(FindIndexUsingStrings) (THIS_ char* PropName1,
char* PropVal1,
char* PropName2,
char* PropVal2,
char* PropName3,
char* PropVal3,
REF(UINT32) unIndex);
/************************************************************************
* Method:
* IHXPlugin2Handler::FindReturnPluginUsingStrings
*
* Purpose:
* Finds a plugin which matches the set of values given. A Plugin
* instance is returned.
* NOTE: that a max of two values may be given.
*/
STDMETHOD(FindPluginUsingStrings) (THIS_ char* PropName1,
char* PropVal1,
char* PropName2,
char* PropVal2,
char* PropName3,
char* PropVal3,
REF(IUnknown*) pUnk);
/************************************************************************
* Method:
* IHXPlugin2Handler::FindImplementationFromClassID
*
* Purpose:
* Finds a CommonClassFactory plugin which supports the
* ClassID given. An instance of the Class is returned.
*/
STDMETHOD(FindImplementationFromClassID)
(
REFGUID GUIDClassID,
REF(IUnknown*) pIUnknownInstance
);
/************************************************************************
* Method:
* IHXPlugin2Handler::Close
*
* Purpose:
* A function which performs all of the functions of delete.
*
*
*/
STDMETHOD(Close) (THIS);
/************************************************************************
* Method:
* IHXPlugin2Handler::SetRequiredPlugins
*
* Purpose:
* This function sets the required plugin list
*
*
*/
STDMETHOD(SetRequiredPlugins) (THIS_ const char** ppszRequiredPlugins);
/************************************************************************
* Method:
* IHXPluginHandler3::RegisterContext
*
* Purpose:
* Sets up the context without loading any plugin info
*
*/
STDMETHOD( RegisterContext )( THIS_ IUnknown* pContext );
/************************************************************************
* Method:
* IHXPluginHandler3::AddPluginMountPoint
*
* Purpose:
*
*/
STDMETHOD( AddPluginMountPoint )( THIS_ const char* pName, UINT32 majorVersion,
UINT32 minorVersion, IHXBuffer* pPath );
/************************************************************************
* Method:
* IHXPluginHandler3::RefreshPluginMountPoint
*
* Purpose:
*
*/
STDMETHOD( RefreshPluginMountPoint )( THIS_ const char* pName );
/************************************************************************
* Method:
* IHXPluginHandler3::RemovePluginMountPoint
*
* Purpose:
*
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -