Merge ssh://192.168.1.103/home/vsc/yap
This commit is contained in:
commit
3fdbbc6a77
@ -3169,15 +3169,14 @@ stash_predicate(USES_REGS1) {
|
|||||||
char ns[1024];
|
char ns[1024];
|
||||||
const char *s = (pe->ModuleOfPred == PROLOG_MODULE ?
|
const char *s = (pe->ModuleOfPred == PROLOG_MODULE ?
|
||||||
"__prolog__stash__" :
|
"__prolog__stash__" :
|
||||||
snprintf(sn,1023,"__%s__".RepAtom(AtomOfTerm( pe->ModuleOfPred ))));
|
snprintf(sn,1023,"__%s__".RepAtom(AtomOfTerm(
|
||||||
pe->ModuleOfPred = MkAtomTerm(Yap_LookupAtom(s));
|
pe->ModuleOfPred )))); pe->ModuleOfPred = MkAtomTerm(Yap_LookupAtom(s));
|
||||||
*/
|
*/
|
||||||
return true;
|
return true;
|
||||||
} else
|
} else
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static Int /* $hidden_predicate(P) */
|
static Int /* $hidden_predicate(P) */
|
||||||
hidden_predicate(USES_REGS1) {
|
hidden_predicate(USES_REGS1) {
|
||||||
PredEntry *pe =
|
PredEntry *pe =
|
||||||
|
7
CMakeLists.txt
Normal file → Executable file
7
CMakeLists.txt
Normal file → Executable file
@ -334,9 +334,14 @@ find_package(GMP)
|
|||||||
list(APPEND YAP_SYSTEM_OPTIONS big_numbers)
|
list(APPEND YAP_SYSTEM_OPTIONS big_numbers)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (GMP_FOUND)
|
if (GMP_FOUND)
|
||||||
#config.h needs this (TODO: change in code latter)
|
#config.h needs this (TODO: change in code latter)
|
||||||
include_directories(${GMP_INCLUDE_DIRS})
|
include_directories(${GMP_INCLUDE_DIRS})
|
||||||
|
check_include_file(gmp.h HAVE_GMP_H)
|
||||||
|
check_include_file_cxx(gmpxx.h HAVE_GMPXX_H)
|
||||||
|
|
||||||
|
|
||||||
endif (GMP_FOUND)
|
endif (GMP_FOUND)
|
||||||
|
|
||||||
option(WITH_READLINE "use readline or libedit" ON)
|
option(WITH_READLINE "use readline or libedit" ON)
|
||||||
@ -416,7 +421,7 @@ set(DEF_TRAILSPACE 0)
|
|||||||
set_property(DIRECTORY APPEND PROPERTY COMPILE_DEFINITIONS DEPTH_LIMIT=1;COROUTINING=1;RATIONAL_TREES=1)
|
set_property(DIRECTORY APPEND PROPERTY COMPILE_DEFINITIONS DEPTH_LIMIT=1;COROUTINING=1;RATIONAL_TREES=1)
|
||||||
|
|
||||||
# inform we are compiling YAP
|
# inform we are compiling YAP
|
||||||
set_property(DIRECTORY APPEND PROPERTY COMPILE_DEFINITIONS "_YAP_NOT_INSTALLED_=1;HAVE_CONFIG_H=1;_GNU_SOURCE")
|
set_property(DIRECTORY APPEND PROPERTY COMPILE_DEFINITIONS "_YAP_NOT_INSTALLED_=1;HAVE_CONFIG_H=1;_GNU_SOURCE=1")
|
||||||
|
|
||||||
# Compilation model
|
# Compilation model
|
||||||
# target_compile_definitions(libYap PUBLIC _XOPEN_SOURCE=700 )
|
# target_compile_definitions(libYap PUBLIC _XOPEN_SOURCE=700 )
|
||||||
|
11
CXX/yapi.hh
Normal file → Executable file
11
CXX/yapi.hh
Normal file → Executable file
@ -8,11 +8,20 @@
|
|||||||
|
|
||||||
#define YAP_CPP_INTERFACE 1
|
#define YAP_CPP_INTERFACE 1
|
||||||
|
|
||||||
#include <gmpxx.h>
|
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
|
extern "C"{
|
||||||
|
#include "config.h"
|
||||||
|
}
|
||||||
|
|
||||||
|
#if HAVE_GMPXX_H
|
||||||
|
#include <gmpxx.h>
|
||||||
|
#elif HAVE_GMP_H
|
||||||
|
#include <gmp.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
*
|
*
|
||||||
* @ingroup fli_c_cxx
|
* @ingroup fli_c_cxx
|
||||||
|
26
H/TermExt.h
26
H/TermExt.h
@ -388,26 +388,6 @@ INLINE_ONLY bool IsStringTerm(Term t) {
|
|||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
#if !defined(__cplusplus)
|
|
||||||
#include <gmp.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#else
|
|
||||||
|
|
||||||
typedef UInt mp_limb_t;
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
Int _mp_size, _mp_alloc;
|
|
||||||
mp_limb_t *_mp_d;
|
|
||||||
} MP_INT;
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
MP_INT _mp_num;
|
|
||||||
MP_INT _mp_den;
|
|
||||||
} MP_RAT;
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
INLINE_ONLY bool IsBigIntTerm(Term);
|
INLINE_ONLY bool IsBigIntTerm(Term);
|
||||||
|
|
||||||
INLINE_ONLY bool IsBigIntTerm(Term t) {
|
INLINE_ONLY bool IsBigIntTerm(Term t) {
|
||||||
@ -415,7 +395,11 @@ INLINE_ONLY bool IsBigIntTerm(Term t) {
|
|||||||
FunctorOfTerm(t) == FunctorBigInt;
|
FunctorOfTerm(t) == FunctorBigInt;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef USE_GMP
|
|
||||||
|
#if !defined(__cplusplus)
|
||||||
|
#include <gmp.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
Term Yap_MkBigIntTerm(MP_INT *);
|
Term Yap_MkBigIntTerm(MP_INT *);
|
||||||
MP_INT *Yap_BigIntOfTerm(Term);
|
MP_INT *Yap_BigIntOfTerm(Term);
|
||||||
|
4
H/YapEval.h
Normal file → Executable file
4
H/YapEval.h
Normal file → Executable file
@ -632,13 +632,13 @@ __Yap_Mk64IntegerTerm(YAP_LONG_LONG i USES_REGS) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
inline static Term add_int(Int i, Int j USES_REGS) {
|
inline static Term add_int(Int i, Int j USES_REGS) {
|
||||||
#if defined(__clang__) || defined(__GNUC__)
|
#if defined(__clang__) || (defined(__GNUC__) && __GNUC__ > 4)
|
||||||
Int w;
|
Int w;
|
||||||
if (!__builtin_add_overflow(i, j, &w))
|
if (!__builtin_add_overflow(i, j, &w))
|
||||||
RINT(w);
|
RINT(w);
|
||||||
return Yap_gmp_add_ints(i, j);
|
return Yap_gmp_add_ints(i, j);
|
||||||
;
|
;
|
||||||
#elif defined(__GNUC__)
|
#elif defined(__GNUC__) && __GNUC__ > 4
|
||||||
Int w;
|
Int w;
|
||||||
if (!__builtin_add_overflow_p(i, j, w))
|
if (!__builtin_add_overflow_p(i, j, w))
|
||||||
RINT(w);
|
RINT(w);
|
||||||
|
@ -24,13 +24,13 @@ inline static int sub_overflow(Int x, Int i, Int j) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
inline static Term sub_int(Int i, Int j USES_REGS) {
|
inline static Term sub_int(Int i, Int j USES_REGS) {
|
||||||
#if defined(__clang__ ) || defined(__GNUC__)
|
#if defined(__clang__ ) || (defined(__GNUC__) && __GNUC__ > 4)
|
||||||
Int k;
|
Int k;
|
||||||
if (__builtin_sub_overflow(i,j,&k)) {
|
if (__builtin_sub_overflow(i,j,&k)) {
|
||||||
return Yap_gmp_sub_ints(i, j);
|
return Yap_gmp_sub_ints(i, j);
|
||||||
}
|
}
|
||||||
RINT(k);
|
RINT(k);
|
||||||
#elif defined(__GNUC__)
|
#elif defined(__GNUC__) && __GNUC__ >4
|
||||||
Int w;
|
Int w;
|
||||||
if (!__builtin_sub_overflow_p(i,j,w))
|
if (!__builtin_sub_overflow_p(i,j,w))
|
||||||
RINT(w);
|
RINT(w);
|
||||||
@ -64,7 +64,7 @@ inline static int mul_overflow(Int z, Int i1, Int i2) {
|
|||||||
return (i2 && z / i2 != i1);
|
return (i2 && z / i2 != i1);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(__clang__) || defined(__GNUC__)
|
#if defined(__clang__) || (defined(__GNUC__) && __GNUC__ > 4)
|
||||||
#define DO_MULTI() \
|
#define DO_MULTI() \
|
||||||
if (__builtin_mul_overflow(i1, i2, &z)) { \
|
if (__builtin_mul_overflow(i1, i2, &z)) { \
|
||||||
goto overflow; \
|
goto overflow; \
|
||||||
|
5
os/fmem.c
Normal file → Executable file
5
os/fmem.c
Normal file → Executable file
@ -23,6 +23,9 @@ static char SccsId[] = "%W% %G%";
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#define _GNU_SOURCE
|
||||||
|
|
||||||
|
|
||||||
#include "YapText.h"
|
#include "YapText.h"
|
||||||
#include "format.h"
|
#include "format.h"
|
||||||
#include "sysbits.h"
|
#include "sysbits.h"
|
||||||
@ -163,7 +166,7 @@ int Yap_open_buf_read_stream(const char *buf, size_t nchars,
|
|||||||
f = st->file = fmemopen((void *)buf, nchars, "r");
|
f = st->file = fmemopen((void *)buf, nchars, "r");
|
||||||
st->vfs = NULL;
|
st->vfs = NULL;
|
||||||
flags = Input_Stream_f | InMemory_Stream_f | Seekable_Stream_f;
|
flags = Input_Stream_f | InMemory_Stream_f | Seekable_Stream_f;
|
||||||
Yap_initStream(sno, f, RepAtom(fname)->StrOfAE, "r", uname, encoding, flags, NULL);
|
Yap_initStream(sno, f, fname, "r", uname, encoding, flags, NULL);
|
||||||
// like any file stream.
|
// like any file stream.
|
||||||
Yap_DefaultStreamOps(st);
|
Yap_DefaultStreamOps(st);
|
||||||
UNLOCK(st->streamlock);
|
UNLOCK(st->streamlock);
|
||||||
|
16
os/iopreds.c
16
os/iopreds.c
@ -342,7 +342,7 @@ void Yap_DefaultStreamOps(StreamDesc *st) {
|
|||||||
st->stream_putc = st->vfs->put_char;
|
st->stream_putc = st->vfs->put_char;
|
||||||
st->stream_wputc = st->vfs->put_wchar;
|
st->stream_wputc = st->vfs->put_wchar;
|
||||||
st->stream_getc = st->vfs->get_char;
|
st->stream_getc = st->vfs->get_char;
|
||||||
st->stream_wgetc = st->vfs->get_char;
|
st->stream_wgetc = st->vfs->get_wchar;
|
||||||
default_peek(st);
|
default_peek(st);
|
||||||
return;
|
return;
|
||||||
} else {
|
} else {
|
||||||
@ -1126,7 +1126,7 @@ static void check_bom(int sno, StreamDesc *st) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Yap_initStream(int sno, FILE *fd, const char *name, const char *io_mode,
|
bool Yap_initStream(int sno, FILE *fd, Atom name, const char *io_mode,
|
||||||
Term file_name, encoding_t encoding, stream_flags_t flags,
|
Term file_name, encoding_t encoding, stream_flags_t flags,
|
||||||
void *vfs) {
|
void *vfs) {
|
||||||
// fprintf(stderr,"+ %s --> %d\n", name, sno);
|
// fprintf(stderr,"+ %s --> %d\n", name, sno);
|
||||||
@ -1228,7 +1228,8 @@ typedef enum open_enum_choices { OPEN_DEFS() } open_choices_t;
|
|||||||
static const param_t open_defs[] = {OPEN_DEFS()};
|
static const param_t open_defs[] = {OPEN_DEFS()};
|
||||||
#undef PAR
|
#undef PAR
|
||||||
|
|
||||||
static bool fill_stream(int sno, StreamDesc *st, Term tin, const char *io_mode, Term user_name, encoding_t enc) {
|
static bool fill_stream(int sno, StreamDesc *st, Term tin, const char *io_mode,
|
||||||
|
Term user_name, encoding_t enc) {
|
||||||
struct vfs *vfsp = NULL;
|
struct vfs *vfsp = NULL;
|
||||||
const char *fname;
|
const char *fname;
|
||||||
|
|
||||||
@ -1283,8 +1284,7 @@ static bool fill_stream(int sno, StreamDesc *st, Term tin, const char *io_mode,
|
|||||||
}
|
}
|
||||||
buf = pop_output_text_stack(j, buf);
|
buf = pop_output_text_stack(j, buf);
|
||||||
Atom nat = Yap_LookupAtom(Yap_StrPrefix(buf, 32));
|
Atom nat = Yap_LookupAtom(Yap_StrPrefix(buf, 32));
|
||||||
sno = Yap_open_buf_read_stream(buf, strlen(buf) + 1,
|
sno = Yap_open_buf_read_stream(buf, strlen(buf) + 1, &LOCAL_encoding,
|
||||||
&LOCAL_encoding,
|
|
||||||
MEM_BUF_MALLOC, nat,
|
MEM_BUF_MALLOC, nat,
|
||||||
MkAtomTerm(NameOfFunctor(f)));
|
MkAtomTerm(NameOfFunctor(f)));
|
||||||
pop_text_stack(j);
|
pop_text_stack(j);
|
||||||
@ -1313,8 +1313,8 @@ static bool fill_stream(int sno, StreamDesc *st, Term tin, const char *io_mode,
|
|||||||
if (!strchr(io_mode, 'b') && binary_file(fname)) {
|
if (!strchr(io_mode, 'b') && binary_file(fname)) {
|
||||||
st->status |= Binary_Stream_f;
|
st->status |= Binary_Stream_f;
|
||||||
}
|
}
|
||||||
Yap_initStream(sno, st->file, fname, io_mode, user_name, LOCAL_encoding,
|
Yap_initStream(sno, st->file, Yap_LookupAtom(fname), io_mode, user_name,
|
||||||
st->status, vfsp);
|
LOCAL_encoding, st->status, vfsp);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1670,7 +1670,7 @@ int Yap_OpenStream(Term tin, const char *io_mode, Term user_name,
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int Yap_FileStream(FILE *fd, char *name, Term file_name, int flags,
|
int Yap_FileStream(FILE *fd, Atom name, Term file_name, int flags,
|
||||||
VFS_t *vfsp) {
|
VFS_t *vfsp) {
|
||||||
CACHE_REGS
|
CACHE_REGS
|
||||||
int sno;
|
int sno;
|
||||||
|
2
os/iopreds.h
Normal file → Executable file
2
os/iopreds.h
Normal file → Executable file
@ -31,7 +31,7 @@ INLINE_ONLY bool IsStreamTerm(Term t) {
|
|||||||
(IsApplTerm(t) && (FunctorOfTerm(t) == FunctorStream)));
|
(IsApplTerm(t) && (FunctorOfTerm(t) == FunctorStream)));
|
||||||
}
|
}
|
||||||
|
|
||||||
extern bool Yap_initStream(int sno, FILE *fd, const char *name, const char *io_mode, Term file_name, encoding_t encoding,
|
extern bool Yap_initStream(int sno, FILE *fd, Atom name, const char *io_mode, Term file_name, encoding_t encoding,
|
||||||
stream_flags_t flags, void *vfs);
|
stream_flags_t flags, void *vfs);
|
||||||
|
|
||||||
#define Yap_CheckStream(arg, kind, msg) \
|
#define Yap_CheckStream(arg, kind, msg) \
|
||||||
|
2
os/mem.c
Normal file → Executable file
2
os/mem.c
Normal file → Executable file
@ -225,7 +225,7 @@ int Yap_open_buf_read_stream(const char *buf, size_t nchars, encoding_t *encp,
|
|||||||
flags = Input_Stream_f | InMemory_Stream_f;
|
flags = Input_Stream_f | InMemory_Stream_f;
|
||||||
st->vfs = NULL;
|
st->vfs = NULL;
|
||||||
st->name = name;
|
st->name = name;
|
||||||
Yap_initStream(sno, f, "Memory Stream","wa", TermNil, encoding, flags, NULL);
|
Yap_initStream(sno, f, Yap_LookupAtom("Memory Stream"),"wa", TermNil, encoding, flags, NULL);
|
||||||
// like any file stream.
|
// like any file stream.
|
||||||
/* currently these streams are not seekable */
|
/* currently these streams are not seekable */
|
||||||
st->status = Input_Stream_f | InMemory_Stream_f;
|
st->status = Input_Stream_f | InMemory_Stream_f;
|
||||||
|
2
os/readline.c
Normal file → Executable file
2
os/readline.c
Normal file → Executable file
@ -218,7 +218,7 @@ static char **prolog_completion(const char *text, int start, int end) {
|
|||||||
} else if (start == 0) {
|
} else if (start == 0) {
|
||||||
int i = 0;
|
int i = 0;
|
||||||
const char *p;
|
const char *p;
|
||||||
while (isblank(text[i++]) && i <= end)
|
while (isspace(text[i++]) && i <= end)
|
||||||
;
|
;
|
||||||
p = text + i;
|
p = text + i;
|
||||||
|
|
||||||
|
@ -363,7 +363,6 @@ Atom Yap_guessFileName(FILE *file, int sno, size_t max) {
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
if (!StreamName(sno)) {
|
if (!StreamName(sno)) {
|
||||||
pop_text_stack(i);
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
pop_text_stack(i);
|
pop_text_stack(i);
|
||||||
|
26
os/yapio.h
26
os/yapio.h
@ -26,8 +26,8 @@
|
|||||||
#include <wchar.h>
|
#include <wchar.h>
|
||||||
|
|
||||||
#include "YapIOConfig.h"
|
#include "YapIOConfig.h"
|
||||||
#include <Yatom.h>
|
|
||||||
#include <VFS.h>
|
#include <VFS.h>
|
||||||
|
#include <Yatom.h>
|
||||||
|
|
||||||
#ifndef _PL_WRITE_
|
#ifndef _PL_WRITE_
|
||||||
|
|
||||||
@ -85,8 +85,9 @@ extern int Yap_PlGetWchar(void);
|
|||||||
extern int Yap_PlFGetchar(void);
|
extern int Yap_PlFGetchar(void);
|
||||||
extern int Yap_GetCharForSIGINT(void);
|
extern int Yap_GetCharForSIGINT(void);
|
||||||
extern Int Yap_StreamToFileNo(Term);
|
extern Int Yap_StreamToFileNo(Term);
|
||||||
extern int Yap_OpenStream(Term tin, const char* io_mode, Term user_name, encoding_t enc);
|
extern int Yap_OpenStream(Term tin, const char *io_mode, Term user_name,
|
||||||
extern int Yap_FileStream(FILE*, char *, Term, int, VFS_t *);
|
encoding_t enc);
|
||||||
|
extern int Yap_FileStream(FILE *, Atom, Term, int, VFS_t *);
|
||||||
extern char *Yap_TermToBuffer(Term t, int flags);
|
extern char *Yap_TermToBuffer(Term t, int flags);
|
||||||
extern char *Yap_HandleToString(yhandle_t l, size_t sz, size_t *length,
|
extern char *Yap_HandleToString(yhandle_t l, size_t sz, size_t *length,
|
||||||
encoding_t *encoding, int flags);
|
encoding_t *encoding, int flags);
|
||||||
@ -118,11 +119,12 @@ extern Term Yap_StringToNumberTerm(const char *s, encoding_t *encp,
|
|||||||
bool error_on);
|
bool error_on);
|
||||||
extern int Yap_FormatFloat(Float f, char **s, size_t sz);
|
extern int Yap_FormatFloat(Float f, char **s, size_t sz);
|
||||||
extern int Yap_open_buf_read_stream(const char *buf, size_t nchars,
|
extern int Yap_open_buf_read_stream(const char *buf, size_t nchars,
|
||||||
encoding_t *encp, memBufSource src, Atom name,
|
encoding_t *encp, memBufSource src,
|
||||||
Term uname);
|
Atom name, Term uname);
|
||||||
extern int Yap_open_buf_write_stream(encoding_t enc, memBufSource src);
|
extern int Yap_open_buf_write_stream(encoding_t enc, memBufSource src);
|
||||||
extern Term Yap_BufferToTerm(const char *s, Term opts);
|
extern Term Yap_BufferToTerm(const char *s, Term opts);
|
||||||
extern X_API Term Yap_BufferToTermWithPrioBindings(const char *s, Term opts, Term bindings, size_t sz,
|
extern X_API Term Yap_BufferToTermWithPrioBindings(const char *s, Term opts,
|
||||||
|
Term bindings, size_t sz,
|
||||||
int prio);
|
int prio);
|
||||||
extern FILE *Yap_GetInputStream(Term t, const char *m);
|
extern FILE *Yap_GetInputStream(Term t, const char *m);
|
||||||
extern FILE *Yap_GetOutputStream(Term t, const char *m);
|
extern FILE *Yap_GetOutputStream(Term t, const char *m);
|
||||||
@ -156,16 +158,14 @@ INLINE_ONLY Term MkCharTerm(Int c) {
|
|||||||
return MkAtomTerm(Yap_ULookupAtom(cs));
|
return MkAtomTerm(Yap_ULookupAtom(cs));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
extern char *GLOBAL_cwd;
|
extern char *GLOBAL_cwd;
|
||||||
|
|
||||||
|
|
||||||
INLINE_ONLY char *Yap_VF(const char *path) {
|
INLINE_ONLY char *Yap_VF(const char *path) {
|
||||||
char *out;
|
char *out;
|
||||||
|
|
||||||
out = (char *)malloc(YAP_FILENAME_MAX + 1);
|
out = (char *)malloc(YAP_FILENAME_MAX + 1);
|
||||||
if ( GLOBAL_cwd == NULL || GLOBAL_cwd[0] == 0 || !Yap_IsAbsolutePath(path, false)) {
|
if (GLOBAL_cwd == NULL || GLOBAL_cwd[0] == 0 ||
|
||||||
|
!Yap_IsAbsolutePath(path, false)) {
|
||||||
return (char *)path;
|
return (char *)path;
|
||||||
}
|
}
|
||||||
strcpy(out, GLOBAL_cwd);
|
strcpy(out, GLOBAL_cwd);
|
||||||
@ -174,12 +174,12 @@ INLINE_ONLY char *Yap_VF(const char *path){
|
|||||||
return out;
|
return out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
INLINE_ONLY char *Yap_VFAlloc(const char *path) {
|
INLINE_ONLY char *Yap_VFAlloc(const char *path) {
|
||||||
char *out;
|
char *out;
|
||||||
|
|
||||||
out = (char *)malloc(YAP_FILENAME_MAX + 1);
|
out = (char *)malloc(YAP_FILENAME_MAX + 1);
|
||||||
if ( GLOBAL_cwd == NULL || GLOBAL_cwd[0] == 0 || !Yap_IsAbsolutePath(path, false)) {
|
if (GLOBAL_cwd == NULL || GLOBAL_cwd[0] == 0 ||
|
||||||
|
!Yap_IsAbsolutePath(path, false)) {
|
||||||
return (char *)path;
|
return (char *)path;
|
||||||
}
|
}
|
||||||
strcpy(out, GLOBAL_cwd);
|
strcpy(out, GLOBAL_cwd);
|
||||||
@ -193,6 +193,4 @@ extern uint64_t Yap_StartOfWTimes;
|
|||||||
|
|
||||||
extern bool Yap_HandleSIGINT(void);
|
extern bool Yap_HandleSIGINT(void);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Reference in New Issue
Block a user