selection code cleanup.
This commit is contained in:
		
							
								
								
									
										97
									
								
								st.c
									
									
									
									
									
								
							
							
						
						
									
										97
									
								
								st.c
									
									
									
									
									
								
							| @@ -286,35 +286,24 @@ static char *getseltext() { | |||||||
|  |  | ||||||
| static void selection_notify(XEvent *e) { | static void selection_notify(XEvent *e) { | ||||||
| 	unsigned long nitems; | 	unsigned long nitems; | ||||||
| 	unsigned long length; | 	unsigned long ofs, rem; | ||||||
| 	int format, res; | 	int format; | ||||||
| 	unsigned char *data; | 	unsigned char *data; | ||||||
| 	Atom type; | 	Atom type; | ||||||
|  |  | ||||||
| 	res = XGetWindowProperty(xw.dis, xw.win, XA_PRIMARY, 0, 0, False,  | 	ofs = 0; | ||||||
| 				AnyPropertyType, &type, &format, &nitems, &length, &data); | 	do { | ||||||
| 	switch(res) { | 		if(XGetWindowProperty(xw.dis, xw.win, XA_PRIMARY, ofs, BUFSIZ/4, | ||||||
| 		case BadAtom: | 					False, AnyPropertyType, &type, &format, | ||||||
| 		case BadValue: | 					&nitems, &rem, &data)) { | ||||||
| 		case BadWindow: | 			fprintf(stderr, "Clipboard allocation failed\n"); | ||||||
| 			fprintf(stderr, "Invalid paste, XGetWindowProperty0"); |  | ||||||
| 			return; | 			return; | ||||||
| 	} | 		} | ||||||
|  |  | ||||||
| 	res = XGetWindowProperty(xw.dis, xw.win, XA_PRIMARY, 0, length, False, |  | ||||||
| 				AnyPropertyType, &type, &format, &nitems, &length, &data); |  | ||||||
| 	switch(res) { |  | ||||||
| 		case BadAtom: |  | ||||||
| 		case BadValue: |  | ||||||
| 		case BadWindow: |  | ||||||
| 			fprintf(stderr, "Invalid paste, XGetWindowProperty0"); |  | ||||||
| 			return; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	if(data) { |  | ||||||
| 		ttywrite((const char *) data, nitems * format / 8); | 		ttywrite((const char *) data, nitems * format / 8); | ||||||
| 		XFree(data); | 		XFree(data); | ||||||
| 	} | 		/* number of 32-bit chunks returned */ | ||||||
|  | 		ofs += nitems * format / 32; | ||||||
|  | 	} while(rem > 0); | ||||||
| } | } | ||||||
|  |  | ||||||
| static void selpaste() { | static void selpaste() { | ||||||
| @@ -325,7 +314,6 @@ static void selection_request(XEvent *e) | |||||||
| { | { | ||||||
| 	XSelectionRequestEvent *xsre; | 	XSelectionRequestEvent *xsre; | ||||||
| 	XSelectionEvent xev; | 	XSelectionEvent xev; | ||||||
| 	int res; |  | ||||||
| 	Atom xa_targets; | 	Atom xa_targets; | ||||||
|  |  | ||||||
| 	xsre = (XSelectionRequestEvent *) e; | 	xsre = (XSelectionRequestEvent *) e; | ||||||
| @@ -341,70 +329,33 @@ static void selection_request(XEvent *e) | |||||||
| 	if(xsre->target == xa_targets) { | 	if(xsre->target == xa_targets) { | ||||||
| 		/* respond with the supported type */ | 		/* respond with the supported type */ | ||||||
| 		Atom string = XA_STRING; | 		Atom string = XA_STRING; | ||||||
| 		res = XChangeProperty(xsre->display, xsre->requestor, xsre->property, XA_ATOM, 32, | 		XChangeProperty(xsre->display, xsre->requestor, xsre->property, | ||||||
| 				PropModeReplace, (unsigned char *) &string, 1); | 				XA_ATOM, 32, PropModeReplace, | ||||||
| 		switch(res) { | 				(unsigned char *) &string, 1); | ||||||
| 			case BadAlloc: | 		xev.property = xsre->property; | ||||||
| 			case BadAtom: |  | ||||||
| 			case BadMatch: |  | ||||||
| 			case BadValue: |  | ||||||
| 			case BadWindow: |  | ||||||
| 				fprintf(stderr, "Error in selection_request, TARGETS"); |  | ||||||
| 				break; |  | ||||||
| 			default: |  | ||||||
| 				xev.property = xsre->property; |  | ||||||
| 		} |  | ||||||
| 	} else if(xsre->target == XA_STRING) { | 	} else if(xsre->target == XA_STRING) { | ||||||
| 		res = XChangeProperty(xsre->display, xsre->requestor, xsre->property, | 		XChangeProperty(xsre->display, xsre->requestor, xsre->property, | ||||||
| 				xsre->target, 8, PropModeReplace, (unsigned char *) sel.clip, | 				xsre->target, 8, PropModeReplace, | ||||||
| 				strlen(sel.clip)); | 				(unsigned char *) sel.clip, strlen(sel.clip)); | ||||||
| 		switch(res) { | 		xev.property = xsre->property; | ||||||
| 			case BadAlloc: |  | ||||||
| 			case BadAtom: |  | ||||||
| 			case BadMatch: |  | ||||||
| 			case BadValue: |  | ||||||
| 			case BadWindow: |  | ||||||
| 				fprintf(stderr, "Error in selection_request, XA_STRING"); |  | ||||||
| 				break; |  | ||||||
| 			default: |  | ||||||
| 			 xev.property = xsre->property; |  | ||||||
| 		} |  | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	/* all done, send a notification to the listener */ | 	/* all done, send a notification to the listener */ | ||||||
| 	res = XSendEvent(xsre->display, xsre->requestor, True, 0, (XEvent *) &xev); | 	if(!XSendEvent(xsre->display, xsre->requestor, True, 0, (XEvent *) &xev)) | ||||||
| 	switch(res) { | 		fprintf(stderr, "Error sending SelectionNotify event\n"); | ||||||
| 		case 0: |  | ||||||
| 		case BadValue: |  | ||||||
| 		case BadWindow: |  | ||||||
| 			fprintf(stderr, "Error in selection_requested, XSendEvent"); |  | ||||||
| 	} |  | ||||||
| } | } | ||||||
|  |  | ||||||
| static void selcopy(char *str) { | static void selcopy(char *str) { | ||||||
| 	/* register the selection for both the clipboard and the primary */ | 	/* register the selection for both the clipboard and the primary */ | ||||||
| 	Atom clipboard; | 	Atom clipboard; | ||||||
| 	int res; |  | ||||||
|  |  | ||||||
| 	free(sel.clip); | 	free(sel.clip); | ||||||
| 	sel.clip = str; | 	sel.clip = str; | ||||||
|  |  | ||||||
| 	res = XSetSelectionOwner(xw.dis, XA_PRIMARY, xw.win, CurrentTime); | 	XSetSelectionOwner(xw.dis, XA_PRIMARY, xw.win, CurrentTime); | ||||||
| 	switch(res) { |  | ||||||
| 		case BadAtom: |  | ||||||
| 		case BadWindow: |  | ||||||
| 			fprintf(stderr, "Invalid copy, XSetSelectionOwner"); |  | ||||||
| 			return; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	clipboard = XInternAtom(xw.dis, "CLIPBOARD", 0); | 	clipboard = XInternAtom(xw.dis, "CLIPBOARD", 0); | ||||||
| 	res = XSetSelectionOwner(xw.dis, clipboard, xw.win, CurrentTime); | 	XSetSelectionOwner(xw.dis, clipboard, xw.win, CurrentTime); | ||||||
| 	switch(res) { |  | ||||||
| 		case BadAtom: |  | ||||||
| 		case BadWindow: |  | ||||||
| 			fprintf(stderr, "Invalid copy, XSetSelectionOwner"); |  | ||||||
| 			return; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	XFlush(xw.dis); | 	XFlush(xw.dis); | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Aurélien Aptel
					Aurélien Aptel