Merge branch 'master' of gitosis@yap.dcc.fc.up.pt:yap-6

This commit is contained in:
Costa Vitor 2009-06-01 15:56:32 -05:00
commit 2ce09e66e7
3 changed files with 54 additions and 6 deletions

View File

@ -342,6 +342,7 @@
#define ATOM_natural MK_ATOM("natural") #define ATOM_natural MK_ATOM("natural")
#define ATOM_newline MK_ATOM("newline") #define ATOM_newline MK_ATOM("newline")
#define ATOM_nil MK_ATOM("[]") #define ATOM_nil MK_ATOM("[]")
#define ATOM_nlink MK_ATOM("nlink")
#define ATOM_no_memory MK_ATOM("no_memory") #define ATOM_no_memory MK_ATOM("no_memory")
#define ATOM_nodebug MK_ATOM("nodebug") #define ATOM_nodebug MK_ATOM("nodebug")
#define ATOM_non_empty_list MK_ATOM("non_empty_list") #define ATOM_non_empty_list MK_ATOM("non_empty_list")
@ -593,6 +594,8 @@
#define ATOM_yfx MK_ATOM("yfx") #define ATOM_yfx MK_ATOM("yfx")
#define ATOM_yfy MK_ATOM("yfy") #define ATOM_yfy MK_ATOM("yfy")
#define ATOM_zero_divisor MK_ATOM("zero_divisor") #define ATOM_zero_divisor MK_ATOM("zero_divisor")
#define FUNCTOR_abs1 MKFUNCTOR(ATOM_abs,1) #define FUNCTOR_abs1 MKFUNCTOR(ATOM_abs,1)
#define FUNCTOR_access1 MKFUNCTOR(ATOM_access,1) #define FUNCTOR_access1 MKFUNCTOR(ATOM_access,1)
#define FUNCTOR_acos1 MKFUNCTOR(ATOM_acos,1) #define FUNCTOR_acos1 MKFUNCTOR(ATOM_acos,1)
@ -714,6 +717,7 @@
#define FUNCTOR_mode1 MKFUNCTOR(ATOM_mode,1) #define FUNCTOR_mode1 MKFUNCTOR(ATOM_mode,1)
#define FUNCTOR_msb1 MKFUNCTOR(ATOM_msb,1) #define FUNCTOR_msb1 MKFUNCTOR(ATOM_msb,1)
#define FUNCTOR_newline1 MKFUNCTOR(ATOM_newline,1) #define FUNCTOR_newline1 MKFUNCTOR(ATOM_newline,1)
#define FUNCTOR_nlink1 MKFUNCTOR(ATOM_nlink,1)
#define FUNCTOR_not_implemented2 MKFUNCTOR(ATOM_not_implemented,2) #define FUNCTOR_not_implemented2 MKFUNCTOR(ATOM_not_implemented,2)
#define FUNCTOR_not_provable1 MKFUNCTOR(ATOM_not_provable,1) #define FUNCTOR_not_provable1 MKFUNCTOR(ATOM_not_provable,1)
#define FUNCTOR_occurs_check2 MKFUNCTOR(ATOM_occurs_check,2) #define FUNCTOR_occurs_check2 MKFUNCTOR(ATOM_occurs_check,2)

View File

