Leaked source code of windows server 2003
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

82 lines
3.4 KiB

  1. //
  2. // Microsoft Windows Media Technologies
  3. // � 1999 Microsoft Corporation. All rights reserved.
  4. //
  5. // Refer to your End User License Agreement for details on your rights/restrictions to use these sample files.
  6. //
  7. // MSHDSP.DLL is a sample WMDM Service Provider(SP) that enumerates fixed drives.
  8. // This sample shows you how to implement an SP according to the WMDM documentation.
  9. // This sample uses fixed drives on your PC to emulate portable media, and
  10. // shows the relationship between different interfaces and objects. Each hard disk
  11. // volume is enumerated as a device and directories and files are enumerated as
  12. // Storage objects under respective devices. You can copy non-SDMI compliant content
  13. // to any device that this SP enumerates. To copy an SDMI compliant content to a
  14. // device, the device must be able to report a hardware embedded serial number.
  15. // Hard disks do not have such serial numbers.
  16. //
  17. // To build this SP, you are recommended to use the MSHDSP.DSP file under Microsoft
  18. // Visual C++ 6.0 and run REGSVR32.EXE to register the resulting MSHDSP.DLL. You can
  19. // then build the sample application from the WMDMAPP directory to see how it gets
  20. // loaded by the application. However, you need to obtain a certificate from
  21. // Microsoft to actually run this SP. This certificate would be in the KEY.C file
  22. // under the INCLUDE directory for one level up.
  23. // MDSPDevice.h : Declaration of the CMDSPDevice
  24. #ifndef __MDSPDEVICE_H_
  25. #define __MDSPDEVICE_H_
  26. /////////////////////////////////////////////////////////////////////////////
  27. // CMDSPDevice
  28. class ATL_NO_VTABLE CMDSPDevice :
  29. public CComObjectRootEx<CComSingleThreadModel>,
  30. public CComCoClass<CMDSPDevice, &CLSID_MDSPDevice>,
  31. public IMDSPDevice, IMDSPDeviceControl
  32. {
  33. public:
  34. CMDSPDevice();
  35. ~CMDSPDevice();
  36. DECLARE_REGISTRY_RESOURCEID(IDR_MDSPDEVICE)
  37. BEGIN_COM_MAP(CMDSPDevice)
  38. COM_INTERFACE_ENTRY(IMDSPDevice)
  39. COM_INTERFACE_ENTRY(IMDSPDeviceControl)
  40. END_COM_MAP()
  41. // IMDSPDevice
  42. public:
  43. HRESULT InitGlobalDeviceInfo();
  44. WCHAR m_wcsName[MAX_PATH];
  45. STDMETHOD(EnumStorage)(/*[out]*/ IMDSPEnumStorage **ppEnumStorage);
  46. STDMETHOD(GetFormatSupport)(_WAVEFORMATEX **pFormatEx,
  47. UINT *pnFormatCount,
  48. LPWSTR **pppwszMimeType,
  49. UINT *pnMimeTypeCount);
  50. STDMETHOD(GetDeviceIcon)(/*[out]*/ ULONG *hIcon);
  51. STDMETHOD(GetStatus)(/*[out]*/ DWORD *pdwStatus);
  52. STDMETHOD(GetPowerSource)(/*[out]*/ DWORD *pdwPowerSource, /*[out]*/ DWORD *pdwPercentRemaining);
  53. STDMETHOD(GetSerialNumber)(/*[out]*/ PWMDMID pSerialNumber, /*[in, out]*/BYTE abMac[WMDM_MAC_LENGTH]);
  54. STDMETHOD(GetType)(/*[out]*/ DWORD *pdwType);
  55. STDMETHOD(GetVersion)(/*[out]*/ DWORD *pdwVersion);
  56. STDMETHOD(GetManufacturer)(/*[out,string,size_is(nMaxChars)]*/ LPWSTR pwszName, /*[in]*/ UINT nMaxChars);
  57. STDMETHOD(GetName)(/*[out,string,size_is(nMaxChars)]*/ LPWSTR pwszName, /*[in]*/ UINT nMaxChars);
  58. STDMETHOD(SendOpaqueCommand)(OPAQUECOMMAND *pCommand);
  59. // IMDSPDeviceControl
  60. STDMETHOD(GetDCStatus)(/*[out]*/ DWORD *pdwStatus);
  61. STDMETHOD(GetCapabilities)(/*[out]*/ DWORD *pdwCapabilitiesMask);
  62. STDMETHOD(Play)();
  63. STDMETHOD(Record)(/*[in]*/ _WAVEFORMATEX *pFormat);
  64. STDMETHOD(Pause)();
  65. STDMETHOD(Resume)();
  66. STDMETHOD(Stop)();
  67. STDMETHOD(Seek)(/*[in]*/ UINT fuMode, /*[in]*/ int nOffset);
  68. protected:
  69. BOOL m_fAlreadyCopiedResFiles;
  70. };
  71. #endif //__MDSPDEVICE_H_