add support for creating a list of codes or atoms incrementally.

This commit is contained in:
Vítor Santos Costa 2008-12-22 13:49:44 +00:00
parent 7598b56c38
commit 8efcdf7eaa
8 changed files with 133 additions and 98 deletions

View File

@ -501,6 +501,9 @@ X_API int STD_PROTO(YAP_AtomGetHold,(Atom));
X_API int STD_PROTO(YAP_AtomReleaseHold,(Atom)); X_API int STD_PROTO(YAP_AtomReleaseHold,(Atom));
X_API Agc_hook STD_PROTO(YAP_AGCRegisterHook,(Agc_hook)); X_API Agc_hook STD_PROTO(YAP_AGCRegisterHook,(Agc_hook));
X_API char *STD_PROTO(YAP_cwd,(void)); X_API char *STD_PROTO(YAP_cwd,(void));
X_API Term STD_PROTO(YAP_OpenList,(int));
X_API Term STD_PROTO(YAP_ExtendList,(Term, Term));
X_API int STD_PROTO(YAP_CloseList,(Term, Term));
static int (*do_getf)(void); static int (*do_getf)(void);
@ -2433,3 +2436,45 @@ YAP_cwd(void)
strncpy(buf, Yap_FileNameBuf, len); strncpy(buf, Yap_FileNameBuf, len);
return buf; return buf;
} }
X_API Term
YAP_OpenList(int n)
{
Term t;
BACKUP_H();
if (H+2*n < ASP-1024) {
if (!dogc())
return FALSE;
}
t = AbsPair(H);
H += 2*n;
RECOVER_H();
return t;
}
X_API Term
YAP_ExtendList(Term t0, Term inp)
{
Term t;
CELL *ptr = RepPair(t0);
ptr[0] = inp;
ptr[1] = AbsPair(ptr+2);
t = AbsPair(ptr+2);
RECOVER_H();
return t;
}
X_API int
YAP_CloseList(Term t0, Term tail)
{
CELL *ptr = RepPair(t0);
RESET_VARIABLE(ptr-1);
if (!Yap_unify((Term)(ptr-1), tail))
return FALSE;
return TRUE;
}

View File

@ -218,23 +218,6 @@ mkfunction(iswupper)
mkfunction(iswpunct) mkfunction(iswpunct)
mkfunction(iswspace) mkfunction(iswspace)
#ifdef __SWI_PROLOG__
#define INIT_DEF(Type, Name, Size) \
static void init_ ## Name (void) {} \
static const Type Name[] {
#define ADD_DEF2(Atom, Type) \
{ Atom, Type },
#define ADD_DEF5(Atom, Type, Reverse, Arity, Ctx) \
{ Atom, Type, Reverse, Arity, Ctx },
\
#define END_DEFS(Atom, F) \
{ Atom, F }
}
#endif
INIT_DEF(char_type, char_types, 26) INIT_DEF(char_type, char_types, 26)
ADD_DEF2(ATOM_alnum, fiswalnum) ADD_DEF2(ATOM_alnum, fiswalnum)
ADD_DEF2(ATOM_csym, fiscsym ) ADD_DEF2(ATOM_csym, fiscsym )

View File

@ -1,6 +1,9 @@
#include "config.h" #include "config.h"
#include <SWI-Prolog.h> #include <SWI-Prolog.h>
/* atom_t macro layer */
#define NULL_ATOM ((atom_t)0)
#include "atoms.h"
#if HAVE_STRING_H #if HAVE_STRING_H
#include <string.h> #include <string.h>
#endif #endif
@ -262,11 +265,6 @@ PL_local_data_t lds;
#define TRY(goal) if ((goal) == FALSE) fail #define TRY(goal) if ((goal) == FALSE) fail
/* atom_t macro layer */
#define NULL_ATOM ((atom_t)0)
#include "atoms.h"
atom_t source_file_name; /** source name of the current file that we are atom_t source_file_name; /** source name of the current file that we are
consulting */ consulting */
int source_line_no; /** guess.... */ int source_line_no; /** guess.... */
@ -489,7 +487,6 @@ extern int writeAtomToStream(IOSTREAM *so, atom_t at);
extern int valueExpression(term_t t, Number r ARG_LD); extern int valueExpression(term_t t, Number r ARG_LD);
extern word lookupAtom(const char *s, size_t len); extern word lookupAtom(const char *s, size_t len);
extern atom_t lookupUCSAtom(const pl_wchar_t *s, size_t len); extern atom_t lookupUCSAtom(const pl_wchar_t *s, size_t len);
extern atom_t codeToAtom(int chrcode);
extern int toIntegerNumber(Number n, int flags); extern int toIntegerNumber(Number n, int flags);
extern int get_atom_ptr_text(Atom a, PL_chars_t *text); extern int get_atom_ptr_text(Atom a, PL_chars_t *text);

