list_or_partial_list support.
This commit is contained in:
parent
9a57a51f40
commit
020323d633
@ -4234,10 +4234,19 @@ p_is_list( USES_REGS1 )
|
|||||||
return Yap_IsListTerm(Deref(ARG1));
|
return Yap_IsListTerm(Deref(ARG1));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
Yap_IsListOrPartialListTerm(Term t)
|
||||||
|
{
|
||||||
|
Term *tailp, tail;
|
||||||
|
Yap_SkipList(&t, &tailp);
|
||||||
|
tail = *tailp;
|
||||||
|
return tail == TermNil || IsVarTerm(tail);
|
||||||
|
}
|
||||||
|
|
||||||
static Int
|
static Int
|
||||||
p_is_list_or_partial_list( USES_REGS1 )
|
p_is_list_or_partial_list( USES_REGS1 )
|
||||||
{
|
{
|
||||||
return Yap_IsListTerm(Deref(ARG1));
|
return Yap_IsListOrPartialListTerm(Deref(ARG1));
|
||||||
}
|
}
|
||||||
|
|
||||||
static Term
|
static Term
|
||||||
@ -4816,8 +4825,8 @@ void Yap_InitUtilCPreds(void)
|
|||||||
Yap_InitCPred("term_variables", 2, p_term_variables, 0);
|
Yap_InitCPred("term_variables", 2, p_term_variables, 0);
|
||||||
Yap_InitCPred("term_variables", 3, p_term_variables3, 0);
|
Yap_InitCPred("term_variables", 3, p_term_variables3, 0);
|
||||||
Yap_InitCPred("term_attvars", 2, p_term_attvars, 0);
|
Yap_InitCPred("term_attvars", 2, p_term_attvars, 0);
|
||||||
Yap_InitCPred("is_list", 1, p_is_list, SafePredFlag);
|
Yap_InitCPred("is_list", 1, p_is_list, SafePredFlag|TestPredFlag);
|
||||||
Yap_InitCPred("$is_list_or_partial_list", 1, p_is_list_or_partial_list, SafePredFlag);
|
Yap_InitCPred("$is_list_or_partial_list", 1, p_is_list_or_partial_list, SafePredFlag|TestPredFlag);
|
||||||
Yap_InitCPred("rational_term_to_tree", 2, p_break_rational, 0);
|
Yap_InitCPred("rational_term_to_tree", 2, p_break_rational, 0);
|
||||||
Yap_InitCPred("tree_to_rational_term", 2, p_restore_rational, 0);
|
Yap_InitCPred("tree_to_rational_term", 2, p_restore_rational, 0);
|
||||||
Yap_InitCPred("=@=", 2, p_variant, 0);
|
Yap_InitCPred("=@=", 2, p_variant, 0);
|
||||||
|
@ -395,6 +395,7 @@ size_t STD_PROTO(Yap_ExportTerm,(Term, char *, size_t, UInt));
|
|||||||
size_t STD_PROTO(Yap_SizeOfExportedTerm,(char *));
|
size_t STD_PROTO(Yap_SizeOfExportedTerm,(char *));
|
||||||
Term STD_PROTO(Yap_ImportTerm,(char *));
|
Term STD_PROTO(Yap_ImportTerm,(char *));
|
||||||
int STD_PROTO(Yap_IsListTerm,(Term));
|
int STD_PROTO(Yap_IsListTerm,(Term));
|
||||||
|
int STD_PROTO(Yap_IsListOrPartialListTerm,(Term));
|
||||||
Term STD_PROTO(Yap_CopyTermNoShare,(Term));
|
Term STD_PROTO(Yap_CopyTermNoShare,(Term));
|
||||||
int STD_PROTO(Yap_SizeGroundTerm,(Term, int));
|
int STD_PROTO(Yap_SizeGroundTerm,(Term, int));
|
||||||
int STD_PROTO(Yap_IsGroundTerm,(Term));
|
int STD_PROTO(Yap_IsGroundTerm,(Term));
|
||||||
|
11
pl/setof.yap
11
pl/setof.yap
@ -32,7 +32,7 @@ _^Goal :-
|
|||||||
|
|
||||||
|
|
||||||
findall(Template, Generator, Answers) :-
|
findall(Template, Generator, Answers) :-
|
||||||
( '$partial_list_or_list'(Answers) ->
|
( '$is_list_or_partial_list'(Answers) ->
|
||||||
true
|
true
|
||||||
;
|
;
|
||||||
'$do_error'(type_error(list,Answers), findall(Template, Generator, Answers))
|
'$do_error'(type_error(list,Answers), findall(Template, Generator, Answers))
|
||||||
@ -80,7 +80,7 @@ findall(Template, Generator, Answers, SoFar) :-
|
|||||||
% This is the setof predicate
|
% This is the setof predicate
|
||||||
|
|
||||||
setof(Template, Generator, Set) :-
|
setof(Template, Generator, Set) :-
|
||||||
( '$partial_list_or_list'(Set) ->
|
( '$is_list_or_partial_list'(Set) ->
|
||||||
true
|
true
|
||||||
;
|
;
|
||||||
'$do_error'(type_error(list,Set), setof(Template, Generator, Set))
|
'$do_error'(type_error(list,Set), setof(Template, Generator, Set))
|
||||||
@ -95,7 +95,7 @@ setof(Template, Generator, Set) :-
|
|||||||
% of these variables
|
% of these variables
|
||||||
|
|
||||||
bagof(Template, Generator, Bag) :-
|
bagof(Template, Generator, Bag) :-
|
||||||
( '$partial_list_or_list'(Bag) ->
|
( '$is_list_or_partial_list'(Bag) ->
|
||||||
true
|
true
|
||||||
;
|
;
|
||||||
'$do_error'(type_error(list,Bag), bagof(Template, Generator, Bag))
|
'$do_error'(type_error(list,Bag), bagof(Template, Generator, Bag))
|
||||||
@ -235,8 +235,3 @@ all(T,G,S) :-
|
|||||||
'$$split'([T1|Tn],T,X,S1,[T1|S2]) :- '$$split'(Tn,T,X,S1,S2).
|
'$$split'([T1|Tn],T,X,S1,[T1|S2]) :- '$$split'(Tn,T,X,S1,S2).
|
||||||
|
|
||||||
|
|
||||||
'$partial_list_or_list'(V) :- var(V), !.
|
|
||||||
'$partial_list_or_list'([]) :- !.
|
|
||||||
'$partial_list_or_list'([_|B]) :- !,
|
|
||||||
'$partial_list_or_list'(B).
|
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user