windows-nt/Source/XPSP1/NT/shell/shell32/hwcmmn.h

115 lines
3.6 KiB
C
Raw Normal View History

2020-09-26 03:20:57 -05:00
#ifndef _HWCMMN_H
#define _HWCMMN_H
#define CT_AUTORUNINF 0x00000001
#define CT_CDAUDIO 0x00000002
#define CT_DVDMOVIE 0x00000004
#define CT_UNKNOWNCONTENT 0x00000008
#define CT_BLANKCDR 0x00000010
#define CT_BLANKCDRW 0x00000020
#define CT_BLANKDVDR 0x00000040
#define CT_BLANKDVDRW 0x00000080
#define CT_AUTOPLAYMUSIC 0x00000100
#define CT_AUTOPLAYPIX 0x00000200
#define CT_AUTOPLAYMOVIE 0x00000400
// Will not be returned by CMountPoint::GetContentType
#define CT_AUTOPLAYMIXEDCONTENT 0x00000800
#define CT_ANYCONTENT 0x00000FFF
#define CT_ANYAUTOPLAYCONTENT ( CT_AUTOPLAYMUSIC | \
CT_AUTOPLAYPIX | \
CT_AUTOPLAYMOVIE)
#define CT_BLANKCDWRITABLE ( CT_BLANKCDR | \
CT_BLANKCDRW )
#define CT_BLANKDVDWRITABLE ( CT_BLANKDVDR | \
CT_BLANKDVDRW )
BOOL IsShellServiceRunning();
HRESULT _GetAutoplayHandler(LPCWSTR pszDeviceID, LPCWSTR pszEventType,
LPCWSTR pszContentTypeHandler, IAutoplayHandler** ppiah);
HRESULT _GetAutoplayHandlerNoContent(LPCWSTR pszDeviceID, LPCWSTR pszEventType,
IAutoplayHandler** ppiah);
HRESULT _GetHWDevice(LPCWSTR pszDeviceID, IHWDevice** ppihwdevice);
STDAPI GetDeviceProperties(LPCWSTR pszDeviceID, IHWDeviceCustomProperties** ppihwdevcp);
HICON _GetIconFromIconLocation(LPCWSTR pszIconLocation, BOOL fBigIcon);
HRESULT _GetDeviceEventFriendlyName(LPCWSTR pszDeviceID, LPWSTR* ppsz);
HRESULT _GetHardwareDevices(IHardwareDevices** ppihwdevices);
HRESULT _GetContentTypeInfo(DWORD dwContentType, LPWSTR pszContentTypeFriendlyName,
DWORD cchContentTypeFriendlyName, LPWSTR pszContentTypeIconLocation,
DWORD cchContentTypeIconLocation);
HRESULT _GetContentTypeHandler(DWORD dwContentType, LPWSTR pszContentTypeHandler,
DWORD cchContentTypeHandler);
HRESULT _GetHandlerInvokeProgIDAndVerb(LPCWSTR pszHandler, LPWSTR pszInvokeProgID,
DWORD cchInvokeProgID, LPWSTR pszInvokeVerb, DWORD cchInvokeVerb);
struct AUTOPLAYPROMPT
{
WCHAR szDriveOrDeviceID[MAX_PATH];
BOOL fDlgWillBeShown;
HWND hwndDlg;
class CCrossThreadFlag* pDeviceGoneFlag;
};
HRESULT DoDeviceNotification(LPCTSTR pszDevice, LPCTSTR pszEventType, CCrossThreadFlag* pDeviceGoneFlag);
BOOL GetGoneFlagForDevice(LPCWSTR pszAltDeviceID, CCrossThreadFlag** ppDeviceGoneFlag);
void AttachGoneFlagForDevice(LPCWSTR pszAltDeviceID, CCrossThreadFlag* pDeviceGoneFlag);
BOOL IsMixedContent(DWORD dwContentType);
class CRefCounted
{
public:
CRefCounted() : _cRCRef(1) {}
virtual ~CRefCounted() {}
ULONG AddRef() { return ::InterlockedIncrement((LONG*)&_cRCRef); }
ULONG Release()
{
ULONG cRef = ::InterlockedDecrement((LONG*)&_cRCRef);
if (!cRef)
{
delete this;
}
return cRef;
}
private:
ULONG _cRCRef; // RC: to avoid name colision
};
// The event is created in the NON-signaled state
// Since it's cross-thread it should always be created on the heap
class CCrossThreadFlag : public CRefCounted
{
public:
BOOL Init();
BOOL Signal();
BOOL IsSignaled();
private:
~CCrossThreadFlag();
HANDLE _hEvent;
#ifdef DEBUG
BOOL _fInited;
#endif
};
#endif //_HWCMMN_H