| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | /*************************************************************************
 | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | *	 YAP Prolog 							 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | *	Yap Prolog was developed at NCCUP - Universidade do Porto	 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | * Copyright L.Damas, V. Santos Costa and Universidade do Porto 1985--	 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | ************************************************************************** | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | * File:		qlyr.c							 * | 
					
						
							|  |  |  | * comments:	quick saver/loader					 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | * Last rev:     $Date: 2011-08-29$,$Author: vsc $			 * | 
					
						
							|  |  |  | * $Log: not supported by cvs2svn $					 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | *************************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "absmi.h"
 | 
					
						
							|  |  |  | #include "alloc.h"
 | 
					
						
							|  |  |  | #include "attvar.h"
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | #include "iopreds.h"
 | 
					
						
							|  |  |  | #include "yapio.h"
 | 
					
						
							|  |  |  | #include <Foreign.h>
 | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | #if HAVE_STRING_H
 | 
					
						
							|  |  |  | #include <string.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "qly.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static void RestoreEntries(PropEntry *, int USES_REGS); | 
					
						
							|  |  |  | static void CleanCode(PredEntry *USES_REGS); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  | typedef enum { | 
					
						
							|  |  |  |   OUT_OF_TEMP_SPACE = 0, | 
					
						
							|  |  |  |   OUT_OF_ATOM_SPACE = 1, | 
					
						
							|  |  |  |   OUT_OF_CODE_SPACE = 2, | 
					
						
							|  |  |  |   UNKNOWN_ATOM = 3, | 
					
						
							|  |  |  |   UNKNOWN_FUNCTOR = 4, | 
					
						
							|  |  |  |   UNKNOWN_PRED_ENTRY = 5, | 
					
						
							|  |  |  |   UNKNOWN_OPCODE = 6, | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   UNKNOWN_DBREF = 7, | 
					
						
							|  |  |  |   BAD_ATOM = 8, | 
					
						
							|  |  |  |   MISMATCH = 9, | 
					
						
							| 
									
										
										
										
											2011-09-01 06:20:21 -07:00
										 |  |  |   INCONSISTENT_CPRED = 10, | 
					
						
							| 
									
										
										
										
											2014-10-02 14:57:50 +01:00
										 |  |  |   BAD_READ = 11, | 
					
						
							|  |  |  |   BAD_HEADER = 12 | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  | } qlfr_err_t; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static char *qlyr_error[] = { | 
					
						
							|  |  |  |     "out of temporary space", | 
					
						
							|  |  |  |     "out of temporary space", | 
					
						
							|  |  |  |     "out of code space", | 
					
						
							|  |  |  |     "unknown atom in saved space", | 
					
						
							|  |  |  |     "unknown functor in saved space", | 
					
						
							|  |  |  |     "unknown predicate in saved space", | 
					
						
							|  |  |  |     "unknown YAAM opcode in saved space", | 
					
						
							|  |  |  |     "unknown data-base reference in saved space", | 
					
						
							|  |  |  |     "corrupted atom in saved space", | 
					
						
							|  |  |  |     "formatting mismatch in saved space", | 
					
						
							|  |  |  |     "foreign predicate has different definition in saved space", | 
					
						
							|  |  |  |     "bad read"}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static char *Yap_AlwaysAllocCodeSpace(UInt size) { | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   char *out; | 
					
						
							|  |  |  |   while (!(out = Yap_AllocCodeSpace(size))) { | 
					
						
							|  |  |  |     if (!Yap_growheap(FALSE, size, NULL)) { | 
					
						
							|  |  |  |       return NULL; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return out; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static void QLYR_ERROR(qlfr_err_t my_err) { | 
					
						
							|  |  |  |   // __android_log_print(ANDROID_LOG_INFO, "YAP ", "error %s in saved state
 | 
					
						
							|  |  |  |   // %s",GLOBAL_RestoreFile, qlyr_error[my_err]);
 | 
					
						
							|  |  |  |   Yap_Error(SYSTEM_ERROR_SAVED_STATE, TermNil, "error %s in saved state %s", | 
					
						
							|  |  |  |             GLOBAL_RestoreFile, qlyr_error[my_err]); | 
					
						
							| 
									
										
										
										
											2014-10-02 14:57:50 +01:00
										 |  |  |   Yap_exit(1); | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static Atom LookupAtom(Atom oat) { | 
					
						
							|  |  |  |   CACHE_REGS | 
					
						
							|  |  |  |   CELL hash = (CELL)(oat) % LOCAL_ImportAtomHashTableSize; | 
					
						
							|  |  |  |   import_atom_hash_entry_t *a; | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |   a = LOCAL_ImportAtomHashChain[hash]; | 
					
						
							|  |  |  |   while (a) { | 
					
						
							|  |  |  |     if (a->oval == oat) { | 
					
						
							|  |  |  |       return a->val; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     a = a->next; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   //  __android_log_print(ANDROID_LOG_INFO, "YAP ", "error %p in saved state ",
 | 
					
						
							|  |  |  |   //  oat);
 | 
					
						
							| 
									
										
										
										
											2011-10-21 19:12:21 +01:00
										 |  |  |   QLYR_ERROR(UNKNOWN_ATOM); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   return NIL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static void InsertAtom(Atom oat, Atom at) { | 
					
						
							| 
									
										
										
										
											2011-09-21 15:30:29 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   CELL hash = (CELL)(oat) % LOCAL_ImportAtomHashTableSize; | 
					
						
							|  |  |  |   import_atom_hash_entry_t *a; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   a = LOCAL_ImportAtomHashChain[hash]; | 
					
						
							|  |  |  |   while (a) { | 
					
						
							|  |  |  |     if (a->oval == oat) { | 
					
						
							|  |  |  |       return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     a = a->next; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   a = (import_atom_hash_entry_t *)malloc(sizeof(import_atom_hash_entry_t)); | 
					
						
							|  |  |  |   if (!a) { | 
					
						
							|  |  |  |     return; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   a->val = at; | 
					
						
							|  |  |  |   a->oval = oat; | 
					
						
							|  |  |  |   a->next = LOCAL_ImportAtomHashChain[hash]; | 
					
						
							|  |  |  |   LOCAL_ImportAtomHashChain[hash] = a; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static Functor LookupFunctor(Functor ofun) { | 
					
						
							| 
									
										
										
										
											2011-09-21 15:30:29 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   CELL hash = (CELL)(ofun) % LOCAL_ImportFunctorHashTableSize; | 
					
						
							|  |  |  |   import_functor_hash_entry_t *f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   f = LOCAL_ImportFunctorHashChain[hash]; | 
					
						
							|  |  |  |   while (f) { | 
					
						
							|  |  |  |     if (f->oval == ofun) { | 
					
						
							|  |  |  |       return f->val; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     f = f->next; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-10-21 19:12:21 +01:00
										 |  |  |   QLYR_ERROR(UNKNOWN_FUNCTOR); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   return NIL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static void InsertFunctor(Functor ofun, Functor fun) { | 
					
						
							| 
									
										
										
										
											2011-09-21 15:30:29 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   CELL hash = (CELL)(ofun) % LOCAL_ImportFunctorHashTableSize; | 
					
						
							|  |  |  |   import_functor_hash_entry_t *f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   f = LOCAL_ImportFunctorHashChain[hash]; | 
					
						
							|  |  |  |   while (f) { | 
					
						
							|  |  |  |     if (f->oval == ofun) { | 
					
						
							|  |  |  |       return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     f = f->next; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   f = (import_functor_hash_entry_t *)malloc( | 
					
						
							|  |  |  |       sizeof(import_functor_hash_entry_t)); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   if (!f) { | 
					
						
							|  |  |  |     return; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   f->val = fun; | 
					
						
							|  |  |  |   f->oval = ofun; | 
					
						
							|  |  |  |   f->next = LOCAL_ImportFunctorHashChain[hash]; | 
					
						
							|  |  |  |   LOCAL_ImportFunctorHashChain[hash] = f; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static PredEntry *LookupPredEntry(PredEntry *op) { | 
					
						
							| 
									
										
										
										
											2011-09-21 15:30:29 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2014-09-23 22:37:08 +01:00
										 |  |  |   CELL hash; | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   import_pred_entry_hash_entry_t *p; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-23 22:37:08 +01:00
										 |  |  |   if (LOCAL_ImportPredEntryHashTableSize == 0) | 
					
						
							|  |  |  |     return NULL; | 
					
						
							|  |  |  |   hash = (CELL)(op) % LOCAL_ImportPredEntryHashTableSize; | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   p = LOCAL_ImportPredEntryHashChain[hash]; | 
					
						
							|  |  |  |   while (p) { | 
					
						
							|  |  |  |     if (p->oval == op) { | 
					
						
							|  |  |  |       return p->val; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     p = p->next; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-10-21 19:12:21 +01:00
										 |  |  |   QLYR_ERROR(UNKNOWN_PRED_ENTRY); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   return NIL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static void InsertPredEntry(PredEntry *op, PredEntry *pe) { | 
					
						
							| 
									
										
										
										
											2011-09-21 15:30:29 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2014-09-23 22:37:08 +01:00
										 |  |  |   CELL hash; | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   import_pred_entry_hash_entry_t *p; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-23 22:37:08 +01:00
										 |  |  |   if (LOCAL_ImportPredEntryHashTableSize == 0) | 
					
						
							| 
									
										
										
										
											2014-09-25 09:47:38 +01:00
										 |  |  |     return; | 
					
						
							| 
									
										
										
										
											2014-09-23 22:37:08 +01:00
										 |  |  |   hash = (CELL)(op) % LOCAL_ImportPredEntryHashTableSize; | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   p = LOCAL_ImportPredEntryHashChain[hash]; | 
					
						
							|  |  |  |   while (p) { | 
					
						
							|  |  |  |     if (p->oval == op) { | 
					
						
							|  |  |  |       return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     p = p->next; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   p = (import_pred_entry_hash_entry_t *)malloc( | 
					
						
							|  |  |  |       sizeof(import_pred_entry_hash_entry_t)); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   if (!p) { | 
					
						
							|  |  |  |     return; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   p->val = pe; | 
					
						
							|  |  |  |   p->oval = op; | 
					
						
							|  |  |  |   p->next = LOCAL_ImportPredEntryHashChain[hash]; | 
					
						
							|  |  |  |   LOCAL_ImportPredEntryHashChain[hash] = p; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static OPCODE LookupOPCODE(OPCODE op) { | 
					
						
							| 
									
										
										
										
											2011-09-21 15:30:29 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2011-08-24 12:40:06 +01:00
										 |  |  |   CELL hash = (CELL)(op) % LOCAL_ImportOPCODEHashTableSize; | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   import_opcode_hash_entry_t *f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   f = LOCAL_ImportOPCODEHashChain[hash]; | 
					
						
							|  |  |  |   while (f) { | 
					
						
							|  |  |  |     if (f->oval == op) { | 
					
						
							|  |  |  |       return f->val; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     f = f->next; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-10-21 19:12:21 +01:00
										 |  |  |   QLYR_ERROR(UNKNOWN_OPCODE); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   return NIL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static int OpcodeID(OPCODE op) { | 
					
						
							| 
									
										
										
										
											2011-09-21 15:30:29 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2011-08-24 12:40:06 +01:00
										 |  |  |   CELL hash = (CELL)(op) % LOCAL_ImportOPCODEHashTableSize; | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   import_opcode_hash_entry_t *f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   f = LOCAL_ImportOPCODEHashChain[hash]; | 
					
						
							|  |  |  |   while (f) { | 
					
						
							|  |  |  |     if (f->oval == op) { | 
					
						
							|  |  |  |       return f->id; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     f = f->next; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-10-21 19:12:21 +01:00
										 |  |  |   QLYR_ERROR(UNKNOWN_OPCODE); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   return NIL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static void InsertOPCODE(OPCODE op0, int i, OPCODE op) { | 
					
						
							| 
									
										
										
										
											2011-09-21 15:30:29 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2011-08-24 12:40:06 +01:00
										 |  |  |   CELL hash = (CELL)(op0) % LOCAL_ImportOPCODEHashTableSize; | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   import_opcode_hash_entry_t *f; | 
					
						
							|  |  |  |   f = LOCAL_ImportOPCODEHashChain[hash]; | 
					
						
							|  |  |  |   while (f) { | 
					
						
							| 
									
										
										
										
											2011-08-24 12:40:06 +01:00
										 |  |  |     if (f->oval == op0) { | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |       return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     f = f->next; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   f = (import_opcode_hash_entry_t *)malloc(sizeof(import_opcode_hash_entry_t)); | 
					
						
							|  |  |  |   if (!f) { | 
					
						
							|  |  |  |     return; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-08-24 12:40:06 +01:00
										 |  |  |   f->val = op; | 
					
						
							|  |  |  |   f->oval = op0; | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   f->id = i; | 
					
						
							|  |  |  |   f->next = LOCAL_ImportOPCODEHashChain[hash]; | 
					
						
							|  |  |  |   LOCAL_ImportOPCODEHashChain[hash] = f; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static DBRef LookupDBRef(DBRef dbr, int inc_ref) { | 
					
						
							| 
									
										
										
										
											2011-09-21 15:30:29 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2014-09-22 18:13:35 +01:00
										 |  |  |   CELL hash; | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   import_dbref_hash_entry_t *p; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-22 18:13:35 +01:00
										 |  |  |   if (LOCAL_ImportDBRefHashTableSize == 0) | 
					
						
							|  |  |  |     return NULL; | 
					
						
							|  |  |  |   hash = (CELL)(dbr) % LOCAL_ImportDBRefHashTableSize; | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   p = LOCAL_ImportDBRefHashChain[hash]; | 
					
						
							|  |  |  |   while (p) { | 
					
						
							|  |  |  |     if (p->oval == dbr) { | 
					
						
							| 
									
										
										
										
											2012-06-12 14:50:36 +01:00
										 |  |  |       if (inc_ref) { | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |         p->count++; | 
					
						
							| 
									
										
										
										
											2012-06-12 14:50:36 +01:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |       return p->val; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     p = p->next; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-10-21 19:12:21 +01:00
										 |  |  |   QLYR_ERROR(UNKNOWN_DBREF); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   return NIL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static LogUpdClause *LookupMayFailDBRef(DBRef dbr) { | 
					
						
							| 
									
										
										
										
											2011-09-21 15:30:29 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2014-09-22 18:13:35 +01:00
										 |  |  |   CELL hash; | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   import_dbref_hash_entry_t *p; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-22 18:13:35 +01:00
										 |  |  |   if (LOCAL_ImportDBRefHashTableSize == 0) | 
					
						
							|  |  |  |     return NULL; | 
					
						
							|  |  |  |   hash = (CELL)(dbr) % LOCAL_ImportDBRefHashTableSize; | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   p = LOCAL_ImportDBRefHashChain[hash]; | 
					
						
							|  |  |  |   while (p) { | 
					
						
							|  |  |  |     if (p->oval == dbr) { | 
					
						
							|  |  |  |       p->count++; | 
					
						
							|  |  |  |       return (LogUpdClause *)p->val; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     p = p->next; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return NULL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static void InsertDBRef(DBRef dbr0, DBRef dbr) { | 
					
						
							| 
									
										
										
										
											2011-09-21 15:30:29 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   CELL hash = (CELL)(dbr0) % LOCAL_ImportDBRefHashTableSize; | 
					
						
							|  |  |  |   import_dbref_hash_entry_t *p; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   p = LOCAL_ImportDBRefHashChain[hash]; | 
					
						
							|  |  |  |   while (p) { | 
					
						
							|  |  |  |     if (p->oval == dbr0) { | 
					
						
							|  |  |  |       return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     p = p->next; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   p = (import_dbref_hash_entry_t *)malloc(sizeof(import_dbref_hash_entry_t)); | 
					
						
							|  |  |  |   if (!p) { | 
					
						
							|  |  |  |     return; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   p->val = dbr; | 
					
						
							|  |  |  |   p->oval = dbr0; | 
					
						
							|  |  |  |   p->count = 0; | 
					
						
							|  |  |  |   p->next = LOCAL_ImportDBRefHashChain[hash]; | 
					
						
							|  |  |  |   LOCAL_ImportDBRefHashChain[hash] = p; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static void InitHash(void) { | 
					
						
							| 
									
										
										
										
											2011-09-21 15:30:29 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   LOCAL_ImportOPCODEHashTableSize = EXPORT_OPCODE_TABLE_SIZE; | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   LOCAL_ImportOPCODEHashChain = (import_opcode_hash_entry_t **)calloc( | 
					
						
							|  |  |  |       1, | 
					
						
							|  |  |  |       sizeof(import_opcode_hash_entry_t *) * LOCAL_ImportOPCODEHashTableSize); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static void CloseHash(void) { | 
					
						
							| 
									
										
										
										
											2011-09-21 15:30:29 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   UInt i; | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   for (i = 0; i < LOCAL_ImportFunctorHashTableSize; i++) { | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |     import_functor_hash_entry_t *a = LOCAL_ImportFunctorHashChain[i]; | 
					
						
							|  |  |  |     while (a) { | 
					
						
							|  |  |  |       import_functor_hash_entry_t *a0 = a; | 
					
						
							|  |  |  |       a = a->next; | 
					
						
							|  |  |  |       free(a0); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   LOCAL_ImportFunctorHashTableSize = 0; | 
					
						
							|  |  |  |   free(LOCAL_ImportFunctorHashChain); | 
					
						
							|  |  |  |   LOCAL_ImportFunctorHashChain = NULL; | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   for (i = 0; i < LOCAL_ImportAtomHashTableSize; i++) { | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |     import_atom_hash_entry_t *a = LOCAL_ImportAtomHashChain[i]; | 
					
						
							|  |  |  |     while (a) { | 
					
						
							|  |  |  |       import_atom_hash_entry_t *a0 = a; | 
					
						
							|  |  |  |       a = a->next; | 
					
						
							|  |  |  |       free(a0); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   LOCAL_ImportAtomHashTableSize = 0; | 
					
						
							|  |  |  |   free(LOCAL_ImportAtomHashChain); | 
					
						
							|  |  |  |   LOCAL_ImportAtomHashChain = NULL; | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   for (i = 0; i < LOCAL_ImportOPCODEHashTableSize; i++) { | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |     import_opcode_hash_entry_t *a = LOCAL_ImportOPCODEHashChain[i]; | 
					
						
							|  |  |  |     while (a) { | 
					
						
							|  |  |  |       import_opcode_hash_entry_t *a0 = a; | 
					
						
							|  |  |  |       a = a->next; | 
					
						
							|  |  |  |       free(a0); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   LOCAL_ImportOPCODEHashTableSize = 0; | 
					
						
							|  |  |  |   free(LOCAL_ImportOPCODEHashChain); | 
					
						
							|  |  |  |   LOCAL_ImportOPCODEHashChain = NULL; | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   for (i = 0; i < LOCAL_ImportPredEntryHashTableSize; i++) { | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |     import_pred_entry_hash_entry_t *a = LOCAL_ImportPredEntryHashChain[i]; | 
					
						
							|  |  |  |     while (a) { | 
					
						
							|  |  |  |       import_pred_entry_hash_entry_t *a0 = a; | 
					
						
							|  |  |  |       a = a->next; | 
					
						
							|  |  |  |       free(a0); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   LOCAL_ImportPredEntryHashTableSize = 0; | 
					
						
							|  |  |  |   free(LOCAL_ImportPredEntryHashChain); | 
					
						
							|  |  |  |   LOCAL_ImportPredEntryHashChain = NULL; | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   for (i = 0; i < LOCAL_ImportDBRefHashTableSize; i++) { | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |     import_dbref_hash_entry_t *a = LOCAL_ImportDBRefHashChain[i]; | 
					
						
							|  |  |  |     while (a) { | 
					
						
							|  |  |  |       import_dbref_hash_entry_t *a0 = a; | 
					
						
							|  |  |  | #ifdef DEBUG
 | 
					
						
							|  |  |  |       if (!a->count) { | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |         fprintf(stderr, "WARNING: unused reference %p %p\n", a->val, a->oval); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |       } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |       a = a->next; | 
					
						
							|  |  |  |       free(a0); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   LOCAL_ImportDBRefHashTableSize = 0; | 
					
						
							|  |  |  |   free(LOCAL_ImportDBRefHashChain); | 
					
						
							|  |  |  |   LOCAL_ImportDBRefHashChain = NULL; | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static inline Atom AtomAdjust(Atom a) { return LookupAtom(a); } | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static inline Functor FuncAdjust(Functor f) { | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   return LookupFunctor(f); | 
					
						
							|  |  |  |   return f; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static inline Term AtomTermAdjust(Term t) { | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   return MkAtomTerm(LookupAtom(AtomOfTerm(t))); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static inline Term TermToGlobalOrAtomAdjust(Term t) { | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   if (t && IsAtomTerm(t)) | 
					
						
							|  |  |  |     return AtomTermAdjust(t); | 
					
						
							|  |  |  |   return t; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define IsOldCode(P) FALSE
 | 
					
						
							|  |  |  | #define IsOldCodeCellPtr(P) FALSE
 | 
					
						
							|  |  |  | #define IsOldDelay(P) FALSE
 | 
					
						
							|  |  |  | #define IsOldDelayPtr(P) FALSE
 | 
					
						
							|  |  |  | #define IsOldLocalInTR(P) FALSE
 | 
					
						
							|  |  |  | #define IsOldLocalInTRPtr(P) FALSE
 | 
					
						
							|  |  |  | #define IsOldGlobal(P) FALSE
 | 
					
						
							|  |  |  | #define IsOldGlobalPtr(P) FALSE
 | 
					
						
							|  |  |  | #define IsOldTrail(P) FALSE
 | 
					
						
							|  |  |  | #define IsOldTrailPtr(P) FALSE
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define CharP(X) ((char *)(X))
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | #define REINIT_LOCK(P)
 | 
					
						
							|  |  |  | #define REINIT_RWLOCK(P)
 | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | #define BlobTypeAdjust(P) (P)
 | 
					
						
							|  |  |  | #define NoAGCAtomAdjust(P) (P)
 | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | #define OrArgAdjust(P)
 | 
					
						
							|  |  |  | #define TabEntryAdjust(P)
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | #define IntegerAdjust(D) (D)
 | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | #define AddrAdjust(P) (P)
 | 
					
						
							|  |  |  | #define MFileAdjust(P) (P)
 | 
					
						
							| 
									
										
										
										
											2011-08-25 03:20:20 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define CodeVarAdjust(P) CodeVarAdjust__(P PASS_REGS)
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static inline Term CodeVarAdjust__(Term var USES_REGS) { | 
					
						
							| 
									
										
										
										
											2011-08-25 03:20:20 +01:00
										 |  |  |   if (var == 0L) | 
					
						
							|  |  |  |     return var; | 
					
						
							|  |  |  |   return (Term)(CharP(var) + LOCAL_HDiff); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | #define ConstantAdjust(P) (P)
 | 
					
						
							|  |  |  | #define ArityAdjust(P) (P)
 | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | #define DoubleInCodeAdjust(P)
 | 
					
						
							|  |  |  | #define IntegerInCodeAdjust(Pxb)
 | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static inline PredEntry *PtoPredAdjust(PredEntry *p) { | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   return LookupPredEntry(p); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static inline PredEntry *PredEntryAdjust(PredEntry *p) { | 
					
						
							| 
									
										
										
										
											2011-08-24 12:40:06 +01:00
										 |  |  |   return LookupPredEntry(p); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static inline OPCODE OpcodeAdjust(OPCODE OP) { return LookupOPCODE(OP); } | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static inline Term ModuleAdjust(Term M) { | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   if (!M) | 
					
						
							|  |  |  |     return M; | 
					
						
							|  |  |  |   return AtomTermAdjust(M); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define ExternalFunctionAdjust(P) (P)
 | 
					
						
							|  |  |  | #define DBRecordAdjust(P) (P)
 | 
					
						
							|  |  |  | #define ModEntryPtrAdjust(P) (P)
 | 
					
						
							|  |  |  | #define AtomEntryAdjust(P) (P)
 | 
					
						
							|  |  |  | #define GlobalEntryAdjust(P) (P)
 | 
					
						
							|  |  |  | #define BlobTermInCodeAdjust(P) BlobTermInCodeAdjust__(P PASS_REGS)
 | 
					
						
							|  |  |  | #if TAGS_FAST_OPS
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static inline Term BlobTermInCodeAdjust__(Term t USES_REGS) { | 
					
						
							|  |  |  |   return (Term)((char *)(t)-LOCAL_HDiff); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | } | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static inline Term BlobTermInCodeAdjust__(Term t USES_REGS) { | 
					
						
							|  |  |  |   return (Term)((char *)(t) + LOCAL_HDiff); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2011-08-25 03:20:20 +01:00
										 |  |  | #define DBTermAdjust(P) DBTermAdjust__(P PASS_REGS)
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static inline DBTerm *DBTermAdjust__(DBTerm *dbtp USES_REGS) { | 
					
						
							|  |  |  |   return (DBTerm *)(CharP(dbtp) + LOCAL_HDiff); | 
					
						
							| 
									
										
										
										
											2011-08-25 03:20:20 +01:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define CellPtoHeapAdjust(P) CellPtoHeapAdjust__(P PASS_REGS)
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static inline CELL *CellPtoHeapAdjust__(CELL *dbtp USES_REGS) { | 
					
						
							|  |  |  |   return (CELL *)(CharP(dbtp) + LOCAL_HDiff); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | #define PtoAtomHashEntryAdjust(P) (P)
 | 
					
						
							|  |  |  | #define CellPtoHeapCellAdjust(P) (P)
 | 
					
						
							|  |  |  | #define CellPtoTRAdjust(P) (P)
 | 
					
						
							|  |  |  | #define CodeAddrAdjust(P) (P)
 | 
					
						
							|  |  |  | #define ConsultObjAdjust(P) (P)
 | 
					
						
							|  |  |  | #define DelayAddrAdjust(P) (P)
 | 
					
						
							|  |  |  | #define DelayAdjust(P) (P)
 | 
					
						
							|  |  |  | #define GlobalAdjust(P) (P)
 | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-12 14:50:36 +01:00
										 |  |  | #define DBRefAdjust(P, Ref) DBRefAdjust__(P, Ref PASS_REGS)
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static inline DBRef DBRefAdjust__(DBRef dbtp, int do_reference USES_REGS) { | 
					
						
							| 
									
										
										
										
											2012-06-12 14:50:36 +01:00
										 |  |  |   return LookupDBRef(dbtp, do_reference); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define DBRefPAdjust(P) DBRefPAdjust__(P PASS_REGS)
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static inline DBRef *DBRefPAdjust__(DBRef *dbtp USES_REGS) { | 
					
						
							|  |  |  |   return (DBRef *)((char *)(dbtp) + LOCAL_HDiff); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | #define LUIndexAdjust(P) (P)
 | 
					
						
							|  |  |  | #define SIndexAdjust(P) (P)
 | 
					
						
							|  |  |  | #define LocalAddrAdjust(P) (P)
 | 
					
						
							|  |  |  | #define GlobalAddrAdjust(P) (P)
 | 
					
						
							|  |  |  | #define OpListAdjust(P) (P)
 | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define PtoLUCAdjust(P) PtoLUCAdjust__(P PASS_REGS)
 | 
					
						
							|  |  |  | #define PtoLUClauseAdjust(P) PtoLUCAdjust__(P PASS_REGS)
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static inline LogUpdClause *PtoLUCAdjust__(LogUpdClause *dbtp USES_REGS) { | 
					
						
							|  |  |  |   return (LogUpdClause *)((char *)(dbtp) + LOCAL_HDiff); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | #define PtoStCAdjust(P) (P)
 | 
					
						
							|  |  |  | #define PtoArrayEAdjust(P) (P)
 | 
					
						
							|  |  |  | #define PtoArraySAdjust(P) (P)
 | 
					
						
							|  |  |  | #define PtoGlobalEAdjust(P) (P)
 | 
					
						
							|  |  |  | #define PtoDelayAdjust(P) (P)
 | 
					
						
							|  |  |  | #define PtoGloAdjust(P) (P)
 | 
					
						
							|  |  |  | #define PtoLocAdjust(P) (P)
 | 
					
						
							| 
									
										
										
										
											2011-08-25 03:20:20 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define PtoHeapCellAdjust(P) PtoHeapCellAdjust__(P PASS_REGS)
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static inline CELL *PtoHeapCellAdjust__(CELL *ptr USES_REGS) { | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   LogUpdClause *out; | 
					
						
							|  |  |  |   if ((out = LookupMayFailDBRef((DBRef)ptr))) | 
					
						
							|  |  |  |     return (CELL *)out; | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   return (CELL *)(CharP(ptr) + LOCAL_HDiff); | 
					
						
							| 
									
										
										
										
											2011-08-25 03:20:20 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | #define TermToGlobalAdjust(P) (P)
 | 
					
						
							|  |  |  | #define PtoOpAdjust(P) PtoOpAdjust__(P PASS_REGS)
 | 
					
						
							|  |  |  | static inline yamop *PtoOpAdjust__(yamop *ptr USES_REGS) { | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   if (ptr) { | 
					
						
							|  |  |  |     if (ptr == LOCAL_ImportFAILCODE) | 
					
						
							|  |  |  |       return FAILCODE; | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |     return (yamop *)((char *)(ptr) + LOCAL_HDiff); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   return ptr; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #define PtoLUIndexAdjust(P) (P)
 | 
					
						
							|  |  |  | #define PtoDBTLAdjust(P) (P)
 | 
					
						
							|  |  |  | #define PtoPtoPredAdjust(P) (P)
 | 
					
						
							|  |  |  | #define OpRTableAdjust(P) (P)
 | 
					
						
							|  |  |  | #define OpEntryAdjust(P) (P)
 | 
					
						
							|  |  |  | #define PropAdjust(P) (P)
 | 
					
						
							|  |  |  | #define TrailAddrAdjust(P) (P)
 | 
					
						
							|  |  |  | #if PRECOMPUTE_REGADDRESS
 | 
					
						
							|  |  |  | #define XAdjust(P) XAdjust__(P PASS_REGS)
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static inline wamreg XAdjust__(wamreg reg USES_REGS) { | 
					
						
							|  |  |  |   return (wamreg)((wamreg)((reg) + LOCAL_XDiff)); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | } | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define XAdjust(X) (X)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #define YAdjust(X) (X)
 | 
					
						
							|  |  |  | #define HoldEntryAdjust(P) (P)
 | 
					
						
							|  |  |  | #define CodeCharPAdjust(P) (P)
 | 
					
						
							| 
									
										
										
										
											2014-12-14 11:52:07 +00:00
										 |  |  | #define CodeConstCharPAdjust(P) (P)
 | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | #define CodeVoidPAdjust(P) (P)
 | 
					
						
							|  |  |  | #define HaltHookAdjust(P) (P)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define recompute_mask(dbr)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define rehash(oldcode, NOfE, KindOfEntries)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define RestoreSWIHash()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define Yap_op_from_opcode(OP) OpcodeID(OP)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static void RestoreFlags(UInt NFlags) {} | 
					
						
							| 
									
										
										
										
											2015-08-07 16:57:53 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | #include "rheap.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static void RestoreHashPreds(USES_REGS1) {} | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static void RestoreAtomList(Atom atm USES_REGS) {} | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static size_t read_bytes(FILE *stream, void *ptr, size_t sz) { | 
					
						
							| 
									
										
										
										
											2015-06-19 00:32:38 +01:00
										 |  |  |   return fread(ptr, sz, 1, stream); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static unsigned char read_byte(FILE *stream) { return getc(stream); } | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static BITS16 read_bits16(FILE *stream) { | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |   BITS16 v; | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   read_bytes(stream, &v, sizeof(BITS16)); | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |   return v; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static UInt read_UInt(FILE *stream) { | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   UInt v; | 
					
						
							|  |  |  |   read_bytes(stream, &v, sizeof(UInt)); | 
					
						
							|  |  |  |   return v; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static Int read_Int(FILE *stream) { | 
					
						
							| 
									
										
										
										
											2014-09-16 04:00:31 -05:00
										 |  |  |   Int v; | 
					
						
							|  |  |  |   read_bytes(stream, &v, sizeof(Int)); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   return v; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static qlf_tag_t read_tag(FILE *stream) { | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   int ch = read_byte(stream); | 
					
						
							|  |  |  |   return ch; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static pred_flags_t read_predFlags(FILE *stream) { | 
					
						
							| 
									
										
										
										
											2015-01-06 17:47:58 +00:00
										 |  |  |   pred_flags_t v; | 
					
						
							|  |  |  |   read_bytes(stream, &v, sizeof(pred_flags_t)); | 
					
						
							|  |  |  |   return v; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static bool checkChars(FILE *stream, char s[]) { | 
					
						
							| 
									
										
										
										
											2014-10-02 14:57:50 +01:00
										 |  |  |   int ch, c; | 
					
						
							|  |  |  |   char *p = s; | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-02 14:57:50 +01:00
										 |  |  |   while ((ch = *p++)) { | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |     if ((c = read_byte(stream)) != ch) { | 
					
						
							| 
									
										
										
										
											2014-10-02 14:57:50 +01:00
										 |  |  |       return false; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return TRUE; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static Atom do_header(FILE *stream) { | 
					
						
							| 
									
										
										
										
											2014-10-02 14:57:50 +01:00
										 |  |  |   char s[256], *p = s, ch; | 
					
						
							|  |  |  |   Atom at; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   if (!checkChars(stream, "#!/bin/sh\nexec_dir=${YAPBINDIR:-")) | 
					
						
							| 
									
										
										
										
											2014-10-02 14:57:50 +01:00
										 |  |  |     return NIL; | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   while ((ch = read_byte(stream)) != '\n') | 
					
						
							|  |  |  |     ; | 
					
						
							|  |  |  |   if (!checkChars(stream, "exec $exec_dir/yap $0 \"$@\"\nsaved ")) | 
					
						
							| 
									
										
										
										
											2014-10-02 14:57:50 +01:00
										 |  |  |     return NIL; | 
					
						
							|  |  |  |   while ((ch = read_byte(stream)) != ',') | 
					
						
							|  |  |  |     *p++ = ch; | 
					
						
							|  |  |  |   *p++ = '\0'; | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   at = Yap_LookupAtom(s); | 
					
						
							|  |  |  |   while ((ch = read_byte(stream))) | 
					
						
							|  |  |  |     ; | 
					
						
							| 
									
										
										
										
											2014-10-02 14:57:50 +01:00
										 |  |  |   return at; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static Int get_header(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2015-06-19 00:32:38 +01:00
										 |  |  |   FILE *stream; | 
					
						
							| 
									
										
										
										
											2014-10-02 14:57:50 +01:00
										 |  |  |   Term t1 = Deref(ARG1); | 
					
						
							|  |  |  |   Atom at; | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   Int rc; | 
					
						
							| 
									
										
										
										
											2014-10-02 14:57:50 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |   if (IsVarTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |     Yap_Error(INSTANTIATION_ERROR, t1, "read_program/3"); | 
					
						
							| 
									
										
										
										
											2014-10-02 14:57:50 +01:00
										 |  |  |     return FALSE; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   if (!(stream = Yap_GetInputStream(t1, "header scanning in qload"))) { | 
					
						
							| 
									
										
										
										
											2014-10-02 14:57:50 +01:00
										 |  |  |     return FALSE; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   if ((at = do_header(stream)) == NIL) | 
					
						
							| 
									
										
										
										
											2015-06-19 10:10:02 +01:00
										 |  |  |     rc = FALSE; | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   else | 
					
						
							|  |  |  |     rc = Yap_unify(ARG2, MkAtomTerm(at)); | 
					
						
							|  |  |  |   return rc; | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static void ReadHash(FILE *stream) { | 
					
						
							| 
									
										
										
										
											2011-09-21 15:30:29 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   UInt i; | 
					
						
							|  |  |  |   RCHECK(read_tag(stream) == QLY_START_X); | 
					
						
							| 
									
										
										
										
											2014-09-16 04:00:31 -05:00
										 |  |  |   LOCAL_XDiff = (char *)(&ARG1) - (char *)read_UInt(stream); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   RCHECK(read_tag(stream) == QLY_START_OPCODES); | 
					
						
							| 
									
										
										
										
											2014-09-16 04:00:31 -05:00
										 |  |  |   RCHECK(read_Int(stream) == _std_top); | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   for (i = 0; i <= _std_top; i++) { | 
					
						
							| 
									
										
										
										
											2014-09-16 04:00:31 -05:00
										 |  |  |     InsertOPCODE((OPCODE)read_UInt(stream), i, Yap_opcode(i)); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   } | 
					
						
							|  |  |  |   RCHECK(read_tag(stream) == QLY_START_ATOMS); | 
					
						
							| 
									
										
										
										
											2014-09-16 04:00:31 -05:00
										 |  |  |   LOCAL_ImportAtomHashTableNum = read_UInt(stream); | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   LOCAL_ImportAtomHashTableSize = LOCAL_ImportAtomHashTableNum * 2; | 
					
						
							|  |  |  |   LOCAL_ImportAtomHashChain = (import_atom_hash_entry_t **)calloc( | 
					
						
							|  |  |  |       LOCAL_ImportAtomHashTableSize, sizeof(import_atom_hash_entry_t *)); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   for (i = 0; i < LOCAL_ImportAtomHashTableNum; i++) { | 
					
						
							| 
									
										
										
										
											2014-09-16 04:00:31 -05:00
										 |  |  |     Atom oat = (Atom)read_UInt(stream); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |     Atom at; | 
					
						
							|  |  |  |     qlf_tag_t tg = read_tag(stream); | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |     if (tg == QLY_ATOM_WIDE) { | 
					
						
							|  |  |  |       wchar_t *rep = (wchar_t *)AllocTempSpace(); | 
					
						
							|  |  |  |       UInt len; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-16 04:00:31 -05:00
										 |  |  |       len = read_UInt(stream); | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |       if (!EnoughTempSpace(len)) | 
					
						
							|  |  |  |         QLYR_ERROR(OUT_OF_TEMP_SPACE); | 
					
						
							|  |  |  |       read_bytes(stream, rep, (len + 1) * sizeof(wchar_t)); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |       while (!(at = Yap_LookupWideAtom(rep))) { | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |         if (!Yap_growheap(FALSE, 0, NULL)) { | 
					
						
							|  |  |  |           exit(1); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |       if (at == NIL) | 
					
						
							|  |  |  |         QLYR_ERROR(OUT_OF_ATOM_SPACE); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |     } else if (tg == QLY_ATOM) { | 
					
						
							|  |  |  |       char *rep = (char *)AllocTempSpace(); | 
					
						
							|  |  |  |       UInt len; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-16 04:00:31 -05:00
										 |  |  |       len = read_UInt(stream); | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |       if (!EnoughTempSpace(len)) | 
					
						
							|  |  |  |         QLYR_ERROR(OUT_OF_TEMP_SPACE); | 
					
						
							|  |  |  |       read_bytes(stream, rep, (len + 1) * sizeof(char)); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |       while (!(at = Yap_FullLookupAtom(rep))) { | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |         if (!Yap_growheap(FALSE, 0, NULL)) { | 
					
						
							|  |  |  |           exit(1); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |       if (at == NIL) | 
					
						
							|  |  |  |         QLYR_ERROR(OUT_OF_ATOM_SPACE); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2011-10-21 19:12:21 +01:00
										 |  |  |       QLYR_ERROR(BAD_ATOM); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |       return; | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |     } | 
					
						
							|  |  |  |     InsertAtom(oat, at); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   /* functors */ | 
					
						
							|  |  |  |   RCHECK(read_tag(stream) == QLY_START_FUNCTORS); | 
					
						
							| 
									
										
										
										
											2014-09-16 04:00:31 -05:00
										 |  |  |   LOCAL_ImportFunctorHashTableNum = read_UInt(stream); | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   LOCAL_ImportFunctorHashTableSize = 2 * LOCAL_ImportFunctorHashTableNum; | 
					
						
							|  |  |  |   LOCAL_ImportFunctorHashChain = (import_functor_hash_entry_t **)calloc( | 
					
						
							|  |  |  |       LOCAL_ImportFunctorHashTableSize, sizeof(import_functor_hash_entry_t *)); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   for (i = 0; i < LOCAL_ImportFunctorHashTableNum; i++) { | 
					
						
							| 
									
										
										
										
											2014-09-16 04:00:31 -05:00
										 |  |  |     Functor of = (Functor)read_UInt(stream); | 
					
						
							|  |  |  |     UInt arity = read_UInt(stream); | 
					
						
							|  |  |  |     Atom oat = (Atom)read_UInt(stream); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |     Atom at = AtomAdjust(oat); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |     Functor f; | 
					
						
							|  |  |  |     while (!(f = Yap_MkFunctor(at, arity))) { | 
					
						
							|  |  |  |       if (!Yap_growheap(FALSE, 0, NULL)) { | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |         exit(1); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |     InsertFunctor(of, f); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   RCHECK(read_tag(stream) == QLY_START_PRED_ENTRIES); | 
					
						
							| 
									
										
										
										
											2014-09-16 04:00:31 -05:00
										 |  |  |   LOCAL_ImportPredEntryHashTableNum = read_UInt(stream); | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   LOCAL_ImportPredEntryHashTableSize = 2 * LOCAL_ImportPredEntryHashTableNum; | 
					
						
							|  |  |  |   LOCAL_ImportPredEntryHashChain = (import_pred_entry_hash_entry_t **)calloc( | 
					
						
							|  |  |  |       LOCAL_ImportPredEntryHashTableSize, | 
					
						
							|  |  |  |       sizeof(import_pred_entry_hash_entry_t *)); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   for (i = 0; i < LOCAL_ImportPredEntryHashTableNum; i++) { | 
					
						
							| 
									
										
										
										
											2014-09-16 04:00:31 -05:00
										 |  |  |     PredEntry *ope = (PredEntry *)read_UInt(stream), *pe; | 
					
						
							|  |  |  |     UInt arity = read_UInt(stream); | 
					
						
							|  |  |  |     Atom omod = (Atom)read_UInt(stream); | 
					
						
							| 
									
										
										
										
											2011-09-07 08:03:46 +02:00
										 |  |  |     Term mod; | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-07 08:03:46 +02:00
										 |  |  |     if (omod) { | 
					
						
							|  |  |  |       mod = MkAtomTerm(AtomAdjust(omod)); | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |       if (mod == TermProlog) | 
					
						
							|  |  |  |         mod = 0; | 
					
						
							| 
									
										
										
										
											2011-10-13 16:46:29 +01:00
										 |  |  |     } else { | 
					
						
							|  |  |  |       mod = TermProlog; | 
					
						
							| 
									
										
										
										
											2011-09-07 08:03:46 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |     if (mod != IDB_MODULE) { | 
					
						
							|  |  |  |       if (arity) { | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |         Functor of = (Functor)read_UInt(stream); | 
					
						
							|  |  |  |         Functor f = LookupFunctor(of); | 
					
						
							|  |  |  |         while (!(pe = RepPredProp(PredPropByFuncAndMod(f, mod)))) { | 
					
						
							|  |  |  |           if (!Yap_growheap(FALSE, 0, NULL)) { | 
					
						
							|  |  |  |             exit(1); | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |         Atom oa = (Atom)read_UInt(stream); | 
					
						
							|  |  |  |         Atom a = LookupAtom(oa); | 
					
						
							|  |  |  |         pe = RepPredProp(PredPropByAtomAndMod(a, mod)); | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2014-10-02 14:57:50 +01:00
										 |  |  |       /* IDB */ | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |       if (arity == (UInt)-1) { | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |         UInt i = read_UInt(stream); | 
					
						
							|  |  |  |         pe = Yap_FindLUIntKey(i); | 
					
						
							|  |  |  |       } else if (arity == (UInt)(-2)) { | 
					
						
							|  |  |  |         Atom oa = (Atom)read_UInt(stream); | 
					
						
							|  |  |  |         Atom a = LookupAtom(oa); | 
					
						
							|  |  |  |         pe = RepPredProp(PredPropByAtomAndMod(a, mod)); | 
					
						
							|  |  |  |         pe->PredFlags |= AtomDBPredFlag; | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |         Functor of = (Functor)read_UInt(stream); | 
					
						
							|  |  |  |         Functor f = LookupFunctor(of); | 
					
						
							|  |  |  |         pe = RepPredProp(PredPropByFuncAndMod(f, mod)); | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2014-10-02 14:57:50 +01:00
										 |  |  |       pe->PredFlags |= LogUpdatePredFlag; | 
					
						
							| 
									
										
										
										
											2011-09-07 08:03:46 +02:00
										 |  |  |       pe->ArityOfPE = 3; | 
					
						
							| 
									
										
										
										
											2014-10-02 14:57:50 +01:00
										 |  |  |       if (pe->OpcodeOfPred == UNDEF_OPCODE) { | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |         pe->OpcodeOfPred = Yap_opcode(_op_fail); | 
					
						
							|  |  |  |         pe->cs.p_code.TrueCodeOfPred = pe->CodeOfPred = FAILCODE; | 
					
						
							| 
									
										
										
										
											2014-10-02 14:57:50 +01:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |     } | 
					
						
							|  |  |  |     InsertPredEntry(ope, pe); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   RCHECK(read_tag(stream) == QLY_START_DBREFS); | 
					
						
							| 
									
										
										
										
											2014-09-16 04:00:31 -05:00
										 |  |  |   LOCAL_ImportDBRefHashTableNum = read_UInt(stream); | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   LOCAL_ImportDBRefHashTableSize = 2 * LOCAL_ImportDBRefHashTableNum + 17; | 
					
						
							|  |  |  |   LOCAL_ImportDBRefHashChain = (import_dbref_hash_entry_t **)calloc( | 
					
						
							|  |  |  |       LOCAL_ImportDBRefHashTableSize, sizeof(import_dbref_hash_entry_t *)); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   for (i = 0; i < LOCAL_ImportDBRefHashTableNum; i++) { | 
					
						
							| 
									
										
										
										
											2014-09-16 04:00:31 -05:00
										 |  |  |     LogUpdClause *ocl = (LogUpdClause *)read_UInt(stream); | 
					
						
							|  |  |  |     UInt sz = read_UInt(stream); | 
					
						
							|  |  |  |     UInt nrefs = read_UInt(stream); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |     LogUpdClause *ncl = (LogUpdClause *)Yap_AlwaysAllocCodeSpace(sz); | 
					
						
							| 
									
										
										
										
											2012-08-23 21:01:32 +01:00
										 |  |  |     if (!ncl) { | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |       QLYR_ERROR(OUT_OF_CODE_SPACE); | 
					
						
							| 
									
										
										
										
											2012-08-23 21:01:32 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |     ncl->Id = FunctorDBRef; | 
					
						
							|  |  |  |     ncl->ClRefCount = nrefs; | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |     InsertDBRef((DBRef)ocl, (DBRef)ncl); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   } | 
					
						
							|  |  |  |   RCHECK(read_tag(stream) == QLY_FAILCODE); | 
					
						
							| 
									
										
										
										
											2014-09-16 04:00:31 -05:00
										 |  |  |   LOCAL_ImportFAILCODE = (yamop *)read_UInt(stream); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static void read_clauses(FILE *stream, PredEntry *pp, UInt nclauses, | 
					
						
							|  |  |  |                          pred_flags_t flags) { | 
					
						
							| 
									
										
										
										
											2011-09-21 15:30:29 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |   if (flags & LogUpdatePredFlag) { | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |     /* first, clean up whatever was there */ | 
					
						
							|  |  |  |     if (pp->cs.p_code.NOfClauses) { | 
					
						
							|  |  |  |       LogUpdClause *cl; | 
					
						
							|  |  |  |       cl = ClauseCodeToLogUpdClause(pp->cs.p_code.FirstClause); | 
					
						
							|  |  |  |       do { | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |         LogUpdClause *ncl = cl->ClNext; | 
					
						
							|  |  |  |         Yap_ErLogUpdCl(cl); | 
					
						
							|  |  |  |         cl = ncl; | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |       } while (cl != NULL); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |     if (!nclauses) { | 
					
						
							|  |  |  |       return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     while ((read_tag(stream) == QLY_START_LU_CLAUSE)) { | 
					
						
							| 
									
										
										
										
											2014-09-16 04:00:31 -05:00
										 |  |  |       char *base = (void *)read_UInt(stream); | 
					
						
							|  |  |  |       UInt size = read_UInt(stream); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |       LogUpdClause *cl; | 
					
						
							|  |  |  |       Int nrefs = 0; | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |       if ((cl = LookupMayFailDBRef((DBRef)base))) { | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |         nrefs = cl->ClRefCount; | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |         cl = (LogUpdClause *)Yap_AlwaysAllocCodeSpace(size); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |       read_bytes(stream, cl, size); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |       cl->ClFlags &= ~InUseMask; | 
					
						
							|  |  |  |       cl->ClRefCount = nrefs; | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |       LOCAL_HDiff = (char *)cl - base; | 
					
						
							| 
									
										
										
										
											2011-09-21 15:30:29 +01:00
										 |  |  |       RestoreLUClause(cl, pp PASS_REGS); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |       Yap_AssertzClause(pp, cl->ClCode); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |   } else if (flags & MegaClausePredFlag) { | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |     CACHE_REGS | 
					
						
							| 
									
										
										
										
											2014-09-16 04:00:31 -05:00
										 |  |  |     char *base = (void *)read_UInt(stream); | 
					
						
							|  |  |  |     UInt mask = read_UInt(stream); | 
					
						
							|  |  |  |     UInt size = read_UInt(stream); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |     MegaClause *cl = (MegaClause *)Yap_AlwaysAllocCodeSpace(size); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |     if (nclauses) { | 
					
						
							|  |  |  |       Yap_Abolish(pp); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |     LOCAL_HDiff = (char *)cl - base; | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |     read_bytes(stream, cl, size); | 
					
						
							| 
									
										
										
										
											2013-01-11 18:36:34 +00:00
										 |  |  |     cl->ClFlags = mask; | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |     pp->cs.p_code.FirstClause = pp->cs.p_code.LastClause = cl->ClCode; | 
					
						
							| 
									
										
										
										
											2011-08-31 21:13:29 -07:00
										 |  |  |     pp->PredFlags |= MegaClausePredFlag; | 
					
						
							|  |  |  |     /* enter index mode */ | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |     if (mask & ExoMask) { | 
					
						
							|  |  |  |       struct index_t **icl = (struct index_t **)(cl->ClCode); | 
					
						
							| 
									
										
										
										
											2013-01-11 18:36:34 +00:00
										 |  |  |       pp->OpcodeOfPred = Yap_opcode(_enter_exo); | 
					
						
							|  |  |  |       icl[0] = NULL; | 
					
						
							|  |  |  |       icl[1] = NULL; | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       pp->OpcodeOfPred = INDEX_OPCODE; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |     pp->CodeOfPred = pp->cs.p_code.TrueCodeOfPred = | 
					
						
							|  |  |  |         (yamop *)(&(pp->OpcodeOfPred)); | 
					
						
							| 
									
										
										
										
											2011-08-31 21:13:29 -07:00
										 |  |  |     /* This must be set for restoremegaclause */ | 
					
						
							|  |  |  |     pp->cs.p_code.NOfClauses = nclauses; | 
					
						
							|  |  |  |     RestoreMegaClause(cl PASS_REGS); | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |   } else if (flags & DynamicPredFlag) { | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |     UInt i; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (i = 0; i < nclauses; i++) { | 
					
						
							| 
									
										
										
										
											2014-09-16 04:00:31 -05:00
										 |  |  |       char *base = (void *)read_UInt(stream); | 
					
						
							|  |  |  |       UInt size = read_UInt(stream); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |       DynamicClause *cl = (DynamicClause *)Yap_AlwaysAllocCodeSpace(size); | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |       LOCAL_HDiff = (char *)cl - base; | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |       read_bytes(stream, cl, size); | 
					
						
							| 
									
										
										
										
											2011-09-20 11:36:49 +01:00
										 |  |  |       INIT_LOCK(cl->ClLock); | 
					
						
							| 
									
										
										
										
											2011-09-21 15:30:29 +01:00
										 |  |  |       RestoreDynamicClause(cl, pp PASS_REGS); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |       Yap_AssertzClause(pp, cl->ClCode); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     UInt i; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |     if (flags & SYSTEM_PRED_FLAGS) { | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |       if (nclauses) { | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |         QLYR_ERROR(INCONSISTENT_CPRED); | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |       } | 
					
						
							|  |  |  |       return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     Yap_Abolish(pp); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |     for (i = 0; i < nclauses; i++) { | 
					
						
							| 
									
										
										
										
											2014-09-16 04:00:31 -05:00
										 |  |  |       char *base = (void *)read_UInt(stream); | 
					
						
							|  |  |  |       UInt size = read_UInt(stream); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |       StaticClause *cl = (StaticClause *)Yap_AlwaysAllocCodeSpace(size); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |       LOCAL_HDiff = (char *)cl - base; | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |       read_bytes(stream, cl, size); | 
					
						
							|  |  |  |       RestoreStaticClause(cl PASS_REGS); | 
					
						
							|  |  |  |       Yap_AssertzClause(pp, cl->ClCode); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static void read_pred(FILE *stream, Term mod) { | 
					
						
							|  |  |  |   pred_flags_t flags; | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |   UInt nclauses; | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   PredEntry *ap; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-16 04:00:31 -05:00
										 |  |  |   ap = LookupPredEntry((PredEntry *)read_UInt(stream)); | 
					
						
							| 
									
										
										
										
											2015-01-06 17:47:58 +00:00
										 |  |  |   flags = read_predFlags(stream); | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | #if 0
 | 
					
						
							|  |  |  |   if (ap->ArityOfPE && ap->ModuleOfPred != IDB_MODULE) | 
					
						
							| 
									
										
										
										
											2016-01-03 02:06:09 +00:00
										 |  |  |     // __android_log_print(ANDROID_LOG_INFO, "YAP ", "   %s/%ld %llx %llx\n", NameOfFunctor(ap->FunctorOfPred)->StrOfAE, ap->ArityOfPE, ap->PredFlags, flags);
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |      printf("   %s/%ld %llx %llx\n", NameOfFunctor(ap->FunctorOfPred)->StrOfAE, ap->ArityOfPE, ap->PredFlags, flags); | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |   else if (ap->ModuleOfPred != IDB_MODULE) | 
					
						
							| 
									
										
										
										
											2016-01-03 02:06:09 +00:00
										 |  |  |     //__android_log_print(ANDROID_LOG_INFO, "YAP ","   %s/%ld %llx %llx\n", ((Atom)(ap->FunctorOfPred))->StrOfAE, ap->ArityOfPE, flags);
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |      printf("   %s/%ld %llx %llx\n", ((Atom)(ap->FunctorOfPred))->StrOfAE, ap->ArityOfPE, ap->PredFlags, flags); | 
					
						
							| 
									
										
										
										
											2016-01-03 02:06:09 +00:00
										 |  |  |     //else
 | 
					
						
							|  |  |  |     //  __android_log_print(ANDROID_LOG_INFO, "YAP ","   number\n");
 | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2016-01-03 02:06:09 +00:00
										 |  |  |   if (flags & ForeignPredFlags) { | 
					
						
							|  |  |  |     if (!(ap->PredFlags & ForeignPredFlags)) | 
					
						
							|  |  |  |       QLYR_ERROR(INCONSISTENT_CPRED); | 
					
						
							|  |  |  |     if (flags & MetaPredFlag) | 
					
						
							|  |  |  |       ap->PredFlags |= MetaPredFlag; | 
					
						
							|  |  |  |     return; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   nclauses = read_UInt(stream); | 
					
						
							|  |  |  |   if (ap->PredFlags & IndexedPredFlag) { | 
					
						
							|  |  |  |     Yap_RemoveIndexation(ap); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   // fl1 = flags & ((pred_flags_t)STATIC_PRED_FLAGS|(UInt)EXTRA_PRED_FLAGS);
 | 
					
						
							|  |  |  |   // ap->PredFlags &= ~((UInt)STATIC_PRED_FLAGS|(UInt)EXTRA_PRED_FLAGS);
 | 
					
						
							| 
									
										
										
										
											2016-01-03 02:06:09 +00:00
										 |  |  |   ap->PredFlags = flags & ~StatePredFlags; | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |   if (flags & NumberDBPredFlag) { | 
					
						
							| 
									
										
										
										
											2014-09-16 04:00:31 -05:00
										 |  |  |     ap->src.IndxId = read_UInt(stream); | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2014-09-16 04:00:31 -05:00
										 |  |  |     ap->src.OwnerFile = (Atom)read_UInt(stream); | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-31 21:13:29 -07:00
										 |  |  |     if (ap->src.OwnerFile) { | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |       ap->src.OwnerFile = AtomAdjust(ap->src.OwnerFile); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2014-09-16 04:00:31 -05:00
										 |  |  |   ap->TimeStampOfPred = read_UInt(stream); | 
					
						
							| 
									
										
										
										
											2011-09-07 22:04:42 +02:00
										 |  |  |   /* multifile predicates cannot reside in module 0 */ | 
					
						
							| 
									
										
										
										
											2016-01-03 02:06:09 +00:00
										 |  |  |   //  if (flags & MultiFileFlag && ap->ModuleOfPred == PROLOG_MODULE) {
 | 
					
						
							|  |  |  |   //  ap->ModuleOfPred = TermProlog;
 | 
					
						
							|  |  |  |   // }
 | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |   if (nclauses) | 
					
						
							|  |  |  |     read_clauses(stream, ap, nclauses, flags); | 
					
						
							| 
									
										
										
										
											2015-06-19 00:32:38 +01:00
										 |  |  | #if DEBUG
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | // Yap_PrintPredName( ap );
 | 
					
						
							| 
									
										
										
										
											2015-06-19 00:32:38 +01:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |   if (flags & HiddenPredFlag) { | 
					
						
							| 
									
										
										
										
											2015-01-18 01:32:13 +00:00
										 |  |  |     Yap_HidePred(ap); | 
					
						
							| 
									
										
										
										
											2012-10-19 18:10:48 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static void read_ops(FILE *stream) { | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |   Int x; | 
					
						
							|  |  |  |   while ((x = read_tag(stream)) != QLY_END_OPS) { | 
					
						
							| 
									
										
										
										
											2014-09-16 04:00:31 -05:00
										 |  |  |     Atom at = (Atom)read_UInt(stream); | 
					
						
							|  |  |  |     Term mod = (Term)read_UInt(stream); | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |     OpEntry *op; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     at = AtomAdjust(at); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |     if (mod) | 
					
						
							|  |  |  |       mod = MkAtomTerm(AtomAdjust(AtomOfTerm(mod))); | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |     op = Yap_OpPropForModule(at, mod); | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |     op->Prefix = read_bits16(stream); | 
					
						
							|  |  |  |     op->Infix = read_bits16(stream); | 
					
						
							|  |  |  |     op->Posfix = read_bits16(stream); | 
					
						
							| 
									
										
										
										
											2011-09-20 11:36:49 +01:00
										 |  |  |     WRITE_UNLOCK(op->OpRWLock); | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static void read_module(FILE *stream) { | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   qlf_tag_t x; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-22 18:13:35 +01:00
										 |  |  |   InitHash(); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   ReadHash(stream); | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |   while ((x = read_tag(stream)) == QLY_START_MODULE) { | 
					
						
							| 
									
										
										
										
											2014-09-16 04:00:31 -05:00
										 |  |  |     Term mod = (Term)read_UInt(stream); | 
					
						
							| 
									
										
										
										
											2014-09-22 18:13:35 +01:00
										 |  |  |     if (mod == 0) | 
					
						
							|  |  |  |       mod = TermProlog; | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |     mod = MkAtomTerm(AtomAdjust(AtomOfTerm(mod))); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |     if (mod) | 
					
						
							| 
									
										
										
										
											2014-09-22 18:13:35 +01:00
										 |  |  |       while ((x = read_tag(stream)) == QLY_START_PREDICATE) { | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |         read_pred(stream, mod); | 
					
						
							| 
									
										
										
										
											2014-09-22 18:13:35 +01:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |   read_ops(stream); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   CloseHash(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static Int p_read_module_preds(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2015-06-19 00:32:38 +01:00
										 |  |  |   FILE *stream; | 
					
						
							| 
									
										
										
										
											2012-02-18 11:01:06 +00:00
										 |  |  |   Term t1 = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-18 11:01:06 +00:00
										 |  |  |   if (IsVarTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |     Yap_Error(INSTANTIATION_ERROR, t1, "read_qly/3"); | 
					
						
							| 
									
										
										
										
											2012-02-18 11:01:06 +00:00
										 |  |  |     return FALSE; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (!IsAtomTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |     Yap_Error(TYPE_ERROR_ATOM, t1, "read_qly/3"); | 
					
						
							|  |  |  |     return (FALSE); | 
					
						
							| 
									
										
										
										
											2012-02-18 11:01:06 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   if (!(stream = Yap_GetInputStream(t1, "scanning preducate modules"))) { | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |     return FALSE; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-08-24 12:40:06 +01:00
										 |  |  |   read_module(stream); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   return TRUE; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static void ReInitProlog(void) { | 
					
						
							| 
									
										
										
										
											2012-09-21 11:49:59 +01:00
										 |  |  |   Term t = MkAtomTerm(AtomInitProlog); | 
					
						
							| 
									
										
										
										
											2012-04-15 00:01:02 +01:00
										 |  |  |   YAP_RunGoalOnce(t); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | static Int qload_program(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2015-06-19 00:32:38 +01:00
										 |  |  |   FILE *stream; | 
					
						
							| 
									
										
										
										
											2012-02-18 11:01:06 +00:00
										 |  |  |   Term t1 = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-18 11:01:06 +00:00
										 |  |  |   if (IsVarTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |     Yap_Error(INSTANTIATION_ERROR, t1, "read_program/3"); | 
					
						
							| 
									
										
										
										
											2012-02-18 11:01:06 +00:00
										 |  |  |     return FALSE; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   if ((stream = Yap_GetInputStream(t1, "from read_program"))) { | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |     return FALSE; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   Yap_Reset(YAP_RESET_FROM_RESTORE); | 
					
						
							|  |  |  |   if (do_header(stream) == NIL) | 
					
						
							| 
									
										
										
										
											2014-10-02 14:57:50 +01:00
										 |  |  |     return FALSE; | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   read_module(stream); | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   fclose(stream); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   /* back to the top level we go */ | 
					
						
							| 
									
										
										
										
											2012-09-21 11:49:59 +01:00
										 |  |  |   ReInitProlog(); | 
					
						
							| 
									
										
										
										
											2015-06-19 00:32:38 +01:00
										 |  |  |   return true; | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-17 16:25:43 +01:00
										 |  |  | YAP_file_type_t Yap_Restore(const char *s, const char *lib_dir) { | 
					
						
							| 
									
										
										
										
											2015-04-13 13:32:32 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |   FILE *stream = Yap_OpenRestore(s, lib_dir); | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  |   if (!stream) | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |     return -1; | 
					
						
							| 
									
										
										
										
											2013-01-18 14:29:41 +00:00
										 |  |  |   GLOBAL_RestoreFile = s; | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   if (do_header(stream) == NIL) | 
					
						
							| 
									
										
										
										
											2016-06-17 16:25:43 +01:00
										 |  |  |     return YAP_BOOT_PL; | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   read_module(stream); | 
					
						
							| 
									
										
										
										
											2016-05-10 08:33:44 +01:00
										 |  |  |   setBooleanGlobalPrologFlag(SAVED_PROGRAM_FLAG, true); | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   fclose(stream); | 
					
						
							| 
									
										
										
										
											2013-01-18 14:29:41 +00:00
										 |  |  |   GLOBAL_RestoreFile = NULL; | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  |   LOCAL_SourceModule = CurrentModule = USER_MODULE; | 
					
						
							| 
									
										
										
										
											2016-06-17 16:25:43 +01:00
										 |  |  |   return YAP_QLY; | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-29 01:55:12 +01:00
										 |  |  | void Yap_InitQLYR(void) { | 
					
						
							|  |  |  |   Yap_InitCPred("$qload_module_preds", 1, p_read_module_preds, | 
					
						
							|  |  |  |                 SyncPredFlag | UserCPredFlag | HiddenPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("$qload_file_preds", 1, p_read_module_preds, | 
					
						
							|  |  |  |                 SyncPredFlag | HiddenPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("$qload_program", 1, qload_program, | 
					
						
							|  |  |  |                 SyncPredFlag | HiddenPredFlag); | 
					
						
							| 
									
										
										
										
											2016-05-10 08:33:44 +01:00
										 |  |  |     Yap_InitCPred("$q_header", 2, get_header, SyncPredFlag | HiddenPredFlag); | 
					
						
							| 
									
										
										
										
											2011-09-01 06:20:21 -07:00
										 |  |  |   if (FALSE) { | 
					
						
							|  |  |  |     restore_codes(); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | } |