| 
									
										
										
										
											2010-04-03 05:58:14 +01:00
										 |  |  | /************************************************************************
 | 
					
						
							|  |  |  | **                                                                     ** | 
					
						
							|  |  |  | **                   The YapTab/YapOr/OPTYap systems                   ** | 
					
						
							|  |  |  | **                                                                     ** | 
					
						
							|  |  |  | ** YapTab extends the Yap Prolog engine to support sequential tabling  ** | 
					
						
							|  |  |  | ** YapOr extends the Yap Prolog engine to support or-parallelism       ** | 
					
						
							|  |  |  | ** OPTYap extends the Yap Prolog engine to support or-parallel tabling ** | 
					
						
							|  |  |  | **                                                                     ** | 
					
						
							|  |  |  | **                                                                     ** | 
					
						
							|  |  |  | **      Yap Prolog was developed at University of Porto, Portugal      ** | 
					
						
							|  |  |  | **                                                                     ** | 
					
						
							|  |  |  | ************************************************************************/ | 
					
						
							| 
									
										
										
										
											2005-05-31 08:24:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #ifdef SCCS
 | 
					
						
							|  |  |  | static char     SccsId[] = "%W% %G%"; | 
					
						
							|  |  |  | #endif /* SCCS */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /************************************************************
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Unification Routines | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | *************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline | 
					
						
							|  |  |  | Int bind_variable(Term t0, Term t1) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   tr_fr_ptr TR0 = TR; | 
					
						
							| 
									
										
										
										
											2002-11-26 22:19:48 +00:00
										 |  |  |   if (Yap_IUnify(t0,t1)) { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     return(TRUE); | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     while(TR != TR0) { | 
					
						
							|  |  |  |       CELL *p = (CELL *)TrailTerm(--TR); | 
					
						
							|  |  |  |       RESET_VARIABLE(p); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return(FALSE); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | EXTERN inline | 
					
						
							|  |  |  | Int unify(Term t0, Term t1) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   tr_fr_ptr TR0 = TR; | 
					
						
							| 
									
										
										
										
											2002-11-26 22:19:48 +00:00
										 |  |  |   if (Yap_IUnify(t0,t1)) { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     return(TRUE); | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     while(TR != TR0) { | 
					
						
							|  |  |  |       CELL *p = (CELL *)TrailTerm(--TR); | 
					
						
							|  |  |  |       RESET_VARIABLE(p); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     return(FALSE); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | EXTERN inline Int unify_constant(register Term a, register Term cons) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   CELL *pt; | 
					
						
							| 
									
										
										
										
											2014-01-17 09:39:29 +00:00
										 |  |  |   CELL *pt0, *pt1; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   deref_head(a,unify_cons_unk); | 
					
						
							|  |  |  |  unify_cons_nonvar: | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     if (a == cons) return(TRUE); | 
					
						
							|  |  |  |     else if (IsApplTerm(a) && IsExtensionFunctor(FunctorOfTerm(a))) { | 
					
						
							|  |  |  |       Functor fun = FunctorOfTerm(a); | 
					
						
							| 
									
										
										
										
											2014-01-17 09:39:29 +00:00
										 |  |  |       if (!IsApplTerm(cons) || FunctorOfTerm(cons) != fun) | 
					
						
							|  |  |  | 	return FALSE; | 
					
						
							|  |  |  |       switch((CELL)fun) { | 
					
						
							|  |  |  |       case (CELL)FunctorDBRef: | 
					
						
							|  |  |  | 	return(pt0 == pt1); | 
					
						
							|  |  |  |       case (CELL)FunctorLongInt: | 
					
						
							|  |  |  | 	return(pt0[1] == pt1[1]); | 
					
						
							|  |  |  |       case (CELL)FunctorString: | 
					
						
							|  |  |  | 	return(strcmp( (const char *)(pt0+2),  (const char *)(pt1+2)) == 0); | 
					
						
							|  |  |  |       case (CELL)FunctorDouble: | 
					
						
							|  |  |  | 	return(FloatOfTerm(AbsAppl(pt0)) == FloatOfTerm(AbsAppl(pt1))); | 
					
						
							|  |  |  | #ifdef USE_GMP
 | 
					
						
							|  |  |  |       case (CELL)FunctorBigInt: | 
					
						
							|  |  |  | 	return(Yap_gmp_tcmp_big_big(AbsAppl(pt0),AbsAppl(pt0)) == 0); | 
					
						
							|  |  |  | #endif /* USE_GMP */
 | 
					
						
							|  |  |  |       default: | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	return(FALSE); | 
					
						
							| 
									
										
										
										
											2014-01-17 09:39:29 +00:00
										 |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     /* no other factors are accepted as arguments */ | 
					
						
							|  |  |  |     return(FALSE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |      | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   deref_body(a,pt,unify_cons_unk,unify_cons_nonvar); | 
					
						
							| 
									
										
										
										
											2014-05-29 11:32:28 +02:00
										 |  |  |   YapBind(pt,cons); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   return(TRUE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 |