-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmain.cpp
115 lines (96 loc) · 3.41 KB
/
main.cpp
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
115
#include "helping_funs.h"
#include "jobexec.h"
#include "worker.h"
int main(int argc, char *argv[])
{
unsigned int N;
char * docfile = check_program_args(argv, argc, N);
pid_t pid;
unsigned int i;
cout<<"---> Parameters given <---"<<endl;
cout<<"-> N: '"<<N<<"'"<<endl;
cout<<"-> docfile: '"<<docfile<<"'"<<endl<<endl;
FILE * fp = open_file(docfile);
if (fp == NULL)
{
exit(1);
}
unsigned int n_dirs = get_number_of_lines(fp); //number of lines of docfile
char ** dirs = (char**) malloc(n_dirs * sizeof(char *));
for(unsigned int i = 0; i < n_dirs; i++)
{
dirs[i] = NULL;
}
bool parsing_err = parse_docs(dirs, fp);
fclose(fp);
if (parsing_err == 1)
{
delete_str_array(dirs, n_dirs);
cout<<"-! ERROR at parsing input docfile - Programm will exit !-"<<endl;
exit(1);
}
if (N > n_dirs)
{
N = n_dirs;
cout<<"-! WARNING !- There are less directories than workers so N will be set as the number of directories"<<endl;
cout<<"-> N (new value): '"<<N<<"'"<<endl;
}
workers_pids_size = N;
workers_pids = (int *)malloc(N * sizeof(int));
char ** boss_to_worker_ffs_names = (char **) malloc(N * sizeof(char *));
char ** worker_to_boss_ffs_names = (char **) malloc(N * sizeof(char *));
//create and store fifos' names
for(unsigned int i = 0; i < N; i++)
{
char i_str[get_number_of_digits(i) + 1];
sprintf(i_str, "%d", i);
unsigned int fifo_name_len = strlen("jobexec_to_worker.fifo") + 1 + get_number_of_digits(i);
boss_to_worker_ffs_names[i] = (char *) malloc(fifo_name_len * sizeof(char));
strcpy(boss_to_worker_ffs_names[i], "jobexec_to_worker");
strcat(boss_to_worker_ffs_names[i], i_str);
strcat(boss_to_worker_ffs_names[i], ".fifo");
fifo_name_len = strlen("worker_to_jobexec.fifo") + 1 + get_number_of_digits(i);
worker_to_boss_ffs_names[i] = (char *) malloc(fifo_name_len * sizeof(char));
strcpy(worker_to_boss_ffs_names[i], "worker");
strcat(worker_to_boss_ffs_names[i], i_str);
strcat(worker_to_boss_ffs_names[i], "_to_jobexec.fifo");
}
for (i = 0; i < N; i++) //N children (workers) will be created with fork
{
if (mkfifo(boss_to_worker_ffs_names[i], 0666) == -1)
{
perror("problem in making fifo");
exit(2);
}
if (mkfifo(worker_to_boss_ffs_names[i], 0666) == -1)
{
perror("problem in making fifo");
exit(2);
}
if ((pid = fork()) == -1)
{
perror("fork failed");
exit(1);
}
else if (pid == 0)
{//child (worker) process
worker(i, boss_to_worker_ffs_names[i], worker_to_boss_ffs_names[i]);
delete_str_array(dirs, n_dirs);
delete_str_array(boss_to_worker_ffs_names, N);
delete_str_array(worker_to_boss_ffs_names, N);
free(workers_pids);
exit(0);
}
else
{
workers_pids[i] = pid; //store children's pids in a global array
}
}
//parent - job executor process
job_executor(boss_to_worker_ffs_names, worker_to_boss_ffs_names, dirs, N, n_dirs);
delete_str_array(dirs, n_dirs);
delete_str_array(boss_to_worker_ffs_names, N);
delete_str_array(worker_to_boss_ffs_names, N);
free(workers_pids);
return 0;
}