mirror of
				https://github.com/halpz/re3.git
				synced 2025-10-25 04:17:16 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			679 lines
		
	
	
		
			22 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			679 lines
		
	
	
		
			22 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| //---------------------------------------------------------------------
 | |
| //
 | |
| //  Copyright (c) 1999-2002 Microsoft Corporation
 | |
| //
 | |
| //  BDATIF.idl
 | |
| //
 | |
| //---------------------------------------------------------------------
 | |
| 
 | |
| cpp_quote("//+-------------------------------------------------------------------------")
 | |
| cpp_quote("//")
 | |
| cpp_quote("//  Microsoft Windows")
 | |
| cpp_quote("//  Copyright (C) Microsoft Corporation, 1999-2002.")
 | |
| cpp_quote("//")
 | |
| cpp_quote("//--------------------------------------------------------------------------")
 | |
| cpp_quote("#if ( _MSC_VER >= 800 )")
 | |
| cpp_quote("#pragma warning(disable:4201)    /* Nameless struct/union */")
 | |
| cpp_quote("#endif")
 | |
| cpp_quote("#if ( _MSC_VER >= 1020 )")
 | |
| cpp_quote("#pragma once")
 | |
| cpp_quote("#endif")
 | |
| 
 | |
| 
 | |
| //---------------------------------------------------------------------
 | |
| // IUnknown import idl
 | |
| //---------------------------------------------------------------------
 | |
| 
 | |
| #ifndef DO_NO_IMPORTS
 | |
| import "unknwn.idl";
 | |
| import "strmif.idl";
 | |
| import "tuner.idl";
 | |
| import "bdaiface.idl";
 | |
| #endif
 | |
| 
 | |
| 
 | |
| interface IMPEG2_TIF_CONTROL;
 | |
| interface IATSCChannelInfo;
 | |
| interface IMPEG2PIDMap;
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| //******************************************************************************
 | |
| //
 | |
| //  IBDA_TIF_REGISTRATION interface
 | |
| //
 | |
| //  Implemented by the Microsoft ATSC/DVB BDA Network Provider
 | |
| //
 | |
| //      Used by a transport information filter (TIF) to Register with the NP 
 | |
| //	AND obtain an Interface to the Demux to set/ Remove PIDs.The TIF here passes 
 | |
| //      IUNKNOWN of the pin it is connecting to and obtains the IMPEG2PIDMAP interface
 | |
| //      implemented by the NP to Map/ UnMap pids.
 | |
| //
 | |
| 
 | |
| [
 | |
|     object,
 | |
|     uuid(DFEF4A68-EE61-415f-9CCB-CD95F2F98A3A),
 | |
|     helpstring("BDA Network Provider Registration Inteface for DVB/ATSC Transport Information Filters"),
 | |
|     pointer_default(unique)
 | |
| ]
 | |
| interface IBDA_TIF_REGISTRATION : IUnknown
 | |
| {
 | |
| 
 | |
|     [helpstring("Used to register a transport analyzer with the Network Provider")]
 | |
|     HRESULT
 | |
|     RegisterTIFEx (
 | |
|         [in]  IPin *    pTIFInputPin,
 | |
|         [in, out] ULONG *   ppvRegistrationContext,
 | |
|         [in, out] IUnknown **    ppMpeg2DataControl
 | |
|         );
 | |
| 
 | |
|     [helpstring("Used to unregister TIF with the Network Provider")]
 | |
|     HRESULT
 | |
|     UnregisterTIF (
 | |
|         [in] ULONG          pvRegistrationContext
 | |
|         );
 | |
| }
 | |
| 
 | |
| 
 | |
| //******************************************************************************
 | |
| //
 | |
| //  IMPEG2_TIF_CONTROL interface
 | |
| //
 | |
| //  Implemented by the Microsoft ATSC/DVB BDA Network Provider
 | |
| //
 | |
| //      Used by a transport information filter (TIF) to request table
 | |
| //      sections carried on specific PIDs within the transport stream.
 | |
| //      The Network Provider Filter will, in turn, do the necessary
 | |
| //      control on the Demux Filter. All sections are delivered as comlete
 | |
| //      mpeg2 table sections via the TIF's connection to the Demux Filter.
 | |
| //
 | |
