fix fixes (lots of white space, somehow.

This commit is contained in:
Vítor Santos Costa 2016-02-29 03:13:23 +00:00
parent 0ccee1aa55
commit b9eb327d86
27 changed files with 2157 additions and 2230 deletions

View File

@ -1090,7 +1090,7 @@ execute_dealloc( USES_REGS1 )
else else
ENV_YREG = (CELL *) ((CELL) ENV_YREG + ENV_Size(CP)); ENV_YREG = (CELL *) ((CELL) ENV_YREG + ENV_Size(CP));
#endif /* FROZEN_STACKS */ #endif /* FROZEN_STACKS */
YENV = ENV_YREG; YENV = ENVYREG;
P = NEXTOP(P,p); P = NEXTOP(P,p);
} }

View File

@ -1317,7 +1317,7 @@ atom_length( USES_REGS1 )
if (!IsIntegerTerm(t2)) { if (!IsIntegerTerm(t2)) {
Yap_Error(TYPE_ERROR_INTEGER, t2, "atom_length/2"); Yap_Error(TYPE_ERROR_INTEGER, t2, "atom_length/2");
return(FALSE); return(FALSE);
} else if ((len = IntegerOfTerm(t2)) < 0) { } else if ((Int)(len = IntegerOfTerm(t2)) < 0) {
Yap_Error(DOMAIN_ERROR_NOT_LESS_THAN_ZERO, t2, "atom_length/2"); Yap_Error(DOMAIN_ERROR_NOT_LESS_THAN_ZERO, t2, "atom_length/2");
return(FALSE); return(FALSE);
} }
@ -1354,7 +1354,7 @@ atomic_length( USES_REGS1 )
Yap_Error(TYPE_ERROR_INTEGER, t2, "atomic_length/2"); Yap_Error(TYPE_ERROR_INTEGER, t2, "atomic_length/2");
return(FALSE); return(FALSE);
} }
if ((len = IntegerOfTerm(t2)) < 0) { if ((Int)(len = IntegerOfTerm(t2)) < 0) {
Yap_Error(DOMAIN_ERROR_NOT_LESS_THAN_ZERO, t2, "atomic_length/2"); Yap_Error(DOMAIN_ERROR_NOT_LESS_THAN_ZERO, t2, "atomic_length/2");
return(FALSE); return(FALSE);
} }
@ -1383,7 +1383,7 @@ string_length( USES_REGS1 )
Yap_Error(TYPE_ERROR_INTEGER, t2, "string_length/2"); Yap_Error(TYPE_ERROR_INTEGER, t2, "string_length/2");
return(FALSE); return(FALSE);
} }
if (FALSE && (len = IntegerOfTerm(t2)) < 0) { if (FALSE && (Int)(len = IntegerOfTerm(t2)) < 0) {
Yap_Error(DOMAIN_ERROR_NOT_LESS_THAN_ZERO, t2, "string_length/2"); Yap_Error(DOMAIN_ERROR_NOT_LESS_THAN_ZERO, t2, "string_length/2");
return(FALSE); return(FALSE);
} }

View File

