/*++ Copyright (c) 1994-95 Microsoft Corporation Module Name: domcol.cpp Abstract: Domain collection object implementation. Author: Don Ryan (donryan) 04-Jan-1994 Environment: User Mode - Win32 Revision History: --*/ #include "stdafx.h" #include "llsmgr.h" #ifdef _DEBUG #undef THIS_FILE static char BASED_CODE THIS_FILE[] = __FILE__; #endif IMPLEMENT_DYNCREATE(CDomains, CCmdTarget) BEGIN_MESSAGE_MAP(CDomains, CCmdTarget) //{{AFX_MSG_MAP(CDomains) // NOTE - the ClassWizard will add and remove mapping macros here. //}}AFX_MSG_MAP END_MESSAGE_MAP() BEGIN_DISPATCH_MAP(CDomains, CCmdTarget) //{{AFX_DISPATCH_MAP(CDomains) DISP_PROPERTY_EX(CDomains, "Application", GetApplication, SetNotSupported, VT_DISPATCH) DISP_PROPERTY_EX(CDomains, "Parent", GetParent, SetNotSupported, VT_DISPATCH) DISP_PROPERTY_EX(CDomains, "Count", GetCount, SetNotSupported, VT_I4) DISP_FUNCTION(CDomains, "Item", GetItem, VT_DISPATCH, VTS_VARIANT) //}}AFX_DISPATCH_MAP END_DISPATCH_MAP() CDomains::CDomains(CCmdTarget* pParent, CObArray* pObArray) /*++ Routine Description: Constructor for domain collection. Note AddRef() is not called on theApp.m_pApplication. Arguments: pParent - creator of object. pObArray - object list to enumerate. Return Values: None. --*/ { EnableAutomation(); #ifdef ENABLE_PARENT_CHECK ASSERT(pParent && pParent->IsKindOf(RUNTIME_CLASS(CApplication))); #endif // ENABLE_PARENT_CHECK ASSERT_VALID(pObArray); m_pParent = pParent; m_pObArray = pObArray; } CDomains::~CDomains() /*++ Routine Description: Destructor for domain collection. Arguments: None. Return Values: None. --*/ { // // Nothing to do here. // } void CDomains::OnFinalRelease() /*++ Routine Description: When the last reference for an automation object is released OnFinalRelease is called. This implementation deletes object. Arguments: None. Return Values: None. --*/ { delete this; } LPDISPATCH CDomains::GetApplication() /*++ Routine Description: Returns the application object. Arguments: None. Return Values: VT_DISPATCH. --*/ { return theApp.GetAppIDispatch(); } long CDomains::GetCount() /*++ Routine Description: Returns number of items in collection. Arguments: None. Return Values: VT_I4. --*/ { ASSERT_VALID(m_pObArray); return (long)m_pObArray->GetSize(); } LPDISPATCH CDomains::GetItem(const VARIANT FAR& index) /*++ Routine Description: Retrieves specified domain object from collection. Arguments: index - optional argument that may be a string (VT_BSTR) indicating a domain name or a number (VT_I4) indicating the position within collection. Return Values: VT_DISPATCH. --*/ { ASSERT_VALID(m_pObArray); LPDISPATCH lpdispatch = NULL; CDomain* pDomain; INT_PTR iDomain; VARIANT vDomain; VariantInit(&vDomain); iDomain = m_pObArray->GetSize(); if (NULL != iDomain) { if (index.vt == VT_BSTR) { while (iDomain--) { pDomain = (CDomain*)m_pObArray->GetAt(iDomain); if (NULL != pDomain) { ASSERT(pDomain->IsKindOf(RUNTIME_CLASS(CDomain))); if (!pDomain->m_strName.CompareNoCase(index.bstrVal)) { lpdispatch = pDomain->GetIDispatch(TRUE); break; } } } } else if (SUCCEEDED(VariantChangeType(&vDomain, (VARIANT FAR *)&index, 0, VT_I4))) { if (((int)vDomain.lVal >= 0) && ((int)vDomain.lVal < iDomain)) { pDomain = (CDomain*)m_pObArray->GetAt((int)vDomain.lVal); if (NULL != pDomain) { ASSERT(pDomain->IsKindOf(RUNTIME_CLASS(CDomain))); lpdispatch = pDomain->GetIDispatch(TRUE); } } } } return lpdispatch; } LPDISPATCH CDomains::GetParent() /*++ Routine Description: Returns the parent of the object. Arguments: None. Return Values: VT_DISPATCH. --*/ { return m_pParent ? m_pParent->GetIDispatch(TRUE) : NULL; }