| [
 | |
|     object,
 | |
|     uuid(F9BAC2F9-4149-4916-B2EF-FAA202326862),
 | |
|     helpstring("BDA Network Provider Inteface for DVB/ATSC Transport Information Filters"),
 | |
|     pointer_default(unique)
 | |
| ]
 | |
| interface IMPEG2_TIF_CONTROL : IUnknown
 | |
| {
 | |
| 
 | |
|     [helpstring("Used to register a transport analyzer with the Network Provider")]
 | |
|     HRESULT
 | |
|     RegisterTIF (
 | |
|         [in]  IUnknown *    pUnkTIF,
 | |
|         [in, out] ULONG *   ppvRegistrationContext
 | |
| 	);
 | |
| 
 | |
|     [helpstring("Used to unregister TIF with the Network Provider")]
 | |
|     HRESULT
 | |
|     UnregisterTIF (
 | |
|         [in] ULONG          pvRegistrationContext
 | |
|         );
 | |
| 
 | |
|     [helpstring("Used to add PSI/SI MPEG2 packet IDs to the TIF's data stream")]
 | |
|     HRESULT
 | |
|     AddPIDs (
 | |
|         [in] ULONG      ulcPIDs,
 | |
|         [in] ULONG *    pulPIDs
 | |
|         );
 | |
| 
 | |
|     [helpstring("Used to remove PSI/SI MPEG2 packet IDs from the TIF's data stream")]
 | |
|     HRESULT
 | |
|     DeletePIDs (
 | |
|         [in] ULONG      ulcPIDs,
 | |
|         [in] ULONG *    pulPIDs
 | |
|         );
 | |
| 
 | |
|     [helpstring("Returns the number of MPEG2 Packet IDs being filtered into the TIF's input data.")]
 | |
|     HRESULT
 | |
|     GetPIDCount (
 | |
|         [out] ULONG *   pulcPIDs
 | |
|         );
 | |
| 
 | |
|     [helpstring("Returns the the list of MPEG2 Packet IDs being filtered into the TIF's input data.")]
 | |
|     HRESULT
 | |
|     GetPIDs (
 | |
|         [out] ULONG *   pulcPIDs,
 | |
|         [out] ULONG *   pulPIDs
 | |
|         );
 | |
| 
 | |
| }
 | |
| 
 | |
| 
 | |
| //******************************************************************************
 | |
| //
 | |
| //  ITuneRequestInfo interface
 | |
| //
 | |
| //  Implemented by a BDA transport information filter (TIF)
 | |
| //
 | |
| //      Used by the BDA Network Provider to obtain network specific
 | |
| //      information about locating transport streams and aquiring
 | |
| //      services.
 | |
| //
 | |
| //
 | |
| //      GetLocatorData -
 | |
| //
 | |
| //      GetComponentData -
 | |
| //
 | |
| //      CreateComponentList -
 | |
| //
 | |
| //      GetNextService -
 | |
| //
 | |
| //      GetPreviouService -
 | |
| //
 | |
| //      GetNextLocator -
 | |
| //
 | |
| //      GetPreviousLocator -
 | |
| //
 | |
| [
 | |
|     object,
 | |
|     uuid(A3B152DF-7A90-4218-AC54-9830BEE8C0B6),
 | |
|     helpstring("Interface provided by the Mpeg2 Transport Information Filter to supply tuning details."),
 | |
|     pointer_default(unique)
 | |
| ]
 | |
| interface ITuneRequestInfo : IUnknown
 | |