@ -37,7 +37,7 @@ typedef int bool;
*********************************/ *********************************/
#include "pl-table.h" #include "pl-table.h"
#include "pl-stream.h" #include "SWI-Stream.h"
#include "pl-os.h" #include "pl-os.h"
#include "pl-error.h" #include "pl-error.h"
@ -53,6 +53,12 @@ typedef int bool;
#include "pl-opts.h" #include "pl-opts.h"
/*******************************
* LIST BUILDING *
*******************************/
#include "pl-privitf.h"
// numbers // numbers
typedef enum typedef enum
@ -94,6 +100,10 @@ typedef struct {
int io_initialised; int io_initialised;
cleanup_status cleaning; /* Inside PL_cleanup() */ cleanup_status cleaning; /* Inside PL_cleanup() */
struct
{ Table table; /* global (read-only) features */
} prolog_flag;
struct struct
{ TempFile _tmpfile_head; { TempFile _tmpfile_head;
TempFile _tmpfile_tail; TempFile _tmpfile_tail;
@ -122,6 +132,15 @@ extern gds_t gds;
#define GD (&gds) #define GD (&gds)
#define GLOBAL_LD (&gds) #define GLOBAL_LD (&gds)
typedef struct
{ unsigned long flags; /* Fast access to some boolean Prolog flags */
} pl_features_t;
#define truePrologFlag(flag) true(&LD->prolog_flag.mask, flag)
#define setPrologFlagMask(flag) set(&LD->prolog_flag.mask, flag)
#define clearPrologFlagMask(flag) clear(&LD->prolog_flag.mask, flag)
// LOCAL variables (heap will get this form LOCAL // LOCAL variables (heap will get this form LOCAL
#define FT_ATOM 0 /* atom feature */ #define FT_ATOM 0 /* atom feature */
@ -134,9 +153,28 @@ extern gds_t gds;
#define FF_READONLY 0x10 /* feature is read-only */ #define FF_READONLY 0x10 /* feature is read-only */
#define FF_KEEP 0x20 /* keep value it already set */ #define FF_KEEP 0x20 /* keep value it already set */
typedef struct #define PLFLAG_CHARESCAPE 0x000001 /* handle \ in atoms */
{ unsigned long flags; /* the feature flags */ #define PLFLAG_GC 0x000002 /* do GC */
} pl_features_t; #define PLFLAG_TRACE_GC 0x000004 /* verbose gc */
#define PLFLAG_TTY_CONTROL 0x000008 /* allow for tty control */
#define PLFLAG_READLINE 0x000010 /* readline is loaded */
#define PLFLAG_DEBUG_ON_ERROR 0x000020 /* start tracer on error */
#define PLFLAG_REPORT_ERROR 0x000040 /* print error message */
#define PLFLAG_FILE_CASE 0x000080 /* file names are case sensitive */
#define PLFLAG_FILE_CASE_PRESERVING 0x000100 /* case preserving file names */
#define PLFLAG_DOS_FILE_NAMES 0x000200 /* dos (8+3) file names */
#define ALLOW_VARNAME_FUNCTOR 0x000400 /* Read Foo(x) as 'Foo'(x) */
#define PLFLAG_ISO 0x000800 /* Strict ISO compliance */
#define PLFLAG_OPTIMISE 0x001000 /* -O: optimised compilation */
#define PLFLAG_FILEVARS 0x002000 /* Expand $var and ~ in filename */
#define PLFLAG_AUTOLOAD 0x004000 /* do autoloading */
#define PLFLAG_CHARCONVERSION 0x008000 /* do character-conversion */
#define PLFLAG_LASTCALL 0x010000 /* Last call optimization enabled? */
#define PLFLAG_EX_ABORT 0x020000 /* abort with exception */
#define PLFLAG_BACKQUOTED_STRING 0x040000 /* `a string` */
#define PLFLAG_SIGNALS 0x080000 /* Handle signals */
#define PLFLAG_DEBUGINFO 0x100000 /* generate debug info */
#define PLFLAG_FILEERRORS 0x200000 /* Edinburgh file errors */
typedef enum typedef enum
{ OCCURS_CHECK_FALSE = 0, { OCCURS_CHECK_FALSE = 0,
@ -213,6 +251,13 @@ typedef struct PL_local_data {
int next; /* prompt on next read operation */ int next; /* prompt on next read operation */
} prompt; } prompt;
struct
{ Table table; /* Feature table */
pl_features_t mask; /* Masked access to booleans */
int write_attributes; /* how to write attvars? */
occurs_check_t occurs_check; /* Unify and occurs check */
} prolog_flag;
IOENC encoding; /* default I/O encoding */ IOENC encoding; /* default I/O encoding */
struct struct
@ -298,7 +343,6 @@ extern int ttymode;
#define FILE_CASE_FEATURE 0x00080 /* file names are case sensitive */ #define FILE_CASE_FEATURE 0x00080 /* file names are case sensitive */
#define FILE_CASE_PRESERVING_FEATURE 0x0100 /* case preserving file names */ #define FILE_CASE_PRESERVING_FEATURE 0x0100 /* case preserving file names */
#define DOS_FILE_NAMES_FEATURE 0x00200 /* dos (8+3) file names */ #define DOS_FILE_NAMES_FEATURE 0x00200 /* dos (8+3) file names */
#define ALLOW_VARNAME_FUNCTOR 0x00400 /* Read Foo(x) as 'Foo'(x) */
#define ISO_FEATURE 0x00800 /* Strict ISO compliance */ #define ISO_FEATURE 0x00800 /* Strict ISO compliance */
#define OPTIMISE_FEATURE 0x01000 /* -O: optimised compilation */ #define OPTIMISE_FEATURE 0x01000 /* -O: optimised compilation */
#define FILEVARS_FEATURE 0x02000 /* Expand $var and ~ in filename */ #define FILEVARS_FEATURE 0x02000 /* Expand $var and ~ in filename */

View File

@ -70,7 +70,7 @@ locking is required.
#define PL_KERNEL 1 #define PL_KERNEL 1
#include <wchar.h> #include <wchar.h>
typedef wchar_t pl_wchar_t; typedef wchar_t pl_wchar_t;
#include "pl-stream.h" #include "SWI-Stream.h"
#include "pl-utf8.h" #include "pl-utf8.h"
#include <sys/types.h> #include <sys/types.h>
#ifdef HAVE_SYS_TIME_H #ifdef HAVE_SYS_TIME_H