Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

189 lines
4.6 KiB

/////////////////////////////////////////////////////////////////////////////
//
// Copyright (c) 1996 Microsoft Corporation
//
// Module Name:
// ClusMru.cpp
//
// Abstract:
// Implementation of the CRecentClusterList class.
//
// Author:
// David Potter (davidp) May 3, 1996
//
// Revision History:
//
// Notes:
//
/////////////////////////////////////////////////////////////////////////////
#include "stdafx.h"
#include "ClusMru.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CRecentClusterList
/////////////////////////////////////////////////////////////////////////////
//++
//
// CRecentClusterList::Add
//
// Routine Description:
// Add an item to the list of recently used cluster names.
// Implemented to remove file-ness of base class' method.
//
// Arguments:
// lpszPathName Name of the cluster or server to add.
//
// Return Value:
// None.
//
//--
/////////////////////////////////////////////////////////////////////////////
void CRecentClusterList::Add(LPCTSTR lpszPathName)
{
ASSERT(m_arrNames != NULL);
ASSERT(lpszPathName != NULL);
ASSERT(AfxIsValidString(lpszPathName));
// update the MRU list, if an existing MRU string matches file name
for (int iMRU = 0; iMRU < m_nSize-1; iMRU++)
{
if (lstrcmpi(m_arrNames[iMRU], lpszPathName) == 0)
break; // iMRU will point to matching entry
}
// move MRU strings before this one down
for (; iMRU > 0; iMRU--)
{
ASSERT(iMRU > 0);
ASSERT(iMRU < m_nSize);
m_arrNames[iMRU] = m_arrNames[iMRU-1];
}
// place this one at the beginning
m_arrNames[0] = lpszPathName;
} //*** CRecentClusterList::Add()
/////////////////////////////////////////////////////////////////////////////
//++
//
// CRecentClusterList::GetDisplayName
//
// Routine Description:
// Get the display name of a particular item.
// Implemented to remove file-ness of base class' method.
//
// Arguments:
// strName [OUT] String in which to return the display name.
// nIndex [IN] Index of item in array.
// lpszCurDir [IN] Must be NULL.
// nCurDir [IN] Must be 0.
// bAtLeastName [IN] Not used.
//
// Return Value:
// None.
//
//--
/////////////////////////////////////////////////////////////////////////////
BOOL CRecentClusterList::GetDisplayName(
CString & strName,
int nIndex,
LPCTSTR lpszCurDir,
int nCurDir,
BOOL bAtLeastName
) const
{
ASSERT(lpszCurDir == NULL);
ASSERT(nCurDir == 0);
if (m_arrNames[nIndex].IsEmpty())
return FALSE;
strName = m_arrNames[nIndex];
return TRUE;
} //*** CRecentClusterList::GetDisplayName()
/////////////////////////////////////////////////////////////////////////////
//++
//
// CRecentClusterList::UpdateMenu
//
// Routine Description:
// Update the menu with the MRU items.
// Implemented to remove file-ness of base class' method and to use
// our version of GetDisplayName, since it isn't virtual.
//
// Arguments:
// pCmdUI [IN OUT] Command routing object.
//
// Return Value:
// None.
//
//--
/////////////////////////////////////////////////////////////////////////////
void CRecentClusterList::UpdateMenu(CCmdUI * pCmdUI)
{
ASSERT(m_arrNames != NULL);
CMenu* pMenu = pCmdUI->m_pMenu;
if (m_strOriginal.IsEmpty() && pMenu != NULL)
pMenu->GetMenuString(pCmdUI->m_nID, m_strOriginal, MF_BYCOMMAND);
if (m_arrNames[0].IsEmpty())
{
// no MRU files
if (!m_strOriginal.IsEmpty())
pCmdUI->SetText(m_strOriginal);
pCmdUI->Enable(FALSE);
return;
}
if (pCmdUI->m_pMenu == NULL)
return;
for (int iMRU = 0; iMRU < m_nSize; iMRU++)
pCmdUI->m_pMenu->DeleteMenu(pCmdUI->m_nID + iMRU, MF_BYCOMMAND);
CString strName;
CString strTemp;
for (iMRU = 0; iMRU < m_nSize; iMRU++)
{
if (!GetDisplayName(strName, iMRU, NULL, 0))
break;
// double up any '&' characters so they are not underlined
LPCTSTR lpszSrc = strName;
LPTSTR lpszDest = strTemp.GetBuffer(strName.GetLength()*2);
while (*lpszSrc != 0)
{
if (*lpszSrc == '&')
*lpszDest++ = '&';
if (_istlead(*lpszSrc))
*lpszDest++ = *lpszSrc++;
*lpszDest++ = *lpszSrc++;
}
*lpszDest = 0;
strTemp.ReleaseBuffer();
// insert mnemonic + the file name
TCHAR buf[10];
wsprintf(buf, _T("&%d "), (iMRU+1+m_nStart) % 10);
pCmdUI->m_pMenu->InsertMenu(pCmdUI->m_nIndex++,
MF_STRING | MF_BYPOSITION, pCmdUI->m_nID++,
CString(buf) + strTemp);
}
// update end menu count
pCmdUI->m_nIndex--; // point to last menu added
pCmdUI->m_nIndexMax = pCmdUI->m_pMenu->GetMenuItemCount();
pCmdUI->m_bEnableChanged = TRUE; // all the added items are enabled
} //*** CRecentFileList::UpdateMenu()