aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/ChangeLog11
-rw-r--r--src/algebra/draw.spad.pamphlet8
-rw-r--r--src/algebra/plot.spad.pamphlet6
-rw-r--r--src/algebra/plot3d.spad.pamphlet6
-rw-r--r--src/include/cfuns.h2
-rw-r--r--src/interp/sys-os.boot6
-rw-r--r--src/lib/cfuns-c.c2
7 files changed, 26 insertions, 15 deletions
diff --git a/src/ChangeLog b/src/ChangeLog
index 217b1308..e20f0f34 100644
--- a/src/ChangeLog
+++ b/src/ChangeLog
@@ -1,3 +1,14 @@
+2009-04-16 Gabriel Dos Reis <gdr@cs.tamu.edu>
+
+ Fix SF/2763053
+ * interp/sys-os.boot ($NaNvalue): Remove.
+ (quietDoubleNaN): Import.
+ * include/cfuns.h (quiet_double_NaN): Rename from NANQ.
+ * lib/cfuns-c.c (quiet_double_NaN): Likewise.
+ * algebra/draw.spad.pamphlet: Replace $NaNvalue with quietDoubleNaN.
+ * algebra/plot.spad.pamphlet: Likewise.
+ * algebra/plot3d.spad.pamphlet: Likewise.
+
2009-04-15 Gabriel Dos Reis <gdr@cs.tamu.edu>
Fix SF/2760823
diff --git a/src/algebra/draw.spad.pamphlet b/src/algebra/draw.spad.pamphlet
index de5dc3e3..52f12b71 100644
--- a/src/algebra/draw.spad.pamphlet
+++ b/src/algebra/draw.spad.pamphlet
@@ -318,9 +318,9 @@ TopLevelDrawFunctionsForCompiledFunctions():
myTrap1: (SF-> SF, SF) -> SF
myTrap1(ff:SF-> SF, f:SF):SF ==
s := trapNumericErrors(ff(f))$Lisp :: Union(SF, "failed")
- s case "failed" => _$NaNvalue$Lisp
+ s case "failed" => quietDoubleNaN()$Lisp
r:=s::SF
- r >max()$SF or r < min()$SF => _$NaNvalue$Lisp
+ r >max()$SF or r < min()$SF => quietDoubleNaN()$Lisp
r
makePt2: (SF,SF) -> Point SF
@@ -493,9 +493,9 @@ TopLevelDrawFunctionsForCompiledFunctions():
myTrap2: ((SF, SF) -> SF, SF, SF) -> SF
myTrap2(ff:(SF, SF) -> SF, u:SF, v:SF):SF ==
s := trapNumericErrors(ff(u, v))$Lisp :: Union(SF, "failed")
- s case "failed" => _$NaNvalue$Lisp
+ s case "failed" => quietDoubleNaN()$Lisp
r:SF := s::SF
- r >max()$SF or r < min()$SF => _$NaNvalue$Lisp
+ r >max()$SF or r < min()$SF => quietDoubleNaN()$Lisp
r
recolor(ptFunc,colFunc) ==
diff --git a/src/algebra/plot.spad.pamphlet b/src/algebra/plot.spad.pamphlet
index 5b5eefd3..0ab68ee1 100644
--- a/src/algebra/plot.spad.pamphlet
+++ b/src/algebra/plot.spad.pamphlet
@@ -284,7 +284,7 @@ Plot(): Exports == Implementation where
xDiff = 0 or yDiff = 0 => curve
l := lo tRange; h := hi tRange
(tDiff := h-l) = 0 => curve
--- if (EQL(yDiff, _$NaNvalue$Lisp)$Lisp) then yDiff := 1::F
+-- if (EQL(yDiff, quietDoubleNaN()$Lisp)$Lisp) then yDiff := 1::F
t := curve.knots
#t < 3 => curve
p := curve.points; f := curve.source
@@ -477,9 +477,9 @@ Plot(): Exports == Implementation where
myTrap: (F-> F, F) -> F
myTrap(ff:F-> F, f:F):F ==
s := trapNumericErrors(ff(f))$Lisp :: Union(F, "failed")
- s case "failed" => _$NaNvalue$Lisp
+ s case "failed" => quietDoubleNaN()$Lisp
r:F:=s::F
- r > max()$F or r < min()$F => _$NaNvalue$Lisp
+ r > max()$F or r < min()$F => quietDoubleNaN()$Lisp
r
plot(f:F -> F,xRange:R) ==
diff --git a/src/algebra/plot3d.spad.pamphlet b/src/algebra/plot3d.spad.pamphlet
index faf926ad..658b3a32 100644
--- a/src/algebra/plot3d.spad.pamphlet
+++ b/src/algebra/plot3d.spad.pamphlet
@@ -192,11 +192,11 @@ Plot3D(): Exports == Implementation where
select(l,f,g) ==
m := f first l
- if (EQL(m, _$NaNvalue$Lisp)$Lisp) then m := 0
+ if (EQL(m, quietDoubleNaN()$Lisp)$Lisp) then m := 0
-- for p in rest l repeat m := g(m,fp)
for p in rest l repeat
fp : F := f p
- if (EQL(fp, _$NaNvalue$Lisp)$Lisp) then fp := 0
+ if (EQL(fp, quietDoubleNaN()$Lisp)$Lisp) then fp := 0
m := g(m,fp)
m
@@ -447,7 +447,7 @@ Plot3D(): Exports == Implementation where
myTrap(ff:F-> F, f:F):F ==
s := trapNumericErrors(ff(f))$Lisp :: Union(F, "failed")
if (s) case "failed" then
- r:F := _$NaNvalue$Lisp
+ r:F := quietDoubleNaN()$Lisp
else
r:F := s
r
diff --git a/src/include/cfuns.h b/src/include/cfuns.h
index 4d0a8f05..46f4cad5 100644
--- a/src/include/cfuns.h
+++ b/src/include/cfuns.h
@@ -64,7 +64,7 @@ OPENAXIOM_EXPORT int oa_copy_file(const char*, const char*);
OPENAXIOM_EXPORT double plus_infinity(void);
OPENAXIOM_EXPORT double minus_infinity(void);
-OPENAXIOM_EXPORT double NANQ(void);
+OPENAXIOM_EXPORT double quiet_double_NaN(void);
OPENAXIOM_EXPORT openaxiom_byteorder oa_get_host_byteorder(void);
diff --git a/src/interp/sys-os.boot b/src/interp/sys-os.boot
index c4f45e66..aae3dad3 100644
--- a/src/interp/sys-os.boot
+++ b/src/interp/sys-os.boot
@@ -198,16 +198,16 @@ runProgram(prog,args) ==
++ numeric limits
+
+import quiet__double__NaN: () -> double for quietDoubleNaN
+
)if %hasFeature KEYWORD::GCL
import plus__infinity: () -> double for plusInfinity
import minus__infinity: () -> double for minusInfinity
-import NANQ: () -> double for NaNQ
-
$plusInfinity := plusInfinity()
$minusInfinity := minusInfinity()
-$NaNvalue := NaNQ()
)elseif %hasFeature KEYWORD::SBCL
$plusInfinity == SB_-EXT::DOUBLE_-FLOAT_-POSITIVE_-INFINITY
diff --git a/src/lib/cfuns-c.c b/src/lib/cfuns-c.c
index 4a443b82..e7fa22ec 100644
--- a/src/lib/cfuns-c.c
+++ b/src/lib/cfuns-c.c
@@ -667,7 +667,7 @@ minus_infinity(void)
}
OPENAXIOM_EXPORT double
-NANQ(void)
+quiet_double_NaN(void)
{
#ifdef NAN
return NAN;