| {
 | |
| 
 | |
|     [helpstring("TIF fills in channel/program locator information for the given tune request.")]
 | |
|     HRESULT
 | |
|     GetLocatorData (
 | |
|         [in]  ITuneRequest *Request
 | |
|         );
 | |
| 
 | |
|     [helpstring("TIF fills in all network specific component data for the existing component list on the given tune request.")]
 | |
|     HRESULT
 | |
|     GetComponentData (
 | |
|         [in]  ITuneRequest *CurrentRequest
 | |
|         );
 | |
| 
 | |
|     [helpstring("TIF creates a complete component list and fills in all network specific component data on the given tune request")]
 | |
|     HRESULT
 | |
|     CreateComponentList (
 | |
|         [in]  ITuneRequest *CurrentRequest
 | |
|         );
 | |
| 
 | |
|     [helpstring("TIF creates a new TuneRequest with channel/program locator information for the next service.")]
 | |
|     HRESULT
 | |
|     GetNextProgram (
 | |
|         [in]  ITuneRequest *CurrentRequest,
 | |
|         [out, retval] ITuneRequest **TuneRequest
 | |
|         );
 | |
| 
 | |
|     [helpstring("TIF creates a new TuneRequest with channel/program locator information for the previous service.")]
 | |
|     HRESULT
 | |
|     GetPreviousProgram (
 | |
|         [in]  ITuneRequest *CurrentRequest,
 | |
|         [out, retval] ITuneRequest **TuneRequest
 | |
|         );
 | |
| 
 | |
|     [helpstring("TIF creates a new TuneRequest with locator information for the next transport stream.")]
 | |
|     HRESULT
 | |
|     GetNextLocator (
 | |
|         [in]  ITuneRequest *CurrentRequest,
 | |
|         [out, retval] ITuneRequest **TuneRequest
 | |
|         );
 | |
| 
 | |
|     [helpstring("TIF creates a new TuneRequest with locator information for the previous transport stream.")]
 | |
|     HRESULT
 | |
|     GetPreviousLocator (
 | |
|         [in]  ITuneRequest *CurrentRequest,
 | |
|         [out, retval] ITuneRequest **TuneRequest
 | |
|         );
 | |
| }
 | |
|     
 | |
| 
 | |
| //******************************************************************************
 | |
| //
 | |
| //  IGuideDataEvent
 | |
| //
 | |
| //  This is the guide data event notification callback interface.  The
 | |
| //  callback interface is registered on a transport analyzer's
 | |
| //  IConnectionPoint by the event consumer.
 | |
| //
 | |
| //  The event consumer MUST NOT BLOCK THE CALLING THREAD.
 | |
| //
 | |
| //  If the consumer requires additional information about the event, it
 | |
| //  should queue the event to a separate thread.    
 | |
| //
 | |
| // {EFDA0C80-F395-42c3-9B3C-56B37DEC7BB7}
 | |
| //
 | |
| [
 | |
|     object,
 | |
|     uuid(EFDA0C80-F395-42c3-9B3C-56B37DEC7BB7),
 | |
|     helpstring("Consumers of a guide data events must implement this callback interface."),
 | |
|     pointer_default(unique)
 | |
| ]
 | |
| interface IGuideDataEvent : IUnknown
 | |
| {
 | |
|     //  Indicates that a complete set of guide data has been acquire from
 | |
|     //  the current transport stream.
 | |
|     //
 | |
|     //  MANDATORY - If a transport analyzer supports IGuideDataEvent then
 | |
|     //              it must supply this event.
 | |
|     //
 | |
|     HRESULT GuideDataAcquired(
 | |
|         );
 | |
|         
 | |
|     //  Indicates that information about one or more programs changed.
 | |
|     //
 | |
|     //  If varProgramDescriptionID is NULL then the consumer
 | |
|     //  must get properties for all programs to determine which ones
 | |
|     //  changed.
 | |
|     //
 | |
|     //  MANDATORY - If a transport analyzer supports IGuideDataEvent then
 | |
|     //              it must supply this event.
 | |
|     //
 | |
|     HRESULT ProgramChanged(
 | |
|         [in] VARIANT    varProgramDescriptionID
 | |
|         );
 | |
|         
 | |
|     //  Indicates that information about one or more services changed.
 | |
|     //
 | |
|     //  If varServiceDescriptionID is NULL then the consumer
 | |
|     //  must get properties for all services to determine which ones
 | |
|     //  changed.
 | |
|     //
 | |
|     //  MANDATORY - If a transport analyzer supports IGuideDataEvent then
 | |
|     //              it must supply this event.
 | |
|     //
 | |
|     HRESULT ServiceChanged(
 | |
|         [in] VARIANT    varServiceDescriptionID
 | |
|         );
 | |
|         
 | |
|     //  Indicates that information about one or more schedule entries
 | |
|     //  changed.
 | |
|     //
 | |
|     //  If varScheduleEntryDescriptionID is NULL then the consumer
 | |
|     //  must get properties for all schedule entries to determine which ones
 | |
|     //  changed.
 | |
|     //
 | |
|     //  MANDATORY - If a transport analyzer supports IGuideDataEvent then
 | |
|     //              it must supply this event.
 | |
|     //
 | |
|     HRESULT ScheduleEntryChanged(
 | |
|         [in] VARIANT    varScheduleEntryDescriptionID
 | |
|         );
 | |
|         
 | |
|     //  Indicates that the program with the given Description.ID
 | |
|     //  has been deleted.
 | |
|     //  
 | |
|     //
 | |
|     //  Optional - Transport analyzer may supply this event.  Consumer
 | |
|     //             may return E_NOTIMPL.   
 | |
|     //
 | |
|     HRESULT ProgramDeleted(
 | |
|         [in] VARIANT    varProgramDescriptionID
 | |
|         );
 | |
|         
 | |
|     //  Indicates that the service with the given Description.ID
 | |
|     //  has been deleted.
 | |
|     //  
 | |
|     //
 | |
|     //  Optional - Transport analyzer may supply this event.  Consumer
 | |
|     //             may return E_NOTIMPL.   
 | |
|     //
 | |
|     HRESULT ServiceDeleted(
 | |
|         [in] VARIANT    varServiceDescriptionID
 | |
|         );
 | |
|         
 | |
|         
 | |
|     //  Indicates that the schedule entry with the given Description.ID
 | |
|     //  has been deleted.
 | |
|     //  
 | |
|     //
 | |
|     //  Optional - Transport analyzer may supply this event.  Consumer
 | |
|     //             may return E_NOTIMPL.   
 | |
|     //
 | |
|     HRESULT ScheduleDeleted(
 | |
|         [in] VARIANT    varScheduleEntryDescriptionID
 | |
|         );
 | |
| }
 | |
