readstdin: use getline(3)
currently readstdin(): - fgets() into a local buffer, - strchr() the buffer to eleminate the newline - stdups() the buffer into items a simpler way is to just use getline(3), which will do the allocation for us; eliminating the need for stdup()-ing. additionally getline returns back the amount of bytes read, which eliminates the need for strchr()-ing to find the newline.
This commit is contained in:
		
							
								
								
									
										14
									
								
								dmenu.c
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								dmenu.c
									
									
									
									
									
								
							@ -549,18 +549,18 @@ paste(void)
 | 
			
		||||
static void
 | 
			
		||||
readstdin(void)
 | 
			
		||||
{
 | 
			
		||||
	char buf[sizeof text], *p;
 | 
			
		||||
	size_t i, size = 0;
 | 
			
		||||
	char *line = NULL;
 | 
			
		||||
	size_t i, junk, size = 0;
 | 
			
		||||
	ssize_t len;
 | 
			
		||||
 | 
			
		||||
	/* read each line from stdin and add it to the item list */
 | 
			
		||||
	for (i = 0; fgets(buf, sizeof buf, stdin); i++) {
 | 
			
		||||
	for (i = 0; (len = getline(&line, &junk, stdin)) != -1; i++, line = NULL) {
 | 
			
		||||
		if (i + 1 >= size / sizeof *items)
 | 
			
		||||
			if (!(items = realloc(items, (size += BUFSIZ))))
 | 
			
		||||
				die("cannot realloc %zu bytes:", size);
 | 
			
		||||
		if ((p = strchr(buf, '\n')))
 | 
			
		||||
			*p = '\0';
 | 
			
		||||
		if (!(items[i].text = strdup(buf)))
 | 
			
		||||
			die("cannot strdup %zu bytes:", strlen(buf) + 1);
 | 
			
		||||
		if (line[len - 1] == '\n')
 | 
			
		||||
			line[len - 1] = '\0';
 | 
			
		||||
		items[i].text = line;
 | 
			
		||||
		items[i].out = 0;
 | 
			
		||||
	}
 | 
			
		||||
	if (items)
 | 
			
		||||
 | 
			
		||||
		Reference in New Issue
	
	Block a user