xref: /onnv-gate/usr/src/lib/efcode/fcode_test/parse.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 ." parse:"
28*0Sstevel@tonic-gate : $=  ( str1 len1 str2 len2 -- true/false )
29*0Sstevel@tonic-gate   2 pick <> if
30*0Sstevel@tonic-gate      3drop false
31*0Sstevel@tonic-gate   else
32*0Sstevel@tonic-gate      swap dup 0= if
33*0Sstevel@tonic-gate         3drop true
34*0Sstevel@tonic-gate      else
35*0Sstevel@tonic-gate         true swap 0 do
36*0Sstevel@tonic-gate            2 pick i + c@
37*0Sstevel@tonic-gate            2 pick i + c@
38*0Sstevel@tonic-gate            = and
39*0Sstevel@tonic-gate         loop nip nip
40*0Sstevel@tonic-gate      then
41*0Sstevel@tonic-gate   then
42*0Sstevel@tonic-gate ;
43*0Sstevel@tonic-gate : parse-test
44*0Sstevel@tonic-gate   " $= test.1" " abcd" " abcd" $= .passed?
45*0Sstevel@tonic-gate   " $= test.2" " abdc" " abcd" $= invert .passed?
46*0Sstevel@tonic-gate   " $= test.3" " abc"  " abcd" $= invert .passed?
47*0Sstevel@tonic-gate   " 9600,8,n,1,-"
48*0Sstevel@tonic-gate   ascii , left-parse-string " 9600" $= " left-parse.1" rot .passed?
49*0Sstevel@tonic-gate   ascii , left-parse-string " 8"    $= " left-parse.2" rot .passed?
50*0Sstevel@tonic-gate   ascii , left-parse-string " n"    $= " left-parse.3" rot .passed?
51*0Sstevel@tonic-gate   ascii , left-parse-string " 1"    $= " left-parse.4" rot .passed?
52*0Sstevel@tonic-gate   ascii , left-parse-string " -"    $= " left-parse.5" rot .passed?
53*0Sstevel@tonic-gate   2drop
54*0Sstevel@tonic-gate ;
55*0Sstevel@tonic-gate parse-test
56*0Sstevel@tonic-gate cr
57