| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | /*************************************************************************
 | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | *	 YAP Prolog 							 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | *	Yap Prolog was developed at NCCUP - Universidade do Porto	 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | * Copyright L.Damas, V. Santos Costa and Universidade do Porto 1985--	 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | ************************************************************************** | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | * File:		atoms.c							 * | 
					
						
							|  |  |  | * comments:	General-purpose C implemented system predicates		 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | * Last rev:     $Date: 2008-07-24 16:02:00 $,$Author: vsc $	     	 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | *************************************************************************/ | 
					
						
							|  |  |  | #ifdef SCCS
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static char SccsId[] = "%W% %G%"; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-13 21:42:34 +01:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * @file atomic.c | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @defgroup Predicates_on_Atoms Predicates on Atoms and Strings | 
					
						
							|  |  |  |  *    @ingroup builtins | 
					
						
							|  |  |  |  * @{ | 
					
						
							| 
									
										
										
										
											2014-09-11 14:06:57 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-13 21:42:34 +01:00
										 |  |  | @brief The following predicates are used to manipulate atoms, strings, lists of codes and lists of chars: | 
					
						
							| 
									
										
										
										
											2014-09-11 14:06:57 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-15 03:13:50 -05:00
										 |  |  | \toc | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-26 17:36:33 +00:00
										 |  |  | */ | 
					
						
							| 
									
										
										
										
											2014-09-11 14:06:57 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | #define HAS_CACHE_REGS 1
 | 
					
						
							|  |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |  * This file includes the definition of a miscellania of standard operations | 
					
						
							|  |  |  |  * for yap refering to sequences of characters conversions. | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "Yap.h"
 | 
					
						
							| 
									
										
										
										
											2017-01-22 22:10:38 +00:00
										 |  |  | #include "YapEval.h"
 | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | #include "YapHeap.h"
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | #include "YapText.h"
 | 
					
						
							|  |  |  | #include "Yatom.h"
 | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | #include "yapio.h"
 | 
					
						
							|  |  |  | #ifdef TABLING
 | 
					
						
							|  |  |  | #include "tab.macros.h"
 | 
					
						
							|  |  |  | #endif /* TABLING */
 | 
					
						
							|  |  |  | #include <stdio.h>
 | 
					
						
							|  |  |  | #if HAVE_STRING_H
 | 
					
						
							|  |  |  | #include <string.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #if HAVE_MALLOC_H
 | 
					
						
							|  |  |  | #include <malloc.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | #include <wchar.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int name(USES_REGS1); | 
					
						
							|  |  |  | static Int atom_chars(USES_REGS1); | 
					
						
							|  |  |  | static Int atom_codes(USES_REGS1); | 
					
						
							|  |  |  | static Int atom_length(USES_REGS1); | 
					
						
							|  |  |  | static Int string_length(USES_REGS1); | 
					
						
							|  |  |  | static Int atom_split(USES_REGS1); | 
					
						
							|  |  |  | static Int number_chars(USES_REGS1); | 
					
						
							|  |  |  | static Int number_codes(USES_REGS1); | 
					
						
							|  |  |  | static Int current_atom(USES_REGS1); | 
					
						
							|  |  |  | static Int cont_current_atom(USES_REGS1); | 
					
						
							| 
									
										
										
										
											2015-09-21 17:05:36 -05:00
										 |  |  | static int AlreadyHidden(unsigned char *); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int hide_atom(USES_REGS1); | 
					
						
							|  |  |  | static Int hidden_atom(USES_REGS1); | 
					
						
							|  |  |  | static Int unhide_atom(USES_REGS1); | 
					
						
							| 
									
										
										
										
											2016-02-28 19:32:55 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static int AlreadyHidden(unsigned char *name) { | 
					
						
							|  |  |  |   AtomEntry *chain; | 
					
						
							| 
									
										
										
										
											2014-07-26 19:14:15 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |   READ_LOCK(INVISIBLECHAIN.AERWLock); | 
					
						
							|  |  |  |   chain = RepAtom(INVISIBLECHAIN.Entry); | 
					
						
							|  |  |  |   READ_UNLOCK(INVISIBLECHAIN.AERWLock); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   while (!EndOfPAEntr(chain) && | 
					
						
							|  |  |  |          strcmp((char *)chain->StrOfAE, (char *)name) != 0) | 
					
						
							| 
									
										
										
										
											2014-07-26 19:14:15 -05:00
										 |  |  |     chain = RepAtom(chain->NextOfAE); | 
					
						
							|  |  |  |   if (EndOfPAEntr(chain)) | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |     return false; | 
					
						
							|  |  |  |   return true; | 
					
						
							| 
									
										
										
										
											2014-07-26 19:14:15 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-03 01:24:57 +00:00
										 |  |  | /** @pred hide_atom(+ _Atom_)
 | 
					
						
							| 
									
										
										
										
											2014-07-26 19:14:15 -05:00
										 |  |  |     Make atom  _Atom_ invisible. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Notice that defining a new atom with the same characters will | 
					
						
							|  |  |  |     result in a different atom.xs | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  **/ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int hide_atom(USES_REGS1) { /* hide(+Atom)		 */ | 
					
						
							|  |  |  |   Atom atomToInclude; | 
					
						
							| 
									
										
										
										
											2014-07-26 19:14:15 -05:00
										 |  |  |   Term t1 = Deref(ARG1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (IsVarTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     Yap_Error(INSTANTIATION_ERROR, t1, "hide_atom/1"); | 
					
						
							|  |  |  |     return (FALSE); | 
					
						
							| 
									
										
										
										
											2014-07-26 19:14:15 -05:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (!IsAtomTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     Yap_Error(TYPE_ERROR_ATOM, t1, "hide_atom/1"); | 
					
						
							|  |  |  |     return (FALSE); | 
					
						
							| 
									
										
										
										
											2014-07-26 19:14:15 -05:00
										 |  |  |   } | 
					
						
							|  |  |  |   atomToInclude = AtomOfTerm(t1); | 
					
						
							| 
									
										
										
										
											2015-09-21 17:05:36 -05:00
										 |  |  |   if (AlreadyHidden(RepAtom(atomToInclude)->UStrOfAE)) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     Yap_Error(SYSTEM_ERROR_INTERNAL, t1, | 
					
						
							|  |  |  |               "an atom of name %s was already hidden", | 
					
						
							|  |  |  |               RepAtom(atomToInclude)->StrOfAE); | 
					
						
							|  |  |  |     return (FALSE); | 
					
						
							| 
									
										
										
										
											2014-07-26 19:14:15 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-01-07 23:42:52 +00:00
										 |  |  |   AtomEntry *ae = RepAtom(atomToInclude); | 
					
						
							|  |  |  |   Prop p = ae->PropsOfAE; | 
					
						
							|  |  |  |   while (p) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     if (IsPredProperty(p->KindOfPE) || IsDBProperty(p->KindOfPE)) { | 
					
						
							| 
									
										
										
										
											2016-01-07 23:42:52 +00:00
										 |  |  |       RepPredProp(p)->PredFlags |= HiddenPredFlag; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-07 23:42:52 +00:00
										 |  |  |     } else if (p->KindOfPE == FunctorProperty) { | 
					
						
							|  |  |  |       Prop q = RepFunctorProp(p)->PropsOfFE; | 
					
						
							|  |  |  |       while (q) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |         if (IsPredProperty(q->KindOfPE) || IsDBProperty(q->KindOfPE)) { | 
					
						
							| 
									
										
										
										
											2016-01-07 23:42:52 +00:00
										 |  |  |           RepPredProp(q)->PredFlags |= HiddenPredFlag; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         q = q->NextOfPE; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     p = p->NextOfPE; | 
					
						
							| 
									
										
										
										
											2016-01-07 23:42:52 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2014-07-26 19:14:15 -05:00
										 |  |  |   Yap_ReleaseAtom(atomToInclude); | 
					
						
							|  |  |  |   WRITE_LOCK(INVISIBLECHAIN.AERWLock); | 
					
						
							|  |  |  |   WRITE_LOCK(RepAtom(atomToInclude)->ARWLock); | 
					
						
							|  |  |  |   RepAtom(atomToInclude)->NextOfAE = INVISIBLECHAIN.Entry; | 
					
						
							|  |  |  |   WRITE_UNLOCK(RepAtom(atomToInclude)->ARWLock); | 
					
						
							|  |  |  |   INVISIBLECHAIN.Entry = atomToInclude; | 
					
						
							|  |  |  |   WRITE_UNLOCK(INVISIBLECHAIN.AERWLock); | 
					
						
							|  |  |  |   return (TRUE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | /** @pred hidden_atom( +Atom )
 | 
					
						
							| 
									
										
										
										
											2014-07-26 19:14:15 -05:00
										 |  |  |     Is the  atom _Ãtom_ visible to Prolog? | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  **/ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int hidden_atom(USES_REGS1) { /* '$hidden_atom'(+F)		 */ | 
					
						
							|  |  |  |   Atom at; | 
					
						
							|  |  |  |   AtomEntry *chain; | 
					
						
							| 
									
										
										
										
											2014-07-26 19:14:15 -05:00
										 |  |  |   Term t1 = Deref(ARG1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (IsVarTerm(t1)) | 
					
						
							|  |  |  |     return (FALSE); | 
					
						
							|  |  |  |   if (IsAtomTerm(t1)) | 
					
						
							|  |  |  |     at = AtomOfTerm(t1); | 
					
						
							|  |  |  |   else if (IsApplTerm(t1)) | 
					
						
							|  |  |  |     at = NameOfFunctor(FunctorOfTerm(t1)); | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     return (FALSE); | 
					
						
							|  |  |  |   READ_LOCK(INVISIBLECHAIN.AERWLock); | 
					
						
							|  |  |  |   chain = RepAtom(INVISIBLECHAIN.Entry); | 
					
						
							|  |  |  |   while (!EndOfPAEntr(chain) && AbsAtom(chain) != at) | 
					
						
							|  |  |  |     chain = RepAtom(chain->NextOfAE); | 
					
						
							|  |  |  |   READ_UNLOCK(INVISIBLECHAIN.AERWLock); | 
					
						
							|  |  |  |   if (EndOfPAEntr(chain)) | 
					
						
							|  |  |  |     return (FALSE); | 
					
						
							|  |  |  |   return (TRUE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | /** @pred unhide_atom(+ _Atom_)
 | 
					
						
							| 
									
										
										
										
											2016-02-28 19:32:55 +00:00
										 |  |  |     Make hidden atom  _Atom_ visible | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     Note that the operation fails if another atom with name _Atom_ was defined | 
					
						
							|  |  |  |  since. | 
					
						
							| 
									
										
										
										
											2014-07-26 19:14:15 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |  **/ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int unhide_atom(USES_REGS1) { /* unhide_atom(+Atom)		 */ | 
					
						
							|  |  |  |   AtomEntry *atom, *old, *chain; | 
					
						
							| 
									
										
										
										
											2014-07-26 19:14:15 -05:00
										 |  |  |   Term t1 = Deref(ARG1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (IsVarTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     Yap_Error(INSTANTIATION_ERROR, t1, "unhide_atom/1"); | 
					
						
							|  |  |  |     return (FALSE); | 
					
						
							| 
									
										
										
										
											2014-07-26 19:14:15 -05:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (!IsAtomTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     Yap_Error(TYPE_ERROR_ATOM, t1, "unhide_atom/1"); | 
					
						
							|  |  |  |     return (FALSE); | 
					
						
							| 
									
										
										
										
											2014-07-26 19:14:15 -05:00
										 |  |  |   } | 
					
						
							|  |  |  |   atom = RepAtom(AtomOfTerm(t1)); | 
					
						
							|  |  |  |   WRITE_LOCK(atom->ARWLock); | 
					
						
							|  |  |  |   if (atom->PropsOfAE != NIL) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     Yap_Error(SYSTEM_ERROR_INTERNAL, t1, "cannot unhide_atom an atom in use"); | 
					
						
							|  |  |  |     return (FALSE); | 
					
						
							| 
									
										
										
										
											2014-07-26 19:14:15 -05:00
										 |  |  |   } | 
					
						
							|  |  |  |   WRITE_LOCK(INVISIBLECHAIN.AERWLock); | 
					
						
							|  |  |  |   chain = RepAtom(INVISIBLECHAIN.Entry); | 
					
						
							|  |  |  |   old = NIL; | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   while (!EndOfPAEntr(chain) && | 
					
						
							|  |  |  |          strcmp((char *)chain->StrOfAE, (char *)atom->StrOfAE) != 0) { | 
					
						
							| 
									
										
										
										
											2014-07-26 19:14:15 -05:00
										 |  |  |     old = chain; | 
					
						
							|  |  |  |     chain = RepAtom(chain->NextOfAE); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (EndOfPAEntr(chain)) | 
					
						
							|  |  |  |     return (FALSE); | 
					
						
							|  |  |  |   atom->PropsOfAE = chain->PropsOfAE; | 
					
						
							|  |  |  |   if (old == NIL) | 
					
						
							|  |  |  |     INVISIBLECHAIN.Entry = chain->NextOfAE; | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     old->NextOfAE = chain->NextOfAE; | 
					
						
							|  |  |  |   WRITE_UNLOCK(INVISIBLECHAIN.AERWLock); | 
					
						
							|  |  |  |   WRITE_UNLOCK(atom->ARWLock); | 
					
						
							|  |  |  |   return (TRUE); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-05 13:06:12 +01:00
										 |  |  |   /** @pred  char_code(? _A_,? _I_) is iso
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   The built-in succeeds with  _A_ bound to character represented as an | 
					
						
							|  |  |  |   atom, and  _I_ bound to the character code represented as an | 
					
						
							|  |  |  |   integer. At least, one of either  _A_ or  _I_ must be bound before | 
					
						
							|  |  |  |   the call. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int char_code(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   Int t0 = Deref(ARG1); | 
					
						
							|  |  |  |   if (IsVarTerm(t0)) { | 
					
						
							|  |  |  |     Term t1 = Deref(ARG2); | 
					
						
							|  |  |  |     if (IsVarTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |       Yap_Error(INSTANTIATION_ERROR, t0, "char_code/2"); | 
					
						
							|  |  |  |       return (FALSE); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |     } else if (!IsIntegerTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2013-12-05 21:26:46 +00:00
										 |  |  |       if (!IsBigIntTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |         Yap_Error(REPRESENTATION_ERROR_INT, t1, "char_code/2"); | 
					
						
							|  |  |  |         return (FALSE); | 
					
						
							| 
									
										
										
										
											2013-12-05 21:26:46 +00:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |       Yap_Error(TYPE_ERROR_INTEGER, t1, "char_code/2"); | 
					
						
							|  |  |  |       return (FALSE); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |     } else { | 
					
						
							|  |  |  |       Int code = IntegerOfTerm(t1); | 
					
						
							|  |  |  |       Term tout; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (code < 0) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |         Yap_Error(REPRESENTATION_ERROR_CHARACTER_CODE, t1, "char_code/2"); | 
					
						
							|  |  |  |         return (FALSE); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |       } | 
					
						
							|  |  |  |       if (code > MAX_ISO_LATIN1) { | 
					
						
							| 
									
										
										
										
											2016-11-02 00:16:36 -05:00
										 |  |  |         unsigned char codes[10]; | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if (code > CHARCODE_MAX) { | 
					
						
							|  |  |  |           Yap_Error(REPRESENTATION_ERROR_INT, t1, "char_code/2"); | 
					
						
							|  |  |  |           return (FALSE); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |         size_t n = put_utf8(codes, code); | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |         codes[n] = code; | 
					
						
							| 
									
										
										
										
											2016-11-02 00:16:36 -05:00
										 |  |  |         tout = MkAtomTerm(Yap_ULookupAtom(codes)); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |         char codes[2]; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |         codes[0] = code; | 
					
						
							|  |  |  |         codes[1] = '\0'; | 
					
						
							|  |  |  |         tout = MkAtomTerm(Yap_LookupAtom(codes)); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |       return Yap_unify(ARG1, tout); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |     } | 
					
						
							|  |  |  |   } else if (!IsAtomTerm(t0)) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     Yap_Error(TYPE_ERROR_CHARACTER, t0, "char_code/2"); | 
					
						
							|  |  |  |     return (FALSE); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } else { | 
					
						
							|  |  |  |     Atom at = AtomOfTerm(t0); | 
					
						
							|  |  |  |     Term tf; | 
					
						
							| 
									
										
										
										
											2016-11-02 00:16:36 -05:00
										 |  |  |     unsigned char *c = RepAtom(at)->UStrOfAE; | 
					
						
							|  |  |  |     int32_t v; | 
					
						
							|  |  |  |     c += get_utf8(c, 1, &v); | 
					
						
							|  |  |  |     if (c[0] != '\0') { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_CHARACTER, t0, "char_code/2"); | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-11-02 00:16:36 -05:00
										 |  |  |     tf = MkIntTerm(v); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     return Yap_unify(ARG2, tf); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-05 13:06:12 +01:00
										 |  |  |   /** @pred name( _A_, _L_)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   The predicate holds when at least one of the arguments is ground | 
					
						
							|  |  |  |   (otherwise, an error message will be displayed). The argument  _A_ will | 
					
						
							|  |  |  |   be unified with an atomic symbol and  _L_ with the list of the ASCII | 
					
						
							|  |  |  |   codes for the characters of the external representation of  _A_. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   ~~~~~{.prolog} | 
					
						
							|  |  |  |    name(yap,L). | 
					
						
							|  |  |  |   ~~~~~ | 
					
						
							|  |  |  |   will return: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   ~~~~~{.prolog} | 
					
						
							|  |  |  |    L = [121,97,112]. | 
					
						
							|  |  |  |   ~~~~~ | 
					
						
							|  |  |  |   and | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   ~~~~~{.prolog} | 
					
						
							|  |  |  |    name(3,L). | 
					
						
							|  |  |  |   ~~~~~ | 
					
						
							|  |  |  |   will return: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   ~~~~~{.prolog} | 
					
						
							|  |  |  |    L = [51]. | 
					
						
							|  |  |  |   ~~~~~ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   */ | 
					
						
							|  |  |  |   static Int name(USES_REGS1) { /* name(?Atomic,?String)		 */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   Term t = Deref(ARG2), NewT, AtomNameT = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |   LOCAL_MAX_SIZE = 1024; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | restart_aux: | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   if (Yap_IsGroundTerm(AtomNameT)) { | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |     if (!IsVarTerm(t) && !IsPairTerm(t) && t != TermNil) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |       Yap_Error(TYPE_ERROR_LIST, ARG2, "name/2"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       pop_text_stack(l); | 
					
						
							|  |  |  |       ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     // verify if an atom, int, float or bi§gnnum
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     NewT = Yap_AtomicToListOfCodes(AtomNameT PASS_REGS); | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |     if (NewT) { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       pop_text_stack(l); | 
					
						
							|  |  |  |       ReleaseAndReturn(Yap_unify(NewT, ARG2)); | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     // else
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   } else if (IsVarTerm(t)) { | 
					
						
							|  |  |  |     Yap_Error(INSTANTIATION_ERROR, t, "name/2"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     pop_text_stack(l); | 
					
						
							| 
									
										
										
										
											2015-09-29 23:05:33 +01:00
										 |  |  |     return FALSE; | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     Term at = Yap_ListToAtomic(t PASS_REGS); | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |     if (at) { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       pop_text_stack(l); | 
					
						
							|  |  |  |       ReleaseAndReturn(Yap_unify(at, ARG1)); | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   if (LOCAL_Error_TYPE && Yap_HandleError("atom/2")) { | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     AtomNameT = Deref(ARG1); | 
					
						
							|  |  |  |     t = Deref(ARG2); | 
					
						
							|  |  |  |     goto restart_aux; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   pop_text_stack(l); | 
					
						
							|  |  |  |   ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int string_to_atomic( | 
					
						
							|  |  |  |     USES_REGS1) { /* string_to_atom(?String,?Atom)		 */ | 
					
						
							|  |  |  |   Term t2 = Deref(ARG2), t1 = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |   LOCAL_MAX_SIZE = 1024; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | restart_aux: | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   if (IsStringTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |     Term t; | 
					
						
							|  |  |  |     // verify if an atom, int, float or bignnum
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     t = Yap_StringToAtomic(t1 PASS_REGS); | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |     if (t != 0L) { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       pop_text_stack(l); | 
					
						
							|  |  |  |       ReleaseAndReturn(Yap_unify(t, t2)); | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |     // else
 | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   } else if (IsVarTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     Term t0 = Yap_AtomicToString(t2 PASS_REGS); | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |     if (t0) { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       pop_text_stack(l); | 
					
						
							|  |  |  |       ReleaseAndReturn(Yap_unify(t0, t1)); | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   } else { | 
					
						
							|  |  |  |     LOCAL_Error_TYPE = TYPE_ERROR_STRING; | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   if (LOCAL_Error_TYPE && Yap_HandleError("string_to_atomic/2")) { | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |     t1 = Deref(ARG1); | 
					
						
							|  |  |  |     t2 = Deref(ARG2); | 
					
						
							|  |  |  |     goto restart_aux; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   pop_text_stack(l); | 
					
						
							|  |  |  |   ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-05 13:06:12 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | /// @pred atomic_to_string(?Atomic.?String)
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // reverse to string_to_atomic(_Atomic_, _String_).
 | 
					
						
							|  |  |  | // The second argument may be a sequence of codes or atoms.
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | static Int atomic_to_string( | 
					
						
							|  |  |  |     USES_REGS1) {  | 
					
						
							|  |  |  |   Term t1 = ARG1; ARG1 = ARG2, ARG2 = t1; | 
					
						
							|  |  |  |   return string_to_atomic(PASS_REGS1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /// @pred string_to_atom(?String, ?Atom)
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // Verifies if (a) at least one of the argument is bound. If _String_
 | 
					
						
							|  |  |  | // is bound it must be a string term, list if codes, or list of atoms,
 | 
					
						
							|  |  |  | // and _Atom_ musr be bound to a symbol with the same text. Otherwise,
 | 
					
						
							|  |  |  | // _Atom_ must be an _Atom_ and _String_ will unify with a string term
 | 
					
						
							|  |  |  | // of the same text.
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // Notes:
 | 
					
						
							|  |  |  | //   - some versions of YAP allow the first argument to be a number. Please use
 | 
					
						
							|  |  |  | //     atomic_to_string/2 in this YAP. 
 | 
					
						
							|  |  |  | //                                                          
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int string_to_atom( | 
					
						
							|  |  |  |     USES_REGS1) { /* string_to_atom(?String,?Atom)		 */ | 
					
						
							|  |  |  |   Term t2 = Deref(ARG2), t1 = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |   LOCAL_MAX_SIZE = 1024; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | restart_aux: | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   if (IsStringTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     Atom at; | 
					
						
							|  |  |  |     // verify if an atom, int, float or bignnum
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     at = Yap_StringSWIToAtom(t1 PASS_REGS); | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |     if (at) { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       pop_text_stack(l); | 
					
						
							|  |  |  |       ReleaseAndReturn(Yap_unify(MkAtomTerm(at), t2)); | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     // else
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   } else if (IsVarTerm(t1)) { | 
					
						
							|  |  |  |     Term t0 = Yap_AtomSWIToString(t2 PASS_REGS); | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |     if (t0) { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       pop_text_stack(l); | 
					
						
							|  |  |  |       ReleaseAndReturn(Yap_unify(t0, t1)); | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   } else { | 
					
						
							|  |  |  |     LOCAL_Error_TYPE = TYPE_ERROR_ATOM; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   if (LOCAL_Error_TYPE && Yap_HandleError("string_to_atom/2")) { | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     t1 = Deref(ARG1); | 
					
						
							|  |  |  |     t2 = Deref(ARG2); | 
					
						
							|  |  |  |     goto restart_aux; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   pop_text_stack(l); | 
					
						
							|  |  |  |   ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-05 13:06:12 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | /// @pred atom_to_string(?Atom.?String)
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // reverse to string_to_atom(_Atom_, _String_). 
 | 
					
						
							|  |  |  | // The second argument may be a sequence of codes or atoms.
 | 
					
						
							|  |  |  | //                                                          
 | 
					
						
							|  |  |  | static Int atom_to_string( | 
					
						
							|  |  |  |     USES_REGS1) { /* string_to_atom(?String,?Atom)		 */ | 
					
						
							|  |  |  |   Term t2 = ARG1; ARG1 = ARG2; ARG2 = t2; | 
					
						
							|  |  |  |   return string_to_atom(PASS_REGS1); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int string_to_list(USES_REGS1) { | 
					
						
							|  |  |  |   Term list = Deref(ARG2), string = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |   LOCAL_MAX_SIZE = 1024; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | restart_aux: | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   if (IsVarTerm(string)) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     Term t1 = Yap_ListToString(list PASS_REGS); | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |     if (t1) { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       pop_text_stack(l); | 
					
						
							|  |  |  |       ReleaseAndReturn(Yap_unify(ARG1, t1)); | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   } else if (IsStringTerm(string)) { | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |     Term tf = Yap_StringToListOfCodes(string PASS_REGS); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     pop_text_stack(l); | 
					
						
							|  |  |  |     ReleaseAndReturn(Yap_unify(ARG2, tf)); | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   } else { | 
					
						
							|  |  |  |     LOCAL_Error_TYPE = TYPE_ERROR_STRING; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   if (LOCAL_Error_TYPE && Yap_HandleError("string_to_list/2")) { | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     string = Deref(ARG1); | 
					
						
							|  |  |  |     list = Deref(ARG2); | 
					
						
							|  |  |  |     goto restart_aux; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   pop_text_stack(l); | 
					
						
							|  |  |  |   ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-05 13:06:12 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | /// @pred atom_string(?Atom.?String)
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // reverse to string_to_atom(_Atom_, _String_). 
 | 
					
						
							|  |  |  | // The second argument may be a sequence of codes or atoms.
 | 
					
						
							|  |  |  | //                                                          
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int atom_string(USES_REGS1) { | 
					
						
							|  |  |  |   Term t1 = Deref(ARG1), t2 = Deref(ARG2); | 
					
						
							| 
									
										
										
										
											2015-09-21 17:05:36 -05:00
										 |  |  |   LOCAL_MAX_SIZE = 1024; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2015-09-21 17:05:36 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | restart_aux: | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   if (IsVarTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2015-09-21 17:05:36 -05:00
										 |  |  |     Atom at; | 
					
						
							|  |  |  |     // verify if an atom, int, float or bignnum
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     at = Yap_StringSWIToAtom(t2 PASS_REGS); | 
					
						
							| 
									
										
										
										
											2015-09-21 17:05:36 -05:00
										 |  |  |     if (at) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(MkAtomTerm(at), t1)); | 
					
						
							| 
									
										
										
										
											2015-09-21 17:05:36 -05:00
										 |  |  |     // else
 | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   } else if (IsAtomTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     Term t0 = Yap_AtomSWIToString(t1 PASS_REGS); | 
					
						
							|  |  |  |     if (t0) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(t0, t2)); | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   } else { | 
					
						
							|  |  |  |     LOCAL_Error_TYPE = TYPE_ERROR_ATOM; | 
					
						
							| 
									
										
										
										
											2015-09-21 17:05:36 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   if (LOCAL_Error_TYPE && Yap_HandleError("atom_string/2")) { | 
					
						
							| 
									
										
										
										
											2015-09-21 17:05:36 -05:00
										 |  |  |     t1 = Deref(ARG1); | 
					
						
							|  |  |  |     t2 = Deref(ARG2); | 
					
						
							|  |  |  |     goto restart_aux; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-05 13:06:12 +01:00
										 |  |  | // The second argument may be a sequence of codes or atoms.
 | 
					
						
							|  |  |  | //                                                          
 | 
					
						
							|  |  |  | static Int string_atom( | 
					
						
							|  |  |  |     USES_REGS1) { /* string_to_atom(?String,?Atom)		 */ | 
					
						
							|  |  |  |   Term t2 = ARG1; ARG1 = ARG2; ARG2 = t2; | 
					
						
							|  |  |  |   return atom_string(PASS_REGS1); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /** @pred  atom_chars(? _A_,? _L_) is iso
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   The predicate holds when at least one of the arguments is ground | 
					
						
							|  |  |  |   (otherwise, an error message will be displayed). The argument  _A_ must | 
					
						
							|  |  |  |   be unifiable with an atom, and the argument  _L_ with the list of the | 
					
						
							|  |  |  |   characters of  _A_. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int atom_chars(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |   Term t1; | 
					
						
							|  |  |  |   LOCAL_MAX_SIZE = 1024; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | restart_aux: | 
					
						
							|  |  |  |   t1 = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   if (IsAtomTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |     Term tf = Yap_AtomSWIToListOfAtoms(t1 PASS_REGS); | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     if (tf) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(ARG2, tf)); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   } else if (IsVarTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     /* ARG1 unbound */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     Term t = Deref(ARG2); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |     Atom af = Yap_ListOfAtomsToAtom(t PASS_REGS); | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     if (af) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(ARG1, MkAtomTerm(af))); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     /* error handling */ | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   } else { | 
					
						
							|  |  |  |     LOCAL_Error_TYPE = TYPE_ERROR_ATOM; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   if (LOCAL_Error_TYPE && Yap_HandleError("atom_chars/2")) { | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     goto restart_aux; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int atom_codes(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |   Term t1; | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   t1 = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  | restart_aux: | 
					
						
							|  |  |  |   if (IsAtomTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2016-02-14 04:12:31 +00:00
										 |  |  |     Term tf = Yap_AtomToListOfCodes(t1 PASS_REGS); | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     if (tf) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(ARG2, tf)); | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   } else if (IsVarTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     /* ARG1 unbound */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     Term t = Deref(ARG2); | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     Atom af = Yap_ListToAtom(t PASS_REGS); | 
					
						
							|  |  |  |     if (af) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(ARG1, MkAtomTerm(af))); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   } else if (IsVarTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |     LOCAL_Error_TYPE = TYPE_ERROR_ATOM; | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   /* error handling */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   if (LOCAL_Error_TYPE && Yap_HandleError("atom_codes/2")) { | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     t1 = Deref(ARG1); | 
					
						
							|  |  |  |     goto restart_aux; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int string_codes(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2013-12-05 21:26:46 +00:00
										 |  |  |   Term t1; | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   t1 = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  | restart_aux: | 
					
						
							|  |  |  |   if (IsStringTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2013-12-05 21:26:46 +00:00
										 |  |  |     Term tf = Yap_StringSWIToListOfCodes(t1 PASS_REGS); | 
					
						
							|  |  |  |     if (tf) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(ARG2, tf)); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   } else if (IsVarTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2013-12-05 21:26:46 +00:00
										 |  |  |     /* ARG1 unbound */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     Term t = Deref(ARG2); | 
					
						
							| 
									
										
										
										
											2013-12-05 21:26:46 +00:00
										 |  |  |     Term tf = Yap_ListSWIToString(t PASS_REGS); | 
					
						
							|  |  |  |     if (tf) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(ARG1, tf)); | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   } else { | 
					
						
							|  |  |  |     LOCAL_Error_TYPE = TYPE_ERROR_STRING; | 
					
						
							| 
									
										
										
										
											2013-12-05 21:26:46 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   /* error handling */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   if (LOCAL_Error_TYPE && Yap_HandleError("atom_codes/2")) { | 
					
						
							| 
									
										
										
										
											2013-12-05 21:26:46 +00:00
										 |  |  |     t1 = Deref(ARG1); | 
					
						
							|  |  |  |     goto restart_aux; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-12-05 21:26:46 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int string_chars(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   Term t1; | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   t1 = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  | restart_aux: | 
					
						
							|  |  |  |   if (IsStringTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |     Term tf = Yap_StringSWIToListOfAtoms(t1 PASS_REGS); | 
					
						
							|  |  |  |     if (tf) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(ARG2, tf)); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   } else if (IsVarTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |     /* ARG1 unbound */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     Term t = Deref(ARG2); | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |     Term tf = Yap_ListSWIToString(t PASS_REGS); | 
					
						
							|  |  |  |     if (tf) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(ARG1, tf)); | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   } else { | 
					
						
							|  |  |  |     LOCAL_Error_TYPE = TYPE_ERROR_STRING; | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   /* error handling */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   if (LOCAL_Error_TYPE && Yap_HandleError("string_chars/2")) { | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |     t1 = Deref(ARG1); | 
					
						
							|  |  |  |     goto restart_aux; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | /** @pred  number_chars(? _I_,? _L_) is iso
 | 
					
						
							| 
									
										
										
										
											2015-10-08 10:16:10 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | The predicate holds when at least one of the arguments is ground | 
					
						
							|  |  |  | (otherwise, an error message will be displayed). The argument  _I_ must | 
					
						
							|  |  |  | be unifiable with a number, and the argument  _L_ with the list of the | 
					
						
							|  |  |  | characters of the external representation of  _I_. | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-10-08 10:16:10 +01:00
										 |  |  | */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int number_chars(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |   Term t1; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | restart_aux: | 
					
						
							|  |  |  |   t1 = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   if (IsNumTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |     Term t2 = Deref(ARG2); | 
					
						
							|  |  |  |     if (IsVarTerm(t2)) { | 
					
						
							|  |  |  |       t1 = Yap_NumberToListOfAtoms(t1 PASS_REGS); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (t1) { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(t1, t2)); | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |     } else { | 
					
						
							|  |  |  |       t2 = Yap_ListToNumber(t2 PASS_REGS); | 
					
						
							|  |  |  |       if (t2) { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |         ReleaseAndReturn(Yap_unify(t1, t2)); | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2015-10-18 11:38:29 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   } else if (IsVarTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     /* ARG1 unbound */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     Term t = Deref(ARG2); | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     Term tf = Yap_ListToNumber(t PASS_REGS); | 
					
						
							| 
									
										
										
										
											2015-10-18 11:38:29 +01:00
										 |  |  |     if (tf) { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(ARG1, tf)); | 
					
						
							| 
									
										
										
										
											2015-10-18 11:38:29 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   } else if (IsVarTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |     LOCAL_Error_TYPE = TYPE_ERROR_NUMBER; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |   /* error handling */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   if (LOCAL_Error_TYPE && Yap_HandleError("number_chars/2")) { | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     goto restart_aux; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-05 13:06:12 +01:00
										 |  |  |   /** @pred  number_atom(? _I_,? _A_)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   The predicate holds when at least one of the arguments is ground | 
					
						
							|  |  |  |   (otherwise, an error message will be displayed). The argument  _I_ must | 
					
						
							|  |  |  |   be unifiable with a number, and the argument  _A_ must be unifiable | 
					
						
							|  |  |  |   with an atom representing the number. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int number_atom(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |   Term t1; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | restart_aux: | 
					
						
							|  |  |  |   t1 = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   if (IsNumTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |     Term t2 = Deref(ARG2); | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     Atom af; | 
					
						
							|  |  |  |     af = Yap_NumberToAtom(t1 PASS_REGS); | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |     if (af) { | 
					
						
							|  |  |  |       if (IsVarTerm(t2)) { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |         ReleaseAndReturn(Yap_unify(t1, t2)); | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |       } else { | 
					
						
							|  |  |  |         t2 = Yap_AtomToNumber(t2 PASS_REGS); | 
					
						
							|  |  |  |         if (t2) { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |           ReleaseAndReturn(Yap_unify(t1, t2)); | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   } else if (IsVarTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     /* ARG1 unbound */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     Term t = Deref(ARG2); | 
					
						
							| 
									
										
										
										
											2014-10-09 10:42:15 +01:00
										 |  |  |     Term tf = Yap_AtomToNumber(t PASS_REGS); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn(Yap_unify(ARG1, tf)); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   } else if (IsVarTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |     LOCAL_Error_TYPE = TYPE_ERROR_NUMBER; | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   } /* error handling */ | 
					
						
							|  |  |  |   if (LOCAL_Error_TYPE && Yap_HandleError("number_atom/2")) { | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     goto restart_aux; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-05 13:06:12 +01:00
										 |  |  |   /** @pred  number_string(? _I_,? _L_)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   The predicate holds when at least one of the arguments is ground | 
					
						
							|  |  |  |   (otherwise, an error message will be displayed). The argument  _I_ must | 
					
						
							|  |  |  |   be unifiable with a number, and the argument  _L_ must be unifiable | 
					
						
							|  |  |  |   with a term string representing the number. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int number_string(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2013-12-05 21:26:46 +00:00
										 |  |  |   Term t1; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | restart_aux: | 
					
						
							|  |  |  |   t1 = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   if (IsNumTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2013-12-05 21:26:46 +00:00
										 |  |  |     Term tf; | 
					
						
							|  |  |  |     tf = Yap_NumberToString(t1 PASS_REGS); | 
					
						
							|  |  |  |     if (tf) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(ARG2, tf)); | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   } else if (IsVarTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2013-12-05 21:26:46 +00:00
										 |  |  |     /* ARG1 unbound */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     Term t = Deref(ARG2); | 
					
						
							| 
									
										
										
										
											2013-12-05 21:26:46 +00:00
										 |  |  |     Term tf = Yap_StringToNumber(t PASS_REGS); | 
					
						
							|  |  |  |     if (tf) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(ARG1, tf)); | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   } else { | 
					
						
							|  |  |  |     LOCAL_Error_TYPE = TYPE_ERROR_NUMBER; | 
					
						
							| 
									
										
										
										
											2013-12-05 21:26:46 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   /* error handling */ | 
					
						
							|  |  |  |   if (LOCAL_Error_TYPE && Yap_HandleError("number_string/2")) { | 
					
						
							| 
									
										
										
										
											2013-12-05 21:26:46 +00:00
										 |  |  |     goto restart_aux; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-12-05 21:26:46 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-05 13:06:12 +01:00
										 |  |  |   /** @pred  number_codes(? _I_,? _L_)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   The predicate holds when at least one of the arguments is ground | 
					
						
							|  |  |  |   (otherwise, an error message will be displayed). The argument  _I_ must | 
					
						
							|  |  |  |   be unifiable with a number, and the argument  _L_ must be unifiable | 
					
						
							|  |  |  |   with a list of UNICODE numbers representing the number. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int number_codes(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |   Term t1; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | restart_aux: | 
					
						
							|  |  |  |   t1 = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   if (IsNumTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     Term tf; | 
					
						
							|  |  |  |     tf = Yap_NumberToListOfCodes(t1 PASS_REGS); | 
					
						
							|  |  |  |     if (tf) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(ARG2, tf)); | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   } else if (IsVarTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |     /* ARG1 unbound */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     Term t = Deref(ARG2); | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     Term tf = Yap_ListToNumber(t PASS_REGS); | 
					
						
							|  |  |  |     if (tf) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(ARG1, tf)); | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   } else { | 
					
						
							|  |  |  |     LOCAL_Error_TYPE = TYPE_ERROR_NUMBER; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } | 
					
						
							|  |  |  |   /* error handling */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   if (LOCAL_Error_TYPE && Yap_HandleError("number_codes/2")) { | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     goto restart_aux; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int cont_atom_concat3(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |   Term t3; | 
					
						
							|  |  |  |   Atom ats[2]; | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   Int i, max; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | restart_aux: | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |   t3 = Deref(ARG3); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   i = IntOfTerm(EXTRA_CBACK_ARG(3, 1)); | 
					
						
							|  |  |  |   max = IntOfTerm(EXTRA_CBACK_ARG(3, 2)); | 
					
						
							|  |  |  |   EXTRA_CBACK_ARG(3, 1) = MkIntTerm(i + 1); | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |   if (!Yap_SpliceAtom(t3, ats, i, max PASS_REGS) && | 
					
						
							|  |  |  |       LOCAL_Error_TYPE == YAP_NO_ERROR) { | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |     release_cut_fail(); | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |     if (i < max) { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(ARG1, MkAtomTerm(ats[0])) && | 
					
						
							|  |  |  |                        Yap_unify(ARG2, MkAtomTerm(ats[1]))); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     if (Yap_unify(ARG1, MkAtomTerm(ats[0])) && | 
					
						
							|  |  |  |         Yap_unify(ARG2, MkAtomTerm(ats[1]))) | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |       release_cut_succeed(); | 
					
						
							|  |  |  |     release_cut_fail(); | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |   /* Error handling */ | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |   if (LOCAL_Error_TYPE) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     if (Yap_HandleError("atom_concat/3")) { | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |       goto restart_aux; | 
					
						
							|  |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |   release_cut_fail(); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int atom_concat3(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |   Term t1; | 
					
						
							|  |  |  |   Term t2, t3, ot; | 
					
						
							|  |  |  |   Atom at; | 
					
						
							| 
									
										
										
										
											2016-08-24 02:04:49 -05:00
										 |  |  |   bool g1, g2, g3; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | restart_aux: | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   t1 = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |   t2 = Deref(ARG2); | 
					
						
							|  |  |  |   t3 = Deref(ARG3); | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |   g1 = Yap_IsGroundTerm(t1); | 
					
						
							|  |  |  |   g2 = Yap_IsGroundTerm(t2); | 
					
						
							|  |  |  |   g3 = Yap_IsGroundTerm(t3); | 
					
						
							| 
									
										
										
										
											2016-08-24 02:04:49 -05:00
										 |  |  |   if (g1 && g2) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     at = Yap_ConcatAtoms(t1, t2 PASS_REGS); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |     ot = ARG3; | 
					
						
							| 
									
										
										
										
											2016-08-24 02:04:49 -05:00
										 |  |  |   } else if (g1 && g3) { | 
					
						
							|  |  |  |     at = Yap_SubtractHeadAtom(t3, t1 PASS_REGS); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |     ot = ARG2; | 
					
						
							| 
									
										
										
										
											2016-08-24 02:04:49 -05:00
										 |  |  |   } else if (g2 && g3) { | 
					
						
							|  |  |  |     at = Yap_SubtractTailAtom(t3, t2 PASS_REGS); | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |     ot = ARG1; | 
					
						
							| 
									
										
										
										
											2016-08-24 02:04:49 -05:00
										 |  |  |   } else if (g3) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     EXTRA_CBACK_ARG(3, 1) = MkIntTerm(0); | 
					
						
							|  |  |  |     EXTRA_CBACK_ARG(3, 2) = MkIntTerm(Yap_AtomToLength(t3 PASS_REGS)); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn(cont_atom_concat3(PASS_REGS1)); | 
					
						
							| 
									
										
										
										
											2014-10-22 17:17:34 +01:00
										 |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |     LOCAL_Error_TYPE = INSTANTIATION_ERROR; | 
					
						
							|  |  |  |     at = NULL; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   pop_text_stack(l); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |   if (at) { | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |     if (Yap_unify(ot, MkAtomTerm(at))) { | 
					
						
							|  |  |  |       release_cut_succeed(); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       release_cut_fail(); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   /* Error handling */ | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |   if (LOCAL_Error_TYPE) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     if (Yap_HandleError("atom_concat/3")) { | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |       goto restart_aux; | 
					
						
							|  |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |   release_cut_fail(); | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-12 00:32:17 +01:00
										 |  |  | #define CastToNumeric(x) CastToNumeric__(x PASS_REGS)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Term CastToNumeric__(Atom at USES_REGS) { | 
					
						
							|  |  |  |   Term t; | 
					
						
							|  |  |  |   if ((t = Yap_AtomToNumber(MkAtomTerm(at) PASS_REGS))) | 
					
						
							| 
									
										
										
										
											2014-10-12 00:32:17 +01:00
										 |  |  |     return t; | 
					
						
							|  |  |  |   return MkAtomTerm(at); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int cont_atomic_concat3(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2014-10-12 00:32:17 +01:00
										 |  |  |   Term t3; | 
					
						
							|  |  |  |   Atom ats[2]; | 
					
						
							|  |  |  |   size_t i, max; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | restart_aux: | 
					
						
							| 
									
										
										
										
											2014-10-12 00:32:17 +01:00
										 |  |  |   t3 = Deref(ARG3); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   i = IntOfTerm(EXTRA_CBACK_ARG(3, 1)); | 
					
						
							|  |  |  |   max = IntOfTerm(EXTRA_CBACK_ARG(3, 2)); | 
					
						
							|  |  |  |   EXTRA_CBACK_ARG(3, 1) = MkIntTerm(i + 1); | 
					
						
							|  |  |  |   if (!Yap_SpliceAtom(t3, ats, i, max PASS_REGS)) { | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |     release_cut_fail(); | 
					
						
							| 
									
										
										
										
											2014-10-12 00:32:17 +01:00
										 |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     Term t1 = CastToNumeric(ats[0]); | 
					
						
							|  |  |  |     Term t2 = CastToNumeric(ats[1]); | 
					
						
							|  |  |  |     if (i < max) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(ARG1, t1) && Yap_unify(ARG2, t2)); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     if (Yap_unify(ARG1, t1) && Yap_unify(ARG2, t2)) | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |       release_cut_succeed(); | 
					
						
							|  |  |  |     release_cut_fail(); | 
					
						
							| 
									
										
										
										
											2014-10-12 00:32:17 +01:00
										 |  |  |   } | 
					
						
							|  |  |  |   /* Error handling */ | 
					
						
							|  |  |  |   if (LOCAL_Error_TYPE) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     if (Yap_HandleError("string_concat/3")) { | 
					
						
							| 
									
										
										
										
											2014-10-12 00:32:17 +01:00
										 |  |  |       goto restart_aux; | 
					
						
							|  |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2014-10-12 00:32:17 +01:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |   release_cut_fail(); | 
					
						
							| 
									
										
										
										
											2014-10-12 00:32:17 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int atomic_concat3(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   Term t1; | 
					
						
							| 
									
										
										
										
											2014-10-12 00:32:17 +01:00
										 |  |  |   Term t2, t3, ot; | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   Atom at = NULL; | 
					
						
							| 
									
										
										
										
											2016-08-24 02:04:49 -05:00
										 |  |  |   bool g1, g2, g3; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | restart_aux: | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   t1 = Deref(ARG1); | 
					
						
							|  |  |  |   t2 = Deref(ARG2); | 
					
						
							| 
									
										
										
										
											2014-10-12 00:32:17 +01:00
										 |  |  |   t3 = Deref(ARG3); | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |   g1 = Yap_IsGroundTerm(t1); | 
					
						
							|  |  |  |   g2 = Yap_IsGroundTerm(t2); | 
					
						
							|  |  |  |   g3 = Yap_IsGroundTerm(t3); | 
					
						
							| 
									
										
										
										
											2016-08-24 02:04:49 -05:00
										 |  |  |   if (g1 && g2) { | 
					
						
							|  |  |  |     at = Yap_ConcatAtomics(t1, t2 PASS_REGS); | 
					
						
							| 
									
										
										
										
											2014-10-12 00:32:17 +01:00
										 |  |  |     ot = ARG3; | 
					
						
							| 
									
										
										
										
											2016-08-24 02:04:49 -05:00
										 |  |  |   } else if (g1 && g3) { | 
					
						
							|  |  |  |     at = Yap_SubtractHeadAtom(t3, t1 PASS_REGS); | 
					
						
							| 
									
										
										
										
											2014-10-12 00:32:17 +01:00
										 |  |  |     ot = ARG2; | 
					
						
							| 
									
										
										
										
											2016-08-24 02:04:49 -05:00
										 |  |  |   } else if (g2 && g3) { | 
					
						
							|  |  |  |     at = Yap_SubtractTailAtom(t3, t2 PASS_REGS); | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |     ot = ARG1; | 
					
						
							| 
									
										
										
										
											2016-08-24 02:04:49 -05:00
										 |  |  |   } else if (g3) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     EXTRA_CBACK_ARG(3, 1) = MkIntTerm(0); | 
					
						
							|  |  |  |     EXTRA_CBACK_ARG(3, 2) = MkIntTerm(Yap_AtomicToLength(t3 PASS_REGS)); | 
					
						
							|  |  |  |     return cont_atomic_concat3(PASS_REGS1); | 
					
						
							| 
									
										
										
										
											2014-10-12 00:32:17 +01:00
										 |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |     LOCAL_Error_TYPE = INSTANTIATION_ERROR; | 
					
						
							|  |  |  |     at = NULL; | 
					
						
							| 
									
										
										
										
											2014-10-12 00:32:17 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |   if (at) { | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |     if (Yap_unify(ot, MkAtomTerm(at))) { | 
					
						
							|  |  |  |       release_cut_succeed(); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       release_cut_fail(); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   /* Error handling */ | 
					
						
							| 
									
										
										
										
											2014-10-12 00:32:17 +01:00
										 |  |  |   if (LOCAL_Error_TYPE) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     if (Yap_HandleError("atomic_concat/3")) { | 
					
						
							| 
									
										
										
										
											2014-10-12 00:32:17 +01:00
										 |  |  |       goto restart_aux; | 
					
						
							|  |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2016-08-24 02:04:49 -05:00
										 |  |  |       return false; | 
					
						
							| 
									
										
										
										
											2014-10-12 00:32:17 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |   release_cut_fail(); | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int cont_string_concat3(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   Term t3; | 
					
						
							|  |  |  |   Term ts[2]; | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |   size_t i, max; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | restart_aux: | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   t3 = Deref(ARG3); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   i = IntOfTerm(EXTRA_CBACK_ARG(3, 1)); | 
					
						
							|  |  |  |   max = IntOfTerm(EXTRA_CBACK_ARG(3, 2)); | 
					
						
							|  |  |  |   EXTRA_CBACK_ARG(3, 1) = MkIntTerm(i + 1); | 
					
						
							|  |  |  |   if (!Yap_SpliceString(t3, ts, i, max PASS_REGS)) { | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |     release_cut_fail(); | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     if (i < max) | 
					
						
							|  |  |  |       return Yap_unify(ARG1, ts[0]) && Yap_unify(ARG2, ts[1]); | 
					
						
							|  |  |  |     if (Yap_unify(ARG1, ts[0]) && Yap_unify(ARG2, ts[1])) | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |       release_cut_succeed(); | 
					
						
							|  |  |  |     release_cut_fail(); | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   /* Error handling */ | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |   if (LOCAL_Error_TYPE) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     if (Yap_HandleError("string_concat/3")) { | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |       goto restart_aux; | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       return FALSE; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |   release_cut_fail(); | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int string_concat3(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   Term t1; | 
					
						
							|  |  |  |   Term t2, t3, ot; | 
					
						
							| 
									
										
										
										
											2015-11-05 16:40:25 +00:00
										 |  |  |   Term tf = 0; | 
					
						
							| 
									
										
										
										
											2016-08-24 02:04:49 -05:00
										 |  |  |   bool g1, g2, g3; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | restart_aux: | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   t1 = Deref(ARG1); | 
					
						
							|  |  |  |   t2 = Deref(ARG2); | 
					
						
							|  |  |  |   t3 = Deref(ARG3); | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |   g1 = Yap_IsGroundTerm(t1); | 
					
						
							|  |  |  |   g2 = Yap_IsGroundTerm(t2); | 
					
						
							|  |  |  |   g3 = Yap_IsGroundTerm(t3); | 
					
						
							| 
									
										
										
										
											2016-08-24 02:04:49 -05:00
										 |  |  |   if (g1 && g2) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     tf = Yap_ConcatStrings(t1, t2 PASS_REGS); | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |     ot = ARG3; | 
					
						
							| 
									
										
										
										
											2016-08-24 02:04:49 -05:00
										 |  |  |   } else if (g1 && g3) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     tf = Yap_SubtractHeadString(t3, t1 PASS_REGS); | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |     ot = ARG2; | 
					
						
							| 
									
										
										
										
											2016-08-24 02:04:49 -05:00
										 |  |  |   } else if (g2 && g3) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     tf = Yap_SubtractTailString(t3, t2 PASS_REGS); | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |     ot = ARG1; | 
					
						
							| 
									
										
										
										
											2016-08-24 02:04:49 -05:00
										 |  |  |   } else if (g3) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     EXTRA_CBACK_ARG(3, 1) = MkIntTerm(0); | 
					
						
							|  |  |  |     EXTRA_CBACK_ARG(3, 2) = MkIntTerm(Yap_StringToLength(t3 PASS_REGS)); | 
					
						
							|  |  |  |     return cont_string_concat3(PASS_REGS1); | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  |     LOCAL_Error_TYPE = INSTANTIATION_ERROR; | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (tf) { | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |     if (Yap_unify(ot, tf)) { | 
					
						
							|  |  |  |       release_cut_succeed(); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |       release_cut_fail(); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   /* Error handling */ | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |   if (LOCAL_Error_TYPE) { | 
					
						
							| 
									
										
										
										
											2016-08-24 02:04:49 -05:00
										 |  |  |     if (Yap_HandleError("atom_concat/3")) { | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |       goto restart_aux; | 
					
						
							|  |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-12-06 23:24:01 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |   release_cut_fail(); | 
					
						
							| 
									
										
										
										
											2013-12-06 23:24:01 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int cont_string_code3(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2013-12-06 23:24:01 +00:00
										 |  |  |   Term t2; | 
					
						
							|  |  |  |   Int i, j; | 
					
						
							| 
									
										
										
										
											2015-09-21 17:05:36 -05:00
										 |  |  |   utf8proc_int32_t chr; | 
					
						
							|  |  |  |   const unsigned char *s; | 
					
						
							|  |  |  |   const unsigned char *s0; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | restart_aux: | 
					
						
							| 
									
										
										
										
											2013-12-06 23:24:01 +00:00
										 |  |  |   t2 = Deref(ARG2); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   s0 = UStringOfTerm(t2); | 
					
						
							|  |  |  |   i = IntOfTerm( | 
					
						
							|  |  |  |       EXTRA_CBACK_ARG(3, 1)); // offset in coded string, increases by 1..6
 | 
					
						
							|  |  |  |   j = IntOfTerm( | 
					
						
							|  |  |  |       EXTRA_CBACK_ARG(3, 2)); // offset in UNICODE string, always increases by 1
 | 
					
						
							|  |  |  |   s = (s0 + i) + get_utf8((unsigned char *)s0 + i, -1, &chr); | 
					
						
							| 
									
										
										
										
											2013-12-06 23:24:01 +00:00
										 |  |  |   if (s[0]) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     EXTRA_CBACK_ARG(3, 1) = MkIntTerm(s - s0); | 
					
						
							|  |  |  |     EXTRA_CBACK_ARG(3, 2) = MkIntTerm(j + 1); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn(Yap_unify(MkIntegerTerm(chr), ARG3) && | 
					
						
							|  |  |  |                      Yap_unify(MkIntegerTerm(j + 1), ARG1)); | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   if (Yap_unify(MkIntegerTerm(chr), ARG3) && | 
					
						
							|  |  |  |       Yap_unify(MkIntegerTerm(j), ARG1)) { | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |     release_cut_succeed(); | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     release_cut_fail(); | 
					
						
							| 
									
										
										
										
											2013-12-06 23:24:01 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   /* Error handling */ | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |   if (LOCAL_Error_TYPE) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     if (Yap_HandleError("string_code/3")) { | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |       goto restart_aux; | 
					
						
							|  |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |   release_cut_fail(); | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int string_code3(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2013-12-06 23:24:01 +00:00
										 |  |  |   Term t1; | 
					
						
							|  |  |  |   Term t2; | 
					
						
							| 
									
										
										
										
											2015-09-21 17:05:36 -05:00
										 |  |  |   const unsigned char *s; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | restart_aux: | 
					
						
							| 
									
										
										
										
											2013-12-06 23:24:01 +00:00
										 |  |  |   t1 = Deref(ARG1); | 
					
						
							|  |  |  |   t2 = Deref(ARG2); | 
					
						
							|  |  |  |   if (IsVarTerm(t2)) { | 
					
						
							|  |  |  |     LOCAL_Error_TYPE = INSTANTIATION_ERROR; | 
					
						
							|  |  |  |   } else if (!IsStringTerm(t2)) { | 
					
						
							|  |  |  |     LOCAL_Error_TYPE = TYPE_ERROR_STRING; | 
					
						
							|  |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     s = UStringOfTerm(t2); | 
					
						
							| 
									
										
										
										
											2013-12-06 23:24:01 +00:00
										 |  |  |     t1 = Deref(ARG1); | 
					
						
							|  |  |  |     if (IsVarTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |       EXTRA_CBACK_ARG(3, 1) = MkIntTerm(0); | 
					
						
							|  |  |  |       EXTRA_CBACK_ARG(3, 2) = MkIntTerm(0); | 
					
						
							|  |  |  |       return cont_string_code3(PASS_REGS1); | 
					
						
							|  |  |  |     } else if (!IsIntegerTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2013-12-06 23:24:01 +00:00
										 |  |  |       LOCAL_Error_TYPE = TYPE_ERROR_INTEGER; | 
					
						
							|  |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2015-09-21 17:05:36 -05:00
										 |  |  |       const unsigned char *ns = s; | 
					
						
							|  |  |  |       utf8proc_int32_t chr; | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |       Int indx = IntegerOfTerm(t1); | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |       if (indx <= 0) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |         if (indx < 0) { | 
					
						
							|  |  |  |           LOCAL_Error_TYPE = DOMAIN_ERROR_NOT_LESS_THAN_ZERO; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |         release_cut_fail(); | 
					
						
							| 
									
										
										
										
											2013-12-06 23:24:01 +00:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2016-07-30 23:08:59 -05:00
										 |  |  |       ns = skip_utf8(s, indx); | 
					
						
							| 
									
										
										
										
											2013-12-06 23:24:01 +00:00
										 |  |  |       if (ns == NULL) { | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |         release_cut_fail(); // silently fail?
 | 
					
						
							| 
									
										
										
										
											2013-12-06 23:24:01 +00:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2016-07-30 23:08:59 -05:00
										 |  |  |       get_utf8(ns, -1, &chr); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |       if (chr == '\0') | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |         release_cut_fail(); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |       if (Yap_unify(ARG3, MkIntegerTerm(chr))) | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |         release_cut_succeed(); | 
					
						
							|  |  |  |       release_cut_fail(); | 
					
						
							| 
									
										
										
										
											2013-12-06 23:24:01 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   /* Error handling */ | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |   if (LOCAL_Error_TYPE) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     if (Yap_HandleError("string_code/3")) { | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |       goto restart_aux; | 
					
						
							|  |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-12-06 23:24:01 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |   release_cut_fail(); | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int get_string_code3(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |   Term t1; | 
					
						
							|  |  |  |   Term t2; | 
					
						
							| 
									
										
										
										
											2015-09-21 17:05:36 -05:00
										 |  |  |   const unsigned char *s; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | restart_aux: | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |   t1 = Deref(ARG1); | 
					
						
							|  |  |  |   t2 = Deref(ARG2); | 
					
						
							|  |  |  |   if (IsVarTerm(t2)) { | 
					
						
							|  |  |  |     LOCAL_Error_TYPE = INSTANTIATION_ERROR; | 
					
						
							|  |  |  |   } else if (!IsStringTerm(t2)) { | 
					
						
							|  |  |  |     LOCAL_Error_TYPE = TYPE_ERROR_STRING; | 
					
						
							|  |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     s = UStringOfTerm(t2); | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |     t1 = Deref(ARG1); | 
					
						
							|  |  |  |     if (IsVarTerm(t1)) { | 
					
						
							|  |  |  |       LOCAL_Error_TYPE = INSTANTIATION_ERROR; | 
					
						
							| 
									
										
										
										
											2016-10-19 22:44:59 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     } else if (!IsIntegerTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |       LOCAL_Error_TYPE = TYPE_ERROR_INTEGER; | 
					
						
							|  |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2016-07-30 23:08:59 -05:00
										 |  |  |       const unsigned char *ns = s; | 
					
						
							| 
									
										
										
										
											2015-09-21 17:05:36 -05:00
										 |  |  |       utf8proc_int32_t chr; | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |       Int indx = IntegerOfTerm(t1); | 
					
						
							| 
									
										
										
										
											2016-07-30 23:08:59 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |       if (indx <= 0) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |         if (indx < 0) { | 
					
						
							|  |  |  |           LOCAL_Error_TYPE = DOMAIN_ERROR_NOT_LESS_THAN_ZERO; | 
					
						
							|  |  |  |         } else { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |           ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |         indx -= 1; | 
					
						
							| 
									
										
										
										
											2016-07-30 23:08:59 -05:00
										 |  |  |         ns = skip_utf8(ns, indx); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |         if (ns == NULL) { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |           ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |         } else { | 
					
						
							|  |  |  |           get_utf8(ns, -1, &chr); | 
					
						
							|  |  |  |           if (chr != '\0') | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |             ReleaseAndReturn(Yap_unify(ARG3, MkIntegerTerm(chr))); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(FALSE); // replace by error cod )e
 | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   /* Error handling */ | 
					
						
							|  |  |  |   if (LOCAL_Error_TYPE) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     if (Yap_HandleError("string_code/3")) { | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |       goto restart_aux; | 
					
						
							|  |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |   release_cut_fail(); | 
					
						
							| 
									
										
										
										
											2013-12-06 23:24:01 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int atom_concat2(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |   Term t1; | 
					
						
							|  |  |  |   Term *tailp; | 
					
						
							|  |  |  |   Int n; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | restart_aux: | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |   t1 = Deref(ARG1); | 
					
						
							|  |  |  |   n = Yap_SkipList(&t1, &tailp); | 
					
						
							|  |  |  |   if (*tailp != TermNil) { | 
					
						
							|  |  |  |     LOCAL_Error_TYPE = TYPE_ERROR_LIST; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     seq_tv_t *inpv = (seq_tv_t *)malloc(n * sizeof(seq_tv_t)), out; | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |     int i = 0; | 
					
						
							|  |  |  |     Atom at; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |     if (!inpv) { | 
					
						
							| 
									
										
										
										
											2015-09-25 10:57:26 +01:00
										 |  |  |       LOCAL_Error_TYPE = RESOURCE_ERROR_HEAP; | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |       free(inpv); | 
					
						
							|  |  |  |       goto error; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     while (t1 != TermNil) { | 
					
						
							|  |  |  |       inpv[i].type = YAP_STRING_ATOM; | 
					
						
							|  |  |  |       inpv[i].val.t = HeadOfTerm(t1); | 
					
						
							|  |  |  |       i++; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |       t1 = TailOfTerm(t1); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |     out.type = YAP_STRING_ATOM; | 
					
						
							|  |  |  |     if (!Yap_Concat_Text(n, inpv, &out PASS_REGS)) { | 
					
						
							|  |  |  |       free(inpv); | 
					
						
							|  |  |  |       goto error; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |     free(inpv); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     at = out.val.a; | 
					
						
							|  |  |  |     if (at) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(ARG2, MkAtomTerm(at))); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | error: | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |   /* Error handling */ | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |   if (LOCAL_Error_TYPE) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     if (Yap_HandleError("atom_concat/2")) { | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |       goto restart_aux; | 
					
						
							|  |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |   release_cut_fail(); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int string_concat2(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2014-04-09 12:39:29 +01:00
										 |  |  |   Term t1; | 
					
						
							|  |  |  |   Term *tailp; | 
					
						
							|  |  |  |   Int n; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | restart_aux: | 
					
						
							| 
									
										
										
										
											2014-04-09 12:39:29 +01:00
										 |  |  |   t1 = Deref(ARG1); | 
					
						
							|  |  |  |   n = Yap_SkipList(&t1, &tailp); | 
					
						
							|  |  |  |   if (*tailp != TermNil) { | 
					
						
							|  |  |  |     LOCAL_Error_TYPE = TYPE_ERROR_LIST; | 
					
						
							|  |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     seq_tv_t *inpv = (seq_tv_t *)malloc(n * sizeof(seq_tv_t)), out; | 
					
						
							| 
									
										
										
										
											2014-04-09 12:39:29 +01:00
										 |  |  |     int i = 0; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-09 12:39:29 +01:00
										 |  |  |     if (!inpv) { | 
					
						
							| 
									
										
										
										
											2015-09-25 10:57:26 +01:00
										 |  |  |       LOCAL_Error_TYPE = RESOURCE_ERROR_HEAP; | 
					
						
							| 
									
										
										
										
											2014-04-09 12:39:29 +01:00
										 |  |  |       free(inpv); | 
					
						
							|  |  |  |       goto error; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     while (t1 != TermNil) { | 
					
						
							|  |  |  |       inpv[i].type = YAP_STRING_STRING; | 
					
						
							|  |  |  |       inpv[i].val.t = HeadOfTerm(t1); | 
					
						
							|  |  |  |       i++; | 
					
						
							|  |  |  |       t1 = TailOfTerm(t1); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     out.type = YAP_STRING_STRING; | 
					
						
							|  |  |  |     if (!Yap_Concat_Text(n, inpv, &out PASS_REGS)) { | 
					
						
							|  |  |  |       free(inpv); | 
					
						
							|  |  |  |       goto error; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     free(inpv); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     if (out.val.t) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(ARG2, out.val.t)); | 
					
						
							| 
									
										
										
										
											2014-04-09 12:39:29 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | error: | 
					
						
							| 
									
										
										
										
											2014-04-09 12:39:29 +01:00
										 |  |  |   /* Error handling */ | 
					
						
							|  |  |  |   if (LOCAL_Error_TYPE) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     if (Yap_HandleError("string_code/3")) { | 
					
						
							| 
									
										
										
										
											2014-04-09 12:39:29 +01:00
										 |  |  |       goto restart_aux; | 
					
						
							|  |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2014-04-09 12:39:29 +01:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |   release_cut_fail(); | 
					
						
							| 
									
										
										
										
											2014-04-09 12:39:29 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int atomic_concat2(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |   Term t1; | 
					
						
							|  |  |  |   Term *tailp; | 
					
						
							|  |  |  |   Int n; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | restart_aux: | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |   t1 = Deref(ARG1); | 
					
						
							|  |  |  |   n = Yap_SkipList(&t1, &tailp); | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   if (*tailp != TermNil) { | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |     LOCAL_Error_TYPE = TYPE_ERROR_LIST; | 
					
						
							|  |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     seq_tv_t *inpv = (seq_tv_t *)malloc(n * sizeof(seq_tv_t)), out; | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |     int i = 0; | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |     Atom at; | 
					
						
							| 
									
										
										
										
											2015-12-15 09:28:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     if (n == 1) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(ARG2, HeadOfTerm(t1))); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |     if (!inpv) { | 
					
						
							| 
									
										
										
										
											2015-09-25 10:57:26 +01:00
										 |  |  |       LOCAL_Error_TYPE = RESOURCE_ERROR_HEAP; | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |       free(inpv); | 
					
						
							|  |  |  |       goto error; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     while (t1 != TermNil) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |       inpv[i].type = YAP_STRING_STRING | YAP_STRING_ATOM | YAP_STRING_INT | | 
					
						
							|  |  |  |                      YAP_STRING_FLOAT | YAP_STRING_BIG | YAP_STRING_CHARS | | 
					
						
							|  |  |  |                      YAP_STRING_CODES; | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |       inpv[i].val.t = HeadOfTerm(t1); | 
					
						
							|  |  |  |       i++; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |       t1 = TailOfTerm(t1); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |     out.type = YAP_STRING_ATOM; | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |     if (!Yap_Concat_Text(n, inpv, &out PASS_REGS)) { | 
					
						
							|  |  |  |       free(inpv); | 
					
						
							|  |  |  |       goto error; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |     free(inpv); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     at = out.val.a; | 
					
						
							|  |  |  |     if (at) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(ARG2, MkAtomTerm(at))); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | error: | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   /* Error handling */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   if (LOCAL_Error_TYPE && Yap_HandleError("atom_concat/3")) { | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |     goto restart_aux; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return FALSE; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int atomics_to_string2(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |   Term t1; | 
					
						
							|  |  |  |   Term *tailp; | 
					
						
							|  |  |  |   Int n; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | restart_aux: | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |   t1 = Deref(ARG1); | 
					
						
							|  |  |  |   n = Yap_SkipList(&t1, &tailp); | 
					
						
							|  |  |  |   if (*tailp != TermNil) { | 
					
						
							|  |  |  |     LOCAL_Error_TYPE = TYPE_ERROR_LIST; | 
					
						
							|  |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     seq_tv_t *inpv = (seq_tv_t *)malloc(n * sizeof(seq_tv_t)), out; | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |     int i = 0; | 
					
						
							|  |  |  |     Atom at; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |     if (!inpv) { | 
					
						
							| 
									
										
										
										
											2015-09-25 10:57:26 +01:00
										 |  |  |       LOCAL_Error_TYPE = RESOURCE_ERROR_HEAP; | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |       free(inpv); | 
					
						
							|  |  |  |       goto error; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     while (t1 != TermNil) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |       inpv[i].type = YAP_STRING_STRING | YAP_STRING_ATOM | YAP_STRING_INT | | 
					
						
							|  |  |  |                      YAP_STRING_FLOAT | YAP_STRING_BIG | YAP_STRING_TERM; | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |       inpv[i].val.t = HeadOfTerm(t1); | 
					
						
							|  |  |  |       i++; | 
					
						
							|  |  |  |       t1 = TailOfTerm(t1); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     out.type = YAP_STRING_STRING; | 
					
						
							|  |  |  |     if (!Yap_Concat_Text(n, inpv, &out PASS_REGS)) { | 
					
						
							|  |  |  |       free(inpv); | 
					
						
							|  |  |  |       goto error; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     free(inpv); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     at = out.val.a; | 
					
						
							|  |  |  |     if (at) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(ARG2, MkAtomTerm(at))); | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | error: | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |   /* Error handling */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   if (LOCAL_Error_TYPE && Yap_HandleError("atomics_to_string/2")) { | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |     goto restart_aux; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int atomics_to_string3(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |   Term t1, t2; | 
					
						
							|  |  |  |   Term *tailp; | 
					
						
							|  |  |  |   Int n; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | restart_aux: | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |   t1 = Deref(ARG1); | 
					
						
							|  |  |  |   t2 = Deref(ARG2); | 
					
						
							|  |  |  |   n = Yap_SkipList(&t1, &tailp); | 
					
						
							|  |  |  |   if (*tailp != TermNil) { | 
					
						
							|  |  |  |     LOCAL_Error_TYPE = TYPE_ERROR_LIST; | 
					
						
							|  |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     seq_tv_t *inpv = (seq_tv_t *)malloc((n * 2 - 1) * sizeof(seq_tv_t)), out; | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |     int i = 0; | 
					
						
							|  |  |  |     Atom at; | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |     if (!inpv) { | 
					
						
							| 
									
										
										
										
											2015-09-25 10:57:26 +01:00
										 |  |  |       LOCAL_Error_TYPE = RESOURCE_ERROR_HEAP; | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |       free(inpv); | 
					
						
							|  |  |  |       goto error; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     while (t1 != TermNil) { | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |       inpv[i].type = YAP_STRING_STRING | YAP_STRING_ATOM | YAP_STRING_INT | | 
					
						
							|  |  |  |                      YAP_STRING_FLOAT | YAP_STRING_BIG | YAP_STRING_TERM; | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |       inpv[i].val.t = HeadOfTerm(t1); | 
					
						
							|  |  |  |       i++; | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |       inpv[i].type = YAP_STRING_STRING | YAP_STRING_ATOM | YAP_STRING_INT | | 
					
						
							|  |  |  |                      YAP_STRING_FLOAT | YAP_STRING_BIG | YAP_STRING_TERM; | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |       inpv[i].val.t = t2; | 
					
						
							|  |  |  |       i++; | 
					
						
							|  |  |  |       t1 = TailOfTerm(t1); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     out.type = YAP_STRING_STRING; | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     if (!Yap_Concat_Text(2 * n - 1, inpv, &out PASS_REGS)) { | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |       free(inpv); | 
					
						
							|  |  |  |       goto error; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     free(inpv); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     at = out.val.a; | 
					
						
							|  |  |  |     if (at) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(ARG3, MkAtomTerm(at))); | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | error: | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |   /* Error handling */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   if (LOCAL_Error_TYPE && Yap_HandleError("atomics_to_string/3")) { | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  |     goto restart_aux; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-12-08 19:12:24 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-05 13:06:12 +01:00
										 |  |  |   /** @pred  atom_length(+ _A_,? _I_) is iso
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   The predicate holds when the first argument is an atom, and the | 
					
						
							|  |  |  |   second unifies with the number of characters forming that atom. If | 
					
						
							|  |  |  |   bound, _I_ must be a non-negative integer. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int atom_length(USES_REGS1) { | 
					
						
							|  |  |  |   Term t1 = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   Term t2 = Deref(ARG2); | 
					
						
							| 
									
										
										
										
											2016-02-28 19:32:55 +00:00
										 |  |  |   size_t len; | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2014-10-22 17:54:50 +01:00
										 |  |  |   if (!Yap_IsGroundTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |     Yap_Error(INSTANTIATION_ERROR, t1, "at first argument"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2014-10-22 17:54:50 +01:00
										 |  |  |   } else if (!IsAtomTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |     Yap_Error(TYPE_ERROR_ATOM, t1, "at first argument"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2014-10-22 17:54:50 +01:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   if (Yap_IsGroundTerm(t2)) { | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |     if (!IsIntegerTerm(t2)) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_INTEGER, t2, "atom_length/2"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     } else if ((Int)(len = IntegerOfTerm(t2)) < 0) { | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |       Yap_Error(DOMAIN_ERROR_NOT_LESS_THAN_ZERO, t2, "atom_length/2"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  | restart_aux: | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   len = Yap_AtomicToLength(t1 PASS_REGS); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |   if (len != (size_t)-1) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn(Yap_unify(ARG2, MkIntegerTerm(len))); | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |   /* error handling */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   if (LOCAL_Error_TYPE && Yap_HandleError("atom_length/2")) { | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |     goto restart_aux; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-05 13:06:12 +01:00
										 |  |  |   /** @pred  atomic_length(+ _A_,? _I_) is iso
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   The predicate holds when the first argument is a number or atom, and | 
					
						
							|  |  |  |   the second unifies with the number of characters needed to represent | 
					
						
							|  |  |  |   the number, or atom. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int atomic_length(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2014-10-22 17:54:50 +01:00
										 |  |  |   Term t1 = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |   Term t2 = Deref(ARG2); | 
					
						
							| 
									
										
										
										
											2016-02-28 19:32:55 +00:00
										 |  |  |   size_t len; | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2014-10-22 17:54:50 +01:00
										 |  |  |   if (!Yap_IsGroundTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |     Yap_Error(INSTANTIATION_ERROR, t1, "at first argument"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2014-10-22 17:54:50 +01:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |   if (IsNonVarTerm(t2)) { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |     if (!IsIntegerTerm(t2)) { | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |       Yap_Error(TYPE_ERROR_INTEGER, t2, "atom_length/2"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |     } else if ((Int)(len = IntegerOfTerm(t2)) < 0) { | 
					
						
							|  |  |  |       Yap_Error(DOMAIN_ERROR_NOT_LESS_THAN_ZERO, t2, "atom_length/2"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | restart_aux: | 
					
						
							|  |  |  |   len = Yap_AtomicToLength(t1 PASS_REGS); | 
					
						
							|  |  |  |   if (len != (size_t)-1) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn(Yap_unify(ARG2, MkIntegerTerm(len))); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |   /* error handling */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   if (LOCAL_Error_TYPE && Yap_HandleError("atomic_length/2")) { | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |     goto restart_aux; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int string_length(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |   Term t1; | 
					
						
							|  |  |  |   Term t2 = Deref(ARG2); | 
					
						
							| 
									
										
										
										
											2016-02-28 19:32:55 +00:00
										 |  |  |   size_t len; | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   if (Yap_IsGroundTerm(t2)) { | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if (!IsIntegerTerm(t2)) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_INTEGER, t2, "string_length/2"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  |     if (FALSE && (Int)(len = IntegerOfTerm(t2)) < 0) { | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |       Yap_Error(DOMAIN_ERROR_NOT_LESS_THAN_ZERO, t2, "string_length/2"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | restart_aux: | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   t1 = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   len = Yap_AtomicToLength(t1 PASS_REGS); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |   if (len != (size_t)-1) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn(Yap_unify(ARG2, MkIntegerTerm(len))); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |   /* error handling */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   if (LOCAL_Error_TYPE && Yap_HandleError("string_length/2")) { | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |     goto restart_aux; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  | /** @pred downcase_text_to_atom(+Text, -Atom)
 | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2016-07-30 23:08:59 -05:00
										 |  |  |  * Convert all upper case code-points in text _Text_ to  downcase. Unify the | 
					
						
							|  |  |  |  * result as atom _Atom_ with the second argument. | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static Int downcase_text_to_atom(USES_REGS1) { | 
					
						
							|  |  |  |   Term t1 = Deref(ARG1); | 
					
						
							|  |  |  |   Term t2 = Deref(ARG2); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |   if (!Yap_IsGroundTerm(t1)) { | 
					
						
							|  |  |  |     Yap_Error(INSTANTIATION_ERROR, t1, "at first argument"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (IsNonVarTerm(t2)) { | 
					
						
							|  |  |  |     if (!IsAtomTerm(t2)) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_ATOM, t2, "at second argument"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn((FALSE)); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   while (true) { | 
					
						
							|  |  |  |     Atom at = Yap_AtomicToLowAtom(t1); | 
					
						
							|  |  |  |     if (at == NULL) { | 
					
						
							|  |  |  |       if (LOCAL_Error_TYPE && Yap_HandleError("downcase_text_to_atom/2")) | 
					
						
							|  |  |  |         continue; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn(Yap_unify(MkAtomTerm(at), t2)); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** @pred upcase_text_to_atom(+Text, -Atom)
 | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2016-07-30 23:08:59 -05:00
										 |  |  |  * Convert all lower case code-points in text _Text_ to  up case. Unify the | 
					
						
							|  |  |  |  * result as atom _Atom_ with the second argument. | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static Int upcase_text_to_atom(USES_REGS1) { | 
					
						
							|  |  |  |   Term t1 = Deref(ARG1); | 
					
						
							|  |  |  |   Term t2 = Deref(ARG2); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |   if (!Yap_IsGroundTerm(t1)) { | 
					
						
							|  |  |  |     Yap_Error(INSTANTIATION_ERROR, t1, "at first argument"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (IsNonVarTerm(t2)) { | 
					
						
							|  |  |  |     if (!IsAtomTerm(t2)) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_ATOM, t2, "at second argument"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn((FALSE)); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   while (true) { | 
					
						
							|  |  |  |     Atom at = Yap_AtomicToUpAtom(t1); | 
					
						
							|  |  |  |     if (at == NULL) { | 
					
						
							|  |  |  |       if (LOCAL_Error_TYPE && Yap_HandleError("upcase_text_to_atom/2")) | 
					
						
							|  |  |  |         continue; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn(Yap_unify(MkAtomTerm(at), t2)); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** @pred downcase_text_to_string(+Text, -String)
 | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2016-07-30 23:08:59 -05:00
										 |  |  |  * Convert all upper case code-points in text _Text_ to  downcase. Unify the | 
					
						
							|  |  |  |  * result as string _String_ with the second argument. | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static Int downcase_text_to_string(USES_REGS1) { | 
					
						
							|  |  |  |   Term t1 = Deref(ARG1); | 
					
						
							|  |  |  |   Term t2 = Deref(ARG2); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |   if (!Yap_IsGroundTerm(t1)) { | 
					
						
							|  |  |  |     Yap_Error(INSTANTIATION_ERROR, t1, "at first argument"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (IsNonVarTerm(t2)) { | 
					
						
							|  |  |  |     if (!IsStringTerm(t2)) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_STRING, t2, "at second argument"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn((FALSE)); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   while (true) { | 
					
						
							|  |  |  |     Term t = Yap_AtomicToLowString(t1); | 
					
						
							|  |  |  |     if (t == TermZERO) { | 
					
						
							|  |  |  |       if (LOCAL_Error_TYPE && Yap_HandleError("downcase_text_to_string/2")) | 
					
						
							|  |  |  |         continue; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn(Yap_unify(t, t2)); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** @pred upcase_text_to_string(+Text, -String)
 | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2016-07-30 23:08:59 -05:00
										 |  |  |  * Convert all lower case code-points in text _Text_ to  up case. Unify the | 
					
						
							|  |  |  |  * result as string _String_ with the second argument. | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static Int upcase_text_to_string(USES_REGS1) { | 
					
						
							|  |  |  |   Term t1 = Deref(ARG1); | 
					
						
							|  |  |  |   Term t2 = Deref(ARG2); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |   if (!Yap_IsGroundTerm(t1)) { | 
					
						
							|  |  |  |     Yap_Error(INSTANTIATION_ERROR, t1, "at first argument"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (IsNonVarTerm(t2)) { | 
					
						
							|  |  |  |     if (!IsStringTerm(t2)) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_STRING, t2, "at second argument"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn((FALSE)); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   while (true) { | 
					
						
							|  |  |  |     Term t = Yap_AtomicToUpString(t1); | 
					
						
							|  |  |  |     if (t == TermZERO) { | 
					
						
							|  |  |  |       if (LOCAL_Error_TYPE && Yap_HandleError("upcase_text_to_string/2")) | 
					
						
							|  |  |  |         continue; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn(Yap_unify(t, t2)); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** @pred downcase_text_to_codes(+Text, -Codes)
 | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2016-07-30 23:08:59 -05:00
										 |  |  |  * Convert all upper case code-points in text _Text_ to  downcase. Unify the | 
					
						
							|  |  |  |  * result as a sequence of codes _Codes_ with the second argument. | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static Int downcase_text_to_codes(USES_REGS1) { | 
					
						
							|  |  |  |   Term t1 = Deref(ARG1); | 
					
						
							|  |  |  |   Term t2 = Deref(ARG2); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |   if (!Yap_IsGroundTerm(t1)) { | 
					
						
							|  |  |  |     Yap_Error(INSTANTIATION_ERROR, t1, "at first argument"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (IsNonVarTerm(t2)) { | 
					
						
							|  |  |  |     if (!Yap_IsListTerm(t2)) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_LIST, t2, "at second argument"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   while (true) { | 
					
						
							|  |  |  |     Term t = Yap_AtomicToLowListOfCodes(t1); | 
					
						
							|  |  |  |     if (t == TermZERO) { | 
					
						
							|  |  |  |       if (LOCAL_Error_TYPE && Yap_HandleError("downcase_text_to_codes/2")) | 
					
						
							|  |  |  |         continue; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn(Yap_unify(t, t2)); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** @pred upcase_text_to_codes(+Text, -Codes)
 | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2016-07-30 23:08:59 -05:00
										 |  |  |  * Convert all lower case code-points in text _Text_ to  up case. Unify the | 
					
						
							|  |  |  |  * result as a sequence of codes _Codes_ with the second argument. | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static Int upcase_text_to_codes(USES_REGS1) { | 
					
						
							|  |  |  |   Term t1 = Deref(ARG1); | 
					
						
							|  |  |  |   Term t2 = Deref(ARG2); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |   if (!Yap_IsGroundTerm(t1)) { | 
					
						
							|  |  |  |     Yap_Error(INSTANTIATION_ERROR, t1, "at first argument"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (IsNonVarTerm(t2)) { | 
					
						
							|  |  |  |     if (!Yap_IsListTerm(t2)) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_LIST, t2, "at second argument"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn((FALSE)); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   while (true) { | 
					
						
							|  |  |  |     Term t = Yap_AtomicToUpListOfCodes(t1); | 
					
						
							|  |  |  |     if (t == TermZERO) { | 
					
						
							|  |  |  |       if (LOCAL_Error_TYPE && Yap_HandleError("upcase_text_to_codes/2")) | 
					
						
							|  |  |  |         continue; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn(Yap_unify(t, t2)); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** @pred downcase_text_to_chars(+Text, -Chars)
 | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2016-07-30 23:08:59 -05:00
										 |  |  |  * Convert all upper case code-points in text _Text_ to  downcase. Unify the | 
					
						
							|  |  |  |  * result as a sequence of chars _Chars_ with the second argument. | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static Int downcase_text_to_chars(USES_REGS1) { | 
					
						
							|  |  |  |   Term t1 = Deref(ARG1); | 
					
						
							|  |  |  |   Term t2 = Deref(ARG2); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |   if (!Yap_IsGroundTerm(t1)) { | 
					
						
							|  |  |  |     Yap_Error(INSTANTIATION_ERROR, t1, "at first argument"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (IsNonVarTerm(t2)) { | 
					
						
							|  |  |  |     if (!Yap_IsListTerm(t2)) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_LIST, t2, "at second argument"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   while (true) { | 
					
						
							|  |  |  |     Term t = Yap_AtomicToLowListOfAtoms(t1); | 
					
						
							|  |  |  |     if (t == TermZERO) { | 
					
						
							|  |  |  |       if (LOCAL_Error_TYPE && Yap_HandleError("downcase_text_to_to_chars/2")) | 
					
						
							|  |  |  |         continue; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn(Yap_unify(t, t2)); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** @pred upcase_text_to_chars(+Text, -Chars)
 | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2016-07-30 23:08:59 -05:00
										 |  |  |  * Convert all lower case code-points in text _Text_ to  up case. Unify the | 
					
						
							|  |  |  |  * result as a sequence of chars _Chars_ with the second argument. | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static Int upcase_text_to_chars(USES_REGS1) { | 
					
						
							|  |  |  |   Term t1 = Deref(ARG1); | 
					
						
							|  |  |  |   Term t2 = Deref(ARG2); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |   if (!Yap_IsGroundTerm(t1)) { | 
					
						
							|  |  |  |     Yap_Error(INSTANTIATION_ERROR, t1, "at first argument"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (IsNonVarTerm(t2)) { | 
					
						
							|  |  |  |     if (!Yap_IsListTerm(t2)) { | 
					
						
							|  |  |  |       Yap_Error(TYPE_ERROR_LIST, t2, "at second argument"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn((FALSE)); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   while (true) { | 
					
						
							|  |  |  |     Term t = Yap_AtomicToUpListOfAtoms(t1); | 
					
						
							|  |  |  |     if (t == TermZERO) { | 
					
						
							|  |  |  |       if (LOCAL_Error_TYPE && Yap_HandleError("upcase_text_to_chars/2")) | 
					
						
							|  |  |  |         continue; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn(Yap_unify(t, t2)); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2016-05-30 11:22:47 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | /* split an atom into two sub-atoms */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int atom_split(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   Term t1 = Deref(ARG1); | 
					
						
							|  |  |  |   Term t2 = Deref(ARG2); | 
					
						
							|  |  |  |   size_t len; | 
					
						
							|  |  |  |   Term to1, to2; | 
					
						
							|  |  |  |   Atom at; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   if (IsVarTerm(t1)) { | 
					
						
							|  |  |  |     Yap_Error(INSTANTIATION_ERROR, t1, "$atom_split/4"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn((FALSE)); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (!IsAtomTerm(t1)) { | 
					
						
							|  |  |  |     Yap_Error(TYPE_ERROR_ATOM, t1, "$atom_split/4"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn((FALSE)); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (IsVarTerm(t2)) { | 
					
						
							|  |  |  |     Yap_Error(INSTANTIATION_ERROR, t2, "$atom_split/4"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn((FALSE)); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (!IsIntTerm(t2)) { | 
					
						
							|  |  |  |     Yap_Error(TYPE_ERROR_INTEGER, t2, "$atom_split/4"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn((FALSE)); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2013-11-04 00:03:05 +00:00
										 |  |  |   if ((Int)(len = IntOfTerm(t2)) < 0) { | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |     Yap_Error(DOMAIN_ERROR_NOT_LESS_THAN_ZERO, t2, "$atom_split/4"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn((FALSE)); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   at = AtomOfTerm(t1); | 
					
						
							| 
									
										
										
										
											2017-01-22 22:10:38 +00:00
										 |  |  |   char *s; | 
					
						
							|  |  |  |   unsigned char *s1, *s10, *s0; | 
					
						
							|  |  |  |   s = RepAtom(at)->StrOfAE; | 
					
						
							|  |  |  |   if (len > strlen(s)) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     ReleaseAndReturn((FALSE)); | 
					
						
							|  |  |  |   s1 = s10 = Malloc(len); | 
					
						
							| 
									
										
										
										
											2017-01-22 22:10:38 +00:00
										 |  |  |   s0 = RepAtom(at)->UStrOfAE; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   if (s1 + len > (unsigned char *)ASP - 1024) | 
					
						
							|  |  |  |     Yap_Error(RESOURCE_ERROR_STACK, t1, "$atom_split/4"); | 
					
						
							|  |  |  |   size_t j; | 
					
						
							|  |  |  |   for (j = 0; j < len; j++) { | 
					
						
							|  |  |  |     int32_t val; | 
					
						
							| 
									
										
										
										
											2017-01-22 22:10:38 +00:00
										 |  |  |     s0 += get_utf8(s0, 1, &val); | 
					
						
							|  |  |  |     s1 += put_utf8(s1, val); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   } | 
					
						
							|  |  |  |   s1[0] = '\0'; | 
					
						
							|  |  |  |   to1 = MkAtomTerm(Yap_ULookupAtom(s10)); | 
					
						
							| 
									
										
										
										
											2017-01-22 22:10:38 +00:00
										 |  |  |   to2 = MkAtomTerm(Yap_LookupAtom(s)); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   ReleaseAndReturn( | 
					
						
							|  |  |  |       (Yap_unify_constant(ARG3, to1) && Yap_unify_constant(ARG4, to2))); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-05 13:06:12 +01:00
										 |  |  |   /** @pred  atom_number(? _Atom_,? _Number_)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   The predicate holds when at least one of the arguments is ground | 
					
						
							|  |  |  |   (otherwise, an error message will be displayed). If the argument | 
					
						
							|  |  |  |    _Atom_ is an atom,  _Number_ must be the number corresponding | 
					
						
							|  |  |  |   to the characters in  _Atom_, otherwise the characters in | 
					
						
							|  |  |  |    _Atom_ must encode a number  _Number_. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int atom_number(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |   Term t1; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | restart_aux: | 
					
						
							|  |  |  |   t1 = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   if (Yap_IsGroundTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     Term tf = Yap_AtomToNumber(t1 PASS_REGS); | 
					
						
							|  |  |  |     if (tf) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(ARG2, tf)); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     /* ARG1 unbound */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     Term t = Deref(ARG2); | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     Atom af = Yap_NumberToAtom(t PASS_REGS); | 
					
						
							|  |  |  |     if (af) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(ARG1, MkAtomTerm(af))); | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   /* error handling */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   if (LOCAL_Error_TYPE && Yap_HandleError("atom_number/2")) { | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |     t1 = Deref(ARG1); | 
					
						
							|  |  |  |     goto restart_aux; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-06-05 13:06:12 +01:00
										 |  |  |   /** @pred  atom_number(? _String_,? _Number_)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   The predicate holds when at least one of the arguments is ground | 
					
						
							|  |  |  |   (otherwise, an error message will be displayed). If the argument | 
					
						
							|  |  |  |    _String_ is a string term,  _String_ must be the number corresponding | 
					
						
							|  |  |  |   to the characters in  _Atom_, otherwise the characters in | 
					
						
							|  |  |  |    _String_ must encode the number  _Number_. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int string_number(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |   Term t1; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | restart_aux: | 
					
						
							|  |  |  |   t1 = Deref(ARG1); | 
					
						
							| 
									
										
										
										
											2013-12-06 15:08:35 +00:00
										 |  |  |   if (Yap_IsGroundTerm(t1)) { | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |     Term tf = Yap_StringToNumber(t1 PASS_REGS); | 
					
						
							|  |  |  |     if (tf) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(ARG2, tf)); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |   } else { | 
					
						
							|  |  |  |     /* ARG1 unbound */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |     Term t = Deref(ARG2); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |     Term tf = Yap_NumberToString(t PASS_REGS); | 
					
						
							|  |  |  |     if (tf) | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       ReleaseAndReturn(Yap_unify(ARG1, tf)); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |   } | 
					
						
							|  |  |  |   /* error handling */ | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   if (LOCAL_Error_TYPE && Yap_HandleError("string_number/2")) { | 
					
						
							| 
									
										
										
										
											2013-12-02 14:49:41 +00:00
										 |  |  |     t1 = Deref(ARG1); | 
					
						
							|  |  |  |     goto restart_aux; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | #define SUB_ATOM_HAS_MIN 1
 | 
					
						
							|  |  |  | #define SUB_ATOM_HAS_SIZE 2
 | 
					
						
							|  |  |  | #define SUB_ATOM_HAS_AFTER 4
 | 
					
						
							|  |  |  | #define SUB_ATOM_HAS_VAL 8
 | 
					
						
							| 
									
										
										
										
											2016-11-02 00:16:36 -05:00
										 |  |  | #define SUB_ATOM_HAS_ATOM 16
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | #define SUB_ATOM_HAS_UTF8 32
 | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-22 22:10:38 +00:00
										 |  |  | static Term build_new_atomic(int mask, const unsigned char *p, size_t minv, | 
					
						
							|  |  |  |                              size_t len USES_REGS) { | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |   int n; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   seq_tv_t outv[5], inp; | 
					
						
							|  |  |  |   size_t cuts[3]; | 
					
						
							|  |  |  |   if (minv) { | 
					
						
							|  |  |  |     cuts[0] = minv; | 
					
						
							|  |  |  |     cuts[1] = minv + len; | 
					
						
							|  |  |  |     cuts[2] = 0; | 
					
						
							|  |  |  |     outv[0].type = 0; | 
					
						
							|  |  |  |     n = 1; | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     cuts[0] = minv + len; | 
					
						
							|  |  |  |     cuts[1] = 0; | 
					
						
							|  |  |  |     n = 0; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |   inp.type = YAP_STRING_CHARS; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   inp.enc = ENC_ISO_UTF8; | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |   inp.val.uc0 = p; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   outv[n + 1].type = 0; | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |   if (mask & SUB_ATOM_HAS_ATOM) { | 
					
						
							|  |  |  |     outv[n].type = YAP_STRING_ATOM; | 
					
						
							|  |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     outv[n].type = YAP_STRING_STRING; | 
					
						
							|  |  |  |     outv[n].val.c = Malloc(512); | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |   } | 
					
						
							|  |  |  |   int lvl = push_text_stack(PASS_REGS1); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   bool rc = Yap_Splice_Text(2 + n, cuts, &inp, outv PASS_REGS); | 
					
						
							|  |  |  |   pop_text_stack(lvl); | 
					
						
							|  |  |  |   if (!rc) | 
					
						
							|  |  |  |     return (false); | 
					
						
							|  |  |  |   if (mask & SUB_ATOM_HAS_ATOM) | 
					
						
							|  |  |  |     return (MkAtomTerm(outv[n].val.a)); | 
					
						
							|  |  |  |   return (outv[n].val.t); | 
					
						
							| 
									
										
										
										
											2013-05-15 17:12:01 -05:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-02 00:16:36 -05:00
										 |  |  | static int check_sub_atom_at(int minv, Atom at, Atom nat, size_t len) { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   const unsigned char *p1; | 
					
						
							|  |  |  |   const unsigned char *p2 = RepAtom(nat)->UStrOfAE; | 
					
						
							|  |  |  |   p1 = skip_utf8(RepAtom(at)->UStrOfAE, minv); | 
					
						
							|  |  |  |   return cmpn_utf8(p1, p2, len) == 0; | 
					
						
							| 
									
										
										
										
											2013-05-15 17:12:01 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-02 00:16:36 -05:00
										 |  |  | static int check_sub_string_at(int minv, const unsigned char *p1, | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |                                const unsigned char *p2, size_t len) { | 
					
						
							| 
									
										
										
										
											2016-11-02 00:16:36 -05:00
										 |  |  |   p1 = skip_utf8((unsigned char *)p1, minv); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   if (p1 == NULL || p2 == NULL) | 
					
						
							|  |  |  |     return p1 == p2; | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  |   return cmpn_utf8(p1, p2, len) == 0; | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-02 00:16:36 -05:00
										 |  |  | static int check_sub_string_bef(int max, Term at, Term nat) { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   size_t len = strlen_utf8(UStringOfTerm(nat)); | 
					
						
							|  |  |  |   int minv = max - len; | 
					
						
							|  |  |  |   const unsigned char *p1, *p2; | 
					
						
							|  |  |  |   int c1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if ((Int)(minv - len) < 0) | 
					
						
							|  |  |  |     return FALSE; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   p1 = skip_utf8((unsigned char *)UStringOfTerm(at), minv); | 
					
						
							|  |  |  |   p2 = UStringOfTerm(nat); | 
					
						
							|  |  |  |   while ((c1 = *p1++) == *p2++ && c1) | 
					
						
							|  |  |  |     ; | 
					
						
							|  |  |  |   return c1 == 0; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-02 00:16:36 -05:00
										 |  |  | static int check_sub_atom_bef(int max, Atom at, Atom nat) { | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |   const unsigned char *p1, *p2 = RepAtom(nat)->UStrOfAE; | 
					
						
							|  |  |  |   size_t len = strlen_utf8(p2); | 
					
						
							|  |  |  |   int minv = max - len; | 
					
						
							|  |  |  |   int c1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if ((Int)(minv - len) < 0) | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  |   p1 = skip_utf8(RepAtom(at)->UStrOfAE, minv); | 
					
						
							|  |  |  |   while ((c1 = *p1++) == *p2++ && c1) | 
					
						
							|  |  |  |     ; | 
					
						
							|  |  |  |   return c1 == 0; | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-03-03 23:15:54 +00:00
										 |  |  | static Int cont_sub_atomic(USES_REGS1) { | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |   Term tat1 = Deref(ARG1); | 
					
						
							|  |  |  |   Term tat5 = Deref(ARG5); | 
					
						
							|  |  |  |   int mask; | 
					
						
							|  |  |  |   size_t minv, len, after, sz; | 
					
						
							|  |  |  |   const unsigned char *p = NULL, *p5 = NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   mask = IntegerOfTerm(EXTRA_CBACK_ARG(5, 1)); | 
					
						
							|  |  |  |   minv = IntegerOfTerm(EXTRA_CBACK_ARG(5, 2)); | 
					
						
							|  |  |  |   len = IntegerOfTerm(EXTRA_CBACK_ARG(5, 3)); | 
					
						
							|  |  |  |   after = IntegerOfTerm(EXTRA_CBACK_ARG(5, 4)); | 
					
						
							|  |  |  |   sz = IntegerOfTerm(EXTRA_CBACK_ARG(5, 5)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!IsVarTerm(tat1)) { | 
					
						
							|  |  |  |     if (IsAtomTerm(tat1)) { | 
					
						
							|  |  |  |       p = AtomOfTerm(tat1)->UStrOfAE; | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       p = UStringOfTerm(tat1); | 
					
						
							| 
									
										
										
										
											2016-11-02 00:16:36 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (!IsVarTerm(tat5)) { | 
					
						
							|  |  |  |     if (IsAtomTerm(tat5)) { | 
					
						
							|  |  |  |       p5 = AtomOfTerm(tat5)->UStrOfAE; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |     } else { | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |       p5 = UStringOfTerm(tat5); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   /* we can have one of two cases: A5 bound or unbound */ | 
					
						
							|  |  |  |   if (mask & SUB_ATOM_HAS_VAL) { | 
					
						
							|  |  |  |     bool found = false; | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       const unsigned char *p1 = p; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       while (!found) { | 
					
						
							|  |  |  |         p = skip_utf8(p1, minv); | 
					
						
							|  |  |  |         if (cmpn_utf8(p, p5, len) == 0) { | 
					
						
							|  |  |  |           Yap_unify(ARG2, MkIntegerTerm(minv)); | 
					
						
							|  |  |  |           Yap_unify(ARG3, MkIntegerTerm(len)); | 
					
						
							|  |  |  |           Yap_unify(ARG4, MkIntegerTerm(after)); | 
					
						
							|  |  |  |           found = true; | 
					
						
							|  |  |  |           /* found one, check if there is any left */ | 
					
						
							|  |  |  |           while (minv <= sz - len) { | 
					
						
							|  |  |  |             int chr; | 
					
						
							|  |  |  |             p += get_utf8((unsigned char *)p, -1, &chr); | 
					
						
							|  |  |  |             after--; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |             minv++; | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |             if (cmpn_utf8(p, p5, len) == 0) | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |           if (minv == sz - len) | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |           after--; | 
					
						
							|  |  |  |           minv++; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2013-05-15 17:12:01 -05:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |     if (found) { | 
					
						
							|  |  |  |       if (minv > sz - len) | 
					
						
							|  |  |  |         cut_succeed(); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       cut_fail(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } else if (mask & SUB_ATOM_HAS_SIZE) { | 
					
						
							| 
									
										
										
										
											2017-01-22 22:10:38 +00:00
										 |  |  |     Term nat = build_new_atomic(mask, p, minv, len PASS_REGS); | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |     Yap_unify(ARG2, MkIntegerTerm(minv)); | 
					
						
							|  |  |  |     Yap_unify(ARG4, MkIntegerTerm(after)); | 
					
						
							|  |  |  |     Yap_unify(ARG5, nat); | 
					
						
							|  |  |  |     minv++; | 
					
						
							|  |  |  |     if (after-- == 0) | 
					
						
							|  |  |  |       cut_succeed(); | 
					
						
							|  |  |  |   } else if (mask & SUB_ATOM_HAS_MIN) { | 
					
						
							|  |  |  |     after = sz - (minv + len); | 
					
						
							| 
									
										
										
										
											2017-01-22 22:10:38 +00:00
										 |  |  |     Term nat = build_new_atomic(mask, p, minv, len PASS_REGS); | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |     Yap_unify(ARG3, MkIntegerTerm(len)); | 
					
						
							|  |  |  |     Yap_unify(ARG4, MkIntegerTerm(after)); | 
					
						
							|  |  |  |     Yap_unify(ARG5, nat); | 
					
						
							|  |  |  |     len++; | 
					
						
							|  |  |  |     if (after-- == 0) | 
					
						
							|  |  |  |       cut_succeed(); | 
					
						
							|  |  |  |   } else if (mask & SUB_ATOM_HAS_AFTER) { | 
					
						
							|  |  |  |     len = sz - (minv + after); | 
					
						
							| 
									
										
										
										
											2017-01-22 22:10:38 +00:00
										 |  |  |     Term nat = build_new_atomic(mask, p, minv, len PASS_REGS); | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |     Yap_unify(ARG2, MkIntegerTerm(minv)); | 
					
						
							|  |  |  |     Yap_unify(ARG3, MkIntegerTerm(len)); | 
					
						
							|  |  |  |     Yap_unify(ARG5, nat); | 
					
						
							|  |  |  |     minv++; | 
					
						
							|  |  |  |     if (len-- == 0) | 
					
						
							|  |  |  |       cut_succeed(); | 
					
						
							|  |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2017-01-22 22:10:38 +00:00
										 |  |  |     Term nat = build_new_atomic(mask, p, minv, len PASS_REGS); | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |     Yap_unify(ARG2, MkIntegerTerm(minv)); | 
					
						
							|  |  |  |     Yap_unify(ARG3, MkIntegerTerm(len)); | 
					
						
							|  |  |  |     Yap_unify(ARG4, MkIntegerTerm(after)); | 
					
						
							|  |  |  |     Yap_unify(ARG5, nat); | 
					
						
							|  |  |  |     len++; | 
					
						
							|  |  |  |     if (after-- == 0) { | 
					
						
							|  |  |  |       if (minv == sz) | 
					
						
							|  |  |  |         cut_succeed(); | 
					
						
							|  |  |  |       minv++; | 
					
						
							|  |  |  |       len = 0; | 
					
						
							|  |  |  |       after = sz - minv; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   EXTRA_CBACK_ARG(5, 1) = MkIntegerTerm(mask); | 
					
						
							|  |  |  |   EXTRA_CBACK_ARG(5, 2) = MkIntegerTerm(minv); | 
					
						
							|  |  |  |   EXTRA_CBACK_ARG(5, 3) = MkIntegerTerm(len); | 
					
						
							|  |  |  |   EXTRA_CBACK_ARG(5, 4) = MkIntegerTerm(after); | 
					
						
							|  |  |  |   EXTRA_CBACK_ARG(5, 5) = MkIntegerTerm(sz); | 
					
						
							|  |  |  |   return TRUE; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  | static Int sub_atomic(bool sub_atom, bool sub_string USES_REGS) { | 
					
						
							|  |  |  |   Term tat1, tbef, tsize, tafter, tout; | 
					
						
							|  |  |  |   int mask = SUB_ATOM_HAS_UTF8; | 
					
						
							|  |  |  |   size_t minv, len, after, sz; | 
					
						
							|  |  |  |   const unsigned char *p = NULL; | 
					
						
							|  |  |  |   int bnds = 0; | 
					
						
							|  |  |  |   Term nat = 0L; | 
					
						
							|  |  |  |   Atom at = NULL; | 
					
						
							| 
									
										
										
										
											2013-05-15 17:12:01 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |   int l = push_text_stack(); | 
					
						
							|  |  |  |   if (sub_atom) | 
					
						
							|  |  |  |     mask |= SUB_ATOM_HAS_ATOM; | 
					
						
							| 
									
										
										
										
											2016-11-02 00:16:36 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |   tat1 = Deref(ARG1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!IsVarTerm(tat1)) { | 
					
						
							|  |  |  |     if (sub_atom) { | 
					
						
							|  |  |  |       if (IsAtomTerm(tat1)) { | 
					
						
							|  |  |  |         p = AtomOfTerm(tat1)->UStrOfAE; | 
					
						
							|  |  |  |         sz = strlen_utf8(p); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |         Yap_Error(TYPE_ERROR_ATOM, tat1, "sub_atom/5"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |         ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |     } else if (sub_string) { | 
					
						
							|  |  |  |       if (IsStringTerm(tat1)) { | 
					
						
							|  |  |  |         p = UStringOfTerm(tat1); | 
					
						
							|  |  |  |         sz = strlen_utf8(p); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2017-02-20 14:39:30 +00:00
										 |  |  |         Yap_Error(TYPE_ERROR_STRING, tat1, "sub_string/5"); | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |         ReleaseAndReturn(false); | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2017-02-20 14:39:30 +00:00
										 |  |  |     } else { | 
					
						
							|  |  |  |       if ((p = Yap_TextToUTF8Buffer(tat1 PASS_REGS))) { | 
					
						
							|  |  |  |         sz = strlen_utf8(p); | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  |         ReleaseAndReturn(false) | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |     } | 
					
						
							|  |  |  |   } else { | 
					
						
							| 
									
										
										
										
											2017-02-20 14:39:30 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |     Yap_Error(INSTANTIATION_ERROR, tat1, "sub_atom/5: first variable\n"); | 
					
						
							|  |  |  |     ReleaseAndReturn(false); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   EXTRA_CBACK_ARG(5, 3) = MkIntegerTerm(0); | 
					
						
							|  |  |  |   tbef = Deref(ARG2); | 
					
						
							|  |  |  |   if (IsVarTerm(tbef)) { | 
					
						
							|  |  |  |     minv = 0; | 
					
						
							|  |  |  |   } else if (!IsIntegerTerm(tbef)) { | 
					
						
							|  |  |  |     Yap_Error(TYPE_ERROR_INTEGER, tbef, "sub_string/5"); | 
					
						
							|  |  |  |     ReleaseAndReturn(FALSE); | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     minv = IntegerOfTerm(tbef); | 
					
						
							|  |  |  |     if ((Int)minv < 0) { | 
					
						
							|  |  |  |       Yap_Error(DOMAIN_ERROR_NOT_LESS_THAN_ZERO, tbef, "sub_string/5"); | 
					
						
							|  |  |  |       ReleaseAndReturn(FALSE); | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     mask |= SUB_ATOM_HAS_MIN; | 
					
						
							|  |  |  |     bnds++; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (IsVarTerm(tsize = Deref(ARG3))) { | 
					
						
							|  |  |  |     len = 0; | 
					
						
							|  |  |  |   } else if (!IsIntegerTerm(tsize)) { | 
					
						
							|  |  |  |     Yap_Error(TYPE_ERROR_INTEGER, tsize, "sub_string/5"); | 
					
						
							|  |  |  |     ReleaseAndReturn(FALSE); | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     len = IntegerOfTerm(tsize); | 
					
						
							|  |  |  |     if ((Int)len < 0) { | 
					
						
							|  |  |  |       Yap_Error(DOMAIN_ERROR_NOT_LESS_THAN_ZERO, tsize, "sub_string/5"); | 
					
						
							|  |  |  |       ReleaseAndReturn(FALSE); | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     mask |= SUB_ATOM_HAS_SIZE; | 
					
						
							|  |  |  |     bnds++; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (IsVarTerm(tafter = Deref(ARG4))) { | 
					
						
							|  |  |  |     after = 0; | 
					
						
							|  |  |  |   } else if (!IsIntegerTerm(tafter)) { | 
					
						
							|  |  |  |     Yap_Error(TYPE_ERROR_INTEGER, tafter, "sub_string/5"); | 
					
						
							|  |  |  |     ReleaseAndReturn(FALSE); | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     after = IntegerOfTerm(tafter); | 
					
						
							|  |  |  |     if ((Int)after < 0) { | 
					
						
							|  |  |  |       Yap_Error(DOMAIN_ERROR_NOT_LESS_THAN_ZERO, tafter, "sub_string/5"); | 
					
						
							|  |  |  |       ReleaseAndReturn(FALSE); | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |     mask |= SUB_ATOM_HAS_AFTER; | 
					
						
							|  |  |  |     bnds++; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (!IsVarTerm(tout = Deref(ARG5))) { | 
					
						
							|  |  |  |     if (sub_atom) { | 
					
						
							|  |  |  |       if (!IsAtomTerm(tout)) { | 
					
						
							|  |  |  |         Yap_Error(TYPE_ERROR_ATOM, tout, "sub_atom/5"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |         ReleaseAndReturn(FALSE); | 
					
						
							|  |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |         Atom oat; | 
					
						
							|  |  |  |         mask |= SUB_ATOM_HAS_VAL | SUB_ATOM_HAS_SIZE; | 
					
						
							|  |  |  |         oat = AtomOfTerm(tout); | 
					
						
							|  |  |  |         len = strlen_utf8(RepAtom(oat)->UStrOfAE); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |     } else { | 
					
						
							|  |  |  |       if (!IsStringTerm(tout)) { | 
					
						
							|  |  |  |         Yap_Error(TYPE_ERROR_STRING, tout, "sub_string/5"); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |         ReleaseAndReturn(FALSE); | 
					
						
							| 
									
										
										
										
											2013-05-15 17:12:01 -05:00
										 |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |         mask |= SUB_ATOM_HAS_VAL | SUB_ATOM_HAS_SIZE; | 
					
						
							|  |  |  |         len = strlen_utf8(UStringOfTerm(tout)); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (!Yap_unify(ARG3, MkIntegerTerm(len))) | 
					
						
							|  |  |  |       release_cut_fail(); | 
					
						
							|  |  |  |     bnds += 2; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   /* the problem is deterministic if we have two cases */ | 
					
						
							|  |  |  |   if (bnds > 1) { | 
					
						
							|  |  |  |     int out = FALSE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if ((mask & (SUB_ATOM_HAS_MIN | SUB_ATOM_HAS_SIZE)) == | 
					
						
							|  |  |  |         (SUB_ATOM_HAS_MIN | SUB_ATOM_HAS_SIZE)) { | 
					
						
							|  |  |  |       if (minv + len > sz) | 
					
						
							|  |  |  |         release_cut_fail(); | 
					
						
							|  |  |  |       if ((Int)(after = (sz - (minv + len))) < 0) | 
					
						
							|  |  |  |         release_cut_fail(); | 
					
						
							| 
									
										
										
										
											2017-01-22 22:10:38 +00:00
										 |  |  |       nat = build_new_atomic(mask, p, minv, len PASS_REGS); | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |       if (!nat) | 
					
						
							|  |  |  |         release_cut_fail(); | 
					
						
							|  |  |  |       out = Yap_unify(ARG4, MkIntegerTerm(after)) && Yap_unify(ARG5, nat); | 
					
						
							|  |  |  |     } else if ((mask & (SUB_ATOM_HAS_MIN | SUB_ATOM_HAS_AFTER)) == | 
					
						
							|  |  |  |                (SUB_ATOM_HAS_MIN | SUB_ATOM_HAS_AFTER)) { | 
					
						
							|  |  |  |       if (sz < minv + after) | 
					
						
							|  |  |  |         release_cut_fail(); | 
					
						
							|  |  |  |       len = sz - (minv + after); | 
					
						
							| 
									
										
										
										
											2017-01-22 22:10:38 +00:00
										 |  |  |       nat = build_new_atomic(mask, p, minv, len PASS_REGS); | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |       if (!nat) | 
					
						
							|  |  |  |         release_cut_fail(); | 
					
						
							|  |  |  |       out = Yap_unify(ARG3, MkIntegerTerm(len)) && Yap_unify(ARG5, nat); | 
					
						
							|  |  |  |     } else if ((mask & (SUB_ATOM_HAS_SIZE | SUB_ATOM_HAS_AFTER)) == | 
					
						
							|  |  |  |                (SUB_ATOM_HAS_SIZE | SUB_ATOM_HAS_AFTER)) { | 
					
						
							|  |  |  |       if (len + after > sz) | 
					
						
							|  |  |  |         release_cut_fail(); | 
					
						
							|  |  |  |       minv = sz - (len + after); | 
					
						
							| 
									
										
										
										
											2017-01-22 22:10:38 +00:00
										 |  |  |       nat = build_new_atomic(mask, p, minv, len PASS_REGS); | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |       if (!nat) | 
					
						
							|  |  |  |         release_cut_fail(); | 
					
						
							|  |  |  |       out = Yap_unify(ARG2, MkIntegerTerm(minv)) && Yap_unify(ARG5, nat); | 
					
						
							|  |  |  |     } else if ((mask & (SUB_ATOM_HAS_MIN | SUB_ATOM_HAS_VAL)) == | 
					
						
							|  |  |  |                (SUB_ATOM_HAS_MIN | SUB_ATOM_HAS_VAL)) { | 
					
						
							|  |  |  |       if (sub_atom) | 
					
						
							|  |  |  |         out = check_sub_atom_at(minv, at, AtomOfTerm(nat), len); | 
					
						
							|  |  |  |       else | 
					
						
							|  |  |  |         out = check_sub_string_at(minv, p, UStringOfTerm(nat), len); | 
					
						
							|  |  |  |     } else if ((mask & (SUB_ATOM_HAS_AFTER | SUB_ATOM_HAS_VAL)) == | 
					
						
							|  |  |  |                (SUB_ATOM_HAS_AFTER | SUB_ATOM_HAS_VAL)) { | 
					
						
							|  |  |  |       if (sub_atom) | 
					
						
							|  |  |  |         out = check_sub_atom_bef(sz - after, at, AtomOfTerm(nat)); | 
					
						
							|  |  |  |       else | 
					
						
							|  |  |  |         out = check_sub_string_bef(sz - after, tat1, tout); | 
					
						
							|  |  |  |     } else if ((mask & (SUB_ATOM_HAS_SIZE | SUB_ATOM_HAS_VAL)) == | 
					
						
							|  |  |  |                (SUB_ATOM_HAS_SIZE | SUB_ATOM_HAS_VAL)) { | 
					
						
							|  |  |  |       if (!sub_atom) { | 
					
						
							|  |  |  |         out = (strlen_utf8(UStringOfTerm(tout)) == len); | 
					
						
							|  |  |  |         if (!out) | 
					
						
							|  |  |  |           release_cut_fail(); | 
					
						
							|  |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2017-01-22 22:10:38 +00:00
										 |  |  |         out = (strlen(RepAtom(AtomOfTerm(tout))->StrOfAE) == len); | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |         if (!out) | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |           release_cut_fail(); | 
					
						
							| 
									
										
										
										
											2013-05-15 17:12:01 -05:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |       if (len == sz) { | 
					
						
							|  |  |  |         out = out && Yap_unify(ARG1, ARG5) && | 
					
						
							|  |  |  |               Yap_unify(ARG2, MkIntegerTerm(0)) && | 
					
						
							|  |  |  |               Yap_unify(ARG4, MkIntegerTerm(0)); | 
					
						
							|  |  |  |       } else if (len > sz) { | 
					
						
							| 
									
										
										
										
											2016-11-04 11:36:48 -05:00
										 |  |  |         release_cut_fail(); | 
					
						
							| 
									
										
										
										
											2013-05-15 17:12:01 -05:00
										 |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |         mask |= SUB_ATOM_HAS_SIZE; | 
					
						
							|  |  |  |         minv = 0; | 
					
						
							|  |  |  |         after = sz - len; | 
					
						
							|  |  |  |         goto backtrackable; | 
					
						
							| 
									
										
										
										
											2013-05-15 17:12:01 -05:00
										 |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |     if (out) | 
					
						
							|  |  |  |       release_cut_succeed(); | 
					
						
							|  |  |  |     release_cut_fail(); | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     if (!(mask & SUB_ATOM_HAS_MIN)) | 
					
						
							|  |  |  |       minv = 0; | 
					
						
							|  |  |  |     if (!(mask & SUB_ATOM_HAS_SIZE)) | 
					
						
							|  |  |  |       len = 0; | 
					
						
							|  |  |  |     if (!(mask & SUB_ATOM_HAS_AFTER)) | 
					
						
							|  |  |  |       after = sz - (len + minv); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | backtrackable: | 
					
						
							|  |  |  |   EXTRA_CBACK_ARG(5, 1) = MkIntegerTerm(mask); | 
					
						
							|  |  |  |   EXTRA_CBACK_ARG(5, 2) = MkIntegerTerm(minv); | 
					
						
							|  |  |  |   EXTRA_CBACK_ARG(5, 3) = MkIntegerTerm(len); | 
					
						
							|  |  |  |   EXTRA_CBACK_ARG(5, 4) = MkIntegerTerm(after); | 
					
						
							|  |  |  |   EXTRA_CBACK_ARG(5, 5) = MkIntegerTerm(sz); | 
					
						
							|  |  |  |   ReleaseAndReturn(cont_sub_atomic(PASS_REGS1)); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  | /** @pred  sub_atom(+ _A_,? _Bef_, ? _Size_, ? _After_, ? _At_out_) is iso
 | 
					
						
							| 
									
										
										
										
											2015-06-18 07:57:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  | True when  _A_ and  _At_out_ are atoms such that the name of | 
					
						
							|  |  |  |  _At_out_ has size  _Size_ and is a sub-string of the name of | 
					
						
							|  |  |  |  _A_, such that  _Bef_ is the number of characters before and | 
					
						
							|  |  |  |  _After_ the number of characters afterwards. | 
					
						
							| 
									
										
										
										
											2015-06-18 07:57:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  | Note that  _A_ must always be known, but  _At_out_ can be unbound when | 
					
						
							|  |  |  | calling this built-in. If all the arguments for sub_atom/5 but  _A_ | 
					
						
							|  |  |  | are unbound, the built-in will backtrack through all possible | 
					
						
							|  |  |  | sub-strings of  _A_. | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |  */ | 
					
						
							|  |  |  | static Int sub_atom(USES_REGS1) { return (sub_atomic(true, false PASS_REGS)); } | 
					
						
							| 
									
										
										
										
											2013-12-04 23:01:30 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  | /** @pred  sub_string(+ _S_,? _Bef_, ? _Size_, ? _After_, ? _S_out_) is
 | 
					
						
							|  |  |  | iso | 
					
						
							| 
									
										
										
										
											2015-06-18 07:57:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  | True when  _S_ and  _S_out_ are strings such that the | 
					
						
							|  |  |  |  _S_out_ has size  _Size_ and is a sub-string of | 
					
						
							|  |  |  |  _S_,   _Bef_ is the number of characters before, and | 
					
						
							|  |  |  |  _After_ the number of characters afterwards. | 
					
						
							| 
									
										
										
										
											2015-06-18 07:57:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  | Note that  _S_ must always be known, but  _S_out_ can be unbound when | 
					
						
							|  |  |  | calling this built-in. If all the arguments for sub_string/5 but  _S_ | 
					
						
							|  |  |  | are unbound, the built-in will generate all possible | 
					
						
							|  |  |  | sub-strings of  _S_. | 
					
						
							| 
									
										
										
										
											2016-02-29 03:13:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |  */ | 
					
						
							|  |  |  | static Int sub_string(USES_REGS1) { return sub_atomic(false, true PASS_REGS); } | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  | static Int cont_current_atom(USES_REGS1) { | 
					
						
							|  |  |  |   Atom catom; | 
					
						
							|  |  |  |   Int i = IntOfTerm(EXTRA_CBACK_ARG(1, 2)); | 
					
						
							|  |  |  |   AtomEntry *ap; /* nasty hack for gcc on hpux */ | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |   /* protect current hash table line */ | 
					
						
							|  |  |  |   if (IsAtomTerm(EXTRA_CBACK_ARG(1, 1))) | 
					
						
							|  |  |  |     catom = AtomOfTerm(EXTRA_CBACK_ARG(1, 1)); | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     catom = NIL; | 
					
						
							|  |  |  |   if (catom == NIL) { | 
					
						
							|  |  |  |     i++; | 
					
						
							|  |  |  |     /* move away from current hash table line */ | 
					
						
							|  |  |  |     while (i < AtomHashTableSize) { | 
					
						
							|  |  |  |       READ_LOCK(HashChain[i].AERWLock); | 
					
						
							|  |  |  |       catom = HashChain[i].Entry; | 
					
						
							|  |  |  |       READ_UNLOCK(HashChain[i].AERWLock); | 
					
						
							|  |  |  |       if (catom != NIL) { | 
					
						
							|  |  |  |         break; | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |       i++; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |     if (i == AtomHashTableSize) { | 
					
						
							|  |  |  |       cut_fail(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   ap = RepAtom(catom); | 
					
						
							|  |  |  |   if (Yap_unify_constant(ARG1, MkAtomTerm(catom))) { | 
					
						
							|  |  |  |     READ_LOCK(ap->ARWLock); | 
					
						
							|  |  |  |     if (ap->NextOfAE == NIL) { | 
					
						
							|  |  |  |       READ_UNLOCK(ap->ARWLock); | 
					
						
							|  |  |  |       i++; | 
					
						
							|  |  |  |       while (i < AtomHashTableSize) { | 
					
						
							|  |  |  |         READ_LOCK(HashChain[i].AERWLock); | 
					
						
							|  |  |  |         catom = HashChain[i].Entry; | 
					
						
							|  |  |  |         READ_UNLOCK(HashChain[i].AERWLock); | 
					
						
							|  |  |  |         if (catom != NIL) { | 
					
						
							|  |  |  |           break; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         i++; | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |       if (i == AtomHashTableSize) { | 
					
						
							|  |  |  |         cut_fail(); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |       } else { | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |         EXTRA_CBACK_ARG(1, 1) = MkAtomTerm(catom); | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |     } else { | 
					
						
							|  |  |  |       EXTRA_CBACK_ARG(1, 1) = MkAtomTerm(ap->NextOfAE); | 
					
						
							|  |  |  |       READ_UNLOCK(ap->ARWLock); | 
					
						
							| 
									
										
										
										
											2016-11-08 01:37:36 -06:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |     EXTRA_CBACK_ARG(1, 2) = MkIntTerm(i); | 
					
						
							|  |  |  |     return (TRUE); | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     return (FALSE); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2013-05-09 18:00:41 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  | static Int current_atom(USES_REGS1) { /* current_atom(?Atom)
 | 
					
						
							|  |  |  |                                          */ | 
					
						
							|  |  |  |   Term t1 = Deref(ARG1); | 
					
						
							|  |  |  |   if (!IsVarTerm(t1)) { | 
					
						
							|  |  |  |     if (IsAtomTerm(t1)) | 
					
						
							|  |  |  |       cut_succeed(); | 
					
						
							|  |  |  |     else | 
					
						
							|  |  |  |       cut_fail(); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   READ_LOCK(HashChain[0].AERWLock); | 
					
						
							|  |  |  |   if (HashChain[0].Entry != NIL) { | 
					
						
							|  |  |  |     EXTRA_CBACK_ARG(1, 1) = MkAtomTerm(HashChain[0].Entry); | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     EXTRA_CBACK_ARG(1, 1) = MkIntTerm(0); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   READ_UNLOCK(HashChain[0].AERWLock); | 
					
						
							|  |  |  |   EXTRA_CBACK_ARG(1, 2) = MkIntTerm(0); | 
					
						
							|  |  |  |   return (cont_current_atom(PASS_REGS1)); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2014-09-11 14:06:57 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  | void Yap_InitBackAtoms(void) { | 
					
						
							|  |  |  |   Yap_InitCPredBack("$current_atom", 1, 2, current_atom, cont_current_atom, | 
					
						
							|  |  |  |                     SafePredFlag | SyncPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPredBack("atom_concat", 3, 2, atom_concat3, cont_atom_concat3, 0); | 
					
						
							|  |  |  |   Yap_InitCPredBack("atomic_concat", 3, 2, atomic_concat3, cont_atomic_concat3, | 
					
						
							|  |  |  |                     0); | 
					
						
							|  |  |  |   Yap_InitCPredBack("string_concat", 3, 2, string_concat3, cont_string_concat3, | 
					
						
							|  |  |  |                     0); | 
					
						
							|  |  |  |   Yap_InitCPredBack("sub_atom", 5, 5, sub_atom, cont_sub_atomic, 0); | 
					
						
							|  |  |  |   Yap_InitCPredBack("sub_string", 5, 5, sub_string, cont_sub_atomic, 0); | 
					
						
							|  |  |  |   Yap_InitCPredBack("string_code", 3, 1, string_code3, cont_string_code3, 0); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2014-09-11 14:06:57 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  | void Yap_InitAtomPreds(void) { | 
					
						
							|  |  |  |   Yap_InitCPred("name", 2, name, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("string_to_atom", 2, string_to_atom, 0); | 
					
						
							| 
									
										
										
										
											2017-06-05 13:06:12 +01:00
										 |  |  |   Yap_InitCPred("atom_to_string", 2, atom_to_string, 0); | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |   Yap_InitCPred("string_to_atomic", 2, string_to_atomic, 0); | 
					
						
							| 
									
										
										
										
											2017-06-05 13:06:12 +01:00
										 |  |  |   Yap_InitCPred("atomic_to_string", 2, atomic_to_string, 0); | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |   Yap_InitCPred("string_to_list", 2, string_to_list, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("char_code", 2, char_code, SafePredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("atom_chars", 2, atom_chars, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("atom_codes", 2, atom_codes, 0); | 
					
						
							| 
									
										
										
										
											2017-06-05 13:06:12 +01:00
										 |  |  |   Yap_InitCPred("atom_string", 2, atom_string, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("string_atom", 2, string_atom, 0); | 
					
						
							| 
									
										
										
										
											2016-11-16 17:06:37 -06:00
										 |  |  |   Yap_InitCPred("string_codes", 2, string_codes, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("string_chars", 2, string_chars, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("atom_length", 2, atom_length, SafePredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("atomic_length", 2, atomic_length, SafePredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("string_length", 2, string_length, SafePredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("$atom_split", 4, atom_split, SafePredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("number_chars", 2, number_chars, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("number_atom", 2, number_atom, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("number_string", 2, number_string, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("number_codes", 2, number_codes, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("atom_number", 2, atom_number, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("string_number", 2, string_number, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("$atom_concat", 2, atom_concat2, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("$string_concat", 2, string_concat2, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("atomic_concat", 2, atomic_concat2, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("atomics_to_string", 2, atomics_to_string2, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("atomics_to_string", 3, atomics_to_string3, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("get_string_code", 3, get_string_code3, 0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   Yap_InitCPred("downcase_text_to_atom", 2, downcase_text_to_atom, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("downcase_atom", 2, downcase_text_to_atom, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("upcase_text_to_atom", 2, upcase_text_to_atom, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("upcase_atom", 2, upcase_text_to_atom, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("downcase_text_to_string", 2, downcase_text_to_string, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("upcase_text_to_string", 2, upcase_text_to_string, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("downcase_text_to_codes", 2, downcase_text_to_codes, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("upcase_text_to_codes", 2, upcase_text_to_codes, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("downcase_text_to_chars", 2, downcase_text_to_chars, 0); | 
					
						
							|  |  |  |   Yap_InitCPred("upcase_text_to_chars", 2, upcase_text_to_chars, 0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* hiding and unhiding some predicates */ | 
					
						
							|  |  |  |   Yap_InitCPred("hide_atom", 1, hide_atom, SafePredFlag | SyncPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("hide", 1, hide_atom, SafePredFlag | SyncPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("unhide_atom", 1, unhide_atom, SafePredFlag | SyncPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("$hidden_atom", 1, hidden_atom, | 
					
						
							|  |  |  |                 HiddenPredFlag | SafePredFlag | SyncPredFlag); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | @} | 
					
						
							|  |  |  | */ |