diff options
| author | Tobias Weimer <wishmaster51@googlemail.com> | 2013-01-12 20:18:54 +0000 | 
|---|---|---|
| committer | Tobias Weimer <wishmaster51@googlemail.com> | 2013-01-12 20:18:54 +0000 | 
| commit | 1eb5d33e9916cd042323e8065961494c492d9416 (patch) | |
| tree | e5954c68a7f34ed9a4937d60bb30e02d2770276c | |
| parent | eec8d5bd49a4f862ea926ad24ee07f19cdc10933 (diff) | |
support for dropping unicode text (fixes #61)
git-svn-id: http://svn.miranda-ng.org/main/trunk@3081 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
| -rw-r--r-- | plugins/FloatingContacts/src/filedrop.cpp | 115 | ||||
| -rw-r--r-- | plugins/FloatingContacts/src/fltcont.h | 2 | ||||
| -rw-r--r-- | plugins/FloatingContacts/src/main.cpp | 7 | 
3 files changed, 52 insertions, 72 deletions
| diff --git a/plugins/FloatingContacts/src/filedrop.cpp b/plugins/FloatingContacts/src/filedrop.cpp index 473c7a6814..eb3b336200 100644 --- a/plugins/FloatingContacts/src/filedrop.cpp +++ b/plugins/FloatingContacts/src/filedrop.cpp @@ -49,21 +49,20 @@ HRESULT STDMETHODCALLTYPE CDropTarget::DragOver( DWORD fKeyState, POINTL pt, DWO  HRESULT STDMETHODCALLTYPE CDropTarget::DragEnter( IDataObject *pData, DWORD fKeyState, POINTL pt, DWORD *pdwEffect)
  {
 -	HWND		hwnd	 =  NULL;
 -	POINT		shortPt;
  	FORMATETC	feFile	 =  { CF_HDROP, NULL, DVASPECT_CONTENT, -1, TYMED_HGLOBAL };
  	FORMATETC	feText	 =  { CF_TEXT, NULL, DVASPECT_CONTENT, -1, TYMED_HGLOBAL };
 -	ThumbInfo *pThumb;
  	if ( S_OK == pData->QueryGetData( &feFile ) ||
  		 S_OK == pData->QueryGetData( &feText ))
  	{
 -		shortPt.x	 =  pt.x; 
 -		shortPt.y	 =  pt.y;
 +		POINT shortPt;
 +		shortPt.x = pt.x; 
 +		shortPt.y = pt.y;
 -		hwnd = WindowFromPoint( shortPt );
 +		HWND hwnd = WindowFromPoint( shortPt );
 -		if ( pThumb = thumbList.FindThumb( hwnd ))
 +		ThumbInfo *pThumb = thumbList.FindThumb(hwnd);
 +		if (pThumb)
  		{
  			hwndCurDrag = hwnd;
  			pThumb->ThumbSelect( TRUE );
 @@ -91,67 +90,61 @@ HRESULT STDMETHODCALLTYPE CDropTarget::DragLeave( )  HRESULT STDMETHODCALLTYPE CDropTarget::Drop( IDataObject *pData,DWORD fKeyState,POINTL pt,DWORD *pdwEffect)
  {
 -	FORMATETC	fe		 =  { CF_HDROP, NULL, DVASPECT_CONTENT, -1, TYMED_HGLOBAL };
 -	STGMEDIUM	stg;
 -	HDROP		hDrop		 =  NULL;
 -	ThumbInfo	*pThumb		 =  NULL;
 -	char		*pText		 =  NULL;
 -	BOOL		bFormatText = FALSE;
 +	FORMATETC fe = { CF_HDROP, NULL, DVASPECT_CONTENT, -1, TYMED_HGLOBAL };
  	*pdwEffect = DROPEFFECT_NONE;
 +	if (hwndCurDrag == NULL)
 +		return S_OK;
 -	if ( hwndCurDrag == NULL ) return( S_OK );
 -
 -	pThumb	 =  (ThumbInfo*)GetWindowLongPtr( hwndCurDrag, GWLP_USERDATA );
 -	if ( pThumb == NULL ) return( S_OK );
 +	ThumbInfo *pThumb = (ThumbInfo*) GetWindowLongPtr( hwndCurDrag, GWLP_USERDATA );
 +	if (pThumb == NULL)
 +		return S_OK;
 -	if ( S_OK != pData->GetData( &fe,&stg ))
 +	STGMEDIUM stg;
 +	bool bFormatText = false;
 +	if ( S_OK != pData->GetData(&fe,&stg))
  	{
 -		fe.cfFormat = CF_TEXT;
 +		fe.cfFormat = CF_UNICODETEXT;
 -		if ( S_OK != pData->GetData( &fe,&stg ))
 +		if ( S_OK != pData->GetData(&fe,&stg))
  		{
 -			return( S_OK );
 +			return S_OK;
  		}
  		else
  		{
 -			bFormatText = TRUE;
 +			bFormatText = true;
  		}
  	}
 -		
 -
 -	if ( !bFormatText )
 +	if (!bFormatText)
  	{
 -		hDrop	 =  (HDROP)stg.hGlobal;
 -		
 -		if ( hDrop != NULL )
 +		HDROP hDrop = (HDROP) stg.hGlobal;
 +		if (hDrop != NULL)
  		{
 -			OnDropFiles( hDrop, pThumb );
 +			OnDropFiles(hDrop, pThumb);
  		}
  	}
  	else
  	{
 -		pText = (char*)GlobalLock( stg.hGlobal );
 -
 -		if ( pText != NULL  )
 +		TCHAR *pText = (TCHAR*) GlobalLock(stg.hGlobal);
 +		if (pText != NULL)
  		{
 -			SendMsgDialog( hwndCurDrag, pText );
 -			GlobalUnlock( stg.hGlobal );
 +			SendMsgDialog(hwndCurDrag, pText);
 +			GlobalUnlock(stg.hGlobal);
  		}
  	}
 -	if ( stg.pUnkForRelease != NULL )
 +	if (stg.pUnkForRelease != NULL)
  	{
 -		stg.pUnkForRelease->Release( );
 +		stg.pUnkForRelease->Release();
  	}
  	else 
  	{
 -		GlobalFree( stg.hGlobal );
 +		GlobalFree(stg.hGlobal);
  	}
 -	DragLeave( );
 +	DragLeave();
  	return S_OK;
  }
 @@ -161,63 +154,55 @@ HRESULT STDMETHODCALLTYPE CDropTarget::Drop( IDataObject *pData,DWORD fKeyState,  BOOL OnDropFiles( HDROP hDrop, ThumbInfo *pThumb )
  {
 -	BOOL	bSuccess			 =  FALSE;
 -	UINT	nFilesCount			 =  0;
 -	UINT	iItem				 =  0;
 -	char	**ppFiles			 =  NULL;	
 -	char	**ppDroppedItems	 =  NULL;
 -	UINT	nDroppedItemsCount	 =  0;
 -	char	szFilename[ MAX_PATH ];
 -	
 -
 -	nDroppedItemsCount = DragQueryFile( hDrop, 0xFFFFFFFF, NULL, 0 );
 +	UINT nDroppedItemsCount = DragQueryFile( hDrop, 0xFFFFFFFF, NULL, 0 );
 -	ppDroppedItems = ( char** )malloc( sizeof(char*)*( nDroppedItemsCount + 1 ));
 +	char **ppDroppedItems = ( char** )malloc( sizeof(char*)*( nDroppedItemsCount + 1 ));
  	if ( ppDroppedItems == NULL )
  	{
 -		return( FALSE );
 +		return FALSE;
  	}
  	ppDroppedItems[ nDroppedItemsCount ] = NULL;
 -	for ( iItem = 0; iItem < nDroppedItemsCount; ++iItem ) 
 +	char  szFilename[ MAX_PATH ];
 +	for (UINT iItem = 0; iItem < nDroppedItemsCount; ++iItem ) 
  	{
  		DragQueryFileA( hDrop, iItem, szFilename, sizeof( szFilename ));
  		ppDroppedItems[ iItem ] = _strdup( szFilename );
  	}
 -	nFilesCount = CountDroppedFiles( ppDroppedItems, nDroppedItemsCount );
 +	UINT nFilesCount = CountDroppedFiles( ppDroppedItems, nDroppedItemsCount );
 -	ppFiles = ( char** )malloc( sizeof( char *)* ( nFilesCount+1 ));
 +	char **ppFiles = ( char** )malloc( sizeof( char *)* ( nFilesCount+1 ));
  	if ( ppFiles == NULL )
  	{
 -		return( FALSE );
 +		return FALSE;
  	}
  	ppFiles[ nFilesCount] = NULL;
  	ProcessDroppedItems( ppDroppedItems, nDroppedItemsCount, ppFiles );
 -	bSuccess = (BOOL)CallService( MS_CLIST_CONTACTFILESDROPPED, (WPARAM)pThumb->hContact, (LPARAM)ppFiles ); 
 +	BOOL bSuccess = (BOOL)CallService( MS_CLIST_CONTACTFILESDROPPED, (WPARAM)pThumb->hContact, (LPARAM)ppFiles ); 
  	// Cleanup
 -	for ( iItem = 0; ppDroppedItems[ iItem ]; ++iItem ) 
 +	for (UINT iItem = 0; ppDroppedItems[ iItem ]; ++iItem ) 
  	{
  		free( ppDroppedItems[ iItem ] );
  	}
  	free( ppDroppedItems );
 -	for ( iItem = 0; iItem < nFilesCount ; ++iItem ) 
 +	for (UINT iItem = 0; iItem < nFilesCount ; ++iItem ) 
  	{
  		free( ppFiles[ iItem ] );
  	}
  	free( ppFiles );
 -	return( bSuccess );
 +	return bSuccess;
  }
 @@ -259,16 +244,14 @@ static int CountFiles( char *szItem )  		while( FALSE != FindNextFileA( hFind, &fd ));
  	}
 -	return( nCount );
 +	return nCount;
  }
  static void SaveFiles( char *szItem, char **ppFiles, int *pnCount )
  {
 -	
 -	WIN32_FIND_DATAA	fd;
 -
 +	WIN32_FIND_DATAA fd;
  	HANDLE hFind = FindFirstFileA( szItem, &fd );
  	if ( hFind != INVALID_HANDLE_VALUE )
 @@ -321,10 +304,9 @@ static void SaveFiles( char *szItem, char **ppFiles, int *pnCount )  static void ProcessDroppedItems( char **ppDroppedItems, int nCount, char **ppFiles  )
  {
 -	int i;
  	int fileCount = 0;
 -	for ( i = 0; i < nCount; ++i )
 +	for (int i = 0; i < nCount; ++i )
  	{
  		SaveFiles( ppDroppedItems[ i ], ppFiles, &fileCount );
  	}
 @@ -334,14 +316,13 @@ static void ProcessDroppedItems( char **ppDroppedItems, int nCount, char **ppFil  static int CountDroppedFiles( char **ppDroppedItems, int nCount  )
  {
  	int fileCount = 0;
 -	int i;
 -	for ( i = 0; i < nCount; ++i )
 +	for (int i = 0; i < nCount; ++i )
  	{
  		fileCount += CountFiles( ppDroppedItems[ i ] );
  	}
 -	return( fileCount );
 +	return fileCount;
  }
 diff --git a/plugins/FloatingContacts/src/fltcont.h b/plugins/FloatingContacts/src/fltcont.h index 3d725d71bc..4f32f30f4e 100644 --- a/plugins/FloatingContacts/src/fltcont.h +++ b/plugins/FloatingContacts/src/fltcont.h @@ -152,7 +152,7 @@ static __forceinline BOOL ImageList_GetIconSize_my(HIMAGELIST himl, SIZE &sz)  void RegHotkey				( HANDLE hContact, HWND hwnd );
  BOOL IsStatusVisible		( int status );
  BOOL HideOnFullScreen		();
 -void SendMsgDialog			( HWND hwnd, char *pText );
 +void SendMsgDialog			( HWND hwnd, TCHAR *pText );
  void SaveContactsPos		( void );
  /////////////////////////////////////////////////////////////////////////////
 diff --git a/plugins/FloatingContacts/src/main.cpp b/plugins/FloatingContacts/src/main.cpp index df6aa4320b..835bdaaad9 100644 --- a/plugins/FloatingContacts/src/main.cpp +++ b/plugins/FloatingContacts/src/main.cpp @@ -554,19 +554,18 @@ static void LoadDBSettings()  		bIsCListShow = (DBGetContactSettingByte(NULL, "CList", "State", 0) == 2);
  }
 -void SendMsgDialog( HWND hwnd, char *pText )
 +void SendMsgDialog( HWND hwnd, TCHAR *pText )
  {
  	ThumbInfo *pThumb = thumbList.FindThumb( hwnd );
  	if ( pThumb != NULL )
 -		CallService( MS_MSG_SENDMESSAGE, (WPARAM)pThumb->hContact, (LPARAM)pText );
 +		CallService( MS_MSG_SENDMESSAGET, (WPARAM)pThumb->hContact, (LPARAM)pText );
  }
  static void ShowContactMenu( HWND hwnd, POINT pt )
  {
  	ThumbInfo	*pThumb		 =  thumbList.FindThumb( hwnd );
 -	int			idCommand	 =  0;
  	if ( pThumb != NULL )
  	{
 @@ -574,7 +573,7 @@ static void ShowContactMenu( HWND hwnd, POINT pt )  		if ( hContactMenu == NULL ) return;
 -		idCommand = TrackPopupMenu( hContactMenu, TPM_RIGHTALIGN | TPM_TOPALIGN | TPM_RETURNCMD, pt.x, pt.y, 0 , hwnd, NULL );
 +		int idCommand = TrackPopupMenu( hContactMenu, TPM_RIGHTALIGN | TPM_TOPALIGN | TPM_RETURNCMD, pt.x, pt.y, 0 , hwnd, NULL );
  		CallService( MS_CLIST_MENUPROCESSCOMMAND, MAKEWPARAM( idCommand , MPCF_CONTACTMENU), (LPARAM)pThumb->hContact );
  	}
  }
 | 
