2008-12-22 12:02:22 +00:00
|
|
|
#ifndef PL_YAP_H
|
|
|
|
#define PL_YAP_H
|
|
|
|
|
|
|
|
#ifdef __YAP_PROLOG__
|
|
|
|
|
2011-02-10 00:01:19 +00:00
|
|
|
/* depends on tag schema, but 4 should always do */
|
|
|
|
#define LMASK_BITS 4 /* total # mask bits */
|
|
|
|
|
2008-12-22 12:02:22 +00:00
|
|
|
#if HAVE_CTYPE_H
|
|
|
|
#include <ctype.h>
|
|
|
|
#endif
|
|
|
|
|
2011-02-10 00:01:19 +00:00
|
|
|
#if HAVE_SYS_STAT_H
|
|
|
|
#include <sys/stat.h>
|
|
|
|
#endif
|
|
|
|
|
2008-12-22 12:02:22 +00:00
|
|
|
#define SIZE_VOIDP SIZEOF_INT_P
|
|
|
|
|
|
|
|
|
|
|
|
#if SIZEOF_LONG_INT==4
|
|
|
|
#define INT64_FORMAT "%lld"
|
|
|
|
#else
|
|
|
|
#define INT64_FORMAT "%ld"
|
|
|
|
#endif
|
2011-02-10 00:01:19 +00:00
|
|
|
#define INTBITSIZE (sizeof(int)*8)
|
2008-12-22 12:02:22 +00:00
|
|
|
|
2011-02-10 00:01:19 +00:00
|
|
|
typedef YAP_Term Module;
|
|
|
|
typedef YAP_Term *Word; /* Anonymous 4 byte object */
|
2008-12-22 12:02:22 +00:00
|
|
|
typedef YAP_Atom Atom;
|
2011-02-12 00:26:28 +00:00
|
|
|
typedef YAP_Term (*Func)(term_t); /* foreign functions */
|
2011-02-10 00:01:19 +00:00
|
|
|
|
2011-02-12 18:42:44 +00:00
|
|
|
extern const char *Yap_GetCurrentPredName(void);
|
|
|
|
extern YAP_Int Yap_GetCurrentPredArity(void);
|
2011-02-15 19:24:15 +00:00
|
|
|
extern int Yap_read_term(term_t t, IOSTREAM *st, term_t vs);
|
2011-02-13 01:03:08 +00:00
|
|
|
extern int Yap_LookupSWIStream(void *swi_s);
|
2011-02-15 19:24:15 +00:00
|
|
|
extern term_t Yap_fetch_module_for_format(term_t args, YAP_Term *modp);
|
2011-02-11 19:01:18 +00:00
|
|
|
|
2011-02-10 00:01:19 +00:00
|
|
|
extern atom_t codeToAtom(int chrcode);
|
|
|
|
|
|
|
|
#define valTermRef(t) ((Word)YAP_AddressFromSlot(t))
|
|
|
|
|
|
|
|
#include "pl-codelist.h"
|
|
|
|
|
2008-12-22 12:02:22 +00:00
|
|
|
//move this to SWI
|
|
|
|
|
2011-02-10 00:01:19 +00:00
|
|
|
#define GP_CREATE 2 /* create (in this module) */
|
|
|
|
|
|
|
|
#ifndef HAVE_MBSCOLL
|
|
|
|
COMMON(int) mbscoll(const char *s1, const char *s2);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef HAVE_MBSCASECOLL
|
|
|
|
COMMON(int) mbscasecoll(const char *s1, const char *s2);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
COMMON(atom_t) TemporaryFile(const char *id, int *fdp);
|
|
|
|
COMMON(char *) Getenv(const char *, char *buf, size_t buflen);
|
2008-12-22 12:02:22 +00:00
|
|
|
|
|
|
|
/*** memory allocation stuff: SWI wraps around malloc */
|
|
|
|
|
|
|
|
#define allocHeap(X) YAP_AllocSpaceFromYap(X)
|
|
|
|
|
|
|
|
#define freeHeap(X,Size) YAP_FreeSpaceFromYap(X)
|
|
|
|
|
|
|
|
#define stopItimer()
|
|
|
|
|
2011-02-10 00:01:19 +00:00
|
|
|
COMMON(word) pl_print(term_t term);
|
|
|
|
COMMON(word) pl_write(term_t term);
|
|
|
|
COMMON(word) pl_write_canonical(term_t term);
|
|
|
|
COMMON(word) pl_write_term(term_t term, term_t options);
|
|
|
|
COMMON(word) pl_writeq(term_t term);
|
|
|
|
|
|
|
|
static inline int
|
|
|
|
get_procedure(term_t descr, predicate_t *proc, term_t he, int f) {
|
|
|
|
YAP_Term t = YAP_GetFromSlot(descr);
|
|
|
|
|
|
|
|
if (YAP_IsVarTerm(t)) return 0;
|
|
|
|
if (YAP_IsAtomTerm(t))
|
|
|
|
*proc = YAP_Predicate(YAP_AtomOfTerm(t),0,YAP_CurrentModule());
|
|
|
|
else if (YAP_IsApplTerm(t)) {
|
|
|
|
YAP_Functor f = YAP_FunctorOfTerm(t);
|
|
|
|
*proc = YAP_Predicate(YAP_NameOfFunctor(f),YAP_ArityOfFunctor(f),YAP_CurrentModule());
|
|
|
|
}
|
|
|
|
return 1;
|
|
|
|
}
|
2008-12-22 13:49:44 +00:00
|
|
|
|
2011-02-10 00:01:19 +00:00
|
|
|
COMMON(intptr_t) lengthList(term_t list, int errors);
|
|
|
|
COMMON(int) promoteToFloatNumber(Number n);
|
|
|
|
COMMON(char *) PrologPath(const char *ospath, char *plpath, size_t len);
|
|
|
|
COMMON(char *) ExpandOneFile(const char *spec, char *file);
|
|
|
|
COMMON(char *) AbsoluteFile(const char *spec, char *path);
|
|
|
|
COMMON(char *) BaseName(const char *f);
|
|
|
|
COMMON(bool) ChDir(const char *path);
|
|
|
|
COMMON(char *) OsPath(const char *plpath, char *ospath);
|
|
|
|
COMMON(bool) ChDir(const char *path);
|
|
|
|
COMMON(int) DeleteTemporaryFile(atom_t name);
|
|
|
|
COMMON(int) IsAbsolutePath(const char *spec);
|
|
|
|
|
|
|
|
/* TBD */
|
2008-12-22 13:49:44 +00:00
|
|
|
|
2010-06-23 11:44:44 +01:00
|
|
|
extern word globalString(size_t size, char *s);
|
|
|
|
extern word globalWString(size_t size, wchar_t *s);
|
|
|
|
|
2008-12-22 12:02:22 +00:00
|
|
|
static inline word
|
|
|
|
valHandle(term_t tt)
|
|
|
|
{
|
|
|
|
return (word)YAP_GetFromSlot(tt);
|
|
|
|
}
|
2010-07-28 17:14:18 +01:00
|
|
|
|
|
|
|
YAP_Int YAP_PLArityOfSWIFunctor(functor_t f);
|
2011-02-10 21:14:38 +00:00
|
|
|
YAP_Atom YAP_AtomFromSWIAtom(atom_t at);
|
2011-02-10 00:01:19 +00:00
|
|
|
PL_blob_t* YAP_find_blob_type(YAP_Atom at);
|
|
|
|
|
2010-07-28 17:14:18 +01:00
|
|
|
|
|
|
|
#define arityFunctor(f) YAP_PLArityOfSWIFunctor(f)
|
2008-12-22 12:02:22 +00:00
|
|
|
|
|
|
|
#define stringAtom(w) YAP_AtomName((YAP_Atom)(w))
|
|
|
|
#define isInteger(A) (YAP_IsIntTerm((A)) && YAP_IsBigNumTerm((A)))
|
|
|
|
#define isString(A) FALSE
|
|
|
|
#define isAtom(A) YAP_IsAtomTerm((A))
|
|
|
|
#define isList(A) YAP_IsPairTerm((A))
|
|
|
|
#define isNil(A) ((A) == YAP_TermNil())
|
2010-02-22 09:35:47 +00:00
|
|
|
#define isReal(A) YAP_IsFloatTerm((A))
|
|
|
|
#define isFloat(A) YAP_IsFloatTerm((A))
|
2008-12-22 12:02:22 +00:00
|
|
|
#define isVar(A) YAP_IsVarTerm((A))
|
|
|
|
#define valReal(w) YAP_FloatOfTerm((w))
|
2010-02-22 09:35:47 +00:00
|
|
|
#define valFloat(w) YAP_FloatOfTerm((w))
|
2008-12-22 12:02:22 +00:00
|
|
|
#define AtomLength(w) YAP_AtomNameLength(w)
|
2011-02-11 01:22:07 +00:00
|
|
|
#define atomValue(atom) YAP_AtomFromSWIAtom(atom)
|
|
|
|
#define atomFromTerm(term) YAP_AtomOfTerm(term)
|
2011-02-10 00:01:19 +00:00
|
|
|
#define atomName(atom) ((char *)YAP_AtomName(atom))
|
|
|
|
#define nameOfAtom(atom) ((char *)YAP_AtomName(atom))
|
|
|
|
#define atomLength(atom) YAP_AtomNameLength(atom)
|
|
|
|
#define atomBlobType(at) YAP_find_blob_type(at)
|
2008-12-22 12:02:22 +00:00
|
|
|
#define argTermP(w,i) ((Word)((YAP_ArgsOfTerm(w)+(i))))
|
2011-02-10 00:01:19 +00:00
|
|
|
#define deRef(t)
|
|
|
|
#define canBind(t) FALSE // VSC: to implement
|
|
|
|
#define MODULE_user YAP_ModuleUser()
|
|
|
|
#define _PL_predicate(A,B,C,D) PL_predicate(A,B,C)
|
|
|
|
#define predicateHasClauses(A) (YAP_NumberOfClausesForPredicate((YAP_PredEntryPtr)A) != 0)
|
2011-02-15 18:39:50 +00:00
|
|
|
#define lookupModule(A) ((Module)PL_new_module(A))
|
2011-02-10 00:01:19 +00:00
|
|
|
#define charEscapeWriteOption(A) FALSE // VSC: to implement
|
|
|
|
#define skip_list(A,B) YAP_SkipList(A,B)
|
|
|
|
#define wordToTermRef(A) YAP_InitSlot(*(A))
|
|
|
|
#define isTaggedInt(A) YAP_IsIntTerm(A)
|
|
|
|
#define valInt(A) YAP_IntOfTerm(A)
|
2008-12-22 12:02:22 +00:00
|
|
|
|
|
|
|
#define clearNumber(n)
|
|
|
|
|
2011-02-10 00:01:19 +00:00
|
|
|
inline static int
|
|
|
|
charCode(YAP_Term w)
|
|
|
|
{ if ( YAP_IsAtomTerm(w) )
|
|
|
|
{
|
|
|
|
Atom a = atomValue(w);
|
|
|
|
|
|
|
|
if ( YAP_AtomNameLength(a) == 1) {
|
|
|
|
if (YAP_IsWideAtom(a)) {
|
|
|
|
return YAP_WideAtomName(a)[0];
|
|
|
|
}
|
|
|
|
return YAP_AtomName(a)[0];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2008-12-22 12:02:22 +00:00
|
|
|
#endif /* __YAP_PROLOG__ */
|
|
|
|
|
2009-06-01 22:56:00 +01:00
|
|
|
#if IN_PL_OS_C
|
2009-05-29 20:36:49 +01:00
|
|
|
static int
|
|
|
|
stripostfix(const char *s, const char *e)
|
|
|
|
{ size_t ls = strlen(s);
|
|
|
|
size_t le = strlen(e);
|
|
|
|
|
|
|
|
if ( ls >= le )
|
|
|
|
return strcasecmp(&s[ls-le], e) == 0;
|
|
|
|
|
|
|
|
return FALSE;
|
|
|
|
}
|
2009-06-01 22:56:00 +01:00
|
|
|
#endif
|
2009-03-13 19:37:52 +00:00
|
|
|
|
2009-06-02 00:01:30 +01:00
|
|
|
|
2008-12-22 12:02:22 +00:00
|
|
|
#endif /* PL_YAP_H */
|