2007-06-12 11:39:47 +01:00
|
|
|
================================================================
|
|
|
|
Logtalk - Open source object-oriented logic programming language
|
2007-11-06 01:50:09 +00:00
|
|
|
Release 2.30.7
|
2006-11-07 18:47:24 +00: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
|
|
|
================================================================
|
2006-11-07 18:47:24 +00:00
|
|
|
|
|
|
|
|
|
|
|
% start by loading the loading the example:
|
|
|
|
|
|
|
|
| ?- logtalk_load(nondet(loader)).
|
|
|
|
...
|
|
|
|
|
|
|
|
|
|
|
|
% make a threaded call with a non-deterministic goal:
|
|
|
|
|
|
|
|
| ?- threaded_call(lists::member(X, [1,2,3])).
|
|
|
|
|
|
|
|
X = _G189
|
|
|
|
yes
|
|
|
|
|
|
|
|
% retrieve through backtracking all solutions for the non-deterministic goal:
|
|
|
|
|
|
|
|
| ?- threaded_exit(lists::member(X, [1,2,3])).
|
|
|
|
|
|
|
|
X = 1 ;
|
|
|
|
X = 2 ;
|
|
|
|
X = 3 ;
|
|
|
|
no
|
2006-12-28 13:03:34 +00:00
|
|
|
|
|
|
|
|
|
|
|
% make a threaded call by commiting to the first solution found:
|
|
|
|
|
|
|
|
| ?- threaded_once(lists::member(X, [1,2,3])).
|
|
|
|
|
|
|
|
X = _G189
|
|
|
|
yes
|
|
|
|
|
|
|
|
% retrieve through backtracking the goal solution:
|
|
|
|
|
|
|
|
| ?- threaded_exit(lists::member(X, [1,2,3])).
|
|
|
|
|
|
|
|
X = 1 ;
|
|
|
|
no
|
2007-11-06 01:50:09 +00:00
|
|
|
|
|
|
|
|
|
|
|
% when two or more variant calls are made...
|
|
|
|
|
|
|
|
| ?- threaded_call(lists::member(X, [1,2,3])), threaded_call(lists::member(Y, [1,2,3])).
|
|
|
|
|
|
|
|
X = _G189 Y =_G190
|
|
|
|
yes
|
|
|
|
|
|
|
|
% ...the first threaded_exit/1 call will pick one of them:
|
|
|
|
|
|
|
|
| ?- threaded_exit(lists::member(X, [1,2,3])).
|
|
|
|
|
|
|
|
X = 1 ;
|
|
|
|
X = 2 ;
|
|
|
|
X = 3 ;
|
|
|
|
no
|
|
|
|
|
|
|
|
% ...and a second threaded_exit/1 call will pick the remaining one:
|
|
|
|
|
|
|
|
| ?- threaded_exit(lists::member(X, [1,2,3])).
|
|
|
|
|
|
|
|
X = 1 ;
|
|
|
|
X = 2 ;
|
|
|
|
X = 3 ;
|
|
|
|
no
|
|
|
|
|
|
|
|
|
|
|
|
% tags may be used to distinguish between threaded calls if needed:
|
|
|
|
|
|
|
|
| ?- threaded_call(lists::member(X, [1,2,3]), Tag).
|
|
|
|
|
|
|
|
Tag = 1
|
|
|
|
yes
|
|
|
|
|
|
|
|
| ?- threaded_call(lists::member(X, [1,2,3]), Tag).
|
|
|
|
|
|
|
|
Tag = 2
|
|
|
|
yes
|
|
|
|
|
|
|
|
| ?- threaded_exit(lists::member(X, [1,2,3]), 2).
|
|
|
|
|
|
|
|
X = 1 ;
|
|
|
|
X = 2 ;
|
|
|
|
X = 3 ;
|
|
|
|
no
|
|
|
|
|
|
|
|
|
|
|
|
% use a subsumed goal instead of a variant of the original goal:
|
|
|
|
|
|
|
|
| ?- threaded_call(lists::member(X, [1,2,3,2])).
|
|
|
|
|
|
|
|
X = _G189
|
|
|
|
yes
|
|
|
|
|
|
|
|
| ?- threaded_exit(lists::member(2, [1,2,3,2])).
|
|
|
|
|
|
|
|
More ;
|
|
|
|
More ;
|
|
|
|
no
|