-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathredirection.c
114 lines (110 loc) · 3.13 KB
/
redirection.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
#include "headers.h"
char colon[32];
void redirection(char *command) {
int d_stdout = dup(STDOUT_FILENO);
int d_stdin = dup(STDIN_FILENO);
int inpf = 0, outf = 0, status;
char *inp = strstr(command, "<");
char *out = strstr(command, ">>");
char *out_file, *inp_file;
char *outcom[2], *incom[2];
char *com_l = (char *)malloc(sizeof(char) * MAX_INPUT_SIZE);
if (inp != NULL)
inpf = 1;
if (out != NULL)
outf = 2;
else {
char *out2 = strstr(command, ">");
if (out2 != NULL)
outf = 1;
}
char *p;
outcom[0] = command;
if (outf) {
outcom[0] = strtok(command, ">");
strcpy(com_l, outcom[0]);
outcom[1] = strtok(NULL, ">");
out_file = strtok(outcom[1], " \r\t\n");
if (out_file == NULL) {
printf(DFLT "No output file entered.\n");
strcpy(colon, ":'(");
return;
}
}
p = outcom[0];
if (inpf) {
int flag = 0;
incom[0] = strtok(p, "<");
strcpy(com_l, incom[0]);
incom[1] = strtok(NULL, "<");
if (incom[1] == NULL) {
printf(DFLT "No input file entered.\n");
strcpy(colon, ":'(");
return;
}
inp_file = strtok(incom[1], " \n\r\t");
struct stat f;
if (stat(inp_file, &f) == 0 && !S_ISDIR(f.st_mode))
flag = 1;
if (!flag) {
printf(DFLT "File does not exist.\n");
strcpy(colon, ":'(");
return;
}
}
char *token = strtok(com_l, " \n\r\t");
char **args = (char **)malloc(sizeof(char *) * 100);
int arg_num = 0;
while (token != NULL) {
args[arg_num] = (char *)malloc(sizeof(char) * (strlen(com_l) + 5));
strcpy(args[arg_num], token);
arg_num++;
token = strtok(NULL, " \n\t\r");
}
args[arg_num] = NULL;
pid_t pid = fork();
if (pid < 0) {
perror(DFLT "fork error");
strcpy(colon, ":'(");
return;
}
if (pid == 0) {
if (inpf) {
int fd = open(inp_file, O_RDONLY);
if (fd < 0) {
perror(DFLT "Input redirection error");
strcpy(colon, ":'(");
return;
}
dup2(fd, 0);
close(fd);
}
if (outf) {
int fd;
if (outf == 1)
fd = open(out_file, O_WRONLY | O_CREAT | O_TRUNC, 0644);
else if (outf == 2)
fd = open(out_file, O_WRONLY | O_CREAT | O_APPEND, 0644);
if (fd < 0) {
perror(DFLT "Output redirection error");
strcpy(colon, ":'(");
return;
}
dup2(fd, 1);
close(fd);
}
if (execvp(args[0], args) < 0) {
perror(DFLT "Command not found");
strcpy(colon, ":'(");
exit(EXIT_FAILURE);
}
dup2(d_stdin, 0);
close(d_stdin);
dup2(d_stdout, 1);
close(d_stdout);
} else
while (wait(&status) != pid);
for (int i = 0; i < arg_num; i++)
free(args[i]);
free(args);
}