| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | /*************************************************************************
 | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | *	 YAP Prolog 	%W% %G% 					 * | 
					
						
							|  |  |  | *	Yap Prolog was developed at NCCUP - Universidade do Porto	 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | * Copyright L.Damas, V.S.Costa and Universidade do Porto 1985-1997	 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | ************************************************************************** | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | * File:		TermExt.h						 * | 
					
						
							|  |  |  | * mods:									 * | 
					
						
							|  |  |  | * comments:	Extensions to standard terms for YAP			 * | 
					
						
							| 
									
										
										
										
											2008-03-25 22:03:14 +00:00
										 |  |  | * version:      $Id: TermExt.h,v 1.15 2008-03-25 22:03:13 vsc Exp $	 * | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | *************************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef USE_SYSTEM_MALLOC
 | 
					
						
							|  |  |  | #define SF_STORE  (&(Yap_heap_regs->funcs))
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define SF_STORE  ((special_functors *)HEAP_INIT_BASE)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-25 22:03:14 +00:00
										 |  |  | #ifdef USE_OFFSETS
 | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | #define   AtomFoundVar ((Atom)(&(((special_functors *)(NULL))->AtFoundVar)))
 | 
					
						
							| 
									
										
										
										
											2005-09-09 17:24:39 +00:00
										 |  |  | #define   AtomFreeTerm ((Atom)(&(((special_functors *)(NULL))->AtFreeTerm)))
 | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | #define   AtomNil ((Atom)(&(((special_functors *)(NULL))->AtNil)))
 | 
					
						
							|  |  |  | #define   AtomDot ((Atom)(&(((special_functors *)(NULL))->AtDot)))
 | 
					
						
							| 
									
										
										
										
											2008-03-25 22:03:14 +00:00
										 |  |  | #elif defined(THREADS)
 | 
					
						
							| 
									
										
										
										
											2005-11-23 03:01:33 +00:00
										 |  |  | #define   AtomFoundVar AbsAtom(SF_STORE->AtFoundVar)
 | 
					
						
							|  |  |  | #define   AtomFreeTerm AbsAtom(SF_STORE->AtFreeTerm)
 | 
					
						
							|  |  |  | #define   AtomNil AbsAtom(SF_STORE->AtNil)
 | 
					
						
							|  |  |  | #define   AtomDot AbsAtom(SF_STORE->AtDot)
 | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | #define   AtomFoundVar AbsAtom(&(SF_STORE->AtFoundVar))
 | 
					
						
							| 
									
										
										
										
											2005-09-09 17:24:39 +00:00
										 |  |  | #define   AtomFreeTerm AbsAtom(&(SF_STORE->AtFreeTerm))
 | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | #define   AtomNil AbsAtom(&(SF_STORE->AtNil))
 | 
					
						
							|  |  |  | #define   AtomDot AbsAtom(&(SF_STORE->AtDot))
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define   TermFoundVar MkAtomTerm(AtomFoundVar)
 | 
					
						
							| 
									
										
										
										
											2005-09-09 17:24:39 +00:00
										 |  |  | #define   TermFreeTerm MkAtomTerm(AtomFreeTerm)
 | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | #define   TermNil MkAtomTerm(AtomNil)
 | 
					
						
							|  |  |  | #define   TermDot MkAtomTerm(AtomDot)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef enum | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   db_ref_e = sizeof (Functor *), | 
					
						
							| 
									
										
										
										
											2010-03-06 22:34:49 +00:00
										 |  |  |   attvar_e = 2*sizeof (Functor *), | 
					
						
							|  |  |  |   long_int_e = 3 * sizeof (Functor *), | 
					
						
							|  |  |  |   big_int_e = 4 * sizeof (Functor *), | 
					
						
							|  |  |  |   double_e = 5 * sizeof (Functor *) | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | } | 
					
						
							|  |  |  | blob_type; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define   FunctorDBRef    ((Functor)(db_ref_e))
 | 
					
						
							| 
									
										
										
										
											2010-03-06 22:34:49 +00:00
										 |  |  | #define   FunctorAttVar   ((Functor)(attvar_e))
 | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | #define   FunctorLongInt  ((Functor)(long_int_e))
 | 
					
						
							|  |  |  | #define   FunctorBigInt   ((Functor)(big_int_e))
 | 
					
						
							|  |  |  | #define   FunctorDouble   ((Functor)(double_e))
 | 
					
						
							| 
									
										
										
										
											2006-08-22 16:12:46 +00:00
										 |  |  | #define   EndSpecials     (double_e+sizeof(Functor *))
 | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-03 07:55:42 +09:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-08 09:24:11 +00:00
										 |  |  | inline EXTERN int IsAttVar (CELL *pt); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN int | 
					
						
							|  |  |  | IsAttVar (CELL *pt) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-11-10 12:26:23 +00:00
										 |  |  | #ifdef YAP_H
 | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2011-11-03 07:55:42 +09:00
										 |  |  |   return (pt)[-1] == (CELL)attvar_e | 
					
						
							|  |  |  |     && pt < H; | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |   return (pt)[-1] == (CELL)attvar_e; | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2010-03-08 09:24:11 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-19 10:25:23 +00:00
										 |  |  | inline EXTERN int GlobalIsAttVar (CELL *pt); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-18 19:34:58 +00:00
										 |  |  | inline EXTERN int | 
					
						
							| 
									
										
										
										
											2011-03-19 10:25:23 +00:00
										 |  |  | GlobalIsAttVar (CELL *pt) | 
					
						
							| 
									
										
										
										
											2011-03-18 19:34:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  |   return (pt)[-1] == (CELL)attvar_e; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-28 15:54:46 +00:00
										 |  |  | typedef enum | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     BIG_INT =      0x01, | 
					
						
							|  |  |  |     BIG_RATIONAL = 0x02, | 
					
						
							|  |  |  |     BIG_FLOAT =    0x04, | 
					
						
							|  |  |  |     EMPTY_ARENA =  0x10, | 
					
						
							|  |  |  |     ARRAY_INT =    0x21, | 
					
						
							| 
									
										
										
										
											2009-02-11 15:10:57 +00:00
										 |  |  |     ARRAY_FLOAT =  0x22, | 
					
						
							| 
									
										
										
										
											2010-06-17 00:31:42 +01:00
										 |  |  |     CLAUSE_LIST =  0x40, | 
					
						
							| 
									
										
										
										
											2010-06-19 00:38:49 +01:00
										 |  |  |     BLOB_STRING =  0x80, /* SWI style strings */ | 
					
						
							|  |  |  |     BLOB_WIDE_STRING =  0x81, /* SWI style strings */ | 
					
						
							| 
									
										
										
										
											2011-07-22 04:09:33 -07:00
										 |  |  |     EXTERNAL_BLOB =  0x100, /* generic data */ | 
					
						
							|  |  |  |     USER_BLOB_START =  0x1000, /* user defined blob */ | 
					
						
							|  |  |  |     USER_BLOB_END =  0x1100 /* end of user defined blob */ | 
					
						
							| 
									
										
										
										
											2008-11-28 15:54:46 +00:00
										 |  |  |   }  | 
					
						
							|  |  |  | big_blob_type; | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN blob_type BlobOfFunctor (Functor f); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN blob_type | 
					
						
							|  |  |  | BlobOfFunctor (Functor f) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2007-09-21 13:52:52 +00:00
										 |  |  |   return (blob_type) (f); | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-21 13:52:52 +00:00
										 |  |  | typedef struct cp_frame { | 
					
						
							|  |  |  |   CELL *start_cp; | 
					
						
							|  |  |  |   CELL *end_cp; | 
					
						
							|  |  |  |   CELL *to; | 
					
						
							|  |  |  | #ifdef RATIONAL_TREES
 | 
					
						
							|  |  |  |   CELL oldv; | 
					
						
							|  |  |  |   int ground; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } copy_frame; | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef COROUTINING
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   /* what to do when someone tries to bind our term to someone else
 | 
					
						
							|  |  |  |      in some  predefined context */ | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  |   void (*bind_op) (Term *, Term CACHE_TYPE); | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  |   /* what to do if someone wants to copy our constraint */ | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  |   int (*copy_term_op) (CELL *, struct cp_frame **, CELL * CACHE_TYPE); | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  |   /* copy the constraint into a term and back */ | 
					
						
							| 
									
										
										
										
											2008-11-28 15:54:46 +00:00
										 |  |  |   Term (*to_term_op) (CELL *); | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  |   int (*term_to_op) (Term, Term CACHE_TYPE); | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  |   /* op called to do marking in GC */ | 
					
						
							|  |  |  |   void (*mark_op) (CELL *); | 
					
						
							|  |  |  | } ext_op; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* known delays */ | 
					
						
							|  |  |  | typedef enum | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   empty_ext = 0 * sizeof (ext_op),	/* default op, this should never be called */ | 
					
						
							|  |  |  |   attvars_ext = 1 * sizeof (ext_op)	/* support for attributed variables */ | 
					
						
							|  |  |  |     /* add your own extensions here */ | 
					
						
							|  |  |  |     /* keep this one */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | exts; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-25 16:40:36 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-10 12:26:23 +00:00
										 |  |  | #ifdef YAP_H
 | 
					
						
							| 
									
										
										
										
											2011-11-03 07:55:42 +09:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | /* make sure that these data structures are the first thing to be allocated
 | 
					
						
							|  |  |  |    in the heap when we start the system */ | 
					
						
							| 
									
										
										
										
											2008-03-25 22:03:14 +00:00
										 |  |  | #ifdef THREADS
 | 
					
						
							| 
									
										
										
										
											2005-11-23 03:01:33 +00:00
										 |  |  | typedef struct special_functors_struct | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   AtomEntry *AtFoundVar; | 
					
						
							|  |  |  |   AtomEntry *AtFreeTerm; | 
					
						
							|  |  |  |   AtomEntry *AtNil; | 
					
						
							|  |  |  |   AtomEntry *AtDot; | 
					
						
							|  |  |  | } special_functors; | 
					
						
							|  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | typedef struct special_functors_struct | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   AtomEntry AtFoundVar; | 
					
						
							|  |  |  |   char AtFoundVarChars[8]; | 
					
						
							| 
									
										
										
										
											2005-09-09 17:24:39 +00:00
										 |  |  |   AtomEntry AtFreeTerm; | 
					
						
							|  |  |  |   char AtFreeTermChars[8]; | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  |   AtomEntry AtNil; | 
					
						
							|  |  |  |   char AtNilChars[8]; | 
					
						
							|  |  |  |   AtomEntry AtDot; | 
					
						
							|  |  |  |   char AtDotChars[8]; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | special_functors; | 
					
						
							| 
									
										
										
										
											2005-11-23 03:01:33 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-10 14:24:20 +00:00
										 |  |  | inline EXTERN Float STD_PROTO (CpFloatUnaligned, (CELL *)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | #if SIZEOF_DOUBLE == SIZEOF_LONG_INT
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-03 07:55:42 +09:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | inline EXTERN Term MkFloatTerm (Float); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Term | 
					
						
							|  |  |  | MkFloatTerm (Float dbl) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  |   return (Term) ((H[0] = (CELL) FunctorDouble, *(Float *) (H + 1) = | 
					
						
							| 
									
										
										
										
											2006-08-22 16:12:46 +00:00
										 |  |  | 		  dbl, H[2] = EndSpecials, H += | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | 		  3, AbsAppl (H - 3))); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Float FloatOfTerm (Term t); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Float | 
					
						
							|  |  |  | FloatOfTerm (Term t) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (Float) (*(Float *) (RepAppl (t) + 1)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define InitUnalignedFloat()
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-10 14:24:20 +00:00
										 |  |  | inline extern Float | 
					
						
							|  |  |  | CpFloatUnaligned(CELL *ptr) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return *((Float *)ptr); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #if SIZEOF_DOUBLE == 2*SIZEOF_LONG_INT
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-07 08:34:20 -08:00
										 |  |  | inline EXTERN void STD_PROTO (AlignGlobalForDouble, ( USES_REGS1 )); | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define DOUBLE_ALIGNED(ADDR) ((CELL)(ADDR) & 0x4)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef i386
 | 
					
						
							|  |  |  | inline EXTERN Float | 
					
						
							|  |  |  | CpFloatUnaligned (CELL * ptr) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return *((Float *) (ptr + 1)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | /* first, need to address the alignment problem */ | 
					
						
							|  |  |  | inline EXTERN Float | 
					
						
							|  |  |  | CpFloatUnaligned (CELL * ptr) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   union | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     Float f; | 
					
						
							|  |  |  |     CELL d[2]; | 
					
						
							|  |  |  |   } u; | 
					
						
							|  |  |  |   u.d[0] = ptr[1]; | 
					
						
							|  |  |  |   u.d[1] = ptr[2]; | 
					
						
							|  |  |  |   return (u.f); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Term MkFloatTerm (Float); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Term | 
					
						
							|  |  |  | MkFloatTerm (Float dbl) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-03-07 08:34:20 -08:00
										 |  |  |   CACHE_REGS | 
					
						
							|  |  |  |   return (Term) ((AlignGlobalForDouble ( PASS_REGS1 ), H[0] = | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | 		  (CELL) FunctorDouble, *(Float *) (H + 1) = dbl, H[3] = | 
					
						
							| 
									
										
										
										
											2006-08-22 16:12:46 +00:00
										 |  |  | 		  EndSpecials, H += | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | 		  4, AbsAppl (H - 4))); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Float FloatOfTerm (Term t); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Float | 
					
						
							|  |  |  | FloatOfTerm (Term t) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (Float) ((DOUBLE_ALIGNED (RepAppl (t)) ? *(Float *) (RepAppl (t) + 1) | 
					
						
							|  |  |  | 		   : CpFloatUnaligned (RepAppl (t)))); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* no alignment problems for 64 bit machines */ | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |      /* OOPS, YAP only understands Floats that are as large as cells or that
 | 
					
						
							|  |  |  |         take two cells!!! */ | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-03 07:55:42 +09:00
										 |  |  | Term STD_PROTO (Yap_MkBlobStringTerm, (const char *, size_t len)); | 
					
						
							|  |  |  | Term STD_PROTO (Yap_MkBlobWideStringTerm, (const wchar_t *, size_t len)); | 
					
						
							|  |  |  | char *STD_PROTO (Yap_BlobStringOfTerm, (Term)); | 
					
						
							|  |  |  | wchar_t *STD_PROTO (Yap_BlobWideStringOfTerm, (Term)); | 
					
						
							|  |  |  | char *STD_PROTO (Yap_BlobStringOfTermAndLength, (Term, size_t *)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* YAP_NOT_INSTALLED */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN int IsFloatTerm (Term); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN int | 
					
						
							|  |  |  | IsFloatTerm (Term t) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (int) (IsApplTerm (t) && FunctorOfTerm (t) == FunctorDouble); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* extern Functor FunctorLongInt; */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-10 12:26:23 +00:00
										 |  |  | #ifdef YAP_H
 | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | inline EXTERN Term MkLongIntTerm (Int); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Term | 
					
						
							|  |  |  | MkLongIntTerm (Int i) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2006-03-03 23:11:30 +00:00
										 |  |  |   H[0] = (CELL) FunctorLongInt; | 
					
						
							|  |  |  |   H[1] = (CELL) (i); | 
					
						
							| 
									
										
										
										
											2006-08-22 16:12:46 +00:00
										 |  |  |   H[2] =  EndSpecials; | 
					
						
							| 
									
										
										
										
											2006-03-03 23:11:30 +00:00
										 |  |  |   H += 3; | 
					
						
							|  |  |  |   return AbsAppl(H - 3); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-03 07:55:42 +09:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | inline EXTERN Int LongIntOfTerm (Term t); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Int | 
					
						
							|  |  |  | LongIntOfTerm (Term t) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (Int) (RepAppl (t)[1]); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN int IsLongIntTerm (Term); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN int | 
					
						
							|  |  |  | IsLongIntTerm (Term t) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (int) (IsApplTerm (t) && FunctorOfTerm (t) == FunctorLongInt); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef USE_GMP
 | 
					
						
							| 
									
										
										
										
											2006-08-23 12:12:14 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | #include <stdio.h>
 | 
					
						
							| 
									
										
										
										
											2006-08-23 12:12:14 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | #include <gmp.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-23 12:12:14 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-09-28 16:15:54 +00:00
										 |  |  | typedef UInt mp_limb_t; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-23 12:12:14 +00:00
										 |  |  | typedef struct { | 
					
						
							| 
									
										
										
										
											2007-03-30 16:47:22 +00:00
										 |  |  |   Int _mp_size, _mp_alloc; | 
					
						
							| 
									
										
										
										
											2006-09-28 16:15:54 +00:00
										 |  |  |   mp_limb_t *_mp_d; | 
					
						
							| 
									
										
										
										
											2006-08-23 12:12:14 +00:00
										 |  |  | } MP_INT; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-05-27 12:24:15 +01:00
										 |  |  | typedef struct { | 
					
						
							|  |  |  |   MP_INT _mp_num; | 
					
						
							|  |  |  |   MP_INT _mp_den; | 
					
						
							|  |  |  | } MP_RAT; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-08-23 12:12:14 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | inline EXTERN int IsBigIntTerm (Term); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN int | 
					
						
							|  |  |  | IsBigIntTerm (Term t) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (int) (IsApplTerm (t) && FunctorOfTerm (t) == FunctorBigInt); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-03-30 16:47:22 +00:00
										 |  |  | #ifdef USE_GMP
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Term STD_PROTO (Yap_MkBigIntTerm, (MP_INT *)); | 
					
						
							|  |  |  | MP_INT *STD_PROTO (Yap_BigIntOfTerm, (Term)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-05-27 12:24:15 +01:00
										 |  |  | Term STD_PROTO (Yap_MkBigRatTerm, (MP_RAT *)); | 
					
						
							|  |  |  | MP_RAT *STD_PROTO (Yap_BigRatOfTerm, (Term)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-02 02:16:19 +00:00
										 |  |  | inline EXTERN void MPZ_SET (mpz_t, MP_INT *); | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-02 02:16:19 +00:00
										 |  |  | inline EXTERN void | 
					
						
							|  |  |  | MPZ_SET (mpz_t dest, MP_INT *src) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   dest->_mp_size = src->_mp_size; | 
					
						
							|  |  |  |   dest->_mp_alloc = src->_mp_alloc; | 
					
						
							|  |  |  |   dest->_mp_d = src->_mp_d; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN int IsLargeIntTerm (Term); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN int | 
					
						
							|  |  |  | IsLargeIntTerm (Term t) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (int) (IsApplTerm (t) | 
					
						
							|  |  |  | 		&& ((FunctorOfTerm (t) <= FunctorBigInt) | 
					
						
							|  |  |  | 		    && (FunctorOfTerm (t) >= FunctorLongInt))); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-05-19 13:48:11 +00:00
										 |  |  | inline EXTERN UInt Yap_SizeOfBigInt (Term); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN UInt | 
					
						
							|  |  |  | Yap_SizeOfBigInt (Term t) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   CELL *pt = RepAppl(t)+1; | 
					
						
							|  |  |  |   return 2+(sizeof(MP_INT)+ | 
					
						
							|  |  |  | 	    (((MP_INT *)pt)->_mp_alloc*sizeof(mp_limb_t)))/sizeof(CELL); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN int IsLargeIntTerm (Term); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN int | 
					
						
							|  |  |  | IsLargeIntTerm (Term t) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (int) (IsApplTerm (t) && FunctorOfTerm (t) == FunctorLongInt); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-19 00:38:49 +01:00
										 |  |  | typedef struct string_struct { | 
					
						
							| 
									
										
										
										
											2011-06-21 15:11:07 +01:00
										 |  |  |   UInt len; | 
					
						
							| 
									
										
										
										
											2010-06-19 00:38:49 +01:00
										 |  |  | }  blob_string_t; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN int IsBlobStringTerm (Term); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN int | 
					
						
							|  |  |  | IsBlobStringTerm (Term t) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (int) (IsApplTerm (t) && | 
					
						
							|  |  |  | 		FunctorOfTerm (t) == FunctorBigInt && | 
					
						
							|  |  |  | 		(RepAppl(t)[1] & BLOB_STRING) == BLOB_STRING); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-07-19 22:42:47 +01:00
										 |  |  | inline EXTERN int IsWideBlobStringTerm (Term); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-19 00:38:49 +01:00
										 |  |  | inline EXTERN int | 
					
						
							| 
									
										
										
										
											2010-07-19 22:42:47 +01:00
										 |  |  | IsWideBlobStringTerm (Term t) | 
					
						
							| 
									
										
										
										
											2010-06-19 00:38:49 +01:00
										 |  |  | { | 
					
						
							|  |  |  |   return (int) (IsApplTerm (t) && | 
					
						
							|  |  |  | 		FunctorOfTerm (t) == FunctorBigInt && | 
					
						
							|  |  |  | 		RepAppl(t)[1] == BLOB_WIDE_STRING); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | /* extern Functor FunctorLongInt; */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN int IsLargeNumTerm (Term); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN int | 
					
						
							|  |  |  | IsLargeNumTerm (Term t) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (int) (IsApplTerm (t) | 
					
						
							|  |  |  | 		&& ((FunctorOfTerm (t) <= FunctorDouble) | 
					
						
							|  |  |  | 		    && (FunctorOfTerm (t) >= FunctorLongInt))); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-22 04:09:33 -07:00
										 |  |  | inline EXTERN int IsExternalBlobTerm (Term, CELL); | 
					
						
							| 
									
										
										
										
											2011-07-21 02:24:21 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN int | 
					
						
							| 
									
										
										
										
											2011-07-22 04:09:33 -07:00
										 |  |  | IsExternalBlobTerm (Term t, CELL tag) | 
					
						
							| 
									
										
										
										
											2011-07-21 02:24:21 -07:00
										 |  |  | { | 
					
						
							|  |  |  |   return (int) (IsApplTerm (t) && | 
					
						
							|  |  |  | 		FunctorOfTerm (t) == FunctorBigInt && | 
					
						
							| 
									
										
										
										
											2011-07-22 04:09:33 -07:00
										 |  |  | 		RepAppl(t)[1] == tag); | 
					
						
							| 
									
										
										
										
											2011-07-21 02:24:21 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN void *ExternalBlobFromTerm (Term); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN void * | 
					
						
							|  |  |  | ExternalBlobFromTerm (Term t) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   MP_INT *base = (MP_INT *)(RepAppl(t)+2); | 
					
						
							|  |  |  |   return (void *) (base+1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN int IsNumTerm (Term); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN int | 
					
						
							|  |  |  | IsNumTerm (Term t) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (int) ((IsIntTerm (t) || IsLargeNumTerm (t))); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Int IsAtomicTerm (Term); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Int | 
					
						
							|  |  |  | IsAtomicTerm (Term t) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (Int) (IsAtomOrIntTerm (t) || IsLargeNumTerm (t)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Int IsExtensionFunctor (Functor); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Int | 
					
						
							|  |  |  | IsExtensionFunctor (Functor f) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (Int) (f <= FunctorDouble); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Int IsBlobFunctor (Functor); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Int | 
					
						
							|  |  |  | IsBlobFunctor (Functor f) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (Int) ((f <= FunctorDouble && f >= FunctorDBRef)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Int IsPrimitiveTerm (Term); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Int | 
					
						
							|  |  |  | IsPrimitiveTerm (Term t) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (Int) ((IsAtomOrIntTerm (t) | 
					
						
							|  |  |  | 		 || (IsApplTerm (t) && IsBlobFunctor (FunctorOfTerm (t))))); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef TERM_EXTENSIONS
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Int IsAttachFunc (Functor); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Int | 
					
						
							|  |  |  | IsAttachFunc (Functor f) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (Int) (FALSE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Int IsAttachedTerm (Term); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Int | 
					
						
							|  |  |  | IsAttachedTerm (Term t) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2010-03-08 09:24:11 +00:00
										 |  |  |   return (Int) ((IsVarTerm (t) && IsAttVar(VarOfTerm(t)))); | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-21 17:07:58 +00:00
										 |  |  | inline EXTERN Int GlobalIsAttachedTerm (Term); | 
					
						
							| 
									
										
										
										
											2011-03-18 19:34:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Int | 
					
						
							| 
									
										
										
										
											2011-03-19 10:25:23 +00:00
										 |  |  | GlobalIsAttachedTerm (Term t) | 
					
						
							| 
									
										
										
										
											2011-03-18 19:34:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-03-19 10:25:23 +00:00
										 |  |  |   return (Int) ((IsVarTerm (t) && GlobalIsAttVar(VarOfTerm(t)))); | 
					
						
							| 
									
										
										
										
											2011-03-18 19:34:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | inline EXTERN Int SafeIsAttachedTerm (Term); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Int | 
					
						
							|  |  |  | SafeIsAttachedTerm (Term t) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2010-03-08 09:24:11 +00:00
										 |  |  |   return (Int) (IsVarTerm (t) && IsAttVar(VarOfTerm(t))); | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN exts ExtFromCell (CELL *); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN exts | 
					
						
							|  |  |  | ExtFromCell (CELL * pt) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2005-09-09 17:24:39 +00:00
										 |  |  |   return attvars_ext; | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Int IsAttachFunc (Functor); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Int | 
					
						
							|  |  |  | IsAttachFunc (Functor f) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (Int) (FALSE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Int IsAttachedTerm (Term); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Int | 
					
						
							|  |  |  | IsAttachedTerm (Term t) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return (Int) (FALSE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-13 10:01:51 +00:00
										 |  |  | inline EXTERN Int Yap_BlobTag(Term t); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN Int Yap_BlobTag(Term t) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   CELL *pt = RepAppl(t); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return pt[1]; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN void *Yap_BlobInfo(Term t); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | inline EXTERN void *Yap_BlobInfo(Term t) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   MP_INT *blobp; | 
					
						
							|  |  |  |   CELL *pt = RepAppl(t); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   blobp = (MP_INT *)(pt+2); | 
					
						
							|  |  |  |   return (void *)(blobp+1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-10 12:26:23 +00:00
										 |  |  | #ifdef YAP_H
 | 
					
						
							| 
									
										
										
										
											2011-11-03 07:55:42 +09:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | inline EXTERN int STD_PROTO (unify_extension, (Functor, CELL, CELL *, CELL)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | EXTERN int STD_PROTO (unify_extension, (Functor, CELL, CELL *, CELL)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-05-28 12:07:01 +01:00
										 |  |  | int   STD_PROTO(Yap_gmp_tcmp_big_big,(Term, Term)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | inline EXTERN int | 
					
						
							|  |  |  | unify_extension (Functor f, CELL d0, CELL * pt0, CELL d1) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   switch (BlobOfFunctor (f)) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |     case db_ref_e: | 
					
						
							|  |  |  |       return (d0 == d1); | 
					
						
							| 
									
										
										
										
											2010-03-06 22:43:21 +00:00
										 |  |  |     case attvar_e: | 
					
						
							|  |  |  |       return (d0 == d1); | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  |     case long_int_e: | 
					
						
							|  |  |  |       return (pt0[1] == RepAppl (d1)[1]); | 
					
						
							|  |  |  |     case big_int_e: | 
					
						
							| 
									
										
										
										
											2006-09-28 16:15:54 +00:00
										 |  |  | #ifdef USE_GMP
 | 
					
						
							| 
									
										
										
										
											2010-05-28 12:07:01 +01:00
										 |  |  |       return (Yap_gmp_tcmp_big_big(d0,d1) == 0); | 
					
						
							| 
									
										
										
										
											2006-09-28 16:15:54 +00:00
										 |  |  | #else
 | 
					
						
							|  |  |  |       return d0 == d1; | 
					
						
							| 
									
										
										
										
											2005-05-27 22:27:59 +00:00
										 |  |  | #endif /* USE_GMP */
 | 
					
						
							|  |  |  |     case double_e: | 
					
						
							|  |  |  |       { | 
					
						
							|  |  |  | 	CELL *pt1 = RepAppl (d1); | 
					
						
							|  |  |  | 	return (pt0[1] == pt1[1] | 
					
						
							|  |  |  | #if SIZEOF_DOUBLE == 2*SIZEOF_LONG_INT
 | 
					
						
							|  |  |  | 		&& pt0[2] == pt1[2] | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	  ); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   return (FALSE); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2010-05-14 12:42:30 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | static inline | 
					
						
							|  |  |  | CELL Yap_IntP_key(CELL *pt) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #ifdef USE_GMP
 | 
					
						
							|  |  |  |   if (((Functor)pt[-1] == FunctorBigInt)) { | 
					
						
							|  |  |  |     MP_INT *b1 = Yap_BigIntOfTerm(AbsAppl(pt-1)); | 
					
						
							|  |  |  |     /* first cell in program */ | 
					
						
							|  |  |  |     CELL val = ((CELL *)(b1+1))[0]; | 
					
						
							|  |  |  |     return MkIntTerm(val & (MAX_ABS_INT-1)); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |   return MkIntTerm(pt[0] & (MAX_ABS_INT-1)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline | 
					
						
							|  |  |  | CELL Yap_Int_key(Term t) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return Yap_IntP_key(RepAppl(t)+1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline | 
					
						
							|  |  |  | CELL Yap_DoubleP_key(CELL *pt) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #if SIZEOF_DOUBLE == 2*SIZEOF_LONG_INT
 | 
					
						
							|  |  |  |   CELL val = pt[0]^pt[1]; | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |   CELL val = pt[0]; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  |   return MkIntTerm(val & (MAX_ABS_INT-1));   | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static inline | 
					
						
							|  |  |  | CELL Yap_Double_key(Term t) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   return Yap_DoubleP_key(RepAppl(t)+1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-03 07:55:42 +09:00
										 |  |  | #endif
 |