|     
 | |
| 
 | |
| //******************************************************************************
 | |
| //
 | |
| //  IGuideDataPropery
 | |
| //
 | |
| // {88EC5E58-BB73-41d6-99CE-66C524B8B591}
 | |
| //
 | |
| [
 | |
|     object,
 | |
|     uuid(88EC5E58-BB73-41d6-99CE-66C524B8B591),
 | |
|     helpstring("Interface provided by a transport analyzer to represent a guide data property."),
 | |
|     pointer_default(unique)
 | |
| ]
 | |
| interface IGuideDataProperty : IUnknown
 | |
| {
 | |
|     [propget] HRESULT Name([out] BSTR *pbstrName);
 | |
|     [propget] HRESULT Language([out] long *idLang);
 | |
|     [propget] HRESULT Value([out] VARIANT *pvar);
 | |
| }
 | |
| 
 | |
| 
 | |
| //******************************************************************************
 | |
| //
 | |
| //  IEnumGuideDataProperties
 | |
| //
 | |
| // {AE44423B-4571-475c-AD2C-F40A771D80EF}
 | |
| //
 | |
| [
 | |
|     object,
 | |
|     uuid(AE44423B-4571-475c-AD2C-F40A771D80EF),
 | |
|     helpstring("Interface provided by a transport analyzer to enumerate guide data properties."),
 | |
|     pointer_default(unique)
 | |
| ]
 | |
| interface IEnumGuideDataProperties : IUnknown
 | |
| {
 | |
|     HRESULT Next([in] unsigned long celt, [out] IGuideDataProperty **ppprop, [out] unsigned long *pcelt);
 | |
|     HRESULT Skip([in] unsigned long celt);
 | |
|     HRESULT Reset();
 | |
|     HRESULT Clone([out] IEnumGuideDataProperties **ppenum);
 | |
| }
 | |
| 
 | |
| 
 | |
| //******************************************************************************
 | |
| //
 | |
| //  IEnumTuneRequests
 | |
| //
 | |
| // {1993299C-CED6-4788-87A3-420067DCE0C7}
 | |
| //
 | |
| [
 | |
|     object,
 | |
|     uuid(1993299C-CED6-4788-87A3-420067DCE0C7),
 | |
|     helpstring("Interface provided by a transport analyzer to enumerate service tune requests ."),
 | |
|     pointer_default(unique)
 | |
| ]
 | |
| interface IEnumTuneRequests : IUnknown
 | |
