note description: "[ Finite sequences: structures where existing items are arranged and accessed sequentially, and new ones can be added at the end. ]" library: "Free implementation of ELKS library" legal: "See notice at end of class." status: "See notice at end of class." names: sequence access: cursor, membership contents: generic date: "$Date: 2018-10-02 14:09:21 +0000 (Tue, 02 Oct 2018) $" revision: "$Revision: 102245 $" deferred class interface SEQUENCE [G] feature -- Status report readable: BOOLEAN -- Is there a current item that may be read? writable: BOOLEAN -- Is there a current item that may be modified? feature -- Element change force (v: like item) -- Add v to end. require extendible: extendible ensure then new_count: count = old count + 1 item_inserted: has (v) append (s: SEQUENCE [G]) -- Append a copy of s. require argument_not_void: s /= Void ensure new_count: count >= old count put (v: like item) -- Add v to end. ensure then new_count: count = old count + 1 feature -- Removal prune (v: like item) -- Remove the first occurrence of v if any. -- If no such occurrence go off. prune_all (v: like item) -- Remove all occurrences of v; go off. note copyright: "Copyright (c) 1984-2018, Eiffel Software and others" license: "Eiffel Forum License v2 (see http://www.eiffel.com/licensing/forum.txt)" source: "[ Eiffel Software 5949 Hollister Ave., Goleta, CA 93117 USA Telephone 805-685-1006, Fax 805-685-6869 Website http://www.eiffel.com Customer support http://support.eiffel.com ]" end -- class SEQUENCE
Generated by ISE EiffelStudio