AAFRESULT STDMETHODCALLTYPE ImplAAFMultipleDescriptor::GetFileDescriptors ( ImplEnumAAFFileDescriptors **ppEnum) { if (ppEnum == NULL) return AAFRESULT_NULL_PARAM; ImplEnumAAFFileDescriptors *theEnum = (ImplEnumAAFFileDescriptors *)CreateImpl(CLSID_EnumAAFFileDescriptors); XPROTECT() { OMStrongReferenceVectorIterator<ImplAAFFileDescriptor> *iter = new OMStrongReferenceVectorIterator<ImplAAFFileDescriptor>(_Descriptors); if (iter == 0) RAISE(AAFRESULT_NOMEMORY); CHECK(theEnum->Initialize(&CLSID_EnumAAFFileDescriptors, this, iter)); *ppEnum = theEnum; } XEXCEPT { if (theEnum) theEnum->ReleaseReference(); theEnum = 0; } XEND; return AAFRESULT_SUCCESS; }
HRESULT STDMETHODCALLTYPE CEnumAAFFileDescriptors::Clone (IEnumAAFFileDescriptors ** ppEnum) { HRESULT hr; ImplEnumAAFFileDescriptors * ptr; ImplAAFRoot * pO; pO = GetRepObject (); assert (pO); ptr = static_cast<ImplEnumAAFFileDescriptors*> (pO); assert (ptr); // // set up for ppEnum // ImplEnumAAFFileDescriptors * internalppEnum = NULL; ImplEnumAAFFileDescriptors ** pinternalppEnum = NULL; if (ppEnum) { pinternalppEnum = &internalppEnum; } try { hr = ptr->Clone (pinternalppEnum); } catch (OMException& e) { // OMExceptions should be handled by the impl code. However, if an // unhandled OMException occurs, control reaches here. We must not // allow the unhandled exception to reach the client code, so we // turn it into a failure status code. // // If the OMException contains an HRESULT, it is returned to the // client, if not, AAFRESULT_UHANDLED_EXCEPTION is returned. // hr = OMExceptionToResult(e, AAFRESULT_UNHANDLED_EXCEPTION); } catch (OMAssertionViolation &) { // Control reaches here if there is a programming error in the // impl code that was detected by an assertion violation. // We must not allow the assertion to reach the client code so // here we turn it into a failure status code. // hr = AAFRESULT_ASSERTION_VIOLATION; } catch (...) { // We CANNOT throw an exception out of a COM interface method! // Return a reasonable exception code. // hr = AAFRESULT_UNEXPECTED_EXCEPTION; } // // cleanup for ppEnum // if (SUCCEEDED(hr)) { IUnknown *pUnknown; HRESULT hStat; if (internalppEnum) { pUnknown = static_cast<IUnknown *> (internalppEnum->GetContainer()); hStat = pUnknown->QueryInterface(IID_IEnumAAFFileDescriptors, (void **)ppEnum); assert (SUCCEEDED (hStat)); //pUnknown->Release(); internalppEnum->ReleaseReference(); // We are through with this pointer. } } return hr; }