-
Notifications
You must be signed in to change notification settings - Fork 160
/
Copy pathexecl.c
63 lines (45 loc) · 1.29 KB
/
execl.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
/*
Canonical fork + execl + wait sequence.
This is run by Bash every time you hit enter:
http://stackoverflow.com/questions/6834487/what-is-the-variable-in-shell-scripting/31649402#31649402
# execl
# execlp
# execsle
# execv
# execvp
# execvpe
Interfaces for `execve` system call.
Execute and *leave*, ends current process!
Common combo: fork + execl.
This is effective because of COW implemented on some systems:
memory will only be copied to new process if needed, and in this case it is no needed.
Takes variable number or args.
Must end null terminated.
Versions:
- char 'p': path, uses PATH var to find executable
- TODO: char 'v', char 'e'? what's the difference?
*/
#include "common.h"
int main(void) {
int status;
pid_t pid = fork();
if (pid == -1) {
perror("fork");
assert(false);
} else if (pid == 0) {
/*
The fist argument is the program call by convention.
This is not enforced however.
*/
execl("./true", "./true", (char *)NULL);
}
wait(&status);
if (WIFEXITED(status)) {
assert(WEXITSTATUS(status) == EXIT_SUCCESS);
} else {
perror("execl abnormal exit");
/* TODO: this fails. */
/*assert(false);*/
}
return EXIT_SUCCESS;
}