### Diff for /gforth/float.fs between versions 1.31 and 1.36

version 1.31, 2000/08/09 20:04:05 version 1.36, 2002/01/17 12:02:55
Line 16 Line 16

\ You should have received a copy of the GNU General Public License  \ You should have received a copy of the GNU General Public License
\ along with this program; if not, write to the Free Software  \ along with this program; if not, write to the Free Software
\ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.  \ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111, USA.

\ 1 cells 4 = [IF]  \ 1 cells 4 = [IF]
\ ' cells   Alias sfloats  \ ' cells   Alias sfloats
Line 100  DOES> ( -- r ) Line 100  DOES> ( -- r )
IF  '- emit  THEN ;    IF  '- emit  THEN ;

: f.  ( r -- ) \ float-ext f-dot  : f.  ( r -- ) \ float-ext f-dot
\G Display (the floating-point number) @i{r} using fixed-point notation,  \G Display (the floating-point number) @i{r} without exponent,
\G followed by a space.  \G followed by a space.
f\$ dup >r 0<    f\$ dup >r 0<=
IF    '0 emit    IF    '0 emit
ELSE  scratch r@ min type  r@ precision - zeros  THEN    ELSE  scratch r@ min type  r@ precision - zeros  THEN
'. emit r@ negate zeros    '. emit r@ negate zeros
Line 110  DOES> ( -- r ) Line 110  DOES> ( -- r )
\ I'm afraid this does not really implement ansi semantics wrt precision.  \ I'm afraid this does not really implement ansi semantics wrt precision.
\ Shouldn't precision indicate the number of places shown after the point?  \ Shouldn't precision indicate the number of places shown after the point?

\ Why do you think so? ANS Forth appears ambiguous on this point. -anton.

: fe. ( r -- ) \ float-ext f-e-dot  : fe. ( r -- ) \ float-ext f-e-dot
\G Display @i{r} using engineering notation, followed by a space.  \G Display @i{r} using engineering notation (with exponent dividable
\G by 3), followed by a space.
f\$ 1- s>d 3 fm/mod 3 * >r 1+ >r    f\$ 1- s>d 3 fm/mod 3 * >r 1+ >r
scratch r@ min type '. emit  scratch r> /string type    scratch r@ tuck min tuck - >r type r> zeros
'. emit scratch r> /string type
'E emit r> . ;    'E emit r> . ;

: fs. ( r -- ) \ float-ext f-s-dot  : fs. ( r -- ) \ float-ext f-s-dot
\G Display @i{r} using scientific notation, followed by a space.  \G Display @i{r} using scientific notation (with exponent), followed
\G by a space.
f\$ 1-    f\$ 1-
scratch over c@ emit '. emit 1 /string type    scratch over c@ emit '. emit 1 /string type
'E emit . ;    'E emit . ;
Line 175  IS interpreter-notfound Line 180  IS interpreter-notfound
\G Divide 1.0e0 by @i{r1}.      \G Divide 1.0e0 by @i{r1}.
1.0e0 fswap f/ ;      1.0e0 fswap f/ ;

get-current environment-wordlist set-current
1.7976931348623157e308 FConstant max-float
set-current

\ We now have primitives for these, so we need not define them  \ We now have primitives for these, so we need not define them

 Removed from v.1.31 changed lines Added in v.1.36

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>