View File

@ -417,7 +417,7 @@ setOSFeatures(void)
/******************************* /*******************************
* MEMORY * * MEMORY *
*******************************/ *******************************/
#if SWI_PROLOG #if __SWI_PROLOG__
uintptr_t uintptr_t
UsedMemory(void) UsedMemory(void)
{ {

View File

@ -34,7 +34,7 @@
#undef LD #undef LD
#define LD LOCAL_LD #define LD LOCAL_LD
#ifdef SWI_PROLOG #ifdef __SWI_PROLOG__
static inline word static inline word
valHandle__LD(term_t r ARG_LD) valHandle__LD(term_t r ARG_LD)
{ Word p = valTermRef(r); { Word p = valTermRef(r);
@ -254,7 +254,7 @@ textToAtom(PL_chars_t *text)
} }
#if SWI_PROLOG #if __SWI_PROLOG__
word word
textToString(PL_chars_t *text) textToString(PL_chars_t *text)
{ PL_canonise_text(text); { PL_canonise_text(text);
@ -279,7 +279,7 @@ PL_unify_text(term_t term, term_t tail, PL_chars_t *text, int type)
return rval; return rval;
} }
case PL_STRING: case PL_STRING:
#if SWI_PROLOG #if __SWI_PROLOG__
{ word w = textToString(text); { word w = textToString(text);
return _PL_unify_atomic(term, w); return _PL_unify_atomic(term, w);
@ -297,7 +297,6 @@ PL_unify_text(term_t term, term_t tail, PL_chars_t *text, int type)
} }
} else } else
{ GET_LD { GET_LD
term_t l = PL_new_term_ref();
word p0, p; word p0, p;
switch(text->encoding) switch(text->encoding)
@ -305,36 +304,28 @@ PL_unify_text(term_t term, term_t tail, PL_chars_t *text, int type)
{ const unsigned char *s = (const unsigned char *)text->text.t; { const unsigned char *s = (const unsigned char *)text->text.t;
const unsigned char *e = &s[text->length]; const unsigned char *e = &s[text->length];
#if SWI_PROLOG p0 = p = INIT_SEQ_CODES(text->length);
p0 = p = allocGlobal(text->length*3); if ( type == PL_CODE_LIST ) {
for( ; s < e; s++) for( ; s < e; s++)
{ *p++ = FUNCTOR_dot2; p = EXTEND_SEQ_CODES(p, *s);
if ( type == PL_CODE_LIST ) } else {
*p++ = consInt(*s); for( ; s < e; s++)
else p = EXTEND_SEQ_ATOMS(p, *s);
*p++ = codeToAtom(*s);
*p = consPtr(p+1, TAG_COMPOUND|STG_GLOBAL);
p++;
} }
#endif
break; break;
} }
case ENC_WCHAR: case ENC_WCHAR:
{ const pl_wchar_t *s = (const pl_wchar_t *)text->text.t; { const pl_wchar_t *s = (const pl_wchar_t *)text->text.t;
const pl_wchar_t *e = &s[text->length]; const pl_wchar_t *e = &s[text->length];
#if SWI_PROLOG p0 = p = INIT_SEQ_CODES(text->length);
p0 = p = allocGlobal(text->length*3); if ( type == PL_CODE_LIST ) {
for( ; s < e; s++) for( ; s < e; s++)
{ *p++ = FUNCTOR_dot2; p = EXTEND_SEQ_CODES(p, *s);
if ( type == PL_CODE_LIST ) } else {
*p++ = consInt(*s); for( ; s < e; s++)
else p = EXTEND_SEQ_ATOMS(p, *s);
*p++ = codeToAtom(*s);
*p = consPtr(p+1, TAG_COMPOUND|STG_GLOBAL);
p++;
} }
#endif
break; break;
} }
case ENC_UTF8: case ENC_UTF8:
@ -342,21 +333,22 @@ PL_unify_text(term_t term, term_t tail, PL_chars_t *text, int type)
const char *e = &s[text->length]; const char *e = &s[text->length];
size_t len = utf8_strlen(s, text->length); size_t len = utf8_strlen(s, text->length);
#if SWI_PROLOG p0 = p = INIT_SEQ_CODES(len);
p0 = p = allocGlobal(len*3); if ( type == PL_CODE_LIST ) {
while(s<e) while (s < e) {
{ int chr; int chr;
s = utf8_get_char(s, &chr); s = utf8_get_char(s, &chr);
*p++ = FUNCTOR_dot2; p = EXTEND_SEQ_CODES(p, chr);
if ( type == PL_CODE_LIST ) }
*p++ = consInt(chr); } else {
else while (s < e) {
*p++ = codeToAtom(chr); int chr;
*p = consPtr(p+1, TAG_COMPOUND|STG_GLOBAL);
p++; s = utf8_get_char(s, &chr);
p = EXTEND_SEQ_ATOMS(p, chr);
}
} }
#endif
break; break;
} }
case ENC_ANSI: case ENC_ANSI:
@ -372,27 +364,21 @@ PL_unify_text(term_t term, term_t tail, PL_chars_t *text, int type)
n -= rc; n -= rc;
s += rc; s += rc;
} }
p0 = p = INIT_SEQ_CODES(len);
#if SWI_PROLOG
p0 = p = allocGlobal(len*3);
memset(&mbs, 0, sizeof(mbs)); memset(&mbs, 0, sizeof(mbs));
n = text->length; n = text->length;
while(n > 0) while(n > 0) {
{ rc = mbrtowc(&wc, s, n, &mbs); rc = mbrtowc(&wc, s, n, &mbs);
*p++ = FUNCTOR_dot2;
if ( type == PL_CODE_LIST ) if ( type == PL_CODE_LIST )
*p++ = consInt(wc); p = EXTEND_SEQ_CODES(p, wc);
else else
*p++ = codeToAtom(wc); p = EXTEND_SEQ_ATOMS(p, wc);
*p = consPtr(p+1, TAG_COMPOUND|STG_GLOBAL);
p++;
s += rc; s += rc;
n -= rc; n -= rc;
} }
#endif
break; break;
} }
default: default:
@ -402,22 +388,7 @@ PL_unify_text(term_t term, term_t tail, PL_chars_t *text, int type)
} }
} }
#if SWI_PROLOG return CLOSE_SEQ_OF_CODES(p, p0, tail, term );
setHandle(l, consPtr(p0, TAG_COMPOUND|STG_GLOBAL));
p--;
if ( tail )
{ setVar(*p);
if ( PL_unify(l, term) )
{ setHandle(tail, makeRefG(p));
return TRUE;
}
return FALSE;
} else
{ *p = ATOM_nil;
return PL_unify(l, term);
}
#endif
} }
} }
default: default:

