improve SWI
This commit is contained in:
parent
9d2795b62a
commit
ae0ab6fa86
@ -539,6 +539,7 @@ extern X_API int PL_is_ground(term_t);
|
|||||||
extern X_API int PL_is_callable(term_t);
|
extern X_API int PL_is_callable(term_t);
|
||||||
extern X_API int PL_is_integer(term_t);
|
extern X_API int PL_is_integer(term_t);
|
||||||
extern X_API int PL_is_list(term_t);
|
extern X_API int PL_is_list(term_t);
|
||||||
|
extern X_API int PL_is_pair(term_t);
|
||||||
extern X_API int PL_is_number(term_t);
|
extern X_API int PL_is_number(term_t);
|
||||||
extern X_API int PL_is_string(term_t);
|
extern X_API int PL_is_string(term_t);
|
||||||
extern X_API int PL_is_variable(term_t);
|
extern X_API int PL_is_variable(term_t);
|
||||||
|
@ -193,19 +193,21 @@ X_API int PL_get_arg(int index, term_t ts, term_t a)
|
|||||||
{
|
{
|
||||||
CACHE_REGS
|
CACHE_REGS
|
||||||
YAP_Term t = Yap_GetFromSlot(ts PASS_REGS);
|
YAP_Term t = Yap_GetFromSlot(ts PASS_REGS);
|
||||||
if ( !YAP_IsApplTerm(t) ) {
|
if (IsVarTerm( t ))
|
||||||
if (YAP_IsPairTerm(t)) {
|
return 0;
|
||||||
|
if ( !IsApplTerm(t) ) {
|
||||||
|
if (IsPairTerm(t)) {
|
||||||
if (index == 1){
|
if (index == 1){
|
||||||
Yap_PutInSlot(a,YAP_HeadOfTerm(t) PASS_REGS);
|
Yap_PutInSlot(a,HeadOfTerm(t) PASS_REGS);
|
||||||
return 1;
|
return 1;
|
||||||
} else if (index == 2) {
|
} else if (index == 2) {
|
||||||
Yap_PutInSlot(a,YAP_TailOfTerm(t) PASS_REGS);
|
Yap_PutInSlot(a,TailOfTerm(t) PASS_REGS);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
Yap_PutInSlot(a,YAP_ArgOfTerm(index, t) PASS_REGS);
|
Yap_PutInSlot(a,ArgOfTerm(index, t) PASS_REGS);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -770,10 +772,11 @@ X_API int PL_cons_functor_v(term_t d, functor_t f, term_t a0)
|
|||||||
tmp = RepAppl(t)+1;
|
tmp = RepAppl(t)+1;
|
||||||
}
|
}
|
||||||
for (i = 0; i < arity; i++) {
|
for (i = 0; i < arity; i++) {
|
||||||
Yap_unify(tmp[i],Yap_GetFromSlot(a0 PASS_REGS));
|
tmp[i] = Yap_GetFromSlot(a0 PASS_REGS);
|
||||||
a0++;
|
a0++;
|
||||||
}
|
}
|
||||||
Yap_PutInSlot(d,t PASS_REGS);
|
Yap_PutInSlot(d,t PASS_REGS);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1593,13 +1596,15 @@ X_API int PL_term_type(term_t t)
|
|||||||
CACHE_REGS
|
CACHE_REGS
|
||||||
/* YAP_ does not support strings as different objects */
|
/* YAP_ does not support strings as different objects */
|
||||||
YAP_Term v = Yap_GetFromSlot(t PASS_REGS);
|
YAP_Term v = Yap_GetFromSlot(t PASS_REGS);
|
||||||
if (YAP_IsVarTerm(v)) {
|
if (IsVarTerm(v)) {
|
||||||
return PL_VARIABLE;
|
return PL_VARIABLE;
|
||||||
} else if (IsAtomTerm(v)) {
|
} else if (IsAtomTerm(v)) {
|
||||||
return PL_ATOM;
|
return PL_ATOM;
|
||||||
} else if (YAP_IsIntTerm(v)) {
|
} else if (IsIntegerTerm(v)) {
|
||||||
return PL_INTEGER;
|
return PL_INTEGER;
|
||||||
} else if (YAP_IsFloatTerm(v)) {
|
} else if (IsStringTerm(v)) {
|
||||||
|
return PL_STRING;
|
||||||
|
} else if (IsFloatTerm(v)) {
|
||||||
return PL_FLOAT;
|
return PL_FLOAT;
|
||||||
} else {
|
} else {
|
||||||
return PL_TERM;
|
return PL_TERM;
|
||||||
@ -1696,6 +1701,13 @@ X_API int PL_is_list(term_t ts)
|
|||||||
return !IsVarTerm(t) && (t == TermNil || IsPairTerm(t));
|
return !IsVarTerm(t) && (t == TermNil || IsPairTerm(t));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
X_API int PL_is_pair(term_t ts)
|
||||||
|
{
|
||||||
|
CACHE_REGS
|
||||||
|
YAP_Term t = Yap_GetFromSlot(ts PASS_REGS);
|
||||||
|
return !IsVarTerm(t) && IsPairTerm(t);
|
||||||
|
}
|
||||||
|
|
||||||
X_API int
|
X_API int
|
||||||
PL_skip_list(term_t list, term_t tail, size_t *len)
|
PL_skip_list(term_t list, term_t tail, size_t *len)
|
||||||
{
|
{
|
||||||
|
@ -1 +1 @@
|
|||||||
Subproject commit e111442b428bcaac015d9545e42faf97df6b30f4
|
Subproject commit f96cfb7533c57789fa25db64b73c09aa7269d244
|
@ -1 +1 @@
|
|||||||
Subproject commit 626133d5b507de73398f2285be7fe8f3d817a16c
|
Subproject commit 9c65bc41956b387fb41a7a91f67c65611c5c9466
|
Reference in New Issue
Block a user