Automatic generation produced by ISE Eiffel

Classes Clusters Cluster hierarchy Chart Relations Text Flat Contracts Flat contracts Go to:
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 feature -- Access conforms_to (other: BIT_REF): BOOLEAN is -- Is dynamic type of current object a descendant of -- dynamic type of other? require -- from ANY other_not_void: other /= void do Result := count <= other.count 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 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 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 rotating bit sequence by s positions -- (Positive s rotates right, negative s rotates left.) do Result := b_rotate ($Current, s) end 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 "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 prefix "not": like Current is -- Bit-by-bit negation do Result := b_not ($Current) 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 feature {NONE} -- Implementation b_and (a_bit1, a_bit2: POINTER): BIT_REF is -- Conjunction of a_bit1 with a_bit2 external "C | %"eif_bits.h%"" end b_count (a_bit: POINTER): INTEGER is -- Size of a_bit 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_item (a_bit: POINTER; index: INTEGER): BOOLEAN is -- Boolean item at position i in a_bit 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_or (a_bit1, a_bit2: POINTER): BIT_REF is -- Disjunction of a_bit1 with a_bit2 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 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_shift (a_bit: POINTER; s: INTEGER): BIT_REF is -- Result of shifting a_bit by s positions 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 c_out (b: POINTER): STRING is -- Out representation of Current external "C | %"eif_bits.h%"" alias "b_eout" end feature -- Output out: STRING is -- Tagged printable representation. do Result := c_out ($Current) end invariant -- from ANY reflexive_equality: standard_is_equal (Current) reflexive_conformance: conforms_to (Current) 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
Classes Clusters Cluster hierarchy Chart Relations Text Flat Contracts Flat contracts Go to:

-- Generated by ISE Eiffel --
For more details: www.eiffel.com