mirror of
https://github.com/sheumann/hush.git
synced 2025-01-04 22:34:37 +00:00
libpwdgrp: can't depend on strlen(line_buff) != 0
function old new delta bb__pgsreader 188 202 +14 Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
This commit is contained in:
parent
84f6def072
commit
57dc3c7b4c
@ -19,7 +19,6 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "libbb.h"
|
#include "libbb.h"
|
||||||
//#include <features.h>
|
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
|
||||||
#ifndef _PATH_SHADOW
|
#ifndef _PATH_SHADOW
|
||||||
@ -1000,7 +999,6 @@ static int bb__parsespent(void *data, char *line)
|
|||||||
if (*endptr != ':') {
|
if (*endptr != ':') {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
*line++ = '\0';
|
*line++ = '\0';
|
||||||
@ -1022,56 +1020,60 @@ static int bb__parsespent(void *data, char *line)
|
|||||||
static int bb__pgsreader(int (*parserfunc)(void *d, char *line), void *data,
|
static int bb__pgsreader(int (*parserfunc)(void *d, char *line), void *data,
|
||||||
char *__restrict line_buff, size_t buflen, FILE *f)
|
char *__restrict line_buff, size_t buflen, FILE *f)
|
||||||
{
|
{
|
||||||
int line_len;
|
|
||||||
int skip;
|
int skip;
|
||||||
int rv = ERANGE;
|
int rv = ERANGE;
|
||||||
|
|
||||||
if (buflen < PWD_BUFFER_SIZE) {
|
if (buflen < PWD_BUFFER_SIZE) {
|
||||||
errno = rv;
|
errno = rv;
|
||||||
} else {
|
return rv;
|
||||||
skip = 0;
|
}
|
||||||
do {
|
|
||||||
if (!fgets(line_buff, buflen, f)) {
|
skip = 0;
|
||||||
if (feof(f)) {
|
while (1) {
|
||||||
rv = ENOENT;
|
if (!fgets(line_buff, buflen, f)) {
|
||||||
}
|
if (feof(f)) {
|
||||||
|
rv = ENOENT;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
int line_len = strlen(line_buff) - 1;
|
||||||
|
if (line_len >= 0 && line_buff[line_len] == '\n') {
|
||||||
|
line_buff[line_len] = '\0';
|
||||||
|
} else
|
||||||
|
if (line_len + 2 == buflen) {
|
||||||
|
/* A start (or continuation) of overlong line */
|
||||||
|
skip = 1;
|
||||||
|
continue;
|
||||||
|
} /* else: a last line in the file, and it has no '\n' */
|
||||||
|
}
|
||||||
|
|
||||||
|
if (skip) {
|
||||||
|
/* This "line" is a remainder of overlong line, ignore */
|
||||||
|
skip = 0;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* NOTE: glibc difference - glibc strips leading whitespace from
|
||||||
|
* records. We do not allow leading whitespace. */
|
||||||
|
|
||||||
|
/* Skip empty lines, comment lines, and lines with leading
|
||||||
|
* whitespace. */
|
||||||
|
if (line_buff[0] != '\0' && line_buff[0] != '#' && !isspace(line_buff[0])) {
|
||||||
|
if (parserfunc == bb__parsegrent) {
|
||||||
|
/* Do evil group hack:
|
||||||
|
* The group entry parsing function needs to know where
|
||||||
|
* the end of the buffer is so that it can construct the
|
||||||
|
* group member ptr table. */
|
||||||
|
((struct group *) data)->gr_name = line_buff + buflen;
|
||||||
|
}
|
||||||
|
if (parserfunc(data, line_buff) == 0) {
|
||||||
|
rv = 0;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
line_len = strlen(line_buff) - 1; /* strlen() must be > 0. */
|
} /* while (1) */
|
||||||
if (line_buff[line_len] == '\n') {
|
|
||||||
line_buff[line_len] = 0;
|
|
||||||
} else if (line_len + 2 == buflen) { /* line too long */
|
|
||||||
++skip;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (skip) {
|
|
||||||
--skip;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* NOTE: glibc difference - glibc strips leading whitespace from
|
|
||||||
* records. We do not allow leading whitespace. */
|
|
||||||
|
|
||||||
/* Skip empty lines, comment lines, and lines with leading
|
|
||||||
* whitespace. */
|
|
||||||
if (*line_buff && (*line_buff != '#') && !isspace(*line_buff)) {
|
|
||||||
if (parserfunc == bb__parsegrent) { /* Do evil group hack. */
|
|
||||||
/* The group entry parsing function needs to know where
|
|
||||||
* the end of the buffer is so that it can construct the
|
|
||||||
* group member ptr table. */
|
|
||||||
((struct group *) data)->gr_name = line_buff + buflen;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!parserfunc(data, line_buff)) {
|
|
||||||
rv = 0;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} while (1);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
return rv;
|
return rv;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user