annotate src/sysdep.cc @ 1755:3a9462b655f1

[project @ 1996-01-22 04:47:22 by jwe]
author jwe
date Mon, 22 Jan 1996 04:47:22 +0000
parents fd0d12493223
children bc7ae9be3378
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
1 // sysdep.cc -*- C++ -*-
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
2 /*
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
3
1009
dfe01093f657 [project @ 1995-01-04 04:05:12 by jwe]
jwe
parents: 998
diff changeset
4 Copyright (C) 1993, 1994, 1995 John W. Eaton
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
5
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
6 This file is part of Octave.
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
7
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
8 Octave is free software; you can redistribute it and/or modify it
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
9 under the terms of the GNU General Public License as published by the
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
10 Free Software Foundation; either version 2, or (at your option) any
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
11 later version.
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
12
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
13 Octave is distributed in the hope that it will be useful, but WITHOUT
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
14 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
15 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
16 for more details.
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
17
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
18 You should have received a copy of the GNU General Public License
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
19 along with Octave; see the file COPYING. If not, write to the Free
1315
611d403c7f3d [project @ 1995-06-25 19:56:32 by jwe]
jwe
parents: 1255
diff changeset
20 Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
21
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
22 */
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
23
661
9ccf86647203 [project @ 1994-08-30 04:41:56 by jwe]
jwe
parents: 636
diff changeset
24 /*
9ccf86647203 [project @ 1994-08-30 04:41:56 by jwe]
jwe
parents: 636
diff changeset
25
9ccf86647203 [project @ 1994-08-30 04:41:56 by jwe]
jwe
parents: 636
diff changeset
26 The function gethostname was adapted from a similar function from GNU
9ccf86647203 [project @ 1994-08-30 04:41:56 by jwe]
jwe
parents: 636
diff changeset
27 Bash, the Bourne Again SHell, copyright (C) 1987, 1989, 1991 Free
9ccf86647203 [project @ 1994-08-30 04:41:56 by jwe]
jwe
parents: 636
diff changeset
28 Software Foundation, Inc.
9ccf86647203 [project @ 1994-08-30 04:41:56 by jwe]
jwe
parents: 636
diff changeset
29
9ccf86647203 [project @ 1994-08-30 04:41:56 by jwe]
jwe
parents: 636
diff changeset
30 */
9ccf86647203 [project @ 1994-08-30 04:41:56 by jwe]
jwe
parents: 636
diff changeset
31
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
32 #ifdef HAVE_CONFIG_H
1192
b6360f2d4fa6 [project @ 1995-03-30 21:38:35 by jwe]
jwe
parents: 1128
diff changeset
33 #include <config.h>
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
34 #endif
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
35
1346
9e41dbb74bca [project @ 1995-09-05 06:37:49 by jwe]
jwe
parents: 1343
diff changeset
36 #include <cfloat>
1343
94bedeb289e5 [project @ 1995-09-04 00:29:21 by jwe]
jwe
parents: 1318
diff changeset
37 #include <cmath>
94bedeb289e5 [project @ 1995-09-04 00:29:21 by jwe]
jwe
parents: 1318
diff changeset
38 #include <cstddef>
1346
9e41dbb74bca [project @ 1995-09-05 06:37:49 by jwe]
jwe
parents: 1343
diff changeset
39 #include <cstdio>
1343
94bedeb289e5 [project @ 1995-09-04 00:29:21 by jwe]
jwe
parents: 1318
diff changeset
40 #include <cstdlib>
94bedeb289e5 [project @ 1995-09-04 00:29:21 by jwe]
jwe
parents: 1318
diff changeset
41 #include <cstring>
94bedeb289e5 [project @ 1995-09-04 00:29:21 by jwe]
jwe
parents: 1318
diff changeset
42
1728
42b4f904f1af [project @ 1996-01-09 11:36:01 by jwe]
jwe
parents: 1711
diff changeset
43 #include <string>
42b4f904f1af [project @ 1996-01-09 11:36:01 by jwe]
jwe
parents: 1711
diff changeset
44
1742
a02f140ed897 [project @ 1996-01-12 11:09:39 by jwe]
jwe
parents: 1728
diff changeset
45 #include <iostream.h>
a02f140ed897 [project @ 1996-01-12 11:09:39 by jwe]
jwe
parents: 1728
diff changeset
46
1350
5f63d83dd694 [project @ 1995-09-05 07:37:59 by jwe]
jwe
parents: 1346
diff changeset
47 #ifdef HAVE_UNISTD_H
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
48 #include <sys/types.h>
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
49 #include <unistd.h>
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
50 #endif
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
51
1430
045e70a15a8f [project @ 1995-09-19 07:05:37 by jwe]
jwe
parents: 1415
diff changeset
52 #if defined (HAVE_TERMIOS_H)
045e70a15a8f [project @ 1995-09-19 07:05:37 by jwe]
jwe
parents: 1415
diff changeset
53 #include <termios.h>
045e70a15a8f [project @ 1995-09-19 07:05:37 by jwe]
jwe
parents: 1415
diff changeset
54 #elif defined (HAVE_TERMIO_H)
045e70a15a8f [project @ 1995-09-19 07:05:37 by jwe]
jwe
parents: 1415
diff changeset
55 #include <termio.h>
045e70a15a8f [project @ 1995-09-19 07:05:37 by jwe]
jwe
parents: 1415
diff changeset
56 #elif defined (HAVE_SGTTY_H)
045e70a15a8f [project @ 1995-09-19 07:05:37 by jwe]
jwe
parents: 1415
diff changeset
57 #include <sgtty.h>
045e70a15a8f [project @ 1995-09-19 07:05:37 by jwe]
jwe
parents: 1415
diff changeset
58 #else
045e70a15a8f [project @ 1995-09-19 07:05:37 by jwe]
jwe
parents: 1415
diff changeset
59 LOSE! LOSE!
045e70a15a8f [project @ 1995-09-19 07:05:37 by jwe]
jwe
parents: 1415
diff changeset
60 #endif
045e70a15a8f [project @ 1995-09-19 07:05:37 by jwe]
jwe
parents: 1415
diff changeset
61
1463
592291d9dfbb [project @ 1995-09-22 07:18:44 by jwe]
jwe
parents: 1430
diff changeset
62 #if defined (HAVE_FLOATINGPOINT_H)
592291d9dfbb [project @ 1995-09-22 07:18:44 by jwe]
jwe
parents: 1430
diff changeset
63 #include <floatingpoint.h>
592291d9dfbb [project @ 1995-09-22 07:18:44 by jwe]
jwe
parents: 1430
diff changeset
64 #endif
592291d9dfbb [project @ 1995-09-22 07:18:44 by jwe]
jwe
parents: 1430
diff changeset
65
592291d9dfbb [project @ 1995-09-22 07:18:44 by jwe]
jwe
parents: 1430
diff changeset
66 #if !defined (HAVE_GETHOSTNAME) && defined (HAVE_SYS_UTSNAME_H)
592291d9dfbb [project @ 1995-09-22 07:18:44 by jwe]
jwe
parents: 1430
diff changeset
67 #include <sys/utsname.h>
592291d9dfbb [project @ 1995-09-22 07:18:44 by jwe]
jwe
parents: 1430
diff changeset
68 #endif
592291d9dfbb [project @ 1995-09-22 07:18:44 by jwe]
jwe
parents: 1430
diff changeset
69
592291d9dfbb [project @ 1995-09-22 07:18:44 by jwe]
jwe
parents: 1430
diff changeset
70 #include <readline/readline.h>
1750
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
71 #include <readline/tilde.h>
1463
592291d9dfbb [project @ 1995-09-22 07:18:44 by jwe]
jwe
parents: 1430
diff changeset
72
592291d9dfbb [project @ 1995-09-22 07:18:44 by jwe]
jwe
parents: 1430
diff changeset
73 extern char *term_clrpag;
592291d9dfbb [project @ 1995-09-22 07:18:44 by jwe]
jwe
parents: 1430
diff changeset
74 extern "C" void _rl_output_character_function ();
592291d9dfbb [project @ 1995-09-22 07:18:44 by jwe]
jwe
parents: 1430
diff changeset
75
1352
19c10b8657d5 [project @ 1995-09-05 08:11:57 by jwe]
jwe
parents: 1350
diff changeset
76 #include "defun.h"
19c10b8657d5 [project @ 1995-09-05 08:11:57 by jwe]
jwe
parents: 1350
diff changeset
77 #include "error.h"
19c10b8657d5 [project @ 1995-09-05 08:11:57 by jwe]
jwe
parents: 1350
diff changeset
78 #include "f77-uscore.h"
542
682393bf54f7 [project @ 1994-07-22 04:41:52 by jwe]
jwe
parents: 529
diff changeset
79 #include "help.h"
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
80 #include "input.h"
1742
a02f140ed897 [project @ 1996-01-12 11:09:39 by jwe]
jwe
parents: 1728
diff changeset
81 #include "mappers.h"
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
82 #include "oct-obj.h"
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
83 #include "pathlen.h"
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
84 #include "pt-const.h"
1352
19c10b8657d5 [project @ 1995-09-05 08:11:57 by jwe]
jwe
parents: 1350
diff changeset
85 #include "sysdep.h"
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
86 #include "toplev.h"
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
87 #include "utils.h"
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
88
1463
592291d9dfbb [project @ 1995-09-22 07:18:44 by jwe]
jwe
parents: 1430
diff changeset
89 extern "C" double F77_FCN (d1mach, D1MACH) (const int&);
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
90
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
91 #ifndef STDIN_FILENO
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
92 #define STDIN_FILENO 1
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
93 #endif
444
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
94
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
95 // Octave's idea of infinity.
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
96 double octave_Inf;
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
97
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
98 // Octave's idea of not a number.
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
99 double octave_NaN;
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
100
1226
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
101 // The floating point format on this system.
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
102 floating_point_format native_float_format = OCTAVE_UNKNOWN_FLT_FMT;
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
103
1415
f18474c64e72 [project @ 1995-09-15 10:09:57 by jwe]
jwe
parents: 1384
diff changeset
104 // Nonzero if the machine we are running on is big-endian.
f18474c64e72 [project @ 1995-09-15 10:09:57 by jwe]
jwe
parents: 1384
diff changeset
105 int octave_words_big_endian;
f18474c64e72 [project @ 1995-09-15 10:09:57 by jwe]
jwe
parents: 1384
diff changeset
106
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
107 #ifdef NeXT
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
108 extern "C"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
109 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
110 typedef void (*_cplus_fcn_int) (int);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
111 extern void (*malloc_error (_cplus_fcn_int)) (int);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
112 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
113
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
114 static void
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
115 malloc_handler (int code)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
116 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
117 if (code == 5)
217
cd2e49fb4f6b [project @ 1993-11-13 09:16:01 by jwe]
jwe
parents: 1
diff changeset
118 warning ("hopefully recoverable malloc error: freeing wild pointer");
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
119 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
120 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
121 panic ("probably irrecoverable malloc error: code %d", code);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
122 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
123 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
124
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
125 static void
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
126 NeXT_init (void)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
127 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
128 malloc_error (malloc_handler);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
129 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
130 #endif
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
131
1226
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
132 union equiv
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
133 {
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
134 double d;
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
135 int i[2];
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
136 };
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
137
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
138 struct float_params
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
139 {
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
140 floating_point_format fp_fmt;
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
141 equiv fp_par[4];
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
142 };
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
143
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
144 #define INIT_FLT_PAR(fp, fmt, sm1, sm2, lrg1, lrg2, rt1, rt2, dv1, dv2) \
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
145 do \
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
146 { \
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
147 fp.fp_fmt = (fmt); \
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
148 fp.fp_par[0].i[0] = (sm1); fp.fp_par[0].i[1] = (sm2); \
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
149 fp.fp_par[1].i[0] = (lrg1); fp.fp_par[1].i[1] = (lrg2); \
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
150 fp.fp_par[2].i[0] = (rt1); fp.fp_par[2].i[1] = (rt2); \
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
151 fp.fp_par[3].i[0] = (dv1); fp.fp_par[3].i[1] = (dv2); \
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
152 } \
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
153 while (0)
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
154
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
155 static int
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
156 equiv_compare (const equiv *std, const equiv *v, int len)
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
157 {
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
158 int i;
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
159 for (i = 0; i < len; i++)
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
160 if (v[i].i[0] != std[i].i[0] || v[i].i[1] != std[i].i[1])
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
161 return 0;
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
162 return 1;
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
163 }
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
164
444
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
165 static void
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
166 octave_ieee_init (void)
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
167 {
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
168 #if defined (HAVE_ISINF) || defined (HAVE_FINITE)
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
169
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
170 // Some version of gcc on some old version of Linux used to crash when
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
171 // trying to make Inf and NaN.
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
172
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
173 #if defined (HAVE_INFINITY)
470
693d18604ccb [project @ 1994-06-06 08:48:27 by jwe]
jwe
parents: 444
diff changeset
174 octave_Inf = (double) infinity ();
967
b228d6cd59a1 [project @ 1994-12-10 00:15:41 by jwe]
jwe
parents: 959
diff changeset
175 #elif defined (linux)
444
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
176 octave_Inf = HUGE_VAL;
967
b228d6cd59a1 [project @ 1994-12-10 00:15:41 by jwe]
jwe
parents: 959
diff changeset
177 #elif defined (__alpha__)
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
178 extern unsigned int DINFINITY[2];
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
179 octave_Inf = (*((double *) (DINFINITY)));
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
180 #else
444
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
181 double tmp = 1e+10;
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
182 octave_Inf = tmp;
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
183 for (;;)
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
184 {
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
185 octave_Inf *= 1e+10;
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
186 if (octave_Inf == tmp)
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
187 break;
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
188 tmp = octave_Inf;
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
189 }
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
190 #endif
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
191
1384
083787534e18 [project @ 1995-09-13 08:25:37 by jwe]
jwe
parents: 1363
diff changeset
192 #endif
083787534e18 [project @ 1995-09-13 08:25:37 by jwe]
jwe
parents: 1363
diff changeset
193
083787534e18 [project @ 1995-09-13 08:25:37 by jwe]
jwe
parents: 1363
diff changeset
194 #if defined (HAVE_ISNAN)
083787534e18 [project @ 1995-09-13 08:25:37 by jwe]
jwe
parents: 1363
diff changeset
195
444
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
196 #if defined (HAVE_QUIET_NAN)
470
693d18604ccb [project @ 1994-06-06 08:48:27 by jwe]
jwe
parents: 444
diff changeset
197 octave_NaN = (double) quiet_nan ();
967
b228d6cd59a1 [project @ 1994-12-10 00:15:41 by jwe]
jwe
parents: 959
diff changeset
198 #elif defined (linux)
444
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
199 octave_NaN = NAN;
967
b228d6cd59a1 [project @ 1994-12-10 00:15:41 by jwe]
jwe
parents: 959
diff changeset
200 #elif defined (__alpha__)
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
201 extern unsigned int DQNAN[2];
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
202 octave_NaN = (*((double *) (DQNAN)));
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
203 #else
444
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
204 octave_NaN = octave_Inf / octave_Inf;
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
205 #endif
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
206
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
207 #endif
1226
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
208
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
209 float_params fp[5];
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
210
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
211 INIT_FLT_PAR (fp[0], OCTAVE_IEEE_BIG,
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
212 1048576, 0,
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
213 2146435071, -1,
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
214 1017118720, 0,
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
215 1018167296, 0);
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
216
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
217 INIT_FLT_PAR (fp[1], OCTAVE_IEEE_LITTLE,
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
218 0, 1048576,
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
219 -1, 2146435071,
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
220 0, 1017118720,
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
221 0, 1018167296);
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
222
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
223 INIT_FLT_PAR (fp[2], OCTAVE_VAX_D,
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
224 128, 0,
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
225 -32769, -1,
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
226 9344, 0,
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
227 9344, 0);
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
228
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
229 INIT_FLT_PAR (fp[3], OCTAVE_VAX_G,
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
230 16, 0,
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
231 -32769, -1,
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
232 15552, 0,
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
233 15552, 0);
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
234
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
235 INIT_FLT_PAR (fp[4], OCTAVE_UNKNOWN_FLT_FMT,
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
236 0, 0,
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
237 0, 0,
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
238 0, 0,
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
239 0, 0);
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
240
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
241 equiv mach_fp_par[4];
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
242
1255
fa24599e3d2c [project @ 1995-04-11 17:49:27 by jwe]
jwe
parents: 1239
diff changeset
243 mach_fp_par[0].d = F77_FCN (d1mach, D1MACH) (1);
fa24599e3d2c [project @ 1995-04-11 17:49:27 by jwe]
jwe
parents: 1239
diff changeset
244 mach_fp_par[1].d = F77_FCN (d1mach, D1MACH) (2);
fa24599e3d2c [project @ 1995-04-11 17:49:27 by jwe]
jwe
parents: 1239
diff changeset
245 mach_fp_par[2].d = F77_FCN (d1mach, D1MACH) (3);
fa24599e3d2c [project @ 1995-04-11 17:49:27 by jwe]
jwe
parents: 1239
diff changeset
246 mach_fp_par[3].d = F77_FCN (d1mach, D1MACH) (4);
1226
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
247
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
248 int i = 0;
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
249 do
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
250 {
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
251 if (equiv_compare (fp[i].fp_par, mach_fp_par, 4))
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
252 {
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
253 native_float_format = fp[i].fp_fmt;
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
254 break;
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
255 }
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
256 }
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
257 while (fp[++i].fp_fmt != OCTAVE_UNKNOWN_FLT_FMT);
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
258
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
259 if (native_float_format == OCTAVE_UNKNOWN_FLT_FMT)
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
260 panic ("unrecognized floating point format!");
444
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
261 }
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
262
1415
f18474c64e72 [project @ 1995-09-15 10:09:57 by jwe]
jwe
parents: 1384
diff changeset
263 static void
f18474c64e72 [project @ 1995-09-15 10:09:57 by jwe]
jwe
parents: 1384
diff changeset
264 ten_little_endians (void)
f18474c64e72 [project @ 1995-09-15 10:09:57 by jwe]
jwe
parents: 1384
diff changeset
265 {
f18474c64e72 [project @ 1995-09-15 10:09:57 by jwe]
jwe
parents: 1384
diff changeset
266 // Are we little or big endian? From Harbison & Steele.
f18474c64e72 [project @ 1995-09-15 10:09:57 by jwe]
jwe
parents: 1384
diff changeset
267
f18474c64e72 [project @ 1995-09-15 10:09:57 by jwe]
jwe
parents: 1384
diff changeset
268 union
f18474c64e72 [project @ 1995-09-15 10:09:57 by jwe]
jwe
parents: 1384
diff changeset
269 {
f18474c64e72 [project @ 1995-09-15 10:09:57 by jwe]
jwe
parents: 1384
diff changeset
270 long l;
f18474c64e72 [project @ 1995-09-15 10:09:57 by jwe]
jwe
parents: 1384
diff changeset
271 char c[sizeof (long)];
f18474c64e72 [project @ 1995-09-15 10:09:57 by jwe]
jwe
parents: 1384
diff changeset
272 } u;
f18474c64e72 [project @ 1995-09-15 10:09:57 by jwe]
jwe
parents: 1384
diff changeset
273
f18474c64e72 [project @ 1995-09-15 10:09:57 by jwe]
jwe
parents: 1384
diff changeset
274 u.l = 1;
f18474c64e72 [project @ 1995-09-15 10:09:57 by jwe]
jwe
parents: 1384
diff changeset
275
f18474c64e72 [project @ 1995-09-15 10:09:57 by jwe]
jwe
parents: 1384
diff changeset
276 octave_words_big_endian = (u.c[sizeof (long) - 1] == 1);
f18474c64e72 [project @ 1995-09-15 10:09:57 by jwe]
jwe
parents: 1384
diff changeset
277 }
f18474c64e72 [project @ 1995-09-15 10:09:57 by jwe]
jwe
parents: 1384
diff changeset
278
505
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
279 #if defined (EXCEPTION_IN_MATH)
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
280 extern "C"
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
281 int
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
282 matherr (struct exception *x)
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
283 {
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
284 // Possibly print our own message someday. Should probably be
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
285 // user-switchable.
505
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
286
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
287 switch (x->type)
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
288 {
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
289 case DOMAIN:
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
290 case SING:
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
291 case OVERFLOW:
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
292 case UNDERFLOW:
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
293 case TLOSS:
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
294 case PLOSS:
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
295 default:
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
296 break;
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
297 }
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
298
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
299 // But don't print the system message.
505
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
300
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
301 return 1;
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
302 }
1466
2f85a175308f [project @ 1995-09-22 07:48:59 by jwe]
jwe
parents: 1465
diff changeset
303 #endif
505
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
304
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
305 void
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
306 sysdep_init (void)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
307 {
959
b527f7cdcc68 [project @ 1994-12-07 16:52:56 by jwe]
jwe
parents: 868
diff changeset
308 #if defined (__386BSD__) || defined (__FreeBSD__)
998
032fcf9f45a4 [project @ 1994-12-16 06:08:59 by jwe]
jwe
parents: 967
diff changeset
309 #if defined (HAVE_FLOATINGPOINT_H)
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
310 // Disable trapping on common exceptions.
401
0823483a6277 [project @ 1994-04-15 07:00:46 by jwe]
jwe
parents: 240
diff changeset
311 fpsetmask (~(FP_X_OFL|FP_X_INV|FP_X_DZ|FP_X_DNML|FP_X_UFL|FP_X_IMP));
0823483a6277 [project @ 1994-04-15 07:00:46 by jwe]
jwe
parents: 240
diff changeset
312 #endif
959
b527f7cdcc68 [project @ 1994-12-07 16:52:56 by jwe]
jwe
parents: 868
diff changeset
313 #endif
401
0823483a6277 [project @ 1994-04-15 07:00:46 by jwe]
jwe
parents: 240
diff changeset
314
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
315 #ifdef NeXT
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
316 NeXT_init ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
317 #endif
444
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
318
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
319 octave_ieee_init ();
1415
f18474c64e72 [project @ 1995-09-15 10:09:57 by jwe]
jwe
parents: 1384
diff changeset
320
f18474c64e72 [project @ 1995-09-15 10:09:57 by jwe]
jwe
parents: 1384
diff changeset
321 ten_little_endians ();
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
322 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
323
767
42731861ee09 [project @ 1994-10-05 21:26:54 by jwe]
jwe
parents: 712
diff changeset
324 // Set terminal in raw mode. From less-177.
42731861ee09 [project @ 1994-10-05 21:26:54 by jwe]
jwe
parents: 712
diff changeset
325 //
42731861ee09 [project @ 1994-10-05 21:26:54 by jwe]
jwe
parents: 712
diff changeset
326 // Change terminal to "raw mode", or restore to "normal" mode.
42731861ee09 [project @ 1994-10-05 21:26:54 by jwe]
jwe
parents: 712
diff changeset
327 // "Raw mode" means
42731861ee09 [project @ 1994-10-05 21:26:54 by jwe]
jwe
parents: 712
diff changeset
328 // 1. An outstanding read will complete on receipt of a single keystroke.
42731861ee09 [project @ 1994-10-05 21:26:54 by jwe]
jwe
parents: 712
diff changeset
329 // 2. Input is not echoed.
42731861ee09 [project @ 1994-10-05 21:26:54 by jwe]
jwe
parents: 712
diff changeset
330 // 3. On output, \n is mapped to \r\n.
42731861ee09 [project @ 1994-10-05 21:26:54 by jwe]
jwe
parents: 712
diff changeset
331 // 4. \t is NOT expanded into spaces.
42731861ee09 [project @ 1994-10-05 21:26:54 by jwe]
jwe
parents: 712
diff changeset
332 // 5. Signal-causing characters such as ctrl-C (interrupt),
42731861ee09 [project @ 1994-10-05 21:26:54 by jwe]
jwe
parents: 712
diff changeset
333 // etc. are NOT disabled.
42731861ee09 [project @ 1994-10-05 21:26:54 by jwe]
jwe
parents: 712
diff changeset
334 // It doesn't matter whether an input \n is mapped to \r, or vice versa.
42731861ee09 [project @ 1994-10-05 21:26:54 by jwe]
jwe
parents: 712
diff changeset
335
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
336 void
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
337 raw_mode (int on)
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
338 {
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
339 static int curr_on = 0;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
340
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
341 int tty_fd = STDIN_FILENO;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
342 if (! isatty (tty_fd))
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
343 {
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
344 if (interactive)
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
345 error ("stdin is not a tty!");
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
346 return;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
347 }
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
348
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
349 if (on == curr_on)
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
350 return;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
351
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
352 #if defined (HAVE_TERMIOS_H)
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
353 {
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
354 struct termios s;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
355 static struct termios save_term;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
356
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
357 if (on)
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
358 {
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
359 // Get terminal modes.
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
360
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
361 tcgetattr (tty_fd, &s);
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
362
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
363 // Save modes and set certain variables dependent on modes.
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
364
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
365 save_term = s;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
366 // ospeed = s.c_cflag & CBAUD;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
367 // erase_char = s.c_cc[VERASE];
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
368 // kill_char = s.c_cc[VKILL];
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
369
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
370 // Set the modes to the way we want them.
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
371
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
372 s.c_lflag &= ~(ICANON|ECHO|ECHOE|ECHOK|ECHONL);
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
373 s.c_oflag |= (OPOST|ONLCR);
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
374 #if defined (OCRNL)
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
375 s.c_oflag &= ~(OCRNL);
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
376 #endif
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
377 #if defined (ONOCR)
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
378 s.c_oflag &= ~(ONOCR);
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
379 #endif
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
380 #if defined (ONLRET)
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
381 s.c_oflag &= ~(ONLRET);
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
382 #endif
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
383 s.c_cc[VMIN] = 1;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
384 s.c_cc[VTIME] = 0;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
385 }
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
386 else
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
387 {
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
388 // Restore saved modes.
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
389
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
390 s = save_term;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
391 }
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
392 tcsetattr (tty_fd, TCSAFLUSH, &s);
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
393 }
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
394 #elif defined (HAVE_TERMIO_H)
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
395 {
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
396 struct termio s;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
397 static struct termio save_term;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
398
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
399 if (on)
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
400 {
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
401 // Get terminal modes.
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
402
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
403 ioctl (tty_fd, TCGETA, &s);
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
404
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
405 // Save modes and set certain variables dependent on modes.
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
406
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
407 save_term = s;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
408 // ospeed = s.c_cflag & CBAUD;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
409 // erase_char = s.c_cc[VERASE];
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
410 // kill_char = s.c_cc[VKILL];
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
411
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
412 // Set the modes to the way we want them.
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
413
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
414 s.c_lflag &= ~(ICANON|ECHO|ECHOE|ECHOK|ECHONL);
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
415 s.c_oflag |= (OPOST|ONLCR);
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
416 #if defined (OCRNL)
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
417 s.c_oflag &= ~(OCRNL);
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
418 #endif
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
419 #if defined (ONOCR)
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
420 s.c_oflag &= ~(ONOCR);
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
421 #endif
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
422 #if defined (ONLRET)
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
423 s.c_oflag &= ~(ONLRET);
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
424 #endif
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
425 s.c_cc[VMIN] = 1;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
426 s.c_cc[VTIME] = 0;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
427 }
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
428 else
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
429 {
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
430 // Restore saved modes.
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
431
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
432 s = save_term;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
433 }
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
434 ioctl (tty_fd, TCSETAW, &s);
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
435 }
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
436 #elif defined (HAVE_SGTTY_H)
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
437 {
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
438 struct sgttyb s;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
439 static struct sgttyb save_term;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
440
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
441 if (on)
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
442 {
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
443 // Get terminal modes.
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
444
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
445 ioctl (tty_fd, TIOCGETP, &s);
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
446
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
447 // Save modes and set certain variables dependent on modes.
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
448
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
449 save_term = s;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
450 // ospeed = s.sg_ospeed;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
451 // erase_char = s.sg_erase;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
452 // kill_char = s.sg_kill;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
453
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
454 // Set the modes to the way we want them.
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
455
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
456 s.sg_flags |= CBREAK;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
457 s.sg_flags &= ~(ECHO);
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
458 }
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
459 else
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
460 {
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
461 // Restore saved modes.
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
462
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
463 s = save_term;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
464 }
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
465 ioctl (tty_fd, TIOCSETN, &s);
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
466 }
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
467 #else
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
468 LOSE! LOSE!
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
469 #endif
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
470
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
471 curr_on = on;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
472 }
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
473
767
42731861ee09 [project @ 1994-10-05 21:26:54 by jwe]
jwe
parents: 712
diff changeset
474 // Read one character from the terminal.
42731861ee09 [project @ 1994-10-05 21:26:54 by jwe]
jwe
parents: 712
diff changeset
475
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
476 int
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
477 kbhit (void)
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
478 {
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
479 int c;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
480 raw_mode (1);
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
481 c = cin.get ();
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
482 raw_mode (0);
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
483 return c;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
484 }
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
485
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
486 string
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
487 octave_getcwd (void)
1111
2a36b558ab55 [project @ 1995-02-15 04:01:38 by jwe]
jwe
parents: 1086
diff changeset
488 {
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
489 string retval;
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
490 char buf[MAXPATHLEN];
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
491
1113
32a5dfd92f0a [project @ 1995-02-15 04:29:49 by jwe]
jwe
parents: 1111
diff changeset
492 #if defined (__EMX__)
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
493 char *tmp = _getcwd2 (buf, MAXPATHLEN);
1111
2a36b558ab55 [project @ 1995-02-15 04:01:38 by jwe]
jwe
parents: 1086
diff changeset
494 #else
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
495 char *tmp = getcwd (buf, MAXPATHLEN);
1111
2a36b558ab55 [project @ 1995-02-15 04:01:38 by jwe]
jwe
parents: 1086
diff changeset
496 #endif
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
497
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
498 if (tmp)
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
499 retval = tmp;
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
500
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
501 return retval;
1111
2a36b558ab55 [project @ 1995-02-15 04:01:38 by jwe]
jwe
parents: 1086
diff changeset
502 }
2a36b558ab55 [project @ 1995-02-15 04:01:38 by jwe]
jwe
parents: 1086
diff changeset
503
2a36b558ab55 [project @ 1995-02-15 04:01:38 by jwe]
jwe
parents: 1086
diff changeset
504 int
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
505 octave_chdir (const string& path)
1111
2a36b558ab55 [project @ 1995-02-15 04:01:38 by jwe]
jwe
parents: 1086
diff changeset
506 {
1113
32a5dfd92f0a [project @ 1995-02-15 04:29:49 by jwe]
jwe
parents: 1111
diff changeset
507 #if defined (__EMX__)
1111
2a36b558ab55 [project @ 1995-02-15 04:01:38 by jwe]
jwe
parents: 1086
diff changeset
508 int retval = -1;
2a36b558ab55 [project @ 1995-02-15 04:01:38 by jwe]
jwe
parents: 1086
diff changeset
509
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
510 if (path.length () == 2 && path[1] == ':')
1111
2a36b558ab55 [project @ 1995-02-15 04:01:38 by jwe]
jwe
parents: 1086
diff changeset
511 {
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
512 char *upper_case_dir_name = strupr (path.c_str ());
1111
2a36b558ab55 [project @ 1995-02-15 04:01:38 by jwe]
jwe
parents: 1086
diff changeset
513 _chdrive (upper_case_dir_name[0]);
2a36b558ab55 [project @ 1995-02-15 04:01:38 by jwe]
jwe
parents: 1086
diff changeset
514 if (_getdrive () == upper_case_dir_name[0])
2a36b558ab55 [project @ 1995-02-15 04:01:38 by jwe]
jwe
parents: 1086
diff changeset
515 retval = _chdir2 ("/");
2a36b558ab55 [project @ 1995-02-15 04:01:38 by jwe]
jwe
parents: 1086
diff changeset
516 }
2a36b558ab55 [project @ 1995-02-15 04:01:38 by jwe]
jwe
parents: 1086
diff changeset
517 else
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
518 retval = _chdir2 (path.c_str ());
1111
2a36b558ab55 [project @ 1995-02-15 04:01:38 by jwe]
jwe
parents: 1086
diff changeset
519
2a36b558ab55 [project @ 1995-02-15 04:01:38 by jwe]
jwe
parents: 1086
diff changeset
520 return retval;
2a36b558ab55 [project @ 1995-02-15 04:01:38 by jwe]
jwe
parents: 1086
diff changeset
521 #else
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
522 return chdir (path.c_str ());
1111
2a36b558ab55 [project @ 1995-02-15 04:01:38 by jwe]
jwe
parents: 1086
diff changeset
523 #endif
2a36b558ab55 [project @ 1995-02-15 04:01:38 by jwe]
jwe
parents: 1086
diff changeset
524 }
2a36b558ab55 [project @ 1995-02-15 04:01:38 by jwe]
jwe
parents: 1086
diff changeset
525
1488
89c587478067 [project @ 1995-09-26 22:49:48 by jwe]
jwe
parents: 1467
diff changeset
526 DEFUN ("clc", Fclc, Sclc, 00,
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
527 "clc (): clear screen")
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
528 {
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
529 Octave_object retval;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
530
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
531 rl_beg_of_line ();
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
532 rl_kill_line (1);
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
533
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
534 #if ! defined (_GO32_)
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
535 if (term_clrpag)
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
536 tputs (term_clrpag, 1, _rl_output_character_function);
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
537 else
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
538 crlf ();
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
539 #else
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
540 crlf ();
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
541 #endif
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
542
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
543 fflush (rl_outstream);
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
544
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
545 return retval;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
546 }
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
547
549
75a371805554 [project @ 1994-07-22 19:44:41 by jwe]
jwe
parents: 545
diff changeset
548 DEFALIAS (home, clc);
75a371805554 [project @ 1994-07-22 19:44:41 by jwe]
jwe
parents: 545
diff changeset
549
1488
89c587478067 [project @ 1995-09-26 22:49:48 by jwe]
jwe
parents: 1467
diff changeset
550 DEFUN ("getenv", Fgetenv, Sgetenv, 10,
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
551 "getenv (STRING): get environment variable values")
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
552 {
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
553 Octave_object retval;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
554
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
555 int nargin = args.length ();
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
556
712
36ba0576bd1b [project @ 1994-09-19 14:18:15 by jwe]
jwe
parents: 661
diff changeset
557 if (nargin == 1)
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
558 {
1728
42b4f904f1af [project @ 1996-01-09 11:36:01 by jwe]
jwe
parents: 1711
diff changeset
559 string tstr = args(0).string_value ();
42b4f904f1af [project @ 1996-01-09 11:36:01 by jwe]
jwe
parents: 1711
diff changeset
560 const char *name = tstr.c_str ();
636
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 610
diff changeset
561
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 610
diff changeset
562 if (! error_state)
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 610
diff changeset
563 {
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 610
diff changeset
564 char *value = getenv (name);
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 610
diff changeset
565 if (value)
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 610
diff changeset
566 retval = value;
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 610
diff changeset
567 else
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 610
diff changeset
568 retval = "";
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 610
diff changeset
569 }
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
570 }
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
571 else
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
572 print_usage ("getenv");
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
573
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
574 return retval;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
575 }
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
576
1706
6bb0c67bbf24 [project @ 1996-01-07 05:40:05 by jwe]
jwe
parents: 1670
diff changeset
577 DEFUN ("putenv", Fputenv, Sputenv, 10,
6bb0c67bbf24 [project @ 1996-01-07 05:40:05 by jwe]
jwe
parents: 1670
diff changeset
578 "putenv (VAR, VALUE): define environment variable VAR=VALUE")
6bb0c67bbf24 [project @ 1996-01-07 05:40:05 by jwe]
jwe
parents: 1670
diff changeset
579 {
6bb0c67bbf24 [project @ 1996-01-07 05:40:05 by jwe]
jwe
parents: 1670
diff changeset
580 Octave_object retval;
6bb0c67bbf24 [project @ 1996-01-07 05:40:05 by jwe]
jwe
parents: 1670
diff changeset
581
6bb0c67bbf24 [project @ 1996-01-07 05:40:05 by jwe]
jwe
parents: 1670
diff changeset
582 int nargin = args.length ();
6bb0c67bbf24 [project @ 1996-01-07 05:40:05 by jwe]
jwe
parents: 1670
diff changeset
583
6bb0c67bbf24 [project @ 1996-01-07 05:40:05 by jwe]
jwe
parents: 1670
diff changeset
584 if (nargin == 2)
6bb0c67bbf24 [project @ 1996-01-07 05:40:05 by jwe]
jwe
parents: 1670
diff changeset
585 {
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
586 string var = args(0).string_value ();
1706
6bb0c67bbf24 [project @ 1996-01-07 05:40:05 by jwe]
jwe
parents: 1670
diff changeset
587
6bb0c67bbf24 [project @ 1996-01-07 05:40:05 by jwe]
jwe
parents: 1670
diff changeset
588 if (! error_state)
6bb0c67bbf24 [project @ 1996-01-07 05:40:05 by jwe]
jwe
parents: 1670
diff changeset
589 {
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
590 string val = args(1).string_value ();
1706
6bb0c67bbf24 [project @ 1996-01-07 05:40:05 by jwe]
jwe
parents: 1670
diff changeset
591
6bb0c67bbf24 [project @ 1996-01-07 05:40:05 by jwe]
jwe
parents: 1670
diff changeset
592 if (! error_state)
1755
3a9462b655f1 [project @ 1996-01-22 04:47:22 by jwe]
jwe
parents: 1750
diff changeset
593 oct_putenv (var.c_str (), val.c_str ());
1706
6bb0c67bbf24 [project @ 1996-01-07 05:40:05 by jwe]
jwe
parents: 1670
diff changeset
594 else
6bb0c67bbf24 [project @ 1996-01-07 05:40:05 by jwe]
jwe
parents: 1670
diff changeset
595 error ("putenv: second argument should be a string");
6bb0c67bbf24 [project @ 1996-01-07 05:40:05 by jwe]
jwe
parents: 1670
diff changeset
596 }
6bb0c67bbf24 [project @ 1996-01-07 05:40:05 by jwe]
jwe
parents: 1670
diff changeset
597 else
6bb0c67bbf24 [project @ 1996-01-07 05:40:05 by jwe]
jwe
parents: 1670
diff changeset
598 error ("putenv: first argument should be a string");
6bb0c67bbf24 [project @ 1996-01-07 05:40:05 by jwe]
jwe
parents: 1670
diff changeset
599 }
6bb0c67bbf24 [project @ 1996-01-07 05:40:05 by jwe]
jwe
parents: 1670
diff changeset
600 else
6bb0c67bbf24 [project @ 1996-01-07 05:40:05 by jwe]
jwe
parents: 1670
diff changeset
601 print_usage ("putenv");
6bb0c67bbf24 [project @ 1996-01-07 05:40:05 by jwe]
jwe
parents: 1670
diff changeset
602
6bb0c67bbf24 [project @ 1996-01-07 05:40:05 by jwe]
jwe
parents: 1670
diff changeset
603 return retval;
6bb0c67bbf24 [project @ 1996-01-07 05:40:05 by jwe]
jwe
parents: 1670
diff changeset
604 }
6bb0c67bbf24 [project @ 1996-01-07 05:40:05 by jwe]
jwe
parents: 1670
diff changeset
605
1488
89c587478067 [project @ 1995-09-26 22:49:48 by jwe]
jwe
parents: 1467
diff changeset
606 DEFUN ("kbhit", Fkbhit, Skbhit, 00,
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
607 "kbhit: get a single character from the terminal")
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
608 {
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
609 Octave_object retval;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
610
1358
dc9c01f66a19 [project @ 1995-09-05 21:10:01 by jwe]
jwe
parents: 1352
diff changeset
611 // XXX FIXME XXX -- add timeout and default value args?
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
612
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
613 if (interactive)
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
614 {
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
615 int c = kbhit ();
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
616 char *s = new char [2];
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
617 s[0] = c;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
618 s[1] = '\0';
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
619 retval = s;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
620 }
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
621
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
622 return retval;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
623 }
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
624
1488
89c587478067 [project @ 1995-09-26 22:49:48 by jwe]
jwe
parents: 1467
diff changeset
625 DEFUN ("pause", Fpause, Spause, 10,
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
626 "pause (seconds): suspend program execution")
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
627 {
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
628 Octave_object retval;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
629
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
630 int nargin = args.length ();
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
631
712
36ba0576bd1b [project @ 1994-09-19 14:18:15 by jwe]
jwe
parents: 661
diff changeset
632 if (! (nargin == 0 || nargin == 1))
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
633 {
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
634 print_usage ("pause");
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
635 return retval;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
636 }
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
637
1579
972ce8b5a757 [project @ 1995-10-19 06:39:35 by jwe]
jwe
parents: 1488
diff changeset
638 if (nargin == 1)
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
639 {
1579
972ce8b5a757 [project @ 1995-10-19 06:39:35 by jwe]
jwe
parents: 1488
diff changeset
640 double dval = args(0).double_value ();
636
fae2bd91c027 [project @ 1994-08-23 18:39:50 by jwe]
jwe
parents: 610
diff changeset
641
1579
972ce8b5a757 [project @ 1995-10-19 06:39:35 by jwe]
jwe
parents: 1488
diff changeset
642 if (! error_state)
972ce8b5a757 [project @ 1995-10-19 06:39:35 by jwe]
jwe
parents: 1488
diff changeset
643 {
972ce8b5a757 [project @ 1995-10-19 06:39:35 by jwe]
jwe
parents: 1488
diff changeset
644 if (xisnan (dval))
972ce8b5a757 [project @ 1995-10-19 06:39:35 by jwe]
jwe
parents: 1488
diff changeset
645 warning ("pause: NaN is an invalid delay");
972ce8b5a757 [project @ 1995-10-19 06:39:35 by jwe]
jwe
parents: 1488
diff changeset
646 else
972ce8b5a757 [project @ 1995-10-19 06:39:35 by jwe]
jwe
parents: 1488
diff changeset
647 {
972ce8b5a757 [project @ 1995-10-19 06:39:35 by jwe]
jwe
parents: 1488
diff changeset
648 int delay = NINT (dval);
972ce8b5a757 [project @ 1995-10-19 06:39:35 by jwe]
jwe
parents: 1488
diff changeset
649 if (delay > 0)
972ce8b5a757 [project @ 1995-10-19 06:39:35 by jwe]
jwe
parents: 1488
diff changeset
650 sleep (delay);
972ce8b5a757 [project @ 1995-10-19 06:39:35 by jwe]
jwe
parents: 1488
diff changeset
651 }
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
652 }
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
653 }
1579
972ce8b5a757 [project @ 1995-10-19 06:39:35 by jwe]
jwe
parents: 1488
diff changeset
654 else
972ce8b5a757 [project @ 1995-10-19 06:39:35 by jwe]
jwe
parents: 1488
diff changeset
655 {
972ce8b5a757 [project @ 1995-10-19 06:39:35 by jwe]
jwe
parents: 1488
diff changeset
656 if (kbhit () == EOF)
972ce8b5a757 [project @ 1995-10-19 06:39:35 by jwe]
jwe
parents: 1488
diff changeset
657 clean_up_and_exit (0);
972ce8b5a757 [project @ 1995-10-19 06:39:35 by jwe]
jwe
parents: 1488
diff changeset
658 }
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
659
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
660 return retval;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
661 }
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
662
862
61d83ce7368c [project @ 1994-10-31 20:39:30 by jwe]
jwe
parents: 844
diff changeset
663 // XXX FIXME XXX -- maybe this should only return 1 if IEEE floating
61d83ce7368c [project @ 1994-10-31 20:39:30 by jwe]
jwe
parents: 844
diff changeset
664 // point functions really work.
61d83ce7368c [project @ 1994-10-31 20:39:30 by jwe]
jwe
parents: 844
diff changeset
665
1488
89c587478067 [project @ 1995-09-26 22:49:48 by jwe]
jwe
parents: 1467
diff changeset
666 DEFUN ("isieee", Fisieee, Sisieee, 00,
862
61d83ce7368c [project @ 1994-10-31 20:39:30 by jwe]
jwe
parents: 844
diff changeset
667 "isieee (): return 1 if host uses IEEE floating point")
61d83ce7368c [project @ 1994-10-31 20:39:30 by jwe]
jwe
parents: 844
diff changeset
668 {
1226
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
669 return (double) (native_float_format == OCTAVE_IEEE_LITTLE
2457d4ba0691 [project @ 1995-04-10 00:41:14 by jwe]
jwe
parents: 1192
diff changeset
670 || native_float_format == OCTAVE_IEEE_BIG);
862
61d83ce7368c [project @ 1994-10-31 20:39:30 by jwe]
jwe
parents: 844
diff changeset
671 }
61d83ce7368c [project @ 1994-10-31 20:39:30 by jwe]
jwe
parents: 844
diff changeset
672
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
673 #if !defined (HAVE_GETHOSTNAME) && defined (HAVE_SYS_UTSNAME_H)
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
674 int
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
675 gethostname (char *name, int namelen)
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
676 {
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
677 int i;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
678 struct utsname ut;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
679
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
680 --namelen;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
681
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
682 uname (&ut);
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
683 i = strlen (ut.nodename) + 1;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
684 strncpy (name, ut.nodename, i < namelen ? i : namelen);
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
685 name[namelen] = '\0';
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
686
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
687 return 0;
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
688 }
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
689 #endif
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
690
1750
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
691 // The check for error state allows us to do this:
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
692 //
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
693 // string foo = oct_tilde_expand (args(0).string_value ());
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
694 //
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
695 // without having to use a temporary and check error_state before
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
696 // calling oct_tilde_expand.
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
697
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
698 string
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
699 oct_tilde_expand (const string& name)
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
700 {
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
701 string retval;
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
702
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
703 if (! error_state)
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
704 {
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
705 char *tmp = tilde_expand (name.c_str ());
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
706 retval = tmp;
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
707 delete [] tmp;
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
708 }
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
709
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
710 return retval;
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
711 }
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
712
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
713 DEFUN ("tilde_expand", Ftilde_expand, Stilde_expand, 10,
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
714 "tilde_expand (STRING): perform tilde expansion on STRING")
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
715 {
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
716 Octave_object retval;
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
717
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
718 int nargin = args.length ();
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
719
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
720 if (nargin == 1)
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
721 retval = oct_tilde_expand (args(0).string_value ());
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
722 else
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
723 print_usage ("tilde_expand");
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
724
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
725 return retval;
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
726 }
fd0d12493223 [project @ 1996-01-13 09:31:07 by jwe]
jwe
parents: 1742
diff changeset
727
529
7ea224e713cd [project @ 1994-07-20 18:54:27 by jwe]
jwe
parents: 505
diff changeset
728 /*
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
729 ;;; Local Variables: ***
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
730 ;;; mode: C++ ***
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
731 ;;; page-delimiter: "^/\\*" ***
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
732 ;;; End: ***
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
733 */