mirror of
https://git.freebsd.org/src.git
synced 2026-01-16 23:02:24 +00:00
xargs: use getline() instead of fgetln()
This replaces fgetln() with getline(). The main reason for this is portability, making things easier for people who want to compile these tools on non-FreeBSD systems. I appreciate that's probably not the top concern for FreeBSD base tools, but fgetln() is impossible to port to most platforms, as concurrent access is essentially impossible to implement fully correct without the line buffer on the FILE struct. Other than this, many generic FreeBSD tools compile fairly cleanly on Linux with a few small changes. Most uses of fgetln() pre-date getline() support (added in 2009 with69099ba2ec), and there's been some previous patches (ee3ca711a88c98e6b1a71a2a4fc8ce) for other tools. Obtained from: https://github.com/dcantrell/bsdutils and https://github.com/chimera-linux/chimerautils Signed-off-by: Martin Tournoij <martin@arp242.net> Reviewed by: imp Pull Request: https://github.com/freebsd/freebsd-src/pull/893
This commit is contained in:
parent
25696725b6
commit
5fbdcd65fe
1 changed files with 4 additions and 4 deletions
|
|
@ -770,22 +770,22 @@ static int
|
|||
prompt(void)
|
||||
{
|
||||
regex_t cre;
|
||||
size_t rsize;
|
||||
size_t rsize = 0;
|
||||
int match;
|
||||
char *response;
|
||||
char *response = NULL;
|
||||
FILE *ttyfp;
|
||||
|
||||
if ((ttyfp = fopen(_PATH_TTY, "r")) == NULL)
|
||||
return (2); /* Indicate that the TTY failed to open. */
|
||||
(void)fprintf(stderr, "?...");
|
||||
(void)fflush(stderr);
|
||||
if ((response = fgetln(ttyfp, &rsize)) == NULL ||
|
||||
if (getline(&response, &rsize, ttyfp) < 0 ||
|
||||
regcomp(&cre, nl_langinfo(YESEXPR), REG_EXTENDED) != 0) {
|
||||
(void)fclose(ttyfp);
|
||||
return (0);
|
||||
}
|
||||
response[rsize - 1] = '\0';
|
||||
match = regexec(&cre, response, 0, NULL, 0);
|
||||
free(response);
|
||||
(void)fclose(ttyfp);
|
||||
regfree(&cre);
|
||||
return (match == 0);
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue