/** @file * DO NOT EDIT! This is a generated file. * Generated from: src/VBox/Main/idl/VirtualBox.xidl (VirtualBox's interface definitions in XML) * Generator: src/VBox/Main/idl/comimpl.xsl */ /* * Copyright (C) 2010-2020 Oracle Corporation * * This file is part of VirtualBox Open Source Edition (OSE), as * available from http://www.virtualbox.org. This file is free software; * you can redistribute it and/or modify it under the terms of the GNU * General Public License (GPL) as published by the Free Software * Foundation, in version 2 as it comes in the "COPYING" file of the * VirtualBox OSE distribution. VirtualBox OSE is distributed in the * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind. */ 1 SafeArray< > aArr(ComSafeArrayInArg()); return .initFrom(aArr); return .assignEx( ); return S_OK; SafeArray<> result; HRESULT hrc = .cloneTo(result); if (SUCCEEDED(hrc)) result.detachTo(ComSafeArrayOutArg()); return hrc; return .cloneToEx( ); return .queryInterfaceTo( ); * = ; return S_OK; if (SUCCEEDED(hrc)) if (SUCCEEDED(hrc)) // purely internal setter inline HRESULT set_(const Utf8Str &a_rString) { return .assignEx(a_rString); } inline HRESULT void ) { *pEvtImpl = dynamic_cast< *>(aEvent); if (pEvtImpl) { pEvtImpl->Reuse(); HRESULT hrc = S_OK; return hrc; } return E_INVALIDARG; } ) { ComObjPtr<> EvtObj; HRESULT hrc = EvtObj.createObject(); if (SUCCEEDED(hrc)) { hrc = EvtObj->init(aSource, VBoxEventType_ , /*waitable*/); if (SUCCEEDED(hrc)) { hrc = EvtObj.queryInterfaceTo(aEvent); if (SUCCEEDED(hrc)) return hrc; } } *aEvent = NULL; return hrc; } ) { AssertReturn(aSource, E_INVALIDARG); ComPtr<IEvent> ptrEvent; HRESULT hrc = ); if (SUCCEEDED(hrc)) { BOOL fDeliveredIgnored = FALSE; hrc = aSource->FireEvent(ptrEvent, /* do not wait for delivery */ 0, &fDeliveredIgnored); AssertComRC(hrc); } return hrc; } COMGETTER(Type)(aType); } STDMETHOD(COMGETTER(Source))(IEventSource * *aSource) RT_OVERRIDE { return mEvent->COMGETTER(Source)(aSource); } STDMETHOD(COMGETTER(Waitable))(BOOL *aWaitable) RT_OVERRIDE { return mEvent->COMGETTER(Waitable)(aWaitable); } STDMETHOD(SetProcessed)() RT_OVERRIDE { return mEvent->SetProcessed(); } STDMETHOD(WaitProcessed)(LONG aTimeout, BOOL *aResult) RT_OVERRIDE { return mEvent->WaitProcessed(aTimeout, aResult); } void uninit() { if (!mEvent.isNull()) { mEvent->uninit(); mEvent.setNull(); } } ]]> init(aSource, aType); } STDMETHOD(AddVeto)(IN_BSTR aVeto) RT_OVERRIDE { return mEvent->AddVeto(aVeto); } STDMETHOD(IsVetoed)(BOOL *aResult) RT_OVERRIDE { return mEvent->IsVetoed(aResult); } STDMETHOD(GetVetos)(ComSafeArrayOut(BSTR, aVetos)) RT_OVERRIDE { return mEvent->GetVetos(ComSafeArrayOutArg(aVetos)); } STDMETHOD(AddApproval)(IN_BSTR aReason) RT_OVERRIDE { return mEvent->AddApproval(aReason); } STDMETHOD(IsApproved)(BOOL *aResult) RT_OVERRIDE { return mEvent->IsApproved(aResult); } STDMETHOD(GetApprovals)(ComSafeArrayOut(BSTR, aReasons)) RT_OVERRIDE { return mEvent->GetApprovals(ComSafeArrayOutArg(aReasons)); } private: ComObjPtr mEvent; ]]> init(aSource, aType, aWaitable); } STDMETHOD(COMGETTER(Generation))(ULONG *aGeneration) RT_OVERRIDE { *aGeneration = mGeneration; return S_OK; } STDMETHOD(Reuse)() RT_OVERRIDE { ASMAtomicIncU32((volatile uint32_t *)&mGeneration); return S_OK; } private: volatile ULONG mGeneration; ComObjPtr mEvent; ]]> init(aSource, aType, aWaitable); } private: ComObjPtr mEvent; ]]> error: has no attributes #include #include #include "VBoxEvents.h" ]]> /** @name Fire off events * @{ */ ); ); /** @} */ /** @name Instantiate events * @{ */ ); ); /** @} */ /** @name Re-init reusable events * @{ */ ); ); /** @} */