5 /* open/read/write/close */
8 /* Signals handling.. */
11 /** If buffer is too small to hold entire string, it is incremented by this value */
12 #define BUFFER_STEP 16
14 /** Buffer used to store line of characters */
17 /** Named pipe used to communnicate with process2 */
18 char * write_pipe = "/tmp/process1pipe";
20 /** File descriptor of pipe */
24 * Handler for signals.
26 void sig_handler(int signo)
28 fprintf(stderr, "[%s] Received %s!\n", "process1", strsignal(signo));
29 if (signo == SIGUSR1) {
31 else if (signo == SIGTERM) {
32 fprintf(stderr, "[%s] > Releasing resources\n", "process1");
42 else if (signo == SIGTSTP) {
43 fprintf(stderr, "[%s] > Closing pipe\n", "process1");
47 else if (signo == SIGCONT) {
48 fprintf(stderr, "[%s] > Opening pipe\n", "process1");
49 file_descriptor = open(write_pipe, O_WRONLY);
54 * Program reads entire lines of text from the standard input and pass them
55 * to the process2 using created pipe.
58 /** Currently fetched from stdin character */
61 /** Current buffer length*/
62 int buffer_length = 0;
64 /** Index of the current character */
68 * Temporary buffer used as a proxy between
69 * checking memory allocation and copying data to real buffer
73 fprintf(stderr, "[%s] Init!\n", "process1");
76 * Register signals handled by process
78 if (signal(SIGUSR1, sig_handler) == SIG_ERR) {
79 fprintf(stderr, "can't catch SIGUSR1\n");
81 if (signal(SIGTERM, sig_handler) == SIG_ERR) {
82 fprintf(stderr, "can't catch SIGTERM\n");
84 if (signal(SIGTSTP, sig_handler) == SIG_ERR) {
85 fprintf(stderr, "can't catch SIGTSTP\n");
87 if (signal(SIGCONT, sig_handler) == SIG_ERR) {
88 fprintf(stderr, "can't catch SIGCONT\n");
91 mkfifo(write_pipe, 0666);
93 file_descriptor = open(write_pipe, O_WRONLY);
99 * Check if current index is bigger than current buffer size.
100 * If so increment buffer size. On error release memory, and set
103 if (i >= buffer_length) {
105 buffer_length += BUFFER_STEP;
106 tmp = (char*) realloc(buffer, buffer_length);
108 fprintf(stderr, "[%s] Memory allocation problem on read!\n", "process1");
116 * If there were no errors or it was not just an empty newline:
119 if (c != EOF || ((i == 0) && (c == 10))) {
120 /* If newline has been found
121 * return entire string and release the memory
123 if (c == 10 && (i != 0)) {
125 write(file_descriptor, buffer, strlen(buffer));
126 fprintf(stderr, "[%s] buffer: %s/%d\n", "process1", buffer, strlen(buffer));
136 * Normal character, add it to the buffer
142 /* Used only for debugging..*/
144 printf("c: %c/%d, i: %d, bl: %d\n", c, c, i, buffer_length);
151 /* Release resources in normal program flow exit. */