2001-06-06 20:40:57 +01:00
|
|
|
=================================================================
|
|
|
|
Logtalk - Object oriented extension to Prolog
|
2002-09-14 19:14:17 +01:00
|
|
|
Release 2.14.3
|
2001-06-06 20:40:57 +01:00
|
|
|
|
2002-01-08 00:05:10 +00:00
|
|
|
Copyright (c) 1998-2002 Paulo Moura. All Rights Reserved.
|
2001-06-06 20:40:57 +01:00
|
|
|
=================================================================
|
|
|
|
|
|
|
|
|
|
|
|
To load all objects in this example consult the points.loader utility
|
|
|
|
file (note that the *.loader files are Prolog files).
|
|
|
|
|
|
|
|
You will need to load the objects in the roots and relations
|
|
|
|
examples (consulting the corresponding roots.loader and relations.loader
|
|
|
|
files).
|
|
|
|
|
|
|
|
You will also need to consult the following files in the library directory:
|
|
|
|
events.loader, types.loader, metapredicates.loader, and hierarchies.loader.
|
2002-02-08 19:57:23 +00:00
|
|
|
Alternatively, you may load the library/all.loader file to load all library
|
|
|
|
entities.
|
|
|
|
|
2001-06-06 20:40:57 +01:00
|
|
|
|
|
|
|
You can find the original description of this example (and a solution using
|
|
|
|
SICStus Objects) at the URL:
|
|
|
|
http://www.sics.se/ps/sicstus/sicstus_32.html#SEC254
|
|
|
|
|
|
|
|
Suppose you wish to represent one point in a two-dimensional space. The
|
|
|
|
protocol you will have to define consists on the operation move/2, wish
|
|
|
|
allows you to move one point to a new position, and on the operation
|
|
|
|
print/0, which prints the point position. From the base class point,
|
|
|
|
which contains the indicated operations, we wish to build three
|
|
|
|
variants. One class bounded_point in which one point can only move in a
|
|
|
|
restricted area in space. One class history_point, characterized from
|
|
|
|
the particularity that each point recalls its previous positions.
|
|
|
|
Finally, a class bounded_history_point combining the functionality of
|
|
|
|
classes bounded_point and history_point.
|
|
|
|
|
|
|
|
At first sight, this looks like the kind of ideal problem to illustrate
|
|
|
|
the advantages of the multiple inheritance mechanisms. This type of
|
|
|
|
solution holds, however, several problems. If the methods move/2 and
|
|
|
|
print/0 are inherited by bounded_history_point of classes
|
|
|
|
history_point and bounded_point simultaneously, then one point will be
|
|
|
|
moved and shown twice. If the inheritance is carried out, for each
|
|
|
|
method, only from one of the superclasses (assuming that it is possible
|
|
|
|
to do so, only by breaking the apparent problem symmetry), then the
|
|
|
|
interfaces of classes history_point and bounded_point will have to
|
|
|
|
contain separately the necessary operations to verify the limits (in the
|
|
|
|
case of bounded_point), or to recall the previous positions (in the
|
|
|
|
case of history_point). This way, the class bounded_history_point could
|
|
|
|
build its own versions of methods move/2 and print/0, adding to the
|
|
|
|
inherited definitions of one of the superclasses the calling of the
|
|
|
|
operation missing in the other superclass. This is the solution adopted
|
|
|
|
in the SICStus Objects. However, this solution also implies a few
|
|
|
|
problems. Let's suppose that method move/2 is inherited from class
|
|
|
|
history_point. Then, any changing operated in the definition of the same
|
|
|
|
method in class bounded_point is ignored by bounded_history_point. The
|
|
|
|
problem can be unnoticed, once the symmetry suggested by the use of
|
|
|
|
multiple inheritance does not reflect on the present implementation.
|
|
|
|
|
|
|
|
The solution just suggested is, in short, a generalization of the
|
|
|
|
problem previously described. Instead of using multiple inheritance,
|
|
|
|
let's use composition mechanisms. In order to do so, let's separate the
|
|
|
|
operations on one point, while an object state, of the classes
|
|
|
|
representing each one of the point types. This can be achieved through
|
|
|
|
the definition of two new categories, bounded_coordinate and
|
|
|
|
point_history, that will define the operations associated both to the
|
|
|
|
memorization of previous values, and to the verification of feasible
|
|
|
|
limits for a coordinate value. Each one of the point, bounded_point,
|
|
|
|
history_point and bounded_history_point classes will import this
|
|
|
|
category, using his operations so as to define the methods affecting the
|
|
|
|
solutions that use multiple inheritance.
|