start work on pspipe(1) again
This commit is contained in:
parent
0fe87b68e8
commit
563234721b
@ -1,13 +1,18 @@
|
|||||||
|
all: pscat
|
||||||
|
|
||||||
pscat: pscat.o ../libpsargs/libpsargs.o
|
pscat: pscat.o ../libpsargs/libpsargs.o
|
||||||
$(CC) $(CFLAGS) -g -o pscat ../libpsargs/libpsargs.o pscat.o
|
$(CC) $(CFLAGS) -g -o pscat ../libpsargs/libpsargs.o pscat.o
|
||||||
|
|
||||||
pscat.o: pscat.c
|
pscat.o: pscat.c
|
||||||
$(CC) $(CFLAGS) -c -I../libpsargs -o pscat.o pscat.c
|
$(CC) $(CFLAGS) -c -DPSCAT=1 -I../libpsargs -o pscat.o pscat.c
|
||||||
|
|
||||||
|
pspipe: pspipe.o ../libpsargs/libpsargs.o
|
||||||
|
$(CC) $(CFLAGS) -g -o pspipe ../libpsargs/libpsargs.o pspipe.o
|
||||||
|
|
||||||
|
pspipe.o: pscat.c
|
||||||
|
$(CC) $(CFLAGS) -c -DPSPIPE=1 -I../libpsargs -o pspipe.o pscat.c
|
||||||
|
|
||||||
../libpsargs/libpsargs.o:
|
../libpsargs/libpsargs.o:
|
||||||
$(MAKE) -C ../libpsargs
|
$(MAKE) -C ../libpsargs
|
||||||
|
|
||||||
clean:
|
.PHONY: all
|
||||||
rm -f *.o pscat
|
|
||||||
|
|
||||||
.PHONY: clean
|
|
||||||
|
@ -1,43 +1,94 @@
|
|||||||
|
#include <errno.h> /* errno */
|
||||||
#include <stdio.h> /* fprintf(3), stderr */
|
#include <stdio.h> /* fprintf(3), stderr */
|
||||||
|
#include <string.h> /* strerror(3) */
|
||||||
#include <sysexits.h> /* EX_USAGE */
|
#include <sysexits.h> /* EX_USAGE */
|
||||||
#include <unistd.h> /* execvp(3) */
|
#include <unistd.h> /* execvp(3) */
|
||||||
#include <sys/types.h> /* <sys/wait.h> */
|
#include <sys/types.h> /* <sys/wait.h> */
|
||||||
#include <sys/wait.h> /* wait(2) */
|
#include <sys/wait.h> /* wait(2) */
|
||||||
|
|
||||||
#include "libpsargs.h"
|
#include "libpsargs.h" /* check_arg(3), corresponding_arg(3) */
|
||||||
|
|
||||||
static char *program_name = "pscat";
|
|
||||||
|
|
||||||
#define L_PAREN '['
|
#define L_PAREN '['
|
||||||
#define R_PAREN ']'
|
#define R_PAREN ']'
|
||||||
|
|
||||||
|
#if defined(PSCAT)
|
||||||
|
static char *program_name = "pscat";
|
||||||
|
|
||||||
int
|
int
|
||||||
forking(char **argv){
|
f(char **argv){
|
||||||
int child;
|
int child;
|
||||||
char **corr;
|
char **corr;
|
||||||
|
|
||||||
corr = corresponding_arg(argv, L_PAREN, R_PAREN);
|
*(corr = corresponding_arg(argv, L_PAREN, R_PAREN)) = NULL;
|
||||||
*corr = NULL;
|
switch(fork()){
|
||||||
if(fork() == 0){
|
case -1:
|
||||||
execvp(argv[1], argv+1);
|
fprintf(stderr, "%s: %s\n", program_name, strerror(errno));
|
||||||
}else{
|
return EX_OSERR;
|
||||||
|
case 0: execvp(argv[1], argv+1);
|
||||||
|
default:
|
||||||
wait(&child);
|
wait(&child);
|
||||||
argv = corr;
|
argv = corr;
|
||||||
if(*++argv == NULL)
|
return *++argv == NULL
|
||||||
return WIFEXITED(child) * WEXITSTATUS(child);
|
? WIFEXITED(child) * WEXITSTATUS(child)
|
||||||
else
|
: f(argv);
|
||||||
return forking(argv);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#elif defined(PSPIPE)
|
||||||
|
static char *program_name = "pspipe";
|
||||||
|
|
||||||
|
/* At the start of the loop argv[0] is { '[', '\0' } and file descriptor 0 is
|
||||||
|
* the intended standard input */
|
||||||
|
int
|
||||||
|
f(char **argv){
|
||||||
|
int child;
|
||||||
|
char **corr;
|
||||||
|
static int fd[2];
|
||||||
|
int r;
|
||||||
|
|
||||||
|
*(corr = corresponding_arg(argv, L_PAREN, R_PAREN)) = NULL;
|
||||||
|
if(corr[1] != NULL){
|
||||||
|
if(pipe(fd) != 0){
|
||||||
|
fprintf(stderr,
|
||||||
|
"%s: %s: %s\n",
|
||||||
|
program_name, argv[1], strerror(errno)
|
||||||
|
);
|
||||||
|
return EX_OSERR;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if((r = fork()) == -1){
|
||||||
|
printf(stderr, "%s: %s\n", program_name, strerror(errno));
|
||||||
|
return EX_OSERR;
|
||||||
|
}
|
||||||
|
if(r == 0)
|
||||||
|
dup2(fd[0], 0);
|
||||||
|
else
|
||||||
|
dup2(fd[1], 1);
|
||||||
|
|
||||||
|
close(fd[1]);
|
||||||
|
close(fd[0]);
|
||||||
|
|
||||||
|
if(r == 1)
|
||||||
|
execvp(argv[1], argv+1);
|
||||||
|
else{
|
||||||
|
argv = corr;
|
||||||
|
return *++argv == NULL
|
||||||
|
? WIFEXITED(child) * WEXITSTATUS(child)
|
||||||
|
: f(argv);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
int main(int argc, char *argv[]){
|
int main(int argc, char *argv[]){
|
||||||
|
|
||||||
|
if(argc != 0)
|
||||||
|
program_name = argv[0];
|
||||||
if(check_arg(++argv, L_PAREN, R_PAREN) == 0){
|
if(check_arg(++argv, L_PAREN, R_PAREN) == 0){
|
||||||
fprintf(stderr,
|
fprintf(stderr,
|
||||||
"Usage: %s \"[\" [utility [argument...]] \"]\" ...\n",
|
"Usage: %s \"[\" [utility [argument...]] \"]\" ...\n",
|
||||||
argv[-1] == NULL ? program_name : argv[-1]
|
program_name
|
||||||
);
|
);
|
||||||
return EX_USAGE;
|
return EX_USAGE;
|
||||||
}else
|
}else return f(argv);
|
||||||
return forking(argv);
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user