1 (* Copyright (C) 2005 Free Software Foundation, Inc. *)
2 (* This file is part of GNU Modula-2.
4 GNU Modula-2 is free software; you can redistribute it and/or modify it under
5 the terms of the GNU General Public License as published by the Free
6 Software Foundation; either version 2, or (at your option) any later
9 GNU Modula-2 is distributed in the hope that it will be useful, but WITHOUT ANY
10 WARRANTY; without even the implied warranty of MERCHANTABILITY or
11 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
14 You should have received a copy of the GNU General Public License along
15 with gm2; see the file COPYING. If not, write to the Free Software
16 Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. *)
20 FROM BitBlockOps IMPORT BlockAnd, BlockOr, BlockXor, BlockNot, BlockShr ;
21 FROM SYSTEM IMPORT ADDRESS, BYTE, WORD, SIZE, ADR, SHIFT ;
22 FROM libc IMPORT exit, printf ;
23 FROM StrLib IMPORT StrEqual ;
26 PROCEDURE Assert (v: BOOLEAN; f: ARRAY OF CHAR; l: CARDINAL; e: ARRAY OF CHAR) ;
32 r := printf("successfully evaluated assertion (%s)\n", ADR(e))
34 r := printf("%s:%d assertion failed when evaluating %s\n", ADR(f), l, ADR(e)) ;
40 PROCEDURE clear (a: ADDRESS; n: CARDINAL) ;
57 byte := VAL(BYTE, BITSET{0, 3, 5, 7}) ;
58 BlockShr(ADR(byte), SIZE(byte), 1) ;
59 Assert(byte=VAL(BYTE, BITSET{2, 4, 6}), __FILE__, __LINE__, 'BlockShr on BYTE') ;
60 BlockXor(ADR(byte), ADR(byte), SIZE(byte)) ;
61 Assert(byte=BYTE(0), __FILE__, __LINE__, 'BlockXor on BYTE')
65 PROCEDURE bitsetTest ;
67 bytes : POINTER TO ARRAY [0..SIZE(BITSET)-1] OF BYTE ;
70 bytes := ADR(bitset) ;
71 bytes^[0] := BYTE(0A3H) ;
72 bytes^[1] := BYTE(053H) ;
73 bytes^[2] := BYTE(031H) ;
74 bytes^[3] := BYTE(01AH) ;
76 BlockShr(ADR(bitset), SIZE(bitset), 1) ;
78 Assert(bytes^[0]=BYTE(051H), __FILE__, __LINE__, 'BlockShr on byte[0]') ;
79 Assert(bytes^[1]=BYTE(0A9H), __FILE__, __LINE__, 'BlockShr on byte[1]') ;
80 Assert(bytes^[2]=BYTE(098H), __FILE__, __LINE__, 'BlockShr on byte[2]') ;
81 Assert(bytes^[3]=BYTE(08DH), __FILE__, __LINE__, 'BlockShr on byte[3]') ;
82 BlockXor(ADR(bitset), ADR(bitset), SIZE(bitset)) ;
83 Assert(bitset=BITSET(0), __FILE__, __LINE__, 'BlockXor on BITSET')