@ -1019,7 +1019,7 @@ Term Yap_UnknownFlag(Term mod) {
ModEntry *fv = Yap_GetModuleEntry(mod); ModEntry *fv = Yap_GetModuleEntry(mod);
if (fv == NULL) if (fv == NULL)
fv = Yap_GetModuleEntry(AtomUser); fv = Yap_GetModuleEntry(TermUser);
if (fv->flags & UNKNOWN_ERROR) if (fv->flags & UNKNOWN_ERROR)
return TermError; return TermError;
if (fv->flags & UNKNOWN_WARNING) if (fv->flags & UNKNOWN_WARNING)

View File

@ -206,7 +206,7 @@ mywrite(FILE *fd, char *buff, Int len) {
while (len > 0) { while (len > 0) {
nwritten = fwrite(buff, 1, (size_t)len, fd); nwritten = fwrite(buff, 1, (size_t)len, fd);
if (nwritten < 0) { if ((long int)nwritten < 0) {
return do_SYSTEM_ERROR_INTERNAL(SYSTEM_ERROR_INTERNAL,"bad write on saved state"); return do_SYSTEM_ERROR_INTERNAL(SYSTEM_ERROR_INTERNAL,"bad write on saved state");
} }
buff += nwritten; buff += nwritten;

View File

@ -1,4 +1,3 @@
/************************************************************************* /*************************************************************************
* * * *
* YAP Prolog * * YAP Prolog *
@ -35,11 +34,11 @@ static char SccsId[] = "%W% %G%";
#if YAP_JIT #if YAP_JIT
#include "amijit.h" #include "amijit.h"
#endif #endif
#include "Yatom.h" #include "Foreign.h"
#include "YapHeap.h" #include "YapHeap.h"
#include "Yatom.h"
#include "eval.h" #include "eval.h"
#include "yapio.h" #include "yapio.h"
#include "Foreign.h"
#ifdef TABLING #ifdef TABLING
#include "tab.macros.h" #include "tab.macros.h"
#endif /* TABLING */ #endif /* TABLING */
@ -56,8 +55,8 @@ static char SccsId[] = "%W% %G%";
#if YAP_JIT #if YAP_JIT
#include <JIT_Compiler.hpp> #include <JIT_Compiler.hpp>
#endif #endif
#include <wchar.h>
#include <fcntl.h> #include <fcntl.h>
#include <wchar.h>
static Int p_setval(USES_REGS1); static Int p_setval(USES_REGS1);
static Int p_value(USES_REGS1); static Int p_value(USES_REGS1);
@ -386,8 +385,11 @@ static Int p_systime(USES_REGS1) {
static Int p_walltime(USES_REGS1) { static Int p_walltime(USES_REGS1) {
uint64_t now, interval; uint64_t now, interval;
return (Yap_unify_constant(ARG1, MkIntegerTerm(now)) && uint64_t t = Yap_walltime();
Yap_unify_constant(ARG2, MkIntegerTerm(interval))); now = t - Yap_StartOfWTimes;
interval = t - LOCAL_LastWTime;
return (Yap_unify_constant(ARG1, MkIntegerTerm(now / 1000)) &&
Yap_unify_constant(ARG2, MkIntegerTerm(interval / 1000)));
} }
static Int p_univ(USES_REGS1) { /* A =.. L */ static Int p_univ(USES_REGS1) { /* A =.. L */
@ -630,13 +632,13 @@ static Int
static bool valid_prop(Prop p, Term task) { static bool valid_prop(Prop p, Term task) {
if ((RepPredProp(p)->PredFlags & HiddenPredFlag) || if ((RepPredProp(p)->PredFlags & HiddenPredFlag) ||
(RepPredProp(p)->OpcodeOfPred == UNDEF_OPCODE) ){ (RepPredProp(p)->OpcodeOfPred == UNDEF_OPCODE)) {
return false; return false;
} }
if(task == TermSystem || task == TermProlog) { if (task == TermSystem || task == TermProlog) {
return RepPredProp(p)->PredFlags & StandardPredFlag; return RepPredProp(p)->PredFlags & StandardPredFlag;
} }
if(task == TermUser) { if (task == TermUser) {
return !(RepPredProp(p)->PredFlags & StandardPredFlag); return !(RepPredProp(p)->PredFlags & StandardPredFlag);
} }
if (IsVarTerm(task)) { if (IsVarTerm(task)) {
@ -682,7 +684,7 @@ static PropEntry *nextPredForAtom(PropEntry *p, Term task) {
return NIL; return NIL;
pe = RepPredProp(p); pe = RepPredProp(p);
if (pe->ArityOfPE == 0 || if (pe->ArityOfPE == 0 ||
(pe->PredFlags & (NumberDBPredFlag |AtomDBPredFlag) ) ) { (pe->PredFlags & (NumberDBPredFlag | AtomDBPredFlag))) {
// if atom prop, search atom list // if atom prop, search atom list
return followLinkedListOfProps(p->NextOfPE, task); return followLinkedListOfProps(p->NextOfPE, task);
} else { } else {
@ -873,8 +875,7 @@ static Int cont_current_predicate(USES_REGS1) {
npp = firstModulePred(pp, task); npp = firstModulePred(pp, task);
if (!npp) { if (!npp) {
if (pp->ModuleOfPred != PROLOG_MODULE && if (pp->ModuleOfPred != PROLOG_MODULE && task != TermUser) {
task != TermUser) {
ModEntry *m = Yap_GetModuleEntry(TermProlog); ModEntry *m = Yap_GetModuleEntry(TermProlog);
npp = firstModulePred(m->PredForME, task); npp = firstModulePred(m->PredForME, task);
if (!npp) if (!npp)
@ -938,9 +939,8 @@ static Int cont_current_predicate(USES_REGS1) {
} else { } else {
rc = Yap_unify(ARG3, name); rc = Yap_unify(ARG3, name);
} }
rc = rc && (IsAtomTerm(t2) || rc = rc && (IsAtomTerm(t2) || Yap_unify(ARG2, ModToTerm(pp->ModuleOfPred))) &&
Yap_unify(ARG2, ModToTerm(pp->ModuleOfPred))) Yap_unify(ARG1, name);
&& Yap_unify(ARG1, name);
if (will_cut) { if (will_cut) {
if (rc) if (rc)
cut_succeed(); cut_succeed();
@ -1105,7 +1105,7 @@ void Yap_show_statistics(void) {
(Unsigned(TR) - Unsigned(LOCAL_TrailBase)))); (Unsigned(TR) - Unsigned(LOCAL_TrailBase))));
fprintf(stderr, "Runtime: %lds.\n", (unsigned long int)(runtime(PASS_REGS1))); fprintf(stderr, "Runtime: %lds.\n", (unsigned long int)(runtime(PASS_REGS1)));
fprintf(stderr, "Cputime: %lds.\n", (unsigned long int)(Yap_cputime())); fprintf(stderr, "Cputime: %lds.\n", (unsigned long int)(Yap_cputime()));
fprintf(stderr, "Walltime: %lds.\n", (unsigned long int)(Yap_walltime())); fprintf(stderr, "Walltime: %llu.\n", Yap_walltime() / 1000);
} }
static Int p_statistics_heap_max(USES_REGS1) { static Int p_statistics_heap_max(USES_REGS1) {

View File

@ -15,8 +15,11 @@
#if defined(_WIN32) #if defined(_WIN32)
#define X_API __declspec(dllexport) #define X_API __declspec(dllexport)
#else
#define X_API
#endif #endif
/* prototype file for Yap */ /* prototype file for Yap */
/* absmi.c */ /* absmi.c */

View File

@ -140,7 +140,5 @@
#define GLOBAL_CharConversionTable Yap_global->CharConversionTable_ #define GLOBAL_CharConversionTable Yap_global->CharConversionTable_
#define GLOBAL_CharConversionTable2 Yap_global->CharConversionTable2_ #define GLOBAL_CharConversionTable2 Yap_global->CharConversionTable2_
#define GLOBAL_LastWTimePtr Yap_global->LastWTimePtr_
#define GLOBAL_MaxPriority Yap_global->MaxPriority_ #define GLOBAL_MaxPriority Yap_global->MaxPriority_

View File

@ -491,3 +491,6 @@
#define LOCAL_MAX_SIZE LOCAL->MAX_SIZE_ #define LOCAL_MAX_SIZE LOCAL->MAX_SIZE_
#define REMOTE_MAX_SIZE(wid) REMOTE(wid)->MAX_SIZE_ #define REMOTE_MAX_SIZE(wid) REMOTE(wid)->MAX_SIZE_
#define LOCAL_LastWTime LOCAL->LastWTime_
#define REMOTE_LastWTime(wid) REMOTE(wid)->LastWTime_

View File

@ -111,7 +111,7 @@ EXTERNAL char GLOBAL_pwd[YAP_FILENAME_MAX];
#endif #endif
//udi.c //udi.c
//struct udi_control_block RtreeCmd void //struct udi_control_block RtreeCmd void
EXTERNAL char* GLOBAL_RestoreFile; EXTERNAL const char* GLOBAL_RestoreFile;
//gprof.c //gprof.c
EXTERNAL Int GLOBAL_ProfCalls; EXTERNAL Int GLOBAL_ProfCalls;
EXTERNAL Int GLOBAL_ProfGCs; EXTERNAL Int GLOBAL_ProfGCs;
@ -139,8 +139,6 @@ EXTERNAL char* GLOBAL_Home;
/* ISO char conversion: I will make no comments */ /* ISO char conversion: I will make no comments */
EXTERNAL char* GLOBAL_CharConversionTable; EXTERNAL char* GLOBAL_CharConversionTable;
EXTERNAL char* GLOBAL_CharConversionTable2; EXTERNAL char* GLOBAL_CharConversionTable2;
/* time */
EXTERNAL void* GLOBAL_LastWTimePtr;
/* max priority */ /* max priority */
EXTERNAL int GLOBAL_MaxPriority; EXTERNAL int GLOBAL_MaxPriority;

View File

@ -111,7 +111,7 @@ typedef struct global_data {
#endif #endif
//udi.c //udi.c
//struct udi_control_block RtreeCmd void //struct udi_control_block RtreeCmd void
char* RestoreFile_; const char* RestoreFile_;
//gprof.c //gprof.c
Int ProfCalls_; Int ProfCalls_;
Int ProfGCs_; Int ProfGCs_;
@ -139,8 +139,6 @@ typedef struct global_data {
/* ISO char conversion: I will make no comments */ /* ISO char conversion: I will make no comments */
char* CharConversionTable_; char* CharConversionTable_;
char* CharConversionTable2_; char* CharConversionTable2_;
/* time */
void* LastWTimePtr_;
/* max priority */ /* max priority */
int MaxPriority_; int MaxPriority_;
} w_shared; } w_shared;

View File

@ -274,4 +274,6 @@ const char* Error_Function_;
Term SourceModule_; Term SourceModule_;
Term Including_; Term Including_;
size_t MAX_SIZE_; size_t MAX_SIZE_;
/* last call to walltime. */
uint64_t LastWTime_;
} w_local; } w_local;

View File

@ -140,7 +140,5 @@ static void InitGlobal(void) {
GLOBAL_CharConversionTable = NULL; GLOBAL_CharConversionTable = NULL;
GLOBAL_CharConversionTable2 = NULL; GLOBAL_CharConversionTable2 = NULL;
GLOBAL_LastWTimePtr = NULL;
GLOBAL_MaxPriority = 1200; GLOBAL_MaxPriority = 1200;
} }

View File

@ -274,4 +274,6 @@ static void InitWorker(int wid) {
REMOTE_SourceModule(wid) = 0; REMOTE_SourceModule(wid) = 0;
REMOTE_Including(wid) = TermNil; REMOTE_Including(wid) = TermNil;
REMOTE_MAX_SIZE(wid) = 1024L; REMOTE_MAX_SIZE(wid) = 1024L;
REMOTE_LastWTime(wid) = NULL;
} }

View File

@ -274,4 +274,6 @@ static void RestoreWorker(int wid USES_REGS) {
} }

View File

@ -16,8 +16,8 @@
*************************************************************************/ *************************************************************************/
/* static char SccsId[] = "X 4.3.3"; */ /* static char SccsId[] = "X 4.3.3"; */
#include "config.h"
#include "YapInterface.h" #include "YapInterface.h"
#include "config.h"
#include "cut_c.h" #include "cut_c.h"
@ -25,8 +25,8 @@
#undef HAVE_UNISTD_H #undef HAVE_UNISTD_H
#endif #endif
#ifdef _WIN32 /* Microsoft's Visual C++ Compiler */ #ifdef _WIN32 /* Microsoft's Visual C++ Compiler */
#include <windows.h>
#include <io.h> #include <io.h>
#include <windows.h>
#endif #endif
#include <stdio.h> #include <stdio.h>
#if HAVE_SYS_TYPES_H #if HAVE_SYS_TYPES_H
@ -58,7 +58,6 @@
#include <ieeefp.h> #include <ieeefp.h>
#endif #endif
static void do_top_goal(YAP_Term Goal); static void do_top_goal(YAP_Term Goal);
static void exec_top_level(int BootMode, YAP_init_args *iap); static void exec_top_level(int BootMode, YAP_init_args *iap);
@ -70,46 +69,35 @@ static void exec_top_level(int BootMode, YAP_init_args *iap);
long _stksize = 32000; long _stksize = 32000;
#endif #endif
static void do_top_goal(YAP_Term Goal) { YAP_RunGoalOnce(Goal); }
static int init_standard_system(int argc, char *argv[], YAP_init_args *iap) {
static void
do_top_goal (YAP_Term Goal)
{
YAP_RunGoalOnce(Goal);
}
static int
init_standard_system(int argc, char *argv[], YAP_init_args *iap)
{
int BootMode; int BootMode;
// BootMode = YAP_parse_yap_arguments(argc,argv,iap); BootMode = YAP_parse_yap_arguments(argc, argv, iap);
/* init memory */ /* init memory */
if (BootMode == YAP_BOOT_FROM_PROLOG || if (BootMode == YAP_BOOT_FROM_PROLOG ||
BootMode == YAP_FULL_BOOT_FROM_PROLOG) { BootMode == YAP_FULL_BOOT_FROM_PROLOG) {
int NewBootMode = YAP_Init(iap); int NewBootMode = YAP_Init(iap);
if (NewBootMode != YAP_BOOT_FROM_PROLOG && BootMode != YAP_FULL_BOOT_FROM_PROLOG) if (NewBootMode != YAP_BOOT_FROM_PROLOG &&
BootMode != YAP_FULL_BOOT_FROM_PROLOG)
BootMode = NewBootMode; BootMode = NewBootMode;
} else { } else {
BootMode = YAP_Init(iap); BootMode = YAP_Init(iap);
} }
if (iap->ErrorNo) { if (iap->ErrorNo) {
/* boot failed */ /* boot failed */
YAP_Error(iap->ErrorNo,0L,iap->ErrorCause); YAP_Error(iap->ErrorNo, 0L, iap->ErrorCause);
} }
return BootMode; return BootMode;
} }
static void exec_top_level(int BootMode, YAP_init_args *iap) {
static void
exec_top_level(int BootMode, YAP_init_args *iap)
{
YAP_Term atomfalse; YAP_Term atomfalse;
YAP_Atom livegoal; YAP_Atom livegoal;
if (BootMode == YAP_BOOT_FROM_SAVED_STACKS) if (BootMode == YAP_BOOT_FROM_SAVED_STACKS) {
{
/* continue executing from the frozen stacks */ /* continue executing from the frozen stacks */
YAP_ContinueGoal(); YAP_ContinueGoal();
} }
@ -119,49 +107,46 @@ exec_top_level(int BootMode, YAP_init_args *iap)
the atom false away ;-). the atom false away ;-).
*/ */
livegoal = YAP_FullLookupAtom("$live"); livegoal = YAP_FullLookupAtom("$live");
atomfalse = YAP_MkAtomTerm (YAP_FullLookupAtom("$false")); atomfalse = YAP_MkAtomTerm(YAP_FullLookupAtom("$false"));
while (YAP_GetValue (livegoal) != atomfalse) { while (YAP_GetValue(livegoal) != atomfalse) {
YAP_Reset( YAP_FULL_RESET ); YAP_Reset(YAP_FULL_RESET);
do_top_goal (YAP_MkAtomTerm (livegoal)); do_top_goal(YAP_MkAtomTerm(livegoal));
} }
YAP_Exit(EXIT_SUCCESS); YAP_Exit(EXIT_SUCCESS);
} }
//FILE *debugf; // FILE *debugf;
#ifdef LIGHT #ifdef LIGHT
int int _main(int argc, char **argv)
_main (int argc, char **argv)
#else #else
int int main(int argc, char **argv)
main (int argc, char **argv)
#endif #endif
{ {
int BootMode; int BootMode;
int i; int i;
YAP_init_args init_args;
BootMode = init_standard_system(argc, argv, &init_args); BootMode = init_standard_system(argc, argv, &init_args);
if (BootMode == YAP_BOOT_ERROR) { if (BootMode == YAP_BOOT_ERROR) {
fprintf(stderr,"[ FATAL ERROR: could not find saved state ]\n"); fprintf(stderr, "[ FATAL ERROR: could not find saved state ]\n");
exit(1); exit(1);
} }
/* Begin preprocessor code */ /* Begin preprocessor code */
if (BootMode != YAP_BOOT_FROM_SAVED_STACKS) { if (BootMode != YAP_BOOT_FROM_SAVED_STACKS) {
// process the definitions // process the definitions
for(i=0;i<init_args.def_c;++i) { for (i = 0; i < init_args.def_c; ++i) {
YAP_Term t_args[2],t_goal; YAP_Term t_args[2], t_goal;
t_args[0] = YAP_MkAtomTerm(YAP_LookupAtom(init_args.def_var[i])); t_args[0] = YAP_MkAtomTerm(YAP_LookupAtom(init_args.def_var[i]));
t_args[1] = YAP_MkAtomTerm(YAP_LookupAtom(init_args.def_value[i])); t_args[1] = YAP_MkAtomTerm(YAP_LookupAtom(init_args.def_value[i]));
t_goal = YAP_MkApplTerm(YAP_MkFunctor(YAP_LookupAtom("ypp_define"),2), 2, t_args); t_goal = YAP_MkApplTerm(YAP_MkFunctor(YAP_LookupAtom("ypp_define"), 2), 2,
t_args);
YAP_RunGoalOnce(t_goal); YAP_RunGoalOnce(t_goal);
} }
} }
YAP_Reset( YAP_FULL_RESET ); YAP_Reset(YAP_FULL_RESET);
/* End preprocessor code */ /* End preprocessor code */
exec_top_level(BootMode, &init_args); exec_top_level(BootMode, &init_args);
return(0); return (0);
} }

View File

@ -131,7 +131,7 @@ char pwd[YAP_FILENAME_MAX] void
//udi.c //udi.c
//struct udi_control_block RtreeCmd void //struct udi_control_block RtreeCmd void
char* RestoreFile void const char* RestoreFile void
//gprof.c //gprof.c
Int ProfCalls void Int ProfCalls void
@ -165,13 +165,9 @@ char* CharConversionTable =NULL
char* CharConversionTable2 =NULL char* CharConversionTable2 =NULL
/* time */
void* LastWTimePtr =NULL
/* max priority */ /* max priority */
int MaxPriority =1200 int MaxPriority =1200
END_GLOBAL_DATA END_GLOBAL_DATA

View File

@ -103,6 +103,8 @@ Term WokenGoals =0L TermToGlobalAdjust
Term AttsMutableList =0L TermToGlobalAdjust Term AttsMutableList =0L TermToGlobalAdjust
#endif #endif
// gc_stuff // gc_stuff
Term GcGeneration =0L TermToGlobalAdjust Term GcGeneration =0L TermToGlobalAdjust
Term GcPhase =0L TermToGlobalAdjust Term GcPhase =0L TermToGlobalAdjust
@ -319,4 +321,8 @@ Term Including =TermNil
size_t MAX_SIZE =1024L size_t MAX_SIZE =1024L
/* last call to walltime. */
uint64_t LastWTime =0
END_WORKER_LOCAL END_WORKER_LOCAL

View File

@ -26,37 +26,32 @@ static char SccsId[] = "%W% %G%";
#include "sysbits.h" #include "sysbits.h"
#if _MSC_VER || defined(__MINGW32__) #if _MSC_VER || defined(__MINGW32__)
#define SYSTEM_STAT _stat #define SYSTEM_STAT _stat
#else #else
#define SYSTEM_STAT stat #define SYSTEM_STAT stat
#endif #endif
static Int file_name_extension(USES_REGS1) {
static Int
file_name_extension(USES_REGS1)
{
Term t1 = Deref(ARG1); Term t1 = Deref(ARG1);
Term t2 = Deref(ARG2); Term t2 = Deref(ARG2);
Term t3 = Deref(ARG3); Term t3 = Deref(ARG3);
bool use_string = false; bool use_string = false;
loop: loop:
if (!IsVarTerm((t3))) { if (!IsVarTerm((t3))) {
const char *f; const char *f;
if (IsAtomTerm(t3)) { if (IsAtomTerm(t3)) {
f = AtomName( AtomOfTerm( t3 ) ); f = AtomName(AtomOfTerm(t3));
} else if (IsStringTerm( t3 )) { } else if (IsStringTerm(t3)) {
f = StringOfTerm( t3 ); f = StringOfTerm(t3);
use_string = true; use_string = true;
} else if (IsApplTerm(t3) && FunctorOfTerm(t3) == FunctorSlash) { } else if (IsApplTerm(t3) && FunctorOfTerm(t3) == FunctorSlash) {
// descend a compound term of the form a/b. // descend a compound term of the form a/b.
Term tn1 = MkVarTerm(), tf1; Term tn1 = MkVarTerm(), tf1;
Term ts[2]; Term ts[2];
ts[0] = ArgOfTerm(1,t3); ts[0] = ArgOfTerm(1, t3);
ts[1] = tn1; ts[1] = tn1;
tf1 = Yap_MkApplTerm( FunctorSlash, 2, ts ); tf1 = Yap_MkApplTerm(FunctorSlash, 2, ts);
if (!Yap_unify(ARG1, tf1)) { if (!Yap_unify(ARG1, tf1)) {
return false; return false;
} }
@ -69,69 +64,70 @@ file_name_extension(USES_REGS1)
char *pts = strrchr(f, '/'); char *pts = strrchr(f, '/');
#if WIN32_ssss #if WIN32_ssss
char *pts1 = strrchr(f, '\\'); char *pts1 = strrchr(f, '\\');
if (pts11 > pts) pts = pts1; if (pts11 > pts)
pts = pts1;
#endif #endif
char *ss = strrchr(f, '.'); char *ss = strrchr(f, '.');
if (pts > ss) ss = NULL; if (pts > ss)
ss = NULL;
if (use_string) { if (use_string) {
char *tmp; char *tmp;
if (!ss) { if (!ss) {
return Yap_unify(ARG1, ARG3) && return Yap_unify(ARG1, ARG3) && Yap_unify(ARG2, MkStringTerm(""));
Yap_unify(ARG2, MkStringTerm( "" ) );
} }
tmp = malloc((ss - f)+1); tmp = malloc((ss - f) + 1);
strncpy(tmp, f, (ss)-f); strncpy(tmp, f, (ss)-f);
if (!Yap_unify(ARG1, MkStringTerm( tmp )) ) { if (!Yap_unify(ARG1, MkStringTerm(tmp))) {
if (tmp != f) if (tmp != f)
free( tmp ); free(tmp);
return false; return false;
} }
if (tmp != f) if (tmp != f)
free(tmp); free(tmp);
// without and with dot // without and with dot
if (!Yap_unify(ARG2, MkStringTerm(ss+1))) if (!Yap_unify(ARG2, MkStringTerm(ss + 1)))
return Yap_unify(ARG2, MkStringTerm(ss)); return Yap_unify(ARG2, MkStringTerm(ss));
return true; return true;
} else { } else {
char *tmp; char *tmp;
if (!ss) { if (!ss) {
return Yap_unify(ARG1, ARG3) && return Yap_unify(ARG1, ARG3) &&
Yap_unify(ARG2, MkAtomTerm(Yap_LookupAtom( "" ) )); Yap_unify(ARG2, MkAtomTerm(Yap_LookupAtom("")));
} }
tmp = malloc((ss - f)+1); tmp = malloc((ss - f) + 1);
strncpy(tmp, f, (ss)-f); strncpy(tmp, f, (ss)-f);
if (!Yap_unify(ARG1, MkAtomTerm(Yap_LookupAtom( tmp ))) ) { if (!Yap_unify(ARG1, MkAtomTerm(Yap_LookupAtom(tmp)))) {
if (tmp != f) if (tmp != f)
free( tmp ); free(tmp);
return false; return false;
} }
if (tmp != f) if (tmp != f)
free(tmp); free(tmp);
// without and with dot // without and with dot
if (!Yap_unify(ARG2, MkAtomTerm(Yap_LookupAtom(ss+1)))) if (!Yap_unify(ARG2, MkAtomTerm(Yap_LookupAtom(ss + 1))))
return Yap_unify(ARG2, MkAtomTerm(Yap_LookupAtom(ss))); return Yap_unify(ARG2, MkAtomTerm(Yap_LookupAtom(ss)));
return true; return true;
} }
} else { } else {
char s[MAXPATHLEN+1]; char s[MAXPATHLEN + 1];
const char *f1, *f2; const char *f1, *f2;
loop1: loop1:
if (IsVarTerm(t1)) { if (IsVarTerm(t1)) {
Yap_Error(INSTANTIATION_ERROR, t1, "access"); Yap_Error(INSTANTIATION_ERROR, t1, "access");
return FALSE; return FALSE;
} else if (IsAtomTerm(t1)) { } else if (IsAtomTerm(t1)) {
f1 = AtomName( AtomOfTerm( t1 ) ); f1 = AtomName(AtomOfTerm(t1));
} else if (IsStringTerm( t1 )) { } else if (IsStringTerm(t1)) {
f1 = StringOfTerm( t1 ); f1 = StringOfTerm(t1);
use_string = true; use_string = true;
} else if (IsApplTerm(t1) && FunctorOfTerm(t1) == FunctorSlash) { } else if (IsApplTerm(t1) && FunctorOfTerm(t1) == FunctorSlash) {
// descend a compound term of the form a/b. // descend a compound term of the form a/b.
Term tn1 = MkVarTerm(), tf1; Term tn1 = MkVarTerm(), tf1;
Term ts[2]; Term ts[2];
ts[0] = ArgOfTerm(1,t1); ts[0] = ArgOfTerm(1, t1);
ts[1] = tn1; ts[1] = tn1;
tf1 = Yap_MkApplTerm( FunctorSlash, 2, ts ); tf1 = Yap_MkApplTerm(FunctorSlash, 2, ts);
if (!Yap_unify(ARG3, tf1)) { if (!Yap_unify(ARG3, tf1)) {
return false; return false;
} }
@ -146,43 +142,41 @@ file_name_extension(USES_REGS1)
Yap_Error(INSTANTIATION_ERROR, t2, "access"); Yap_Error(INSTANTIATION_ERROR, t2, "access");
return FALSE; return FALSE;
} else if (IsAtomTerm(t2)) { } else if (IsAtomTerm(t2)) {
f2 = AtomName( AtomOfTerm( t2 ) ); f2 = AtomName(AtomOfTerm(t2));
} else if (IsStringTerm( t1 )) { } else if (IsStringTerm(t1)) {
f2 = StringOfTerm( t2 ); f2 = StringOfTerm(t2);
use_string = true; use_string = true;
} else { } else {
Yap_Error(TYPE_ERROR_ATOMIC, t2, "file_name_extension/3"); Yap_Error(TYPE_ERROR_ATOMIC, t2, "file_name_extension/3");
return false; return false;
} }
if (f2[0] == '.') { if (f2[0] == '.') {
strncpy(s,f1,MAXPATHLEN); strncpy(s, f1, MAXPATHLEN);
strncat(s,f2,MAXPATHLEN); strncat(s, f2, MAXPATHLEN);
if (use_string) if (use_string)
return Yap_unify_constant(ARG3,MkStringTerm(s)); return Yap_unify_constant(ARG3, MkStringTerm(s));
else else
return Yap_unify_constant(ARG3,MkAtomTerm(Yap_LookupAtom(s))); return Yap_unify_constant(ARG3, MkAtomTerm(Yap_LookupAtom(s)));
} else { } else {
strncpy(s,f1,MAXPATHLEN); strncpy(s, f1, MAXPATHLEN);
strncat(s,".",MAXPATHLEN); strncat(s, ".", MAXPATHLEN);
strncat(s,f2,MAXPATHLEN); strncat(s, f2, MAXPATHLEN);
if (use_string) if (use_string)
return Yap_unify_constant(ARG3,MkStringTerm(s)); return Yap_unify_constant(ARG3, MkStringTerm(s));
else else
return Yap_unify_constant(ARG3,MkAtomTerm(Yap_LookupAtom(s))); return Yap_unify_constant(ARG3, MkAtomTerm(Yap_LookupAtom(s)));
} }
} }
} }
static Int static Int access_path(USES_REGS1) {
access_path(USES_REGS1)
{
Term tname = Deref(ARG1); Term tname = Deref(ARG1);
char *file_name; char *file_name;
if (IsVarTerm(tname)) { if (IsVarTerm(tname)) {
Yap_Error(INSTANTIATION_ERROR, tname, "access"); Yap_Error(INSTANTIATION_ERROR, tname, "access");
return FALSE; return FALSE;
} else if (!IsAtomTerm (tname)) { } else if (!IsAtomTerm(tname)) {
Yap_Error(TYPE_ERROR_ATOM, tname, "access"); Yap_Error(TYPE_ERROR_ATOM, tname, "access");
return FALSE; return FALSE;
} else { } else {
@ -201,16 +195,14 @@ access_path(USES_REGS1)
} }
} }
static Int static Int exists_file(USES_REGS1) {
exists_file(USES_REGS1)
{
Term tname = Deref(ARG1); Term tname = Deref(ARG1);
char *file_name; char *file_name;
if (IsVarTerm(tname)) { if (IsVarTerm(tname)) {
Yap_Error(INSTANTIATION_ERROR, tname, "access"); Yap_Error(INSTANTIATION_ERROR, tname, "access");
return FALSE; return FALSE;
} else if (!IsAtomTerm (tname)) { } else if (!IsAtomTerm(tname)) {
Yap_Error(TYPE_ERROR_ATOM, tname, "access"); Yap_Error(TYPE_ERROR_ATOM, tname, "access");
return FALSE; return FALSE;
} else { } else {
@ -225,7 +217,7 @@ exists_file(USES_REGS1)
#if _MSC_VER #if _MSC_VER
return ss.st_mode & S_IFREG; return ss.st_mode & S_IFREG;
#else #else
return (_stat(ss.st_mode)); return S_ISREG(ss.st_mode);
#endif #endif
#else #else
return FALSE; return FALSE;
@ -233,16 +225,14 @@ exists_file(USES_REGS1)
} }
} }
static Int static Int file_exists(USES_REGS1) {
file_exists(USES_REGS1)
{
Term tname = Deref(ARG1); Term tname = Deref(ARG1);
char *file_name; char *file_name;
if (IsVarTerm(tname)) { if (IsVarTerm(tname)) {
Yap_Error(INSTANTIATION_ERROR, tname, "access"); Yap_Error(INSTANTIATION_ERROR, tname, "access");
return FALSE; return FALSE;
} else if (!IsAtomTerm (tname)) { } else if (!IsAtomTerm(tname)) {
Yap_Error(TYPE_ERROR_ATOM, tname, "access"); Yap_Error(TYPE_ERROR_ATOM, tname, "access");
return FALSE; return FALSE;
} else { } else {
@ -253,7 +243,8 @@ file_exists(USES_REGS1)
if (SYSTEM_STAT(file_name, &ss) != 0) { if (SYSTEM_STAT(file_name, &ss) != 0) {
if (errno == ENOENT) if (errno == ENOENT)
return false; return false;
PlIOError(SYSTEM_ERROR_OPERATING_SYSTEM, tname, "error %s", strerror(errno) ); PlIOError(SYSTEM_ERROR_OPERATING_SYSTEM, tname, "error %s",
strerror(errno));
return false; return false;
} }
return true; return true;
@ -263,16 +254,13 @@ file_exists(USES_REGS1)
} }
} }
static Int time_file(USES_REGS1) {
static Int
time_file(USES_REGS1)
{
Term tname = Deref(ARG1); Term tname = Deref(ARG1);
if (IsVarTerm(tname)) { if (IsVarTerm(tname)) {
Yap_Error(INSTANTIATION_ERROR, tname, "access"); Yap_Error(INSTANTIATION_ERROR, tname, "access");
return FALSE; return FALSE;
} else if (!IsAtomTerm (tname)) { } else if (!IsAtomTerm(tname)) {
Yap_Error(TYPE_ERROR_ATOM, tname, "access"); Yap_Error(TYPE_ERROR_ATOM, tname, "access");
return FALSE; return FALSE;
} else { } else {
@ -282,28 +270,28 @@ time_file(USES_REGS1)
HANDLE hdl; HANDLE hdl;
Term rc; Term rc;
if ((hdl = CreateFile( n, 0, 0, NULL, OPEN_EXISTING, 0, 0)) == 0) if ((hdl = CreateFile(n, 0, 0, NULL, OPEN_EXISTING, 0, 0)) == 0)
return false; return false;
if (GetFileTime(hdl, NULL,NULL,&ft)) if (GetFileTime(hdl, NULL, NULL, &ft))
return false; return false;
// Convert the last-write time to local time. // Convert the last-write time to local time.
// FileTimeToSystemTime(&ftWrite, &stUTC); // FileTimeToSystemTime(&ftWrite, &stUTC);
// SystemTimeToTzSpecificLocalTime(NULL, &stUTC, &stLocal); // SystemTimeToTzSpecificLocalTime(NULL, &stUTC, &stLocal);
CloseHandle( hdl ); CloseHandle(hdl);
ULONGLONG qwResult; ULONGLONG qwResult;
// Copy the time into a quadword. // Copy the time into a quadword.
qwResult = (((ULONGLONG) ft.dwHighDateTime) << 32) + ft.dwLowDateTime; qwResult = (((ULONGLONG)ft.dwHighDateTime) << 32) + ft.dwLowDateTime;
#if SIZEOF_INT_P==8 #if SIZEOF_INT_P == 8
rc = MkIntegerTerm(qwResult); rc = MkIntegerTerm(qwResult);
#elif USE_GMP #elif USE_GMP
char s[64]; char s[64];
MP_INT rop; MP_INT rop;
snprintf(s, 64, "%I64d", (long long int)n); snprintf(s, 64, "%I64d", (long long int)n);
mpz_init_set_str (&rop, s, 10); mpz_init_set_str(&rop, s, 10);
rc = Yap_MkBigNumTerm((void *)&rop) PASS_REGS); rc = Yap_MkBigNumTerm((void *)&rop) PASS_REGS);
#else #else
rc = MkIntegerTerm(ft.dwHighDateTime); rc = MkIntegerTerm(ft.dwHighDateTime);
#endif #endif
return Yap_unify(ARG2, rc); return Yap_unify(ARG2, rc);
@ -321,36 +309,37 @@ time_file(USES_REGS1)
} }
} }
static Int static Int file_size(USES_REGS1) {
file_size(USES_REGS1)
{
int rc; int rc;
Int sno = Yap_CheckStream (ARG1, (Input_Stream_f | Output_Stream_f | Socket_Stream_f), "file_size/2"); Int sno = Yap_CheckStream(
ARG1, (Input_Stream_f | Output_Stream_f | Socket_Stream_f),
"file_size/2");
if (sno < 0) if (sno < 0)
return (FALSE); return (FALSE);
if (GLOBAL_Stream[sno]. status & Seekable_Stream_f && if (GLOBAL_Stream[sno].status & Seekable_Stream_f &&
!(GLOBAL_Stream[sno]. status & (InMemory_Stream_f|Socket_Stream_f|Pipe_Stream_f))) { !(GLOBAL_Stream[sno].status &
(InMemory_Stream_f | Socket_Stream_f | Pipe_Stream_f))) {
// there // there
struct stat file_stat; struct stat file_stat;
if ((rc = fstat(fileno(GLOBAL_Stream[sno].file), &file_stat) )< 0) { if ((rc = fstat(fileno(GLOBAL_Stream[sno].file), &file_stat)) < 0) {
UNLOCK(GLOBAL_Stream[sno].streamlock); UNLOCK(GLOBAL_Stream[sno].streamlock);
if (rc == ENOENT) if (rc == ENOENT)
PlIOError( EXISTENCE_ERROR_SOURCE_SINK, ARG1, "%s in file_size", strerror(errno)); PlIOError(EXISTENCE_ERROR_SOURCE_SINK, ARG1, "%s in file_size",
strerror(errno));
else else
PlIOError( PERMISSION_ERROR_INPUT_STREAM, ARG1, "%s in file_size", strerror(errno)); PlIOError(PERMISSION_ERROR_INPUT_STREAM, ARG1, "%s in file_size",
strerror(errno));
return false; return false;
} }
// and back again // and back again
UNLOCK(GLOBAL_Stream[sno].streamlock); UNLOCK(GLOBAL_Stream[sno].streamlock);
return Yap_unify_constant( ARG2, MkIntegerTerm( file_stat.st_size) ); return Yap_unify_constant(ARG2, MkIntegerTerm(file_stat.st_size));
} }
UNLOCK(GLOBAL_Stream[sno].streamlock); UNLOCK(GLOBAL_Stream[sno].streamlock);
return false; return false;
} }
static Int static Int access_file(USES_REGS1) {
access_file(USES_REGS1)
{
Term tname = Deref(ARG1); Term tname = Deref(ARG1);
Term tmode = Deref(ARG2); Term tmode = Deref(ARG2);
char *ares; char *ares;
@ -359,7 +348,7 @@ access_file(USES_REGS1)
if (IsVarTerm(tmode)) { if (IsVarTerm(tmode)) {
Yap_Error(INSTANTIATION_ERROR, tmode, "access_file/2"); Yap_Error(INSTANTIATION_ERROR, tmode, "access_file/2");
return FALSE; return FALSE;
} else if (!IsAtomTerm (tmode)) { } else if (!IsAtomTerm(tmode)) {
Yap_Error(TYPE_ERROR_ATOM, tname, "access_file/2"); Yap_Error(TYPE_ERROR_ATOM, tname, "access_file/2");
return FALSE; return FALSE;
} }
@ -367,13 +356,13 @@ access_file(USES_REGS1)
if (IsVarTerm(tname)) { if (IsVarTerm(tname)) {
Yap_Error(INSTANTIATION_ERROR, tname, "access_file/2"); Yap_Error(INSTANTIATION_ERROR, tname, "access_file/2");
return FALSE; return FALSE;
} else if (!IsAtomTerm (tname)) { } else if (!IsAtomTerm(tname)) {
Yap_Error(TYPE_ERROR_ATOM, tname, "access_file/2"); Yap_Error(TYPE_ERROR_ATOM, tname, "access_file/2");
return FALSE; return FALSE;
} else { } else {
if (atmode == AtomNone) if (atmode == AtomNone)
return TRUE; return TRUE;
if (! (ares = RepAtom(AtomOfTerm(tname))->StrOfAE)) if (!(ares = RepAtom(AtomOfTerm(tname))->StrOfAE))
return FALSE; return FALSE;
} }
#if HAVE_ACCESS #if HAVE_ACCESS
@ -402,7 +391,7 @@ access_file(USES_REGS1)
return false; return false;
} }
return true; return true;
} }
#else #else
{ {
int mode; int mode;
@ -445,16 +434,14 @@ access_file(USES_REGS1)
#endif #endif
} }
static Int static Int exists_directory(USES_REGS1) {
exists_directory(USES_REGS1)
{
Term tname = Deref(ARG1); Term tname = Deref(ARG1);
char *file_name; char *file_name;
if (IsVarTerm(tname)) { if (IsVarTerm(tname)) {
Yap_Error(INSTANTIATION_ERROR, tname, "exists_directory/1"); Yap_Error(INSTANTIATION_ERROR, tname, "exists_directory/1");
return FALSE; return FALSE;
} else if (!IsAtomTerm (tname)) { } else if (!IsAtomTerm(tname)) {
Yap_Error(TYPE_ERROR_ATOM, tname, "exists_directory/1"); Yap_Error(TYPE_ERROR_ATOM, tname, "exists_directory/1");
return FALSE; return FALSE;
} else { } else {
@ -473,19 +460,16 @@ exists_directory(USES_REGS1)
} }
} }
static Int is_absolute_file_name(USES_REGS1) { /* file_base_name(Stream,N) */
static Int
is_absolute_file_name ( USES_REGS1 )
{ /* file_base_name(Stream,N) */
Term t = Deref(ARG1); Term t = Deref(ARG1);
Atom at; Atom at;
if (IsVarTerm(t)) { if (IsVarTerm(t)) {
Yap_Error(INSTANTIATION_ERROR, t, "file_base_name/2"); Yap_Error(INSTANTIATION_ERROR, t, "file_base_name/2");
return FALSE; return FALSE;
} }
const char *buf = Yap_TextTermToText( t, NULL, 0); const char *buf = Yap_TextTermToText(t, NULL, 0);
if (buf) { if (buf) {
return Yap_IsAbsolutePath( buf ); return Yap_IsAbsolutePath(buf);
} else { } else {
at = AtomOfTerm(t); at = AtomOfTerm(t);
if (IsWideAtom(at)) { if (IsWideAtom(at)) {
@ -499,9 +483,7 @@ is_absolute_file_name ( USES_REGS1 )
return false; return false;
} }
static Int static Int file_base_name(USES_REGS1) { /* file_base_name(Stream,N) */
file_base_name ( USES_REGS1 )
{ /* file_base_name(Stream,N) */
Term t = Deref(ARG1); Term t = Deref(ARG1);
Atom at; Atom at;
if (IsVarTerm(t)) { if (IsVarTerm(t)) {
@ -512,30 +494,31 @@ file_base_name ( USES_REGS1 )
if (IsWideAtom(at)) { if (IsWideAtom(at)) {
wchar_t *c = RepAtom(at)->WStrOfAE; wchar_t *c = RepAtom(at)->WStrOfAE;
Int i = wcslen(c); Int i = wcslen(c);
while (i && !Yap_dir_separator((int)c[--i])); while (i && !Yap_dir_separator((int)c[--i]))
return Yap_unify(ARG2, MkAtomTerm(Yap_LookupWideAtom(c+i))); ;
return Yap_unify(ARG2, MkAtomTerm(Yap_LookupWideAtom(c + i)));
} else { } else {
const char *c = RepAtom(at)->StrOfAE; const char *c = RepAtom(at)->StrOfAE;
const char *s; const char *s;
#if HAVE_BASENAME && 0 // DISABLED: Linux basename is not compatible with file_base_name in SWI and GNU #if HAVE_BASENAME && 0 // DISABLED: Linux basename is not compatible with
char c1[YAP_FILENAME_MAX+1]; // file_base_name in SWI and GNU
strncpy( c1, c, YAP_FILENAME_MAX); char c1[YAP_FILENAME_MAX + 1];
s = basename( c1 ); strncpy(c1, c, YAP_FILENAME_MAX);
s = basename(c1);
#else #else
Int i = strlen(c); Int i = strlen(c);
while (i && !Yap_dir_separator((int)c[--i])); while (i && !Yap_dir_separator((int)c[--i]))
;
if (Yap_dir_separator((int)c[i])) { if (Yap_dir_separator((int)c[i])) {
i++; i++;
} }
s = c+i; s = c + i;
#endif #endif
return Yap_unify(ARG2, MkAtomTerm(Yap_LookupAtom(s))); return Yap_unify(ARG2, MkAtomTerm(Yap_LookupAtom(s)));
} }
} }
static Int static Int file_directory_name(USES_REGS1) { /* file_directory_name(Stream,N) */
file_directory_name ( USES_REGS1 )
{ /* file_directory_name(Stream,N) */
Term t = Deref(ARG1); Term t = Deref(ARG1);
Atom at; Atom at;
if (IsVarTerm(t)) { if (IsVarTerm(t)) {
@ -544,10 +527,11 @@ file_directory_name ( USES_REGS1 )
} }
at = AtomOfTerm(t); at = AtomOfTerm(t);
if (IsWideAtom(at)) { if (IsWideAtom(at)) {
wchar_t s[YAP_FILENAME_MAX+1]; wchar_t s[YAP_FILENAME_MAX + 1];
wchar_t *c = RepAtom(at)->WStrOfAE; wchar_t *c = RepAtom(at)->WStrOfAE;
Int i = wcslen(c); Int i = wcslen(c);
while (i && !Yap_dir_separator((int)c[--i])); while (i && !Yap_dir_separator((int)c[--i]))
;
if (Yap_dir_separator((int)c[i])) { if (Yap_dir_separator((int)c[i])) {
i++; i++;
} }
@ -555,15 +539,17 @@ file_directory_name ( USES_REGS1 )
return Yap_unify(ARG2, MkAtomTerm(Yap_LookupWideAtom(s))); return Yap_unify(ARG2, MkAtomTerm(Yap_LookupWideAtom(s)));
} else { } else {
const char *c = RepAtom(at)->StrOfAE; const char *c = RepAtom(at)->StrOfAE;
#if HAVE_BASENAME && 0 // DISABLED: Linux basename is not compatible with file_base_name in SWI and GNU #if HAVE_BASENAME && 0 // DISABLED: Linux basename is not compatible with
// file_base_name in SWI and GNU
const char *s; const char *s;
char c1[YAP_FILENAME_MAX+1]; char c1[YAP_FILENAME_MAX + 1];
strncpy( c1, c, YAP_FILENAME_MAX); strncpy(c1, c, YAP_FILENAME_MAX);
s = dirname( c1 ); s = dirname(c1);
#else #else
char s[YAP_FILENAME_MAX+1]; char s[YAP_FILENAME_MAX + 1];
Int i = strlen(c); Int i = strlen(c);
while (i && !Yap_dir_separator((int)c[--i])); while (i && !Yap_dir_separator((int)c[--i]))
;
strncpy(s, c, i); strncpy(s, c, i);
s[i] = '\0'; s[i] = '\0';
#endif #endif
@ -571,37 +557,35 @@ file_directory_name ( USES_REGS1 )
} }
} }
static Int same_file(USES_REGS1) {
static Int
same_file( USES_REGS1 ) {
char *f1 = RepAtom(AtomOfTerm(Deref(ARG1)))->StrOfAE; char *f1 = RepAtom(AtomOfTerm(Deref(ARG1)))->StrOfAE;
char *f2 = RepAtom(AtomOfTerm(Deref(ARG2)))->StrOfAE; char *f2 = RepAtom(AtomOfTerm(Deref(ARG2)))->StrOfAE;
if (strcmp(f1,f2) == 0) if (strcmp(f1, f2) == 0)
return TRUE; return TRUE;
#if HAVE_LSTAT #if HAVE_LSTAT
{ {
int out; int out;
struct stat *b1, *b2; struct stat *b1, *b2;
while ((char *)HR+sizeof(struct stat)*2 > (char *)(ASP-1024)) { while ((char *)HR + sizeof(struct stat) * 2 > (char *)(ASP - 1024)) {
if (!Yap_gcl(2*sizeof(struct stat), 2, ENV,Yap_gcP() ) ) { if (!Yap_gcl(2 * sizeof(struct stat), 2, ENV, Yap_gcP())) {
Yap_Error(RESOURCE_ERROR_STACK, TermNil, LOCAL_ErrorMessage); Yap_Error(RESOURCE_ERROR_STACK, TermNil, LOCAL_ErrorMessage);
return FALSE; return FALSE;
} }
} }
b1 = (struct stat *)HR; b1 = (struct stat *)HR;
b2 = b1+1; b2 = b1 + 1;
if (strcmp(f1,"user_input") == 0) { if (strcmp(f1, "user_input") == 0) {
if (fstat(fileno(GLOBAL_Stream[0].file), b1) == -1) { if (fstat(fileno(GLOBAL_Stream[0].file), b1) == -1) {
/* file does not exist, but was opened? Return -1 */ /* file does not exist, but was opened? Return -1 */
return FALSE; return FALSE;
} }
} else if (strcmp(f1,"user_output") == 0) { } else if (strcmp(f1, "user_output") == 0) {
if (fstat(fileno(GLOBAL_Stream[1].file), b1) == -1) { if (fstat(fileno(GLOBAL_Stream[1].file), b1) == -1) {
/* file does not exist, but was opened? Return -1 */ /* file does not exist, but was opened? Return -1 */
return FALSE; return FALSE;
} }
} else if (strcmp(f1,"user_error") == 0) { } else if (strcmp(f1, "user_error") == 0) {
if (fstat(fileno(GLOBAL_Stream[2].file), b1) == -1) { if (fstat(fileno(GLOBAL_Stream[2].file), b1) == -1) {
/* file does not exist, but was opened? Return -1 */ /* file does not exist, but was opened? Return -1 */
return FALSE; return FALSE;
@ -610,17 +594,17 @@ same_file( USES_REGS1 ) {
/* file does not exist, but was opened? Return -1 */ /* file does not exist, but was opened? Return -1 */
return FALSE; return FALSE;
} }
if (strcmp(f2,"user_input") == 0) { if (strcmp(f2, "user_input") == 0) {
if (fstat(fileno(GLOBAL_Stream[0].file), b2) == -1) { if (fstat(fileno(GLOBAL_Stream[0].file), b2) == -1) {
/* file does not exist, but was opened? Return -1 */ /* file does not exist, but was opened? Return -1 */
return FALSE; return FALSE;
} }
} else if (strcmp(f2,"user_output") == 0) { } else if (strcmp(f2, "user_output") == 0) {
if (fstat(fileno(GLOBAL_Stream[1].file), b2) == -1) { if (fstat(fileno(GLOBAL_Stream[1].file), b2) == -1) {
/* file does not exist, but was opened? Return -1 */ /* file does not exist, but was opened? Return -1 */
return FALSE; return FALSE;
} }
} else if (strcmp(f2,"user_error") == 0) { } else if (strcmp(f2, "user_error") == 0) {
if (fstat(fileno(GLOBAL_Stream[2].file), b2) == -1) { if (fstat(fileno(GLOBAL_Stream[2].file), b2) == -1) {
/* file does not exist, but was opened? Return -1 */ /* file does not exist, but was opened? Return -1 */
return FALSE; return FALSE;
@ -631,7 +615,9 @@ same_file( USES_REGS1 ) {
} }
out = (b1->st_ino == b2->st_ino out = (b1->st_ino == b2->st_ino
#ifdef __LCC__ #ifdef __LCC__
&& memcmp((const void *)&(b1->st_dev),(const void *)&(b2->st_dev),sizeof(buf1.st_dev)) == 0 &&
memcmp((const void *)&(b1->st_dev), (const void *)&(b2->st_dev),
sizeof(buf1.st_dev)) == 0
#else #else
&& b1->st_dev == b2->st_dev && b1->st_dev == b2->st_dev
#endif #endif
@ -639,26 +625,25 @@ same_file( USES_REGS1 ) {
return out; return out;
} }
#else #else
return(FALSE); return (FALSE);
#endif #endif
} }
void Yap_InitFiles(void) {
void Yap_InitCPred("file_base_name", 2, file_base_name, SafePredFlag);
Yap_InitFiles( void ) Yap_InitCPred("file_directory_name", 2, file_directory_name, SafePredFlag);
{ Yap_InitCPred("is_absolute_file_name", 1, is_absolute_file_name,
Yap_InitCPred ("file_base_name", 2, file_base_name, SafePredFlag); SafePredFlag);
Yap_InitCPred ("file_directory_name", 2, file_directory_name, SafePredFlag); Yap_InitCPred("same_file", 2, same_file, SafePredFlag | SyncPredFlag);
Yap_InitCPred ("is_absolute_file_name", 1, is_absolute_file_name, SafePredFlag); Yap_InitCPred("$access_file", 2, access_file, SafePredFlag | SyncPredFlag);
Yap_InitCPred ("same_file", 2, same_file, SafePredFlag|SyncPredFlag); Yap_InitCPred("access", 1, access_path, SafePredFlag | SyncPredFlag);
Yap_InitCPred ("$access_file", 2, access_file, SafePredFlag|SyncPredFlag); Yap_InitCPred("exists_directory", 1, exists_directory,
Yap_InitCPred ("access", 1, access_path, SafePredFlag|SyncPredFlag); SafePredFlag | SyncPredFlag);
Yap_InitCPred ("exists_directory", 1, exists_directory, SafePredFlag|SyncPredFlag); Yap_InitCPred("exists_file", 1, exists_file, SafePredFlag | SyncPredFlag);
Yap_InitCPred ("exists_file", 1, exists_file, SafePredFlag|SyncPredFlag); Yap_InitCPred("$file_exists", 1, file_exists, SafePredFlag | SyncPredFlag);
Yap_InitCPred ("$file_exists", 1, file_exists, SafePredFlag|SyncPredFlag); Yap_InitCPred("time_file64", 2, time_file, SafePredFlag | SyncPredFlag);
Yap_InitCPred ("time_file64", 2, time_file, SafePredFlag|SyncPredFlag); Yap_InitCPred("time_file", 2, time_file, SafePredFlag | SyncPredFlag);
Yap_InitCPred ("time_file", 2, time_file, SafePredFlag|SyncPredFlag); Yap_InitCPred("file_size", 2, file_size, SafePredFlag | SyncPredFlag);
Yap_InitCPred ("file_size", 2,file_size, SafePredFlag|SyncPredFlag); Yap_InitCPred("file_name_extension", 3, file_name_extension,
Yap_InitCPred ("file_name_extension", 3, file_name_extension, SafePredFlag|SyncPredFlag); SafePredFlag | SyncPredFlag);
} }

File diff suppressed because it is too large Load Diff

View File

@ -628,6 +628,8 @@ Yap_walltime (void)
void void
Yap_InitWTime (void) Yap_InitWTime (void)
{ {
// start thread 0
REMOTE_LastWTime(0) =
Yap_StartOfWTimes = ((uint64_t)times(NULL))*10000000/TicksPerSec; Yap_StartOfWTimes = ((uint64_t)times(NULL))*10000000/TicksPerSec;
} }

View File

@ -26,8 +26,8 @@
#include <stdio.h> #include <stdio.h>
#include <wchar.h> #include <wchar.h>
#include <Yatom.h>
#include "os/YapIOConfig.h" #include "os/YapIOConfig.h"
#include <Yatom.h>
#ifndef _PL_WRITE_ #ifndef _PL_WRITE_
@ -161,7 +161,7 @@ INLINE_ONLY inline EXTERN Term MkCharTerm(Int c);
* @return the term. * @return the term.
*/ */
INLINE_ONLY inline EXTERN Term MkCharTerm(Int c) { INLINE_ONLY inline EXTERN Term MkCharTerm(Int c) {
int cs[2]; wchar_t cs[2];
if (c < 0) if (c < 0)
return MkAtomTerm(AtomEof); return MkAtomTerm(AtomEof);
cs[0] = c; cs[0] = c;
@ -169,4 +169,7 @@ INLINE_ONLY inline EXTERN Term MkCharTerm(Int c) {
return MkAtomTerm(Yap_LookupMaybeWideAtom(cs)); return MkAtomTerm(Yap_LookupMaybeWideAtom(cs));
} }
/// UT when yap started
uint64_t Yap_StartOfWTimes;
#endif #endif

View File

@ -974,7 +974,107 @@ int AddNamedVar(namedvars varmap, const char *varname) {
void SetNamedVarValuesAt(namedvars varmap, int index, double dvalue, int ivalue, void SetNamedVarValuesAt(namedvars varmap, int index, double dvalue, int ivalue,
void *dynvalue) { void *dynvalue) {
varmap.dvalue[index] = dvalue; varmap.dvalue[index] = dvalue;all_names -o packages/myddas/odbc/libYapodbc.1.0.0.dylib -install_name @rpath/libYapodbc.1.dylib packages/myddas/odbc/CMakeFiles/Yapodbc.dir/myddas_odbc.c.o libYap.6.3.4.dylib /usr/lib/libiodbc.dylib -ldl -lm /usr/local/lib/libgmp.dylib utf8proc/libutf8proc.1.3.0.dylib /usr/local/opt/readline/lib/libreadline.dylib /usr/lib/libncurses.dylib -Wl,-rpath,/Users/vsc/git/yap-6.3/Debug && :
[7/87] : && /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/cc -g -isysroot /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.11.sdk -dynamiclib -Wl,-headerpad_max_install_names -o packages/myddas/postgres/libYappostgres.1.0.0.dylib -install_name @rpath/libYappostgres.1.dylib packages/myddas/postgres/CMakeFiles/Yappostgres.dir/myddas_postgres.c.o libYap.6.3.4.dylib -lpq -ldl -lm /usr/local/lib/libgmp.dylib utf8proc/libutf8proc.1.3.0.dylib /usr/local/opt/readline/lib/libreadline.dylib /usr/lib/libncurses.dylib -Wl,-rpath,/Users/vsc/git/yap-6.3/Debug && :
[8/87] : && /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/cc -g -isysroot /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.11.sdk -dynamiclib -Wl,-headerpad_max_install_names -o packages/myddas/sqlite3/libYapsqlite3.1.0.0.dylib -install_name @rpath/libYapsqlite3.1.dylib packages/myddas/sqlite3/CMakeFiles/Yapsqlite3.dir/myddas_sqlite3.c.o /usr/local/opt/sqlite/lib/libsqlite3.dylib libYap.6.3.4.dylib -ldl -lm /usr/local/lib/libgmp.dylib utf8proc/libutf8proc.1.3.0.dylib /usr/local/opt/readline/lib/libreadline.dylib /usr/lib/libncurses.dylib -Wl,-rpath,/Users/vsc/git/yap-6.3/Debug && :
[9/87] /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/c++ -DCOROUTINING=1 -DDEBUG=1 -DDEPTH_LIMIT=1 -DHAVE_CONFIG_H=1 -DLOW_LEVEL_TRACER=1 -DRATIONAL_TREES=1 -DTABLING=1 -DTHREADED_CODE=1 -DUSE_MYDDAS=1 -DUSE_SYSTEM_MALLOC=1 -DUTF8PROC=1 -DYap___EXPORTS -D_YAP_NOT_INSTALLED_=1 -g -isysroot /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.11.sdk -fPIC -I. -I../H -I../H/generated -I../include -I../os -I../OPTYap -I../utf8proc -I../JIT/HPP -I/usr/local/include -I../CXX/H -I../CXX/include -Wall -fexceptions -MMD -MT CXX/CMakeFiles/Yap++.dir/yapi.cpp.o -MF CXX/CMakeFiles/Yap++.dir/yapi.cpp.o.d -o CXX/CMakeFiles/Yap++.dir/yapi.cpp.o -c ../CXX/yapi.cpp
[10/87] : && /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/cc -g -isysroot /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.11.sdk -dynamiclib -Wl,-headerpad_max_install_names -o library/matrix/matrix.dylib -install_name @rpath/matrix.dylib library/matrix/CMakeFiles/matrix.dir/matrix.c.o libYap.6.3.4.dylib -ldl -lm /usr/local/lib/libgmp.dylib utf8proc/libutf8proc.1.3.0.dylib /usr/local/opt/readline/lib/libreadline.dylib /usr/lib/libncurses.dylib -Wl,-rpath,/Users/vsc/git/yap-6.3/Debug && :
[11/87] : && /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/cc -g -isysroot /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.11.sdk -dynamiclib -Wl,-headerpad_max_install_names -o library/random/yap_random.dylib -install_name @rpath/yap_random.dylib library/random/CMakeFiles/yap_random.dir/yap_random.c.o libYap.6.3.4.dylib -ldl -lm /usr/local/lib/libgmp.dylib utf8proc/libutf8proc.1.3.0.dylib /usr/local/opt/readline/lib/libreadline.dylib /usr/lib/libncurses.dylib -Wl,-rpath,/Users/vsc/git/yap-6.3/Debug && :
[12/87] : && /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/cc -g -isysroot /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.11.sdk -dynamiclib -Wl,-headerpad_max_install_names -o library/regex/regexp.dylib -install_name @rpath/regexp.dylib library/regex/CMakeFiles/regexp.dir/regexp.c.o libYap.6.3.4.dylib -ldl -lm /usr/local/lib/libgmp.dylib utf8proc/libutf8proc.1.3.0.dylib /usr/local/opt/readline/lib/libreadline.dylib /usr/lib/libncurses.dylib -Wl,-rpath,/Users/vsc/git/yap-6.3/Debug && :
[13/87] : && /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/cc -g -isysroot /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.11.sdk -dynamiclib -Wl,-headerpad_max_install_names -o library/rltree/yap_rl.dylib -install_name @rpath/yap_rl.dylib library/rltree/CMakeFiles/yap_rl.dir/yap_rl.c.o library/rltree/CMakeFiles/yap_rl.dir/range_list.c.o libYap.6.3.4.dylib -ldl -lm /usr/local/lib/libgmp.dylib utf8proc/libutf8proc.1.3.0.dylib /usr/local/opt/readline/lib/libreadline.dylib /usr/lib/libncurses.dylib -Wl,-rpath,/Users/vsc/git/yap-6.3/Debug && :
[14/87] cd /Users/vsc/git/yap-6.3/Debug && /Users/vsc/git/yap-6.3/Debug/yap -b /Users/vsc/git/yap-6.3/pl/boot.yap -L /Users/vsc/git/yap-6.3/pl/init.yap -z qend_program
% consulting /Users/vsc/git/yap-6.3/pl/init.yap...
% consulting arith.yap...
% arith.yap consulted 0 bytes in 4 msecs
% consulting bootlists.yap...
% bootlists.yap consulted 0 bytes in 1 msecs
% consulting consult.yap...
% consult.yap consulted 0 bytes in 11 msecs
% consulting preddecls.yap...
% preddecls.yap consulted 0 bytes in 3 msecs
% consulting preddyns.yap...
% preddyns.yap consulted 0 bytes in 3 msecs
% consulting meta.yap...
% meta.yap consulted 0 bytes in 6 msecs
% consulting newmod.yap...
% newmod.yap consulted 0 bytes in 3 msecs
% consulting atoms.yap...
% atoms.yap consulted 0 bytes in 3 msecs
% consulting os.yap...
% os.yap consulted 0 bytes in 3 msecs
% consulting grammar.yap...
:- prolog:use_module(library(expand_macros)) failed.
:- prolog:dynamic prolog:$goal_expansion_allowed/0 failed.
% grammar.yap consulted 0 bytes in 5 msecs
% consulting absf.yap...
% absf.yap consulted 0 bytes in 7 msecs
loading(consulting,directives.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/directives.yap,prolog,5,0)
loading(consulting,preds.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/preds.yap,prolog,9,0)
loading(consulting,modules.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/modules.yap,prolog,9,0)
loading(reconsulting,error.yap)
loaded(reconsulted,/Users/vsc/git/yap-6.3/pl/error.yap,error,3,0)
loading(consulting,errors.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/errors.yap,prolog,1,0)
loading(consulting,utils.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/utils.yap,prolog,4,0)
loading(consulting,control.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/control.yap,prolog,4,0)
loading(consulting,flags.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/flags.yap,prolog,1,0)
loading(consulting,yio.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/yio.yap,prolog,2,0)
loading(consulting,debug.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/debug.yap,prolog,9,0)
loading(consulting,checker.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/checker.yap,prolog,1,0)
loading(consulting,depth_bound.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/depth_bound.yap,prolog,0,0)
loading(consulting,ground.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/ground.yap,prolog,1,0)
loading(consulting,listing.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/listing.yap,prolog,3,0)
loading(consulting,arithpreds.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/arithpreds.yap,prolog,1,0)
loading(consulting,eval.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/eval.yap,prolog,1,0)
loading(consulting,signals.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/signals.yap,prolog,3,0)
loading(consulting,profile.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/profile.yap,prolog,2,0)
loading(consulting,callcount.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/callcount.yap,prolog,0,0)
loading(consulting,load_foreign.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/load_foreign.yap,prolog,1,0)
loading(consulting,setof.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/setof.yap,prolog,1,0)
loading(consulting,sort.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/sort.yap,prolog,1,0)
loading(consulting,statistics.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/statistics.yap,prolog,3,0)
loading(consulting,strict_iso.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/strict_iso.yap,prolog,3,0)
loading(consulting,tabling.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/tabling.yap,prolog,4,0)
loading(consulting,threads.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/threads.yap,prolog,10,0)
loading(consulting,eam.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/eam.yap,prolog,1,0)
loading(consulting,yapor.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/yapor.yap,prolog,2,0)
loading(consulting,qly.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/qly.yap,prolog,7,0)
loading(consulting,spy.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/spy.yap,prolog,3,0)
loading(consulting,udi.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/udi.yap,prolog,0,0)
loading(consulting,protect.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/protect.yap,prolog,1,0)
loading(consulting,arrays.yap)
loaded(consulted,/Users/vsc/git/yap-6.3/pl/arrays.yap,prolog,1,0)
loading(consulting,undefined.yap)
varmap.ivalue[index] = ivalue; varmap.ivalue[index] = ivalue;
varmap.dynvalue[index] = dynvalue; varmap.dynvalue[index] = dynvalue;
} }
@ -987,7 +1087,7 @@ int SetNamedVarValues(namedvars varmap, const char *varname, double dvalue,
} else if ((index < 0) || (index == 0 && varmap.vars[0] == NULL)) { } else if ((index < 0) || (index == 0 && varmap.vars[0] == NULL)) {
index *= -1; index *= -1;
varmap.vars[index] = (char *)malloc(sizeof(char) * (strlen(varname) + 1)); varmap.vars[index] = (char *)malloc(sizeof(char) * (strlen(varname) + 1));
strcpy(varmap.vars[index], varname); strcpy((cinst char *)varmap.vars[index], varname);
varmap.dvalue[index] = dvalue; varmap.dvalue[index] = dvalue;
varmap.ivalue[index] = ivalue; varmap.ivalue[index] = ivalue;
varmap.dynvalue[index] = dynvalue; varmap.dynvalue[index] = dynvalue;

View File

@ -48,7 +48,7 @@ refactoring (trivial):
#define JPL_C_LIB_VERSION_PATCH 4 #define JPL_C_LIB_VERSION_PATCH 4
#define JPL_C_LIB_VERSION_STATUS "alpha" #define JPL_C_LIB_VERSION_STATUS "alpha"
#if JPL_DEBUG #ifndef JPL_DEBUG
/*#define DEBUG(n, g) ((void)0) */ /*#define DEBUG(n, g) ((void)0) */
#define DEBUG_LEVEL 4 #define DEBUG_LEVEL 4
#define JPL_DEBUG(n, g) ( n >= DEBUG_LEVEL ? g : (void)0 ) #define JPL_DEBUG(n, g) ( n >= DEBUG_LEVEL ? g : (void)0 )

View File

@ -3,6 +3,7 @@ macro_optional_find_package (SWIG ON)
macro_log_feature (SWIG_FOUND "Swig" macro_log_feature (SWIG_FOUND "Swig"
"Use SWIG Documentation System " "Use SWIG Documentation System "
"http://www.swig.org" FALSE) "http://www.swig.org" FALSE)
if (SWIG_FOUND) if (SWIG_FOUND)
# #
# SWIG_FOUND - set to true if SWIG is found # SWIG_FOUND - set to true if SWIG is found

View File

@ -25,7 +25,7 @@ set(PL_SOURCES
hacks.yap hacks.yap
init.yap init.yap
listing.yap listing.yap
lists.yap bootlists.yap
load_foreign.yap load_foreign.yap
messages.yap messages.yap
meta.yap meta.yap
@ -48,7 +48,6 @@ set(PL_SOURCES
udi.yap udi.yap
undefined.yap undefined.yap
utils.yap utils.yap
history.pl
swi.yap swi.yap
yapor.yap yapor.yap
yio.yap yio.yap

View File

@ -115,7 +115,7 @@ otherwise.
:- compile_expressions. :- compile_expressions.
:- bootstrap('lists.yap'). :- bootstrap('bootlists.yap').
:- bootstrap('consult.yap'). :- bootstrap('consult.yap').
:- bootstrap('preddecls.yap'). :- bootstrap('preddecls.yap').
:- bootstrap('preddyns.yap'). :- bootstrap('preddyns.yap').