| {
 | |
|     HRESULT Next([in] unsigned long celt, [out] ITuneRequest **ppprop, [out] unsigned long *pcelt);
 | |
|     HRESULT Skip([in] unsigned long celt);
 | |
|     HRESULT Reset();
 | |
|     HRESULT Clone([out] IEnumTuneRequests **ppenum);
 | |
| }
 | |
| 
 | |
| 
 | |
| //******************************************************************************
 | |
| //
 | |
| //  IGuideData
 | |
| //
 | |
| // {61571138-5B01-43cd-AEAF-60B784A0BF93}
 | |
| //
 | |
| [
 | |
|     object,
 | |
|     uuid(61571138-5B01-43cd-AEAF-60B784A0BF93),
 | |
|     helpstring("Interface provided by a transport analyzer to supply guide data information."),
 | |
|     pointer_default(unique)
 | |
| ]
 | |
| interface IGuideData : IUnknown
 | |
| {
 | |
|     //-------------------------------------------------------------------------
 | |
|     //
 | |
|     //  GetServices
 | |
|     //      Returns an enumeration of tune requests for all services whose
 | |
| 	//		information is found in the current transport stream.
 | |
|     //
 | |
|     //  Parameters
 | |
|     //
 | |
|     //      IEnumTuneRequests **
 | |
|     //          Location in which a reference to the resulting
 | |
|     //          IEnumTuneRequests is placed.  The caller must release
 | |
|     //          this reference when finished with it.
 | |
|     //
 | |
|     //  Comments
 | |
|     //      This call is used to enumerate all services whose information
 | |
| 	//		can be found in the service descriptor table. Each tune request
 | |
| 	//		in the IEnumTuneRequest * contains the tune request including the
 | |
| 	//		locator data for the service.
 | |
|     // 
 | |
|     [helpstring("Returns an enumeration of services whose information is found in the given transport stream")]
 | |
|     HRESULT
 | |
|     GetServices (
 | |
|         [out, retval]  IEnumTuneRequests **      ppEnumTuneRequests
 | |
|         );
 | |
| 
 | |
| 
 | |
|     //-------------------------------------------------------------------------
 | |
|     //
 | |
|     //  GetServiceProperties
 | |
|     //      Returns an enumeration of all guide data properties for
 | |
|     //      the service with the given Description.ID.
 | |
|     //
 | |
|     //  Parameters
 | |
|     //      ITuneRequest *  
 | |
|     //          Pointer to a tune request that contains information needed
 | |
|     //          to indentify the requested transport stream.
 | |
|     //          A NULL ITuneRequest * indicates that information about the
 | |
|     //          current transport stream is requested.
 | |
|     //
 | |
|     //      IEnumGuideDataProperties **
 | |
|     //          Location in which a reference to the resulting
 | |
|     //          IEnumGuideDataProperties is placed.  The caller must release
 | |
|     //          this reference when finished with it.
 | |
|     //
 | |
|     //  Required Properties
 | |
|     //      The following properties MUST be included in the returned
 | |
|     //      property enumeration.
 | |
|     //
 | |
|     //      Description.ID
 | |
|     //          Uniquely identifies a service.
 | |
|     //
 | |
|     //      Description.Name
 | |
|     //          The default name to use for this service in the channel lineup.
 | |
|     //
 | |
|     //      Description.Version
 | |
|     //          Identifies the current version of the properties associated
 | |
|     //          with this service.
 | |
|     //
 | |
|     //      Provider.Name
 | |
|     //          Name of the service provider (e.g. "KCTS")
 | |
|     //
 | |
|     //      Provider.NetworkName
 | |
|     //          Name of the network on which the service is provided.
 | |
|     //          (e.g. "PBS")
 | |
|     //
 | |
|     //      Service.TuneRequest
 | |
|     //          Contains a tune request in the variant
 | |
|     //
 | |
|     // 
 | |
|     [helpstring("Returns an enumeration of all guide data properties for the service specified by a tune request.")]
 | |
|     HRESULT
 | |
|     GetServiceProperties (
 | |
|         [in]           ITuneRequest *               pTuneRequest,
 | |
|         [out, retval]  IEnumGuideDataProperties **  ppEnumProperties
 | |
|         );
 | |
| 
 | |
|     //-------------------------------------------------------------------------
 | |
|     //
 | |
|     //  GetProgramIDs
 | |
|     //      Returns an enumeration of the unique identifiers (Description.ID)
 | |
|     //      of programs with description contained in all transport
 | |
|     //      streams
 | |
|     //
 | |
|     //  Parameters
 | |
|     //
 | |
|     //      IEnumVARIANT **
 | |
|     //          Location in which a reference to the resulting
 | |
|     //          IEnumVARIANT is placed.  The caller must release
 | |
|     //          this reference when finished with it.
 | |
|     //
 | |
|     //  Comments
 | |
|     //      This call is used to get a list of programs that have
 | |
|     //      guide data properties in all transport streams.
 | |
|     //      Each variant returned in the IEnumVARIANT * contains the
 | |
|     //      unique Description.ID property for a program.
 | |
|     //      Note that more than on transport stream may contain properties
 | |
|     //      for the same program.  In this case the properties should be
 | |
|     //      merged. 
 | |
|     // 
 | |
|     [helpstring("Returns an enumeration of the Description.ID property for all programs on the given transport stream.")]
 | |
|     HRESULT
 | |
|     GetGuideProgramIDs (
 | |
|         [out, retval]  IEnumVARIANT **      pEnumPrograms
 | |
|         );
 | |
| 
 | |
|     //-------------------------------------------------------------------------
 | |
|     //
 | |
|     //  GetProgramProperties
 | |
|     //      Returns an enumeration of all guide data properties for
 | |
|     //      the program with the given Description.ID.
 | |
|     //
 | |
|     //  Parameters
 | |
|     //      varProgramDescriptionID 
 | |
|     //          Variant containing the unique identifier for the program
 | |
|     //          for which properties are requested.
 | |
|     //
 | |
|     //      IEnumGuideDataProperties **
 | |
|     //          Location in which a reference to the resulting
 | |
|     //          IEnumGuideDataProperties is placed.  The caller must release
 | |
|     //          this reference when finished with it.
 | |
|     //
 | |
|     //  Required Properties
 | |
|     //      The following properties MUST be included in the returned
 | |
|     //      property enumeration.
 | |
|     //
 | |
|     //      Description.ID
 | |
|     //          Uniquely identifies a program.
 | |
|     //
 | |
|     //      Description.Version
 | |
|     //          Identifies the current version of the properties associated
 | |
|     //          with this program.
 | |
|     //
 | |
|     //      Description.Title
 | |
|     //          Human readable title of the program (e.g. "")
 | |
|     //
 | |
|     //      Description.Long
 | |
|     //          A description of the program.
 | |
|     // 
 | |
|     [helpstring("Returns an enumeration of all guide data properties for the program with the given Description.ID.")]
 | |
|     HRESULT
 | |
|     GetProgramProperties (
 | |
|         [in]           VARIANT                      varProgramDescriptionID,
 | |
|         [out, retval]  IEnumGuideDataProperties **  ppEnumProperties
 | |
|         );
 | |
| 
 | |
|     //-------------------------------------------------------------------------
 | |
|     //
 | |
|     //  GetScheduleIDs
 | |
|     //      Returns an enumeration of the unique identifiers (Description.ID)
 | |
|     //      transport of schedule entries with description contained in the
 | |
|     //      given transport stream.
 | |
|     //
 | |
|     //  Parameters
 | |
|     //
 | |
|     //      IEnumVARIANT **
 | |
|     //          Location in which a reference to the resulting
 | |
|     //          IEnumVARIANT is placed.  The caller must release
 | |
|     //          this reference when finished with it.
 | |
|     //
 | |
|     //  Comments
 | |
|     //      This call is used to get a list of schedule entries that have
 | |
|     //      guide data properties in all transport streams.
 | |
|     //      Each variant returned in the IEnumVARIANT * contains the
 | |
|     //      unique Description.ID property for a schedule entry.
 | |
|     //      Note that more than on transport stream may contain properties
 | |
|     //      for the same schedule entry.  In this case the properties
 | |
|     //      should be merged. 
 | |
|     // 
 | |
|     [helpstring("Returns an enumeration of the Description.ID property for all schedule entries in the transport stream specified by a tune request.")]
 | |
|     HRESULT
 | |
|     GetScheduleEntryIDs (
 | |
|         [out, retval]  IEnumVARIANT **      pEnumScheduleEntries
 | |
|         );
 | |
| 
 | |
|     //-------------------------------------------------------------------------
 | |
|     //
 | |
|     //  GetScheduleEntryProperties
 | |
|     //      Returns an enumeration of all guide data properties for
 | |
|     //      the schedule entry with the given Description.ID.
 | |
|     //
 | |
|     //  Parameters
 | |
|     //      varScheduleEntryDescriptionID 
 | |
|     //          Variant containing the unique identifier for the schedule
 | |
|     //          entry for which properties are requested.
 | |
|     //
 | |
|     //      IEnumGuideDataProperties **
 | |
|     //          Location in which a reference to the resulting
 | |
|     //          IEnumGuideDataProperties is placed.  The caller must release
 | |
|     //          this reference when finished with it.
 | |
|     //
 | |
|     //  Required Properties
 | |
|     //      The following properties MUST be included in the returned
 | |
|     //      property enumeration.
 | |
|     //
 | |
|     //      Description.ID
 | |
|     //          Uniquely identifies a schedule entry.
 | |
|     //
 | |
|     //      Description.Version
 | |
|     //          Identifies the current version of the properties associated
 | |
|     //          with this program.
 | |
|     //
 | |
|     //      Time.Start
 | |
|     //          The starting time and date of this schedule entry.
 | |
|     //
 | |
|     //      Time.End
 | |
|     //          The ending time and date of this schedule entry.
 | |
|     //
 | |
|     //      Schedule.Program
 | |
|     //          The Description.ID of the program that will play at the
 | |
|     //          time specified by this schedule entry.
 | |
|     //
 | |
|     //      Schedule.Service
 | |
|     //          The Description.ID of the Service that carries the
 | |
|     //          program that will play at the time specified by this
 | |
|     //          schedule entry.
 | |
|     // 
 | |
|     [helpstring("Returns an enumeration of all guide data properties for the schedule entry with the given Description.ID.")]
 | |
|     HRESULT
 | |
|     GetScheduleEntryProperties (
 | |
|         [in]           VARIANT                      varScheduleEntryDescriptionID,
 | |
|         [out, retval]  IEnumGuideDataProperties **  ppEnumProperties
 | |
|         );
 | |
| 
 | |
| }
 | |
