| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | /*************************************************************************
 | 
					
						
							| 
									
										
										
										
											2016-08-01 19:17:56 -05:00
										 |  |  |  *									 * | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |  *	 YAP Prolog							 * | 
					
						
							| 
									
										
										
										
											2016-08-01 19:17:56 -05:00
										 |  |  |  *									 * | 
					
						
							|  |  |  |  *	Yap Prolog was developed at NCCUP - Universidade do Porto	 * | 
					
						
							|  |  |  |  *									 * | 
					
						
							|  |  |  |  * Copyright L.Damas, V.S.Costa and Universidade do Porto 1985-1997	 * | 
					
						
							|  |  |  |  *									 * | 
					
						
							|  |  |  |  ************************************************************************** | 
					
						
							|  |  |  |  *									 * | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |  * File:		iopreds.c * | 
					
						
							| 
									
										
										
										
											2016-08-01 19:17:56 -05:00
										 |  |  |  * Last rev:	5/2/88							 * | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |  * mods: * | 
					
						
							| 
									
										
										
										
											2016-08-01 19:17:56 -05:00
										 |  |  |  * comments:	Input/Output C implemented predicates			 * | 
					
						
							|  |  |  |  *									 * | 
					
						
							|  |  |  |  *************************************************************************/ | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | #ifdef SCCS
 | 
					
						
							|  |  |  | static char SccsId[] = "%W% %G%"; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2016-08-01 19:17:56 -05:00
										 |  |  |  * This file includes the definition of a miscellania of standard predicates | 
					
						
							|  |  |  |  * for yap refering to: Files and GLOBAL_Streams, Simple Input/Output, | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "Yap.h"
 | 
					
						
							| 
									
										
										
										
											2017-08-27 22:22:34 +01:00
										 |  |  | #include "YapEval.h"
 | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | #include "YapFlags.h"
 | 
					
						
							| 
									
										
										
										
											2016-04-12 16:04:33 +01:00
										 |  |  | #include "YapHeap.h"
 | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | #include "YapText.h"
 | 
					
						
							| 
									
										
										
										
											2016-04-12 16:04:33 +01:00
										 |  |  | #include "Yatom.h"
 | 
					
						
							|  |  |  | #include "yapio.h"
 | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | #include <stdlib.h>
 | 
					
						
							|  |  |  | #if HAVE_STDARG_H
 | 
					
						
							|  |  |  | #include <stdarg.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_CTYPE_H
 | 
					
						
							|  |  |  | #include <ctype.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_WCTYPE_H
 | 
					
						
							|  |  |  | #include <wctype.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_SYS_TIME_H
 | 
					
						
							|  |  |  | #include <sys/time.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_SYS_TYPES_H
 | 
					
						
							|  |  |  | #include <sys/types.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef HAVE_SYS_STAT_H
 | 
					
						
							|  |  |  | #include <sys/stat.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_SYS_SELECT_H && !_MSC_VER && !defined(__MINGW32__)
 | 
					
						
							|  |  |  | #include <sys/select.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef HAVE_UNISTD_H
 | 
					
						
							|  |  |  | #include <unistd.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_STRING_H
 | 
					
						
							|  |  |  | #include <string.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_SIGNAL_H
 | 
					
						
							|  |  |  | #include <signal.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_FCNTL_H
 | 
					
						
							|  |  |  | /* for O_BINARY and O_TEXT in WIN32 */ | 
					
						
							|  |  |  | #include <fcntl.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef _WIN32
 | 
					
						
							|  |  |  | #if HAVE_IO_H
 | 
					
						
							| 
									
										
										
										
											2016-04-10 06:21:17 -07:00
										 |  |  | /* priows */ | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | #include <io.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if !HAVE_STRNCAT
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | #define strncat(X, Y, Z) strcat(X, Y)
 | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #if !HAVE_STRNCPY
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | #define strncpy(X, Y, Z) strcpy(X, Y)
 | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #if _MSC_VER || defined(__MINGW32__)
 | 
					
						
							|  |  |  | #if HAVE_SOCKET
 | 
					
						
							|  |  |  | #include <winsock2.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #include <windows.h>
 | 
					
						
							|  |  |  | #ifndef S_ISDIR
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | #define S_ISDIR(x) (((x)&_S_IFDIR) == _S_IFDIR)
 | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #include "iopreds.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if _MSC_VER || defined(__MINGW32__)
 | 
					
						
							|  |  |  | #define SYSTEM_STAT _stat
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define SYSTEM_STAT stat
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | static Term syntax_error(TokEntry *errtok, int sno, Term cmod, Int start, bool code, const char *msg); | 
					
						
							| 
									
										
										
										
											2016-02-14 04:15:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | static void clean_vars(VarEntry *p) { | 
					
						
							|  |  |  |   if (p == NULL) | 
					
						
							|  |  |  |     return; | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  |   p->VarAdr = TermNil; | 
					
						
							|  |  |  |   clean_vars(p->VarLeft); | 
					
						
							|  |  |  |   clean_vars(p->VarRight); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #undef PAR
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef O_QUASIQUOTATIONS
 | 
					
						
							|  |  |  | /** '$qq_open'(+QQRange, -Stream) is det.
 | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 15:20:17 +01:00
										 |  |  |     Opens a quasi-quoted memory range. | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-02 15:20:17 +01:00
										 |  |  |     @arg QQRange is a term '$quasi_quotation'(ReadData, Start, Length) | 
					
						
							|  |  |  |     @arg Stream  is a UTF-8 encoded string, whose position indication | 
					
						
							|  |  |  |     reflects the location in the real file. | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | static Int qq_open(USES_REGS1) { | 
					
						
							|  |  |  |   PRED_LD | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     Term t = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |   if (!IsVarTerm(t) && IsApplTerm(t) && FunctorOfTerm(t) = | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |       FunctorDQuasiQuotation) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     void *ptr; | 
					
						
							|  |  |  |     char *start; | 
					
						
							|  |  |  |     size_t l int s; | 
					
						
							|  |  |  |     Term t0, t1, t2; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (IsPointerTerm((t0 = ArgOfTerm(1, t))) && | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 	IsPointerTerm((t1 = ArgOfTerm(2, t))) && | 
					
						
							|  |  |  | 	IsIntegerTerm((t2 = ArgOfTerm(3, t)))) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |       ptr = PointerOfTerm(t0); | 
					
						
							|  |  |  |       start = PointerOfTerm(t1); | 
					
						
							|  |  |  |       len = IntegerOfTerm(t2); | 
					
						
							|  |  |  |       if ((s = Yap_open_buf_read_stream(start, len, ENC_UTF8, MEM_BUF_USER)) < | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 	  0) | 
					
						
							|  |  |  | 	return false; | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |       return Yap_unify(ARG2, Yap_MkStream(s)); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_READ_CONTEXT, t); | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | static int parse_quasi_quotations(ReadData _PL_rd ARG_LD) { | 
					
						
							|  |  |  |   if (_PL_rd->qq_tail) { | 
					
						
							|  |  |  |     term_t av; | 
					
						
							|  |  |  |     int rc; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!PL_unify_nil(_PL_rd->qq_tail)) | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!_PL_rd->quasi_quotations) { | 
					
						
							|  |  |  |       if ((av = PL_new_term_refs(2)) && PL_put_term(av + 0, _PL_rd->qq) && | 
					
						
							|  |  |  | #if __YAP_PROLOG__
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 	  PL_put_atom(av + 1, YAP_SWIAtomFromAtom(_PL_rd->module->AtomOfME)) && | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 	  PL_put_atom(av + 1, _PL_rd->module->name) && | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 	  PL_cons_functor_v(av, FUNCTOR_dparse_quasi_quotations2, av)) { | 
					
						
							|  |  |  | 	term_t ex; | 
					
						
							|  |  |  | 	rc = callProlog(MODULE_system, av + 0, PL_Q_CATCH_EXCEPTION, &ex); | 
					
						
							|  |  |  | 	if (rc) | 
					
						
							|  |  |  | 	  return TRUE; | 
					
						
							|  |  |  | 	_PL_rd->exception = ex; | 
					
						
							|  |  |  | 	_PL_rd->has_exception = TRUE; | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |       } | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  |     } else | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |       return TRUE; | 
					
						
							|  |  |  |   } else if (_PL_rd->quasi_quotations) /* user option, but no quotes */ | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |       return PL_unify_nil(_PL_rd->quasi_quotations); | 
					
						
							|  |  |  |     } else | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  |     return TRUE; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | #endif /*O_QUASIQUOTATIONS*/
 | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | #define READ_DEFS()							\
 | 
					
						
							|  |  |  |   PAR("comments", list_filler, READ_COMMENTS)				\ | 
					
						
							|  |  |  |   , PAR("module", isatom, READ_MODULE), PAR("priority", nat, READ_PRIORITY), \ | 
					
						
							|  |  |  |     PAR("output", filler, READ_OUTPUT),					\ | 
					
						
							|  |  |  |     PAR("quasi_quotations", filler, READ_QUASI_QUOTATIONS),		\ | 
					
						
							|  |  |  |     PAR("term_position", filler, READ_TERM_POSITION),			\ | 
					
						
							|  |  |  |     PAR("syntax_errors", isatom, READ_SYNTAX_ERRORS),			\ | 
					
						
							|  |  |  |     PAR("singletons", filler, READ_SINGLETONS),				\ | 
					
						
							|  |  |  |     PAR("variables", filler, READ_VARIABLES),				\ | 
					
						
							|  |  |  |     PAR("variable_names", filler, READ_VARIABLE_NAMES),			\ | 
					
						
							|  |  |  |     PAR("character_escapes", booleanFlag, READ_CHARACTER_ESCAPES),	\ | 
					
						
							|  |  |  |     PAR("backquoted_string", isatom, READ_BACKQUOTED_STRING),		\ | 
					
						
							|  |  |  |     PAR("cycles", ok, READ_CYCLES), PAR(NULL, ok, READ_END) | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | #define PAR(x, y, z) z
 | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | typedef enum open_enum_choices { READ_DEFS() } read_choices_t; | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | #undef PAR
 | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | #define PAR(x, y, z)				\
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |   { x, y, z } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static const param_t read_defs[] = {READ_DEFS()}; | 
					
						
							|  |  |  | #undef PAR
 | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-04 12:52:42 -06:00
										 |  |  | static Term add_output(Term t, Term tail) { | 
					
						
							|  |  |  |   Term topt = Yap_MkNewApplTerm(Yap_MkFunctor(AtomOutput, 1), 1); | 
					
						
							| 
									
										
										
										
											2018-06-14 11:27:43 +01:00
										 |  |  |   tail = Deref(tail); | 
					
						
							|  |  |  |   if (IsVarTerm(tail)) { | 
					
						
							|  |  |  |     Yap_ThrowError(INSTANTIATION_ERROR, tail, "unbound list of options"); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-12-04 12:52:42 -06:00
										 |  |  |   Yap_unify(t, ArgOfTerm(1, topt)); | 
					
						
							| 
									
										
										
										
											2018-06-14 11:27:43 +01:00
										 |  |  |   if (IsVarTerm(tail)) { | 
					
						
							|  |  |  |     Yap_ThrowError(INSTANTIATION_ERROR, tail, "unbound list of options"); | 
					
						
							|  |  |  |   } else if (IsPairTerm(tail) || tail == TermNil) { | 
					
						
							| 
									
										
										
										
											2016-12-05 14:50:04 -06:00
										 |  |  |     return MkPairTerm(topt, tail); | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     return MkPairTerm(topt, MkPairTerm(tail, TermNil)); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-12-04 12:52:42 -06:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static Term add_names(Term t, Term tail) { | 
					
						
							|  |  |  |   Term topt = Yap_MkNewApplTerm(Yap_MkFunctor(AtomVariableNames, 1), 1); | 
					
						
							|  |  |  |   Yap_unify(t, ArgOfTerm(1, topt)); | 
					
						
							| 
									
										
										
										
											2018-06-14 11:27:43 +01:00
										 |  |  |   if (IsVarTerm(tail)) { | 
					
						
							|  |  |  |     Yap_ThrowError(INSTANTIATION_ERROR, tail, "unbound list of options"); | 
					
						
							|  |  |  |   } else if (IsPairTerm(tail) || tail == TermNil) { | 
					
						
							| 
									
										
										
										
											2016-12-05 14:50:04 -06:00
										 |  |  |     return MkPairTerm(topt, tail); | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     return MkPairTerm(topt, MkPairTerm(tail, TermNil)); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-12-04 12:52:42 -06:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static Term add_priority(Term t, Term tail) { | 
					
						
							|  |  |  |   Term topt = Yap_MkNewApplTerm(Yap_MkFunctor(AtomPriority, 1), 1); | 
					
						
							|  |  |  |   Yap_unify(t, ArgOfTerm(1, topt)); | 
					
						
							| 
									
										
										
										
											2018-06-14 11:27:43 +01:00
										 |  |  |   if (IsVarTerm(tail)) { | 
					
						
							|  |  |  |     Yap_ThrowError(INSTANTIATION_ERROR, tail, "unbound list of options"); | 
					
						
							|  |  |  |   } else if (IsPairTerm(tail) || tail == TermNil) { | 
					
						
							| 
									
										
										
										
											2016-12-05 14:50:04 -06:00
										 |  |  |     return MkPairTerm(topt, tail); | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     return MkPairTerm(topt, MkPairTerm(tail, TermNil)); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-12-04 12:52:42 -06:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-27 22:22:34 +01:00
										 |  |  | static Term scanToList(TokEntry *tok, TokEntry *errtok) { | 
					
						
							| 
									
										
										
										
											2017-08-21 12:29:58 +01:00
										 |  |  |   TokEntry *tok0 = tok; | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  |   CELL *Hi = HR; | 
					
						
							| 
									
										
										
										
											2017-08-27 22:22:34 +01:00
										 |  |  |   Term ts[1]; | 
					
						
							|  |  |  |   ts[0] = TermNil; | 
					
						
							|  |  |  |   Term *tailp = ts; | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-27 22:22:34 +01:00
										 |  |  |   while (tok) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-27 22:22:34 +01:00
										 |  |  |     if (HR > ASP - 1024) { | 
					
						
							|  |  |  |       Int used = HR - Hi; | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |       /* for some reason moving this earlier confuses gcc on solaris */ | 
					
						
							|  |  |  |       HR = Hi; | 
					
						
							| 
									
										
										
										
											2017-08-21 12:29:58 +01:00
										 |  |  |       tok = tok0; | 
					
						
							| 
									
										
										
										
											2017-08-27 22:22:34 +01:00
										 |  |  |       if (!Yap_gcl(used, 1, ENV, CP)) { | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 	return 0; | 
					
						
							| 
									
										
										
										
											2017-08-21 12:29:58 +01:00
										 |  |  |       } | 
					
						
							|  |  |  |       continue; | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2017-08-27 22:22:34 +01:00
										 |  |  |     if (tok == errtok && tok->Tok != Error_tok) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |       *tailp = MkPairTerm(MkAtomTerm(AtomError), TermNil); | 
					
						
							|  |  |  |       tailp = RepPair(*tailp) + 1; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-11-16 17:17:33 -06:00
										 |  |  |     Term rep = Yap_tokRep(tok); | 
					
						
							|  |  |  |     *tailp = MkPairTerm(rep, TermNil); | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     tailp = RepPair(*tailp) + 1; | 
					
						
							| 
									
										
										
										
											2017-08-27 22:22:34 +01:00
										 |  |  |     if (tok->TokNext == NULL) { | 
					
						
							|  |  |  |       break; | 
					
						
							| 
									
										
										
										
											2017-08-21 12:29:58 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2017-08-27 22:22:34 +01:00
										 |  |  |     tok = tok->TokNext; | 
					
						
							| 
									
										
										
										
											2015-07-27 22:22:44 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2017-08-27 22:22:34 +01:00
										 |  |  |   return ts[0]; | 
					
						
							| 
									
										
										
										
											2017-08-21 12:29:58 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-27 22:22:34 +01:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2018-07-02 15:20:17 +01:00
										 |  |  |    @pred scan_to_list( +Stream, -Tokens ) | 
					
						
							| 
									
										
										
										
											2018-07-21 12:08:09 +01:00
										 |  |  |    Generate a list of tokens from a scan of the (input) stream, Tokens are of | 
					
						
							|  |  |  |    the form: | 
					
						
							| 
									
										
										
										
											2018-07-02 15:20:17 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |    + `atom`(Atom) | 
					
						
							|  |  |  |    + `<QQ>`(Text) | 
					
						
							|  |  |  |    + `number`(Number) | 
					
						
							|  |  |  |    + `var`(VarName) | 
					
						
							|  |  |  |    + `string`(String) | 
					
						
							|  |  |  |    + 'EOF'' | 
					
						
							|  |  |  |    + symbols, including `(`, `)`, `,`, `;` | 
					
						
							| 
									
										
										
										
											2017-08-21 12:29:58 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2017-09-23 02:17:55 +01:00
										 |  |  | static Int scan_to_list(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2017-08-27 22:22:34 +01:00
										 |  |  |   int inp_stream; | 
					
						
							|  |  |  |   Term tpos, tout; | 
					
						
							| 
									
										
										
										
											2017-08-21 12:29:58 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-27 22:22:34 +01:00
										 |  |  |   /* needs to change LOCAL_output_stream for write */ | 
					
						
							|  |  |  |   inp_stream = Yap_CheckTextStream(ARG1, Input_Stream_f, "read/3"); | 
					
						
							|  |  |  |   if (inp_stream == -1) { | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   TokEntry *tok = LOCAL_tokptr = LOCAL_toktide = | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     Yap_tokenizer(GLOBAL_Stream + inp_stream, false, &tpos); | 
					
						
							| 
									
										
										
										
											2017-08-27 22:22:34 +01:00
										 |  |  |   UNLOCK(GLOBAL_Stream[inp_stream].streamlock); | 
					
						
							|  |  |  |   tout = scanToList(tok, NULL); | 
					
						
							|  |  |  |   if (tout == 0) | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  |   Yap_clean_tokenizer(tok, LOCAL_VarTable, LOCAL_AnonVarTable); | 
					
						
							| 
									
										
										
										
											2017-08-21 12:29:58 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-27 22:22:34 +01:00
										 |  |  |   return Yap_unify(ARG2, tout); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |  * Syntax Error Handler | 
					
						
							| 
									
										
										
										
											2017-08-21 12:29:58 +01:00
										 |  |  |  * | 
					
						
							|  |  |  |  * @par tokptr: the sequence of tokens | 
					
						
							|  |  |  |  * @par sno: the stream numbet | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Implicit arguments: | 
					
						
							|  |  |  |  *    + | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | static Term syntax_error(TokEntry *errtok, int sno, Term cmod, Int newpos, bool code, const char *msg) { | 
					
						
							| 
									
										
										
										
											2017-08-27 22:22:34 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |   Yap_MkErrorRecord( LOCAL_ActiveError, __FILE__, __FUNCTION__, __LINE__, SYNTAX_ERROR,  0,  NULL); | 
					
						
							| 
									
										
										
										
											2017-08-27 22:22:34 +01:00
										 |  |  |   TokEntry *tok = LOCAL_tokptr; | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |   Int start_line = tok->TokLine; | 
					
						
							|  |  |  |   Int err_line = errtok->TokLine; | 
					
						
							|  |  |  |   Int end_line = GetCurInpLine(GLOBAL_Stream+sno); | 
					
						
							| 
									
										
										
										
											2018-02-21 13:02:20 +00:00
										 |  |  |   Int startpos = tok->TokPos; | 
					
						
							|  |  |  |   Int errpos = errtok->TokPos; | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |   Int endpos = GetCurInpPos(GLOBAL_Stream+sno); | 
					
						
							| 
									
										
										
										
											2018-05-16 00:00:12 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |   Yap_local.ActiveError->errorNo = SYNTAX_ERROR; | 
					
						
							|  |  |  |   Yap_local.ActiveError->parserFirstLine =  start_line; | 
					
						
							|  |  |  |   Yap_local.ActiveError->parserLine = err_line; | 
					
						
							|  |  |  |   Yap_local.ActiveError->parserLastLine = end_line; | 
					
						
							|  |  |  |   Yap_local.ActiveError->parserFirstPos =  startpos; | 
					
						
							|  |  |  |   Yap_local.ActiveError->parserPos = errpos; | 
					
						
							|  |  |  |   Yap_local.ActiveError->parserLastPos =endpos; | 
					
						
							|  |  |  |   Yap_local.ActiveError->parserFile = | 
					
						
							|  |  |  |     RepAtom(AtomOfTerm((GLOBAL_Stream+sno)->user_name))->StrOfAE; | 
					
						
							|  |  |  |   Yap_local.ActiveError->parserReadingCode = code; | 
					
						
							| 
									
										
										
										
											2018-01-05 16:57:38 +00:00
										 |  |  | #if HAVE_FTELLO
 | 
					
						
							| 
									
										
										
										
											2018-02-01 01:44:34 +00:00
										 |  |  |       fseeko(GLOBAL_Stream[sno].file, startpos, SEEK_SET); | 
					
						
							| 
									
										
										
										
											2018-01-05 16:57:38 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2018-02-01 01:44:34 +00:00
										 |  |  |       fseek(GLOBAL_Stream[sno].file, startpos, SEEK_SET); | 
					
						
							| 
									
										
										
										
											2018-01-05 16:57:38 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |   int lvl = push_text_stack(); | 
					
						
							|  |  |  |   if (GLOBAL_Stream[sno].status & Seekable_Stream_f) { | 
					
						
							|  |  |  |     char *o, *o2; | 
					
						
							|  |  |  |     if (errpos <= startpos) { | 
					
						
							|  |  |  |       o  = malloc(1); | 
					
						
							|  |  |  |       o[0] = '\0'; | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       Int sza = (errpos-startpos)+1; | 
					
						
							|  |  |  |       o  = malloc(sza); | 
					
						
							|  |  |  |       fread(o,sza-1,1,GLOBAL_Stream[sno].file); | 
					
						
							|  |  |  |       o[sza-1] = '\0'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     Yap_local.ActiveError->parserTextA = o; | 
					
						
							|  |  |  |     if (endpos <= errpos) { | 
					
						
							|  |  |  |       o2  = malloc(1); | 
					
						
							|  |  |  |       o2[0] = '\0'; | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       Int sza = (endpos-errpos)+1; | 
					
						
							|  |  |  |       o2  = malloc(sza); | 
					
						
							|  |  |  |       fread(o2,sza-1,1,GLOBAL_Stream[sno].file); | 
					
						
							|  |  |  |       o2[sza-1] = '\0'; | 
					
						
							| 
									
										
										
										
											2018-02-01 01:44:34 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     Yap_local.ActiveError->parserTextB = o2; | 
					
						
							| 
									
										
										
										
											2018-01-05 16:57:38 +00:00
										 |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     size_t sz = 1024, total=sz, e; | 
					
						
							|  |  |  |     char *o = malloc(1024); | 
					
						
							|  |  |  |     char *s = o; | 
					
						
							|  |  |  |     o[0] = '\0'; | 
					
						
							| 
									
										
										
										
											2018-01-05 16:57:38 +00:00
										 |  |  |     while (tok) { | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |       if (tok->Tok == Error_tok) { | 
					
						
							|  |  |  | 	o = realloc(o, strlen(o)+1); | 
					
						
							|  |  |  | 	Yap_local.ActiveError->parserTextA= o; | 
					
						
							|  |  |  | 	o = malloc(1024); | 
					
						
							|  |  |  | 	total = sz = 1024; | 
					
						
							|  |  |  | 	tok = tok->TokNext; | 
					
						
							|  |  |  | 	continue; | 
					
						
							| 
									
										
										
										
											2018-01-05 16:57:38 +00:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |       const char *ns = Yap_tokText(tok); | 
					
						
							|  |  |  |       e = strlen(ns); | 
					
						
							|  |  |  |       if (ns && ns[0] && e+1 > sz-256) { | 
					
						
							|  |  |  | 	strcat(s,ns); | 
					
						
							|  |  |  | 	o +=  e; | 
					
						
							|  |  |  | 	sz -= e; | 
					
						
							| 
									
										
										
										
											2018-01-05 16:57:38 +00:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |       if (tok->TokNext && tok->TokNext->TokLine > tok->TokLine) { | 
					
						
							|  |  |  | 	strcat(s,"\n") | 
					
						
							|  |  |  | 	  ;sz--; | 
					
						
							| 
									
										
										
										
											2018-01-05 16:57:38 +00:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |       tok = tok->TokNext; | 
					
						
							| 
									
										
										
										
											2017-08-27 22:22:34 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     o = realloc(o, strlen(o)+1); | 
					
						
							|  |  |  |     Yap_local.ActiveError->parserTextA= o; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-27 22:22:34 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-27 22:22:34 +01:00
										 |  |  |   /* 0:  strat, error, end line */ | 
					
						
							|  |  |  |   /*2 msg */ | 
					
						
							|  |  |  |   /* 1: file */ | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |   if (!msg) | 
					
						
							|  |  |  |     msg = "unspecified"; | 
					
						
							|  |  |  |   Yap_local.ActiveError->culprit = | 
					
						
							|  |  |  |   Yap_local.ActiveError->errorMsg = (char*)msg; | 
					
						
							|  |  |  |   Yap_local.ActiveError->errorMsgLen = strlen(msg); | 
					
						
							| 
									
										
										
										
											2017-08-27 22:22:34 +01:00
										 |  |  |   clean_vars(LOCAL_VarTable); | 
					
						
							|  |  |  |   clean_vars(LOCAL_AnonVarTable); | 
					
						
							| 
									
										
										
										
											2016-01-03 02:06:09 +00:00
										 |  |  |   if (Yap_ExecutionMode == YAP_BOOT_MODE) { | 
					
						
							|  |  |  |     fprintf(stderr, "SYNTAX ERROR while booting: "); | 
					
						
							| 
									
										
										
										
											2018-07-21 12:08:09 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |   pop_text_stack(lvl); | 
					
						
							|  |  |  |   return  Yap_MkFullError(); | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | Term Yap_syntax_error(TokEntry *errtok, int sno, const char *msg) { | 
					
						
							|  |  |  |   return syntax_error(errtok, sno, CurrentModule, -1, false, msg); | 
					
						
							| 
									
										
										
										
											2016-04-12 16:04:33 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | typedef struct FEnv { | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  |   Term qq, tp, sp, np, vp, ce; | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |   Term tpos;           /// initial position of the term to be read.
 | 
					
						
							| 
									
										
										
										
											2016-12-04 12:52:42 -06:00
										 |  |  |   Term t, t0;          /// the output term
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |   TokEntry *tokstart;  /// the token list
 | 
					
						
							|  |  |  |   TokEntry *toklast;   /// the last token
 | 
					
						
							|  |  |  |   CELL *old_H;         /// initial H, will be reset on stack overflow.
 | 
					
						
							|  |  |  |   tr_fr_ptr old_TR;    /// initial TR
 | 
					
						
							|  |  |  |   xarg *args;          /// input args
 | 
					
						
							|  |  |  |   bool reading_clause; /// read_clause
 | 
					
						
							|  |  |  |   size_t nargs;        /// arity of current procedure
 | 
					
						
							| 
									
										
										
										
											2015-12-15 09:28:43 +00:00
										 |  |  |   encoding_t enc;      /// encoding of the stream being read
 | 
					
						
							| 
									
										
										
										
											2016-01-20 22:38:09 +00:00
										 |  |  |   Term tcomms;         /// Access to comments
 | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  |   Term cmod;           /// Access to comments
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |   char *msg;           /// Error  Messagge
 | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | } FEnv; | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | typedef struct renv { | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  |   Term bq; | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |   bool ce, sw; | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   Term sy; | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  |   UInt cpos; | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   int prio; | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  |   int ungetc_oldc; | 
					
						
							|  |  |  |   int had_ungetc; | 
					
						
							|  |  |  |   bool seekable; | 
					
						
							|  |  |  | } REnv; | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | static xarg *setClauseReadEnv(Term opts, FEnv *fe, struct renv *re, | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 			      int inp_stream); | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | static xarg *setReadEnv(Term opts, FEnv *fe, struct renv *re, int inp_stream) { | 
					
						
							| 
									
										
										
										
											2016-04-12 16:04:33 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     LOCAL_VarTable = NULL; | 
					
						
							| 
									
										
										
										
											2015-10-18 11:48:51 +01:00
										 |  |  |   LOCAL_AnonVarTable = NULL; | 
					
						
							| 
									
										
										
										
											2015-12-15 09:28:43 +00:00
										 |  |  |   fe->enc = GLOBAL_Stream[inp_stream].encoding; | 
					
						
							| 
									
										
										
										
											2018-06-14 11:27:43 +01:00
										 |  |  |   xarg *args = | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     Yap_ArgListToVector(opts, read_defs, READ_END, DOMAIN_ERROR_READ_OPTION); | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   if (args == NULL) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     return NULL; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-01-03 02:06:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-19 11:44:16 +00:00
										 |  |  |   re->bq = getReadTermBackQuotesFlag(); | 
					
						
							| 
									
										
										
										
											2016-12-04 12:52:42 -06:00
										 |  |  |   if (args[READ_OUTPUT].used) { | 
					
						
							|  |  |  |     fe->t0 = args[READ_OUTPUT].tvalue; | 
					
						
							| 
									
										
										
										
											2016-03-05 12:18:43 +00:00
										 |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2016-12-04 12:52:42 -06:00
										 |  |  |     fe->t0 = 0; | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-12-05 14:50:04 -06:00
										 |  |  |   if (args[READ_MODULE].used) { | 
					
						
							|  |  |  |     fe->cmod = args[READ_MODULE].tvalue; | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     fe->cmod = CurrentModule; | 
					
						
							|  |  |  |     if (fe->cmod == TermProlog) | 
					
						
							|  |  |  |       fe->cmod = PROLOG_MODULE; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (args[READ_BACKQUOTED_STRING].used) { | 
					
						
							| 
									
										
										
										
											2018-03-19 11:44:16 +00:00
										 |  |  |     if (!setReadTermBackQuotesFlag(args[READ_BACKQUOTED_STRING].tvalue)) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |       return false; | 
					
						
							| 
									
										
										
										
											2016-05-30 11:25:28 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  |   if (args[READ_QUASI_QUOTATIONS].used) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     fe->qq = args[READ_QUASI_QUOTATIONS].tvalue; | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     fe->qq = 0; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-01-20 22:38:09 +00:00
										 |  |  |   if (args[READ_COMMENTS].used) { | 
					
						
							|  |  |  |     fe->tcomms = args[READ_COMMENTS].tvalue; | 
					
						
							| 
									
										
										
										
											2016-04-12 16:04:33 +01:00
										 |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2016-01-20 22:38:09 +00:00
										 |  |  |     fe->tcomms = 0; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  |   if (args[READ_TERM_POSITION].used) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     fe->tp = args[READ_TERM_POSITION].tvalue; | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     fe->tp = 0; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  |   if (args[READ_SINGLETONS].used) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     fe->sp = args[READ_SINGLETONS].tvalue; | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     fe->sp = 0; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  |   if (args[READ_SYNTAX_ERRORS].used) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     re->sy = args[READ_SYNTAX_ERRORS].tvalue; | 
					
						
							|  |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |     re->sy = TermError; // getYapFlag( MkAtomTerm(AtomSyntaxErrors) );
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   if (args[READ_VARIABLES].used) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     fe->vp = args[READ_VARIABLES].tvalue; | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     fe->vp = 0; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   if (args[READ_VARIABLE_NAMES].used) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     fe->np = args[READ_VARIABLE_NAMES].tvalue; | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     fe->np = 0; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-04-12 16:04:33 +01:00
										 |  |  |   if (args[READ_CHARACTER_ESCAPES].used || Yap_CharacterEscapes(fe->cmod)) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     fe->ce = true; | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     fe->ce = false; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   re->seekable = (GLOBAL_Stream[inp_stream].status & Seekable_Stream_f) != 0; | 
					
						
							|  |  |  |   if (re->seekable) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     re->cpos = GLOBAL_Stream[inp_stream].charcount; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   if (args[READ_PRIORITY].used) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     re->prio = IntegerOfTerm(args[READ_PRIORITY].tvalue); | 
					
						
							| 
									
										
										
										
											2015-12-15 08:38:56 +00:00
										 |  |  |     if (re->prio > GLOBAL_MaxPriority) { | 
					
						
							| 
									
										
										
										
											2018-06-14 11:27:43 +01:00
										 |  |  |       Yap_ThrowError(DOMAIN_ERROR_OPERATOR_PRIORITY, opts, | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 		     "max priority in Prolog is %d, not %ld", | 
					
						
							|  |  |  | 		     GLOBAL_MaxPriority, re->prio); | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |   } else { | 
					
						
							|  |  |  |     re->prio = LOCAL_default_priority; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |   fe->msg = NULL; | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   return args; | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | typedef enum { | 
					
						
							| 
									
										
										
										
											2018-07-21 12:08:09 +01:00
										 |  |  |   YAP_START_PARSING,  /// initialization
 | 
					
						
							|  |  |  |   YAP_SCANNING,       /// input to list of tokens
 | 
					
						
							|  |  |  |   YAP_SCANNING_ERROR, /// serious error (eg oom); trying error handling, followd
 | 
					
						
							|  |  |  |   /// by either restart or failure
 | 
					
						
							|  |  |  |   YAP_PARSING,         /// list of tokens to term
 | 
					
						
							|  |  |  |   YAP_PARSING_ERROR,   /// oom or syntax error
 | 
					
						
							|  |  |  |   YAP_PARSING_FINISHED /// exit parser
 | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | } parser_state_t; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | Int Yap_FirstLineInParse(void) { | 
					
						
							| 
									
										
										
										
											2016-04-12 16:04:33 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     return LOCAL_StartLineCount; | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-21 17:05:36 -05:00
										 |  |  | #define PUSHFET(X) *HR++ = fe->X
 | 
					
						
							|  |  |  | #define POPFET(X) fe->X = *--HR
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | static void reset_regs(TokEntry *tokstart, FEnv *fe) { | 
					
						
							| 
									
										
										
										
											2016-04-12 16:04:33 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     restore_machine_regs(); | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  |   /* restart global */ | 
					
						
							| 
									
										
										
										
											2015-09-21 17:05:36 -05:00
										 |  |  |   PUSHFET(qq); | 
					
						
							|  |  |  |   PUSHFET(tp); | 
					
						
							|  |  |  |   PUSHFET(sp); | 
					
						
							|  |  |  |   PUSHFET(np); | 
					
						
							|  |  |  |   PUSHFET(vp); | 
					
						
							|  |  |  |   PUSHFET(tpos); | 
					
						
							|  |  |  |   PUSHFET(t); | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   HR = fe->old_H; | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  |   TR = (tr_fr_ptr)LOCAL_ScannerStack; | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |   LOCAL_Error_TYPE = YAP_NO_ERROR; | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   Yap_growstack_in_parser(&fe->old_TR, &tokstart, &LOCAL_VarTable); | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  |   LOCAL_ScannerStack = (char *)TR; | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   TR = fe->old_TR; | 
					
						
							| 
									
										
										
										
											2015-09-21 17:05:36 -05:00
										 |  |  |   POPFET(t); | 
					
						
							|  |  |  |   POPFET(tpos); | 
					
						
							|  |  |  |   POPFET(vp); | 
					
						
							|  |  |  |   POPFET(np); | 
					
						
							|  |  |  |   POPFET(sp); | 
					
						
							|  |  |  |   POPFET(tp); | 
					
						
							|  |  |  |   POPFET(qq); | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-14 04:15:28 +00:00
										 |  |  | static Term get_variables(FEnv *fe, TokEntry *tokstart) { | 
					
						
							| 
									
										
										
										
											2016-02-22 13:01:09 +00:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     Term v; | 
					
						
							| 
									
										
										
										
											2017-08-21 12:29:58 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-11-10 14:16:10 +00:00
										 |  |  |   if (fe->vp) { | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  |     while (true) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |       fe->old_H = HR; | 
					
						
							| 
									
										
										
										
											2017-08-21 12:29:58 +01:00
										 |  |  |       if (setjmp(LOCAL_IOBotch) == 0) { | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 	if ((v = Yap_Variables(LOCAL_VarTable, TermNil))) { | 
					
						
							|  |  |  | 	  fe->old_H = HR; | 
					
						
							|  |  |  | 	  return v; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 	reset_regs(tokstart, fe); | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-02-14 04:15:28 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   return 0; | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-14 04:15:28 +00:00
										 |  |  | static Term get_varnames(FEnv *fe, TokEntry *tokstart) { | 
					
						
							| 
									
										
										
										
											2016-02-22 13:01:09 +00:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     Term v; | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  |   if (fe->np) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     while (true) { | 
					
						
							|  |  |  |       fe->old_H = HR; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-21 12:29:58 +01:00
										 |  |  |       if (setjmp(LOCAL_IOBotch) == 0) { | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 	if ((v = Yap_VarNames(LOCAL_VarTable, TermNil))) { | 
					
						
							|  |  |  | 	  fe->old_H = HR; | 
					
						
							|  |  |  | 	  return v; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 	reset_regs(tokstart, fe); | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-02-14 04:15:28 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   return 0; | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-14 04:15:28 +00:00
										 |  |  | static Term get_singletons(FEnv *fe, TokEntry *tokstart) { | 
					
						
							| 
									
										
										
										
											2016-04-12 16:04:33 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     Term v; | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |   if (fe->sp) { | 
					
						
							|  |  |  |     while (TRUE) { | 
					
						
							|  |  |  |       fe->old_H = HR; | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-21 12:29:58 +01:00
										 |  |  |       if (setjmp(LOCAL_IOBotch) == 0) { | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 	if ((v = Yap_Singletons(LOCAL_VarTable, TermNil))) { | 
					
						
							|  |  |  | 	  return v; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 	reset_regs(tokstart, fe); | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-02-14 04:15:28 +00:00
										 |  |  |   return 0; | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-14 04:15:28 +00:00
										 |  |  | static void warn_singletons(FEnv *fe, TokEntry *tokstart) { | 
					
						
							| 
									
										
										
										
											2016-04-12 16:04:33 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     Term v; | 
					
						
							| 
									
										
										
										
											2016-02-14 04:15:28 +00:00
										 |  |  |   fe->sp = TermNil; | 
					
						
							|  |  |  |   v = get_singletons(fe, tokstart); | 
					
						
							|  |  |  |   if (v && v != TermNil) { | 
					
						
							|  |  |  |     Term singls[4]; | 
					
						
							|  |  |  |     singls[0] = Yap_MkApplTerm(Yap_MkFunctor(AtomSingleton, 1), 1, &v); | 
					
						
							|  |  |  |     singls[1] = MkIntegerTerm(LOCAL_SourceFileLineno); | 
					
						
							|  |  |  |     singls[2] = MkAtomTerm(LOCAL_SourceFileName); | 
					
						
							|  |  |  |     if (fe->t) | 
					
						
							|  |  |  |       singls[3] = fe->t; | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |       singls[1] = TermTrue; | 
					
						
							|  |  |  |     Term t = Yap_MkApplTerm(Yap_MkFunctor(AtomStyleCheck, 4), 4, singls); | 
					
						
							| 
									
										
										
										
											2018-04-10 13:14:16 +01:00
										 |  |  |     Yap_PrintWarning(t); | 
					
						
							| 
									
										
										
										
											2016-02-14 04:15:28 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-14 04:15:28 +00:00
										 |  |  | static Term get_stream_position(FEnv *fe, TokEntry *tokstart) { | 
					
						
							| 
									
										
										
										
											2016-04-12 16:04:33 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     Term v; | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  |   if (fe->tp) { | 
					
						
							|  |  |  |     while (true) { | 
					
						
							|  |  |  |       fe->old_H = HR; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-21 12:29:58 +01:00
										 |  |  |       if (setjmp(LOCAL_IOBotch) == 0) { | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 	if ((v = CurrentPositionToTerm())) { | 
					
						
							|  |  |  | 	  return v; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 	reset_regs(tokstart, fe); | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2017-08-27 22:22:34 +01:00
										 |  |  |   return 0; | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static bool complete_processing(FEnv *fe, TokEntry *tokstart) { | 
					
						
							| 
									
										
										
										
											2016-04-12 16:04:33 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     Term v1, v2, v3, vc, tp; | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-05 14:50:04 -06:00
										 |  |  |   if (fe->t0 && fe->t && !(Yap_unify(fe->t, fe->t0))) | 
					
						
							| 
									
										
										
										
											2016-12-04 12:52:42 -06:00
										 |  |  |     return false; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  |   if (fe->t && fe->vp) | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  |     v1 = get_variables(fe, tokstart); | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     v1 = 0L; | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  |   if (fe->t && fe->np) | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  |     v2 = get_varnames(fe, tokstart); | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     v2 = 0L; | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  |   if (fe->t && fe->sp) | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  |     v3 = get_singletons(fe, tokstart); | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     v3 = 0L; | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  |   if (fe->t && fe->tcomms) | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  |     vc = LOCAL_Comments; | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     vc = 0L; | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  |   if (fe->t && fe->tp) | 
					
						
							| 
									
										
										
										
											2016-02-14 04:15:28 +00:00
										 |  |  |     tp = get_stream_position(fe, tokstart); | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  |   else | 
					
						
							|  |  |  |     tp = 0L; | 
					
						
							| 
									
										
										
										
											2015-09-21 17:05:36 -05:00
										 |  |  |   Yap_clean_tokenizer(tokstart, LOCAL_VarTable, LOCAL_AnonVarTable); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:25:28 +01:00
										 |  |  |   free(fe->args); | 
					
						
							| 
									
										
										
										
											2015-09-21 17:05:36 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |   // trail must be ok by now.]
 | 
					
						
							| 
									
										
										
										
											2016-02-14 04:15:28 +00:00
										 |  |  |   if (fe->t) { | 
					
						
							|  |  |  |     return (!v1 || Yap_unify(v1, fe->vp)) && (!v2 || Yap_unify(v2, fe->np)) && | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |       (!v3 || Yap_unify(v3, fe->sp)) && (!tp || Yap_unify(tp, fe->tp)) && | 
					
						
							|  |  |  |       (!vc || Yap_unify(vc, fe->tcomms)); | 
					
						
							| 
									
										
										
										
											2016-02-14 04:15:28 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   return true; | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-14 04:15:28 +00:00
										 |  |  | static bool complete_clause_processing(FEnv *fe, TokEntry *tokstart) { | 
					
						
							| 
									
										
										
										
											2016-04-12 16:04:33 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     Term v_vp, v_vnames, v_comments, v_pos; | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-21 13:02:20 +00:00
										 |  |  |   if (fe->t0 && fe->t && !Yap_unify(fe->t, fe->t0)) | 
					
						
							| 
									
										
										
										
											2016-12-04 12:52:42 -06:00
										 |  |  |     return false; | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  |   if (fe->t && fe->vp) | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  |     v_vp = get_variables(fe, tokstart); | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     v_vp = 0L; | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  |   if (fe->t && fe->np) | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  |     v_vnames = get_varnames(fe, tokstart); | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     v_vnames = 0L; | 
					
						
							| 
									
										
										
										
											2018-10-08 19:03:29 +01:00
										 |  |  |   if (fe->t && trueGlobalPrologFlag(SINGLE_VAR_WARNINGS_FLAG)) { | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  |     warn_singletons(fe, tokstart); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  |   if (fe->t && fe->tcomms) | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  |     v_comments = LOCAL_Comments; | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     v_comments = 0L; | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  |   if (fe->t && fe->tp) | 
					
						
							| 
									
										
										
										
											2016-02-14 04:15:28 +00:00
										 |  |  |     v_pos = get_stream_position(fe, tokstart); | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  |   else | 
					
						
							|  |  |  |     v_pos = 0L; | 
					
						
							|  |  |  |   Yap_clean_tokenizer(tokstart, LOCAL_VarTable, LOCAL_AnonVarTable); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:25:28 +01:00
										 |  |  |   free(fe->args); | 
					
						
							| 
									
										
										
										
											2016-02-14 04:15:28 +00:00
										 |  |  |   // trail must be ok by now.]
 | 
					
						
							|  |  |  |   if (fe->t) { | 
					
						
							|  |  |  |     return (!v_vp || Yap_unify(v_vp, fe->vp)) && | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |       (!v_vnames || Yap_unify(v_vnames, fe->np)) && | 
					
						
							|  |  |  |       (!v_pos || Yap_unify(v_pos, fe->tp)) && | 
					
						
							|  |  |  |       (!v_comments || Yap_unify(v_comments, fe->tcomms)); | 
					
						
							| 
									
										
										
										
											2016-02-14 04:15:28 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   return true; | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | static parser_state_t initParser(Term opts, FEnv *fe, REnv *re, int inp_stream, | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 				 bool clause); | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | static parser_state_t parse(REnv *re, FEnv *fe, int inp_stream); | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | static parser_state_t scanError(REnv *re, FEnv *fe, int inp_stream); | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | static parser_state_t scanEOF(FEnv *fe, int inp_stream); | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | static parser_state_t scan(REnv *re, FEnv *fe, int inp_stream); | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | static parser_state_t scanEOF(FEnv *fe, int inp_stream) { | 
					
						
							| 
									
										
										
										
											2016-04-12 16:04:33 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     // bool store_comments = false;
 | 
					
						
							|  |  |  |     TokEntry *tokstart = LOCAL_tokptr; | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |   // check for an user abort
 | 
					
						
							|  |  |  |   if (tokstart != NULL && tokstart->Tok != Ord(eot_tok)) { | 
					
						
							|  |  |  |     /* we got the end of file from an abort */ | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     if (fe->msg && !strcmp(fe->msg, "Abort")) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |       fe->t = 0L; | 
					
						
							|  |  |  |       Yap_clean_tokenizer(tokstart, LOCAL_VarTable, LOCAL_AnonVarTable); | 
					
						
							|  |  |  |       return YAP_PARSING_FINISHED; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     // a :- <eof>
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     if (GLOBAL_Stream[inp_stream].status & Past_Eof_Stream_f) { | 
					
						
							|  |  |  |       fe->msg = "parsing stopped at a end-of-file"; | 
					
						
							| 
									
										
										
										
											2016-12-05 14:50:04 -06:00
										 |  |  |       return YAP_PARSING_ERROR; | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     /* we need to force the next read to also give end of file.*/ | 
					
						
							|  |  |  |     GLOBAL_Stream[inp_stream].status |= Push_Eof_Stream_f; | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     fe->msg = "end of file found before end of term"; | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     return YAP_PARSING; | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     // <eof>
 | 
					
						
							|  |  |  |     // return end_of_file
 | 
					
						
							|  |  |  |     TR = (tr_fr_ptr)tokstart; | 
					
						
							|  |  |  |     Yap_clean_tokenizer(tokstart, LOCAL_VarTable, LOCAL_AnonVarTable); | 
					
						
							|  |  |  |     fe->t = MkAtomTerm(AtomEof); | 
					
						
							|  |  |  |     if (fe->np && !Yap_unify(TermNil, fe->np)) | 
					
						
							|  |  |  |       fe->t = 0; | 
					
						
							|  |  |  |     if (fe->sp && !Yap_unify(TermNil, fe->sp)) | 
					
						
							|  |  |  |       fe->t = 0; | 
					
						
							|  |  |  |     if (fe->vp && !Yap_unify(TermNil, fe->vp)) | 
					
						
							|  |  |  |       fe->t = 0; | 
					
						
							|  |  |  |     if (fe->tp && !Yap_unify(fe->tp, fe->tpos)) | 
					
						
							|  |  |  |       fe->t = 0; | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | #if DEBUG
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     if (GLOBAL_Option['p' - 'a' + 1]) { | 
					
						
							| 
									
										
										
										
											2015-07-22 19:33:30 -05:00
										 |  |  |       fprintf(stderr, "[ end_of_file %p ]\n", GLOBAL_Stream[inp_stream].name); | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     return YAP_PARSING_FINISHED; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | static parser_state_t initParser(Term opts, FEnv *fe, REnv *re, int inp_stream, | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 				 bool clause) { | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |   LOCAL_ErrorMessage = NULL; | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   fe->old_TR = TR; | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  |   LOCAL_Error_TYPE = YAP_NO_ERROR; | 
					
						
							|  |  |  |   LOCAL_SourceFileName = GLOBAL_Stream[inp_stream].name; | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   LOCAL_eot_before_eof = false; | 
					
						
							|  |  |  |   fe->tpos = StreamPosition(inp_stream); | 
					
						
							| 
									
										
										
										
											2016-12-04 12:52:42 -06:00
										 |  |  |   fe->reading_clause = clause; | 
					
						
							|  |  |  |   if (clause) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     fe->args = setClauseReadEnv(opts, fe, re, inp_stream); | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     fe->args = setReadEnv(opts, fe, re, inp_stream); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-10-09 10:31:07 +01:00
										 |  |  |   if (fe->args == NULL) { | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |     if (LOCAL_Error_TYPE == DOMAIN_ERROR_OUT_OF_RANGE) | 
					
						
							| 
									
										
										
										
											2015-10-09 10:31:07 +01:00
										 |  |  |       LOCAL_Error_TYPE = DOMAIN_ERROR_READ_OPTION; | 
					
						
							|  |  |  |     if (LOCAL_Error_TYPE) | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |       Yap_Error(LOCAL_Error_TYPE, opts, NULL); | 
					
						
							| 
									
										
										
										
											2015-10-09 10:31:07 +01:00
										 |  |  |     fe->t = 0; | 
					
						
							| 
									
										
										
										
											2015-11-10 14:16:10 +00:00
										 |  |  |     return YAP_PARSING_FINISHED; | 
					
						
							|  |  |  |     ; | 
					
						
							| 
									
										
										
										
											2015-10-09 10:31:07 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   if (GLOBAL_Stream[inp_stream].status & Push_Eof_Stream_f) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     fe->t = MkAtomTerm(AtomEof); | 
					
						
							|  |  |  |     GLOBAL_Stream[inp_stream].status &= ~Push_Eof_Stream_f; | 
					
						
							|  |  |  |     return YAP_PARSING_FINISHED; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (!fe->args) { | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |     return YAP_PARSING_FINISHED; | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   return YAP_SCANNING; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-29 13:47:57 +00:00
										 |  |  | static parser_state_t scan(REnv *re, FEnv *fe, int sno) { | 
					
						
							| 
									
										
										
										
											2016-04-12 16:04:33 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     /* preserve   value of H after scanning: otherwise we may lose strings
 | 
					
						
							|  |  |  |        and floats */ | 
					
						
							|  |  |  |     LOCAL_tokptr = LOCAL_toktide = | 
					
						
							| 
									
										
										
										
											2015-12-15 09:28:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     Yap_tokenizer(GLOBAL_Stream + sno, false, &fe->tpos); | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  | #if DEBUG
 | 
					
						
							|  |  |  |   if (GLOBAL_Option[2]) { | 
					
						
							|  |  |  |     TokEntry *t = LOCAL_tokptr; | 
					
						
							|  |  |  |     int n = 0; | 
					
						
							|  |  |  |     while (t) { | 
					
						
							| 
									
										
										
										
											2016-11-16 17:17:33 -06:00
										 |  |  |       fprintf(stderr, "[Token %d %s %d]", Ord(t->Tok), Yap_tokText(t), n++); | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |       t = t->TokNext; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     fprintf(stderr, "\n"); | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-11-16 17:17:33 -06:00
										 |  |  |   if (LOCAL_ErrorMessage) | 
					
						
							|  |  |  |     return YAP_SCANNING_ERROR; | 
					
						
							|  |  |  |   if (LOCAL_tokptr->Tok != Ord(eot_tok)) { | 
					
						
							|  |  |  |     // next step
 | 
					
						
							|  |  |  |     return YAP_PARSING; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (LOCAL_tokptr->Tok == eot_tok && LOCAL_tokptr->TokInfo == TermNl) { | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     LOCAL_ErrorMessage = ". is end-of-term?"; | 
					
						
							| 
									
										
										
										
											2016-11-16 17:17:33 -06:00
										 |  |  |     return YAP_PARSING_ERROR; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2017-11-29 13:47:57 +00:00
										 |  |  |   return scanEOF(fe, sno); | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | static parser_state_t scanError(REnv *re, FEnv *fe, int inp_stream) { | 
					
						
							| 
									
										
										
										
											2016-04-12 16:04:33 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     fe->t = 0; | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   // running out of memory
 | 
					
						
							| 
									
										
										
										
											2015-09-25 10:57:26 +01:00
										 |  |  |   if (LOCAL_Error_TYPE == RESOURCE_ERROR_TRAIL) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     LOCAL_Error_TYPE = YAP_NO_ERROR; | 
					
						
							|  |  |  |     if (!Yap_growtrail(sizeof(CELL) * K16, FALSE)) { | 
					
						
							|  |  |  |       return YAP_PARSING_FINISHED; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-09-25 10:57:26 +01:00
										 |  |  |   } else if (LOCAL_Error_TYPE == RESOURCE_ERROR_AUXILIARY_STACK) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     LOCAL_Error_TYPE = YAP_NO_ERROR; | 
					
						
							|  |  |  |     if (!Yap_ExpandPreAllocCodeSpace(0, NULL, TRUE)) { | 
					
						
							|  |  |  |       return YAP_PARSING_FINISHED; | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-09-25 10:57:26 +01:00
										 |  |  |   } else if (LOCAL_Error_TYPE == RESOURCE_ERROR_HEAP) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     LOCAL_Error_TYPE = YAP_NO_ERROR; | 
					
						
							|  |  |  |     if (!Yap_growheap(FALSE, 0, NULL)) { | 
					
						
							|  |  |  |       return YAP_PARSING_FINISHED; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-09-25 10:57:26 +01:00
										 |  |  |   } else if (LOCAL_Error_TYPE == RESOURCE_ERROR_STACK) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     LOCAL_Error_TYPE = YAP_NO_ERROR; | 
					
						
							|  |  |  |     if (!Yap_gcl(LOCAL_Error_Size, fe->nargs, ENV, CP)) { | 
					
						
							|  |  |  |       return YAP_PARSING_FINISHED; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   // go back to the start
 | 
					
						
							| 
									
										
										
										
											2018-02-21 13:02:20 +00:00
										 |  |  |   if (LOCAL_Error_TYPE == SYNTAX_ERROR) { | 
					
						
							|  |  |  |     return YAP_PARSING_ERROR; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   if (re->seekable) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     if (GLOBAL_Stream[inp_stream].status & InMemory_Stream_f) { | 
					
						
							|  |  |  |       GLOBAL_Stream[inp_stream].u.mem_string.pos = re->cpos; | 
					
						
							|  |  |  |     } else if (GLOBAL_Stream[inp_stream].status) { | 
					
						
							| 
									
										
										
										
											2018-01-05 16:57:38 +00:00
										 |  |  | #if HAVE_FTELLO
 | 
					
						
							|  |  |  |       fseeko(GLOBAL_Stream[inp_stream].file, re->cpos, 0L); | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |       fseek(GLOBAL_Stream[inp_stream].file, re->cpos, 0L); | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | #endif
 | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   return YAP_SCANNING; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | static parser_state_t parseError(REnv *re, FEnv *fe, int inp_stream) { | 
					
						
							| 
									
										
										
										
											2016-04-12 16:04:33 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     fe->t = 0; | 
					
						
							| 
									
										
										
										
											2016-12-05 14:50:04 -06:00
										 |  |  |   if (LOCAL_Error_TYPE != SYNTAX_ERROR && LOCAL_Error_TYPE != YAP_NO_ERROR) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     return YAP_SCANNING_ERROR; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   Term ParserErrorStyle = re->sy; | 
					
						
							| 
									
										
										
										
											2016-12-05 14:50:04 -06:00
										 |  |  |   if (ParserErrorStyle == TermQuiet || LOCAL_Error_TYPE == YAP_NO_ERROR) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     /* just fail */ | 
					
						
							|  |  |  |     LOCAL_Error_TYPE = YAP_NO_ERROR; | 
					
						
							|  |  |  |     return YAP_PARSING_FINISHED; | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |   } | 
					
						
							|  |  |  |   Term t = syntax_error(fe->toklast, inp_stream, fe->cmod, re->cpos, fe->reading_clause, fe->msg); | 
					
						
							|  |  |  |   if (ParserErrorStyle == TermException) { | 
					
						
							|  |  |  |     if (LOCAL_RestartEnv && !LOCAL_delay) { | 
					
						
							|  |  |  |       Yap_RestartYap(5); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     Yap_exit(5); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-01-05 16:57:38 +00:00
										 |  |  |     if (re->seekable) { | 
					
						
							|  |  |  |       re->cpos = GLOBAL_Stream[inp_stream].charcount; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     LOCAL_Error_TYPE = WARNING_SYNTAX_ERROR; | 
					
						
							|  |  |  |       t =  Yap_MkFullError(); | 
					
						
							|  |  |  |     Yap_PrintWarning(t); | 
					
						
							|  |  |  |     LOCAL_Error_TYPE = YAPC_NO_ERROR; | 
					
						
							|  |  |  |     if (ParserErrorStyle == TermDec10) { | 
					
						
							| 
									
										
										
										
											2016-02-19 11:34:48 +00:00
										 |  |  |       return YAP_SCANNING; | 
					
						
							| 
									
										
										
										
											2016-04-12 16:04:33 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   return YAP_PARSING_FINISHED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | static parser_state_t parse(REnv *re, FEnv *fe, int inp_stream) { | 
					
						
							| 
									
										
										
										
											2016-04-12 16:04:33 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     TokEntry *tokstart = LOCAL_tokptr; | 
					
						
							| 
									
										
										
										
											2016-04-10 06:21:17 -07:00
										 |  |  |   fe->t = Yap_Parse(re->prio, fe->enc, fe->cmod); | 
					
						
							| 
									
										
										
										
											2015-07-27 22:22:44 -05:00
										 |  |  |   fe->toklast = LOCAL_tokptr; | 
					
						
							|  |  |  |   LOCAL_tokptr = tokstart; | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |   TR = (tr_fr_ptr)tokstart; | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | #if EMACS
 | 
					
						
							|  |  |  |   first_char = tokstart->TokPos; | 
					
						
							|  |  |  | #endif /* EMACS */
 | 
					
						
							| 
									
										
										
										
											2016-02-19 11:34:48 +00:00
										 |  |  |   if (LOCAL_Error_TYPE != YAP_NO_ERROR || fe->t == 0) | 
					
						
							|  |  |  |     return YAP_PARSING_ERROR; | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   return YAP_PARSING_FINISHED; | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @brief generic routine to read terms from a stream | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @arg inp_stream: where we read from | 
					
						
							|  |  |  |  * @arg: opts, a list with options | 
					
						
							| 
									
										
										
										
											2016-07-31 09:53:23 -05:00
										 |  |  |  * @arg: if called from read_term, arity | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |  *  called from read_clause, -arity | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @return the term or 0 in case of error. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2015-07-27 22:22:44 -05:00
										 |  |  |  * Implementation uses a state machine: default is init, scan, parse, complete. | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |  * | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-11-29 13:47:57 +00:00
										 |  |  | Term Yap_read_term(int sno, Term opts, bool clause) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |   FEnv fe; | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   REnv re; | 
					
						
							|  |  |  | #if EMACS
 | 
					
						
							|  |  |  |   int emacs_cares = FALSE; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-14 11:27:43 +01:00
										 |  |  |   yap_error_descriptor_t *new = malloc(sizeof *new); | 
					
						
							| 
									
										
										
										
											2018-07-21 12:08:09 +01:00
										 |  |  |   bool err = Yap_pushErrorContext(true, new); | 
					
						
							| 
									
										
										
										
											2016-11-02 00:16:36 -05:00
										 |  |  |   int lvl = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   parser_state_t state = YAP_START_PARSING; | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  |   while (true) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     switch (state) { | 
					
						
							|  |  |  |     case YAP_START_PARSING: | 
					
						
							| 
									
										
										
										
											2017-11-29 13:47:57 +00:00
										 |  |  |       state = initParser(opts, &fe, &re, sno, clause); | 
					
						
							| 
									
										
										
										
											2016-11-02 00:16:36 -05:00
										 |  |  |       if (state == YAP_PARSING_FINISHED) { | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 	pop_text_stack(lvl); | 
					
						
							|  |  |  | 	Yap_popErrorContext(err, true); | 
					
						
							|  |  |  | 	return 0; | 
					
						
							| 
									
										
										
										
											2016-11-02 00:16:36 -05:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |       break; | 
					
						
							|  |  |  |     case YAP_SCANNING: | 
					
						
							| 
									
										
										
										
											2017-11-29 13:47:57 +00:00
										 |  |  |       state = scan(&re, &fe, sno); | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |       break; | 
					
						
							|  |  |  |     case YAP_SCANNING_ERROR: | 
					
						
							| 
									
										
										
										
											2017-11-29 13:47:57 +00:00
										 |  |  |       state = scanError(&re, &fe, sno); | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |       break; | 
					
						
							|  |  |  |     case YAP_PARSING: | 
					
						
							| 
									
										
										
										
											2017-11-29 13:47:57 +00:00
										 |  |  |       state = parse(&re, &fe, sno); | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |       break; | 
					
						
							|  |  |  |     case YAP_PARSING_ERROR: | 
					
						
							| 
									
										
										
										
											2017-11-29 13:47:57 +00:00
										 |  |  |       state = parseError(&re, &fe, sno); | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |       break; | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |     case YAP_PARSING_FINISHED: { | 
					
						
							|  |  |  |       CACHE_REGS | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 	bool done; | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |       if (fe.reading_clause) | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 	done = complete_clause_processing(&fe, LOCAL_tokptr); | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |       else | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 	done = complete_processing(&fe, LOCAL_tokptr); | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |       if (!done) { | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 	state = YAP_PARSING_ERROR; | 
					
						
							|  |  |  | 	fe.t = 0; | 
					
						
							|  |  |  | 	break; | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2016-01-03 02:06:09 +00:00
										 |  |  | #if EMACS
 | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |       first_char = tokstart->TokPos; | 
					
						
							| 
									
										
										
										
											2016-01-03 02:06:09 +00:00
										 |  |  | #endif /* EMACS */
 | 
					
						
							| 
									
										
										
										
											2016-11-02 00:16:36 -05:00
										 |  |  |       pop_text_stack(lvl); | 
					
						
							| 
									
										
										
										
											2018-04-16 14:54:53 +01:00
										 |  |  |       Yap_popErrorContext(err, true); | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |       return fe.t; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-06-14 11:27:43 +01:00
										 |  |  |   Yap_popErrorContext(err, true); | 
					
						
							| 
									
										
										
										
											2016-11-02 00:16:36 -05:00
										 |  |  |   pop_text_stack(lvl); | 
					
						
							| 
									
										
										
										
											2016-02-11 06:17:30 -08:00
										 |  |  |   return 0; | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | static Int | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | read_term2(USES_REGS1) { /* '$read'(+Flag,?Term,?Module,?Vars,-Pos,-Err) */ | 
					
						
							| 
									
										
										
										
											2016-12-04 12:52:42 -06:00
										 |  |  |   return Yap_read_term(LOCAL_c_input_stream, add_output(ARG1, ARG2), false) != | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     0; | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | static Int read_term( | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 		     USES_REGS1) { /* '$read2'(+Flag,?Term,?Module,?Vars,-Pos,-Err,+Stream)  */ | 
					
						
							| 
									
										
										
										
											2017-11-29 13:47:57 +00:00
										 |  |  |   int sno; | 
					
						
							| 
									
										
										
										
											2016-07-31 09:53:23 -05:00
										 |  |  |   Term out; | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  |   /* needs to change LOCAL_output_stream for write */ | 
					
						
							| 
									
										
										
										
											2016-02-18 12:10:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-29 13:47:57 +00:00
										 |  |  |   sno = Yap_CheckTextStream(ARG1, Input_Stream_f, "read/3"); | 
					
						
							|  |  |  |   if (sno == -1) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     return (FALSE); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2017-11-29 13:47:57 +00:00
										 |  |  |   out = Yap_read_term(sno, add_output(ARG2, ARG3), false); | 
					
						
							|  |  |  |   UNLOCK(GLOBAL_Stream[sno].streamlock); | 
					
						
							| 
									
										
										
										
											2016-12-04 12:52:42 -06:00
										 |  |  |   return out != 0L; | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | #define READ_CLAUSE_DEFS()						\
 | 
					
						
							|  |  |  |   PAR("comments", list_filler, READ_CLAUSE_COMMENTS)			\ | 
					
						
							|  |  |  |   , PAR("module", isatom, READ_CLAUSE_MODULE),				\ | 
					
						
							|  |  |  |     PAR("variable_names", filler, READ_CLAUSE_VARIABLE_NAMES),		\ | 
					
						
							|  |  |  |     PAR("variables", filler, READ_CLAUSE_VARIABLES),			\ | 
					
						
							|  |  |  |     PAR("term_position", filler, READ_CLAUSE_TERM_POSITION),		\ | 
					
						
							|  |  |  |     PAR("syntax_errors", isatom, READ_CLAUSE_SYNTAX_ERRORS),		\ | 
					
						
							|  |  |  |     PAR("output", isatom, READ_CLAUSE_OUTPUT),				\ | 
					
						
							|  |  |  |     PAR(NULL, ok, READ_CLAUSE_END) | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | #define PAR(x, y, z) z
 | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | typedef enum read_clause_enum_choices { | 
					
						
							| 
									
										
										
										
											2018-07-21 12:08:09 +01:00
										 |  |  |   READ_CLAUSE_DEFS() | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | } read_clause_choices_t; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #undef PAR
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | #define PAR(x, y, z)				\
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |   { x, y, z } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | static const param_t read_clause_defs[] = {READ_CLAUSE_DEFS()}; | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | #undef PAR
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-05 16:57:38 +00:00
										 |  |  | static xarg *setClauseReadEnv(Term opts, FEnv *fe, struct renv *re, int sno) { | 
					
						
							| 
									
										
										
										
											2016-04-12 16:04:33 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2016-01-20 22:38:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     xarg *args = Yap_ArgListToVector(opts, read_clause_defs, READ_CLAUSE_END, | 
					
						
							|  |  |  | 				     DOMAIN_ERROR_READ_OPTION); | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   if (args == NULL) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     return NULL; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-12-04 12:52:42 -06:00
										 |  |  |   if (args[READ_CLAUSE_OUTPUT].used) { | 
					
						
							|  |  |  |     fe->t0 = args[READ_CLAUSE_OUTPUT].tvalue; | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     fe->t0 = 0; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-02-28 19:32:55 +00:00
										 |  |  |   if (args[READ_CLAUSE_MODULE].used) { | 
					
						
							| 
									
										
										
										
											2016-03-05 12:18:43 +00:00
										 |  |  |     fe->cmod = args[READ_CLAUSE_MODULE].tvalue; | 
					
						
							| 
									
										
										
										
											2016-02-28 19:32:55 +00:00
										 |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2016-03-05 12:18:43 +00:00
										 |  |  |     fe->cmod = LOCAL_SourceModule; | 
					
						
							| 
									
										
										
										
											2016-04-12 16:04:33 +01:00
										 |  |  |     if (fe->cmod == TermProlog) | 
					
						
							|  |  |  |       fe->cmod = PROLOG_MODULE; | 
					
						
							| 
									
										
										
										
											2016-02-28 19:32:55 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-03-19 11:44:16 +00:00
										 |  |  |   re->bq = getReadTermBackQuotesFlag(); | 
					
						
							| 
									
										
										
										
											2017-11-29 13:47:57 +00:00
										 |  |  |   fe->enc = GLOBAL_Stream[sno].encoding; | 
					
						
							| 
									
										
										
										
											2016-02-14 04:15:28 +00:00
										 |  |  |   fe->sp = 0; | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   fe->qq = 0; | 
					
						
							| 
									
										
										
										
											2016-12-04 12:52:42 -06:00
										 |  |  |   if (args[READ_CLAUSE_OUTPUT].used) { | 
					
						
							|  |  |  |     fe->t0 = args[READ_CLAUSE_OUTPUT].tvalue; | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     fe->t0 = 0; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   if (args[READ_CLAUSE_TERM_POSITION].used) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     fe->tp = args[READ_CLAUSE_TERM_POSITION].tvalue; | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     fe->tp = 0; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  |   fe->sp = 0; | 
					
						
							|  |  |  |   if (args[READ_CLAUSE_COMMENTS].used) { | 
					
						
							| 
									
										
										
										
											2016-01-20 22:38:09 +00:00
										 |  |  |     fe->tcomms = args[READ_CLAUSE_COMMENTS].tvalue; | 
					
						
							|  |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  |     fe->tcomms = 0L; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (args[READ_CLAUSE_SYNTAX_ERRORS].used) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     re->sy = args[READ_CLAUSE_SYNTAX_ERRORS].tvalue; | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     re->sy = TermDec10; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   fe->vp = 0; | 
					
						
							| 
									
										
										
										
											2015-07-22 19:33:30 -05:00
										 |  |  |   if (args[READ_CLAUSE_VARIABLE_NAMES].used) { | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     fe->np = args[READ_CLAUSE_VARIABLE_NAMES].tvalue; | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     fe->np = 0; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-01-31 10:39:15 +00:00
										 |  |  |   if (args[READ_CLAUSE_VARIABLES].used) { | 
					
						
							|  |  |  |     fe->vp = args[READ_CLAUSE_VARIABLES].tvalue; | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     fe->vp = 0; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-03-05 12:18:43 +00:00
										 |  |  |   fe->ce = Yap_CharacterEscapes(fe->cmod); | 
					
						
							| 
									
										
										
										
											2017-11-29 13:47:57 +00:00
										 |  |  |   re->seekable = (GLOBAL_Stream[sno].status & Seekable_Stream_f) != 0; | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   if (re->seekable) { | 
					
						
							| 
									
										
										
										
											2017-11-29 13:47:57 +00:00
										 |  |  |     re->cpos = GLOBAL_Stream[sno].charcount; | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   re->prio = LOCAL_default_priority; | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |   fe->msg = NULL; | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  |   return args; | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2016-12-04 12:52:42 -06:00
										 |  |  |  * @pred read_clause( +Stream, -Clause, ?Opts) is det | 
					
						
							| 
									
										
										
										
											2016-08-01 19:17:56 -05:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2016-12-04 12:52:42 -06:00
										 |  |  |  * Same as read_clause/3, but from the standard input stream. | 
					
						
							| 
									
										
										
										
											2016-08-01 19:17:56 -05:00
										 |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | static Int read_clause2(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2016-12-04 12:52:42 -06:00
										 |  |  |   Term ctl = add_output(ARG1, ARG2); | 
					
						
							|  |  |  |   return Yap_read_term(LOCAL_c_input_stream, ctl, true); | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2016-12-04 12:52:42 -06:00
										 |  |  |  * @pred read_clause( +Stream, -Clause, ?Opts) is det | 
					
						
							| 
									
										
										
										
											2016-08-01 19:17:56 -05:00
										 |  |  |  * | 
					
						
							|  |  |  |  * This predicate receives a set of options _OPts_ based on read_term/3, but | 
					
						
							|  |  |  |  *specific | 
					
						
							|  |  |  |  * to readin clauses. The following options are considered: | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2016-12-04 12:52:42 -06:00
										 |  |  |  *   + The `comments` option unifies its argument with the comments in the | 
					
						
							|  |  |  |  *term, | 
					
						
							| 
									
										
										
										
											2016-08-01 19:17:56 -05:00
										 |  |  |  *     represented as strings | 
					
						
							| 
									
										
										
										
											2016-12-04 12:52:42 -06:00
										 |  |  |  *   + The `process_comments` option calls a hook, it is current ignored by | 
					
						
							|  |  |  |  *YAP. | 
					
						
							| 
									
										
										
										
											2016-08-01 19:17:56 -05:00
										 |  |  |  *   + The `term_position` unifies its argument with a term describing the | 
					
						
							|  |  |  |  *     position of the term. | 
					
						
							|  |  |  |  *   + The `syntax_errors` flag controls response to syntactic errors, the | 
					
						
							|  |  |  |  *default is `dec10`. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The next two options are called implicitly: | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *   + The `module` option is initialized to the current source module, by | 
					
						
							|  |  |  |  *default. | 
					
						
							|  |  |  |  *   + The `singletons` option is set from the single var flag | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  | static Int read_clause( | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 		       USES_REGS1) { /* '$read2'(+Flag,?Term,?Module,?Vars,-Pos,-Err,+Stream)  */ | 
					
						
							| 
									
										
										
										
											2017-11-29 13:47:57 +00:00
										 |  |  |   int sno; | 
					
						
							| 
									
										
										
										
											2016-07-31 09:53:23 -05:00
										 |  |  |   Term out; | 
					
						
							| 
									
										
										
										
											2016-12-04 12:52:42 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  |   /* needs to change LOCAL_output_stream for write */ | 
					
						
							| 
									
										
										
										
											2017-11-29 13:47:57 +00:00
										 |  |  |   sno = Yap_CheckTextStream(ARG1, Input_Stream_f, "read/3"); | 
					
						
							|  |  |  |   if (sno < 0) | 
					
						
							| 
									
										
										
										
											2015-11-05 16:54:13 +00:00
										 |  |  |     return false; | 
					
						
							| 
									
										
										
										
											2017-11-29 13:47:57 +00:00
										 |  |  |   out = Yap_read_term(sno, add_output(ARG2, ARG3), true); | 
					
						
							|  |  |  |   UNLOCK(GLOBAL_Stream[sno].streamlock); | 
					
						
							| 
									
										
										
										
											2016-12-04 12:52:42 -06:00
										 |  |  |   return out != 0; | 
					
						
							| 
									
										
										
										
											2015-06-18 01:20:05 +01:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-16 17:17:33 -06:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * start input for a meta-clause. Should obtain: | 
					
						
							|  |  |  |  *   - predicate name | 
					
						
							|  |  |  |  *   - predicate arity | 
					
						
							|  |  |  |  *   - address for 256 cluses. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param  ARG1 input stream | 
					
						
							|  |  |  |  * @param  ARG2 Adress of predicate. | 
					
						
							|  |  |  |  * @param  ARG3 Term read. | 
					
						
							|  |  |  |  * @return            [description] | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #if 0
 | 
					
						
							|  |  |  | static Int start_mega(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2017-11-29 13:47:57 +00:00
										 |  |  |   int sno; | 
					
						
							| 
									
										
										
										
											2016-11-16 17:17:33 -06:00
										 |  |  |   Term out; | 
					
						
							|  |  |  |   Term t3 = Deref(ARG3); | 
					
						
							|  |  |  |   yhandle_t h = Yap_InitSlot(ARG2); | 
					
						
							|  |  |  |   TokENtry *tok; | 
					
						
							|  |  |  |   arity_t srity = 0; | 
					
						
							|  |  |  |   /* needs to change LOCAL_output_stream for write */ | 
					
						
							| 
									
										
										
										
											2017-11-29 13:47:57 +00:00
										 |  |  |   sno = Yap_CheckTextStream(ARG1, Input_Stream_f, "read_exo/3"); | 
					
						
							|  |  |  |   if (sno < 0) | 
					
						
							| 
									
										
										
										
											2016-11-16 17:17:33 -06:00
										 |  |  |     return false; | 
					
						
							|  |  |  |   /* preserve   value of H after scanning: otherwise we may lose strings
 | 
					
						
							|  |  |  |      and floats */ | 
					
						
							|  |  |  |   LOCAL_tokptr = LOCAL_toktide = | 
					
						
							| 
									
										
										
										
											2018-07-02 15:20:17 +01:00
										 |  |  |     x Yap_tokenizer(GLOBAL_Stream + sno, false, &tpos); | 
					
						
							| 
									
										
										
										
											2016-11-16 17:17:33 -06:00
										 |  |  |   if (tokptr->Tok == Name_tok && (next = tokptr->TokNext) != NULL && | 
					
						
							|  |  |  |       next->Tok == Ponctuation_tok && next->TokInfo == TermOpenBracket) { | 
					
						
							| 
									
										
										
										
											2018-07-02 15:20:17 +01:00
										 |  |  |     bool start = true; | 
					
						
							|  |  |  |     while((tokptr = next->TokNext)) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (IsAtomOrIntTerm(t=*tp)) { | 
					
						
							|  |  |  | 	ip->opc = Yap_opcode(get_atom); | 
					
						
							|  |  |  | 	ip->y_u.x_c.c = t. | 
					
						
							|  |  |  | 	  ip->y_u.x_c.x = tp++; /() c */ | 
					
						
							|  |  |  | 				   } else if (IsAtomOrIntTerm(t=*tp)) { | 
					
						
							|  |  |  | 	(IsAtom(tok->Tokt)||IsIntTerm(XREGS+(i+1)))extra[arity] | 
					
						
							|  |  |  | 	  ] | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2016-11-16 17:17:33 -06:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * @pred source_location( - _File_ , _Line_ ) | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * unify  _File_ and  _Line_ wuth the position of the last term read, if the | 
					
						
							|  |  |  |      *term | 
					
						
							|  |  |  |      * comes from a stream created by opening a file-system path with open/3 and | 
					
						
							|  |  |  |      *friends.>position | 
					
						
							|  |  |  |      * It ignores user_input or | 
					
						
							|  |  |  |      * sockets. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param - _File_ | 
					
						
							|  |  |  |      * @param - _Line_ | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @note SWI-Prolog built-in. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     static Int source_location(USES_REGS1) { | 
					
						
							|  |  |  |       return Yap_unify(ARG1, MkAtomTerm(LOCAL_SourceFileName)) && | 
					
						
							|  |  |  | 	Yap_unify(ARG2, MkIntegerTerm(LOCAL_SourceFileLineno)); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * @pred read(+ Stream, -Term ) is iso | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * Reads term  _T_ from the stream  _S_ instead of from the current input | 
					
						
							|  |  |  |      * stream. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param - _Stream_ | 
					
						
							|  |  |  |      * @param - _Term_ | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     static Int read2( | 
					
						
							|  |  |  | 		     USES_REGS1) { /* '$read2'(+Flag,?Term,?Module,?Vars,-Pos,-Err,+Stream)  */ | 
					
						
							|  |  |  |       int sno; | 
					
						
							|  |  |  |       Int out; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       /* needs to change LOCAL_output_stream for write */ | 
					
						
							|  |  |  |       sno = Yap_CheckTextStream(ARG1, Input_Stream_f, "read/3"); | 
					
						
							|  |  |  |       if (sno == -1) { | 
					
						
							|  |  |  | 	return (FALSE); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       out = Yap_read_term(sno, add_output(ARG2, TermNil), false); | 
					
						
							|  |  |  |       UNLOCK(GLOBAL_Stream[sno].streamlock); | 
					
						
							|  |  |  |       return out; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     /** @pred  read(- T) is iso
 | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 	Reads the next term from the current input stream, and unifies it with | 
					
						
							|  |  |  | 	_T_. The term must be followed by a dot (`.`) and any blank-character | 
					
						
							|  |  |  | 	as previously defined. The syntax of the term must match the current | 
					
						
							|  |  |  | 	declarations for operators (see op). If the end-of-stream is reached, | 
					
						
							|  |  |  | 	_T_ is unified with the atom `end_of_file`. Further reads from of | 
					
						
							|  |  |  | 	the same stream may cause an error failure (see open/3). | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     */ | 
					
						
							|  |  |  |     static Int read1( | 
					
						
							|  |  |  | 		     USES_REGS1) { /* '$read2'(+Flag,?Term,?Module,?Vars,-Pos,-Err,+Stream)  */ | 
					
						
							|  |  |  |       Term out = Yap_read_term(LOCAL_c_input_stream, add_output(ARG1, TermNil), 1); | 
					
						
							|  |  |  |       return out; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     /**  @pred fileerrors
 | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 	 Switches on the file_errors flag so that in certain error conditions | 
					
						
							|  |  |  | 	 Input/Output predicates will produce an appropriated message and abort. | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     */ | 
					
						
							|  |  |  |     static Int fileerrors(USES_REGS1) { | 
					
						
							|  |  |  |       return setYapFlag(TermFileErrors, TermTrue); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |        @pred  nofileerrors | 
					
						
							| 
									
										
										
										
											2015-07-06 12:03:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |        Switches off the `file_errors` flag, so that the predicates see/1, | 
					
						
							|  |  |  |        tell/1, open/3 and close/1 just fail, instead of producing | 
					
						
							|  |  |  |        an error message and aborting whenever the specified file cannot be | 
					
						
							|  |  |  |        opened or closed. | 
					
						
							| 
									
										
										
										
											2018-07-02 15:20:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     */ | 
					
						
							|  |  |  |     static Int nofileerrors( | 
					
						
							|  |  |  | 			    USES_REGS1) { /* '$read2'(+Flag,?Term,?Module,?Vars,-Pos,-Err,+Stream)  */ | 
					
						
							|  |  |  |       return setYapFlag(TermFileerrors, TermFalse); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-07-02 15:20:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     static Int style_checker(USES_REGS1) { | 
					
						
							|  |  |  |       Term t = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2018-07-21 12:08:09 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |       if (IsVarTerm(t)) { | 
					
						
							|  |  |  | 	Term t = TermNil; | 
					
						
							|  |  |  | 	if (getYapFlag(MkAtomTerm(AtomSingleVarWarnings)) == TermTrue) { | 
					
						
							|  |  |  | 	  t = MkPairTerm(MkAtomTerm(AtomSingleVarWarnings), t); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (getYapFlag(MkAtomTerm(AtomDiscontiguousWarnings)) == TermTrue) { | 
					
						
							|  |  |  | 	  t = MkPairTerm(MkAtomTerm(AtomDiscontiguousWarnings), t); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if (getYapFlag(MkAtomTerm(AtomRedefineWarnings)) == TermTrue) { | 
					
						
							|  |  |  | 	  t = MkPairTerm(MkAtomTerm(AtomRedefineWarnings), t); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  | 	while (IsPairTerm(t)) { | 
					
						
							|  |  |  | 	  Term h = HeadOfTerm(t); | 
					
						
							|  |  |  | 	  t = TailOfTerm(t); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	  if (IsVarTerm(h)) { | 
					
						
							|  |  |  | 	    Yap_Error(INSTANTIATION_ERROR, t, "style_check/1"); | 
					
						
							|  |  |  | 	    return (FALSE); | 
					
						
							|  |  |  | 	  } else if (IsAtomTerm(h)) { | 
					
						
							|  |  |  | 	    Atom at = AtomOfTerm(h); | 
					
						
							|  |  |  | 	    if (at == AtomSingleVarWarnings) | 
					
						
							|  |  |  | 	      setYapFlag(MkAtomTerm(AtomSingleVarWarnings), TermTrue); | 
					
						
							|  |  |  | 	    else if (at == AtomDiscontiguousWarnings) | 
					
						
							|  |  |  | 	      setYapFlag(MkAtomTerm(AtomDiscontiguousWarnings), TermTrue); | 
					
						
							|  |  |  | 	    else if (at == AtomRedefineWarnings) | 
					
						
							|  |  |  | 	      setYapFlag(MkAtomTerm(AtomRedefineWarnings), TermTrue); | 
					
						
							|  |  |  | 	  } else { | 
					
						
							|  |  |  | 	    Atom at = AtomOfTerm(ArgOfTerm(1, h)); | 
					
						
							|  |  |  | 	    if (at == AtomSingleVarWarnings) | 
					
						
							|  |  |  | 	      setYapFlag(MkAtomTerm(AtomSingleVarWarnings), TermFalse); | 
					
						
							|  |  |  | 	    else if (at == AtomDiscontiguousWarnings) | 
					
						
							|  |  |  | 	      setYapFlag(MkAtomTerm(AtomDiscontiguousWarnings), TermFalse); | 
					
						
							|  |  |  | 	    else if (at == AtomRedefineWarnings) | 
					
						
							|  |  |  | 	      setYapFlag(MkAtomTerm(AtomRedefineWarnings), TermFalse); | 
					
						
							|  |  |  | 	  } | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |       return TRUE; | 
					
						
							| 
									
										
										
										
											2015-08-18 14:37:39 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-01-05 16:57:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     Term Yap_BufferToTerm(const char *s, Term opts) { | 
					
						
							|  |  |  |       Term rval; | 
					
						
							|  |  |  |       int sno; | 
					
						
							|  |  |  |       encoding_t l = ENC_ISO_UTF8; | 
					
						
							|  |  |  |       sno = | 
					
						
							|  |  |  | 	Yap_open_buf_read_stream((char *)s, strlen(s) + 1, &l, MEM_BUF_USER, | 
					
						
							|  |  |  | 				 Yap_LookupAtom(Yap_StrPrefix(s, 16)), TermNone); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       GLOBAL_Stream[sno].status |= CloseOnException_Stream_f; | 
					
						
							|  |  |  |       rval = Yap_read_term(sno, opts, false); | 
					
						
							|  |  |  |       Yap_CloseStream(sno); | 
					
						
							|  |  |  |       return rval; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-01-05 16:57:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     Term Yap_UBufferToTerm(const unsigned char *s, Term opts) { | 
					
						
							|  |  |  |       Term rval; | 
					
						
							|  |  |  |       int sno; | 
					
						
							|  |  |  |       encoding_t l = ENC_ISO_UTF8; | 
					
						
							|  |  |  |       sno = Yap_open_buf_read_stream( | 
					
						
							|  |  |  | 				     (char *)s, strlen((const char *)s), &l, MEM_BUF_USER, | 
					
						
							|  |  |  | 				     Yap_LookupAtom(Yap_StrPrefix((char *)s, 16)), TermNone); | 
					
						
							|  |  |  |       GLOBAL_Stream[sno].status |= CloseOnException_Stream_f; | 
					
						
							|  |  |  |       rval = Yap_read_term(sno, opts, false); | 
					
						
							|  |  |  |       Yap_CloseStream(sno); | 
					
						
							|  |  |  |       return rval; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-01-05 16:57:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     X_API Term Yap_BufferToTermWithPrioBindings(const char *s, Term opts, | 
					
						
							|  |  |  | 						Term bindings, size_t len, | 
					
						
							|  |  |  | 						int prio) { | 
					
						
							|  |  |  |       CACHE_REGS | 
					
						
							|  |  |  | 	Term ctl; | 
					
						
							| 
									
										
										
										
											2018-01-05 16:57:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |       ctl = opts; | 
					
						
							|  |  |  |       if (bindings) { | 
					
						
							|  |  |  | 	ctl = add_names(bindings, TermNil); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       if (prio != 1200) { | 
					
						
							|  |  |  | 	ctl = add_priority(bindings, ctl); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       return Yap_BufferToTerm(s, ctl); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-01-05 16:57:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * @pred read_term_from_atom( +Atom , -T , +Options ) | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * read a term _T_ stored in constant _Atom_ according to  _Options_ | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param _Atom_ the source _Atom_ | 
					
						
							|  |  |  |      * @param _T_ the output term _T_, may be any term | 
					
						
							|  |  |  |      * @param _Options_ read_term/3 options. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @note Originally from SWI-Prolog, in YAP only works with internalised | 
					
						
							|  |  |  |      *atoms | 
					
						
							|  |  |  |      * Check  read_term_from_atomic/3 for the general version. Also, the built-in | 
					
						
							|  |  |  |      *is | 
					
						
							|  |  |  |      *supposed to | 
					
						
							|  |  |  |      * use YAP's internal encoding, so please avoid the encoding/1 option. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     static Int read_term_from_atom(USES_REGS1) { | 
					
						
							|  |  |  |       Term t1 = Deref(ARG1); | 
					
						
							|  |  |  |       Atom at; | 
					
						
							|  |  |  |       const unsigned char *s; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (IsVarTerm(t1)) { | 
					
						
							|  |  |  | 	Yap_Error(INSTANTIATION_ERROR, t1, "style_check/1"); | 
					
						
							|  |  |  | 	return false; | 
					
						
							|  |  |  |       } else if (!IsAtomTerm(t1)) { | 
					
						
							|  |  |  | 	Yap_Error(TYPE_ERROR_ATOM, t1, "style_check/1"); | 
					
						
							|  |  |  | 	return false; | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  | 	at = AtomOfTerm(t1); | 
					
						
							|  |  |  | 	s = at->UStrOfAE; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       Term ctl = add_output(ARG2, ARG3); | 
					
						
							| 
									
										
										
										
											2018-01-05 16:57:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |       return Yap_UBufferToTerm(s, ctl); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-01-05 16:57:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      *  @pred read_term_from_atomic( +Atomic , - T , +Options ) | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * read a term _T_ stored in text _Atomic_ according to  _Options_ | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param _Atomic_ the source may be an atom, string, list of codes, or list | 
					
						
							|  |  |  |      *of | 
					
						
							|  |  |  |      *chars. | 
					
						
							|  |  |  |      * @param _T_ the output term _T_, may be any term | 
					
						
							|  |  |  |      * @param _Options_ read_term/3 options. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @notes Idea originally from SWI-Prolog, but in YAP we separate atomic and | 
					
						
							|  |  |  |      *atom. | 
					
						
							|  |  |  |      * Encoding is fixed in atoms and strings. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     static Int read_term_from_atomic(USES_REGS1) { | 
					
						
							|  |  |  |       Term t1 = Deref(ARG1); | 
					
						
							|  |  |  |       const unsigned char *s; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (IsVarTerm(t1)) { | 
					
						
							|  |  |  | 	Yap_Error(INSTANTIATION_ERROR, t1, "read_term_from_atomic/3"); | 
					
						
							|  |  |  | 	return (FALSE); | 
					
						
							|  |  |  |       } else if (!IsAtomicTerm(t1)) { | 
					
						
							|  |  |  | 	Yap_Error(TYPE_ERROR_ATOMIC, t1, "read_term_from_atomic/3"); | 
					
						
							|  |  |  | 	return (FALSE); | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  | 	Term t = Yap_AtomicToString(t1 PASS_REGS); | 
					
						
							|  |  |  | 	s = UStringOfTerm(t); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       Term ctl = add_output(ARG2, ARG3); | 
					
						
							| 
									
										
										
										
											2018-01-05 16:57:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |       return Yap_UBufferToTerm(s, ctl); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-01-05 16:57:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * @pred read_term_from_string( +String , - T , + Options ) | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * read a term _T_ stored in constant _String_ according to  _Options_ | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param _String_ the source _String_ | 
					
						
							|  |  |  |      * @param _T_ the output term _T_, may be any term | 
					
						
							|  |  |  |      * @param _Options_ read_term/3 options. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      *  Idea from SWI-Prolog, in YAP only works with strings | 
					
						
							|  |  |  |      * Check  read_term_from_atomic/3 for the general version. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     static Int read_term_from_string(USES_REGS1) { | 
					
						
							|  |  |  |       Term t1 = Deref(ARG1), rc; | 
					
						
							|  |  |  |       const unsigned char *s; | 
					
						
							|  |  |  |       size_t len; | 
					
						
							|  |  |  |       BACKUP_H() | 
					
						
							|  |  |  | 	if (IsVarTerm(t1)) { | 
					
						
							|  |  |  | 	  Yap_Error(INSTANTIATION_ERROR, t1, "read_term_from_string/3"); | 
					
						
							|  |  |  | 	  return (FALSE); | 
					
						
							|  |  |  | 	} else if (!IsStringTerm(t1)) { | 
					
						
							|  |  |  | 	  Yap_Error(TYPE_ERROR_STRING, t1, "read_term_from_string/3"); | 
					
						
							|  |  |  | 	  return (FALSE); | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 	  s = UStringOfTerm(t1); | 
					
						
							|  |  |  | 	  len = strlen_utf8(s); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  |       char *ss = (char *)s; | 
					
						
							|  |  |  |       encoding_t enc = ENC_ISO_UTF8; | 
					
						
							|  |  |  |       int sno = Yap_open_buf_read_stream(ss, len, &enc, MEM_BUF_USER, | 
					
						
							|  |  |  | 					 Yap_LookupAtom(Yap_StrPrefix(ss, 16)), | 
					
						
							|  |  |  | 					 TermString); | 
					
						
							|  |  |  |       GLOBAL_Stream[sno].status |= CloseOnException_Stream_f; | 
					
						
							|  |  |  |       rc = Yap_read_term(sno, Deref(ARG3), 3); | 
					
						
							|  |  |  |       Yap_CloseStream(sno); | 
					
						
							|  |  |  |       RECOVER_H(); | 
					
						
							|  |  |  |       if (!rc) | 
					
						
							|  |  |  | 	return false; | 
					
						
							|  |  |  |       return Yap_unify(rc, ARG2); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-01-05 16:57:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     static Int atomic_to_term(USES_REGS1) { | 
					
						
							|  |  |  |       Term t1 = Deref(ARG1); | 
					
						
							|  |  |  |       int l = push_text_stack(); | 
					
						
							|  |  |  |       const unsigned char *s = Yap_TextToUTF8Buffer(t1 PASS_REGS); | 
					
						
							|  |  |  |       Int rc = Yap_UBufferToTerm(s, add_output(ARG2, add_names(ARG3, TermNil))); | 
					
						
							|  |  |  |       pop_text_stack(l); | 
					
						
							|  |  |  |       return rc; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-01-05 16:57:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     static Int atom_to_term(USES_REGS1) { | 
					
						
							|  |  |  |       Term t1 = Deref(ARG1); | 
					
						
							|  |  |  |       if (IsVarTerm(t1)) { | 
					
						
							|  |  |  | 	Yap_Error(INSTANTIATION_ERROR, t1, "read_term_from_string/3"); | 
					
						
							|  |  |  | 	return (FALSE); | 
					
						
							|  |  |  |       } else if (!IsAtomTerm(t1)) { | 
					
						
							|  |  |  | 	Yap_Error(TYPE_ERROR_ATOM, t1, "read_term_from_atomic/3"); | 
					
						
							|  |  |  | 	return (FALSE); | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  | 	Term t = Yap_AtomicToString(t1 PASS_REGS); | 
					
						
							|  |  |  | 	const unsigned char *us = UStringOfTerm(t); | 
					
						
							|  |  |  | 	return Yap_UBufferToTerm(us, add_output(ARG2, add_names(ARG3, TermNil))); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-01-05 16:57:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     static Int string_to_term(USES_REGS1) { | 
					
						
							|  |  |  |       Term t1 = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2018-07-21 12:08:09 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |       if (IsVarTerm(t1)) { | 
					
						
							|  |  |  | 	Yap_Error(INSTANTIATION_ERROR, t1, "read_term_from_string/3"); | 
					
						
							|  |  |  | 	return (FALSE); | 
					
						
							|  |  |  |       } else if (!IsStringTerm(t1)) { | 
					
						
							|  |  |  | 	Yap_Error(TYPE_ERROR_STRING, t1, "read_term_from_string/3"); | 
					
						
							|  |  |  | 	return (FALSE); | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  | 	const unsigned char *us = UStringOfTerm(t1); | 
					
						
							|  |  |  | 	return Yap_UBufferToTerm(us, add_output(ARG2, add_names(ARG3, TermNil))); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-07-21 12:08:09 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-22 12:38:13 +01:00
										 |  |  |     void Yap_InitReadTPreds(void) { | 
					
						
							|  |  |  |       Yap_InitCPred("read_term", 2, read_term2, SyncPredFlag); | 
					
						
							|  |  |  |       Yap_InitCPred("read_term", 3, read_term, SyncPredFlag); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       Yap_InitCPred("scan_to_list", 2, scan_to_list, SyncPredFlag); | 
					
						
							|  |  |  |       Yap_InitCPred("read", 1, read1, SyncPredFlag); | 
					
						
							|  |  |  |       Yap_InitCPred("read", 2, read2, SyncPredFlag); | 
					
						
							|  |  |  |       Yap_InitCPred("read_clause", 2, read_clause2, SyncPredFlag); | 
					
						
							|  |  |  |       Yap_InitCPred("read_clause", 3, read_clause, 0); | 
					
						
							|  |  |  |       Yap_InitCPred("read_term_from_atom", 3, read_term_from_atom, 0); | 
					
						
							|  |  |  |       Yap_InitCPred("read_term_from_atomic", 3, read_term_from_atomic, 0); | 
					
						
							|  |  |  |       Yap_InitCPred("read_term_from_string", 3, read_term_from_string, 0); | 
					
						
							|  |  |  |       Yap_InitCPred("atom_to_term", 3, atom_to_term, 0); | 
					
						
							|  |  |  |       Yap_InitCPred("atomic_to_term", 3, atomic_to_term, 0); | 
					
						
							|  |  |  |       Yap_InitCPred("string_to_term", 3, string_to_term, 0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       Yap_InitCPred("fileerrors", 0, fileerrors, SyncPredFlag); | 
					
						
							|  |  |  |       Yap_InitCPred("nofileeleerrors", 0, nofileerrors, SyncPredFlag); | 
					
						
							|  |  |  |       Yap_InitCPred("source_location", 2, source_location, SyncPredFlag); | 
					
						
							|  |  |  |       Yap_InitCPred("$style_checker", 1, style_checker, | 
					
						
							|  |  |  | 		    SyncPredFlag | HiddenPredFlag); | 
					
						
							|  |  |  |     } |