note description: "Objects that may be compared according to a total order relation" status: "See notice at end of class" names: comparable, comparison; date: "$Date$" revision: "$Revision$" deferred class COMPARABLE inherit PART_COMPARABLE redefine is_less, is_less_equal, is_greater, is_greater_equal, is_equal end feature -- Comparison is_less alias "<" (other: like Current): BOOLEAN -- Is current object less than `other'? deferred ensure then asymmetric: Result implies not (other < Current) end is_less_equal alias "<=" (other: like Current): BOOLEAN -- Is current object less than or equal to `other'? do Result := not (other < Current) ensure then definition: Result = ((Current < other) or is_equal (other)) end is_greater alias ">" (other: like Current): BOOLEAN -- Is current object greater than `other'? do Result := other < Current ensure then definition: Result = (other < Current) end is_greater_equal alias ">=" (other: like Current): BOOLEAN -- Is current object greater than or equal to `other'? do Result := not (Current < other) ensure then definition: Result = (other <= Current) end is_equal (other: like Current): BOOLEAN -- Is `other' attached to an object of the same type -- as current object and identical to it? do Result := (not (Current < other) and not (other < Current)) ensure then trichotomy: Result = (not (Current < other) and not (other < Current)) end three_way_comparison (other: like Current): INTEGER -- If current object equal to `other', 0; -- if smaller, -1; if greater, 1 require other_exists: other /= Void do if Current < other then Result := -1 elseif other < Current then Result := 1 end ensure equal_zero: (Result = 0) = is_equal (other) smaller_negative: (Result = -1) = (Current < other) greater_positive: (Result = 1) = (Current > other) end max (other: like Current): like Current -- The greater of current object and `other' require other_exists: other /= Void do if Current >= other then Result := Current else Result := other end ensure current_if_not_smaller: Current >= other implies Result = Current other_if_smaller: Current < other implies Result = other end min (other: like Current): like Current -- The smaller of current object and `other' require other_exists: other /= Void do if Current <= other then Result := Current else Result := other end ensure current_if_not_greater: Current <= other implies Result = Current other_if_greater: Current > other implies Result = other end invariant irreflexive_comparison: not (Current < Current) note library: "[ EiffelBase: Library of reusable components for Eiffel. ]" status: "[ --| Copyright (c) 1993-2006 University of Southern California and contributors. 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 Customer support http://support.eiffel.com ]" info: "[ For latest info see award-winning pages: http://eiffel.com ]" end -- class COMPARABLE