libutil/getlines: fix crash with no lines
because b->lines and b->nlines would be 0 with no lines read.
reproduce: printf '' | sort or cols
bug was introduced by commit: 66a5ea722d
			
			
This commit is contained in:
		@@ -9,20 +9,21 @@
 | 
				
			|||||||
void
 | 
					void
 | 
				
			||||||
getlines(FILE *fp, struct linebuf *b)
 | 
					getlines(FILE *fp, struct linebuf *b)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	char *line = NULL, **nline;
 | 
						char *line = NULL;
 | 
				
			||||||
	size_t size = 0, linelen;
 | 
						size_t size = 0, linelen;
 | 
				
			||||||
	ssize_t len;
 | 
						ssize_t len;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	while ((len = getline(&line, &size, fp)) > 0) {
 | 
						while ((len = getline(&line, &size, fp)) > 0) {
 | 
				
			||||||
		if (++b->nlines > b->capacity) {
 | 
							if (++b->nlines > b->capacity) {
 | 
				
			||||||
			b->capacity += 512;
 | 
								b->capacity += 512;
 | 
				
			||||||
			nline = erealloc(b->lines, b->capacity * sizeof(*b->lines));
 | 
								b->lines = erealloc(b->lines, b->capacity * sizeof(*b->lines));
 | 
				
			||||||
			b->lines = nline;
 | 
					 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		linelen = len + 1;
 | 
							linelen = len + 1;
 | 
				
			||||||
		b->lines[b->nlines - 1] = memcpy(emalloc(linelen), line, linelen);
 | 
							b->lines[b->nlines - 1] = memcpy(emalloc(linelen), line, linelen);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	free(line);
 | 
						free(line);
 | 
				
			||||||
 | 
						if(!b->nlines || !b->lines)
 | 
				
			||||||
 | 
							return;
 | 
				
			||||||
	if (!strchr(b->lines[b->nlines - 1], '\n')) {
 | 
						if (!strchr(b->lines[b->nlines - 1], '\n')) {
 | 
				
			||||||
		b->lines[b->nlines - 1] = erealloc(b->lines[b->nlines - 1], linelen + 1);
 | 
							b->lines[b->nlines - 1] = erealloc(b->lines[b->nlines - 1], linelen + 1);
 | 
				
			||||||
		b->lines[b->nlines - 1][linelen - 1] = '\n';
 | 
							b->lines[b->nlines - 1][linelen - 1] = '\n';
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user