View File

@ -31,6 +31,25 @@ typedef YAP_Atom Atom;
typedef uintptr_t PL_atomic_t; /* same a word */ typedef uintptr_t PL_atomic_t; /* same a word */
#ifdef __SWI_PROLOG__
/* just to make clear how it would look in SWI */
#define INIT_DEF(Type, Name, Size) \
static void init_ ## Name (void) {} \
static const Type Name[] {
#define ADD_DEF2(Atom, Type) \
{ Atom, Type },
#define ADD_DEF5(Atom, Type, Reverse, Arity, Ctx) \
{ Atom, Type, Reverse, Arity, Ctx },
\
#define END_DEFS(Atom, F) \
{ Atom, F }
}
#endif
#define INIT_DEF(Type, Name, Size) \ #define INIT_DEF(Type, Name, Size) \
static Type Name[Size]; \ static Type Name[Size]; \
static void init_ ## Name (void) { \ static void init_ ## Name (void) { \
@ -109,20 +128,35 @@ typedef uintptr_t PL_atomic_t; /* same a word */
#define stopItimer() #define stopItimer()
/* TBD */ /* TBD */
extern atom_t codeToAtom(int chrcode);
static inline word static inline word
INIT_SEQ_CODES(size_t n) INIT_SEQ_CODES(size_t n)
{ {
return 0L; /* TBD: shift */ return (word)YAP_OpenList(n);
} }
static inline word static inline word
EXTEND_SEQ_CODES(word gstore, int c) { EXTEND_SEQ_CODES(word gstore, int c) {
return gstore; return (word)YAP_ExtendList((YAP_Term)gstore, YAP_MkIntTerm(c));
}
static inline word
EXTEND_SEQ_ATOMS(word gstore, int c) {
return (word)YAP_ExtendList((YAP_Term)gstore, codeToAtom(c));
} }
static inline int static inline int
CLOSE_SEQ_OF_CODES(word gstore, word lp, word t1, word t2) { CLOSE_SEQ_OF_CODES(word gstore, word lp, word arg2, word arg3) {
return TRUE; if (arg3 == (word)ATOM_nil) {
if (!YAP_CloseList((YAP_Term)gstore, YAP_TermNil()))
return FALSE;
} else {
if (!YAP_CloseList((YAP_Term)gstore, YAP_GetFromSlot(arg2)))
return FALSE;
}
return YAP_Unify(YAP_GetFromSlot(arg3), lp);
} }
static inline Word static inline Word

