5.1 Class GENERAL |
indexing
description: "Platform-independent universal properties. % %This class is an ancestor to all developer-written classes."
class interface
GENERAL
feature -- Access
generating_type: STRING -- Name of current object's generating type -- (type of which it is a direct instance)
generator: STRING -- Name of current object's generating class -- (base class of the type of which it is a direct instance)
id_object (id: INTEGER): ANY -- Object for which object_id has returned id; -- void if none.
object_id: INTEGER -- Value identifying current object uniquely; -- meaningful only for reference types.
stripped (other: GENERAL): like other -- New object with fields copied from current object, -- but limited to attributes of type of other. require conformance: conforms_to (other) ensure stripped_to_other: Result.same_type (other)
feature -- Status report
frozen conforms_to (other: GENERAL): BOOLEAN -- Does type of current object conform to type -- of other (as per Eiffel: The Language, chapter13)? require other_not_void: other /= Void
frozen same_type (other: GENERAL): BOOLEAN -- Is type of current object identical to type of other? require other_not_void: other /= Void ensure definition: Result = (conforms_to (other) and other.conforms_to (Current))
feature -- Comparison
frozen deep_equal (some: GENERAL; other: like some): BOOLEAN -- Are some and other either both void -- or attached to isomorphic object structures? ensure shallow_implies_deep: standard_equal (some, other) implies Result; same_type: Result implies some.same_type (other); symmetric: Result implies deep_equal (other, some)
frozen equal (some: GENERAL; other: like some): BOOLEAN -- Are some and other either both void or attached -- to objects considered equal? ensure definition: Result = (some = Void and other = Void) or else ((some /= Void and other /= Void) and then some.is_equal (other));
is_equal (other: like Current): BOOLEAN -- Is other attached to an object considered equal -- to current object? require other_not_void: other /= Void ensure consistent: standard_is_equal (other) implies Result; same_type: Result implies same_type (other); symmetric: Result implies other.is_equal (Current)
frozen standard_equal (some: GENERAL; other: like some): BOOLEAN -- Are some and other either both void or attached to -- field-by-field identical objects of the same type? -- Always uses the default object comparison criterion. ensure definition: Result = (some = Void and other = Void) or else ((some /= Void and other /= Void) and then some.standard_is_equal (other))
frozen standard_is_equal (other: like Current): BOOLEAN -- Is other attached to an object of the same type as -- current object, and field-by-field identical to it? require other_not_void: other /= Void ensure same_type: Result implies same_type (other); symmetric: Result implies other.standard_is_equal (Current)
feature -- Duplication
frozen clone (other: GENERAL): like other -- Void if other is void; otherwise new object -- equal to other. ensure equal: equal (Result, other)
copy (other: like Current) -- Update current object using fields of object attached -- to other, so as to yield equal objects. require other_not_void: other /= Void; type_identity: same_type (other) ensure is_equal: is_equal (other)
frozen deep_clone (other: GENERAL): like other -- Void if other is void: otherwise, new object structure -- recursively duplicated from the one attached to other ensure deep_equal: deep_equal (other, Result)
frozen standard_clone (other: GENERAL): like other -- Void if other is void; otherwise new object -- field-by-field identical to other. -- Always uses the default copying semantics. ensure equal: standard_equal (Result, other)
frozen standard_copy (other: like Current) -- Copy every field of other onto corresponding field -- of current object. require other_not_void: other /= Void; type_identity: same_type (other) ensure is_standard_equal: standard_is_equal (other)
feature -- Basic operations
frozen default: like Current -- Default value of current type
frozen default_pointer: POINTER -- Default value of type POINTER -- (Avoid the need to write p.default for some p -- of type POINTER.) ensure Result = Result.default
default_rescue -- Handle exception if no Rescue clause. -- (Default: do nothing.)
frozen do_nothing -- Execute a null action.
frozen Void: NONE -- Void reference
feature -- Output
io: STD_FILES -- Handle to standard file setup
out: STRING -- New string containing terse printable representation -- of current object
print (some: GENERAL) -- Write terse external representation of some on -- standard output.
frozen tagged_out: STRING -- New string containing printable representation of -- current object, each field preceded by its attribute -- name, a colon and a space.
invariant
reflexive_equality: standard_is_equal (Current); reflexive_conformance: conforms_to (Current); involutive_object_id: id_object (object_id) = Current
end
Copyright © 1995, Nonprofit
International Consortium for Eiffel mailto:nice@atlanta.twr.com Last Updated: 26 October 1997 |