2012-06-22 10:01:32 +01:00
|
|
|
|
/*************************************************************************
|
2017-12-05 15:14:57 +00:00
|
|
|
|
* *
|
|
|
|
|
* Yap Prolog *
|
|
|
|
|
* *
|
|
|
|
|
* Yap Prolog Was Developed At Nccup - Universidade Do Porto *
|
|
|
|
|
* *
|
|
|
|
|
* Copyright L.Damas, V.S.Costa And Universidade Do Porto 1985-1997 *
|
|
|
|
|
* *
|
|
|
|
|
**************************************************************************
|
|
|
|
|
* *
|
|
|
|
|
* File: Yap.C * Last
|
2017-12-10 11:42:51 +00:00
|
|
|
|
*Rev:
|
2017-12-10 01:22:45 +00:00
|
|
|
|
* Mods:
|
2017-12-05 15:14:57 +00:00
|
|
|
|
** Comments: Yap's Main File: parse arguments *
|
|
|
|
|
* *
|
|
|
|
|
*************************************************************************/
|
2012-06-22 10:01:32 +01:00
|
|
|
|
/* static char SccsId[] = "X 4.3.3"; */
|
2018-06-19 12:29:16 +01:00
|
|
|
|
|
2013-11-16 00:27:02 +00:00
|
|
|
|
#include "Yap.h"
|
2013-11-25 10:34:50 +00:00
|
|
|
|
#include "YapHeap.h"
|
2016-01-31 10:21:50 +00:00
|
|
|
|
#include "YapInterface.h"
|
2017-12-10 01:22:45 +00:00
|
|
|
|
#include "YapStreams.h"
|
2018-06-19 12:29:16 +01:00
|
|
|
|
#include "config.h"
|
2018-02-14 10:37:07 +00:00
|
|
|
|
#include "iopreds.h"
|
2017-12-05 15:14:57 +00:00
|
|
|
|
|
2015-06-19 01:30:13 +01:00
|
|
|
|
#if HAVE_UNISTD_H
|
2017-12-05 15:14:57 +00:00
|
|
|
|
|
2015-06-19 01:30:13 +01:00
|
|
|
|
#include <unistd.h>
|
2017-12-05 15:14:57 +00:00
|
|
|
|
|
2015-06-19 01:30:13 +01:00
|
|
|
|
#endif
|
2013-11-15 10:38:00 +00:00
|
|
|
|
#if HAVE_STDINT_H
|
2017-12-05 15:14:57 +00:00
|
|
|
|
|
2013-11-15 10:38:00 +00:00
|
|
|
|
#include <stdint.h>
|
2017-12-05 15:14:57 +00:00
|
|
|
|
|
2013-11-15 10:38:00 +00:00
|
|
|
|
#endif
|
2017-12-05 15:14:57 +00:00
|
|
|
|
|
2016-04-05 08:07:28 +01:00
|
|
|
|
#include <stdlib.h>
|
2017-12-05 15:14:57 +00:00
|
|
|
|
|
2018-06-18 10:51:01 +01:00
|
|
|
|
#include <stddef.h>
|
2012-06-22 10:01:32 +01:00
|
|
|
|
#ifdef _MSC_VER /* Microsoft's Visual C++ Compiler */
|
2016-01-31 10:21:50 +00:00
|
|
|
|
#ifdef HAVE_UNISTD_H
|
|
|
|
|
#undef HAVE_UNISTD_H
|
2012-06-22 10:01:32 +01:00
|
|
|
|
#endif
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#include <stdio.h>
|
2017-12-05 15:14:57 +00:00
|
|
|
|
|
2012-06-22 10:01:32 +01:00
|
|
|
|
#if HAVE_STRING_H
|
2017-12-05 15:14:57 +00:00
|
|
|
|
|
2012-06-22 10:01:32 +01:00
|
|
|
|
#include <string.h>
|
2017-12-05 15:14:57 +00:00
|
|
|
|
|
2012-06-22 10:01:32 +01:00
|
|
|
|
#endif
|
2014-12-04 07:59:30 +00:00
|
|
|
|
#if HAVE_ERRNO_H
|
2017-12-05 15:14:57 +00:00
|
|
|
|
|
2014-12-04 07:59:30 +00:00
|
|
|
|
#include <errno.h>
|
2017-12-05 15:14:57 +00:00
|
|
|
|
|
2014-12-04 07:59:30 +00:00
|
|
|
|
#endif
|
|
|
|
|
#if HAVE_DIRECT_H
|
|
|
|
|
#include <direct.h>
|
|
|
|
|
#endif
|
2012-06-22 10:01:32 +01:00
|
|
|
|
|
2017-12-10 11:42:51 +00:00
|
|
|
|
#if HAVE_LIBGEN_H
|
2017-11-15 12:18:19 +00:00
|
|
|
|
#include <libgen.h>
|
|
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
2018-01-18 14:47:27 +00:00
|
|
|
|
X_API bool YAP_initialized = false;
|
|
|
|
|
static int n_mdelays = 0;
|
|
|
|
|
static YAP_delaymodule_t *m_delays;
|
|
|
|
|
|
|
|
|
|
static void init_globals(YAP_init_args *yap_init) {
|
|
|
|
|
GLOBAL_FAST_BOOT_FLAG = yap_init->FastBoot;
|
|
|
|
|
#if defined(YAPOR) || defined(TABLING)
|
|
|
|
|
|
|
|
|
|
Yap_init_root_frames();
|
|
|
|
|
|
|
|
|
|
#endif /* YAPOR || TABLING */
|
|
|
|
|
#ifdef YAPOR
|
|
|
|
|
Yap_init_yapor_workers();
|
|
|
|
|
#if YAPOR_THREADS
|
|
|
|
|
if (Yap_thread_self() != 0) {
|
|
|
|
|
#else
|
|
|
|
|
if (worker_id != 0) {
|
|
|
|
|
#endif
|
|
|
|
|
#if defined(YAPOR_COPY) || defined(YAPOR_SBA)
|
|
|
|
|
/*
|
|
|
|
|
In the SBA we cannot just happily inherit registers
|
|
|
|
|
from the other workers
|
|
|
|
|
*/
|
|
|
|
|
Yap_InitYaamRegs(worker_id, true);
|
|
|
|
|
#endif /* YAPOR_COPY || YAPOR_SBA */
|
|
|
|
|
#ifndef YAPOR_THREADS
|
|
|
|
|
Yap_InitPreAllocCodeSpace(0);
|
|
|
|
|
#endif /* YAPOR_THREADS */
|
|
|
|
|
/* slaves, waiting for work */
|
|
|
|
|
CurrentModule = USER_MODULE;
|
|
|
|
|
P = GETWORK_FIRST_TIME;
|
|
|
|
|
Yap_exec_absmi(FALSE, YAP_EXEC_ABSMI);
|
|
|
|
|
Yap_Error(SYSTEM_ERROR_INTERNAL, TermNil,
|
|
|
|
|
"abstract machine unexpected exit (YAP_Init)");
|
|
|
|
|
}
|
|
|
|
|
#endif /* YAPOR */
|
|
|
|
|
RECOVER_MACHINE_REGS();
|
|
|
|
|
/* make sure we do this after restore */
|
|
|
|
|
if (yap_init->MaxStackSize) {
|
|
|
|
|
GLOBAL_AllowLocalExpansion = FALSE;
|
|
|
|
|
} else {
|
|
|
|
|
GLOBAL_AllowLocalExpansion = TRUE;
|
|
|
|
|
}
|
|
|
|
|
if (yap_init->MaxGlobalSize) {
|
|
|
|
|
GLOBAL_AllowGlobalExpansion = FALSE;
|
|
|
|
|
} else {
|
|
|
|
|
GLOBAL_AllowGlobalExpansion = TRUE;
|
|
|
|
|
}
|
|
|
|
|
if (yap_init->MaxTrailSize) {
|
|
|
|
|
GLOBAL_AllowTrailExpansion = FALSE;
|
|
|
|
|
} else {
|
|
|
|
|
GLOBAL_AllowTrailExpansion = TRUE;
|
|
|
|
|
}
|
|
|
|
|
if (yap_init->PrologRCFile) {
|
|
|
|
|
Yap_PutValue(AtomConsultOnBoot,
|
|
|
|
|
MkAtomTerm(Yap_LookupAtom(yap_init->PrologRCFile)));
|
|
|
|
|
/*
|
|
|
|
|
This must be done again after restore, as yap_flags
|
|
|
|
|
has been overwritten ....
|
|
|
|
|
*/
|
|
|
|
|
setBooleanGlobalPrologFlag(HALT_AFTER_CONSULT_FLAG,
|
2018-03-14 00:41:05 +00:00
|
|
|
|
yap_init->HaltAfterBoot);
|
2018-01-18 14:47:27 +00:00
|
|
|
|
}
|
|
|
|
|
if (yap_init->PrologTopLevelGoal) {
|
|
|
|
|
Yap_PutValue(AtomTopLevelGoal,
|
|
|
|
|
MkAtomTerm(Yap_LookupAtom(yap_init->PrologTopLevelGoal)));
|
|
|
|
|
}
|
|
|
|
|
if (yap_init->PrologGoal) {
|
|
|
|
|
Yap_PutValue(AtomInitGoal,
|
|
|
|
|
MkAtomTerm(Yap_LookupAtom(yap_init->PrologGoal)));
|
|
|
|
|
}
|
|
|
|
|
if (yap_init->PrologAddPath) {
|
|
|
|
|
Yap_PutValue(AtomExtendFileSearchPath,
|
|
|
|
|
MkAtomTerm(Yap_LookupAtom(yap_init->PrologAddPath)));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (yap_init->QuietMode) {
|
|
|
|
|
setVerbosity(TermSilent);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2017-12-10 01:22:45 +00:00
|
|
|
|
const char *Yap_BINDIR, *Yap_ROOTDIR, *Yap_SHAREDIR, *Yap_LIBDIR, *Yap_DLLDIR,
|
2018-06-15 11:09:04 +01:00
|
|
|
|
*Yap_PLDIR, *Yap_BOOTSTRAP, *Yap_COMMONSDIR,
|
2018-03-02 21:18:24 +00:00
|
|
|
|
*Yap_INPUT_STARTUP, *Yap_OUTPUT_STARTUP, *Yap_BOOTFILE, *Yap_INCLUDEDIR;
|
2017-12-05 15:14:57 +00:00
|
|
|
|
|
2018-03-17 10:38:56 +00:00
|
|
|
|
/**
|
|
|
|
|
* consult loop in C: used to boot the system, butt supports goal execution and recursive consulting.
|
|
|
|
|
*
|
|
|
|
|
* */
|
2018-06-18 22:53:53 +01:00
|
|
|
|
static bool consult(const char *b_file USES_REGS) {
|
2017-12-10 11:42:51 +00:00
|
|
|
|
Term t;
|
2018-02-14 00:13:13 +00:00
|
|
|
|
int c_stream, osno, oactive;
|
2017-12-10 11:42:51 +00:00
|
|
|
|
Functor functor_query = Yap_MkFunctor(Yap_LookupAtom("?-"), 1);
|
|
|
|
|
Functor functor_command1 = Yap_MkFunctor(Yap_LookupAtom(":-"), 1);
|
2018-01-19 14:38:26 +00:00
|
|
|
|
Functor functor_compile2 = Yap_MkFunctor(Yap_LookupAtom("c_compile"), 1);
|
2018-06-19 12:29:16 +01:00
|
|
|
|
char *full;
|
2018-01-22 13:53:17 +00:00
|
|
|
|
|
2018-03-17 10:38:56 +00:00
|
|
|
|
/* consult in C */
|
2018-02-14 10:37:07 +00:00
|
|
|
|
int lvl = push_text_stack();
|
2018-06-19 12:29:16 +01:00
|
|
|
|
- char *full = Malloc(YAP_FILENAME_MAX + 1);
|
2018-06-18 12:13:33 +01:00
|
|
|
|
full[0] = '\0';
|
2017-12-10 11:42:51 +00:00
|
|
|
|
/* the consult mode does not matter here, really */
|
2018-06-19 12:29:16 +01:00
|
|
|
|
vvvif ((osno = Yap_CheckAlias(AtomLoopStream)) < 0)
|
2018-02-14 10:37:07 +00:00
|
|
|
|
osno = 0;
|
2018-04-07 19:45:18 +01:00
|
|
|
|
c_stream = YAP_InitConsult(YAP_BOOT_MODE, b_file, &full, &oactive);
|
2018-02-14 00:13:13 +00:00
|
|
|
|
if (c_stream < 0) {
|
2018-02-22 08:18:45 +00:00
|
|
|
|
fprintf(stderr, "[ FATAL ERROR: could not open file %s ]\n", b_file);
|
2018-03-02 21:18:24 +00:00
|
|
|
|
pop_text_stack(lvl);
|
2017-12-10 11:42:51 +00:00
|
|
|
|
exit(1);
|
|
|
|
|
}
|
2018-02-14 10:37:07 +00:00
|
|
|
|
if (!Yap_AddAlias(AtomLoopStream, c_stream)) {
|
|
|
|
|
pop_text_stack(lvl);
|
2018-06-18 22:53:53 +01:00
|
|
|
|
return false;
|
2018-02-14 10:37:07 +00:00
|
|
|
|
}
|
2018-01-18 14:47:27 +00:00
|
|
|
|
|
2018-01-22 13:53:17 +00:00
|
|
|
|
do {
|
2017-12-10 11:42:51 +00:00
|
|
|
|
CACHE_REGS
|
2018-01-22 13:53:17 +00:00
|
|
|
|
YAP_Reset(YAP_FULL_RESET, false);
|
2017-12-10 11:42:51 +00:00
|
|
|
|
Yap_StartSlots();
|
2018-03-02 21:18:24 +00:00
|
|
|
|
__android_log_print(ANDROID_LOG_INFO, "YAPDroid", "read %s <%d>", b_file,
|
|
|
|
|
GLOBAL_Stream[c_stream].linecount);
|
2018-06-19 12:29:16 +01:00
|
|
|
|
Term vs = YAP_MkVarTerm(), pos = MkVarTerm();
|
2018-02-14 00:13:13 +00:00
|
|
|
|
t = YAP_ReadClauseFromStream(c_stream, vs, pos);
|
2018-01-22 13:53:17 +00:00
|
|
|
|
// Yap_GetNèwSlot(t);
|
2018-06-18 22:53:53 +01:00
|
|
|
|
if (t == TermEof)
|
|
|
|
|
break;
|
2017-12-10 11:42:51 +00:00
|
|
|
|
if (t == 0) {
|
2018-01-22 13:53:17 +00:00
|
|
|
|
fprintf(stderr, "[ SYNTAX ERROR: while parsing stream %s at line %ld ]\n",
|
2018-02-14 00:13:13 +00:00
|
|
|
|
b_file, GLOBAL_Stream[c_stream].linecount);
|
2018-01-18 14:47:27 +00:00
|
|
|
|
} else if (IsVarTerm(t) || t == TermNil) {
|
2018-02-25 00:29:08 +00:00
|
|
|
|
fprintf(stderr, "[ line: " Int_FORMAT ": term cannot be compiled ]",
|
2018-02-14 00:13:13 +00:00
|
|
|
|
GLOBAL_Stream[c_stream].linecount);
|
2018-06-18 22:53:53 +01:00
|
|
|
|
} else if (IsApplTerm(t) && (FunctorOfTerm(t) == functor_query ||
|
2017-12-10 11:42:51 +00:00
|
|
|
|
FunctorOfTerm(t) == functor_command1)) {
|
2018-01-18 14:47:27 +00:00
|
|
|
|
t = ArgOfTerm(1, t);
|
|
|
|
|
if (IsApplTerm(t) && FunctorOfTerm(t) == functor_compile2) {
|
2018-01-22 13:53:17 +00:00
|
|
|
|
consult(RepAtom(AtomOfTerm(ArgOfTerm(1, t)))->StrOfAE);
|
2018-01-18 14:47:27 +00:00
|
|
|
|
} else {
|
|
|
|
|
YAP_RunGoalOnce(t);
|
|
|
|
|
}
|
2017-12-10 11:42:51 +00:00
|
|
|
|
} else {
|
2018-04-02 14:49:45 +01:00
|
|
|
|
YAP_CompileClause(t);
|
2017-12-10 01:22:45 +00:00
|
|
|
|
}
|
2018-06-18 22:53:53 +01:00
|
|
|
|
} while (true);
|
2018-04-09 02:00:51 +01:00
|
|
|
|
yap_error_descriptor_t *errd;
|
2018-05-24 12:00:10 +01:00
|
|
|
|
if ((errd =
|
2018-05-27 00:47:03 +01:00
|
|
|
|
Yap_GetException(LOCAL_ActiveError))) {
|
2018-04-09 02:00:51 +01:00
|
|
|
|
fprintf(stderr, "%s:%ld:0: Error %s %s Found\n", errd->errorFile, (long int) errd->errorLine, errd->classAsText,
|
|
|
|
|
errd->errorAsText);
|
2017-12-10 01:22:45 +00:00
|
|
|
|
}
|
|
|
|
|
BACKUP_MACHINE_REGS();
|
2018-02-14 10:37:07 +00:00
|
|
|
|
YAP_EndConsult(c_stream, &osno, full);
|
|
|
|
|
pop_text_stack(lvl);
|
2018-06-18 22:53:53 +01:00
|
|
|
|
return true;
|
2017-12-10 01:22:45 +00:00
|
|
|
|
}
|
|
|
|
|
|
2018-02-23 14:07:21 +00:00
|
|
|
|
///
|
|
|
|
|
///
|
2018-03-02 21:18:24 +00:00
|
|
|
|
static const char *sel(bool dir, bool ok1, const char *s1, bool ok2, const char *s2,
|
|
|
|
|
...) {
|
|
|
|
|
if (ok1 && s1)
|
|
|
|
|
return s1;
|
|
|
|
|
if (ok2)
|
|
|
|
|
return s2;
|
2017-12-10 11:42:51 +00:00
|
|
|
|
return NULL;
|
2017-12-10 01:22:45 +00:00
|
|
|
|
}
|
2017-12-05 15:14:57 +00:00
|
|
|
|
|
2018-03-02 21:18:24 +00:00
|
|
|
|
static const char *join(const char *s0, const char *s1) {
|
2018-02-23 14:07:21 +00:00
|
|
|
|
CACHE_REGS
|
2018-03-02 21:18:24 +00:00
|
|
|
|
|
|
|
|
|
if (!s0 || s0[0] == '\0')
|
|
|
|
|
return s1;
|
|
|
|
|
if (!s1 || s1[0] == '\0')
|
|
|
|
|
return s0;
|
2018-02-26 21:38:19 +00:00
|
|
|
|
// int lvl = push_text_stack();
|
2018-03-02 21:18:24 +00:00
|
|
|
|
char *buf = malloc(FILENAME_MAX + 1);
|
|
|
|
|
strcpy(buf, s0);
|
|
|
|
|
strcat(buf, s1);
|
|
|
|
|
return buf;
|
2017-12-10 01:22:45 +00:00
|
|
|
|
}
|
2017-12-05 15:14:57 +00:00
|
|
|
|
|
2018-03-02 21:18:24 +00:00
|
|
|
|
static void Yap_set_locations(YAP_init_args *iap) {
|
2018-02-23 14:07:21 +00:00
|
|
|
|
|
|
|
|
|
/// ROOT_DIR is the home of the YAP system. It can be:
|
|
|
|
|
/// -- provided by the user;
|
|
|
|
|
/// -- obtained from DESTDIR + DE=efalkRoot
|
|
|
|
|
///
|
|
|
|
|
/// It is:
|
|
|
|
|
// --_not useful in Android, WIN32;
|
|
|
|
|
/// -- DESTDIR/ in Anaconda
|
2018-03-02 21:18:24 +00:00
|
|
|
|
/// -- /usr/locall in most Unix style systems
|
|
|
|
|
Yap_ROOTDIR = sel(true, iap->ROOTDIR != NULL, iap->ROOTDIR, true,
|
2018-02-21 17:41:00 +00:00
|
|
|
|
#if __ANDROID__
|
2018-03-02 21:18:24 +00:00
|
|
|
|
NULL,
|
2018-02-21 17:41:00 +00:00
|
|
|
|
#else
|
2018-03-02 21:18:24 +00:00
|
|
|
|
join(getenv("DESTDIR"), YAP_ROOTDIR),
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#endif
|
2018-03-02 21:18:24 +00:00
|
|
|
|
false);
|
2018-02-23 14:07:21 +00:00
|
|
|
|
/// BINDIR: where the OS stores header files, namely libYap...
|
2018-03-02 21:18:24 +00:00
|
|
|
|
Yap_BINDIR = sel(true, iap->BINDIR != NULL, iap->BINDIR, true,
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#if __ANDROID__
|
2018-03-02 21:18:24 +00:00
|
|
|
|
NULL,
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#else
|
2018-03-02 21:18:24 +00:00
|
|
|
|
join(getenv("DESTDIR"), YAP_BINDIR),
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#endif
|
2018-03-02 21:18:24 +00:00
|
|
|
|
false);
|
2018-02-23 14:07:21 +00:00
|
|
|
|
/// LIBDIR: where the OS stores dynamic libraries, namely libYap...
|
2018-03-02 21:18:24 +00:00
|
|
|
|
Yap_LIBDIR = sel(true, iap->LIBDIR != NULL, iap->LIBDIR, true,
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#if __ANDROID__
|
2018-03-02 21:18:24 +00:00
|
|
|
|
NULL,
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#else
|
2018-03-02 21:18:24 +00:00
|
|
|
|
join(getenv("DESTDIR"), YAP_LIBDIR),
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#endif
|
2018-03-02 21:18:24 +00:00
|
|
|
|
false);
|
2018-02-23 14:07:21 +00:00
|
|
|
|
/// DLLDIR: where libraries can find expicitely loaded DLLs
|
2018-03-02 21:18:24 +00:00
|
|
|
|
Yap_DLLDIR = sel(true, iap->DLLDIR != NULL, iap->DLLDIR, true,
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#if __ANDROID__
|
2018-06-15 11:09:04 +01:00
|
|
|
|
NULL,
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#else
|
2018-03-02 21:18:24 +00:00
|
|
|
|
join(getenv("DESTDIR"), YAP_DLLDIR),
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#endif
|
2018-03-02 21:18:24 +00:00
|
|
|
|
false);
|
2018-02-23 14:07:21 +00:00
|
|
|
|
/// INCLUDEDIR: where the OS stores header files, namely libYap...
|
2018-03-02 21:18:24 +00:00
|
|
|
|
Yap_INCLUDEDIR = sel(true, iap->INCLUDEDIR != NULL, iap->INCLUDEDIR, true,
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#if __ANDROID__
|
2018-03-02 21:18:24 +00:00
|
|
|
|
NULL,
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#else
|
2018-03-02 21:18:24 +00:00
|
|
|
|
join(getenv("DESTDIR"), YAP_INCLUDEDIR),
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#endif
|
2018-03-02 21:18:24 +00:00
|
|
|
|
false);
|
2018-02-23 14:07:21 +00:00
|
|
|
|
/// SHAREDIR: where OS & ARCH independent files live
|
2018-03-02 21:18:24 +00:00
|
|
|
|
Yap_SHAREDIR = sel(true, iap->SHAREDIR != NULL, iap->SHAREDIR, true,
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#if __ANDROID__
|
2018-03-02 21:18:24 +00:00
|
|
|
|
"/assets",
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#else
|
2018-03-02 21:18:24 +00:00
|
|
|
|
join(getenv("DESTDIR"), YAP_SHAREDIR),
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#endif
|
2018-03-02 21:18:24 +00:00
|
|
|
|
false);
|
2018-02-23 14:07:21 +00:00
|
|
|
|
/// PLDIR: where we can find Prolog files
|
2018-03-02 21:18:24 +00:00
|
|
|
|
Yap_PLDIR = sel(true, iap->PLDIR != NULL, iap->PLDIR, true,
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#if __ANDROID__
|
2018-03-02 21:18:24 +00:00
|
|
|
|
"/assets/Yap",
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#else
|
2018-03-02 21:18:24 +00:00
|
|
|
|
join(getenv("DESTDIR"), YAP_PLDIR),
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#endif
|
2018-03-02 21:18:24 +00:00
|
|
|
|
false);
|
2018-02-23 14:07:21 +00:00
|
|
|
|
/// ``COMMONSDIR: Prolog Commons
|
2018-03-02 21:18:24 +00:00
|
|
|
|
Yap_COMMONSDIR = sel(true, iap->COMMONSDIR != NULL, iap->COMMONSDIR, true,
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#if __ANDROID__
|
2018-03-02 21:18:24 +00:00
|
|
|
|
"/assets/PrologCommons",
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#else
|
2018-03-02 21:18:24 +00:00
|
|
|
|
join(getenv("DESTDIR"), YAP_SHAREDIR "/PrologCommons"),
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#endif
|
2018-03-02 21:18:24 +00:00
|
|
|
|
false);
|
|
|
|
|
/// BOOTPLDIR: where we can find Prolog bootstrap files
|
|
|
|
|
Yap_BOOTSTRAP = sel(true, iap->BOOTSTRAP != NULL, iap->BOOTSTRAP, true,
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#if __ANDROID__
|
2018-06-19 12:29:16 +01:00
|
|
|
|
"/assets/Yap/pl/boot,yap",
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#else
|
2018-03-02 21:18:24 +00:00
|
|
|
|
join(getenv("DESTDIR"), YAP_BOOTSTRAP),
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#endif
|
2018-03-02 21:18:24 +00:00
|
|
|
|
false);
|
2018-06-15 11:09:04 +01:00
|
|
|
|
/// BOOTFILE: where we can find the core Prolog boot file
|
2018-03-02 21:18:24 +00:00
|
|
|
|
Yap_BOOTFILE = sel(false, iap->BOOTFILE != NULL, iap->BOOTFILE, true,
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#if __ANDROID__
|
2018-03-02 21:18:24 +00:00
|
|
|
|
"/assets/Yap/pl/boot.yap",
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#else
|
2018-03-02 21:18:24 +00:00
|
|
|
|
join(getenv("DESTDIR"), YAP_BOOTFILE),
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#endif
|
2018-03-02 21:18:24 +00:00
|
|
|
|
false);
|
|
|
|
|
/// STARTUP: where we can find the core Prolog bootstrap file
|
|
|
|
|
Yap_OUTPUT_STARTUP =
|
|
|
|
|
sel(false, iap->OUTPUT_STARTUP != NULL, iap->OUTPUT_STARTUP, true,
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#if __ANDROID__
|
2018-03-02 21:18:24 +00:00
|
|
|
|
NULL,
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#else
|
2018-03-02 21:18:24 +00:00
|
|
|
|
join(getenv("DESTDIR"), YAP_OUTPUT_STARTUP),
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#endif
|
2018-03-02 21:18:24 +00:00
|
|
|
|
false);
|
|
|
|
|
Yap_INPUT_STARTUP =
|
|
|
|
|
sel(false, iap->INPUT_STARTUP != NULL, iap->INPUT_STARTUP, true,
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#if __ANDROID__
|
2018-03-02 21:18:24 +00:00
|
|
|
|
NULL,
|
2018-02-23 14:07:21 +00:00
|
|
|
|
#else
|
2018-03-02 21:18:24 +00:00
|
|
|
|
join(getenv("DESTDIR"), YAP_INPUT_STARTUP),
|
2018-02-21 17:41:00 +00:00
|
|
|
|
#endif
|
2018-03-02 21:18:24 +00:00
|
|
|
|
false);
|
|
|
|
|
if (Yap_ROOTDIR)
|
2017-12-20 00:29:15 +00:00
|
|
|
|
setAtomicGlobalPrologFlag(HOME_FLAG,
|
|
|
|
|
MkAtomTerm(Yap_LookupAtom(Yap_ROOTDIR)));
|
2017-12-10 11:42:51 +00:00
|
|
|
|
if (Yap_PLDIR)
|
|
|
|
|
setAtomicGlobalPrologFlag(PROLOG_LIBRARY_DIRECTORY_FLAG,
|
2017-12-20 00:29:15 +00:00
|
|
|
|
MkAtomTerm(Yap_LookupAtom(Yap_PLDIR)));
|
2017-12-10 11:42:51 +00:00
|
|
|
|
if (Yap_DLLDIR)
|
|
|
|
|
setAtomicGlobalPrologFlag(PROLOG_FOREIGN_DIRECTORY_FLAG,
|
2017-12-20 00:29:15 +00:00
|
|
|
|
MkAtomTerm(Yap_LookupAtom(Yap_DLLDIR)));
|
2017-12-05 15:14:57 +00:00
|
|
|
|
}
|
|
|
|
|
|
2016-07-31 10:47:55 +01:00
|
|
|
|
static void print_usage(void) {
|
2017-12-10 01:22:45 +00:00
|
|
|
|
fprintf(stderr, "\n[ Valid switches for command line arguments: ]\n");
|
|
|
|
|
fprintf(stderr, " -? Shows this screen\n");
|
|
|
|
|
fprintf(stderr, " -b Boot file \n");
|
|
|
|
|
fprintf(stderr, " -dump-runtime-variables\n");
|
|
|
|
|
fprintf(stderr, " -f initialization file or \"none\"\n");
|
|
|
|
|
fprintf(stderr, " -g Run Goal Before Top-Level \n");
|
|
|
|
|
fprintf(stderr, " -z Run Goal Before Top-Level \n");
|
|
|
|
|
fprintf(stderr, " -q start with informational messages off\n");
|
|
|
|
|
fprintf(stderr, " -l load Prolog file\n");
|
|
|
|
|
fprintf(stderr, " -L run Prolog file and exit\n");
|
|
|
|
|
fprintf(stderr, " -p extra path for file-search-path\n");
|
|
|
|
|
fprintf(stderr, " -hSize Heap area in Kbytes (default: %d, minimum: %d)\n",
|
|
|
|
|
DefHeapSpace, MinHeapSpace);
|
|
|
|
|
fprintf(stderr,
|
|
|
|
|
" -sSize Stack area in Kbytes (default: %d, minimum: %d)\n",
|
|
|
|
|
DefStackSpace, MinStackSpace);
|
|
|
|
|
fprintf(stderr,
|
|
|
|
|
" -tSize Trail area in Kbytes (default: %d, minimum: %d)\n",
|
|
|
|
|
DefTrailSpace, MinTrailSpace);
|
|
|
|
|
fprintf(stderr, " -GSize Max Area for Global Stack\n");
|
|
|
|
|
fprintf(stderr,
|
|
|
|
|
" -LSize Max Area for Local Stack (number must follow L)\n");
|
|
|
|
|
fprintf(stderr, " -TSize Max Area for Trail (number must follow T)\n");
|
|
|
|
|
fprintf(stderr, " -nosignals disable signal handling from Prolog\n");
|
|
|
|
|
fprintf(stderr, "\n[Execution Modes]\n");
|
|
|
|
|
fprintf(stderr, " -J0 Interpreted mode (default)\n");
|
|
|
|
|
fprintf(stderr, " -J1 Mixed mode only for user predicates\n");
|
|
|
|
|
fprintf(stderr, " -J2 Mixed mode for all predicates\n");
|
|
|
|
|
fprintf(stderr, " -J3 Compile all user predicates\n");
|
|
|
|
|
fprintf(stderr, " -J4 Compile all predicates\n");
|
2012-06-22 10:01:32 +01:00
|
|
|
|
|
|
|
|
|
#ifdef TABLING
|
2017-12-10 01:22:45 +00:00
|
|
|
|
fprintf(stderr,
|
|
|
|
|
" -ts Maximum table space area in Mbytes (default: unlimited)\n");
|
2012-06-22 10:01:32 +01:00
|
|
|
|
#endif /* TABLING */
|
2017-12-10 01:22:45 +00:00
|
|
|
|
#if defined(YAPOR_COPY) || defined(YAPOR_COW) || defined(YAPOR_SBA) || \
|
2016-01-31 10:21:50 +00:00
|
|
|
|
defined(YAPOR_THREADS)
|
2017-12-10 01:22:45 +00:00
|
|
|
|
fprintf(stderr, " -w Number of workers (default: %d)\n",
|
|
|
|
|
DEFAULT_NUMBERWORKERS);
|
|
|
|
|
fprintf(stderr,
|
|
|
|
|
" -sl Loop scheduler executions before look for hiden "
|
|
|
|
|
"shared work (default: %d)\n",
|
|
|
|
|
DEFAULT_SCHEDULERLOOP);
|
|
|
|
|
fprintf(stderr, " -d Value of delayed release of load (default: %d)\n",
|
|
|
|
|
DEFAULT_DELAYEDRELEASELOAD);
|
2012-06-22 10:01:32 +01:00
|
|
|
|
#endif /* YAPOR_COPY || YAPOR_COW || YAPOR_SBA || YAPOR_THREADS */
|
2017-12-10 01:22:45 +00:00
|
|
|
|
/* nf: Preprocessor */
|
|
|
|
|
/* fprintf(stderr," -DVar=Name Persistent definition\n"); */
|
|
|
|
|
fprintf(stderr, "\n");
|
2012-06-22 10:01:32 +01:00
|
|
|
|
}
|
|
|
|
|
|
2016-01-31 10:21:50 +00:00
|
|
|
|
static int myisblank(int c) {
|
2017-12-10 01:22:45 +00:00
|
|
|
|
switch (c) {
|
|
|
|
|
case ' ':
|
|
|
|
|
case '\t':
|
|
|
|
|
case '\n':
|
|
|
|
|
case '\r':
|
|
|
|
|
return TRUE;
|
|
|
|
|
default:
|
|
|
|
|
return FALSE;
|
|
|
|
|
}
|
2012-06-22 10:01:32 +01:00
|
|
|
|
}
|
|
|
|
|
|
2016-01-31 10:21:50 +00:00
|
|
|
|
static char *add_end_dot(char arg[]) {
|
2017-12-10 01:22:45 +00:00
|
|
|
|
int sz = strlen(arg), i;
|
|
|
|
|
i = sz;
|
|
|
|
|
while (i && myisblank(arg[--i]))
|
|
|
|
|
;
|
|
|
|
|
if (i && arg[i] != ',') {
|
|
|
|
|
char *p = (char *)malloc(sz + 2);
|
|
|
|
|
if (!p)
|
|
|
|
|
return NULL;
|
|
|
|
|
strncpy(p, arg, sz);
|
|
|
|
|
p[sz] = '.';
|
|
|
|
|
p[sz + 1] = '\0';
|
|
|
|
|
return p;
|
|
|
|
|
}
|
|
|
|
|
return arg;
|
2012-06-22 10:01:32 +01:00
|
|
|
|
}
|
|
|
|
|
|
2016-01-31 10:21:50 +00:00
|
|
|
|
static int dump_runtime_variables(void) {
|
2017-12-10 01:22:45 +00:00
|
|
|
|
fprintf(stdout, "CC=\"%s\"\n", C_CC);
|
|
|
|
|
fprintf(stdout, "YAP_ROOTDIR=\"%s\"\n", YAP_ROOTDIR);
|
|
|
|
|
fprintf(stdout, "YAP_LIBS=\"%s\"\n", C_LIBS);
|
|
|
|
|
fprintf(stdout, "YAP_SHLIB_SUFFIX=\"%s\"\n", SO_EXT);
|
|
|
|
|
fprintf(stdout, "YAP_VERSION=%s\n", YAP_NUMERIC_VERSION);
|
|
|
|
|
exit(0);
|
|
|
|
|
return 1;
|
2012-06-22 10:01:32 +01:00
|
|
|
|
}
|
|
|
|
|
|
2017-12-05 15:14:57 +00:00
|
|
|
|
X_API YAP_file_type_t Yap_InitDefaults(void *x, char *saved_state, int argc,
|
|
|
|
|
char *argv[]) {
|
2017-12-10 01:22:45 +00:00
|
|
|
|
|
|
|
|
|
if (!LOCAL_TextBuffer)
|
|
|
|
|
LOCAL_TextBuffer = Yap_InitTextAllocator();
|
|
|
|
|
YAP_init_args *iap = x;
|
|
|
|
|
memset(iap, 0, sizeof(YAP_init_args));
|
2016-07-31 10:47:55 +01:00
|
|
|
|
#if __ANDROID__
|
2017-12-10 01:22:45 +00:00
|
|
|
|
iap->boot_file_type = YAP_BOOT_PL;
|
2018-06-15 11:09:04 +01:00
|
|
|
|
iap->INPUT_STARTUP = NULL;
|
2017-12-10 01:22:45 +00:00
|
|
|
|
iap->assetManager = NULL;
|
2016-07-31 10:47:55 +01:00
|
|
|
|
#else
|
2017-12-10 01:22:45 +00:00
|
|
|
|
iap->boot_file_type = YAP_QLY;
|
2018-02-25 00:29:08 +00:00
|
|
|
|
iap->INPUT_STARTUP = saved_state;
|
2016-07-31 10:47:55 +01:00
|
|
|
|
#endif
|
2017-12-10 01:22:45 +00:00
|
|
|
|
iap->Argc = argc;
|
|
|
|
|
iap->Argv = argv;
|
|
|
|
|
return YAP_QLY;
|
2016-07-31 10:47:55 +01:00
|
|
|
|
}
|
2012-06-22 10:01:32 +01:00
|
|
|
|
|
2017-12-05 15:14:57 +00:00
|
|
|
|
/**
|
|
|
|
|
* @short Paese command line
|
|
|
|
|
* @param argc number of arguments
|
|
|
|
|
* @param argv arguments
|
|
|
|
|
* @param iap options, see YAP_init_args
|
|
|
|
|
* @return boot from saved state or restore; error
|
|
|
|
|
*/
|
2017-12-10 01:22:45 +00:00
|
|
|
|
X_API YAP_file_type_t YAP_parse_yap_arguments(int argc, char *argv[],
|
|
|
|
|
YAP_init_args *iap) {
|
|
|
|
|
char *p;
|
|
|
|
|
size_t *ssize;
|
2017-11-15 12:18:19 +00:00
|
|
|
|
|
2017-12-10 01:22:45 +00:00
|
|
|
|
Yap_InitDefaults(iap, NULL, argc, argv);
|
|
|
|
|
while (--argc > 0) {
|
|
|
|
|
p = *++argv;
|
|
|
|
|
if (*p == '-')
|
|
|
|
|
switch (*++p) {
|
|
|
|
|
case 'b':
|
|
|
|
|
iap->boot_file_type = YAP_PL;
|
|
|
|
|
if (p[1])
|
2018-02-23 14:07:21 +00:00
|
|
|
|
iap->BOOTFILE = p + 1;
|
2017-12-10 01:22:45 +00:00
|
|
|
|
else if (argv[1] && *argv[1] != '-') {
|
2018-02-23 14:07:21 +00:00
|
|
|
|
iap->BOOTFILE = *++argv;
|
2017-12-10 01:22:45 +00:00
|
|
|
|
argc--;
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
case 'B':
|
|
|
|
|
iap->boot_file_type = YAP_BOOT_PL;
|
|
|
|
|
if (p[1])
|
2018-02-25 00:29:08 +00:00
|
|
|
|
iap->BOOTSTRAP = p + 1;
|
2017-12-10 01:22:45 +00:00
|
|
|
|
else if (argv[1] && *argv[1] != '-') {
|
2018-02-25 00:29:08 +00:00
|
|
|
|
iap->BOOTSTRAP = *++argv;
|
2017-12-10 01:22:45 +00:00
|
|
|
|
argc--;
|
|
|
|
|
}
|
2018-01-18 14:47:27 +00:00
|
|
|
|
iap->install = true;
|
2017-12-10 01:22:45 +00:00
|
|
|
|
break;
|
|
|
|
|
case '?':
|
|
|
|
|
print_usage();
|
|
|
|
|
exit(EXIT_SUCCESS);
|
|
|
|
|
case 'q':
|
|
|
|
|
iap->QuietMode = TRUE;
|
|
|
|
|
break;
|
|
|
|
|
#if defined(YAPOR_COPY) || defined(YAPOR_COW) || defined(YAPOR_SBA) || \
|
2016-01-31 10:21:50 +00:00
|
|
|
|
defined(YAPOR_THREADS)
|
2017-12-10 01:22:45 +00:00
|
|
|
|
case 'w':
|
|
|
|
|
ssize = &(iap->NumberWorkers);
|
|
|
|
|
goto GetSize;
|
|
|
|
|
case 'd':
|
|
|
|
|
if (!strcmp("dump-runtime-variables", p))
|
|
|
|
|
return dump_runtime_variables();
|
|
|
|
|
ssize = &(iap->DelayedReleaseLoad);
|
|
|
|
|
goto GetSize;
|
2012-06-22 10:01:32 +01:00
|
|
|
|
#else
|
2017-12-10 01:22:45 +00:00
|
|
|
|
case 'd':
|
|
|
|
|
if (!strcmp("dump-runtime-variables", p))
|
|
|
|
|
return dump_runtime_variables();
|
2012-06-22 10:01:32 +01:00
|
|
|
|
#endif /* YAPOR_COPY || YAPOR_COW || YAPOR_SBA || YAPOR_THREADS */
|
2017-12-10 01:22:45 +00:00
|
|
|
|
case 'F':
|
|
|
|
|
/* just ignore for now */
|
|
|
|
|
argc--;
|
|
|
|
|
argv++;
|
|
|
|
|
break;
|
|
|
|
|
case 'f':
|
|
|
|
|
iap->FastBoot = TRUE;
|
|
|
|
|
if (argc > 1 && argv[1][0] != '-') {
|
|
|
|
|
argc--;
|
|
|
|
|
argv++;
|
|
|
|
|
if (strcmp(*argv, "none")) {
|
2018-01-18 14:47:27 +00:00
|
|
|
|
iap->PrologRCFile = *argv;
|
2017-12-10 01:22:45 +00:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
// execution mode
|
|
|
|
|
case 'J':
|
|
|
|
|
switch (p[1]) {
|
|
|
|
|
case '0':
|
|
|
|
|
iap->ExecutionMode = YAPC_INTERPRETED;
|
|
|
|
|
break;
|
|
|
|
|
case '1':
|
|
|
|
|
iap->ExecutionMode = YAPC_MIXED_MODE_USER;
|
|
|
|
|
break;
|
|
|
|
|
case '2':
|
|
|
|
|
iap->ExecutionMode = YAPC_MIXED_MODE_ALL;
|
|
|
|
|
break;
|
|
|
|
|
case '3':
|
|
|
|
|
iap->ExecutionMode = YAPC_COMPILE_USER;
|
|
|
|
|
break;
|
|
|
|
|
case '4':
|
|
|
|
|
iap->ExecutionMode = YAPC_COMPILE_ALL;
|
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
fprintf(stderr, "[ YAP unrecoverable error: unknown switch -%c%c ]\n",
|
|
|
|
|
*p, p[1]);
|
|
|
|
|
exit(EXIT_FAILURE);
|
|
|
|
|
}
|
|
|
|
|
p++;
|
|
|
|
|
break;
|
|
|
|
|
case 'G':
|
|
|
|
|
ssize = &(iap->MaxGlobalSize);
|
|
|
|
|
goto GetSize;
|
|
|
|
|
break;
|
|
|
|
|
case 's':
|
|
|
|
|
case 'S':
|
|
|
|
|
ssize = &(iap->StackSize);
|
|
|
|
|
#if defined(YAPOR_COPY) || defined(YAPOR_COW) || defined(YAPOR_SBA) || \
|
2016-01-31 10:21:50 +00:00
|
|
|
|
defined(YAPOR_THREADS)
|
2017-12-10 01:22:45 +00:00
|
|
|
|
if (p[1] == 'l') {
|
|
|
|
|
p++;
|
|
|
|
|
ssize = &(iap->SchedulerLoop);
|
|
|
|
|
}
|
2012-06-22 10:01:32 +01:00
|
|
|
|
#endif /* YAPOR_COPY || YAPOR_COW || YAPOR_SBA || YAPOR_THREADS */
|
2017-12-10 01:22:45 +00:00
|
|
|
|
goto GetSize;
|
|
|
|
|
case 'a':
|
|
|
|
|
case 'A':
|
|
|
|
|
ssize = &(iap->AttsSize);
|
|
|
|
|
goto GetSize;
|
|
|
|
|
case 'T':
|
|
|
|
|
ssize = &(iap->MaxTrailSize);
|
|
|
|
|
goto get_trail_size;
|
|
|
|
|
case 't':
|
|
|
|
|
ssize = &(iap->TrailSize);
|
2012-06-22 10:01:32 +01:00
|
|
|
|
#ifdef TABLING
|
2017-12-10 01:22:45 +00:00
|
|
|
|
if (p[1] == 's') {
|
|
|
|
|
p++;
|
|
|
|
|
ssize = &(iap->MaxTableSpaceSize);
|
|
|
|
|
}
|
2012-06-22 10:01:32 +01:00
|
|
|
|
#endif /* TABLING */
|
2017-12-10 01:22:45 +00:00
|
|
|
|
get_trail_size:
|
|
|
|
|
if (*++p == '\0') {
|
|
|
|
|
if (argc > 1)
|
|
|
|
|
--argc, p = *++argv;
|
|
|
|
|
else {
|
|
|
|
|
fprintf(stderr,
|
|
|
|
|
"[ YAP unrecoverable error: missing size in flag %s ]",
|
|
|
|
|
argv[0]);
|
|
|
|
|
print_usage();
|
|
|
|
|
exit(EXIT_FAILURE);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
{
|
|
|
|
|
unsigned long int i = 0, ch;
|
|
|
|
|
while ((ch = *p++) >= '0' && ch <= '9')
|
|
|
|
|
i = i * 10 + ch - '0';
|
|
|
|
|
switch (ch) {
|
|
|
|
|
case 'M':
|
|
|
|
|
case 'm':
|
|
|
|
|
i *= 1024;
|
|
|
|
|
ch = *p++;
|
|
|
|
|
break;
|
|
|
|
|
case 'g':
|
|
|
|
|
i *= 1024 * 1024;
|
|
|
|
|
ch = *p++;
|
|
|
|
|
break;
|
|
|
|
|
case 'k':
|
|
|
|
|
case 'K':
|
|
|
|
|
ch = *p++;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
if (ch) {
|
2018-01-18 14:47:27 +00:00
|
|
|
|
iap->PrologTopLevelGoal = add_end_dot(*argv);
|
2017-12-10 01:22:45 +00:00
|
|
|
|
} else {
|
|
|
|
|
*ssize = i;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
case 'h':
|
|
|
|
|
case 'H':
|
|
|
|
|
ssize = &(iap->HeapSize);
|
|
|
|
|
GetSize:
|
|
|
|
|
if (*++p == '\0') {
|
|
|
|
|
if (argc > 1)
|
|
|
|
|
--argc, p = *++argv;
|
|
|
|
|
else {
|
|
|
|
|
fprintf(stderr,
|
|
|
|
|
"[ YAP unrecoverable error: missing size in flag %s ]",
|
|
|
|
|
argv[0]);
|
|
|
|
|
print_usage();
|
|
|
|
|
exit(EXIT_FAILURE);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
{
|
|
|
|
|
unsigned long int i = 0, ch;
|
|
|
|
|
while ((ch = *p++) >= '0' && ch <= '9')
|
|
|
|
|
i = i * 10 + ch - '0';
|
|
|
|
|
switch (ch) {
|
|
|
|
|
case 'M':
|
|
|
|
|
case 'm':
|
|
|
|
|
i *= 1024;
|
|
|
|
|
ch = *p++;
|
|
|
|
|
break;
|
|
|
|
|
case 'g':
|
|
|
|
|
case 'G':
|
|
|
|
|
i *= 1024 * 1024;
|
|
|
|
|
ch = *p++;
|
|
|
|
|
break;
|
|
|
|
|
case 'k':
|
|
|
|
|
case 'K':
|
|
|
|
|
ch = *p++;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
if (ch) {
|
|
|
|
|
fprintf(
|
|
|
|
|
stderr,
|
|
|
|
|
"[ YAP unrecoverable error: illegal size specification %s ]",
|
|
|
|
|
argv[-1]);
|
|
|
|
|
Yap_exit(1);
|
|
|
|
|
}
|
|
|
|
|
*ssize = i;
|
|
|
|
|
}
|
|
|
|
|
break;
|
2012-06-22 10:01:32 +01:00
|
|
|
|
#ifdef DEBUG
|
2017-12-10 01:22:45 +00:00
|
|
|
|
case 'P':
|
|
|
|
|
if (p[1] != '\0') {
|
|
|
|
|
while (p[1] != '\0') {
|
|
|
|
|
int ch = p[1];
|
|
|
|
|
if (ch >= 'A' && ch <= 'Z')
|
|
|
|
|
ch += ('a' - 'A');
|
|
|
|
|
if (ch >= 'a' && ch <= 'z')
|
|
|
|
|
GLOBAL_Option[ch - 96] = 1;
|
|
|
|
|
p++;
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
YAP_SetOutputMessage();
|
|
|
|
|
}
|
|
|
|
|
break;
|
2012-06-22 10:01:32 +01:00
|
|
|
|
#endif
|
2017-12-10 01:22:45 +00:00
|
|
|
|
case 'L':
|
|
|
|
|
if (p[1] && p[1] >= '0' &&
|
|
|
|
|
p[1] <= '9') /* hack to emulate SWI's L local option */
|
|
|
|
|
{
|
|
|
|
|
ssize = &(iap->MaxStackSize);
|
|
|
|
|
goto GetSize;
|
|
|
|
|
}
|
|
|
|
|
iap->QuietMode = TRUE;
|
2018-03-14 00:41:05 +00:00
|
|
|
|
iap->HaltAfterBoot = true;
|
2017-12-10 01:22:45 +00:00
|
|
|
|
case 'l':
|
|
|
|
|
p++;
|
|
|
|
|
if (!*++argv) {
|
|
|
|
|
fprintf(stderr,
|
|
|
|
|
"%% YAP unrecoverable error: missing load file name\n");
|
|
|
|
|
exit(1);
|
|
|
|
|
} else if (!strcmp("--", *argv)) {
|
|
|
|
|
/* shell script, the next entry should be the file itself */
|
2018-01-18 14:47:27 +00:00
|
|
|
|
iap->PrologRCFile = argv[1];
|
2017-12-10 01:22:45 +00:00
|
|
|
|
argc = 1;
|
|
|
|
|
break;
|
|
|
|
|
} else {
|
2018-01-18 14:47:27 +00:00
|
|
|
|
iap->PrologRCFile = *argv;
|
2017-12-10 01:22:45 +00:00
|
|
|
|
argc--;
|
|
|
|
|
}
|
|
|
|
|
if (*p) {
|
|
|
|
|
/* we have something, usually, of the form:
|
|
|
|
|
-L --
|
|
|
|
|
FileName
|
|
|
|
|
ExtraArgs
|
|
|
|
|
*/
|
|
|
|
|
/* being called from a script */
|
|
|
|
|
while (*p && (*p == ' ' || *p == '\t'))
|
|
|
|
|
p++;
|
|
|
|
|
if (p[0] == '-' && p[1] == '-') {
|
|
|
|
|
/* ignore what is next */
|
|
|
|
|
argc = 1;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
/* run goal before top-level */
|
|
|
|
|
case 'g':
|
|
|
|
|
if ((*argv)[0] == '\0')
|
2018-01-18 14:47:27 +00:00
|
|
|
|
iap->PrologGoal = *argv;
|
2017-12-10 01:22:45 +00:00
|
|
|
|
else {
|
|
|
|
|
argc--;
|
|
|
|
|
if (argc == 0) {
|
|
|
|
|
fprintf(stderr, " [ YAP unrecoverable error: missing "
|
|
|
|
|
"initialization goal for option 'g' ]\n");
|
|
|
|
|
exit(EXIT_FAILURE);
|
|
|
|
|
}
|
|
|
|
|
argv++;
|
2018-01-18 14:47:27 +00:00
|
|
|
|
iap->PrologGoal = *argv;
|
2017-12-10 01:22:45 +00:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
/* run goal as top-level */
|
|
|
|
|
case 'z':
|
|
|
|
|
if ((*argv)[0] == '\0')
|
2018-01-18 14:47:27 +00:00
|
|
|
|
iap->PrologTopLevelGoal = *argv;
|
2017-12-10 01:22:45 +00:00
|
|
|
|
else {
|
|
|
|
|
argc--;
|
|
|
|
|
if (argc == 0) {
|
2017-12-10 11:42:51 +00:00
|
|
|
|
fprintf(stderr, " [ YAP unrecoverable error: missing goal for "
|
|
|
|
|
"option 'z' ]\n");
|
2017-12-10 01:22:45 +00:00
|
|
|
|
exit(EXIT_FAILURE);
|
|
|
|
|
}
|
|
|
|
|
argv++;
|
2018-01-18 14:47:27 +00:00
|
|
|
|
iap->PrologTopLevelGoal = add_end_dot(*argv);
|
2016-01-31 10:21:50 +00:00
|
|
|
|
}
|
2018-03-14 00:41:05 +00:00
|
|
|
|
iap->HaltAfterBoot = true;
|
2017-12-10 01:22:45 +00:00
|
|
|
|
break;
|
|
|
|
|
case 'n':
|
|
|
|
|
if (!strcmp("nosignals", p)) {
|
|
|
|
|
iap->PrologCannotHandleInterrupts = true;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
case '-':
|
|
|
|
|
if (!strcmp("-nosignals", p)) {
|
|
|
|
|
iap->PrologCannotHandleInterrupts = true;
|
|
|
|
|
break;
|
2018-01-22 13:53:17 +00:00
|
|
|
|
} else if (!strncmp("-output-saved-state=", p,
|
|
|
|
|
strlen("-output-saved-state="))) {
|
2018-02-23 14:07:21 +00:00
|
|
|
|
iap->OUTPUT_STARTUP = p + strlen("-output-saved-state=");
|
2018-01-18 14:47:27 +00:00
|
|
|
|
} else if (!strncmp("-home=", p, strlen("-home="))) {
|
2018-02-23 14:07:21 +00:00
|
|
|
|
iap->ROOTDIR = p + strlen("-home=");
|
2018-01-22 13:53:17 +00:00
|
|
|
|
} else if (!strncmp("-system-library-directory=", p,
|
|
|
|
|
strlen("-system-library-directory="))) {
|
2018-02-23 14:07:21 +00:00
|
|
|
|
iap->LIBDIR = p + strlen("-system-library-directory=");
|
2018-01-22 13:53:17 +00:00
|
|
|
|
} else if (!strncmp("-system-shared-directory=", p,
|
|
|
|
|
strlen("-system-shared-directory="))) {
|
2018-02-23 14:07:21 +00:00
|
|
|
|
iap->SHAREDIR = p + strlen("-system-shared-directory=");
|
2018-01-22 13:53:17 +00:00
|
|
|
|
} else if (!strncmp("-prolog-library-directory=", p,
|
|
|
|
|
strlen("-prolog-library-directory="))) {
|
2018-02-23 14:07:21 +00:00
|
|
|
|
iap->PLDIR = p + strlen("-prolog-library-directory=");
|
2018-01-22 13:53:17 +00:00
|
|
|
|
} else if (!strncmp("-dll-library-directory=", p,
|
|
|
|
|
strlen("-dll-library-directory="))) {
|
2018-02-23 14:07:21 +00:00
|
|
|
|
iap->DLLDIR = p + strlen("-dll-library-directory=");
|
2018-01-18 14:47:27 +00:00
|
|
|
|
} else if (!strncmp("-home=", p, strlen("-home="))) {
|
2018-02-23 14:07:21 +00:00
|
|
|
|
iap->ROOTDIR = p + strlen("-home=");
|
2017-12-10 01:22:45 +00:00
|
|
|
|
} else if (!strncmp("-cwd=", p, strlen("-cwd="))) {
|
|
|
|
|
if (!Yap_ChDir(p + strlen("-cwd="))) {
|
|
|
|
|
fprintf(stderr, " [ YAP unrecoverable error in setting cwd: %s ]\n",
|
|
|
|
|
strerror(errno));
|
|
|
|
|
}
|
|
|
|
|
} else if (!strncmp("-stack=", p, strlen("-stack="))) {
|
|
|
|
|
ssize = &(iap->StackSize);
|
|
|
|
|
p += strlen("-stack=");
|
|
|
|
|
goto GetSize;
|
|
|
|
|
} else if (!strncmp("-trail=", p, strlen("-trail="))) {
|
|
|
|
|
ssize = &(iap->TrailSize);
|
|
|
|
|
p += strlen("-trail=");
|
|
|
|
|
goto GetSize;
|
|
|
|
|
} else if (!strncmp("-heap=", p, strlen("-heap="))) {
|
|
|
|
|
ssize = &(iap->HeapSize);
|
|
|
|
|
p += strlen("-heap=");
|
|
|
|
|
goto GetSize;
|
2018-01-22 13:53:17 +00:00
|
|
|
|
} else if (!strncmp("-max-stack=", p, strlen("-max-stack="))) {
|
2018-01-18 14:47:27 +00:00
|
|
|
|
ssize = &(iap->MaxStackSize);
|
|
|
|
|
p += strlen("-max-stack=");
|
|
|
|
|
goto GetSize;
|
|
|
|
|
} else if (!strncmp("-max-trail=", p, strlen("-max-trail="))) {
|
|
|
|
|
ssize = &(iap->MaxTrailSize);
|
|
|
|
|
p += strlen("-max-trail=");
|
|
|
|
|
goto GetSize;
|
|
|
|
|
} else if (!strncmp("-max-heap=", p, strlen("-max-heap="))) {
|
|
|
|
|
ssize = &(iap->MaxHeapSize);
|
|
|
|
|
p += strlen("-max-heap=");
|
|
|
|
|
goto GetSize;
|
2017-12-10 01:22:45 +00:00
|
|
|
|
} else if (!strncmp("-goal=", p, strlen("-goal="))) {
|
2018-01-18 14:47:27 +00:00
|
|
|
|
iap->PrologGoal = p + strlen("-goal=");
|
2017-12-10 01:22:45 +00:00
|
|
|
|
} else if (!strncmp("-top-level=", p, strlen("-top-level="))) {
|
2018-01-18 14:47:27 +00:00
|
|
|
|
iap->PrologTopLevelGoal = p + strlen("-top-level=");
|
2017-12-10 01:22:45 +00:00
|
|
|
|
} else if (!strncmp("-table=", p, strlen("-table="))) {
|
|
|
|
|
ssize = &(iap->MaxTableSpaceSize);
|
|
|
|
|
p += strlen("-table=");
|
|
|
|
|
goto GetSize;
|
|
|
|
|
} else if (!strncmp("-", p, strlen("-="))) {
|
|
|
|
|
ssize = &(iap->MaxTableSpaceSize);
|
|
|
|
|
p += strlen("-table=");
|
|
|
|
|
/* skip remaining arguments */
|
|
|
|
|
argc = 1;
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
case 'p':
|
|
|
|
|
if ((*argv)[0] == '\0')
|
2018-01-18 14:47:27 +00:00
|
|
|
|
iap->PrologAddPath = *argv;
|
2017-12-10 01:22:45 +00:00
|
|
|
|
else {
|
|
|
|
|
argc--;
|
|
|
|
|
if (argc == 0) {
|
2017-12-10 11:42:51 +00:00
|
|
|
|
fprintf(stderr, " [ YAP unrecoverable error: missing paths for "
|
|
|
|
|
"option 'p' ]\n");
|
2017-12-10 01:22:45 +00:00
|
|
|
|
exit(EXIT_FAILURE);
|
|
|
|
|
}
|
|
|
|
|
argv++;
|
2018-01-18 14:47:27 +00:00
|
|
|
|
iap->PrologAddPath = *argv;
|
2017-12-10 01:22:45 +00:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
/* nf: Begin preprocessor code */
|
|
|
|
|
case 'D': {
|
|
|
|
|
char *var, *value;
|
|
|
|
|
++p;
|
|
|
|
|
var = p;
|
|
|
|
|
if (var == NULL || *var == '\0')
|
|
|
|
|
break;
|
|
|
|
|
while (*p != '=' && *p != '\0')
|
|
|
|
|
++p;
|
|
|
|
|
if (*p == '\0')
|
|
|
|
|
break;
|
|
|
|
|
*p = '\0';
|
|
|
|
|
++p;
|
|
|
|
|
value = p;
|
|
|
|
|
if (*value == '\0')
|
|
|
|
|
break;
|
|
|
|
|
if (iap->def_c == YAP_MAX_YPP_DEFS)
|
|
|
|
|
break;
|
|
|
|
|
iap->def_var[iap->def_c] = var;
|
|
|
|
|
iap->def_value[iap->def_c] = value;
|
|
|
|
|
++(iap->def_c);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
/* End preprocessor code */
|
|
|
|
|
default: {
|
|
|
|
|
fprintf(stderr, "[ YAP unrecoverable error: unknown switch -%c ]\n",
|
|
|
|
|
*p);
|
|
|
|
|
print_usage();
|
|
|
|
|
exit(EXIT_FAILURE);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else {
|
2018-02-25 00:29:08 +00:00
|
|
|
|
iap->INPUT_STARTUP = p;
|
2012-06-22 10:01:32 +01:00
|
|
|
|
}
|
2017-12-10 01:22:45 +00:00
|
|
|
|
}
|
|
|
|
|
return iap->boot_file_type;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
YAP_DelayInit()
|
|
|
|
|
|
|
|
|
|
ensures initialization is done after engine creation.
|
|
|
|
|
It receives a pointer to function and a string describing
|
|
|
|
|
the module.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
X_API bool YAP_DelayInit(YAP_ModInit_t f, const char s[]) {
|
|
|
|
|
if (m_delays) {
|
|
|
|
|
m_delays = realloc(m_delays, (n_mdelays + 1) * sizeof(YAP_delaymodule_t));
|
|
|
|
|
} else {
|
|
|
|
|
m_delays = malloc(sizeof(YAP_delaymodule_t));
|
|
|
|
|
}
|
|
|
|
|
m_delays[n_mdelays].f = f;
|
|
|
|
|
m_delays[n_mdelays].s = s;
|
|
|
|
|
n_mdelays++;
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bool Yap_LateInit(const char s[]) {
|
|
|
|
|
int i;
|
|
|
|
|
for (i = 0; i < n_mdelays; i++) {
|
|
|
|
|
if (!strcmp(m_delays[i].s, s)) {
|
|
|
|
|
m_delays[i].f();
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// whether Yap is under control of some other system
|
|
|
|
|
bool Yap_embedded = true;
|
|
|
|
|
|
|
|
|
|
struct ssz_t {
|
|
|
|
|
size_t Heap, Stack, Trail;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
static void init_hw(YAP_init_args *yap_init, struct ssz_t *spt) {
|
|
|
|
|
Yap_page_size = Yap_InitPageSize(); /* init memory page size, required by
|
|
|
|
|
later functions */
|
|
|
|
|
#if defined(YAPOR_COPY) || defined(YAPOR_COW) || defined(YAPOR_SBA)
|
|
|
|
|
Yap_init_yapor_global_local_memory();
|
|
|
|
|
#endif /* YAPOR_COPY || YAPOR_COW || YAPOR_SBA */
|
|
|
|
|
if (!yap_init->Embedded) {
|
|
|
|
|
GLOBAL_PrologShouldHandleInterrupts =
|
|
|
|
|
!yap_init->PrologCannotHandleInterrupts;
|
|
|
|
|
Yap_InitSysbits(0); /* init signal handling and time, required by later
|
|
|
|
|
functions */
|
|
|
|
|
GLOBAL_argv = yap_init->Argv;
|
|
|
|
|
GLOBAL_argc = yap_init->Argc;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#if __ANDROID__
|
|
|
|
|
|
|
|
|
|
// if (yap_init->assetManager)
|
2018-03-02 21:18:24 +00:00
|
|
|
|
// Yap_InitAssetManager();
|
2017-12-10 01:22:45 +00:00
|
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
if (yap_init->TrailSize == 0) {
|
|
|
|
|
if (spt->Trail == 0)
|
|
|
|
|
spt->Trail = DefTrailSpace;
|
|
|
|
|
} else {
|
|
|
|
|
spt->Trail = yap_init->TrailSize;
|
|
|
|
|
}
|
|
|
|
|
// Atts = yap_init->AttsSize;
|
|
|
|
|
if (yap_init->StackSize == 0) {
|
|
|
|
|
spt->Stack = DefStackSpace;
|
|
|
|
|
} else {
|
|
|
|
|
spt->Stack = yap_init->StackSize;
|
|
|
|
|
}
|
|
|
|
|
#ifndef USE_SYSTEM_MALLOC
|
|
|
|
|
if (yap_init->HeapSize == 0) {
|
|
|
|
|
if (spt->Heap == 0)
|
|
|
|
|
spt->Heap = DefHeapSpace;
|
|
|
|
|
} else {
|
|
|
|
|
spt->Heap = yap_init->HeapSize;
|
|
|
|
|
}
|
|
|
|
|
#endif
|
|
|
|
|
}
|
|
|
|
|
|
2018-03-14 00:41:05 +00:00
|
|
|
|
static void end_init(YAP_init_args *iap) {
|
2017-12-10 01:22:45 +00:00
|
|
|
|
YAP_initialized = true;
|
2018-03-14 00:41:05 +00:00
|
|
|
|
if (iap->HaltAfterBoot) Yap_exit(0);
|
2018-01-22 13:53:17 +00:00
|
|
|
|
LOCAL_PrologMode &= ~BootMode;
|
2018-06-19 12:29:16 +01:00
|
|
|
|
CurrentModule = USER_MODULE
|
2017-12-10 01:22:45 +00:00
|
|
|
|
}
|
|
|
|
|
|
2018-03-02 21:18:24 +00:00
|
|
|
|
static void start_modules(void) {
|
2018-02-23 14:07:21 +00:00
|
|
|
|
Term cm = CurrentModule;
|
|
|
|
|
size_t i;
|
|
|
|
|
for (i = 0; i < n_mdelays; i++) {
|
|
|
|
|
CurrentModule = MkAtomTerm(YAP_LookupAtom(m_delays[i].s));
|
|
|
|
|
m_delays[i].f();
|
|
|
|
|
}
|
|
|
|
|
CurrentModule = cm;
|
|
|
|
|
}
|
|
|
|
|
|
2017-12-10 01:22:45 +00:00
|
|
|
|
/* this routine is supposed to be called from an external program
|
|
|
|
|
that wants to control Yap */
|
|
|
|
|
|
2018-03-14 00:41:05 +00:00
|
|
|
|
X_API void YAP_Init(YAP_init_args *yap_init) {
|
|
|
|
|
bool try_restore = yap_init->boot_file_type == YAP_QLY;
|
|
|
|
|
bool do_bootstrap = yap_init->boot_file_type == YAP_BOOT_PL;
|
2017-12-10 01:22:45 +00:00
|
|
|
|
struct ssz_t minfo;
|
|
|
|
|
|
|
|
|
|
if (YAP_initialized)
|
2018-03-02 21:18:24 +00:00
|
|
|
|
/* ignore repeated calls to YAP_Init */
|
2018-03-14 00:41:05 +00:00
|
|
|
|
return;
|
2017-12-10 01:22:45 +00:00
|
|
|
|
if (!LOCAL_TextBuffer)
|
|
|
|
|
LOCAL_TextBuffer = Yap_InitTextAllocator();
|
|
|
|
|
|
|
|
|
|
Yap_embedded = yap_init->Embedded;
|
|
|
|
|
|
|
|
|
|
minfo.Trail = 0, minfo.Stack = 0, minfo.Trail = 0;
|
|
|
|
|
init_hw(yap_init, &minfo);
|
|
|
|
|
Yap_InitWorkspace(yap_init, minfo.Heap, minfo.Stack, minfo.Trail, 0,
|
|
|
|
|
yap_init->MaxTableSpaceSize, yap_init->NumberWorkers,
|
|
|
|
|
yap_init->SchedulerLoop, yap_init->DelayedReleaseLoad);
|
|
|
|
|
//
|
|
|
|
|
|
|
|
|
|
CACHE_REGS
|
2018-06-15 13:50:55 +01:00
|
|
|
|
|
2017-12-10 01:22:45 +00:00
|
|
|
|
if (yap_init->QuietMode) {
|
|
|
|
|
setVerbosity(TermSilent);
|
|
|
|
|
}
|
2018-01-18 14:47:27 +00:00
|
|
|
|
if (yap_init->PrologRCFile != NULL) {
|
2017-12-10 01:22:45 +00:00
|
|
|
|
/*
|
|
|
|
|
This must be done before restore, otherwise
|
|
|
|
|
restore will print out messages ....
|
|
|
|
|
*/
|
|
|
|
|
setBooleanGlobalPrologFlag(HALT_AFTER_CONSULT_FLAG,
|
2018-03-14 00:41:05 +00:00
|
|
|
|
yap_init->HaltAfterBoot);
|
2017-12-10 01:22:45 +00:00
|
|
|
|
}
|
|
|
|
|
/* tell the system who should cope with interrupts */
|
|
|
|
|
Yap_ExecutionMode = yap_init->ExecutionMode;
|
|
|
|
|
Yap_set_locations(yap_init);
|
2018-02-14 00:13:13 +00:00
|
|
|
|
|
2018-03-14 00:41:05 +00:00
|
|
|
|
if (do_bootstrap ||
|
|
|
|
|
!try_restore ||
|
|
|
|
|
!Yap_SavedInfo(Yap_INPUT_STARTUP, &minfo.Trail, &minfo.Stack,
|
|
|
|
|
&minfo.Heap) ) {
|
2018-01-22 13:53:17 +00:00
|
|
|
|
init_globals(yap_init);
|
2018-01-18 14:47:27 +00:00
|
|
|
|
|
2018-01-22 13:53:17 +00:00
|
|
|
|
start_modules();
|
2018-06-18 22:53:53 +01:00
|
|
|
|
TermEof = MkAtomTerm( Yap_LookupAtom("end_of_file"));
|
2018-03-14 00:41:05 +00:00
|
|
|
|
consult(Yap_BOOTSTRAP PASS_REGS);
|
|
|
|
|
setAtomicGlobalPrologFlag(RESOURCE_DATABASE_FLAG,
|
|
|
|
|
MkAtomTerm(Yap_LookupAtom(Yap_BOOTFILE)));
|
|
|
|
|
setBooleanGlobalPrologFlag(SAVED_PROGRAM_FLAG, false);
|
2017-12-10 01:22:45 +00:00
|
|
|
|
} else {
|
2018-03-14 00:41:05 +00:00
|
|
|
|
Yap_Restore(Yap_INPUT_STARTUP);
|
2018-01-18 14:47:27 +00:00
|
|
|
|
init_globals(yap_init);
|
|
|
|
|
|
|
|
|
|
start_modules();
|
2018-06-18 10:51:01 +01:00
|
|
|
|
if (yap_init->install && Yap_OUTPUT_STARTUP) {
|
2018-03-14 00:41:05 +00:00
|
|
|
|
setAtomicGlobalPrologFlag(RESOURCE_DATABASE_FLAG,
|
|
|
|
|
MkAtomTerm(Yap_LookupAtom(Yap_INPUT_STARTUP)));
|
|
|
|
|
setBooleanGlobalPrologFlag(SAVED_PROGRAM_FLAG, true);
|
|
|
|
|
}
|
2018-06-18 22:53:53 +01:00
|
|
|
|
}
|
2018-03-14 00:41:05 +00:00
|
|
|
|
YAP_RunGoalOnce(TermInitProlog);
|
|
|
|
|
if (yap_init->install && Yap_OUTPUT_STARTUP) {
|
2018-06-19 12:29:16 +01:00
|
|
|
|
>>>>>>> ff2b867ec3c3831e10b8465e0a9e3c1a03e3d4d2
|
2018-01-27 10:17:27 +00:00
|
|
|
|
Term t = MkAtomTerm(Yap_LookupAtom(Yap_OUTPUT_STARTUP));
|
2018-06-19 12:29:16 +01:00
|
|
|
|
Term g = Yap_MkApplTerm(Yap_MkFunctor(Yap_LookupAtom("qsave_program"), 1),
|
2018-01-22 13:53:17 +00:00
|
|
|
|
1, &t);
|
2018-02-14 00:13:13 +00:00
|
|
|
|
|
2018-01-22 13:53:17 +00:00
|
|
|
|
YAP_RunGoalOnce(g);
|
2018-03-14 00:41:05 +00:00
|
|
|
|
}
|
2018-06-18 22:53:53 +01:00
|
|
|
|
|
2018-03-14 00:41:05 +00:00
|
|
|
|
end_init(yap_init);
|
2017-12-10 01:22:45 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#if (DefTrailSpace < MinTrailSpace)
|
|
|
|
|
#undef DefTrailSpace
|
|
|
|
|
#define DefTrailSpace MinTrailSpace
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if (DefStackSpace < MinStackSpace)
|
|
|
|
|
#undef DefStackSpace
|
|
|
|
|
#define DefStackSpace MinStackSpace
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#if (DefHeapSpace < MinHeapSpace)
|
|
|
|
|
#undef DefHeapSpace
|
|
|
|
|
#define DefHeapSpace MinHeapSpace
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
#define DEFAULT_NUMBERWORKERS 1
|
|
|
|
|
#define DEFAULT_SCHEDULERLOOP 10
|
|
|
|
|
#define DEFAULT_DELAYEDRELEASELOAD 3
|
|
|
|
|
|
2018-03-14 00:41:05 +00:00
|
|
|
|
X_API void YAP_FastInit(char *saved_state, int argc, char *argv[]) {
|
2017-12-10 01:22:45 +00:00
|
|
|
|
YAP_init_args init_args;
|
|
|
|
|
YAP_file_type_t out;
|
|
|
|
|
|
|
|
|
|
if ((out = Yap_InitDefaults(&init_args, saved_state, argc, argv)) !=
|
|
|
|
|
YAP_FOUND_BOOT_ERROR)
|
2018-03-14 00:41:05 +00:00
|
|
|
|
YAP_Init(&init_args);
|
2017-12-10 01:22:45 +00:00
|
|
|
|
if (out == YAP_FOUND_BOOT_ERROR) {
|
|
|
|
|
Yap_Error(init_args.ErrorNo, TermNil, init_args.ErrorCause);
|
|
|
|
|
}
|
|
|
|
|
}
|