📄 nsiinterfacerequestor.h
字号:
/* * DO NOT EDIT. THIS FILE IS GENERATED FROM nsIInterfaceRequestor.idl */#ifndef __gen_nsIInterfaceRequestor_h__#define __gen_nsIInterfaceRequestor_h__#ifndef __gen_nsISupports_h__#include "nsISupports.h"#endif/* For IDL files that don't want to include root IDL files. */#ifndef NS_NO_VTABLE#define NS_NO_VTABLE#endif/* starting interface: nsIInterfaceRequestor */#define NS_IINTERFACEREQUESTOR_IID_STR "033a1470-8b2a-11d3-af88-00a024ffc08c"#define NS_IINTERFACEREQUESTOR_IID \ {0x033a1470, 0x8b2a, 0x11d3, \ { 0xaf, 0x88, 0x00, 0xa0, 0x24, 0xff, 0xc0, 0x8c }}/** * The nsIInterfaceRequestor interface defines a generic interface for * requesting interfaces that a given object might provide access to. * This is very similar to QueryInterface found in nsISupports. * The main difference is that interfaces returned from GetInterface() * are not required to provide a way back to the object implementing this * interface. The semantics of QI() dictate that given an interface A that * you QI() on to get to interface B, you must be able to QI on B to get back * to A. This interface however allows you to obtain an interface C from A * that may or most likely will not have the ability to get back to A. * * @status FROZEN */class NS_NO_VTABLE nsIInterfaceRequestor : public nsISupports { public: NS_DEFINE_STATIC_IID_ACCESSOR(NS_IINTERFACEREQUESTOR_IID) /** * Retrieves the specified interface pointer. * * @param uuid The IID of the interface being requested. * @param result [out] The interface pointer to be filled in if * the interface is accessible. * @return NS_OK - interface was successfully returned. * NS_NOINTERFACE - interface not accessible. * NS_ERROR* - method failure. */ /* void getInterface (in nsIIDRef uuid, [iid_is (uuid), retval] out nsQIResult result); */ NS_IMETHOD GetInterface(const nsIID & uuid, void * *result) = 0;};/* Use this macro when declaring classes that implement this interface. */#define NS_DECL_NSIINTERFACEREQUESTOR \ NS_IMETHOD GetInterface(const nsIID & uuid, void * *result); /* Use this macro to declare functions that forward the behavior of this interface to another object. */#define NS_FORWARD_NSIINTERFACEREQUESTOR(_to) \ NS_IMETHOD GetInterface(const nsIID & uuid, void * *result) { return _to GetInterface(uuid, result); } /* Use this macro to declare functions that forward the behavior of this interface to another object in a safe way. */#define NS_FORWARD_SAFE_NSIINTERFACEREQUESTOR(_to) \ NS_IMETHOD GetInterface(const nsIID & uuid, void * *result) { return !_to ? NS_ERROR_NULL_POINTER : _to->GetInterface(uuid, result); } #if 0/* Use the code below as a template for the implementation class for this interface. *//* Header file */class nsInterfaceRequestor : public nsIInterfaceRequestor{public: NS_DECL_ISUPPORTS NS_DECL_NSIINTERFACEREQUESTOR nsInterfaceRequestor(); virtual ~nsInterfaceRequestor(); /* additional members */};/* Implementation file */NS_IMPL_ISUPPORTS1(nsInterfaceRequestor, nsIInterfaceRequestor)nsInterfaceRequestor::nsInterfaceRequestor(){ /* member initializers and constructor code */}nsInterfaceRequestor::~nsInterfaceRequestor(){ /* destructor code */}/* void getInterface (in nsIIDRef uuid, [iid_is (uuid), retval] out nsQIResult result); */NS_IMETHODIMP nsInterfaceRequestor::GetInterface(const nsIID & uuid, void * *result){ return NS_ERROR_NOT_IMPLEMENTED;}/* End of implementation class template. */#endif#endif /* __gen_nsIInterfaceRequestor_h__ */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -