2007-06-12 11:39:47 +01:00
|
|
|
================================================================
|
|
|
|
Logtalk - Open source object-oriented logic programming language
|
|
|
|
Release 2.30.1
|
2001-06-06 20:40:57 +01:00
|
|
|
|
2007-01-10 12:46:10 +00:00
|
|
|
Copyright (c) 1998-2007 Paulo Moura. All Rights Reserved.
|
2007-06-12 11:39:47 +01:00
|
|
|
================================================================
|
2001-06-06 20:40:57 +01:00
|
|
|
|
|
|
|
|
2007-03-28 23:44:31 +01:00
|
|
|
% start by loading the example and the required library files:
|
2004-11-29 20:36:31 +00:00
|
|
|
|
|
|
|
| ?- logtalk_load(bricks(loader)).
|
2004-06-13 19:04:28 +01:00
|
|
|
...
|
|
|
|
|
2001-06-06 20:40:57 +01:00
|
|
|
|
|
|
|
% create four bricks, all standing on the "ground" (use your imagination... ;-)
|
|
|
|
|
2007-03-28 23:44:31 +01:00
|
|
|
| ?- brick::(new(a, [position-(8, 1)]), new(b, [position-(6, 1)]), new(c, [position-(4, 1)]), new(d, [position-(2, 1)])).
|
2001-06-06 20:40:57 +01:00
|
|
|
yes
|
|
|
|
|
|
|
|
% set up ascii stack monitor so we can watch the bricks moving
|
|
|
|
|
|
|
|
| ?- after_event_registry::set_monitor(_, move(_,_), _, stack_monitor).
|
|
|
|
yes
|
|
|
|
|
|
|
|
|
|
|
|
% make the stack
|
|
|
|
|
2007-03-28 23:44:31 +01:00
|
|
|
| ?- brick_stack::(add_tuple([c,d]), add_tuple([b,c]), add_tuple([a,b])).
|
2001-06-06 20:40:57 +01:00
|
|
|
|.c......
|
|
|
|
|.d...b.a
|
|
|
|
---------
|
|
|
|
|.b......
|
|
|
|
|.c......
|
|
|
|
|.d.....a
|
|
|
|
---------
|
|
|
|
|.a
|
|
|
|
|.b
|
|
|
|
|.c
|
|
|
|
|.d
|
|
|
|
---
|
|
|
|
yes
|
|
|
|
|
|
|
|
|
|
|
|
% check results
|
|
|
|
|
|
|
|
| ?- brick_stack::tuple(Tuple), write(Tuple), nl, fail.
|
|
|
|
[c,d]
|
|
|
|
[b,c]
|
|
|
|
[a,b]
|
|
|
|
no
|
|
|
|
|
|
|
|
| ?- before_event_registry::monitors(Mb), after_event_registry::monitors(Ma).
|
|
|
|
Ma = [brick_stack, stack_monitor]
|
|
|
|
Mb = [brick_stack]
|
|
|
|
yes
|
|
|
|
|
|
|
|
|
|
|
|
% move all stack to new position by moving bottom brick; check results
|
|
|
|
|
|
|
|
| ?- d::move(9, 1).
|
|
|
|
|.a.......
|
|
|
|
|.b.......
|
|
|
|
|.c.......
|
|
|
|
|........d
|
|
|
|
----------
|
|
|
|
|.a.......
|
|
|
|
|.b.......
|
|
|
|
|........c
|
|
|
|
|........d
|
|
|
|
----------
|
|
|
|
|.a.......
|
|
|
|
|........b
|
|
|
|
|........c
|
|
|
|
|........d
|
|
|
|
----------
|
|
|
|
|........a
|
|
|
|
|........b
|
|
|
|
|........c
|
|
|
|
|........d
|
|
|
|
----------
|
|
|
|
yes
|
|
|
|
|
|
|
|
| ?- a::position(Xa, Ya), b::position(Xb, Yb), c::position(Xc, Yc), d::position(Xd, Yd).
|
|
|
|
Xa = 9,
|
|
|
|
Xb = 9,
|
|
|
|
Xc = 9,
|
|
|
|
Xd = 9,
|
|
|
|
Ya = 4,
|
|
|
|
Yb = 3,
|
|
|
|
Yc = 2,
|
|
|
|
Yd = 1
|
|
|
|
yes
|
|
|
|
|
|
|
|
| ?- brick_stack::tuple(Tuple), write(Tuple), nl, fail.
|
|
|
|
[c,d]
|
|
|
|
[b,c]
|
|
|
|
[a,b]
|
|
|
|
no
|
|
|
|
|
|
|
|
|
|
|
|
% break stack in half by moving b to the "ground"; check results
|
|
|
|
|
|
|
|
| ?- b::move(3, 1).
|
|
|
|
|........a
|
|
|
|
|.........
|
|
|
|
|........c
|
|
|
|
|..b.....d
|
|
|
|
----------
|
|
|
|
|..a.....c
|
|
|
|
|..b.....d
|
|
|
|
----------
|
|
|
|
yes
|
|
|
|
|
|
|
|
| ?- a::position(Xa, Ya), b::position(Xb, Yb), c::position(Xc, Yc), d::position(Xd, Yd).
|
|
|
|
Xa = 3,
|
|
|
|
Xb = 3,
|
|
|
|
Xc = 9,
|
|
|
|
Xd = 9,
|
|
|
|
Ya = 2,
|
|
|
|
Yb = 1,
|
|
|
|
Yc = 2,
|
|
|
|
Yd = 1
|
|
|
|
yes
|
|
|
|
|
|
|
|
| ?- brick_stack::tuple(Tuple), write(Tuple), nl, fail.
|
|
|
|
[c,d]
|
|
|
|
[a,b]
|
|
|
|
no
|
|
|
|
|
|
|
|
|
|
|
|
% create new brick_stack tuple ; check results
|
|
|
|
|
|
|
|
| ?- brick_stack::add_tuple([d, a]).
|
|
|
|
|..d......
|
|
|
|
|..a.....c
|
|
|
|
|..b......
|
|
|
|
----------
|
|
|
|
|..c
|
|
|
|
|..d
|
|
|
|
|..a
|
|
|
|
|..b
|
|
|
|
----
|
|
|
|
yes
|
|
|
|
|
|
|
|
| ?- a::position(Xa, Ya), b::position(Xb, Yb), c::position(Xc, Yc), d::position(Xd, Yd).
|
|
|
|
Xa = 3,
|
|
|
|
Xb = 3,
|
|
|
|
Xc = 3,
|
|
|
|
Xd = 3,
|
|
|
|
Ya = 2,
|
|
|
|
Yb = 1,
|
|
|
|
Yc = 4,
|
|
|
|
Yd = 3
|
|
|
|
yes
|
|
|
|
|
|
|
|
| ?- brick_stack::tuple(Tuple), write(Tuple), nl, fail.
|
|
|
|
[c,d]
|
|
|
|
[a,b]
|
|
|
|
[d,a]
|
|
|
|
no
|
|
|
|
|
|
|
|
|
|
|
|
% move all stack to new position by moving bottom brick; check results
|
|
|
|
|
|
|
|
| ?- b::move(5, 1).
|
|
|
|
|..c..
|
|
|
|
|..d..
|
|
|
|
|..a..
|
|
|
|
|....b
|
|
|
|
------
|
|
|
|
|..c..
|
|
|
|
|..d..
|
|
|
|
|....a
|
|
|
|
|....b
|
|
|
|
------
|
|
|
|
|..c..
|
|
|
|
|....d
|
|
|
|
|....a
|
|
|
|
|....b
|
|
|
|
------
|
|
|
|
|....c
|
|
|
|
|....d
|
|
|
|
|....a
|
|
|
|
|....b
|
|
|
|
------
|
|
|
|
yes
|
|
|
|
|
|
|
|
| ?- a::position(Xa, Ya), b::position(Xb, Yb), c::position(Xc, Yc), d::position(Xd, Yd).
|
|
|
|
Xa = 5,
|
|
|
|
Xb = 5,
|
|
|
|
Xc = 5,
|
|
|
|
Xd = 5,
|
|
|
|
Ya = 2,
|
|
|
|
Yb = 1,
|
|
|
|
Yc = 4,
|
|
|
|
Yd = 3
|
|
|
|
yes
|
|
|
|
|
|
|
|
| ?- brick_stack::tuple(Tuple), write(Tuple), nl, fail.
|
|
|
|
[c,d]
|
|
|
|
[a,b]
|
|
|
|
[d,a]
|
|
|
|
no
|
|
|
|
|
|
|
|
|
|
|
|
% clean up instances, tuples and monitors
|
|
|
|
|
|
|
|
| ?- brick_stack::remove_all_tuples.
|
|
|
|
yes
|
|
|
|
|
|
|
|
| ?- after_event_registry::del_monitors(_, _, _, stack_monitor).
|
|
|
|
yes
|
|
|
|
|
|
|
|
| ?- brick::delete_all.
|
|
|
|
yes
|