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.
225 lines
5.9 KiB
225 lines
5.9 KiB
/////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// Copyright (c) 1996-2002 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:
|
|
// pszPathName Name of the cluster or server to add.
|
|
//
|
|
// Return Value:
|
|
// None.
|
|
//
|
|
//--
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
void CRecentClusterList::Add(LPCTSTR pszPathName)
|
|
{
|
|
ASSERT(m_arrNames != NULL);
|
|
ASSERT(pszPathName != NULL);
|
|
ASSERT(AfxIsValidString(pszPathName));
|
|
|
|
int idxMRU;
|
|
// update the MRU list, if an existing MRU string matches file name
|
|
for (idxMRU = 0; idxMRU < m_nSize-1; idxMRU++)
|
|
{
|
|
if (ClRtlStrICmp(m_arrNames[idxMRU], pszPathName) == 0)
|
|
{
|
|
break; // iMRU will point to matching entry
|
|
}
|
|
}
|
|
// move MRU strings before this one down
|
|
for (; idxMRU > 0; idxMRU--)
|
|
{
|
|
ASSERT(idxMRU > 0);
|
|
ASSERT(idxMRU < m_nSize);
|
|
m_arrNames[idxMRU] = m_arrNames[idxMRU-1];
|
|
}
|
|
// place this one at the beginning
|
|
m_arrNames[0] = pszPathName;
|
|
|
|
} //*** 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.
|
|
// pszCurDir [IN] Must be NULL.
|
|
// nCurDir [IN] Must be 0.
|
|
// bAtLeastName [IN] Not used.
|
|
//
|
|
// Return Value:
|
|
// TRUE - Display name returned.
|
|
// FALSE - Display name not returned.
|
|
//
|
|
//--
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
BOOL CRecentClusterList::GetDisplayName(
|
|
CString & strName,
|
|
int nIndex,
|
|
LPCTSTR pszCurDir,
|
|
int nCurDir,
|
|
BOOL bAtLeastName
|
|
) const
|
|
{
|
|
BOOL bSuccess = FALSE;
|
|
|
|
ASSERT(pszCurDir == NULL);
|
|
ASSERT(nCurDir == 0);
|
|
|
|
UNREFERENCED_PARAMETER( pszCurDir );
|
|
UNREFERENCED_PARAMETER( nCurDir );
|
|
UNREFERENCED_PARAMETER( bAtLeastName );
|
|
|
|
if (m_arrNames[nIndex].IsEmpty())
|
|
{
|
|
goto Cleanup;
|
|
}
|
|
|
|
strName = m_arrNames[nIndex];
|
|
bSuccess = TRUE;
|
|
|
|
Cleanup:
|
|
|
|
return bSuccess;
|
|
|
|
} //*** 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;
|
|
CString strName;
|
|
CString strTemp;
|
|
|
|
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);
|
|
goto Cleanup;
|
|
}
|
|
|
|
if (pCmdUI->m_pMenu == NULL)
|
|
{
|
|
goto Cleanup;
|
|
}
|
|
|
|
for (int iMRU = 0; iMRU < m_nSize; iMRU++)
|
|
{
|
|
pCmdUI->m_pMenu->DeleteMenu(pCmdUI->m_nID + iMRU, MF_BYCOMMAND);
|
|
}
|
|
|
|
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 szBuf[10];
|
|
HRESULT hr = StringCchPrintf( szBuf, RTL_NUMBER_OF( szBuf ), _T("&%d "), (iMRU+1+m_nStart) % 10 );
|
|
ASSERT( SUCCEEDED( hr ) );
|
|
pCmdUI->m_pMenu->InsertMenu(pCmdUI->m_nIndex++,
|
|
MF_STRING | MF_BYPOSITION, pCmdUI->m_nID++,
|
|
CString(szBuf) + 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
|
|
|
|
Cleanup:
|
|
|
|
return;
|
|
|
|
} //*** CRecentFileList::UpdateMenu
|