annotate src/sysdep.cc @ 505:f264c1454c2b

[project @ 1994-07-09 06:02:45 by jwe]
author jwe
date Sat, 09 Jul 1994 06:04:22 +0000
parents 693d18604ccb
children 7ea224e713cd
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
401
0823483a6277 [project @ 1994-04-15 07:00:46 by jwe]
jwe
parents: 240
diff changeset
4 Copyright (C) 1993, 1994 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
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
20 Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
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
240
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
24 #ifdef HAVE_CONFIG_H
a99f28f5e351 [project @ 1993-11-30 20:24:36 by jwe]
jwe
parents: 217
diff changeset
25 #include "config.h"
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
26 #endif
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
27
470
693d18604ccb [project @ 1994-06-06 08:48:27 by jwe]
jwe
parents: 444
diff changeset
28 #include <math.h>
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
29 #include <stdlib.h>
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
30
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
31 #include "error.h"
444
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
32 #include "sysdep.h"
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
33
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
34 // Octave's idea of infinity.
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
35 double octave_Inf;
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
36
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
37 // Octave's idea of not a number.
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
38 double octave_NaN;
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
39
401
0823483a6277 [project @ 1994-04-15 07:00:46 by jwe]
jwe
parents: 240
diff changeset
40 #if defined (__386BSD__) && defined (HAVE_FLOATINGPOINT_H)
0823483a6277 [project @ 1994-04-15 07:00:46 by jwe]
jwe
parents: 240
diff changeset
41 #include <floatingpoint.h>
0823483a6277 [project @ 1994-04-15 07:00:46 by jwe]
jwe
parents: 240
diff changeset
42 #endif
0823483a6277 [project @ 1994-04-15 07:00:46 by jwe]
jwe
parents: 240
diff changeset
43
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
44 #ifdef NeXT
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
45 extern "C"
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
46 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
47 typedef void (*_cplus_fcn_int) (int);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
48 extern void (*malloc_error (_cplus_fcn_int)) (int);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
49 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
50
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
51 static void
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
52 malloc_handler (int code)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
53 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
54 if (code == 5)
217
cd2e49fb4f6b [project @ 1993-11-13 09:16:01 by jwe]
jwe
parents: 1
diff changeset
55 warning ("hopefully recoverable malloc error: freeing wild pointer");
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
56 else
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
57 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
58 panic ("probably irrecoverable malloc error: code %d", code);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
59 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
60 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
61
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
62 static void
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
63 NeXT_init (void)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
64 {
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
65 malloc_error (malloc_handler);
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
66 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
67 #endif
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
68
444
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
69 static void
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
70 octave_ieee_init (void)
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
71 {
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
72 #if defined (HAVE_ISINF) || defined (HAVE_FINITE)
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
73
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
74 // 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
75 // trying to make Inf and NaN.
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
76
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
77 #if defined (HAVE_INFINITY)
470
693d18604ccb [project @ 1994-06-06 08:48:27 by jwe]
jwe
parents: 444
diff changeset
78 octave_Inf = (double) infinity ();
444
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
79 #else
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
80 #ifdef linux
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
81 octave_Inf = HUGE_VAL;
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
82 #else
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
83 double tmp = 1e+10;
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
84 octave_Inf = tmp;
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
85 for (;;)
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
86 {
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
87 octave_Inf *= 1e+10;
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
88 if (octave_Inf == tmp)
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
89 break;
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
90 tmp = octave_Inf;
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
91 }
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
92 #endif
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
93 #endif
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 #if defined (HAVE_QUIET_NAN)
470
693d18604ccb [project @ 1994-06-06 08:48:27 by jwe]
jwe
parents: 444
diff changeset
96 octave_NaN = (double) quiet_nan ();
444
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
97 #else
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
98 #ifdef linux
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
99 octave_NaN = NAN;
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
100 #else
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
101 octave_NaN = octave_Inf / octave_Inf;
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
102 #endif
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
103 #endif
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
104
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
105 #else
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
106
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
107 // This is sort of cheesy, but what can we do, other than blowing it
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
108 // off completely, or writing an entire IEEE emulation package?
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
109
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
110 octave_Inf = DBL_MAX;
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
111 octave_NaN = DBL_MAX;
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
112
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
113 #endif
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
114 }
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
115
505
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
116
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
117 #if defined (EXCEPTION_IN_MATH)
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
118 extern "C"
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
119 {
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
120 int
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
121 matherr (struct exception *x)
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
122 {
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
123 // Possibly print our own message someday. Should probably be
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
124 // user-switchable.
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
125
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
126 switch (x->type)
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
127 {
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
128 case DOMAIN:
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
129 case SING:
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
130 case OVERFLOW:
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
131 case UNDERFLOW:
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
132 case TLOSS:
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
133 case PLOSS:
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
134 default:
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
135 break;
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
136 }
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
137
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
138 // But don't print the system message.
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
139
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
140 return 1;
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
141 }
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
142 }
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
143 #endif
f264c1454c2b [project @ 1994-07-09 06:02:45 by jwe]
jwe
parents: 470
diff changeset
144
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
145 void
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
146 sysdep_init (void)
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
147 {
401
0823483a6277 [project @ 1994-04-15 07:00:46 by jwe]
jwe
parents: 240
diff changeset
148 #if defined (__386BSD__) && defined (HAVE_FLOATINGPOINT_H)
0823483a6277 [project @ 1994-04-15 07:00:46 by jwe]
jwe
parents: 240
diff changeset
149 // Disable trapping on common exceptions.
0823483a6277 [project @ 1994-04-15 07:00:46 by jwe]
jwe
parents: 240
diff changeset
150 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
151 #endif
0823483a6277 [project @ 1994-04-15 07:00:46 by jwe]
jwe
parents: 240
diff changeset
152
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
153 #ifdef NeXT
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
154 NeXT_init ();
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
155 #endif
444
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
156
ba637cc5c5f3 [project @ 1994-06-02 17:15:07 by jwe]
jwe
parents: 401
diff changeset
157 octave_ieee_init ();
1
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
158 }
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
159
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
160 /*
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
161 ;;; Local Variables: ***
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
162 ;;; mode: C++ ***
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
163 ;;; page-delimiter: "^/\\*" ***
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
164 ;;; End: ***
78fd87e624cb [project @ 1993-08-08 01:13:40 by jwe]
jwe
parents:
diff changeset
165 */