fix conflict in error handling (not supposed to be exported by SWI-Prolog.h
add PL_eval_expression_to_int64_ex
This commit is contained in:
parent
9d5a049c8f
commit
98fef199bd
@ -292,8 +292,6 @@ typedef struct foreign_context *control_t;
|
|||||||
#define PL_fail return FALSE /* fail */
|
#define PL_fail return FALSE /* fail */
|
||||||
#define PL_succeed return TRUE /* success */
|
#define PL_succeed return TRUE /* success */
|
||||||
|
|
||||||
extern X_API void PL_free(void *);
|
|
||||||
|
|
||||||
extern X_API PL_agc_hook_t PL_agc_hook(PL_agc_hook_t);
|
extern X_API PL_agc_hook_t PL_agc_hook(PL_agc_hook_t);
|
||||||
extern X_API char* PL_atom_chars(atom_t);
|
extern X_API char* PL_atom_chars(atom_t);
|
||||||
extern X_API term_t PL_copy_term_ref(term_t);
|
extern X_API term_t PL_copy_term_ref(term_t);
|
||||||
@ -427,6 +425,7 @@ extern X_API void PL_erase(record_t);
|
|||||||
extern X_API int PL_action(int,...);
|
extern X_API int PL_action(int,...);
|
||||||
extern X_API void *PL_malloc(int);
|
extern X_API void *PL_malloc(int);
|
||||||
extern X_API void PL_free(void *);
|
extern X_API void PL_free(void *);
|
||||||
|
extern X_API int PL_eval_expression_to_int_64_ex(term_t t, int64_t *val);
|
||||||
|
|
||||||
#define PL_register_foreign(name, arity, function, flags) PL_register_foreign_in_module(NULL, (name), (arity), (function), (flags))
|
#define PL_register_foreign(name, arity, function, flags) PL_register_foreign_in_module(NULL, (name), (arity), (function), (flags))
|
||||||
|
|
||||||
@ -467,46 +466,6 @@ extern X_API const char *PL_cwd(void);
|
|||||||
|
|
||||||
void swi_install(void);
|
void swi_install(void);
|
||||||
|
|
||||||
#define ERR_NO_ERROR 0
|
|
||||||
#define ERR_INSTANTIATION 1 /* void */
|
|
||||||
#define ERR_TYPE 2 /* atom_t expected, term_t value */
|
|
||||||
#define ERR_DOMAIN 3 /* atom_t domain, term_t value */
|
|
||||||
#define ERR_REPRESENTATION 4 /* atom_t what */
|
|
||||||
#define ERR_MODIFY_STATIC_PROC 5 /* predicate_t proc */
|
|
||||||
#define ERR_EVALUATION 6 /* atom_t what */
|
|
||||||
#define ERR_AR_TYPE 7 /* atom_t expected, Number value */
|
|
||||||
#define ERR_NOT_EVALUABLE 8 /* functor_t func */
|
|
||||||
#define ERR_DIV_BY_ZERO 9 /* void */
|
|
||||||
#define ERR_FAILED 10 /* predicate_t proc */
|
|
||||||
#define ERR_FILE_OPERATION 11 /* atom_t action, atom_t type, term_t */
|
|
||||||
#define ERR_PERMISSION 12 /* atom_t type, atom_t op, term_t obj*/
|
|
||||||
#define ERR_NOT_IMPLEMENTED 13 /* const char *what */
|
|
||||||
#define ERR_EXISTENCE 14 /* atom_t type, term_t obj */
|
|
||||||
#define ERR_STREAM_OP 15 /* atom_t action, term_t obj */
|
|
||||||
#define ERR_RESOURCE 16 /* atom_t resource */
|
|
||||||
#define ERR_NOMEM 17 /* void */
|
|
||||||
#define ERR_SYSCALL 18 /* void */
|
|
||||||
#define ERR_SHELL_FAILED 19 /* term_t command */
|
|
||||||
#define ERR_SHELL_SIGNALLED 20 /* term_t command, int signal */
|
|
||||||
#define ERR_AR_UNDEF 21 /* void */
|
|
||||||
#define ERR_AR_OVERFLOW 22 /* void */
|
|
||||||
#define ERR_AR_UNDERFLOW 23 /* void */
|
|
||||||
#define ERR_UNDEFINED_PROC 24 /* Definition def */
|
|
||||||
#define ERR_SIGNALLED 25 /* int sig, char *name */
|
|
||||||
#define ERR_CLOSED_STREAM 26 /* IOSTREAM * */
|
|
||||||
#define ERR_BUSY 27 /* mutexes */
|
|
||||||
#define ERR_PERMISSION_PROC 28 /* op, type, Definition */
|
|
||||||
#define ERR_DDE_OP 29 /* op, error */
|
|
||||||
#define ERR_SYNTAX 30 /* what */
|
|
||||||
#define ERR_SHARED_OBJECT_OP 31 /* op, error */
|
|
||||||
#define ERR_TIMEOUT 32 /* op, object */
|
|
||||||
#define ERR_NOT_IMPLEMENTED_PROC 33 /* name, arity */
|
|
||||||
#define ERR_FORMAT 34 /* message */
|
|
||||||
#define ERR_FORMAT_ARG 35 /* seq, term */
|
|
||||||
#define ERR_OCCURS_CHECK 36 /* Word, Word */
|
|
||||||
#define ERR_CHARS_TYPE 37 /* char *, term */
|
|
||||||
#define ERR_MUST_BE_VAR 38 /* int argn, term_t term */
|
|
||||||
|
|
||||||
X_API int PL_error(const char *pred, int arity, const char *msg, int id, ...);
|
X_API int PL_error(const char *pred, int arity, const char *msg, int id, ...);
|
||||||
|
|
||||||
|
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
|
|
||||||
#include <Yap.h>
|
#include <Yap.h>
|
||||||
#include <Yatom.h>
|
#include <Yatom.h>
|
||||||
|
#include <eval.h>
|
||||||
|
|
||||||
#if HAVE_MATH_H
|
#if HAVE_MATH_H
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
@ -425,7 +426,7 @@ X_API int PL_get_wchars(term_t l, size_t *len, wchar_t **wsp, unsigned flags)
|
|||||||
YAP: YAP_Functor YAP_FunctorOfTerm(Term) */
|
YAP: YAP_Functor YAP_FunctorOfTerm(Term) */
|
||||||
X_API int PL_get_functor(term_t ts, functor_t *f)
|
X_API int PL_get_functor(term_t ts, functor_t *f)
|
||||||
{
|
{
|
||||||
YAP_Term t = Yap_GetFromSlot(ts);
|
Term t = Yap_GetFromSlot(ts);
|
||||||
if ( IsAtomTerm(t)) {
|
if ( IsAtomTerm(t)) {
|
||||||
*f = t;
|
*f = t;
|
||||||
} else {
|
} else {
|
||||||
@ -916,6 +917,46 @@ X_API int PL_raise_exception(term_t exception)
|
|||||||
#define FUNCTOR_timeout_error2 FunctorToSWIFunctor(FunctorTimeoutError)
|
#define FUNCTOR_timeout_error2 FunctorToSWIFunctor(FunctorTimeoutError)
|
||||||
#define FUNCTOR_type_error2 FunctorToSWIFunctor(FunctorTypeError)
|
#define FUNCTOR_type_error2 FunctorToSWIFunctor(FunctorTypeError)
|
||||||
|
|
||||||
|
#define ERR_NO_ERROR 0
|
||||||
|
#define ERR_INSTANTIATION 1 /* void */
|
||||||
|
#define ERR_TYPE 2 /* atom_t expected, term_t value */
|
||||||
|
#define ERR_DOMAIN 3 /* atom_t domain, term_t value */
|
||||||
|
#define ERR_REPRESENTATION 4 /* atom_t what */
|
||||||
|
#define ERR_MODIFY_STATIC_PROC 5 /* predicate_t proc */
|
||||||
|
#define ERR_EVALUATION 6 /* atom_t what */
|
||||||
|
#define ERR_AR_TYPE 7 /* atom_t expected, Number value */
|
||||||
|
#define ERR_NOT_EVALUABLE 8 /* functor_t func */
|
||||||
|
#define ERR_DIV_BY_ZERO 9 /* void */
|
||||||
|
#define ERR_FAILED 10 /* predicate_t proc */
|
||||||
|
#define ERR_FILE_OPERATION 11 /* atom_t action, atom_t type, term_t */
|
||||||
|
#define ERR_PERMISSION 12 /* atom_t type, atom_t op, term_t obj*/
|
||||||
|
#define ERR_NOT_IMPLEMENTED 13 /* const char *what */
|
||||||
|
#define ERR_EXISTENCE 14 /* atom_t type, term_t obj */
|
||||||
|
#define ERR_STREAM_OP 15 /* atom_t action, term_t obj */
|
||||||
|
#define ERR_RESOURCE 16 /* atom_t resource */
|
||||||
|
#define ERR_NOMEM 17 /* void */
|
||||||
|
#define ERR_SYSCALL 18 /* void */
|
||||||
|
#define ERR_SHELL_FAILED 19 /* term_t command */
|
||||||
|
#define ERR_SHELL_SIGNALLED 20 /* term_t command, int signal */
|
||||||
|
#define ERR_AR_UNDEF 21 /* void */
|
||||||
|
#define ERR_AR_OVERFLOW 22 /* void */
|
||||||
|
#define ERR_AR_UNDERFLOW 23 /* void */
|
||||||
|
#define ERR_UNDEFINED_PROC 24 /* Definition def */
|
||||||
|
#define ERR_SIGNALLED 25 /* int sig, char *name */
|
||||||
|
#define ERR_CLOSED_STREAM 26 /* IOSTREAM * */
|
||||||
|
#define ERR_BUSY 27 /* mutexes */
|
||||||
|
#define ERR_PERMISSION_PROC 28 /* op, type, Definition */
|
||||||
|
#define ERR_DDE_OP 29 /* op, error */
|
||||||
|
#define ERR_SYNTAX 30 /* what */
|
||||||
|
#define ERR_SHARED_OBJECT_OP 31 /* op, error */
|
||||||
|
#define ERR_TIMEOUT 32 /* op, object */
|
||||||
|
#define ERR_NOT_IMPLEMENTED_PROC 33 /* name, arity */
|
||||||
|
#define ERR_FORMAT 34 /* message */
|
||||||
|
#define ERR_FORMAT_ARG 35 /* seq, term */
|
||||||
|
#define ERR_OCCURS_CHECK 36 /* Word, Word */
|
||||||
|
#define ERR_CHARS_TYPE 37 /* char *, term */
|
||||||
|
#define ERR_MUST_BE_VAR 38 /* int argn, term_t term */
|
||||||
|
|
||||||
X_API int PL_error(const char *pred, int arity, const char *msg, int id, ...)
|
X_API int PL_error(const char *pred, int arity, const char *msg, int id, ...)
|
||||||
{
|
{
|
||||||
term_t formal, swi, predterm, msgterm, except;
|
term_t formal, swi, predterm, msgterm, except;
|
||||||
@ -2127,6 +2168,32 @@ PL_free(void *obj)
|
|||||||
return YAP_FreeSpaceFromYap(obj);
|
return YAP_FreeSpaceFromYap(obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
X_API int
|
||||||
|
PL_eval_expression_to_int_64_ex(term_t t, int64_t *val)
|
||||||
|
{
|
||||||
|
Term res = Yap_Eval(Yap_GetFromSlot(t));
|
||||||
|
if (!res) {
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
if (IsIntegerTerm(res)) {
|
||||||
|
*val = IntegerOfTerm(res);
|
||||||
|
return TRUE;
|
||||||
|
} else if (YAP_IsBigNumTerm(res)) {
|
||||||
|
MP_INT g;
|
||||||
|
char s[64];
|
||||||
|
|
||||||
|
YAP_BigNumOfTerm(t, (void *)&g);
|
||||||
|
if (mpz_sizeinbase(&g,2) > 64) {
|
||||||
|
return PL_error(NULL,0,NULL, ERR_EVALUATION, AtomToSWIAtom(Yap_LookupAtom("int_overflow")));
|
||||||
|
}
|
||||||
|
mpz_get_str (s, 10, &g);
|
||||||
|
sscanf(s, "%lld", (long long int *)val);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
PL_error(NULL,0,NULL, ERR_TYPE, AtomToSWIAtom(Yap_LookupAtom("integer_expression")));
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static int
|
static int
|
||||||
SWI_ctime(void)
|
SWI_ctime(void)
|
||||||
|
@ -509,7 +509,6 @@ extern bool readLine(IOSTREAM *in, IOSTREAM *out, char *buffer);
|
|||||||
extern bool tellString(char **s, size_t *size, IOENC enc);
|
extern bool tellString(char **s, size_t *size, IOENC enc);
|
||||||
extern bool tellString(char **s, size_t *size, IOENC enc);
|
extern bool tellString(char **s, size_t *size, IOENC enc);
|
||||||
extern bool toldString(void);
|
extern bool toldString(void);
|
||||||
ssize_t Sread_user(void *handle, char *buf, size_t size);
|
|
||||||
|
|
||||||
extern int setupOutputRedirect(term_t to, redir_context *ctx, int redir);
|
extern int setupOutputRedirect(term_t to, redir_context *ctx, int redir);
|
||||||
extern void discardOutputRedirect(redir_context *ctx);
|
extern void discardOutputRedirect(redir_context *ctx);
|
||||||
@ -577,6 +576,10 @@ extern atom_t lookupUCSAtom(const pl_wchar_t *s, size_t len);
|
|||||||
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);
|
||||||
|
|
||||||
|
/* empty stub */
|
||||||
|
void setPrologFlag(const char *name, int flags, ...);
|
||||||
|
void PL_set_prolog_flag(const char *name, int flags, ...);
|
||||||
|
|
||||||
static inline word
|
static inline word
|
||||||
setBoolean(int *flag, term_t old, term_t new)
|
setBoolean(int *flag, term_t old, term_t new)
|
||||||
{ if ( !PL_unify_bool_ex(old, *flag) ||
|
{ if ( !PL_unify_bool_ex(old, *flag) ||
|
||||||
|
@ -544,4 +544,13 @@ ok:
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
setPrologFlag(const char *name, int flags, ...)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
PL_set_prolog_flag(const char *name, int flags, ...)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
@ -198,4 +198,44 @@ stripostfix(const char *s, const char *e)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#define ERR_NO_ERROR 0
|
||||||
|
#define ERR_INSTANTIATION 1 /* void */
|
||||||
|
#define ERR_TYPE 2 /* atom_t expected, term_t value */
|
||||||
|
#define ERR_DOMAIN 3 /* atom_t domain, term_t value */
|
||||||
|
#define ERR_REPRESENTATION 4 /* atom_t what */
|
||||||
|
#define ERR_MODIFY_STATIC_PROC 5 /* predicate_t proc */
|
||||||
|
#define ERR_EVALUATION 6 /* atom_t what */
|
||||||
|
#define ERR_AR_TYPE 7 /* atom_t expected, Number value */
|
||||||
|
#define ERR_NOT_EVALUABLE 8 /* functor_t func */
|
||||||
|
#define ERR_DIV_BY_ZERO 9 /* void */
|
||||||
|
#define ERR_FAILED 10 /* predicate_t proc */
|
||||||
|
#define ERR_FILE_OPERATION 11 /* atom_t action, atom_t type, term_t */
|
||||||
|
#define ERR_PERMISSION 12 /* atom_t type, atom_t op, term_t obj*/
|
||||||
|
#define ERR_NOT_IMPLEMENTED 13 /* const char *what */
|
||||||
|
#define ERR_EXISTENCE 14 /* atom_t type, term_t obj */
|
||||||
|
#define ERR_STREAM_OP 15 /* atom_t action, term_t obj */
|
||||||
|
#define ERR_RESOURCE 16 /* atom_t resource */
|
||||||
|
#define ERR_NOMEM 17 /* void */
|
||||||
|
#define ERR_SYSCALL 18 /* void */
|
||||||
|
#define ERR_SHELL_FAILED 19 /* term_t command */
|
||||||
|
#define ERR_SHELL_SIGNALLED 20 /* term_t command, int signal */
|
||||||
|
#define ERR_AR_UNDEF 21 /* void */
|
||||||
|
#define ERR_AR_OVERFLOW 22 /* void */
|
||||||
|
#define ERR_AR_UNDERFLOW 23 /* void */
|
||||||
|
#define ERR_UNDEFINED_PROC 24 /* Definition def */
|
||||||
|
#define ERR_SIGNALLED 25 /* int sig, char *name */
|
||||||
|
#define ERR_CLOSED_STREAM 26 /* IOSTREAM * */
|
||||||
|
#define ERR_BUSY 27 /* mutexes */
|
||||||
|
#define ERR_PERMISSION_PROC 28 /* op, type, Definition */
|
||||||
|
#define ERR_DDE_OP 29 /* op, error */
|
||||||
|
#define ERR_SYNTAX 30 /* what */
|
||||||
|
#define ERR_SHARED_OBJECT_OP 31 /* op, error */
|
||||||
|
#define ERR_TIMEOUT 32 /* op, object */
|
||||||
|
#define ERR_NOT_IMPLEMENTED_PROC 33 /* name, arity */
|
||||||
|
#define ERR_FORMAT 34 /* message */
|
||||||
|
#define ERR_FORMAT_ARG 35 /* seq, term */
|
||||||
|
#define ERR_OCCURS_CHECK 36 /* Word, Word */
|
||||||
|
#define ERR_CHARS_TYPE 37 /* char *, term */
|
||||||
|
#define ERR_MUST_BE_VAR 38 /* int argn, term_t term */
|
||||||
|
|
||||||
#endif /* PL_YAP_H */
|
#endif /* PL_YAP_H */
|
||||||
|
@ -44,3 +44,4 @@ typedef enum
|
|||||||
int sgml2pl_error(plerrorid, ...);
|
int sgml2pl_error(plerrorid, ...);
|
||||||
|
|
||||||
#endif /*H_ERROR_INCLUDED*/
|
#endif /*H_ERROR_INCLUDED*/
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user