documentation.
This commit is contained in:
parent
70cb6ed01e
commit
b41986ee3c
@ -95,5 +95,5 @@ endif()
|
|||||||
|
|
||||||
|
|
||||||
install(FILES ${PL_BOOT_SOURCES}
|
install(FILES ${PL_BOOT_SOURCES}
|
||||||
DESTINATION ${libpl}/pll
|
DESTINATION ${libpl}/pl
|
||||||
)
|
)
|
||||||
|
@ -15,6 +15,10 @@
|
|||||||
* *
|
* *
|
||||||
*************************************************************************/
|
*************************************************************************/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @file checker.yap
|
||||||
|
*
|
||||||
|
*/
|
||||||
:- system_module( style_checker, [no_style_check/1,
|
:- system_module( style_checker, [no_style_check/1,
|
||||||
style_check/1], ['$check_term'/5,
|
style_check/1], ['$check_term'/5,
|
||||||
'$sv_warning'/2,
|
'$sv_warning'/2,
|
||||||
@ -24,7 +28,7 @@
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
||||||
@defgroup YAPStyle Checker
|
@defgroup YAPStyleChecker Style Checker
|
||||||
@ingroup YAPCompilerSettings
|
@ingroup YAPCompilerSettings
|
||||||
@{
|
@{
|
||||||
|
|
||||||
@ -167,6 +171,6 @@ separated by clauses from other procedures.
|
|||||||
|
|
||||||
discontiguous(P) :- '$discontiguous'(P).
|
discontiguous(P) :- '$discontiguous'(P).
|
||||||
|
|
||||||
/*
|
/**
|
||||||
@}
|
@}
|
||||||
*/
|
*/
|
||||||
|
@ -101,6 +101,10 @@ files and to set-up the Prolog environment. We discuss
|
|||||||
|
|
||||||
+ @ref YAPCompilerSettings
|
+ @ref YAPCompilerSettings
|
||||||
|
|
||||||
|
@}
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
@defgroup YAPReadFiles The Predicates that Read Source Files
|
@defgroup YAPReadFiles The Predicates that Read Source Files
|
||||||
@ingroup YAPConsulting
|
@ingroup YAPConsulting
|
||||||
|
|
||||||
@ -1678,6 +1682,10 @@ End of conditional compilation.
|
|||||||
current_prolog_flag(source, true), !.
|
current_prolog_flag(source, true), !.
|
||||||
'$fetch_comp_status'(compact).
|
'$fetch_comp_status'(compact).
|
||||||
|
|
||||||
|
/** consult_depth(-int:_LV_)
|
||||||
|
*
|
||||||
|
* Unify _LV_ with the number of files being consulted.
|
||||||
|
*/
|
||||||
consult_depth(LV) :- '$show_consult_level'(LV).
|
consult_depth(LV) :- '$show_consult_level'(LV).
|
||||||
|
|
||||||
prolog_library(File) :-
|
prolog_library(File) :-
|
||||||
|
@ -41,7 +41,7 @@
|
|||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @ingroup AttributedVariables_Builtins
|
* @addtogroup AttributedVariables_Builtins
|
||||||
* @{
|
* @{
|
||||||
*
|
*
|
||||||
*
|
*
|
||||||
@ -141,42 +141,6 @@ freeze_goal(V,G) :-
|
|||||||
'$current_module'(M),
|
'$current_module'(M),
|
||||||
internal_freeze(V, redo_freeze(_Done,V,M:G)).
|
internal_freeze(V, redo_freeze(_Done,V,M:G)).
|
||||||
|
|
||||||
%
|
|
||||||
%
|
|
||||||
% Dif is tricky because we need to wake up on the two variables being
|
|
||||||
% bound together, or on any variable of the term being bound to
|
|
||||||
% another. Also, the day YAP fully supports infinite rational trees,
|
|
||||||
% dif should work for them too. Hence, term comparison should not be
|
|
||||||
% implemented in Prolog.
|
|
||||||
%
|
|
||||||
% This is the way dif works. The '$can_unify' predicate does not know
|
|
||||||
% anything about dif semantics, it just compares two terms for
|
|
||||||
% equaility and is based on compare. If it succeeds without generating
|
|
||||||
% a list of variables, the terms are equal and dif fails. If it fails,
|
|
||||||
% dif succeeds.
|
|
||||||
%
|
|
||||||
% If it succeeds but it creates a list of variables, dif creates
|
|
||||||
% suspension records for all these variables on the '$redo_dif'(V,
|
|
||||||
% X, Y) goal. V is a flag that says whether dif has completed or not,
|
|
||||||
% X and Y are the original goals. Whenever one of these variables is
|
|
||||||
% bound, it calls '$redo_dif' again. '$redo_dif' will then check whether V
|
|
||||||
% was bound. If it was, dif has succeeded and redo_dif just
|
|
||||||
% exits. Otherwise, '$redo_dif' will call dif again to see what happened.
|
|
||||||
%
|
|
||||||
% Dif needs two extensions from the suspension engine:
|
|
||||||
%
|
|
||||||
% First, it needs
|
|
||||||
% for the engine to be careful when binding two suspended
|
|
||||||
% variables. Basically, in this case the engine must be sure to wake
|
|
||||||
% up one of the goals, as they may make dif fail. The way the engine
|
|
||||||
% does so is by searching the list of suspended variables, and search
|
|
||||||
% whether they share a common suspended goal. If they do, that
|
|
||||||
% suspended goal is added to the WokenList.
|
|
||||||
%
|
|
||||||
% Second, thanks to dif we may try to suspend on the same variable
|
|
||||||
% several times. dif calls a special version of freeze that checks
|
|
||||||
% whether that is in fact the case.
|
|
||||||
%
|
|
||||||
/** @pred dif( _X_, _Y_)
|
/** @pred dif( _X_, _Y_)
|
||||||
|
|
||||||
|
|
||||||
@ -185,6 +149,42 @@ suspend if unification may still succeed or fail, and will fail if they
|
|||||||
always unify.
|
always unify.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Dif is tricky because we need to wake up on the two variables being
|
||||||
|
bound together, or on any variable of the term being bound to
|
||||||
|
another. Also, the day YAP fully supports infinite rational trees,
|
||||||
|
dif should work for them too. Hence, term comparison should not be
|
||||||
|
implemented in Prolog.
|
||||||
|
|
||||||
|
This is the way dif works. The '$can_unify' predicate does not know
|
||||||
|
anything about dif semantics, it just compares two terms for
|
||||||
|
equaility and is based on compare. If it succeeds without generating
|
||||||
|
a list of variables, the terms are equal and dif fails. If it fails,
|
||||||
|
dif succeeds.
|
||||||
|
|
||||||
|
If it succeeds but it creates a list of variables, dif creates
|
||||||
|
suspension records for all these variables on the '$redo_dif'(V,
|
||||||
|
X, Y) goal. V is a flag that says whether dif has completed or not,
|
||||||
|
X and Y are the original goals. Whenever one of these variables is
|
||||||
|
bound, it calls '$redo_dif' again. '$redo_dif' will then check whether V
|
||||||
|
was bound. If it was, dif has succeeded and redo_dif just
|
||||||
|
exits. Otherwise, '$redo_dif' will call dif again to see what happened.
|
||||||
|
|
||||||
|
Dif needs two extensions from the suspension engine:
|
||||||
|
|
||||||
|
First, it needs
|
||||||
|
for the engine to be careful when binding two suspended
|
||||||
|
variables. Basically, in this case the engine must be sure to wake
|
||||||
|
up one of the goals, as they may make dif fail. The way the engine
|
||||||
|
does so is by searching the list of suspended variables, and search
|
||||||
|
whether they share a common suspended goal. If they do, that
|
||||||
|
suspended goal is added to the WokenList.
|
||||||
|
|
||||||
|
Second, thanks to dif we may try to suspend on the same variable
|
||||||
|
several times. dif calls a special version of freeze that checks
|
||||||
|
whether that is in fact the case.
|
||||||
|
|
||||||
|
|
||||||
*/
|
*/
|
||||||
prolog:dif(X, Y) :-
|
prolog:dif(X, Y) :-
|
||||||
'$can_unify'(X, Y, LVars), !,
|
'$can_unify'(X, Y, LVars), !,
|
||||||
@ -198,6 +198,7 @@ dif_suspend_on_lvars([H|T], G) :-
|
|||||||
internal_freeze(H, G),
|
internal_freeze(H, G),
|
||||||
dif_suspend_on_lvars(T, G).
|
dif_suspend_on_lvars(T, G).
|
||||||
|
|
||||||
|
%% @pred redo_dif(_Done_, _X_, _Y_)
|
||||||
%
|
%
|
||||||
% This predicate is called whenever a variable dif was suspended on is
|
% This predicate is called whenever a variable dif was suspended on is
|
||||||
% bound. Note that dif may have already executed successfully.
|
% bound. Note that dif may have already executed successfully.
|
||||||
@ -263,7 +264,7 @@ redo_ground('$done', _, Goal) :-
|
|||||||
%
|
%
|
||||||
% support for when/2 built-in
|
% support for when/2 built-in
|
||||||
%
|
%
|
||||||
/** @pred when(+ _C_,: _G_)
|
/** @pred when(+ _C_, 0:_G_)
|
||||||
|
|
||||||
|
|
||||||
Delay execution of goal _G_ until the conditions _C_ are
|
Delay execution of goal _G_ until the conditions _C_ are
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
||||||
@ingroup ModuleBuiltins
|
@addtogroup ModuleBuiltins
|
||||||
@{
|
@{
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -4,11 +4,10 @@
|
|||||||
/** @file preddyns.yap */
|
/** @file preddyns.yap */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @addtogroup Database
|
* @addtogroup Internal_Database
|
||||||
* @{
|
|
||||||
*
|
|
||||||
* @brief main operations on dynamic predicates.
|
* @brief main operations on dynamic predicates.
|
||||||
|
*
|
||||||
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/** @pred asserta(+ _C_) is iso
|
/** @pred asserta(+ _C_) is iso
|
||||||
|
@ -446,7 +446,7 @@ hide_predicate(P0) :-
|
|||||||
nonvar(P),
|
nonvar(P),
|
||||||
P = N/A,
|
P = N/A,
|
||||||
!,
|
!,
|
||||||
functor(S,N,A).
|
functor(_S,N,A).
|
||||||
hide_predicate(P0) :-
|
hide_predicate(P0) :-
|
||||||
strip_module(P0, M, P),
|
strip_module(P0, M, P),
|
||||||
'$hide_predicate'(P, M).
|
'$hide_predicate'(P, M).
|
||||||
|
@ -362,7 +362,7 @@ available it tries reconsulting the source file.
|
|||||||
qload_module(Mod) :-
|
qload_module(Mod) :-
|
||||||
prolog_flag(verbose_load, OldF, false),
|
prolog_flag(verbose_load, OldF, false),
|
||||||
prolog_flag(verbose, OldV, silent),
|
prolog_flag(verbose, OldV, silent),
|
||||||
Verbosity = silent
|
Verbosity = silent,
|
||||||
StartMsg = loading_module,
|
StartMsg = loading_module,
|
||||||
EndMsg = module_loaded,
|
EndMsg = module_loaded,
|
||||||
'$current_module'(SourceModule, Mod),
|
'$current_module'(SourceModule, Mod),
|
||||||
|
29
pl/setof.yap
29
pl/setof.yap
@ -34,20 +34,21 @@
|
|||||||
setof/3], []).
|
setof/3], []).
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
*
|
||||||
@defgroup Sets Collecting Solutions to a Goal
|
* @defgroup Sets Collecting Solutions to a Goal
|
||||||
@ingroup builtins
|
* @ingroup builtins
|
||||||
@{
|
* @{
|
||||||
|
*
|
||||||
When there are several solutions to a goal, if the user wants to collect all
|
*
|
||||||
the solutions he may be led to use the data base, because backtracking will
|
* When there are several solutions to a goal, if the user wants to collect all
|
||||||
forget previous solutions.
|
* the solutions he may be led to use the data base, because backtracking will
|
||||||
|
* forget previous solutions.
|
||||||
YAP allows the programmer to choose from several system
|
*
|
||||||
predicates instead of writing his own routines. findall/3 gives you
|
* YAP allows the programmer to choose from several system
|
||||||
the fastest, but crudest solution. The other built-in predicates
|
* predicates instead of writing his own routines. findall/3 gives you
|
||||||
post-process the result of the query in several different ways:
|
* the fastest, but crudest solution. The other built-in predicates
|
||||||
|
* post-process the result of the query in several different ways:
|
||||||
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
:- use_system_module( '$_boot', ['$catch'/3]).
|
:- use_system_module( '$_boot', ['$catch'/3]).
|
||||||
|
@ -7,8 +7,11 @@
|
|||||||
*
|
*
|
||||||
* @addtogroup TopLevel Top-Level and Boot Predicates
|
* @addtogroup TopLevel Top-Level and Boot Predicates
|
||||||
* @ingroup YAPControl
|
* @ingroup YAPControl
|
||||||
|
*
|
||||||
|
* [TOC]
|
||||||
|
*
|
||||||
* @{
|
* @{
|
||||||
*/
|
* \*/
|
||||||
|
|
||||||
:- '$system_meta_predicates'([
|
:- '$system_meta_predicates'([
|
||||||
catch(0,?,0),
|
catch(0,?,0),
|
||||||
|
Reference in New Issue
Block a user