annotate src/oct-procbuf.cc @ 5540:cda6a105ae9a before-ov-branch

[project @ 2005-11-17 05:47:13 by jwe]
author jwe
date Thu, 17 Nov 2005 05:47:13 +0000
parents 3fadccb05d5d
children 7ef7b8388901
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
1 /*
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
2
2847
8b262e771614 [project @ 1997-03-27 16:18:26 by jwe]
jwe
parents: 2442
diff changeset
3 Copyright (C) 1996, 1997 John W. Eaton
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
4
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
5 This file is part of Octave.
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
6
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
7 Octave is free software; you can redistribute it and/or modify it
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
8 under the terms of the GNU General Public License as published by the
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
9 Free Software Foundation; either version 2, or (at your option) any
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
10 later version.
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
11
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
12 Octave is distributed in the hope that it will be useful, but WITHOUT
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
13 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
15 for more details.
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
16
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
17 You should have received a copy of the GNU General Public License
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
18 along with Octave; see the file COPYING. If not, write to the Free
5307
4c8a2e4e0717 [project @ 2005-04-26 19:24:27 by jwe]
jwe
parents: 4472
diff changeset
19 Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
4c8a2e4e0717 [project @ 2005-04-26 19:24:27 by jwe]
jwe
parents: 4472
diff changeset
20 02110-1301, USA.
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
21
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
22 */
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
23
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
24 #ifdef HAVE_CONFIG_H
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
25 #include <config.h>
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
26 #endif
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
27
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
28 #include <cerrno>
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
29
3503
d14c483b3c12 [project @ 2000-02-01 04:06:07 by jwe]
jwe
parents: 3447
diff changeset
30 #include <iostream>
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
31
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
32 #ifdef HAVE_UNISTD_H
2442
f667d7ec08b9 [project @ 1996-10-30 18:46:22 by jwe]
jwe
parents: 2094
diff changeset
33 #ifdef HAVE_SYS_TYPES_H
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
34 #include <sys/types.h>
2442
f667d7ec08b9 [project @ 1996-10-30 18:46:22 by jwe]
jwe
parents: 2094
diff changeset
35 #endif
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
36 #include <unistd.h>
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
37 #endif
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
38
3174
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
39 #include "lo-mappers.h"
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
40 #include "lo-utils.h"
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
41 #include "oct-procbuf.h"
5453
89f5979e8552 [project @ 2005-09-17 00:50:58 by jwe]
jwe
parents: 5451
diff changeset
42 #include "oct-syscalls.h"
3176
fccab8e7d35f [project @ 1998-05-18 20:33:31 by jwe]
jwe
parents: 3174
diff changeset
43 #include "variables.h"
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
44
3174
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
45 #include "defun.h"
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
46 #include "gripes.h"
3308
7ae1928ca623 [project @ 1999-10-21 08:57:11 by jwe]
jwe
parents: 3258
diff changeset
47 #include "utils.h"
3174
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
48
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
49 // Number of microseconds to delay in the parent after forking.
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
50 static int Vkluge_procbuf_delay = 0;
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
51
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
52 // This class is based on the procbuf class from libg++, written by
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
53 // Per Bothner, Copyright (C) 1993 Free Software Foundation.
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
54
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
55 static octave_procbuf *octave_procbuf_list = 0;
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
56
5451
ed08548b9054 [project @ 2005-09-15 19:52:50 by jwe]
jwe
parents: 5307
diff changeset
57 #if defined (__CYGWIN32__)
ed08548b9054 [project @ 2005-09-15 19:52:50 by jwe]
jwe
parents: 5307
diff changeset
58 #define W32POPEN popen
ed08548b9054 [project @ 2005-09-15 19:52:50 by jwe]
jwe
parents: 5307
diff changeset
59 #define W32PCLOSE pclose
ed08548b9054 [project @ 2005-09-15 19:52:50 by jwe]
jwe
parents: 5307
diff changeset
60 #elif defined (__MINGW32__)
ed08548b9054 [project @ 2005-09-15 19:52:50 by jwe]
jwe
parents: 5307
diff changeset
61 #define W32POPEN _popen
ed08548b9054 [project @ 2005-09-15 19:52:50 by jwe]
jwe
parents: 5307
diff changeset
62 #define W32PCLOSE _pclose
ed08548b9054 [project @ 2005-09-15 19:52:50 by jwe]
jwe
parents: 5307
diff changeset
63 #endif
ed08548b9054 [project @ 2005-09-15 19:52:50 by jwe]
jwe
parents: 5307
diff changeset
64
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
65 octave_procbuf *
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
66 octave_procbuf::open (const char *command, int mode)
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
67 {
5451
ed08548b9054 [project @ 2005-09-15 19:52:50 by jwe]
jwe
parents: 5307
diff changeset
68 #if defined (__CYGWIN32__) || defined (__MINGW32__)
4472
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
69
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
70 if (is_open ())
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
71 return 0;
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
72
5451
ed08548b9054 [project @ 2005-09-15 19:52:50 by jwe]
jwe
parents: 5307
diff changeset
73 f = ::W32POPEN (command, (mode & std::ios::in) ? "r" : "w");
4472
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
74
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
75 if (! f)
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
76 return 0;
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
77
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
78 // Oops... popen doesn't return the associated pid, so fake it for now
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
79
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
80 proc_pid = 1;
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
81
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
82 open_p = true;
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
83
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
84 if (mode & std::ios::out)
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
85 ::setvbuf (f, 0, _IOLBF, 0);
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
86
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
87 return this;
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
88
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
89 #elif defined (HAVE_SYS_WAIT_H)
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
90
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
91 int pipe_fds[2];
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
92
3544
71bd2d124119 [project @ 2000-02-02 21:02:31 by jwe]
jwe
parents: 3531
diff changeset
93 volatile int child_std_end = (mode & std::ios::in) ? 1 : 0;
3156
a494f93e60ff [project @ 1998-02-20 07:47:48 by jwe]
jwe
parents: 3147
diff changeset
94
3147
894d516b4a00 [project @ 1998-02-06 06:00:08 by jwe]
jwe
parents: 2847
diff changeset
95 volatile int parent_end, child_end;
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
96
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
97 if (is_open ())
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
98 return 0;
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
99
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
100 if (pipe (pipe_fds) < 0)
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
101 return 0;
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
102
3544
71bd2d124119 [project @ 2000-02-02 21:02:31 by jwe]
jwe
parents: 3531
diff changeset
103 if (mode & std::ios::in)
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
104 {
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
105 parent_end = pipe_fds[0];
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
106 child_end = pipe_fds[1];
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
107 }
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
108 else
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
109 {
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
110 parent_end = pipe_fds[1];
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
111 child_end = pipe_fds[0];
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
112 }
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
113
3156
a494f93e60ff [project @ 1998-02-20 07:47:48 by jwe]
jwe
parents: 3147
diff changeset
114 proc_pid = ::fork ();
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
115
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
116 if (proc_pid == 0)
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
117 {
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
118 ::close (parent_end);
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
119
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
120 if (child_end != child_std_end)
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
121 {
3156
a494f93e60ff [project @ 1998-02-20 07:47:48 by jwe]
jwe
parents: 3147
diff changeset
122 ::dup2 (child_end, child_std_end);
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
123 ::close (child_end);
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
124 }
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
125
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
126 while (octave_procbuf_list)
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
127 {
3644
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
128 FILE *fp = octave_procbuf_list->f;
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
129
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
130 if (fp)
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
131 {
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
132 ::fclose (fp);
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
133 fp = 0;
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
134 }
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
135
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
136 octave_procbuf_list = octave_procbuf_list->next;
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
137 }
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
138
5510
3fadccb05d5d [project @ 2005-10-26 17:50:55 by jwe]
jwe
parents: 5453
diff changeset
139 execl ("/bin/sh", "sh", "-c", command, static_cast<void *> (0));
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
140
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
141 exit (127);
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
142 }
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
143
3174
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
144 if (Vkluge_procbuf_delay > 0)
3308
7ae1928ca623 [project @ 1999-10-21 08:57:11 by jwe]
jwe
parents: 3258
diff changeset
145 octave_usleep (Vkluge_procbuf_delay);
3174
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
146
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
147 ::close (child_end);
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
148
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
149 if (proc_pid < 0)
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
150 {
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
151 ::close (parent_end);
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
152 return 0;
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
153 }
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
154
3632
95d7c4b2b2e8 [project @ 2000-03-23 09:23:34 by jwe]
jwe
parents: 3631
diff changeset
155 f = ::fdopen (parent_end, (mode & std::ios::in) ? "r" : "w");
3631
0b6b55fd0a5c [project @ 2000-03-23 09:16:36 by jwe]
jwe
parents: 3544
diff changeset
156
3649
3a067b216fd6 [project @ 2000-03-31 06:02:44 by jwe]
jwe
parents: 3644
diff changeset
157 if (mode & std::ios::out)
3a067b216fd6 [project @ 2000-03-31 06:02:44 by jwe]
jwe
parents: 3644
diff changeset
158 ::setvbuf (f, 0, _IOLBF, 0);
3a067b216fd6 [project @ 2000-03-31 06:02:44 by jwe]
jwe
parents: 3644
diff changeset
159
3631
0b6b55fd0a5c [project @ 2000-03-23 09:16:36 by jwe]
jwe
parents: 3544
diff changeset
160 open_p = true;
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
161
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
162 next = octave_procbuf_list;
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
163 octave_procbuf_list = this;
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
164
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
165 return this;
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
166
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
167 #else
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
168
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
169 return 0;
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
170
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
171 #endif
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
172 }
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
173
3631
0b6b55fd0a5c [project @ 2000-03-23 09:16:36 by jwe]
jwe
parents: 3544
diff changeset
174 octave_procbuf *
0b6b55fd0a5c [project @ 2000-03-23 09:16:36 by jwe]
jwe
parents: 3544
diff changeset
175 octave_procbuf::close (void)
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
176 {
5451
ed08548b9054 [project @ 2005-09-15 19:52:50 by jwe]
jwe
parents: 5307
diff changeset
177
ed08548b9054 [project @ 2005-09-15 19:52:50 by jwe]
jwe
parents: 5307
diff changeset
178
ed08548b9054 [project @ 2005-09-15 19:52:50 by jwe]
jwe
parents: 5307
diff changeset
179 #if defined (__CYGWIN32__) || defined (__MINGW32__)
4472
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
180
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
181 if (f)
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
182 {
5451
ed08548b9054 [project @ 2005-09-15 19:52:50 by jwe]
jwe
parents: 5307
diff changeset
183 wstatus = ::W32PCLOSE (f);
4472
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
184 f = 0;
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
185 }
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
186
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
187 open_p = false;
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
188
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
189 return this;
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
190
f52db9e1296a [project @ 2003-07-29 18:03:03 by jwe]
jwe
parents: 4233
diff changeset
191 #elif defined (HAVE_SYS_WAIT_H)
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
192
3644
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
193 if (f)
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
194 {
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
195 pid_t wait_pid;
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
196
3644
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
197 int status = -1;
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
198
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
199 for (octave_procbuf **ptr = &octave_procbuf_list;
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
200 *ptr != 0;
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
201 ptr = &(*ptr)->next)
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
202 {
3644
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
203 if (*ptr == this)
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
204 {
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
205 *ptr = (*ptr)->next;
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
206 status = 0;
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
207 break;
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
208 }
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
209 }
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
210
3644
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
211 if (status == 0 && ::fclose (f) == 0)
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
212 {
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
213 using namespace std;
3531
97cf542676e1 [project @ 2000-02-02 11:30:40 by jwe]
jwe
parents: 3503
diff changeset
214
3644
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
215 do
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
216 {
5453
89f5979e8552 [project @ 2005-09-17 00:50:58 by jwe]
jwe
parents: 5451
diff changeset
217 wait_pid = octave_syscalls::waitpid (proc_pid, &wstatus, 0);
3644
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
218 }
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
219 while (wait_pid == -1 && errno == EINTR);
3631
0b6b55fd0a5c [project @ 2000-03-23 09:16:36 by jwe]
jwe
parents: 3544
diff changeset
220 }
3644
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
221
9add655e8b8c [project @ 2000-03-24 11:58:50 by jwe]
jwe
parents: 3632
diff changeset
222 f = 0;
3631
0b6b55fd0a5c [project @ 2000-03-23 09:16:36 by jwe]
jwe
parents: 3544
diff changeset
223 }
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
224
3631
0b6b55fd0a5c [project @ 2000-03-23 09:16:36 by jwe]
jwe
parents: 3544
diff changeset
225 open_p = false;
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
226
3631
0b6b55fd0a5c [project @ 2000-03-23 09:16:36 by jwe]
jwe
parents: 3544
diff changeset
227 return this;
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
228
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
229 #else
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
230
3631
0b6b55fd0a5c [project @ 2000-03-23 09:16:36 by jwe]
jwe
parents: 3544
diff changeset
231 return 0;
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
232
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
233 #endif
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
234 }
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
235
3174
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
236 static int
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
237 kluge_procbuf_delay (void)
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
238 {
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
239 double val;
3447
5c76d8f267f7 [project @ 2000-01-17 20:12:43 by jwe]
jwe
parents: 3308
diff changeset
240 if (builtin_real_scalar_variable ("__kluge_procbuf_delay__", val)
3174
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
241 && ! xisnan (val))
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
242 {
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
243 int ival = NINT (val);
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
244 if (ival >= 0 && (double) ival == val)
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
245 {
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
246 Vkluge_procbuf_delay = ival;
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
247 return 0;
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
248 }
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
249 }
3447
5c76d8f267f7 [project @ 2000-01-17 20:12:43 by jwe]
jwe
parents: 3308
diff changeset
250 gripe_invalid_value_specified ("__kluge_procbuf_delay__");
3174
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
251 return -1;
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
252 }
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
253
3195
7a5a5da64756 [project @ 1998-10-28 22:54:04 by jwe]
jwe
parents: 3189
diff changeset
254 void
3174
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
255 symbols_of_oct_procbuf (void)
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
256 {
4233
ccfdb55c8156 [project @ 2002-12-20 22:43:54 by jwe]
jwe
parents: 4101
diff changeset
257 DEFVAR (__kluge_procbuf_delay__, Vkluge_procbuf_delay, kluge_procbuf_delay,
3447
5c76d8f267f7 [project @ 2000-01-17 20:12:43 by jwe]
jwe
parents: 3308
diff changeset
258 "-*- texinfo -*-\n\
5c76d8f267f7 [project @ 2000-01-17 20:12:43 by jwe]
jwe
parents: 3308
diff changeset
259 @defvr __kluge_procbuf_delay__\n\
5c76d8f267f7 [project @ 2000-01-17 20:12:43 by jwe]
jwe
parents: 3308
diff changeset
260 Number of microseconds to delay in the parent after forking.\n\
5c76d8f267f7 [project @ 2000-01-17 20:12:43 by jwe]
jwe
parents: 3308
diff changeset
261 @end defvr");
5c76d8f267f7 [project @ 2000-01-17 20:12:43 by jwe]
jwe
parents: 3308
diff changeset
262
3174
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
263 }
390d5e396682 [project @ 1998-05-04 16:36:17 by jwe]
jwe
parents: 3156
diff changeset
264
2094
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
265 /*
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
266 ;;; Local Variables: ***
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
267 ;;; mode: C++ ***
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
268 ;;; End: ***
a23645b0364e [project @ 1996-04-28 09:00:07 by jwe]
jwe
parents:
diff changeset
269 */