| 
									
										
										
										
											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 <SWI-Stream.h>
 | 
					
						
							|  |  |  | #include "absmi.h"
 | 
					
						
							|  |  |  | #include "Foreign.h"
 | 
					
						
							|  |  |  | #include "alloc.h"
 | 
					
						
							|  |  |  | #include "yapio.h"
 | 
					
						
							|  |  |  | #include "iopreds.h"
 | 
					
						
							|  |  |  | #include "attvar.h"
 | 
					
						
							|  |  |  | #if HAVE_STRING_H
 | 
					
						
							|  |  |  | #include <string.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "qly.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-25 17:15:04 -05: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, | 
					
						
							|  |  |  |   BAD_READ = 11 | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  | } qlfr_err_t; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-18 14:29:41 +00: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" }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  | static char * | 
					
						
							|  |  |  | Yap_AlwaysAllocCodeSpace(UInt size) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   char *out; | 
					
						
							|  |  |  |   while (!(out = Yap_AllocCodeSpace(size))) { | 
					
						
							|  |  |  |     if (!Yap_growheap(FALSE, size, NULL)) { | 
					
						
							|  |  |  |       return NULL; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return out; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  | static void | 
					
						
							| 
									
										
										
										
											2011-10-21 19:12:21 +01:00
										 |  |  | QLYR_ERROR(qlfr_err_t my_err) | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2013-01-18 14:29:41 +00:00
										 |  |  |   Yap_Error(SAVED_STATE_ERROR,TermNil,"error %s in saved state %s",GLOBAL_RestoreFile, qlyr_error[my_err]);  | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |   exit(1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | static Atom | 
					
						
							|  |  |  | LookupAtom(Atom oat) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-09-21 15:30:29 +01:00
										 |  |  |  CACHE_REGS  | 
					
						
							|  |  |  |  CELL hash = (CELL)(oat) % LOCAL_ImportAtomHashTableSize; | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |  import_atom_hash_entry_t *a; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   a = LOCAL_ImportAtomHashChain[hash]; | 
					
						
							|  |  |  |   while (a) { | 
					
						
							|  |  |  |     if (a->oval == oat) { | 
					
						
							|  |  |  |       return a->val; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     a = a->next; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-10-21 19:12:21 +01:00
										 |  |  |   QLYR_ERROR(UNKNOWN_ATOM); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   return NIL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 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; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 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; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 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; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   f = (import_functor_hash_entry_t *)malloc(sizeof(import_functor_hash_entry_t)); | 
					
						
							|  |  |  |   if (!f) { | 
					
						
							|  |  |  |     return; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   f->val = fun; | 
					
						
							|  |  |  |   f->oval = ofun; | 
					
						
							|  |  |  |   f->next = LOCAL_ImportFunctorHashChain[hash]; | 
					
						
							|  |  |  |   LOCAL_ImportFunctorHashChain[hash] = f; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PredEntry * | 
					
						
							|  |  |  | LookupPredEntry(PredEntry *op) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-09-21 15:30:29 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   CELL hash = (CELL)(op) % LOCAL_ImportPredEntryHashTableSize; | 
					
						
							|  |  |  |   import_pred_entry_hash_entry_t *p; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   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; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | InsertPredEntry(PredEntry *op, PredEntry *pe) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-09-21 15:30:29 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   CELL hash = (CELL)(op) % LOCAL_ImportPredEntryHashTableSize; | 
					
						
							|  |  |  |   import_pred_entry_hash_entry_t *p; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   p = LOCAL_ImportPredEntryHashChain[hash]; | 
					
						
							|  |  |  |   while (p) { | 
					
						
							|  |  |  |     if (p->oval == op) { | 
					
						
							|  |  |  |       return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     p = p->next; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   p = (import_pred_entry_hash_entry_t *)malloc(sizeof(import_pred_entry_hash_entry_t)); | 
					
						
							|  |  |  |   if (!p) { | 
					
						
							|  |  |  |     return; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   p->val = pe; | 
					
						
							|  |  |  |   p->oval = op; | 
					
						
							|  |  |  |   p->next = LOCAL_ImportPredEntryHashChain[hash]; | 
					
						
							|  |  |  |   LOCAL_ImportPredEntryHashChain[hash] = p; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 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; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 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; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							| 
									
										
										
										
											2011-08-24 12:40:06 +01:00
										 |  |  | InsertOPCODE(OPCODE op0, int i, OPCODE op) | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											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; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  | static DBRef | 
					
						
							| 
									
										
										
										
											2012-06-12 14:50:36 +01:00
										 |  |  | LookupDBRef(DBRef dbr, int inc_ref) | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-09-21 15:30:29 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   CELL hash = (CELL)(dbr) % LOCAL_ImportDBRefHashTableSize; | 
					
						
							|  |  |  |   import_dbref_hash_entry_t *p; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   p = LOCAL_ImportDBRefHashChain[hash]; | 
					
						
							|  |  |  |   while (p) { | 
					
						
							|  |  |  |     if (p->oval == dbr) { | 
					
						
							| 
									
										
										
										
											2012-06-12 14:50:36 +01:00
										 |  |  |       if (inc_ref) { | 
					
						
							|  |  |  | 	p->count++; | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											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; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static LogUpdClause * | 
					
						
							|  |  |  | LookupMayFailDBRef(DBRef dbr) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-09-21 15:30:29 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   CELL hash = (CELL)(dbr) % LOCAL_ImportDBRefHashTableSize; | 
					
						
							|  |  |  |   import_dbref_hash_entry_t *p; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   p = LOCAL_ImportDBRefHashChain[hash]; | 
					
						
							|  |  |  |   while (p) { | 
					
						
							|  |  |  |     if (p->oval == dbr) { | 
					
						
							|  |  |  |       p->count++; | 
					
						
							|  |  |  |       return (LogUpdClause *)p->val; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     p = p->next; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return NULL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 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; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03: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; | 
					
						
							|  |  |  |   LOCAL_ImportOPCODEHashChain = (import_opcode_hash_entry_t **)calloc(1, sizeof(import_opcode_hash_entry_t *)* LOCAL_ImportOPCODEHashTableSize); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | CloseHash(void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-09-21 15:30:29 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   UInt i; | 
					
						
							|  |  |  |   for (i=0; i < LOCAL_ImportFunctorHashTableSize; i++) { | 
					
						
							|  |  |  |     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; | 
					
						
							|  |  |  |   for (i=0; i < LOCAL_ImportAtomHashTableSize; i++) { | 
					
						
							|  |  |  |     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; | 
					
						
							|  |  |  |   for (i=0; i < LOCAL_ImportOPCODEHashTableSize; i++) { | 
					
						
							|  |  |  |     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; | 
					
						
							|  |  |  |   for (i=0; i < LOCAL_ImportPredEntryHashTableSize; i++) { | 
					
						
							|  |  |  |     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; | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   for (i=0; i < LOCAL_ImportDBRefHashTableSize; i++) { | 
					
						
							|  |  |  |     import_dbref_hash_entry_t *a = LOCAL_ImportDBRefHashChain[i]; | 
					
						
							|  |  |  |     while (a) { | 
					
						
							|  |  |  |       import_dbref_hash_entry_t *a0 = a; | 
					
						
							|  |  |  | #ifdef DEBUG
 | 
					
						
							|  |  |  |       if (!a->count) { | 
					
						
							| 
									
										
										
										
											2012-08-23 09:04:58 -05: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
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline Atom | 
					
						
							|  |  |  | AtomAdjust(Atom a) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return LookupAtom(a); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline Functor | 
					
						
							|  |  |  | FuncAdjust(Functor f) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return LookupFunctor(f); | 
					
						
							|  |  |  |   return f; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline Term | 
					
						
							|  |  |  | AtomTermAdjust(Term t) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return MkAtomTerm(LookupAtom(AtomOfTerm(t))); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline Term | 
					
						
							|  |  |  | TermToGlobalOrAtomAdjust(Term t) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   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))
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define REINIT_LOCK(P) 
 | 
					
						
							|  |  |  | #define REINIT_RWLOCK(P) 
 | 
					
						
							|  |  |  | #define BlobTypeAdjust(P) (P)
 | 
					
						
							|  |  |  | #define NoAGCAtomAdjust(P) (P)
 | 
					
						
							|  |  |  | #define OrArgAdjust(P) 
 | 
					
						
							|  |  |  | #define TabEntryAdjust(P) 
 | 
					
						
							|  |  |  | #define IntegerAdjust(D)  (D)
 | 
					
						
							|  |  |  | #define AddrAdjust(P) (P)
 | 
					
						
							|  |  |  | #define MFileAdjust(P) (P)
 | 
					
						
							| 
									
										
										
										
											2011-08-25 03:20:20 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define CodeVarAdjust(P) CodeVarAdjust__(P PASS_REGS)
 | 
					
						
							|  |  |  | static inline Term | 
					
						
							|  |  |  | CodeVarAdjust__ (Term var USES_REGS) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   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)
 | 
					
						
							|  |  |  | #define DoubleInCodeAdjust(P) 
 | 
					
						
							|  |  |  | #define IntegerInCodeAdjust(Pxb) 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline PredEntry * | 
					
						
							|  |  |  | PtoPredAdjust(PredEntry *p) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return LookupPredEntry(p); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-24 12:40:06 +01:00
										 |  |  | static inline PredEntry * | 
					
						
							|  |  |  | PredEntryAdjust(PredEntry *p) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return LookupPredEntry(p); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | static inline OPCODE | 
					
						
							|  |  |  | OpcodeAdjust(OPCODE OP) { | 
					
						
							|  |  |  |   return LookupOPCODE(OP); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline Term | 
					
						
							|  |  |  | ModuleAdjust(Term M) { | 
					
						
							|  |  |  |   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
 | 
					
						
							|  |  |  | static inline Term | 
					
						
							|  |  |  | BlobTermInCodeAdjust__ (Term t USES_REGS) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (Term) ((char *)(t) - LOCAL_HDiff); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | static inline Term | 
					
						
							|  |  |  | BlobTermInCodeAdjust__ (Term t USES_REGS) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (Term) ((char *)(t) + LOCAL_HDiff); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2011-08-25 03:20:20 +01:00
										 |  |  | #define DBTermAdjust(P) DBTermAdjust__(P PASS_REGS)
 | 
					
						
							|  |  |  | static inline DBTerm * | 
					
						
							|  |  |  | DBTermAdjust__ (DBTerm * dbtp USES_REGS) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-08-31 14:10:31 -07:00
										 |  |  |   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)
 | 
					
						
							|  |  |  | static inline CELL * | 
					
						
							|  |  |  | CellPtoHeapAdjust__ (CELL * dbtp USES_REGS) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (CELL *) (CharP (dbtp) + LOCAL_HDiff); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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)
 | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  | static inline DBRef | 
					
						
							| 
									
										
										
										
											2012-06-12 14:50:36 +01:00
										 |  |  | DBRefAdjust__ (DBRef dbtp, int do_reference USES_REGS) | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											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)
 | 
					
						
							|  |  |  | static inline DBRef * | 
					
						
							|  |  |  | DBRefPAdjust__ (DBRef * dbtp USES_REGS) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (DBRef *) ((char *)(dbtp) + LOCAL_HDiff); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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)
 | 
					
						
							|  |  |  | static inline LogUpdClause * | 
					
						
							|  |  |  | PtoLUCAdjust__ (LogUpdClause * dbtp USES_REGS) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (LogUpdClause *) ((char *)(dbtp) + LOCAL_HDiff); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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)
 | 
					
						
							|  |  |  | 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; | 
					
						
							| 
									
										
										
										
											2011-08-31 14:10:31 -07: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; | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03: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)
 | 
					
						
							|  |  |  | static inline wamreg | 
					
						
							|  |  |  | XAdjust__ (wamreg reg USES_REGS) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (wamreg) ((wamreg) ((reg) + LOCAL_XDiff)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define XAdjust(X) (X)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #define YAdjust(X) (X)
 | 
					
						
							|  |  |  | #define HoldEntryAdjust(P) (P)
 | 
					
						
							|  |  |  | #define CodeCharPAdjust(P) (P)
 | 
					
						
							|  |  |  | #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)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "rheap.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | RestoreHashPreds( USES_REGS1 ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | RestoreAtomList(Atom atm USES_REGS) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static size_t | 
					
						
							|  |  |  | read_bytes(IOSTREAM *stream, void *ptr, size_t sz) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-09-02 15:37:47 +01:00
										 |  |  |   return Sfread(ptr, sz, 1, stream); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static unsigned char | 
					
						
							|  |  |  | read_byte(IOSTREAM *stream) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   return  Sgetc(stream); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  | static BITS16 | 
					
						
							|  |  |  | read_bits16(IOSTREAM *stream) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   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; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | static UInt | 
					
						
							|  |  |  | read_uint(IOSTREAM *stream) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   UInt v; | 
					
						
							|  |  |  |   read_bytes(stream, &v, sizeof(UInt)); | 
					
						
							|  |  |  |   return v; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int | 
					
						
							|  |  |  | read_int(IOSTREAM *stream) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   int v; | 
					
						
							|  |  |  |   read_bytes(stream, &v, sizeof(int)); | 
					
						
							|  |  |  |   return v; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static qlf_tag_t | 
					
						
							|  |  |  | read_tag(IOSTREAM *stream) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   int ch = read_byte(stream); | 
					
						
							|  |  |  |   return ch; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  | static void | 
					
						
							|  |  |  | read_header(IOSTREAM *stream) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   int ch; | 
					
						
							|  |  |  |   while ((ch = read_byte(stream))); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | static void | 
					
						
							|  |  |  | ReadHash(IOSTREAM *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); | 
					
						
							|  |  |  |   LOCAL_XDiff = (char *)(&ARG1) - (char *)read_uint(stream); | 
					
						
							|  |  |  |   RCHECK(read_tag(stream) == QLY_START_OPCODES); | 
					
						
							|  |  |  |   RCHECK(read_int(stream) == _std_top); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   for (i= 0; i <= _std_top; i++) { | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |     InsertOPCODE((OPCODE)read_uint(stream), i, Yap_opcode(i)); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   RCHECK(read_tag(stream) == QLY_START_ATOMS); | 
					
						
							|  |  |  |   LOCAL_ImportAtomHashTableNum = read_uint(stream); | 
					
						
							| 
									
										
										
										
											2012-08-22 18:57:13 -05:00
										 |  |  |   LOCAL_ImportAtomHashTableSize = LOCAL_ImportAtomHashTableNum*2; | 
					
						
							| 
									
										
										
										
											2012-08-23 09:04:58 -05:00
										 |  |  |   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++) { | 
					
						
							|  |  |  |     Atom oat = (Atom)read_uint(stream); | 
					
						
							|  |  |  |     Atom at; | 
					
						
							|  |  |  |     qlf_tag_t tg = read_tag(stream); | 
					
						
							|  |  |  |        | 
					
						
							|  |  |  |     if (tg == QLY_ATOM_WIDE) { | 
					
						
							|  |  |  |       wchar_t *rep = (wchar_t *)AllocTempSpace(); | 
					
						
							|  |  |  |       UInt len; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       len = read_uint(stream); | 
					
						
							| 
									
										
										
										
											2011-10-21 19:12:21 +01:00
										 |  |  |       if (!EnoughTempSpace(len)) QLYR_ERROR(OUT_OF_TEMP_SPACE); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |       read_bytes(stream, rep, (len+1)*sizeof(wchar_t)); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |       while (!(at = Yap_LookupWideAtom(rep))) { | 
					
						
							|  |  |  | 	if (!Yap_growheap(FALSE, 0, NULL)) { | 
					
						
							|  |  |  | 	  exit(1); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2011-10-21 19:12:21 +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; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       len = read_uint(stream); | 
					
						
							| 
									
										
										
										
											2011-10-21 19:12:21 +01:00
										 |  |  |       if (!EnoughTempSpace(len)) QLYR_ERROR(OUT_OF_TEMP_SPACE); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |       read_bytes(stream, rep, (len+1)*sizeof(char)); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |       while (!(at = Yap_FullLookupAtom(rep))) { | 
					
						
							|  |  |  | 	if (!Yap_growheap(FALSE, 0, NULL)) { | 
					
						
							|  |  |  | 	  exit(1); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2011-10-21 19:12:21 +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); | 
					
						
							|  |  |  |   LOCAL_ImportFunctorHashTableNum = read_uint(stream); | 
					
						
							| 
									
										
										
										
											2012-08-22 18:57:13 -05:00
										 |  |  |   LOCAL_ImportFunctorHashTableSize = 2*LOCAL_ImportFunctorHashTableNum; | 
					
						
							| 
									
										
										
										
											2012-08-23 09:04:58 -05:00
										 |  |  |   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++) { | 
					
						
							|  |  |  |     Functor of = (Functor)read_uint(stream); | 
					
						
							|  |  |  |     UInt arity = read_uint(stream); | 
					
						
							|  |  |  |     Atom oat = (Atom)read_uint(stream); | 
					
						
							|  |  |  |     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)) { | 
					
						
							|  |  |  | 	exit(1); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |     InsertFunctor(of, f); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   RCHECK(read_tag(stream) == QLY_START_PRED_ENTRIES); | 
					
						
							|  |  |  |   LOCAL_ImportPredEntryHashTableNum = read_uint(stream); | 
					
						
							| 
									
										
										
										
											2012-08-22 18:57:13 -05:00
										 |  |  |   LOCAL_ImportPredEntryHashTableSize = 2*LOCAL_ImportPredEntryHashTableNum; | 
					
						
							| 
									
										
										
										
											2012-08-23 09:04:58 -05:00
										 |  |  |   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++) { | 
					
						
							|  |  |  |     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; | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  |     if (omod) { | 
					
						
							|  |  |  |       mod = MkAtomTerm(AtomAdjust(omod)); | 
					
						
							|  |  |  |       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) { | 
					
						
							|  |  |  | 	Functor of = (Functor)read_uint(stream); | 
					
						
							|  |  |  | 	Functor f = LookupFunctor(of); | 
					
						
							| 
									
										
										
										
											2011-09-07 08:03:46 +02:00
										 |  |  | 	while(!(pe = RepPredProp(PredPropByFuncAndMod(f,mod)))) { | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  | 	  if (!Yap_growheap(FALSE, 0, NULL)) { | 
					
						
							|  |  |  | 	    exit(1); | 
					
						
							|  |  |  | 	  } | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |       } else { | 
					
						
							|  |  |  | 	Atom oa = (Atom)read_uint(stream); | 
					
						
							|  |  |  | 	Atom a = LookupAtom(oa); | 
					
						
							| 
									
										
										
										
											2011-09-07 08:03:46 +02:00
										 |  |  | 	pe = RepPredProp(PredPropByAtomAndMod(a,mod)); | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |       if (arity == (UInt)-1) { | 
					
						
							|  |  |  | 	UInt i = read_uint(stream); | 
					
						
							|  |  |  | 	pe = Yap_FindLUIntKey(i); | 
					
						
							|  |  |  |       }	else if (arity == (UInt)(-2)) { | 
					
						
							|  |  |  | 	Atom oa = (Atom)read_uint(stream); | 
					
						
							|  |  |  | 	Atom a = LookupAtom(oa); | 
					
						
							| 
									
										
										
										
											2011-09-07 08:03:46 +02:00
										 |  |  | 	pe = RepPredProp(PredPropByAtomAndMod(a,mod)); | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |       } else { | 
					
						
							|  |  |  | 	Functor of = (Functor)read_uint(stream); | 
					
						
							|  |  |  | 	Functor f = LookupFunctor(of); | 
					
						
							| 
									
										
										
										
											2011-09-07 08:03:46 +02:00
										 |  |  | 	pe = RepPredProp(PredPropByFuncAndMod(f,mod)); | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2011-09-07 08:03:46 +02:00
										 |  |  |       pe->ArityOfPE = 3; | 
					
						
							| 
									
										
										
										
											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); | 
					
						
							|  |  |  |   LOCAL_ImportDBRefHashTableNum = read_uint(stream); | 
					
						
							| 
									
										
										
										
											2012-08-22 18:57:13 -05:00
										 |  |  |   LOCAL_ImportDBRefHashTableSize = 2*LOCAL_ImportDBRefHashTableNum; | 
					
						
							| 
									
										
										
										
											2012-08-23 09:04:58 -05:00
										 |  |  |   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++) { | 
					
						
							|  |  |  |     LogUpdClause *ocl = (LogUpdClause *)read_uint(stream); | 
					
						
							|  |  |  |     UInt sz = read_uint(stream); | 
					
						
							|  |  |  |     UInt nrefs = read_uint(stream); | 
					
						
							|  |  |  |     LogUpdClause *ncl = (LogUpdClause *)Yap_AlwaysAllocCodeSpace(sz); | 
					
						
							| 
									
										
										
										
											2012-08-23 21:01:32 +01:00
										 |  |  |     if (!ncl) { | 
					
						
							|  |  |  |       QLYR_ERROR(OUT_OF_CODE_SPACE);	 | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |     ncl->Id = FunctorDBRef; | 
					
						
							|  |  |  |     ncl->ClRefCount = nrefs; | 
					
						
							|  |  |  |     InsertDBRef((DBRef)ocl,(DBRef)ncl); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   RCHECK(read_tag(stream) == QLY_FAILCODE); | 
					
						
							|  |  |  |   LOCAL_ImportFAILCODE = (yamop *)read_uint(stream); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | read_clauses(IOSTREAM *stream, PredEntry *pp, UInt nclauses, UInt flags) { | 
					
						
							| 
									
										
										
										
											2011-09-21 15:30:29 +01:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   if (pp->PredFlags & 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 { | 
					
						
							|  |  |  | 	LogUpdClause *ncl = cl->ClNext; | 
					
						
							|  |  |  | 	Yap_ErLogUpdCl(cl); | 
					
						
							|  |  |  | 	cl = ncl; | 
					
						
							|  |  |  |       } while (cl != NULL); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |     if (!nclauses) { | 
					
						
							|  |  |  |       return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     while ((read_tag(stream) == QLY_START_LU_CLAUSE)) { | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03: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))) { | 
					
						
							|  |  |  | 	nrefs = cl->ClRefCount; | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  | 	cl = (LogUpdClause *)Yap_AlwaysAllocCodeSpace(size); | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											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; | 
					
						
							|  |  |  |       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); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } else if (pp->PredFlags & MegaClausePredFlag) { | 
					
						
							|  |  |  |     CACHE_REGS | 
					
						
							|  |  |  |     char *base = (void *)read_uint(stream); | 
					
						
							| 
									
										
										
										
											2013-01-11 18:36:34 +00:00
										 |  |  |     UInt mask = read_uint(stream); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |     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); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |     LOCAL_HDiff = (char *)cl-base; | 
					
						
							|  |  |  |     read_bytes(stream, cl, size); | 
					
						
							| 
									
										
										
										
											2013-01-11 18:36:34 +00:00
										 |  |  |     cl->ClFlags = mask; | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03: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 */ | 
					
						
							| 
									
										
										
										
											2013-01-11 18:36:34 +00:00
										 |  |  |     if (mask & ExoMask) {  | 
					
						
							|  |  |  |       struct index_t **icl = (struct index_t **)(cl->ClCode);  | 
					
						
							|  |  |  |       pp->OpcodeOfPred = Yap_opcode(_enter_exo); | 
					
						
							|  |  |  |       icl[0] = NULL; | 
					
						
							|  |  |  |       icl[1] = NULL; | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       pp->OpcodeOfPred = INDEX_OPCODE; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-08-31 21:13:29 -07:00
										 |  |  |     pp->CodeOfPred = pp->cs.p_code.TrueCodeOfPred = (yamop *)(&(pp->OpcodeOfPred));  | 
					
						
							|  |  |  |     /* This must be set for restoremegaclause */ | 
					
						
							|  |  |  |     pp->cs.p_code.NOfClauses = nclauses; | 
					
						
							|  |  |  |     RestoreMegaClause(cl PASS_REGS); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   } else if (pp->PredFlags & DynamicPredFlag) { | 
					
						
							|  |  |  |     UInt i; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (i = 0; i < nclauses; i++) { | 
					
						
							|  |  |  |       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); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |      | 
					
						
							|  |  |  |       LOCAL_HDiff = (char *)cl-base; | 
					
						
							|  |  |  |       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; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |     if (pp->PredFlags & SYSTEM_PRED_FLAGS) { | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |       if (nclauses) { | 
					
						
							| 
									
										
										
										
											2011-10-21 19:12:21 +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++) { | 
					
						
							|  |  |  |       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
										 |  |  | 
 | 
					
						
							|  |  |  |       LOCAL_HDiff = (char *)cl-base; | 
					
						
							|  |  |  |       read_bytes(stream, cl, size); | 
					
						
							|  |  |  |       RestoreStaticClause(cl PASS_REGS); | 
					
						
							|  |  |  |       Yap_AssertzClause(pp, cl->ClCode); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | read_pred(IOSTREAM *stream, Term mod) { | 
					
						
							| 
									
										
										
										
											2011-09-07 08:03:46 +02:00
										 |  |  |   UInt flags; | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   UInt nclauses, fl1; | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   PredEntry *ap; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-07 08:03:46 +02:00
										 |  |  |   ap = LookupPredEntry((PredEntry *)read_uint(stream)); | 
					
						
							|  |  |  |   flags = read_uint(stream); | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   nclauses = read_uint(stream); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   if (ap->PredFlags & IndexedPredFlag) { | 
					
						
							|  |  |  |     Yap_RemoveIndexation(ap); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   fl1 = flags & STATIC_PRED_FLAGS; | 
					
						
							|  |  |  |   ap->PredFlags &= ~STATIC_PRED_FLAGS; | 
					
						
							| 
									
										
										
										
											2011-08-25 03:20:20 +01:00
										 |  |  |   ap->PredFlags |= fl1; | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |   if (flags & NumberDBPredFlag) { | 
					
						
							|  |  |  |     ap->src.IndxId = read_uint(stream); | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     ap->src.OwnerFile = (Atom)read_uint(stream); | 
					
						
							| 
									
										
										
										
											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); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2012-08-23 21:01:32 +01:00
										 |  |  |   ap->TimeStampOfPred = read_uint(stream); | 
					
						
							| 
									
										
										
										
											2011-09-07 22:04:42 +02:00
										 |  |  |   /* multifile predicates cannot reside in module 0 */ | 
					
						
							|  |  |  |   if (flags & MultiFileFlag && ap->ModuleOfPred == PROLOG_MODULE) | 
					
						
							|  |  |  |     ap->ModuleOfPred = TermProlog; | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   read_clauses(stream, ap, nclauses, flags); | 
					
						
							| 
									
										
										
										
											2012-10-19 18:10:48 +01:00
										 |  |  |   if (flags & HiddenPredFlag) { | 
					
						
							|  |  |  |     Yap_HidePred(ap); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  | static void | 
					
						
							|  |  |  | read_ops(IOSTREAM *stream)  { | 
					
						
							|  |  |  |   Int x; | 
					
						
							|  |  |  |   while ((x = read_tag(stream)) != QLY_END_OPS) { | 
					
						
							|  |  |  |     Atom at = (Atom)read_uint(stream); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |     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); | 
					
						
							|  |  |  |     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
										 |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | static void | 
					
						
							| 
									
										
										
										
											2011-08-24 12:40:06 +01:00
										 |  |  | read_module(IOSTREAM *stream) { | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   qlf_tag_t x; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  |   InitHash(); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   read_header(stream); | 
					
						
							| 
									
										
										
										
											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) { | 
					
						
							|  |  |  |     Term mod = (Term)read_uint(stream); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     mod = MkAtomTerm(AtomAdjust(AtomOfTerm(mod))); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |     if (mod) | 
					
						
							| 
									
										
										
										
											2011-08-27 21:23:14 -03:00
										 |  |  |     while ((x = read_tag(stream)) == QLY_START_PREDICATE) { | 
					
						
							|  |  |  |       read_pred(stream, mod); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											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(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static Int | 
					
						
							|  |  |  | p_read_module_preds( USES_REGS1 ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   IOSTREAM *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)) { | 
					
						
							|  |  |  |     Yap_Error(INSTANTIATION_ERROR,t1,"read_qly/3"); | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (!IsAtomTerm(t1)) { | 
					
						
							|  |  |  |     Yap_Error(TYPE_ERROR_ATOM,t1,"read_qly/3"); | 
					
						
							|  |  |  |     return(FALSE); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (!(stream = Yap_GetInputStream(AtomOfTerm(t1))) ) { | 
					
						
							| 
									
										
										
										
											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; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-15 00:01:02 +01:00
										 |  |  | static void | 
					
						
							| 
									
										
										
										
											2012-09-21 11:49:59 +01:00
										 |  |  | ReInitProlog(void) | 
					
						
							| 
									
										
										
										
											2012-04-15 00:01:02 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-09-21 11:49:59 +01:00
										 |  |  |   Term t = MkAtomTerm(AtomInitProlog); | 
					
						
							|  |  |  | #if defined(YAPOR) || defined(TABLING)
 | 
					
						
							|  |  |  |   Yap_init_root_frames(); | 
					
						
							|  |  |  | #endif /* YAPOR || TABLING */
 | 
					
						
							| 
									
										
										
										
											2012-12-11 22:07:10 +00:00
										 |  |  |   Yap_InitYaamRegs( 0 ); | 
					
						
							| 
									
										
										
										
											2012-04-15 00:01:02 +01:00
										 |  |  |   YAP_RunGoalOnce(t); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  | static Int | 
					
						
							|  |  |  | p_read_program( USES_REGS1 ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   IOSTREAM *stream; | 
					
						
							|  |  |  |   void YAP_Reset(void); | 
					
						
							| 
									
										
										
										
											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)) { | 
					
						
							|  |  |  |     Yap_Error(INSTANTIATION_ERROR,t1,"read_program/3"); | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (!IsAtomTerm(t1)) { | 
					
						
							|  |  |  |     Yap_Error(TYPE_ERROR_ATOM,t1,"read_program/3"); | 
					
						
							|  |  |  |     return(FALSE); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (!(stream = Yap_GetInputStream(AtomOfTerm(t1))) ) { | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |     return FALSE; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   YAP_Reset(); | 
					
						
							|  |  |  |   read_module(stream); | 
					
						
							|  |  |  |   Sclose( stream ); | 
					
						
							|  |  |  |   /* back to the top level we go */ | 
					
						
							| 
									
										
										
										
											2011-09-21 15:30:29 +01:00
										 |  |  |   Yap_CloseSlots(PASS_REGS1); | 
					
						
							| 
									
										
										
										
											2012-09-21 11:49:59 +01:00
										 |  |  |   ReInitProlog(); | 
					
						
							| 
									
										
										
										
											2012-02-05 12:04:29 +00:00
										 |  |  |   Yap_RestartYap( 3 ); | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   return TRUE; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int  | 
					
						
							|  |  |  | Yap_Restore(char *s, char *lib_dir) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   IOSTREAM *stream  = Yap_OpenRestore(s, lib_dir); | 
					
						
							|  |  |  |   if (!stream)  | 
					
						
							|  |  |  |     return -1; | 
					
						
							| 
									
										
										
										
											2013-01-18 14:29:41 +00:00
										 |  |  |   GLOBAL_RestoreFile = s; | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   read_module(stream); | 
					
						
							|  |  |  |   Sclose( stream ); | 
					
						
							| 
									
										
										
										
											2013-01-18 14:29:41 +00:00
										 |  |  |   GLOBAL_RestoreFile = NULL; | 
					
						
							| 
									
										
										
										
											2011-08-31 13:59:30 -07:00
										 |  |  |   return DO_ONLY_CODE; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | void Yap_InitQLYR(void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-10-19 18:10:48 +01:00
										 |  |  |   Yap_InitCPred("$qload_module_preds", 1, p_read_module_preds, SyncPredFlag|UserCPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("$qload_program", 1, p_read_program, SyncPredFlag|UserCPredFlag); | 
					
						
							| 
									
										
										
										
											2011-09-01 06:20:21 -07:00
										 |  |  |   if (FALSE) { | 
					
						
							|  |  |  |     restore_codes(); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-08-24 00:11:54 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 |