Merge pull request #401 from fufesou/copy_paste_3
Windows clipboard -- fix memory leak
This commit is contained in:
		
						commit
						9b22ee765d
					
				| @ -248,7 +248,7 @@ typedef struct wf_clipboard wfClipboard; | |||||||
| 
 | 
 | ||||||
| #define WM_CLIPRDR_MESSAGE (WM_USER + 156) | #define WM_CLIPRDR_MESSAGE (WM_USER + 156) | ||||||
| #define OLE_SETCLIPBOARD 1 | #define OLE_SETCLIPBOARD 1 | ||||||
| #define DELAY_RENDERING 2 | #define DELAYED_RENDERING 2 | ||||||
| 
 | 
 | ||||||
| BOOL wf_cliprdr_init(wfClipboard *clipboard, CliprdrClientContext *cliprdr); | BOOL wf_cliprdr_init(wfClipboard *clipboard, CliprdrClientContext *cliprdr); | ||||||
| BOOL wf_cliprdr_uninit(wfClipboard *clipboard, CliprdrClientContext *cliprdr); | BOOL wf_cliprdr_uninit(wfClipboard *clipboard, CliprdrClientContext *cliprdr); | ||||||
| @ -1632,14 +1632,16 @@ static LRESULT CALLBACK cliprdr_proc(HWND hWnd, UINT Msg, WPARAM wParam, LPARAM | |||||||
| 
 | 
 | ||||||
| 			break; | 			break; | ||||||
| 
 | 
 | ||||||
| 		case DELAY_RENDERING: | 		case DELAYED_RENDERING: | ||||||
|  | 			FORMAT_IDS *format_ids = (FORMAT_IDS *)lParam; | ||||||
| 			if (!try_open_clipboard(clipboard->hwnd)) | 			if (!try_open_clipboard(clipboard->hwnd)) | ||||||
| 			{ | 			{ | ||||||
| 				// failed to open clipboard
 | 				// failed to open clipboard
 | ||||||
|  | 				free(format_ids->formats); | ||||||
|  | 				free(format_ids); | ||||||
| 				break; | 				break; | ||||||
| 			} | 			} | ||||||
| 
 | 
 | ||||||
| 			FORMAT_IDS *format_ids = (FORMAT_IDS *)lParam; |  | ||||||
| 			for (UINT32 i = 0; i < format_ids->size; ++i) | 			for (UINT32 i = 0; i < format_ids->size; ++i) | ||||||
| 			{ | 			{ | ||||||
| 				if (cliprdr_send_data_request(format_ids->serverConnID, format_ids->remoteConnID, clipboard, format_ids->formats[i]) != 0) | 				if (cliprdr_send_data_request(format_ids->serverConnID, format_ids->remoteConnID, clipboard, format_ids->formats[i]) != 0) | ||||||
| @ -1668,7 +1670,6 @@ static LRESULT CALLBACK cliprdr_proc(HWND hWnd, UINT Msg, WPARAM wParam, LPARAM | |||||||
| 
 | 
 | ||||||
| 			free(format_ids->formats); | 			free(format_ids->formats); | ||||||
| 			free(format_ids); | 			free(format_ids); | ||||||
| 
 |  | ||||||
| 			break; | 			break; | ||||||
| 
 | 
 | ||||||
| 		default: | 		default: | ||||||
| @ -2159,7 +2160,7 @@ static UINT wf_cliprdr_server_format_list(CliprdrClientContext *context, | |||||||
| 				{ | 				{ | ||||||
| 					format_ids->formats[i] = clipboard->format_mappings[i].local_format_id; | 					format_ids->formats[i] = clipboard->format_mappings[i].local_format_id; | ||||||
| 				} | 				} | ||||||
| 				if (PostMessage(clipboard->hwnd, WM_CLIPRDR_MESSAGE, DELAY_RENDERING, format_ids)) | 				if (PostMessage(clipboard->hwnd, WM_CLIPRDR_MESSAGE, DELAYED_RENDERING, format_ids)) | ||||||
| 				{ | 				{ | ||||||
| 					rc = CHANNEL_RC_OK; | 					rc = CHANNEL_RC_OK; | ||||||
| 				} | 				} | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user