Automatic generation produced by ISE Eiffel
indexing description: "Bit sequences of length `count', with binary operations" status: "See notice at end of class" date: "$Date: 2001-11-16 20:32:23 +0000 (Fri, 16 Nov 2001) $" revision: "$Revision: 51435 $" class BIT_REF inherit ANY redefine out, generator, conforms_to end feature -- Access item (i: INTEGER): BOOLEAN is -- i-th bit -- Was declared in BIT_REF as synonym of @. require index_large_enough: i >= 1 index_small_enough: i <= count do Result := b_item ($Current, i) end infix "@" (i: INTEGER): BOOLEAN is -- i-th bit -- Was declared in BIT_REF as synonym of item. require index_large_enough: i >= 1 index_small_enough: i <= count do Result := b_item ($Current, i) end generator: STRING is -- Name of the current object's generating class. do create Result.make (10) Result.append ("BIT ") Result.append_integer (count) end conforms_to (other: BIT_REF): BOOLEAN is -- Is dynamic type of current object a descendant of -- dynamic type of other? do Result := count <= other.count end feature -- Measurement count: INTEGER is -- Size of the current bit object do Result := b_count ($Current) end feature -- Element change put (value: BOOLEAN; i: INTEGER) is -- Set the i-th bit to 1 if value is True, 0 if False require index_large_enough: i >= 1 index_small_enough: i <= count do b_put ($Current, value, i) ensure value_inserted: item (i) = value end feature -- Basic operations infix "^" (s: INTEGER): like Current is -- Result of shifting bit sequence by s positions -- (Positive s shifts right, negative s shifts left; -- bits falling off the sequence's bounds are lost.) do Result := b_shift ($Current, s) end infix "#" (s: INTEGER): like Current is -- Result of rotating bit sequence by s positions -- (Positive s rotates right, negative s rotates left.) do Result := b_rotate ($Current, s) end infix "and" (other: BIT_REF): BIT_REF is -- Bit-by-bit boolean conjunction with other require other_exists: other /= void conformance: other.count <= count do Result := b_and ($Current, $other) end infix "implies" (other: BIT_REF): BIT_REF is -- Bit-by-bit boolean implication of other require other_exists: other /= void conformance: other.count <= count do Result := b_implies ($Current, $other) end infix "or" (other: BIT_REF): BIT_REF is -- Bit-by-bit boolean disjunction with other require other_exists: other /= void conformance: other.count <= count do Result := b_or ($Current, $other) end infix "xor" (other: BIT_REF): BIT_REF is -- Bit-by-bit exclusive or with other require other_exists: other /= void conformance: other.count <= count do Result := b_xor ($Current, $other) end prefix "not": like Current is -- Bit-by-bit negation do Result := b_not ($Current) end feature -- Output out: STRING is -- Tagged printable representation. do Result := c_out ($Current) end feature {NONE} -- Implementation b_item (a_bit: POINTER; index: INTEGER): BOOLEAN is -- Boolean item at position i in a_bit external "C | %"eif_bits.h%"" end b_count (a_bit: POINTER): INTEGER is -- Size of a_bit external "C | %"eif_bits.h%"" end b_shift (a_bit: POINTER; s: INTEGER): BIT_REF is -- Result of shifting a_bit by s positions external "C | %"eif_bits.h%"" end b_rotate (a_bit: POINTER; s: INTEGER): BIT_REF is -- Result of rotating a_bit by s positions external "C | %"eif_bits.h%"" end b_and (a_bit1, a_bit2: POINTER): BIT_REF is -- Conjunction of a_bit1 with a_bit2 external "C | %"eif_bits.h%"" end b_implies (a_bit1, a_bit2: POINTER): BIT_REF is -- Implication for a_bit1 of a_bit2 external "C | %"eif_bits.h%"" end b_or (a_bit1, a_bit2: POINTER): BIT_REF is -- Disjunction of a_bit1 with a_bit2 external "C | %"eif_bits.h%"" end b_xor (a_bit1, a_bit2: POINTER): BIT_REF is -- Exclusive or of a_bit1 with a_bit2 external "C | %"eif_bits.h%"" end b_not (a_bit: POINTER): BIT_REF is -- Negation of a_bit external "C | %"eif_bits.h%"" end b_put (a_bit: POINTER; val: BOOLEAN; index: INTEGER) is -- Put val in a_bit at position index. external "C | %"eif_bits.h%"" end c_out (b: POINTER): STRING is -- Out representation of Current external "C | %"eif_bits.h%"" alias "b_eout" end indexing library: "[ EiffelBase: Library of reusable components for Eiffel. ]" status: "[ Copyright 1986-2001 Interactive Software Engineering (ISE). For ISE customers the original versions are an ISE product covered by the ISE Eiffel license and support agreements. ]" license: "[ EiffelBase may now be used by anyone as FREE SOFTWARE to develop any product, public-domain or commercial, without payment to ISE, under the terms of the ISE Free Eiffel Library License (IFELL) at http://eiffel.com/products/base/license.html. ]" source: "[ Interactive Software Engineering Inc. ISE Building 360 Storke Road, Goleta, CA 93117 USA Telephone 805-685-1006, Fax 805-685-6869 Electronic mail <info@eiffel.com> Customer support http://support.eiffel.com ]" info: "[ For latest info see award-winning pages: http://eiffel.com ]" end -- class BIT_REF -- Generated by ISE Eiffel --
For more details: www.eiffel.com