applied cls' patch, thanks Connor!
This commit is contained in:
		
							parent
							
								
									37236f8840
								
							
						
					
					
						commit
						8e3e61170b
					
				
							
								
								
									
										24
									
								
								dmenu.c
									
									
									
									
									
								
							
							
						
						
									
										24
									
								
								dmenu.c
									
									
									
									
									
								
							| @ -372,7 +372,7 @@ initfont(const char *fontstr) { | ||||
| 
 | ||||
| void | ||||
| kpress(XKeyEvent * e) { | ||||
| 	char buf[32]; | ||||
| 	char buf[sizeof text]; | ||||
| 	int i, num; | ||||
| 	unsigned int len; | ||||
| 	KeySym ksym; | ||||
| @ -457,25 +457,23 @@ kpress(XKeyEvent * e) { | ||||
| 				char *c; | ||||
| 				if(!(fp = (FILE*)popen("sselp", "r"))) | ||||
| 					eprint("dmenu: Could not popen sselp\n"); | ||||
| 				c = fgets(text + len, sizeof(text) - len, fp); | ||||
| 				c = fgets(buf, sizeof buf, fp); | ||||
| 				pclose(fp); | ||||
| 				if(c == NULL) | ||||
| 					return; | ||||
| 			} | ||||
| 			len = strlen(text); | ||||
| 			if(len && text[len-1] == '\n') | ||||
| 				text[--len] = '\0'; | ||||
| 			match(text); | ||||
| 			drawmenu(); | ||||
| 			return; | ||||
| 			num = strlen(buf); | ||||
| 			if(num && buf[num-1] == '\n') | ||||
| 				buf[--num] = '\0'; | ||||
| 			break; | ||||
| 		} | ||||
| 	} | ||||
| 	switch(ksym) { | ||||
| 	default: | ||||
| 		num = MIN(num, sizeof text - cursor); | ||||
| 		if(num && !iscntrl((int) buf[0])) { | ||||
| 			buf[num] = 0; | ||||
| 			memmove(text + cursor + num, text + cursor, sizeof text - cursor); | ||||
| 			strncpy(text + cursor, buf, sizeof text - cursor); | ||||
| 			memmove(text + cursor + num, text + cursor, sizeof text - cursor - num); | ||||
| 			memmove(text + cursor, buf, num); | ||||
| 			cursor+=num; | ||||
| 			match(text); | ||||
| 		} | ||||
| @ -487,6 +485,10 @@ kpress(XKeyEvent * e) { | ||||
| 			match(text); | ||||
| 		} | ||||
| 		break; | ||||
| 	case XK_Delete: | ||||
| 		memmove(text + cursor, text + cursor + 1, sizeof text - cursor); | ||||
| 		match(text); | ||||
| 		break; | ||||
| 	case XK_End: | ||||
| 		if(!item) | ||||
| 			return; | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 anselm@garbe.us
						anselm@garbe.us