improve SWI

This commit is contained in:
Vítor Santos Costa 2014-02-02 21:46:33 +00:00
parent 9d2795b62a
commit ae0ab6fa86
4 changed files with 24 additions and 11 deletions

View File

@ -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);

View File

@ -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