2020-09-30 16:53:55 +02:00

242 lines
5.6 KiB
C++

/*++
Module Name:
JPEnum.cpp
Abstract:
This file contains the Implementation of the Class CJunctionPointEnum.
This class implements IEnumVARIANT for DfsJunctionPoint enumeration.
--*/
#include "stdafx.h"
#include "DfsCore.h"
#include "DfsJP.h"
#include "JPEnum.h"
/////////////////////////////////////////////////////////////////////////////
// ~CJunctionPointEnum
CJunctionPointEnum :: ~CJunctionPointEnum ()
{
_FreeMemberVariables();
}
/////////////////////////////////////////////////////////////////////////////
// Initialize
STDMETHODIMP CJunctionPointEnum :: Initialize
(
JUNCTIONNAMELIST* i_pjiList, // Pointer to the list of junction points.
FILTERDFSLINKS_TYPE i_lLinkFilterType,
BSTR i_bstrEnumFilter, // Filtering string expresseion
ULONG* o_pulCount // count of links that matches the filter
)
{
/*++
Routine Description:
Initializes the JunctionPointEnum object.
It copies the JunctionPoint list passed to it by the junction point
object.
Arguments:
i_pjiList - Pointer to the list of junction points.
i_lLinkFilterType - The type of link filtering.
i_bstrEnumFilter - The string expression to do prefix filtering.
o_pulCount - to hold the count of links that matches the specified filter.
--*/
if (!i_pjiList)
return E_INVALIDARG;
if (i_lLinkFilterType != FILTERDFSLINKS_TYPE_NO_FILTER &&
(!i_bstrEnumFilter || !*i_bstrEnumFilter))
return E_INVALIDARG;
if (o_pulCount)
*o_pulCount = 0;
HRESULT hr = S_OK;
JUNCTIONNAMELIST::iterator i;
JUNCTIONNAMELIST::iterator j;
for (i = i_pjiList->begin(); i != i_pjiList->end(); i++)
{ // Copy filtered junctions to its own internal list
if (i_lLinkFilterType != FILTERDFSLINKS_TYPE_NO_FILTER)
{
if ( !FilterMatch((*i)->m_bstrJPName, i_lLinkFilterType, i_bstrEnumFilter) )
continue;
}
JUNCTIONNAME* pTemp = (*i)->Copy();
BREAK_OUTOFMEMORY_IF_NULL(pTemp, &hr);
m_JunctionPoints.push_back(pTemp);
}
if (SUCCEEDED(hr))
{
m_iCurrentInEnumOfJunctionPoints = m_JunctionPoints.begin();
if (o_pulCount)
*o_pulCount = m_JunctionPoints.size();
} else
_FreeMemberVariables();
return hr;
}
/////////////////////////////////////////////////////////////////////////////
// IEnumVariant Methods
/////////////////////////////////////////////////////////////////////////////
// Next
STDMETHODIMP CJunctionPointEnum::Next
(
ULONG i_ulNumOfJunctionPoints, //To fetch.
VARIANT* o_pIJunctionPointArray, //Array to fetch into.
ULONG* o_ulNumOfJunctionPointsFetched //The number of values fetched, (Arg can be NULL)
)
{
/*++
Routine Description:
Gets the next object in the list.
Arguments:
i_ulNumOfJunctionPoints - the number of objects to return
o_pIJunctionPointArray - an array of variants in which to return the objects
o_ulNumOfJunctionPointsFetched - the number of objects that are actually returned
Return value:
S_OK, On success
S_FALSE if the end of the list has been reached
--*/
if (!o_pIJunctionPointArray || !i_ulNumOfJunctionPoints)
return E_INVALIDARG;
HRESULT hr = S_OK;
ULONG nCount = 0;
for (nCount = 0;
nCount < i_ulNumOfJunctionPoints && m_iCurrentInEnumOfJunctionPoints != m_JunctionPoints.end();
m_iCurrentInEnumOfJunctionPoints++)
{
IDfsJunctionPoint *pIJunctionPointPtr = (*m_iCurrentInEnumOfJunctionPoints)->m_piDfsJunctionPoint;
pIJunctionPointPtr->AddRef();
o_pIJunctionPointArray[nCount].vt = VT_DISPATCH;
o_pIJunctionPointArray[nCount].pdispVal = pIJunctionPointPtr;
nCount++;
}
if (o_ulNumOfJunctionPointsFetched)
*o_ulNumOfJunctionPointsFetched = nCount;
if (SUCCEEDED(hr) && !nCount)
return S_FALSE;
else
return hr;
}
/////////////////////////////////////////////////////////////////////////////
// Skip
STDMETHODIMP CJunctionPointEnum :: Skip
(
unsigned long i_ulJunctionPointsToSkip //Items to skip
)
{
/*++
Routine Description:
Skips the next 'n' objects in the list.
Arguments:
i_ulJunctionPointsToSkip - the number of objects to skip over
Return value:
S_OK, On success
S_FALSE, if the end of the list is reached
--*/
for (unsigned int j = 0; j < i_ulJunctionPointsToSkip &&
m_iCurrentInEnumOfJunctionPoints != m_JunctionPoints.end(); j++)
{
m_iCurrentInEnumOfJunctionPoints++;
}
return (m_iCurrentInEnumOfJunctionPoints != m_JunctionPoints.end()) ? S_OK : S_FALSE;
}
/////////////////////////////////////////////////////////////////////////////
// Reset
STDMETHODIMP CJunctionPointEnum :: Reset()
{
/*++
Routine Description:
Resets the current enumeration pointer to the start of the list
--*/
m_iCurrentInEnumOfJunctionPoints = m_JunctionPoints.begin();
return S_OK;
}
/////////////////////////////////////////////////////////////////////////////
// Clone
STDMETHODIMP CJunctionPointEnum :: Clone
(
IEnumVARIANT FAR* FAR* ppenum
)
{
/*++
Routine Description:
Creates a clone of the enumerator object
Arguments:
ppenum - address of the pointer to the IEnumVARIANT interface
of the newly created enumerator object
Notes:
This has not been implemented.
--*/
return E_NOTIMPL;
}