| 
 | |
| 
 | |
| //******************************************************************************
 | |
| //
 | |
| //  IGuideDataLoader
 | |
| //
 | |
| // All Guide Data Loaders MUST implement this interface.  It is how they are
 | |
| // provided with the IGuideData interface that they will use.
 | |
| //
 | |
| // {4764ff7c-fa95-4525-af4d-d32236db9e38}
 | |
| [
 | |
| 	object,
 | |
| 	uuid(4764ff7c-fa95-4525-af4d-d32236db9e38),
 | |
| 	helpstring("IGuideDataLoader Interface"),
 | |
| 	pointer_default(unique)
 | |
| ]
 | |
| interface IGuideDataLoader : IUnknown
 | |
| {
 | |
|     HRESULT Init([in] IGuideData *pGuideStore);
 | |
|     HRESULT Terminate();
 | |
| };
 | |
| 
 | |
| [
 | |
| 	uuid(8224A083-7F8C-432D-B83E-3C5E9BDE3528),
 | |
| 	version(1.0),
 | |
| 	helpstring("psisload 1.0 Type Library")
 | |
| ]
 | |
| library PSISLOADLib
 | |
| {
 | |
| 	importlib("stdole32.tlb");
 | |
| 	importlib("stdole2.tlb");
 | |
| 
 | |
| 	[
 | |
| 		uuid(14EB8748-1753-4393-95AE-4F7E7A87AAD6),
 | |
| 		helpstring("TIFLoad Class")
 | |
| 	]
 | |
| 	coclass TIFLoad
 | |
| 	{
 | |
| 		interface IGuideDataLoader;
 | |
|         interface IGuideDataEvent;
 | |
| 	};
 | |
| };
 | |
| 
 | |
| cpp_quote("#if ( _MSC_VER >= 800 )")
 | |
| cpp_quote("#pragma warning(default:4201)    /* Nameless struct/union */")
 | |
| cpp_quote("#endif")
 |