cd ../gtk ==> cd ../ui/gtk
[obnox/wireshark/wip.git] / sync_pipe_write.c
1 /* sync_pipe_write.c
2  *
3  * $Id$
4  *
5  * Wireshark - Network traffic analyzer
6  * By Gerald Combs <gerald@wireshark.org>
7  * Copyright 1998 Gerald Combs
8  *
9  * This program is free software; you can redistribute it and/or
10  * modify it under the terms of the GNU General Public License
11  * as published by the Free Software Foundation; either version 2
12  * of the License, or (at your option) any later version.
13  *
14  * This program is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17  * GNU General Public License for more details.
18  *
19  * You should have received a copy of the GNU General Public License
20  * along with this program; if not, write to the Free Software
21  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
22  */
23
24 #ifdef HAVE_CONFIG_H
25 # include "config.h"
26 #endif
27
28 #include <string.h>
29
30 #ifdef HAVE_UNISTD_H
31 #include <unistd.h>
32 #endif
33
34 #ifdef _WIN32
35 #include <io.h>
36 #endif
37
38 #include <glib.h>
39
40 #include "sync_pipe.h"
41 #include "log.h"
42
43 /****************************************************************************************************************/
44 /* sync_pipe handling */
45
46
47 /* write a single message header to the recipient pipe */
48 int
49 pipe_write_header(int pipe_fd, char indicator, int length)
50 {
51     guchar header[1+3]; /* indicator + 3-byte len */
52
53
54     g_assert(length <= SP_MAX_MSG_LEN);
55
56     /* write header (indicator + 3-byte len) */
57     header[0] = indicator;
58     header[1] = (length >> 16) & 0xFF;
59     header[2] = (length >> 8) & 0xFF;
60     header[3] = (length >> 0) & 0xFF;
61
62     /* write header */
63     return write(pipe_fd, header, sizeof header);
64 }
65
66
67 /* write a message to the recipient pipe in the standard format 
68    (3 digit message length (excluding length and indicator field), 
69    1 byte message indicator and the rest is the message).
70    If msg is NULL, the message has only a length and indicator. */
71 void
72 pipe_write_block(int pipe_fd, char indicator, const char *msg)
73 {
74     int ret;
75     int len;
76
77     /*g_warning("write %d enter", pipe_fd);*/
78
79     if(msg != NULL) {
80         len = (int) strlen(msg) + 1;    /* including the terminating '\0'! */
81     } else {
82         len = 0;
83     }
84
85     /* write header (indicator + 3-byte len) */
86     ret = pipe_write_header(pipe_fd, indicator, len);
87     if(ret == -1) {
88         return;
89     }
90
91     /* write value (if we have one) */
92     if(len) {
93         /*g_warning("write %d indicator: %c value len: %u msg: %s", pipe_fd, indicator, len, msg);*/
94         ret = (int) write(pipe_fd, msg, len);
95         if(ret == -1) {
96             return;
97         }
98     } else {
99         /*g_warning("write %d indicator: %c no value", pipe_fd, indicator);*/
100     }
101
102     /*g_warning("write %d leave", pipe_fd);*/
103 }
104
105
106 void
107 sync_pipe_errmsg_to_parent(int pipe_fd, const char *error_msg,
108                            const char *secondary_error_msg)
109 {
110
111     /* first write a "master header" with the length of the two messages plus their "slave headers" */
112     pipe_write_header(pipe_fd, SP_ERROR_MSG, (int) (strlen(error_msg) + 1 + 4 + strlen(secondary_error_msg) + 1 + 4));
113     pipe_write_block(pipe_fd, SP_ERROR_MSG, error_msg);
114     pipe_write_block(pipe_fd, SP_ERROR_MSG, secondary_error_msg);
115 }