xref: /onnv-gate/usr/src/lib/efcode/fcode_test/stack.fth (revision 0:68f95e015346)
1*0Sstevel@tonic-gate\ #ident	"%Z%%M%	%I%	%E% SMI"
2*0Sstevel@tonic-gate\ purpose:
3*0Sstevel@tonic-gate\ copyright: Copyright 2005 Sun Microsystems, Inc.  All rights reserved.
4*0Sstevel@tonic-gate\ copyright: Use is subject to license terms.
5*0Sstevel@tonic-gate\ copyright:
6*0Sstevel@tonic-gate\ copyright: CDDL HEADER START
7*0Sstevel@tonic-gate\ copyright:
8*0Sstevel@tonic-gate\ copyright: The contents of this file are subject to the terms of the
9*0Sstevel@tonic-gate\ copyright: Common Development and Distribution License, Version 1.0 only
10*0Sstevel@tonic-gate\ copyright: (the "License").  You may not use this file except in compliance
11*0Sstevel@tonic-gate\ copyright: with the License.
12*0Sstevel@tonic-gate\ copyright:
13*0Sstevel@tonic-gate\ copyright: You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
14*0Sstevel@tonic-gate\ copyright: or http://www.opensolaris.org/os/licensing.
15*0Sstevel@tonic-gate\ copyright: See the License for the specific language governing permissions
16*0Sstevel@tonic-gate\ copyright: and limitations under the License.
17*0Sstevel@tonic-gate\ copyright:
18*0Sstevel@tonic-gate\ copyright: When distributing Covered Code, include this CDDL HEADER in each
19*0Sstevel@tonic-gate\ copyright: file and include the License file at usr/src/OPENSOLARIS.LICENSE.
20*0Sstevel@tonic-gate\ copyright: If applicable, add the following below this CDDL HEADER, with the
21*0Sstevel@tonic-gate\ copyright: fields enclosed by brackets "[]" replaced with your own identifying
22*0Sstevel@tonic-gate\ copyright: information: Portions Copyright [yyyy] [name of copyright owner]
23*0Sstevel@tonic-gate\ copyright:
24*0Sstevel@tonic-gate\ copyright: CDDL HEADER END
25*0Sstevel@tonic-gate\ copyright:
26*0Sstevel@tonic-gate
27*0Sstevel@tonic-gate." Stack Manipulation: "
28*0Sstevel@tonic-gate	" drop"		1 0 drop		.passed?
29*0Sstevel@tonic-gate	" swap"		1 2 1 swap drop =	.passed?
30*0Sstevel@tonic-gate	" nip"		1 0 1 nip - 0=		.passed?
31*0Sstevel@tonic-gate	" over"		1 2 over 1 = nip nip	.passed?
32*0Sstevel@tonic-gate	" dup"		1 dup =			.passed?
33*0Sstevel@tonic-gate	" tuck"		2 1 tuck nip =		.passed?
34*0Sstevel@tonic-gate	" rot"		3 2 1 rot 3 = nip nip	.passed?
35*0Sstevel@tonic-gate	" -rot"		3 2 1 -rot 2 = nip nip	.passed?
36*0Sstevel@tonic-gate	" 2rot"		1 2 3 4 5 6 2rot 2 = swap 1 = and swap 6 = and swap
37*0Sstevel@tonic-gate			   5 = and swap 4 = and swap 3 = and .passed?
38*0Sstevel@tonic-gate	" 2dup"		1 -1 2dup + 0= nip nip	.passed?
39*0Sstevel@tonic-gate	" ?dup"		0 1 ?dup = nip 		.passed?
40*0Sstevel@tonic-gate	" 2swap"	1 1 0 0 2swap and nip nip .passed?
41*0Sstevel@tonic-gate	" 2drop"	1 1 0 0 2drop and	.passed?
42*0Sstevel@tonic-gate	" 2over"	1 2 0 0 2over 2swap 2drop rot = -rot = = .passed?
43*0Sstevel@tonic-gate	" roll"		1 2 3 4 3 roll 1 = nip nip nip .passed?
44*0Sstevel@tonic-gate	" depth"	0 0 depth 4 = nip nip .passed?
45*0Sstevel@tonic-gatecr
46*0Sstevel@tonic-gate
47*0Sstevel@tonic-gate." Return Stack: "
48*0Sstevel@tonic-gate: test-rs
49*0Sstevel@tonic-gate	" >r"		3 1 >r 2 >r 3 =		.passed?
50*0Sstevel@tonic-gate	" r@"		3 r@ 2 = nip		.passed?
51*0Sstevel@tonic-gate	" r>"		3 r> 2 = r> 1 = and nip	.passed?
52*0Sstevel@tonic-gate;  test-rs
53*0Sstevel@tonic-gate: bail-test ( -- )	r> drop  ;
54*0Sstevel@tonic-gate: bail ( -- )		1 bail-test drop 0 ;
55*0Sstevel@tonic-gate	" Manipulate"	bail			.passed?
56*0Sstevel@tonic-gatecr
57