ttyread: test for EOF while reading tty
When a read operation returns 0 then it means that we arrived to the end of the file, and new reads will return 0 unless you do some other operation such as lseek(). This case happens with USB-232 adapters when they are unplugged.
This commit is contained in:
		
							parent
							
								
									21e0d6e8b8
								
							
						
					
					
						commit
						e52319cc7d
					
				
					 1 changed files with 16 additions and 9 deletions
				
			
		
							
								
								
									
										25
									
								
								st.c
									
										
									
									
									
								
							
							
						
						
									
										25
									
								
								st.c
									
										
									
									
									
								
							|  | @ -823,17 +823,24 @@ ttyread(void) | |||
| 	int ret; | ||||
| 
 | ||||
| 	/* append read bytes to unprocessed bytes */ | ||||
| 	if ((ret = read(cmdfd, buf+buflen, LEN(buf)-buflen)) < 0) | ||||
| 	ret = read(cmdfd, buf+buflen, LEN(buf)-buflen); | ||||
| 
 | ||||
| 	switch (ret) { | ||||
| 	case 0: | ||||
| 		fputs("Found EOF in input\n", stderr); | ||||
| 		exit(0); | ||||
| 	case -1: | ||||
| 		die("couldn't read from shell: %s\n", strerror(errno)); | ||||
| 	buflen += ret; | ||||
| 	default: | ||||
| 		buflen += ret; | ||||
| 		written = twrite(buf, buflen, 0); | ||||
| 		buflen -= written; | ||||
| 		/* keep any uncomplete utf8 char for the next call */ | ||||
| 		if (buflen > 0) | ||||
| 			memmove(buf, buf + written, buflen); | ||||
| 		return ret; | ||||
| 
 | ||||
| 	written = twrite(buf, buflen, 0); | ||||
| 	buflen -= written; | ||||
| 	/* keep any uncomplete utf8 char for the next call */ | ||||
| 	if (buflen > 0) | ||||
| 		memmove(buf, buf + written, buflen); | ||||
| 
 | ||||
| 	return ret; | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| void | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue