version 1.9, 2007/11/03 08:27:14
|
version 1.12, 2008/11/08 18:28:22
|
Line 180 HAS-FLOATING-STACK [IF]
|
Line 180 HAS-FLOATING-STACK [IF]
|
: F} ( ... -- ... ) |
: F} ( ... -- ... ) |
FDEPTH ACTUAL-FDEPTH @ = IF |
FDEPTH ACTUAL-FDEPTH @ = IF |
FDEPTH START-FDEPTH @ > IF |
FDEPTH START-FDEPTH @ > IF |
FDEPTH START-FDEPTH @ DO |
FDEPTH START-FDEPTH @ - 0 DO |
ACTUAL-FRESULTS I FLOATS + F@ FCONF= INVERT IF |
ACTUAL-FRESULTS I FLOATS + F@ FCONF= INVERT IF |
S" INCORRECT FP RESULT: " ERROR LEAVE |
S" INCORRECT FP RESULT: " ERROR LEAVE |
THEN |
THEN |
Line 192 HAS-FLOATING-STACK [IF]
|
Line 192 HAS-FLOATING-STACK [IF]
|
|
|
: F...}T ( -- ) |
: F...}T ( -- ) |
FCURSOR @ START-FDEPTH @ + ACTUAL-FDEPTH @ <> IF |
FCURSOR @ START-FDEPTH @ + ACTUAL-FDEPTH @ <> IF |
S" NUMBER OF FLOAT RESULTS BEFORE '->' DOES NOT MATCH ...}T SPRECIFICATION: " ERROR |
S" NUMBER OF FLOAT RESULTS BEFORE '->' DOES NOT MATCH ...}T SPECIFICATION: " ERROR |
ELSE FDEPTH START-FDEPTH @ = 0= IF |
ELSE FDEPTH START-FDEPTH @ = 0= IF |
S" NUMBER OF FLOAT RESULTS BEFORE AND AFTER '->' DOES NOT MATCH: " ERROR |
S" NUMBER OF FLOAT RESULTS BEFORE AND AFTER '->' DOES NOT MATCH: " ERROR |
THEN THEN ; |
THEN THEN ; |
Line 213 HAS-FLOATING-STACK [IF]
|
Line 213 HAS-FLOATING-STACK [IF]
|
: F} ; |
: F} ; |
: F...}T ; |
: F...}T ; |
|
|
|
HAS-FLOATING [IF] |
DECIMAL |
DECIMAL |
: COMPUTE-CELLS-PER-FP ( -- U ) |
: COMPUTE-CELLS-PER-FP ( -- U ) |
DEPTH 0E DEPTH 1- >R FDROP R> SWAP - ; |
DEPTH 0E DEPTH 1- >R FDROP R> SWAP - ; |
HEX |
HEX |
|
|
COMPUTE-CELLS-PER-FP CONSTANT CELLS-PER-FP |
COMPUTE-CELLS-PER-FP CONSTANT CELLS-PER-FP |
|
|
: FTESTER ( R -- ) |
: FTESTER ( R -- ) |
DEPTH CELLS-PER-FP < ACTUAL-DEPTH @ XCURSOR @ START-DEPTH @ + CELLS-PER-FP + < OR IF |
DEPTH CELLS-PER-FP < ACTUAL-DEPTH @ XCURSOR @ START-DEPTH @ + CELLS-PER-FP + < OR IF |
S" NUMBER OF RESULTS AFTER '->' BELOW ...}T SPECIFICATION: " ERROR EXIT |
S" NUMBER OF RESULTS AFTER '->' BELOW ...}T SPECIFICATION: " ERROR EXIT |
Line 227 HAS-FLOATING-STACK [IF]
|
Line 228 HAS-FLOATING-STACK [IF]
|
S" INCORRECT FP RESULT: " ERROR |
S" INCORRECT FP RESULT: " ERROR |
THEN THEN |
THEN THEN |
CELLS-PER-FP XCURSOR +! ; |
CELLS-PER-FP XCURSOR +! ; |
[THEN] |
[THEN] |
|
[THEN] |
|
|
: EMPTY-STACK \ ( ... -- ) EMPTY STACK: HANDLES UNDERFLOWED STACK TOO. |
: EMPTY-STACK \ ( ... -- ) EMPTY STACK: HANDLES UNDERFLOWED STACK TOO. |
DEPTH START-DEPTH @ < IF |
DEPTH START-DEPTH @ < IF |
Line 260 HAS-FLOATING-STACK [IF]
|
Line 262 HAS-FLOATING-STACK [IF]
|
\ (ACTUAL) CONTENTS. |
\ (ACTUAL) CONTENTS. |
DEPTH ACTUAL-DEPTH @ = IF \ IF DEPTHS MATCH |
DEPTH ACTUAL-DEPTH @ = IF \ IF DEPTHS MATCH |
DEPTH START-DEPTH @ > IF \ IF THERE IS SOMETHING ON THE STACK |
DEPTH START-DEPTH @ > IF \ IF THERE IS SOMETHING ON THE STACK |
DEPTH START-DEPTH @ DO \ FOR EACH STACK ITEM |
DEPTH START-DEPTH @ - 0 DO \ FOR EACH STACK ITEM |
ACTUAL-RESULTS I CELLS + @ \ COMPARE ACTUAL WITH EXPECTED |
ACTUAL-RESULTS I CELLS + @ \ COMPARE ACTUAL WITH EXPECTED |
<> IF S" INCORRECT RESULT: " ERROR LEAVE THEN |
<> IF S" INCORRECT RESULT: " ERROR LEAVE THEN |
LOOP |
LOOP |
Line 287 HAS-FLOATING-STACK [IF]
|
Line 289 HAS-FLOATING-STACK [IF]
|
1 XCURSOR +! ; |
1 XCURSOR +! ; |
|
|
: X}T XTESTER ...}T ; |
: X}T XTESTER ...}T ; |
: R}T FTESTER ...}T ; |
|
: XX}T XTESTER XTESTER ...}T ; |
: XX}T XTESTER XTESTER ...}T ; |
|
: XXX}T XTESTER XTESTER XTESTER ...}T ; |
|
: XXXX}T XTESTER XTESTER XTESTER XTESTER ...}T ; |
|
|
|
HAS-FLOATING [IF] |
|
: R}T FTESTER ...}T ; |
: XR}T FTESTER XTESTER ...}T ; |
: XR}T FTESTER XTESTER ...}T ; |
: RX}T XTESTER FTESTER ...}T ; |
: RX}T XTESTER FTESTER ...}T ; |
: RR}T FTESTER FTESTER ...}T ; |
: RR}T FTESTER FTESTER ...}T ; |
: XXX}T XTESTER XTESTER XTESTER ...}T ; |
|
: XXR}T FTESTER XTESTER XTESTER ...}T ; |
: XXR}T FTESTER XTESTER XTESTER ...}T ; |
: XRX}T XTESTER FTESTER XTESTER ...}T ; |
: XRX}T XTESTER FTESTER XTESTER ...}T ; |
: XRR}T FTESTER FTESTER XTESTER ...}T ; |
: XRR}T FTESTER FTESTER XTESTER ...}T ; |
Line 300 HAS-FLOATING-STACK [IF]
|
Line 305 HAS-FLOATING-STACK [IF]
|
: RXR}T FTESTER XTESTER FTESTER ...}T ; |
: RXR}T FTESTER XTESTER FTESTER ...}T ; |
: RRX}T XTESTER FTESTER FTESTER ...}T ; |
: RRX}T XTESTER FTESTER FTESTER ...}T ; |
: RRR}T FTESTER FTESTER FTESTER ...}T ; |
: RRR}T FTESTER FTESTER FTESTER ...}T ; |
: XXXX}T XTESTER XTESTER XTESTER XTESTER ...}T ; |
|
: XXXR}T FTESTER XTESTER XTESTER XTESTER ...}T ; |
: XXXR}T FTESTER XTESTER XTESTER XTESTER ...}T ; |
: XXRX}T XTESTER FTESTER XTESTER XTESTER ...}T ; |
: XXRX}T XTESTER FTESTER XTESTER XTESTER ...}T ; |
: XXRR}T FTESTER FTESTER XTESTER XTESTER ...}T ; |
: XXRR}T FTESTER FTESTER XTESTER XTESTER ...}T ; |
Line 316 HAS-FLOATING-STACK [IF]
|
Line 320 HAS-FLOATING-STACK [IF]
|
: RRXR}T FTESTER XTESTER FTESTER FTESTER ...}T ; |
: RRXR}T FTESTER XTESTER FTESTER FTESTER ...}T ; |
: RRRX}T XTESTER FTESTER FTESTER FTESTER ...}T ; |
: RRRX}T XTESTER FTESTER FTESTER FTESTER ...}T ; |
: RRRR}T FTESTER FTESTER FTESTER FTESTER ...}T ; |
: RRRR}T FTESTER FTESTER FTESTER FTESTER ...}T ; |
|
[THEN] |
|
|
: TESTING \ ( -- ) TALKING COMMENT. |
: TESTING \ ( -- ) TALKING COMMENT. |
SOURCE VERBOSE @ |
SOURCE VERBOSE @ |