windows-nt/Source/XPSP1/NT/admin/pchealth/upload/client/uploadmanager/mpcuploadenum.cpp
2020-09-26 16:20:57 +08:00

168 lines
3.4 KiB
C++

/******************************************************************************
Copyright (c) 2000 Microsoft Corporation
Module Name:
MPCUploadEnum.cpp
Abstract:
This file contains the implementation of the MPCUploadEnum class,
the enumerator of the MPCUpload class.
Revision History:
Davide Massarenti (Dmassare) 04/15/99
created
******************************************************************************/
#include "stdafx.h"
CMPCUploadEnum::CMPCUploadEnum()
{
__ULT_FUNC_ENTRY( "CMPCUploadEnum::CMPCUploadEnum" );
// List m_lstJobs
m_itCurrent = m_lstJobs.begin(); // Iter m_itCurrent
}
void CMPCUploadEnum::FinalRelease()
{
__ULT_FUNC_ENTRY( "CMPCUploadEnum::FinalRelease" );
MPC::ReleaseAll( m_lstJobs );
}
HRESULT CMPCUploadEnum::AddItem( /*[in]*/ IMPCUploadJob* job )
{
__ULT_FUNC_ENTRY( "CMPCUploadEnum::Init" );
MPC::SmartLock<_ThreadModel> lock( this );
m_lstJobs.push_back( job ); job->AddRef();
m_itCurrent = m_lstJobs.begin();
__ULT_FUNC_EXIT(S_OK);
}
STDMETHODIMP CMPCUploadEnum::Next( /*[in]*/ ULONG celt, /*[out]*/ VARIANT *rgelt, /*[out]*/ ULONG *pceltFetched )
{
__ULT_FUNC_ENTRY( "CMPCUploadEnum::Next" );
HRESULT hr;
ULONG cNum = 0;
VARIANT *pelt = rgelt;
MPC::SmartLock<_ThreadModel> lock( this );
if(rgelt == NULL || (celt != 1 && pceltFetched == NULL))
{
__MPC_SET_ERROR_AND_EXIT(hr, E_POINTER);
}
while(celt && m_itCurrent != m_lstJobs.end())
{
IMPCUploadJob* mpcujJob = *m_itCurrent++;
pelt->vt = VT_DISPATCH;
if(FAILED(hr = mpcujJob->QueryInterface( IID_IDispatch, (void**)&pelt->pdispVal )))
{
while(rgelt < pelt)
{
::VariantClear( rgelt++ );
}
cNum = 0;
__MPC_FUNC_LEAVE;
}
pelt++; cNum++; celt--;
}
hr = S_OK;
__ULT_FUNC_CLEANUP;
if(pceltFetched != NULL) *pceltFetched = cNum;
if(SUCCEEDED(hr))
{
if(celt != 0) hr = S_FALSE;
}
__ULT_FUNC_EXIT(hr);
}
STDMETHODIMP CMPCUploadEnum::Skip( /*[in]*/ ULONG celt )
{
__ULT_FUNC_ENTRY( "CMPCUploadEnum::Skip" );
HRESULT hr;
MPC::SmartLock<_ThreadModel> lock( this );
while(celt && m_itCurrent != m_lstJobs.end())
{
m_itCurrent++;
celt--;
}
hr = celt ? S_FALSE : S_OK;
__ULT_FUNC_EXIT(hr);
}
STDMETHODIMP CMPCUploadEnum::Reset()
{
__ULT_FUNC_ENTRY( "CMPCUploadEnum::Reset" );
HRESULT hr;
MPC::SmartLock<_ThreadModel> lock( this );
m_itCurrent = m_lstJobs.begin();
hr = S_OK;
__ULT_FUNC_EXIT(hr);
}
STDMETHODIMP CMPCUploadEnum::Clone( /*[out]*/ IEnumVARIANT* *ppEnum )
{
__ULT_FUNC_ENTRY( "CMPCUploadEnum::Clone" );
HRESULT hr;
Iter it;
CComPtr<CMPCUploadEnum> pEnum;
MPC::SmartLock<_ThreadModel> lock( this );
__MPC_PARAMCHECK_BEGIN(hr)
__MPC_PARAMCHECK_POINTER_AND_SET(ppEnum,NULL);
__MPC_PARAMCHECK_END();
__MPC_EXIT_IF_METHOD_FAILS(hr, MPC::CreateInstance( &pEnum ));
for(it = m_lstJobs.begin(); it != m_lstJobs.end(); it++)
{
__MPC_EXIT_IF_METHOD_FAILS(hr, pEnum->AddItem( *it ));
}
__MPC_EXIT_IF_METHOD_FAILS(hr, pEnum->QueryInterface( IID_IEnumVARIANT, (void**)ppEnum ));
hr = S_OK;
__ULT_FUNC_CLEANUP;
__ULT_FUNC_EXIT(hr);
}