| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081 | 
							- #include "stdafx.h"
 
- #include ".\cf_textaggregator.h"
 
- #include "Misc.h"
 
- CCF_TextAggregator::CCF_TextAggregator(CStringA csSepator) :
 
- 	m_csSeparator(csSepator)
 
- {
 
- }
 
- CCF_TextAggregator::~CCF_TextAggregator(void)
 
- {
 
- }
 
- bool CCF_TextAggregator::AddClip(LPVOID lpData, int nDataSize, int nPos, int nCount, UINT cfType)
 
- {
 
- 	if (cfType == CF_HDROP)
 
- 	{
 
- 		CStringA hDropFiles = _T("");
 
- 		HDROP drop = (HDROP)GlobalLock((HDROP)lpData);
 
- 		int nNumFiles = DragQueryFileA(drop, -1, NULL, 0);
 
- 		CHAR file[MAX_PATH];
 
- 		for (int nFile = 0; nFile < nNumFiles; nFile++)
 
- 		{
 
- 			if (DragQueryFileA(drop, nFile, file, sizeof(file)) > 0)
 
- 			{
 
- 				hDropFiles += file;
 
- 				hDropFiles += "\r\n";
 
- 			}
 
- 		}
 
- 		if (hDropFiles != _T(""))
 
- 		{
 
- 			m_csNewText += hDropFiles;
 
- 			if (nPos != nCount - 1)
 
- 			{
 
- 				m_csNewText += m_csSeparator;
 
- 			}
 
- 			return true;
 
- 		}
 
- 		return false;
 
- 	}
 
- 	LPCSTR pText = (LPCSTR)lpData;
 
- 	if(pText == NULL)
 
- 	{
 
- 		return false;
 
- 	}
 
- 	//Ensure it's null terminated
 
- 	if(pText[nDataSize-1] != '\0')
 
- 	{
 
- 		int len = 0;
 
- 		for(len = 0; len < nDataSize && pText[len] != '\0'; len++ )
 
- 		{
 
- 		}
 
- 		// if it is not null terminated, skip this item
 
- 		if(len >= nDataSize)
 
- 			return false;
 
- 	}
 
- 	m_csNewText += pText;
 
- 	
 
- 	if(nPos != nCount-1)
 
- 	{
 
- 		m_csNewText += m_csSeparator;
 
- 	}
 
- 	return true;
 
- }
 
- HGLOBAL CCF_TextAggregator::GetHGlobal()
 
- {
 
- 	long lLen = m_csNewText.GetLength();
 
- 	HGLOBAL hGlobal = NewGlobalP(m_csNewText.GetBuffer(lLen), lLen+sizeof(char));
 
- 	m_csNewText.ReleaseBuffer();
 
- 	return hGlobal;
 
- }
 
 
  |