aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTristan Riehs <tristan.riehs@bordeaux-inp.fr>2023-10-20 08:11:34 +0200
committerTristan Riehs <tristan.riehs@bordeaux-inp.fr>2023-10-20 08:11:34 +0200
commit75c555bada280559253975349c192f956ab35674 (patch)
treed15ba2a4c5535362f7a2caba150ceb08fca6fe09
parentfb811629ea6bf1837c2ae4de2ffa3f3207b28c75 (diff)
piping supported
-rw-r--r--rpt.c22
1 files changed, 12 insertions, 10 deletions
diff --git a/rpt.c b/rpt.c
index cf466c0..6650f1e 100644
--- a/rpt.c
+++ b/rpt.c
@@ -14,8 +14,12 @@
/* Size of the buffer used to clone stdin. */
#define BUFSIZE 8000
+/* Clone of stdin. Used to perform lseek(2) calls between each child
+ process. */
+static FILE *stdin_clone;
+
/* File descriptor associated to the clone of stdin. */
-int clone_fd;
+static int clone_fd;
void
print_usage(FILE *output)
@@ -63,7 +67,7 @@ exec_child(char **argv)
{
int status;
- status = lseek(STDIN_FILENO, 0, L_SET);
+ status = lseek(clone_fd, 0, L_SET);
if (status < 0)
{
@@ -71,7 +75,7 @@ exec_child(char **argv)
exit(4);
}
- status = dup2(dup(clone_fd), STDIN_FILENO);
+ status = dup2(clone_fd, STDIN_FILENO);
if (status < 0)
{
@@ -131,17 +135,16 @@ copy_stdin()
{
ssize_t nbytes;
char buf[BUFSIZE];
- FILE *tmp_stream;
- tmp_stream = tmpfile();
+ stdin_clone = tmpfile(); /* closed at the end of the main */
- if (!tmp_stream)
+ if (!stdin_clone)
{
perror("rpt");
exit(1);
}
- clone_fd = fileno(tmp_stream);
+ clone_fd = fileno(stdin_clone);
errno = 0;
while ((nbytes = read(STDIN_FILENO, buf, BUFSIZE)) > 0)
@@ -150,10 +153,9 @@ copy_stdin()
break;
}
- fclose(tmp_stream);
-
if (errno)
{
+ fclose(stdin_clone);
perror("rpt");
exit(1);
}
@@ -226,6 +228,6 @@ main(int argc, char* argv[])
copy_stdin();
repeat_cmd(argv + optind, count, handle_error_f);
- close(clone_fd);
+ fclose(stdin_clone);
return 0;
}