| 
									
										
										
										
											2001-06-06 19:40:57 +00:00
										 |  |  | ================================================================= | 
					
						
							|  |  |  | Logtalk - Object oriented extension to Prolog | 
					
						
							| 
									
										
										
										
											2002-07-31 23:34:42 +00:00
										 |  |  | Release 2.14.1 | 
					
						
							| 
									
										
										
										
											2001-06-06 19:40:57 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-01-08 00:05:10 +00:00
										 |  |  | Copyright (c) 1998-2002 Paulo Moura.  All Rights Reserved. | 
					
						
							| 
									
										
										
										
											2001-06-06 19:40:57 +00: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 19:40:57 +00: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. |