| 
									
										
										
										
											2014-05-12 17:49:11 +01:00
										 |  |  | /*************************************************************************
 | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | *	 YAP Prolog 							 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | *	Yap Prolog was developed at NCCUP - Universidade do Porto	 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | * Copyright L.Damas, V.S.Costa and Universidade do Porto 1985-2014	 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | *************************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2015-01-04 23:58:23 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     @{ | 
					
						
							| 
									
										
										
										
											2015-04-13 13:28:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-04 23:58:23 +00:00
										 |  |  |     @file swi.h | 
					
						
							| 
									
										
										
										
											2014-05-12 17:49:11 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |   @defgroup swi-c-interface SWI-Prolog Foreign Language Interface | 
					
						
							| 
									
										
										
										
											2014-09-11 14:06:57 -05:00
										 |  |  |   @ingroup ChYInterface | 
					
						
							| 
									
										
										
										
											2014-05-12 17:49:11 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-05-14 10:01:11 +01:00
										 |  |  |  * | 
					
						
							|  |  |  |  *    @tableofcontents | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * A reimplementation of Jan Wielemaker's SWI-Prolog C-language interface, it supports | 
					
						
							|  |  |  |  * most of the functionality in the original implementation. It allows for: | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *   - Term Construction, Access, and Unification | 
					
						
							|  |  |  |  *   - Manipulation of Atoms, Strings, Lists of Codes and Lists of Atoms | 
					
						
							|  |  |  |  *   - Query evaluation | 
					
						
							|  |  |  |  *   - Thread and Prolog engine management | 
					
						
							|  |  |  |  *   - Data-Base Access | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * In this interface, all Prolog data known by C is referenced through term references (term_t), hence | 
					
						
							|  |  |  |  * Prolog has all the information necessary to perform its memory management without special precautions | 
					
						
							|  |  |  |  *  from the C programmer. | 
					
						
							| 
									
										
										
										
											2014-05-12 17:49:11 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2010-11-30 21:59:45 +00:00
										 |  |  | void Yap_swi_install(void); | 
					
						
							|  |  |  | void Yap_install_blobs(void); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define addr_hash(V) (((CELL) (V)) >> 4 & (N_SWI_HASH-1))
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline void | 
					
						
							|  |  |  | add_to_hash(Int i, ADDR key) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2013-10-04 13:22:00 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-30 21:59:45 +00:00
										 |  |  |   UInt h = addr_hash(key); | 
					
						
							|  |  |  |   while (SWI_ReverseHash[h].key) { | 
					
						
							|  |  |  |     h = (h+1)%N_SWI_HASH; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   SWI_ReverseHash[h].key = key; | 
					
						
							|  |  |  |   SWI_ReverseHash[h].pos = i; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static atom_t | 
					
						
							|  |  |  | in_hash(ADDR key) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   UInt h = addr_hash(key); | 
					
						
							|  |  |  |   while (SWI_ReverseHash[h].key) { | 
					
						
							|  |  |  |     if (SWI_ReverseHash[h].key == key) | 
					
						
							|  |  |  |       return SWI_ReverseHash[h].pos; | 
					
						
							|  |  |  |     h = (h+1)%N_SWI_HASH; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline Term | 
					
						
							|  |  |  | SWIModuleToModule(module_t m) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2010-11-30 21:59:45 +00:00
										 |  |  |   if (m) | 
					
						
							| 
									
										
										
										
											2013-11-13 10:38:20 +00:00
										 |  |  |     return MkAtomTerm(m->AtomOfME); | 
					
						
							| 
									
										
										
										
											2010-11-30 21:59:45 +00:00
										 |  |  |   if (CurrentModule) | 
					
						
							|  |  |  |     return CurrentModule; | 
					
						
							|  |  |  |   return USER_MODULE; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline functor_t | 
					
						
							|  |  |  | FunctorToSWIFunctor(Functor at) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   atom_t ats; | 
					
						
							|  |  |  |   if ((ats = in_hash((ADDR)at))) | 
					
						
							| 
									
										
										
										
											2010-12-02 19:38:15 +00:00
										 |  |  |     return (functor_t)((CELL)ats*4+2); | 
					
						
							| 
									
										
										
										
											2010-11-30 21:59:45 +00:00
										 |  |  |   return (functor_t)at; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-11-21 00:22:03 +00:00
										 |  |  | #define isDefinedProcedure(pred) TRUE // TBD
 | 
					
						
							| 
									
										
										
										
											2014-05-14 10:01:11 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |   @} | 
					
						
							|  |  |  | */ |