| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | ! Copyright (C) 2006, 2007 Slava Pestov | 
					
						
							|  |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2008-04-20 06:15:46 -04:00
										 |  |  | USING: alien alien.c-types alien.strings alien.syntax arrays | 
					
						
							|  |  |  | kernel math namespaces sequences io.encodings.string | 
					
						
							| 
									
										
										
										
											2009-04-18 02:56:29 -04:00
										 |  |  | io.encodings.utf8 io.encodings.ascii x11 x11.xlib x11.constants | 
					
						
							| 
									
										
										
										
											2008-12-03 01:05:46 -05:00
										 |  |  | specialized-arrays.int accessors ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | IN: x11.clipboard | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ! This code was based on by McCLIM's Backends/CLX/port.lisp | 
					
						
							|  |  |  | ! and http://common-lisp.net/~crhodes/clx/demo/clipboard.lisp. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  | : XA_CLIPBOARD ( -- atom ) "CLIPBOARD" x-atom ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-09 03:14:14 -04:00
										 |  |  | : XA_UTF8_STRING ( -- atom ) "UTF8_STRING" x-atom ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | TUPLE: x-clipboard atom contents ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : <x-clipboard> ( atom -- clipboard )
 | 
					
						
							| 
									
										
										
										
											2008-04-13 16:06:27 -04:00
										 |  |  |     "" x-clipboard boa ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : selection-property ( -- n )
 | 
					
						
							|  |  |  |     "org.factorcode.Factor.SELECTION" x-atom ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : convert-selection ( win selection -- )
 | 
					
						
							| 
									
										
										
										
											2008-12-15 21:34:57 -05:00
										 |  |  |     swap [ [ dpy get ] dip XA_UTF8_STRING selection-property ] dip
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     CurrentTime XConvertSelection drop ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : snarf-property ( prop-return -- string )
 | 
					
						
							| 
									
										
										
										
											2009-03-19 18:36:38 -04:00
										 |  |  |     dup *void* [ *void* utf8 alien>string ] [ drop f ] if ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : window-property ( win prop delete? -- string )
 | 
					
						
							| 
									
										
										
										
											2008-12-15 21:34:57 -05:00
										 |  |  |     [ [ dpy get ] 2dip 0 -1 ] dip AnyPropertyType | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     0 <Atom> 0 <int> 0 <ulong> 0 <ulong> f <void*> | 
					
						
							|  |  |  |     [ XGetWindowProperty drop ] keep snarf-property ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : selection-from-event ( event window -- string )
 | 
					
						
							| 
									
										
										
										
											2008-08-24 04:59:37 -04:00
										 |  |  |     swap XSelectionEvent-property zero? [ | 
					
						
							|  |  |  |         drop f
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     ] [ | 
					
						
							| 
									
										
										
										
											2009-03-19 18:36:38 -04:00
										 |  |  |         selection-property 1 window-property | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : own-selection ( prop win -- )
 | 
					
						
							| 
									
										
										
										
											2009-01-23 19:20:47 -05:00
										 |  |  |     [ dpy get ] 2dip CurrentTime XSetSelectionOwner drop
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     flush-dpy ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : set-targets-prop ( evt -- )
 | 
					
						
							|  |  |  |     dpy get swap
 | 
					
						
							|  |  |  |     [ XSelectionRequestEvent-requestor ] keep
 | 
					
						
							|  |  |  |     XSelectionRequestEvent-property | 
					
						
							|  |  |  |     "TARGETS" x-atom 32 PropModeReplace | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         "UTF8_STRING" "STRING" "TARGETS" "TIMESTAMP" | 
					
						
							| 
									
										
										
										
											2009-02-06 05:37:28 -05:00
										 |  |  |     } [ x-atom ] int-array{ } map-as
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     4 XChangeProperty drop ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : set-timestamp-prop ( evt -- )
 | 
					
						
							|  |  |  |     dpy get swap
 | 
					
						
							|  |  |  |     [ XSelectionRequestEvent-requestor ] keep
 | 
					
						
							|  |  |  |     [ XSelectionRequestEvent-property ] keep
 | 
					
						
							| 
									
										
										
										
											2008-12-15 21:34:57 -05:00
										 |  |  |     [ "TIMESTAMP" x-atom 32 PropModeReplace ] dip
 | 
					
						
							| 
									
										
										
										
											2008-11-14 21:18:16 -05:00
										 |  |  |     XSelectionRequestEvent-time <int> | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     1 XChangeProperty drop ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : send-notify ( evt prop -- )
 | 
					
						
							|  |  |  |     "XSelectionEvent" <c-object> | 
					
						
							|  |  |  |     SelectionNotify over set-XSelectionEvent-type | 
					
						
							|  |  |  |     [ set-XSelectionEvent-property ] keep
 | 
					
						
							|  |  |  |     over XSelectionRequestEvent-display   over set-XSelectionEvent-display | 
					
						
							|  |  |  |     over XSelectionRequestEvent-requestor over set-XSelectionEvent-requestor | 
					
						
							|  |  |  |     over XSelectionRequestEvent-selection over set-XSelectionEvent-selection | 
					
						
							|  |  |  |     over XSelectionRequestEvent-target    over set-XSelectionEvent-target | 
					
						
							|  |  |  |     over XSelectionRequestEvent-time      over set-XSelectionEvent-time | 
					
						
							| 
									
										
										
										
											2008-12-15 21:34:57 -05:00
										 |  |  |     [ dpy get swap XSelectionRequestEvent-requestor 0 0 ] dip
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  |     XSendEvent drop
 | 
					
						
							|  |  |  |     flush-dpy ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : send-notify-success ( evt -- )
 | 
					
						
							|  |  |  |     dup XSelectionRequestEvent-property send-notify ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : send-notify-failure ( evt -- )
 | 
					
						
							|  |  |  |     0 send-notify ;
 |