View File

@ -864,7 +864,7 @@ then
YAPLIB="$DYNYAPLIB" YAPLIB="$DYNYAPLIB"
DYNLIB_LD="gcc -dynamiclib" DYNLIB_LD="gcc -dynamiclib"
PRE_DYNLOADER_PATH="DYLD_LIBRARY_PATH=\$(abs_top_builddir)" PRE_DYNLOADER_PATH="DYLD_LIBRARY_PATH=\$(abs_top_builddir)"
EXTEND_DYNLOADER_PATH="DYLD_LIBRARY_PATH=\$(DESTDIR)\$(LIBDIR): YAPSHAREDIR=\$(DESTDIR)\$(SHAREDIR)/Yap YAPLIBDIR=\$(DESTDIR)\$(YAPLIBDIR)" EXTEND_DYNLOADER_PATH="DYLD_LIBRARY_PATH=\$(DESTDIR)\$(LIBDIR): YAPSHAREDIR=\$(DESTDIR)\$(SHAREDIR)/Yap YAPBOOTDIR=\$(DESTDIR)\$(SHAREDIR)/Yap/pl YAPLIBDIR=\$(DESTDIR)\$(YAPLIBDIR)"
;; ;;
*) *)
case "$target_cpu" in case "$target_cpu" in
@ -878,7 +878,7 @@ then
JAVA_TARGET=sparc JAVA_TARGET=sparc
;; ;;
esac esac
EXTEND_DYNLOADER_PATH="LD_LIBRARY_PATH=\$(DESTDIR)\$(LIBDIR): YAPSHAREDIR=\$(DESTDIR)\$(SHAREDIR)/Yap YAPLIBDIR=\$(DESTDIR)\$(YAPLIBDIR)" EXTEND_DYNLOADER_PATH="LD_LIBRARY_PATH=\$(DESTDIR)\$(LIBDIR): YAPSHAREDIR=\$(DESTDIR)\$(SHAREDIR)/Yap YAPBOOTDIR=\$(DESTDIR)\$(SHAREDIR)/Yap/pl YAPLIBDIR=\$(DESTDIR)\$(YAPLIBDIR)"
PRE_DYNLOADER_PATH="LD_LIBRARY_PATH=\$(abs_top_builddir)" PRE_DYNLOADER_PATH="LD_LIBRARY_PATH=\$(abs_top_builddir)"
LDFLAGS="$LDFLAGS -Wl,-R,$prefix/lib -Wl,-R,$JAVA_HOME/jre/lib/$JAVA_TARGET" LDFLAGS="$LDFLAGS -Wl,-R,$prefix/lib -Wl,-R,$JAVA_HOME/jre/lib/$JAVA_TARGET"
DYNYAPLIB=libYap"$SHLIB_SUFFIX" DYNYAPLIB=libYap"$SHLIB_SUFFIX"
@ -888,7 +888,7 @@ then
esac esac
else else
PRE_DYNLOADER_PATH="" PRE_DYNLOADER_PATH=""
EXTEND_DYNLOADER_PATH="YAPSHAREDIR=\$(DESTDIR)\$(SHAREDIR)/Yap YAPLIBDIR=\$(DESTDIR)\$(YAPLIBDIR)" EXTEND_DYNLOADER_PATH="YAPSHAREDIR=\$(DESTDIR)\$(SHAREDIR)/Yap YAPBOOTDIR=\$(DESTDIR)\$(SHAREDIR)/Yap/pl YAPLIBDIR=\$(DESTDIR)\$(YAPLIBDIR)"
DYNYAPLIB=libYap.notused DYNYAPLIB=libYap.notused
fi fi

View File

@ -471,6 +471,11 @@ extern X_API void *PROTO(YAP_BlobOfTerm,(YAP_Term));
/* term comparison */ /* term comparison */
extern X_API int PROTO(YAP_CompareTerms,(YAP_Term, YAP_Term)); extern X_API int PROTO(YAP_CompareTerms,(YAP_Term, YAP_Term));
/* list construction */
extern X_API YAP_Term PROTO(YAP_OpenList,(int));
extern X_API YAP_Term PROTO(YAP_ExtendList,(YAP_Term, YAP_Term));
extern X_API int PROTO(YAP_CloseList,(YAP_Term, YAP_Term));
#define YAP_InitCPred(N,A,F) YAP_UserCPredicate(N,F,A) #define YAP_InitCPred(N,A,F) YAP_UserCPredicate(N,F,A)
__END_DECLS __END_DECLS