| 
									
										
										
										
											2010-04-03 05:58:14 +01:00
										 |  |  | /************************************************************************
 | 
					
						
							|  |  |  | **                                                                     ** | 
					
						
							|  |  |  | **                   The YapTab/YapOr/OPTYap systems                   ** | 
					
						
							|  |  |  | **                                                                     ** | 
					
						
							|  |  |  | ** YapTab extends the Yap Prolog engine to support sequential tabling  ** | 
					
						
							|  |  |  | ** YapOr extends the Yap Prolog engine to support or-parallelism       ** | 
					
						
							|  |  |  | ** OPTYap extends the Yap Prolog engine to support or-parallel tabling ** | 
					
						
							|  |  |  | **                                                                     ** | 
					
						
							|  |  |  | **                                                                     ** | 
					
						
							|  |  |  | **      Yap Prolog was developed at University of Porto, Portugal      ** | 
					
						
							|  |  |  | **                                                                     ** | 
					
						
							|  |  |  | ************************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /************************************
 | 
					
						
							|  |  |  | **      Includes & Prototypes      ** | 
					
						
							|  |  |  | ************************************/ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "Yap.h"
 | 
					
						
							|  |  |  | #if defined(YAPOR) || defined(TABLING)
 | 
					
						
							|  |  |  | #include "Yatom.h"
 | 
					
						
							| 
									
										
										
										
											2009-10-23 14:22:17 +01:00
										 |  |  | #include "YapHeap.h"
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  | #include "SWI-Prolog.h"
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #ifdef YAPOR
 | 
					
						
							| 
									
										
										
										
											2011-06-01 18:51:12 +01:00
										 |  |  | #if HAVE_STRING_H
 | 
					
						
							|  |  |  | #include <string.h>
 | 
					
						
							|  |  |  | #endif /* HAVE_STRING_H */
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #if HAVE_SYS_TIME_H
 | 
					
						
							|  |  |  | #include <sys/time.h>
 | 
					
						
							| 
									
										
										
										
											2005-06-03 18:28:11 +00:00
										 |  |  | #endif /* HAVE_SYS_TIME_H */
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #include "or.macros.h"
 | 
					
						
							|  |  |  | #endif /* YAPOR */
 | 
					
						
							|  |  |  | #ifdef TABLING
 | 
					
						
							|  |  |  | #include "tab.macros.h"
 | 
					
						
							|  |  |  | #endif /* TABLING */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef TABLING
 | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | static Int p_freeze_choice_point( USES_REGS1 ); | 
					
						
							|  |  |  | static Int p_wake_choice_point( USES_REGS1 ); | 
					
						
							|  |  |  | static Int p_abolish_frozen_choice_points_until( USES_REGS1 ); | 
					
						
							|  |  |  | static Int p_abolish_frozen_choice_points_all( USES_REGS1 ); | 
					
						
							|  |  |  | static Int p_table( USES_REGS1 ); | 
					
						
							|  |  |  | static Int p_tabling_mode( USES_REGS1 ); | 
					
						
							|  |  |  | static Int p_abolish_table( USES_REGS1 ); | 
					
						
							|  |  |  | static Int p_abolish_all_tables( USES_REGS1 ); | 
					
						
							| 
									
										
										
										
											2011-05-25 20:08:04 +01:00
										 |  |  | static Int p_abolish_all_local_tables( USES_REGS1 ); | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | static Int p_show_tabled_predicates( USES_REGS1 ); | 
					
						
							|  |  |  | static Int p_show_table( USES_REGS1 ); | 
					
						
							|  |  |  | static Int p_show_all_tables( USES_REGS1 ); | 
					
						
							| 
									
										
										
										
											2011-05-25 20:08:04 +01:00
										 |  |  | static Int p_show_all_local_tables( USES_REGS1 ); | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | static Int p_show_global_trie( USES_REGS1 ); | 
					
						
							|  |  |  | static Int p_show_statistics_table( USES_REGS1 ); | 
					
						
							|  |  |  | static Int p_show_statistics_tabling( USES_REGS1 ); | 
					
						
							|  |  |  | static Int p_show_statistics_global_trie( USES_REGS1 ); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif /* TABLING */
 | 
					
						
							| 
									
										
										
										
											2011-06-21 15:19:07 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef YAPOR
 | 
					
						
							| 
									
										
										
										
											2011-06-21 15:19:07 +01:00
										 |  |  | static Int p_parallel_mode( USES_REGS1 ); | 
					
						
							|  |  |  | static Int p_yapor_start( USES_REGS1 ); | 
					
						
							|  |  |  | static Int p_yapor_workers( USES_REGS1 ); | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | static Int p_worker( USES_REGS1 ); | 
					
						
							|  |  |  | static Int p_parallel_new_answer( USES_REGS1 ); | 
					
						
							|  |  |  | static Int p_show_statistics_or( USES_REGS1 ); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* YAPOR */
 | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | #if defined(YAPOR) && defined(TABLING)
 | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | static Int p_show_statistics_opt( USES_REGS1 ); | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | #endif /* YAPOR && TABLING */
 | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | static Int p_get_optyap_statistics( USES_REGS1 ); | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef YAPOR
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | static inline realtime current_time(void); | 
					
						
							|  |  |  | static inline int parallel_new_answer_putchar(int sno, int ch); | 
					
						
							|  |  |  | static inline void show_answers(void); | 
					
						
							|  |  |  | static inline void answer_to_stdout(char *answer); | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | #endif /* YAPOR */
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | #ifdef TABLING
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  | static inline long show_statistics_table_entries(IOSTREAM *out); | 
					
						
							|  |  |  | static inline long show_statistics_subgoal_frames(IOSTREAM *out); | 
					
						
							|  |  |  | static inline long show_statistics_dependency_frames(IOSTREAM *out); | 
					
						
							|  |  |  | static inline long show_statistics_subgoal_trie_nodes(IOSTREAM *out); | 
					
						
							|  |  |  | static inline long show_statistics_answer_trie_nodes(IOSTREAM *out); | 
					
						
							|  |  |  | static inline long show_statistics_subgoal_trie_hashes(IOSTREAM *out); | 
					
						
							|  |  |  | static inline long show_statistics_answer_trie_hashes(IOSTREAM *out); | 
					
						
							|  |  |  | static inline long show_statistics_global_trie_nodes(IOSTREAM *out); | 
					
						
							|  |  |  | static inline long show_statistics_global_trie_hashes(IOSTREAM *out); | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | #endif /* TABLING */
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef YAPOR
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  | static inline long show_statistics_or_frames(IOSTREAM *out); | 
					
						
							|  |  |  | static inline long show_statistics_query_goal_solution_frames(IOSTREAM *out); | 
					
						
							|  |  |  | static inline long show_statistics_query_goal_answer_frames(IOSTREAM *out); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* YAPOR */
 | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | #if defined(YAPOR) && defined(TABLING)
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  | static inline long show_statistics_suspension_frames(IOSTREAM *out); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef TABLING_INNER_CUTS
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  | static inline long show_statistics_table_subgoal_solution_frames(IOSTREAM *out); | 
					
						
							|  |  |  | static inline long show_statistics_table_subgoal_answer_frames(IOSTREAM *out); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* TABLING_INNER_CUTS */
 | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | #endif /* YAPOR && TABLING */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-03 05:58:14 +01:00
										 |  |  | /************************************
 | 
					
						
							|  |  |  | **      Macros & Declarations      ** | 
					
						
							|  |  |  | ************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef YAPOR
 | 
					
						
							|  |  |  | #define TIME_RESOLUTION 1000000
 | 
					
						
							|  |  |  | static int length_answer; | 
					
						
							|  |  |  | static qg_ans_fr_ptr actual_answer; | 
					
						
							|  |  |  | #endif /* YAPOR */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*******************************
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | **      Global functions      ** | 
					
						
							| 
									
										
										
										
											2010-04-03 05:58:14 +01:00
										 |  |  | *******************************/ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-26 22:19:48 +00:00
										 |  |  | void Yap_init_optyap_preds(void) { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #ifdef TABLING
 | 
					
						
							| 
									
										
										
										
											2010-03-09 14:48:20 +00:00
										 |  |  |   Yap_InitCPred("freeze_choice_point", 1, p_freeze_choice_point, SafePredFlag|SyncPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("wake_choice_point", 1, p_wake_choice_point, SafePredFlag|SyncPredFlag); | 
					
						
							| 
									
										
										
										
											2010-05-18 17:34:52 +01:00
										 |  |  |   Yap_InitCPred("abolish_frozen_choice_points", 1, p_abolish_frozen_choice_points_until, SafePredFlag|SyncPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("abolish_frozen_choice_points", 0, p_abolish_frozen_choice_points_all, SafePredFlag|SyncPredFlag); | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |   Yap_InitCPred("$c_table", 2, p_table, SafePredFlag|SyncPredFlag|HiddenPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("$c_tabling_mode", 3, p_tabling_mode, SafePredFlag|SyncPredFlag|HiddenPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("$c_abolish_table", 2, p_abolish_table, SafePredFlag|SyncPredFlag|HiddenPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("abolish_all_tables", 0, p_abolish_all_tables, SafePredFlag|SyncPredFlag); | 
					
						
							| 
									
										
										
										
											2011-05-25 20:08:04 +01:00
										 |  |  |   Yap_InitCPred("abolish_all_local_tables", 0, p_abolish_all_local_tables, SafePredFlag|SyncPredFlag); | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Yap_InitCPred("show_tabled_predicates", 1, p_show_tabled_predicates, SafePredFlag|SyncPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("$c_show_table", 3, p_show_table, SafePredFlag|SyncPredFlag|HiddenPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("show_all_tables", 1, p_show_all_tables, SafePredFlag|SyncPredFlag); | 
					
						
							| 
									
										
										
										
											2011-05-25 20:08:04 +01:00
										 |  |  |   Yap_InitCPred("show_all_local_tables", 1, p_show_all_local_tables, SafePredFlag|SyncPredFlag); | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Yap_InitCPred("show_global_trie", 1, p_show_global_trie, SafePredFlag|SyncPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("$c_table_statistics", 3, p_show_statistics_table, SafePredFlag|SyncPredFlag|HiddenPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("tabling_statistics", 1, p_show_statistics_tabling, SafePredFlag|SyncPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("global_trie_statistics", 1, p_show_statistics_global_trie, SafePredFlag|SyncPredFlag); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif /* TABLING */
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef YAPOR
 | 
					
						
							| 
									
										
										
										
											2011-06-21 15:19:07 +01:00
										 |  |  |   Yap_InitCPred("parallel_mode", 1, p_parallel_mode, SafePredFlag|SyncPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("$c_yapor_start", 0, p_yapor_start, SafePredFlag|SyncPredFlag|HiddenPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("$c_yapor_workers", 1, p_yapor_workers, SafePredFlag|SyncPredFlag|HiddenPredFlag); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   Yap_InitCPred("$c_worker", 0, p_worker, SafePredFlag|SyncPredFlag|HiddenPredFlag); | 
					
						
							|  |  |  |   Yap_InitCPred("$c_parallel_new_answer", 1, p_parallel_new_answer, SafePredFlag|SyncPredFlag|HiddenPredFlag); | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Yap_InitCPred("or_statistics", 1, p_show_statistics_or, SafePredFlag|SyncPredFlag); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* YAPOR */
 | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | #if defined(YAPOR) && defined(TABLING)
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Yap_InitCPred("opt_statistics", 1, p_show_statistics_opt, SafePredFlag|SyncPredFlag); | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | #endif /* YAPOR && TABLING */
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   Yap_InitCPred("$c_get_optyap_statistics", 3, p_get_optyap_statistics, SafePredFlag|SyncPredFlag|HiddenPredFlag); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef YAPOR
 | 
					
						
							|  |  |  | void finish_yapor(void) { | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   GLOBAL_execution_time = current_time() - GLOBAL_execution_time; | 
					
						
							| 
									
										
										
										
											2011-06-21 15:19:07 +01:00
										 |  |  |   GLOBAL_parallel_mode = PARALLEL_MODE_ON; | 
					
						
							|  |  |  |   /*  show_answers(); */ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   return; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif /* YAPOR */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | /***********************************
 | 
					
						
							|  |  |  | **      Tabling C Predicates      ** | 
					
						
							|  |  |  | ***********************************/ | 
					
						
							| 
									
										
										
										
											2010-01-14 15:58:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef TABLING
 | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | static Int p_freeze_choice_point( USES_REGS1 ) { | 
					
						
							| 
									
										
										
										
											2010-05-18 17:34:52 +01:00
										 |  |  |   if (IsVarTerm(Deref(ARG1))) { | 
					
						
							|  |  |  |     Int offset = freeze_current_cp(); | 
					
						
							|  |  |  |     return Yap_unify(ARG1, MkIntegerTerm(offset)); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   } | 
					
						
							|  |  |  |   return (FALSE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | static Int p_wake_choice_point( USES_REGS1 ) { | 
					
						
							| 
									
										
										
										
											2010-05-18 17:34:52 +01:00
										 |  |  |   Term term_offset = Deref(ARG1); | 
					
						
							|  |  |  |   if (IsIntegerTerm(term_offset)) | 
					
						
							|  |  |  |     wake_frozen_cp(IntegerOfTerm(term_offset)); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   return (FALSE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | static Int p_abolish_frozen_choice_points_until( USES_REGS1 ) { | 
					
						
							| 
									
										
										
										
											2010-05-18 17:34:52 +01:00
										 |  |  |   Term term_offset = Deref(ARG1); | 
					
						
							|  |  |  |   if (IsIntegerTerm(term_offset)) | 
					
						
							|  |  |  |     abolish_frozen_cps_until(IntegerOfTerm(term_offset)); | 
					
						
							|  |  |  |   return (TRUE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | static Int p_abolish_frozen_choice_points_all( USES_REGS1 ) { | 
					
						
							| 
									
										
										
										
											2010-05-18 17:34:52 +01:00
										 |  |  |   abolish_frozen_cps_all(); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   return (TRUE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | static Int p_table( USES_REGS1 ) { | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   Term mod, t; | 
					
						
							| 
									
										
										
										
											2003-11-05 16:12:25 +00:00
										 |  |  |   PredEntry *pe; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   Atom at; | 
					
						
							|  |  |  |   int arity; | 
					
						
							|  |  |  |   tab_ent_ptr tab_ent; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   mod = Deref(ARG1); | 
					
						
							|  |  |  |   t = Deref(ARG2); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   if (IsAtomTerm(t)) { | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |     at = AtomOfTerm(t); | 
					
						
							| 
									
										
										
										
											2001-11-15 00:01:43 +00:00
										 |  |  |     pe = RepPredProp(PredPropByAtom(at, mod)); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |     arity = 0; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   } else if (IsApplTerm(t)) { | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |     at = NameOfFunctor(FunctorOfTerm(t)); | 
					
						
							|  |  |  |     pe = RepPredProp(PredPropByFunc(FunctorOfTerm(t), mod)); | 
					
						
							|  |  |  |     arity = ArityOfFunctor(FunctorOfTerm(t)); | 
					
						
							|  |  |  |   } else | 
					
						
							|  |  |  |     return (FALSE); | 
					
						
							|  |  |  |   if (pe->PredFlags & TabledPredFlag) | 
					
						
							|  |  |  |     return (TRUE);  /* predicate already tabled */ | 
					
						
							|  |  |  |   if (pe->cs.p_code.FirstClause) | 
					
						
							|  |  |  |     return (FALSE);  /* predicate already compiled */ | 
					
						
							|  |  |  |   pe->PredFlags |= TabledPredFlag; | 
					
						
							|  |  |  |   new_table_entry(tab_ent, pe, at, arity); | 
					
						
							|  |  |  |   pe->TableOfPred = tab_ent; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   return (TRUE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | static Int p_tabling_mode( USES_REGS1 ) { | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   Term mod, t, tvalue; | 
					
						
							|  |  |  |   tab_ent_ptr tab_ent; | 
					
						
							| 
									
										
										
										
											2003-11-05 16:12:25 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   mod = Deref(ARG1); | 
					
						
							|  |  |  |   t = Deref(ARG2); | 
					
						
							|  |  |  |   if (IsAtomTerm(t)) | 
					
						
							|  |  |  |     tab_ent = RepPredProp(PredPropByAtom(AtomOfTerm(t), mod))->TableOfPred; | 
					
						
							|  |  |  |   else if (IsApplTerm(t)) | 
					
						
							|  |  |  |     tab_ent = RepPredProp(PredPropByFunc(FunctorOfTerm(t), mod))->TableOfPred; | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     return (FALSE); | 
					
						
							|  |  |  |   tvalue = Deref(ARG3); | 
					
						
							|  |  |  |   if (IsVarTerm(tvalue)) { | 
					
						
							|  |  |  |     t = TermNil; | 
					
						
							|  |  |  |     if (IsMode_LocalTrie(TabEnt_flags(tab_ent))) | 
					
						
							|  |  |  |       t = MkPairTerm(MkAtomTerm(AtomLocalTrie), t); | 
					
						
							|  |  |  |     else if (IsMode_GlobalTrie(TabEnt_flags(tab_ent))) | 
					
						
							|  |  |  |       t = MkPairTerm(MkAtomTerm(AtomGlobalTrie), t); | 
					
						
							|  |  |  |     if (IsMode_ExecAnswers(TabEnt_flags(tab_ent))) | 
					
						
							|  |  |  |       t = MkPairTerm(MkAtomTerm(AtomExecAnswers), t); | 
					
						
							|  |  |  |     else if (IsMode_LoadAnswers(TabEnt_flags(tab_ent))) | 
					
						
							|  |  |  |       t = MkPairTerm(MkAtomTerm(AtomLoadAnswers), t); | 
					
						
							|  |  |  |     if (IsMode_Batched(TabEnt_flags(tab_ent))) | 
					
						
							|  |  |  |       t = MkPairTerm(MkAtomTerm(AtomBatched), t); | 
					
						
							|  |  |  |     else if (IsMode_Local(TabEnt_flags(tab_ent))) | 
					
						
							|  |  |  |       t = MkPairTerm(MkAtomTerm(AtomLocal), t); | 
					
						
							|  |  |  |     t = MkPairTerm(MkAtomTerm(AtomDefault), t); | 
					
						
							|  |  |  |     t = MkPairTerm(t, TermNil); | 
					
						
							|  |  |  |     if (IsMode_LocalTrie(TabEnt_mode(tab_ent))) | 
					
						
							|  |  |  |       t = MkPairTerm(MkAtomTerm(AtomLocalTrie), t); | 
					
						
							|  |  |  |     else if (IsMode_GlobalTrie(TabEnt_mode(tab_ent))) | 
					
						
							|  |  |  |       t = MkPairTerm(MkAtomTerm(AtomGlobalTrie), t); | 
					
						
							|  |  |  |     if (IsMode_ExecAnswers(TabEnt_mode(tab_ent))) | 
					
						
							|  |  |  |       t = MkPairTerm(MkAtomTerm(AtomExecAnswers), t); | 
					
						
							|  |  |  |     else if (IsMode_LoadAnswers(TabEnt_mode(tab_ent))) | 
					
						
							|  |  |  |       t = MkPairTerm(MkAtomTerm(AtomLoadAnswers), t); | 
					
						
							|  |  |  |     if (IsMode_Batched(TabEnt_mode(tab_ent))) | 
					
						
							|  |  |  |       t = MkPairTerm(MkAtomTerm(AtomBatched), t); | 
					
						
							|  |  |  |     else if (IsMode_Local(TabEnt_mode(tab_ent))) | 
					
						
							|  |  |  |       t = MkPairTerm(MkAtomTerm(AtomLocal), t); | 
					
						
							|  |  |  |     Bind((CELL *) tvalue, t); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     return(TRUE); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   } else if (IsIntTerm(tvalue)) { | 
					
						
							|  |  |  |     Int value = IntOfTerm(tvalue); | 
					
						
							|  |  |  |     if (value == 1) {  /* batched */ | 
					
						
							|  |  |  |       SetMode_Batched(TabEnt_flags(tab_ent)); | 
					
						
							|  |  |  |       if (! IsMode_Local(yap_flags[TABLING_MODE_FLAG])) { | 
					
						
							|  |  |  | 	SetMode_Batched(TabEnt_mode(tab_ent)); | 
					
						
							|  |  |  | 	return(TRUE); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } else if (value == 2) {  /* local */ | 
					
						
							|  |  |  |       SetMode_Local(TabEnt_flags(tab_ent)); | 
					
						
							|  |  |  |       if (! IsMode_Batched(yap_flags[TABLING_MODE_FLAG])) { | 
					
						
							|  |  |  | 	SetMode_Local(TabEnt_mode(tab_ent)); | 
					
						
							|  |  |  | 	return(TRUE); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } else if (value == 3) {  /* exec_answers */ | 
					
						
							|  |  |  |       SetMode_ExecAnswers(TabEnt_flags(tab_ent)); | 
					
						
							|  |  |  |       if (! IsMode_LoadAnswers(yap_flags[TABLING_MODE_FLAG])) { | 
					
						
							|  |  |  | 	SetMode_ExecAnswers(TabEnt_mode(tab_ent)); | 
					
						
							|  |  |  | 	return(TRUE); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } else if (value == 4) {  /* load_answers */ | 
					
						
							|  |  |  |       SetMode_LoadAnswers(TabEnt_flags(tab_ent)); | 
					
						
							|  |  |  |       if (! IsMode_ExecAnswers(yap_flags[TABLING_MODE_FLAG])) { | 
					
						
							|  |  |  | 	SetMode_LoadAnswers(TabEnt_mode(tab_ent)); | 
					
						
							|  |  |  | 	return(TRUE); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } else if (value == 5) {  /* local_trie */ | 
					
						
							|  |  |  |       SetMode_LocalTrie(TabEnt_flags(tab_ent)); | 
					
						
							|  |  |  |       if (! IsMode_GlobalTrie(yap_flags[TABLING_MODE_FLAG])) { | 
					
						
							|  |  |  | 	SetMode_LocalTrie(TabEnt_mode(tab_ent)); | 
					
						
							|  |  |  | 	return(TRUE); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } else if (value == 6) {  /* global_trie */ | 
					
						
							|  |  |  |       SetMode_GlobalTrie(TabEnt_flags(tab_ent)); | 
					
						
							|  |  |  |       if (! IsMode_LocalTrie(yap_flags[TABLING_MODE_FLAG])) { | 
					
						
							|  |  |  | 	SetMode_GlobalTrie(TabEnt_mode(tab_ent)); | 
					
						
							|  |  |  | 	return(TRUE); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }     | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   return (FALSE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | static Int p_abolish_table( USES_REGS1 ) { | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   Term mod, t; | 
					
						
							|  |  |  |   tab_ent_ptr tab_ent; | 
					
						
							|  |  |  |   sg_hash_ptr hash; | 
					
						
							|  |  |  |   sg_node_ptr sg_node; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   mod = Deref(ARG1); | 
					
						
							|  |  |  |   t = Deref(ARG2); | 
					
						
							|  |  |  |   if (IsAtomTerm(t)) | 
					
						
							|  |  |  |     tab_ent = RepPredProp(PredPropByAtom(AtomOfTerm(t), mod))->TableOfPred; | 
					
						
							|  |  |  |   else if (IsApplTerm(t)) | 
					
						
							|  |  |  |     tab_ent = RepPredProp(PredPropByFunc(FunctorOfTerm(t), mod))->TableOfPred; | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     return (FALSE); | 
					
						
							|  |  |  |   hash = TabEnt_hash_chain(tab_ent); | 
					
						
							|  |  |  |   TabEnt_hash_chain(tab_ent) = NULL; | 
					
						
							| 
									
										
										
										
											2010-04-23 04:22:10 +01:00
										 |  |  |   free_subgoal_hash_chain(hash); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   sg_node = TrNode_child(TabEnt_subgoal_trie(tab_ent)); | 
					
						
							|  |  |  |   if (sg_node) { | 
					
						
							| 
									
										
										
										
											2010-04-23 04:22:10 +01:00
										 |  |  |     if (TabEnt_arity(tab_ent)) { | 
					
						
							|  |  |  |       free_subgoal_trie(sg_node, TRAVERSE_MODE_NORMAL, TRAVERSE_POSITION_FIRST); | 
					
						
							|  |  |  |     } else { | 
					
						
							|  |  |  |       sg_fr_ptr sg_fr = UNTAG_SUBGOAL_LEAF_NODE(sg_node); | 
					
						
							|  |  |  |       FREE_ANSWER_TRIE_NODE(SgFr_answer_trie(sg_fr)); | 
					
						
							|  |  |  | #ifdef LIMIT_TABLING
 | 
					
						
							|  |  |  |       remove_from_global_sg_fr_list(sg_fr); | 
					
						
							|  |  |  | #endif /* LIMIT_TABLING */
 | 
					
						
							|  |  |  |       FREE_SUBGOAL_FRAME(sg_fr); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-04-29 17:29:02 +01:00
										 |  |  |     TrNode_child(TabEnt_subgoal_trie(tab_ent)) = NULL; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   } | 
					
						
							|  |  |  |   return (TRUE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | static Int p_abolish_all_tables( USES_REGS1 ) { | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   tab_ent_ptr tab_ent; | 
					
						
							|  |  |  |   sg_hash_ptr hash; | 
					
						
							|  |  |  |   sg_node_ptr sg_node; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   tab_ent = GLOBAL_root_tab_ent; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   while(tab_ent) { | 
					
						
							|  |  |  |     hash = TabEnt_hash_chain(tab_ent); | 
					
						
							|  |  |  |     TabEnt_hash_chain(tab_ent) = NULL; | 
					
						
							| 
									
										
										
										
											2010-04-23 04:22:10 +01:00
										 |  |  |     free_subgoal_hash_chain(hash); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |     sg_node = TrNode_child(TabEnt_subgoal_trie(tab_ent)); | 
					
						
							| 
									
										
										
										
											2011-04-29 17:29:02 +01:00
										 |  |  |     if (sg_node) { | 
					
						
							| 
									
										
										
										
											2010-04-23 04:22:10 +01:00
										 |  |  |       if (TabEnt_arity(tab_ent)) { | 
					
						
							|  |  |  | 	free_subgoal_trie(sg_node, TRAVERSE_MODE_NORMAL, TRAVERSE_POSITION_FIRST); | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  | 	sg_fr_ptr sg_fr = UNTAG_SUBGOAL_LEAF_NODE(sg_node); | 
					
						
							|  |  |  | 	FREE_ANSWER_TRIE_NODE(SgFr_answer_trie(sg_fr)); | 
					
						
							|  |  |  | #ifdef LIMIT_TABLING
 | 
					
						
							|  |  |  | 	remove_from_global_sg_fr_list(sg_fr); | 
					
						
							|  |  |  | #endif /* LIMIT_TABLING */
 | 
					
						
							|  |  |  | 	FREE_SUBGOAL_FRAME(sg_fr); | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2011-04-29 17:29:02 +01:00
										 |  |  |       TrNode_child(TabEnt_subgoal_trie(tab_ent)) = NULL; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |     } | 
					
						
							|  |  |  |     tab_ent = TabEnt_next(tab_ent); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return (TRUE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-25 20:08:04 +01:00
										 |  |  | static Int p_abolish_all_local_tables( USES_REGS1 ) { | 
					
						
							|  |  |  | #ifdef THREADS
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |   p_abolish_all_tables(); | 
					
						
							|  |  |  | #endif /* THREADS */
 | 
					
						
							|  |  |  |   return (TRUE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | static Int p_show_tabled_predicates( USES_REGS1 ) { | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   IOSTREAM *out; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   tab_ent_ptr tab_ent; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-26 15:26:01 +01:00
										 |  |  |   if (!PL_get_stream_handle(Yap_InitSlot(Deref(ARG1) PASS_REGS), &out)) | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |     return (FALSE); | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   tab_ent = GLOBAL_root_tab_ent; | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "Tabled predicates\n"); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   if (tab_ent == NULL) | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |     Sfprintf(out, "  NONE\n"); | 
					
						
							| 
									
										
										
										
											2011-07-26 15:26:01 +01:00
										 |  |  |   else while(tab_ent) { | 
					
						
							|  |  |  |     Sfprintf(out, "  %s/%d\n", AtomName(TabEnt_atom(tab_ent)), TabEnt_arity(tab_ent)); | 
					
						
							|  |  |  |     tab_ent = TabEnt_next(tab_ent); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   PL_release_stream(out); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   return (TRUE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | static Int p_show_table( USES_REGS1 ) { | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   IOSTREAM *out; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   Term mod, t; | 
					
						
							|  |  |  |   tab_ent_ptr tab_ent; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-26 15:26:01 +01:00
										 |  |  |   if (!PL_get_stream_handle(Yap_InitSlot(Deref(ARG1) PASS_REGS), &out)) | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |     return (FALSE); | 
					
						
							|  |  |  |   mod = Deref(ARG2); | 
					
						
							|  |  |  |   t = Deref(ARG3); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   if (IsAtomTerm(t)) | 
					
						
							|  |  |  |     tab_ent = RepPredProp(PredPropByAtom(AtomOfTerm(t), mod))->TableOfPred; | 
					
						
							|  |  |  |   else if (IsApplTerm(t)) | 
					
						
							|  |  |  |     tab_ent = RepPredProp(PredPropByFunc(FunctorOfTerm(t), mod))->TableOfPred; | 
					
						
							| 
									
										
										
										
											2011-07-26 15:26:01 +01:00
										 |  |  |   else { | 
					
						
							|  |  |  |     PL_release_stream(out); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |     return (FALSE); | 
					
						
							| 
									
										
										
										
											2011-07-26 15:26:01 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   show_table(tab_ent, SHOW_MODE_STRUCTURE, out); | 
					
						
							| 
									
										
										
										
											2011-07-26 15:26:01 +01:00
										 |  |  |   PL_release_stream(out); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   return (TRUE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | static Int p_show_all_tables( USES_REGS1 ) { | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   IOSTREAM *out; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   tab_ent_ptr tab_ent; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-26 15:26:01 +01:00
										 |  |  |   if (!PL_get_stream_handle(Yap_InitSlot(Deref(ARG1) PASS_REGS), &out)) | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |     return (FALSE); | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   tab_ent = GLOBAL_root_tab_ent; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   while(tab_ent) { | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |     show_table(tab_ent, SHOW_MODE_STRUCTURE, out); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |     tab_ent = TabEnt_next(tab_ent); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-07-26 15:26:01 +01:00
										 |  |  |   PL_release_stream(out); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   return (TRUE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-25 20:08:04 +01:00
										 |  |  | static Int p_show_all_local_tables( USES_REGS1 ) { | 
					
						
							|  |  |  | #ifdef THREADS
 | 
					
						
							| 
									
										
										
										
											2011-07-26 15:26:01 +01:00
										 |  |  |   IOSTREAM *out; | 
					
						
							|  |  |  |   tab_ent_ptr tab_ent; | 
					
						
							| 
									
										
										
										
											2011-05-25 20:08:04 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-26 15:26:01 +01:00
										 |  |  |   if (!PL_get_stream_handle(Yap_InitSlot(Deref(ARG1) PASS_REGS), &out)) | 
					
						
							|  |  |  |     return (FALSE);   | 
					
						
							|  |  |  |   tab_ent = GLOBAL_root_tab_ent; | 
					
						
							|  |  |  |   while(tab_ent) { | 
					
						
							|  |  |  |     show_table(tab_ent, SHOW_MODE_STRUCTURE, out); | 
					
						
							|  |  |  |     tab_ent = TabEnt_next(tab_ent); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   PL_release_stream(out); | 
					
						
							| 
									
										
										
										
											2011-05-25 20:08:04 +01:00
										 |  |  | #else
 | 
					
						
							|  |  |  |   p_show_all_tables(); | 
					
						
							|  |  |  | #endif /* THREADS */
 | 
					
						
							|  |  |  |   return (TRUE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | static Int p_show_global_trie( USES_REGS1 ) { | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   IOSTREAM *out; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-26 15:26:01 +01:00
										 |  |  |   if (!PL_get_stream_handle(Yap_InitSlot(Deref(ARG1) PASS_REGS), &out)) | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |     return (FALSE); | 
					
						
							|  |  |  |   show_global_trie(SHOW_MODE_STRUCTURE, out); | 
					
						
							| 
									
										
										
										
											2011-07-26 15:26:01 +01:00
										 |  |  |   PL_release_stream(out); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   return (TRUE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | static Int p_show_statistics_table( USES_REGS1 ) { | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   IOSTREAM *out; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   Term mod, t; | 
					
						
							|  |  |  |   tab_ent_ptr tab_ent; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-26 15:26:01 +01:00
										 |  |  |   if (!PL_get_stream_handle(Yap_InitSlot(Deref(ARG1) PASS_REGS), &out)) | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |     return (FALSE); | 
					
						
							|  |  |  |   mod = Deref(ARG2); | 
					
						
							|  |  |  |   t = Deref(ARG3); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   if (IsAtomTerm(t)) | 
					
						
							|  |  |  |     tab_ent = RepPredProp(PredPropByAtom(AtomOfTerm(t), mod))->TableOfPred; | 
					
						
							|  |  |  |   else if (IsApplTerm(t)) | 
					
						
							|  |  |  |     tab_ent = RepPredProp(PredPropByFunc(FunctorOfTerm(t), mod))->TableOfPred; | 
					
						
							| 
									
										
										
										
											2011-07-26 15:26:01 +01:00
										 |  |  |   else { | 
					
						
							|  |  |  |     PL_release_stream(out); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |     return (FALSE); | 
					
						
							| 
									
										
										
										
											2011-07-26 15:26:01 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   show_table(tab_ent, SHOW_MODE_STATISTICS, out); | 
					
						
							| 
									
										
										
										
											2011-07-26 15:26:01 +01:00
										 |  |  |   PL_release_stream(out); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   return (TRUE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | static Int p_show_statistics_tabling( USES_REGS1 ) { | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   IOSTREAM *out; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   long total_bytes = 0, aux_bytes; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-26 15:26:01 +01:00
										 |  |  |   if (!PL_get_stream_handle(Yap_InitSlot(Deref(ARG1) PASS_REGS), &out)) | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |     return (FALSE); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   aux_bytes = 0; | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "Execution data structures\n"); | 
					
						
							|  |  |  |   aux_bytes += show_statistics_table_entries(out); | 
					
						
							|  |  |  |   aux_bytes += show_statistics_subgoal_frames(out); | 
					
						
							|  |  |  |   aux_bytes += show_statistics_dependency_frames(out); | 
					
						
							|  |  |  |   Sfprintf(out, "  Memory in use (I):               %10ld bytes\n\n", aux_bytes); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   total_bytes += aux_bytes; | 
					
						
							|  |  |  |   aux_bytes = 0; | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "Local trie data structures\n"); | 
					
						
							|  |  |  |   aux_bytes += show_statistics_subgoal_trie_nodes(out); | 
					
						
							|  |  |  |   aux_bytes += show_statistics_answer_trie_nodes(out); | 
					
						
							|  |  |  |   aux_bytes += show_statistics_subgoal_trie_hashes(out); | 
					
						
							|  |  |  |   aux_bytes += show_statistics_answer_trie_hashes(out); | 
					
						
							|  |  |  |   Sfprintf(out, "  Memory in use (II):              %10ld bytes\n\n", aux_bytes); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   total_bytes += aux_bytes; | 
					
						
							|  |  |  |   aux_bytes = 0; | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "Global trie data structures\n"); | 
					
						
							|  |  |  |   aux_bytes += show_statistics_global_trie_nodes(out); | 
					
						
							|  |  |  |   aux_bytes += show_statistics_global_trie_hashes(out); | 
					
						
							|  |  |  |   Sfprintf(out, "  Memory in use (III):             %10ld bytes\n\n", aux_bytes); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   total_bytes += aux_bytes; | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #ifdef USE_PAGES_MALLOC
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "Total memory in use (I+II+III):    %10ld bytes (%ld pages in use)\n", | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           total_bytes, Pg_str_in_use(GLOBAL_pages_void)); | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "Total memory allocated:            %10ld bytes (%ld pages in total)\n", | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_pg_alloc(GLOBAL_pages_void) * Yap_page_size, Pg_pg_alloc(GLOBAL_pages_void)); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #else 
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "Total memory in use (I+II+III):    %10ld bytes\n", total_bytes); | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #endif /* USE_PAGES_MALLOC */
 | 
					
						
							| 
									
										
										
										
											2011-07-26 15:26:01 +01:00
										 |  |  |   PL_release_stream(out); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   return (TRUE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | static Int p_show_statistics_global_trie( USES_REGS1 ) { | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   IOSTREAM *out; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-26 15:26:01 +01:00
										 |  |  |   if (!PL_get_stream_handle(Yap_InitSlot(Deref(ARG1) PASS_REGS), &out)) | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |     return (FALSE); | 
					
						
							|  |  |  |   show_global_trie(SHOW_MODE_STATISTICS, out); | 
					
						
							| 
									
										
										
										
											2011-07-26 15:26:01 +01:00
										 |  |  |   PL_release_stream(out); | 
					
						
							| 
									
										
										
										
											2010-04-23 04:22:10 +01:00
										 |  |  |   return (TRUE); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2010-07-28 00:30:02 +01:00
										 |  |  | #endif /* TABLING */
 | 
					
						
							| 
									
										
										
										
											2010-04-23 04:22:10 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*********************************
 | 
					
						
							|  |  |  | **      YapOr C Predicates      ** | 
					
						
							|  |  |  | *********************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef YAPOR
 | 
					
						
							| 
									
										
										
										
											2011-06-21 15:19:07 +01:00
										 |  |  | static Int p_parallel_mode( USES_REGS1 ) { | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   Term t; | 
					
						
							|  |  |  |   t = Deref(ARG1); | 
					
						
							|  |  |  |   if (IsVarTerm(t)) { | 
					
						
							|  |  |  |     Term ta; | 
					
						
							| 
									
										
										
										
											2011-06-21 15:19:07 +01:00
										 |  |  |     if (GLOBAL_parallel_mode == PARALLEL_MODE_OFF)  | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |       ta = MkAtomTerm(Yap_LookupAtom("off")); | 
					
						
							| 
									
										
										
										
											2011-06-21 15:19:07 +01:00
										 |  |  |     else if (GLOBAL_parallel_mode == PARALLEL_MODE_ON)  | 
					
						
							|  |  |  |       ta = MkAtomTerm(Yap_LookupAtom("on")); | 
					
						
							|  |  |  |     else /* PARALLEL_MODE_RUNNING */ | 
					
						
							|  |  |  |       ta = MkAtomTerm(Yap_LookupAtom("running")); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |     Bind((CELL *)t, ta); | 
					
						
							|  |  |  |     return(TRUE); | 
					
						
							| 
									
										
										
										
											2011-06-21 15:19:07 +01:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (IsAtomTerm(t) && GLOBAL_parallel_mode != PARALLEL_MODE_RUNNING) { | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |     char *s; | 
					
						
							|  |  |  |     s = RepAtom(AtomOfTerm(t))->StrOfAE; | 
					
						
							| 
									
										
										
										
											2011-06-21 15:19:07 +01:00
										 |  |  |     if (strcmp(s,"on") == 0) { | 
					
						
							|  |  |  |       GLOBAL_parallel_mode = PARALLEL_MODE_ON; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |       return(TRUE); | 
					
						
							| 
									
										
										
										
											2011-06-21 15:19:07 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |     if (strcmp(s,"off") == 0) { | 
					
						
							| 
									
										
										
										
											2011-06-21 15:19:07 +01:00
										 |  |  |       GLOBAL_parallel_mode = PARALLEL_MODE_OFF; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |       return(TRUE); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-06-21 15:19:07 +01:00
										 |  |  |     return(FALSE); /* PARALLEL_MODE_RUNNING */ | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   } | 
					
						
							|  |  |  |   return(FALSE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-06-21 15:19:07 +01:00
										 |  |  | static Int p_yapor_start( USES_REGS1 ) { | 
					
						
							|  |  |  | #ifdef TIMESTAMP_CHECK
 | 
					
						
							|  |  |  |   GLOBAL_timestamp = 0; | 
					
						
							|  |  |  | #endif /* TIMESTAMP_CHECK */
 | 
					
						
							|  |  |  |   BITMAP_delete(GLOBAL_bm_idle_workers, 0); | 
					
						
							|  |  |  |   BITMAP_clear(GLOBAL_bm_invisible_workers); | 
					
						
							|  |  |  |   BITMAP_clear(GLOBAL_bm_requestable_workers); | 
					
						
							|  |  |  | #ifdef TABLING_INNER_CUTS
 | 
					
						
							|  |  |  |   BITMAP_clear(GLOBAL_bm_pruning_workers); | 
					
						
							|  |  |  | #endif /* TABLING_INNER_CUTS */
 | 
					
						
							|  |  |  |   make_root_choice_point(); | 
					
						
							|  |  |  |   GLOBAL_parallel_mode = PARALLEL_MODE_RUNNING; | 
					
						
							|  |  |  |   GLOBAL_execution_time = current_time(); | 
					
						
							|  |  |  |   BITMAP_clear(GLOBAL_bm_finished_workers); | 
					
						
							|  |  |  |   PUT_IN_EXECUTING(worker_id); | 
					
						
							|  |  |  |   return (TRUE); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-06-21 15:19:07 +01:00
										 |  |  | static Int p_yapor_workers( USES_REGS1 ) { | 
					
						
							|  |  |  | #ifdef YAPOR_THREADS
 | 
					
						
							|  |  |  |   return Yap_unify(MkIntegerTerm(GLOBAL_number_workers),ARG1); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  |   return FALSE; | 
					
						
							| 
									
										
										
										
											2011-07-26 15:26:01 +01:00
										 |  |  | #endif /* YAPOR_THREADS */
 | 
					
						
							| 
									
										
										
										
											2011-06-21 15:19:07 +01:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-06-21 15:19:07 +01:00
										 |  |  | static Int p_worker( USES_REGS1 ) { | 
					
						
							|  |  |  |   CurrentModule = USER_MODULE; | 
					
						
							|  |  |  |   P = GETWORK_FIRST_TIME; | 
					
						
							|  |  |  |   return TRUE; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | static Int p_parallel_new_answer( USES_REGS1 ) { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   or_fr_ptr leftmost_or_fr; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   length_answer = 0; | 
					
						
							|  |  |  |   ALLOC_QG_ANSWER_FRAME(actual_answer); | 
					
						
							| 
									
										
										
										
											2009-08-19 21:53:49 -05:00
										 |  |  |   Yap_plwrite(ARG1, parallel_new_answer_putchar, 4, 1200); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   AnsFr_answer(actual_answer)[length_answer] = 0; | 
					
						
							|  |  |  |   AnsFr_next(actual_answer) = NULL; | 
					
						
							|  |  |  |   leftmost_or_fr = CUT_leftmost_or_frame(); | 
					
						
							|  |  |  |   LOCK_OR_FRAME(leftmost_or_fr); | 
					
						
							| 
									
										
										
										
											2010-01-27 11:01:28 +00:00
										 |  |  |   if (Get_LOCAL_prune_request()) { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     UNLOCK_OR_FRAME(leftmost_or_fr); | 
					
						
							|  |  |  |     FREE_QG_ANSWER_FRAME(actual_answer); | 
					
						
							|  |  |  |   } else { | 
					
						
							|  |  |  |     CUT_store_answer(leftmost_or_fr, actual_answer); | 
					
						
							|  |  |  |     UNLOCK_OR_FRAME(leftmost_or_fr); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return (TRUE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | static Int p_show_statistics_or( USES_REGS1 ) { | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   IOSTREAM *out; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   long total_bytes = 0, aux_bytes; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-26 15:26:01 +01:00
										 |  |  |   if (!PL_get_stream_handle(Yap_InitSlot(Deref(ARG1) PASS_REGS), &out)) | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |     return (FALSE); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   aux_bytes = 0; | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "Execution data structures\n"); | 
					
						
							|  |  |  |   aux_bytes += show_statistics_or_frames(out); | 
					
						
							|  |  |  |   Sfprintf(out, "  Memory in use (I):               %10ld bytes\n\n", aux_bytes); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   total_bytes += aux_bytes; | 
					
						
							|  |  |  |   aux_bytes = 0; | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "Cut support data structures\n"); | 
					
						
							|  |  |  |   aux_bytes += show_statistics_query_goal_solution_frames(out); | 
					
						
							|  |  |  |   aux_bytes += show_statistics_query_goal_answer_frames(out); | 
					
						
							|  |  |  |   Sfprintf(out, "  Memory in use (II):              %10ld bytes\n\n", aux_bytes); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   total_bytes += aux_bytes; | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #ifdef USE_PAGES_MALLOC
 | 
					
						
							| 
									
										
										
										
											2011-06-02 17:01:00 +01:00
										 |  |  |   Sfprintf(out, "Total memory in use (I+II):        %10ld bytes (%ld pages in use)\n", | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           total_bytes, Pg_str_in_use(GLOBAL_pages_void)); | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "Total memory allocated:            %10ld bytes (%ld pages in total)\n", | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_pg_alloc(GLOBAL_pages_void) * Yap_page_size, Pg_pg_alloc(GLOBAL_pages_void)); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #else 
 | 
					
						
							| 
									
										
										
										
											2011-06-02 17:01:00 +01:00
										 |  |  |   Sfprintf(out, "Total memory in use (I+II):        %10ld bytes\n", total_bytes); | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #endif /* USE_PAGES_MALLOC */
 | 
					
						
							| 
									
										
										
										
											2011-07-26 15:26:01 +01:00
										 |  |  |   PL_release_stream(out); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   return (TRUE); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* YAPOR */
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | /**********************************
 | 
					
						
							|  |  |  | **      OPTYap C Predicates      ** | 
					
						
							|  |  |  | **********************************/ | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #if defined(YAPOR) && defined(TABLING)
 | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | static Int p_show_statistics_opt( USES_REGS1 ) { | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   IOSTREAM *out; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   long total_bytes = 0, aux_bytes; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-26 15:26:01 +01:00
										 |  |  |   if (!PL_get_stream_handle(Yap_InitSlot(Deref(ARG1) PASS_REGS), &out)) | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |     return (FALSE); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   aux_bytes = 0; | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "Execution data structures\n"); | 
					
						
							|  |  |  |   aux_bytes += show_statistics_table_entries(out); | 
					
						
							|  |  |  |   aux_bytes += show_statistics_subgoal_frames(out); | 
					
						
							|  |  |  |   aux_bytes += show_statistics_dependency_frames(out); | 
					
						
							|  |  |  |   aux_bytes += show_statistics_or_frames(out); | 
					
						
							|  |  |  |   aux_bytes += show_statistics_suspension_frames(out); | 
					
						
							|  |  |  |   Sfprintf(out, "  Memory in use (I):               %10ld bytes\n\n", aux_bytes); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   total_bytes += aux_bytes; | 
					
						
							|  |  |  |   aux_bytes = 0; | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "Local trie data structures\n"); | 
					
						
							|  |  |  |   aux_bytes += show_statistics_subgoal_trie_nodes(out); | 
					
						
							|  |  |  |   aux_bytes += show_statistics_answer_trie_nodes(out); | 
					
						
							|  |  |  |   aux_bytes += show_statistics_subgoal_trie_hashes(out); | 
					
						
							|  |  |  |   aux_bytes += show_statistics_answer_trie_hashes(out); | 
					
						
							|  |  |  |   Sfprintf(out, "  Memory in use (II):              %10ld bytes\n\n", aux_bytes); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   total_bytes += aux_bytes; | 
					
						
							|  |  |  |   aux_bytes = 0; | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "Global trie data structures\n"); | 
					
						
							|  |  |  |   aux_bytes += show_statistics_global_trie_nodes(out); | 
					
						
							|  |  |  |   aux_bytes += show_statistics_global_trie_hashes(out); | 
					
						
							|  |  |  |   Sfprintf(out, "  Memory in use (III):             %10ld bytes\n\n", aux_bytes); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   total_bytes += aux_bytes; | 
					
						
							|  |  |  |   aux_bytes = 0; | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "Cut support data structures\n"); | 
					
						
							|  |  |  |   aux_bytes += show_statistics_query_goal_solution_frames(out); | 
					
						
							|  |  |  |   aux_bytes += show_statistics_query_goal_answer_frames(out); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef TABLING_INNER_CUTS
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   aux_bytes += show_statistics_table_subgoal_solution_frames(out); | 
					
						
							|  |  |  |   aux_bytes += show_statistics_table_subgoal_answer_frames(out); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* TABLING_INNER_CUTS */
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Memory in use (IV):              %10ld bytes\n\n", aux_bytes); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   total_bytes += aux_bytes; | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #ifdef USE_PAGES_MALLOC
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "Total memory in use (I+II+III+IV): %10ld bytes (%ld pages in use)\n", | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           total_bytes, Pg_str_in_use(GLOBAL_pages_void)); | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "Total memory allocated:            %10ld bytes (%ld pages in total)\n", | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_pg_alloc(GLOBAL_pages_void) * Yap_page_size, Pg_pg_alloc(GLOBAL_pages_void)); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #else 
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "Total memory in use (I+II+III+IV): %10ld bytes\n", total_bytes); | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #endif /* USE_PAGES_MALLOC */
 | 
					
						
							| 
									
										
										
										
											2011-07-26 15:26:01 +01:00
										 |  |  |   PL_release_stream(out); | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |   return (TRUE); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* YAPOR && TABLING */
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  | static Int p_get_optyap_statistics( USES_REGS1 ) { | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   Term tbytes, tstructs; | 
					
						
							|  |  |  |   Int value, bytes = -1, structs = -1; | 
					
						
							| 
									
										
										
										
											2008-09-18 17:35:21 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   value = IntOfTerm(Deref(ARG1)); | 
					
						
							|  |  |  |   if (value == 0) {  /* total_memory */ | 
					
						
							|  |  |  |     bytes = 0; | 
					
						
							|  |  |  | #ifdef TABLING
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |     bytes += Pg_str_in_use(GLOBAL_pages_tab_ent) * sizeof(struct table_entry); | 
					
						
							|  |  |  |     bytes += Pg_str_in_use(GLOBAL_pages_sg_fr) * sizeof(struct subgoal_frame); | 
					
						
							|  |  |  |     bytes += Pg_str_in_use(GLOBAL_pages_dep_fr) * sizeof(struct dependency_frame); | 
					
						
							|  |  |  |     bytes += Pg_str_in_use(GLOBAL_pages_sg_node) * sizeof(struct subgoal_trie_node); | 
					
						
							|  |  |  |     bytes += Pg_str_in_use(GLOBAL_pages_ans_node) * sizeof(struct answer_trie_node); | 
					
						
							|  |  |  |     bytes += Pg_str_in_use(GLOBAL_pages_sg_hash) * sizeof(struct subgoal_trie_hash); | 
					
						
							|  |  |  |     bytes += Pg_str_in_use(GLOBAL_pages_ans_hash) * sizeof(struct answer_trie_hash); | 
					
						
							|  |  |  |     bytes += Pg_str_in_use(GLOBAL_pages_gt_node) * sizeof(struct global_trie_node); | 
					
						
							|  |  |  |     bytes += Pg_str_in_use(GLOBAL_pages_gt_hash) * sizeof(struct global_trie_hash); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* TABLING */
 | 
					
						
							|  |  |  | #ifdef YAPOR
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |     bytes += Pg_str_in_use(GLOBAL_pages_or_fr ) * sizeof(struct or_frame); | 
					
						
							|  |  |  |     bytes += Pg_str_in_use(GLOBAL_pages_qg_sol_fr ) * sizeof(struct query_goal_solution_frame); | 
					
						
							|  |  |  |     bytes += Pg_str_in_use(GLOBAL_pages_qg_ans_fr) * sizeof(struct query_goal_answer_frame); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* YAPOR */
 | 
					
						
							|  |  |  | #if defined(YAPOR) && defined(TABLING)
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |     bytes += Pg_str_in_use(GLOBAL_pages_susp_fr) * sizeof(struct suspension_frame); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef TABLING_INNER_CUTS
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |     bytes += Pg_str_in_use(GLOBAL_pages_tg_sol_fr) * sizeof(struct table_subgoal_solution_frame); | 
					
						
							|  |  |  |     bytes += Pg_str_in_use(GLOBAL_pages_tg_ans_fr) * sizeof(struct table_subgoal_answer_frame); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* TABLING_INNER_CUTS */
 | 
					
						
							|  |  |  | #endif /* YAPOR && TABLING */
 | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #ifdef USE_PAGES_MALLOC
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |     structs = Pg_pg_alloc(GLOBAL_pages_void) * Yap_page_size; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #else
 | 
					
						
							|  |  |  |     structs = bytes; | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #endif /* USE_PAGES_MALLOC */
 | 
					
						
							| 
									
										
										
										
											2008-09-18 17:35:21 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef TABLING
 | 
					
						
							|  |  |  |   if (value == 1) {  /* table_entries */ | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |     bytes = Pg_str_in_use(GLOBAL_pages_tab_ent) * sizeof(struct table_entry); | 
					
						
							|  |  |  |     structs = Pg_str_in_use(GLOBAL_pages_tab_ent); | 
					
						
							| 
									
										
										
										
											2008-09-18 17:35:21 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   if (value == 2) {  /* subgoal_frames */ | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |     bytes = Pg_str_in_use(GLOBAL_pages_sg_fr) * sizeof(struct subgoal_frame); | 
					
						
							|  |  |  |     structs = Pg_str_in_use(GLOBAL_pages_sg_fr); | 
					
						
							| 
									
										
										
										
											2005-04-07 17:56:58 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   if (value == 3) {  /* dependency_frames */ | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |     bytes = Pg_str_in_use(GLOBAL_pages_dep_fr) * sizeof(struct dependency_frame); | 
					
						
							|  |  |  |     structs = Pg_str_in_use(GLOBAL_pages_dep_fr); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (value == 6) {  /* subgoal_trie_nodes */ | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |     bytes = Pg_str_in_use(GLOBAL_pages_sg_node) * sizeof(struct subgoal_trie_node); | 
					
						
							|  |  |  |     structs = Pg_str_in_use(GLOBAL_pages_sg_node); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (value == 7) {  /* answer_trie_nodes */ | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |     bytes = Pg_str_in_use(GLOBAL_pages_ans_node) * sizeof(struct answer_trie_node); | 
					
						
							|  |  |  |     structs = Pg_str_in_use(GLOBAL_pages_ans_node); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (value == 8) {  /* subgoal_trie_hashes */ | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |     bytes = Pg_str_in_use(GLOBAL_pages_sg_hash) * sizeof(struct subgoal_trie_hash); | 
					
						
							|  |  |  |     structs = Pg_str_in_use(GLOBAL_pages_sg_hash); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (value == 9) {  /* answer_trie_hashes */ | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |     bytes = Pg_str_in_use(GLOBAL_pages_ans_hash) * sizeof(struct answer_trie_hash); | 
					
						
							|  |  |  |     structs = Pg_str_in_use(GLOBAL_pages_ans_hash); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   if (value == 10) {  /* global_trie_nodes */ | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |     bytes = Pg_str_in_use(GLOBAL_pages_gt_node) * sizeof(struct global_trie_node); | 
					
						
							|  |  |  |     structs = Pg_str_in_use(GLOBAL_pages_gt_node); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (value == 11) {  /* global_trie_hashes */ | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |     bytes = Pg_str_in_use(GLOBAL_pages_gt_hash) * sizeof(struct global_trie_hash); | 
					
						
							|  |  |  |     structs = Pg_str_in_use(GLOBAL_pages_gt_hash); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   } | 
					
						
							|  |  |  | #endif /* TABLING */
 | 
					
						
							|  |  |  | #ifdef YAPOR
 | 
					
						
							|  |  |  |   if (value == 4) {  /* or_frames */ | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |     bytes = Pg_str_in_use(GLOBAL_pages_or_fr ) * sizeof(struct or_frame); | 
					
						
							|  |  |  |     structs = Pg_str_in_use(GLOBAL_pages_or_fr ); | 
					
						
							| 
									
										
										
										
											2003-11-05 16:12:25 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   if (value == 12) {  /* query_goal_solution_frames */ | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |     bytes = Pg_str_in_use(GLOBAL_pages_qg_sol_fr ) * sizeof(struct query_goal_solution_frame); | 
					
						
							|  |  |  |     structs = Pg_str_in_use(GLOBAL_pages_qg_sol_fr ); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (value == 13) {  /* query_goal_answer_frames */ | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |     bytes = Pg_str_in_use(GLOBAL_pages_qg_ans_fr) * sizeof(struct query_goal_answer_frame); | 
					
						
							|  |  |  |     structs = Pg_str_in_use(GLOBAL_pages_qg_ans_fr); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   } | 
					
						
							|  |  |  | #endif /* YAPOR */
 | 
					
						
							|  |  |  | #if defined(YAPOR) && defined(TABLING)
 | 
					
						
							|  |  |  |   if (value == 5) {  /* suspension_frames */ | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |     bytes = Pg_str_in_use(GLOBAL_pages_susp_fr) * sizeof(struct suspension_frame); | 
					
						
							|  |  |  |     structs = Pg_str_in_use(GLOBAL_pages_susp_fr); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   } | 
					
						
							|  |  |  | #ifdef TABLING_INNER_CUTS
 | 
					
						
							|  |  |  |   if (value == 14) {  /* table_subgoal_solution_frames */ | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |     bytes = Pg_str_in_use(GLOBAL_pages_tg_sol_fr) * sizeof(struct table_subgoal_solution_frame); | 
					
						
							|  |  |  |     structs = Pg_str_in_use(GLOBAL_pages_tg_sol_fr); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (value == 15) {  /* table_subgoal_answer_frames */ | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |     bytes = Pg_str_in_use(GLOBAL_pages_tg_ans_fr) * sizeof(struct table_subgoal_answer_frame); | 
					
						
							|  |  |  |     structs = Pg_str_in_use(GLOBAL_pages_tg_ans_fr); | 
					
						
							| 
									
										
										
										
											2009-06-17 17:14:16 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* TABLING_INNER_CUTS */
 | 
					
						
							|  |  |  | #endif /* YAPOR && TABLING */
 | 
					
						
							|  |  |  |   if (bytes == -1) | 
					
						
							|  |  |  |     return (FALSE); | 
					
						
							|  |  |  |   tbytes = Deref(ARG2); | 
					
						
							|  |  |  |   tstructs = Deref(ARG3); | 
					
						
							|  |  |  |   if (IsVarTerm(tbytes)) { | 
					
						
							|  |  |  |     Bind((CELL *) tbytes, MkIntTerm(bytes)); | 
					
						
							|  |  |  |   } else if (IsIntTerm(tbytes) &&  IntOfTerm(tbytes) != bytes) | 
					
						
							|  |  |  |     return (FALSE); | 
					
						
							|  |  |  |   if (IsVarTerm(tstructs)) { | 
					
						
							|  |  |  |     Bind((CELL *) tstructs, MkIntTerm(structs)); | 
					
						
							|  |  |  |   } else if (IsIntTerm(tstructs) &&  IntOfTerm(tstructs) != structs) | 
					
						
							|  |  |  |     return (FALSE); | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |   return (TRUE); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-16 03:07:37 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | /******************************
 | 
					
						
							|  |  |  | **      Local functions      ** | 
					
						
							|  |  |  | ******************************/ | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef YAPOR
 | 
					
						
							|  |  |  | static inline realtime current_time(void) { | 
					
						
							|  |  |  |   /* to get time as Yap */ | 
					
						
							|  |  |  |   /*
 | 
					
						
							|  |  |  |   double now, interval; | 
					
						
							|  |  |  |   Yap_cputime_interval(&now, &interval); | 
					
						
							|  |  |  |   return ((realtime)now); | 
					
						
							|  |  |  |   */ | 
					
						
							|  |  |  |   struct timeval tempo; | 
					
						
							|  |  |  |   gettimeofday(&tempo, NULL); | 
					
						
							|  |  |  |   return ((realtime)tempo.tv_sec + (realtime)tempo.tv_usec / TIME_RESOLUTION); | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | static inline int parallel_new_answer_putchar(int sno, int ch) { | 
					
						
							|  |  |  |   AnsFr_answer(actual_answer)[length_answer++] = ch; | 
					
						
							|  |  |  |   return ch; | 
					
						
							| 
									
										
										
										
											2002-05-03 15:30:36 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | static inline void show_answers(void) { | 
					
						
							| 
									
										
										
										
											2011-03-07 16:02:55 +00:00
										 |  |  |   CACHE_REGS | 
					
						
							| 
									
										
										
										
											2011-06-21 15:19:07 +01:00
										 |  |  |   int i, answers = 0; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   if (OrFr_qg_solutions(LOCAL_top_or_fr)) { | 
					
						
							|  |  |  |     qg_ans_fr_ptr aux_answer1, aux_answer2; | 
					
						
							|  |  |  |     aux_answer1 = SolFr_first(OrFr_qg_solutions(LOCAL_top_or_fr)); | 
					
						
							|  |  |  |     while (aux_answer1) { | 
					
						
							|  |  |  |       answer_to_stdout(AnsFr_answer(aux_answer1)); | 
					
						
							|  |  |  |       aux_answer2 = aux_answer1; | 
					
						
							|  |  |  |       aux_answer1 = AnsFr_next(aux_answer1); | 
					
						
							|  |  |  |       FREE_QG_ANSWER_FRAME(aux_answer2); | 
					
						
							| 
									
										
										
										
											2011-06-21 15:19:07 +01:00
										 |  |  |       answers++; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |     } | 
					
						
							|  |  |  |     FREE_QG_SOLUTION_FRAME(OrFr_qg_solutions(LOCAL_top_or_fr)); | 
					
						
							|  |  |  |     OrFr_qg_solutions(LOCAL_top_or_fr) = NULL; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-06-21 15:19:07 +01:00
										 |  |  |   switch(answers) { | 
					
						
							|  |  |  |     case 0:   | 
					
						
							|  |  |  |       Sfprintf(Serror, "[ no answers found"); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |       break; | 
					
						
							|  |  |  |     case 1: | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |       Sfprintf(Serror, "[ 1 answer found"); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |       break; | 
					
						
							|  |  |  |     default: | 
					
						
							| 
									
										
										
										
											2011-06-21 15:19:07 +01:00
										 |  |  |          Sfprintf(Serror, "[ %d answers found", answers); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |       break; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(Serror, " (in %f seconds) ]\n\n", GLOBAL_execution_time); | 
					
						
							|  |  |  |   Sflush(Serror); | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   return; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | static inline void answer_to_stdout(char *answer) { | 
					
						
							|  |  |  |   int length_answer = 0, length_output = 0, caracter, list, par_rectos; | 
					
						
							|  |  |  |   char output[MAX_LENGTH_ANSWER]; | 
					
						
							|  |  |  |   while (1) { | 
					
						
							|  |  |  |     length_answer += 2; | 
					
						
							|  |  |  |     while (answer[length_answer] != ']') { | 
					
						
							|  |  |  |       length_answer++; | 
					
						
							|  |  |  |       caracter = 0; | 
					
						
							|  |  |  |       while (answer[length_answer] != ',' && answer[length_answer] != ']') | 
					
						
							|  |  |  | 	caracter = caracter * 10 + answer[length_answer++] - '0'; | 
					
						
							|  |  |  |       output[length_output++] = caracter; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     length_answer++; | 
					
						
							|  |  |  |     output[length_output++] = ' '; | 
					
						
							|  |  |  |     output[length_output++] = '='; | 
					
						
							|  |  |  |     output[length_output++] = ' ';  | 
					
						
							|  |  |  |     if (answer[length_answer++] == ',') { | 
					
						
							|  |  |  |       list = 1; | 
					
						
							|  |  |  |       output[length_output++] = '['; | 
					
						
							|  |  |  |     } else list = 0; | 
					
						
							|  |  |  |     par_rectos = 1; | 
					
						
							|  |  |  |     while (1) { | 
					
						
							|  |  |  |       if (answer[length_answer] == '[') par_rectos++; | 
					
						
							|  |  |  |       else if (answer[length_answer] == ']' && --par_rectos == 0) break; | 
					
						
							|  |  |  |       output[length_output++] = answer[length_answer++]; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (list) output[length_output++] = ']'; | 
					
						
							|  |  |  |     if (answer[++length_answer] != ']') { | 
					
						
							|  |  |  |       output[length_output++] = ' '; | 
					
						
							|  |  |  |       output[length_output++] = ';'; | 
					
						
							|  |  |  |       output[length_output++] = ' '; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else break; | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   output[length_output] = 0; | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(Serror, "  %s\n", output); | 
					
						
							|  |  |  |   Sflush(Serror); | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |   return; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* YAPOR */
 | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef TABLING
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  | static inline long show_statistics_table_entries(IOSTREAM *out) { | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #ifdef USE_PAGES_MALLOC
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef DEBUG_TABLING
 | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |   pg_hd_ptr pg_hd; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   tab_ent_ptr aux_ptr; | 
					
						
							|  |  |  |   long cont = 0; | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   pg_hd = Pg_free_pg(GLOBAL_pages_tab_ent); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   while (pg_hd) { | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |     aux_ptr = PgHd_free_str(pg_hd); | 
					
						
							|  |  |  |     while (aux_ptr) { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |       cont++; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |       aux_ptr = TabEnt_next(aux_ptr); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     pg_hd = PgHd_next(pg_hd); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   TABLING_ERROR_CHECKING(statistics_table_entries, Pg_str_free(GLOBAL_pages_tab_ent) != cont); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* DEBUG_TABLING */
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Table entries:                   %10ld bytes (%ld pages and %ld structs in use)\n",  | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_tab_ent) * sizeof(struct table_entry), Pg_pg_alloc(GLOBAL_pages_tab_ent), Pg_str_in_use(GLOBAL_pages_tab_ent)); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Table entries:                   %10ld bytes (%ld structs in use)\n",  | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_tab_ent) * sizeof(struct table_entry), Pg_str_in_use(GLOBAL_pages_tab_ent)); | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #endif /* USE_PAGES_MALLOC */
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   return Pg_str_in_use(GLOBAL_pages_tab_ent) * sizeof(struct table_entry); | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  | static inline long show_statistics_subgoal_frames(IOSTREAM *out) { | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #ifdef USE_PAGES_MALLOC
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef DEBUG_TABLING
 | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |   pg_hd_ptr pg_hd; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   sg_fr_ptr aux_ptr; | 
					
						
							|  |  |  |   long cont = 0; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   pg_hd = Pg_free_pg(GLOBAL_pages_sg_fr); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   while (pg_hd) { | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |     aux_ptr = PgHd_free_str(pg_hd); | 
					
						
							|  |  |  |     while (aux_ptr) { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |       cont++; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |       aux_ptr = SgFr_next(aux_ptr); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     pg_hd = PgHd_next(pg_hd); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   TABLING_ERROR_CHECKING(statistics_subgoal_frames, Pg_str_free(GLOBAL_pages_sg_fr) != cont); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* DEBUG_TABLING */
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Subgoal frames:                  %10ld bytes (%ld pages and %ld structs in use)\n",  | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_sg_fr) * sizeof(struct subgoal_frame), Pg_pg_alloc(GLOBAL_pages_sg_fr), Pg_str_in_use(GLOBAL_pages_sg_fr)); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Subgoal frames:                  %10ld bytes (%ld structs in use)\n",  | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_sg_fr) * sizeof(struct subgoal_frame), Pg_str_in_use(GLOBAL_pages_sg_fr)); | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #endif /* USE_PAGES_MALLOC */
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   return Pg_str_in_use(GLOBAL_pages_sg_fr) * sizeof(struct subgoal_frame); | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  | static inline long show_statistics_dependency_frames(IOSTREAM *out) { | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #ifdef USE_PAGES_MALLOC
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef DEBUG_TABLING
 | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |   pg_hd_ptr pg_hd; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   dep_fr_ptr aux_ptr; | 
					
						
							|  |  |  |   long cont = 0; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   pg_hd = Pg_free_pg(GLOBAL_pages_dep_fr); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   while (pg_hd) { | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |     aux_ptr = PgHd_free_str(pg_hd); | 
					
						
							|  |  |  |     while (aux_ptr) { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |       cont++; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |       aux_ptr = DepFr_next(aux_ptr); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     pg_hd = PgHd_next(pg_hd); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   TABLING_ERROR_CHECKING(statistics_dependency_frames, Pg_str_free(GLOBAL_pages_dep_fr) != cont); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* DEBUG_TABLING */
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Dependency frames:               %10ld bytes (%ld pages and %ld structs in use)\n", | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_dep_fr) * sizeof(struct dependency_frame), Pg_pg_alloc(GLOBAL_pages_dep_fr), Pg_str_in_use(GLOBAL_pages_dep_fr)); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Dependency frames:               %10ld bytes (%ld structs in use)\n", | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_dep_fr) * sizeof(struct dependency_frame), Pg_str_in_use(GLOBAL_pages_dep_fr)); | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #endif /* USE_PAGES_MALLOC */
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   return Pg_str_in_use(GLOBAL_pages_dep_fr) * sizeof(struct dependency_frame); | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  | static inline long show_statistics_subgoal_trie_nodes(IOSTREAM *out) { | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #ifdef USE_PAGES_MALLOC
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef DEBUG_TABLING
 | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |   pg_hd_ptr pg_hd; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   sg_node_ptr aux_ptr; | 
					
						
							|  |  |  |   long cont = 0; | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   pg_hd = Pg_free_pg(GLOBAL_pages_sg_node); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   while (pg_hd) { | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |     aux_ptr = PgHd_free_str(pg_hd); | 
					
						
							|  |  |  |     while (aux_ptr) { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |       cont++; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |       aux_ptr = TrNode_next(aux_ptr); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     pg_hd = PgHd_next(pg_hd); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   TABLING_ERROR_CHECKING(statistics_subgoal_trie_nodes, Pg_str_free(GLOBAL_pages_sg_node) != cont); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* DEBUG_TABLING */
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Subgoal trie nodes:              %10ld bytes (%ld pages and %ld structs in use)\n",  | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_sg_node) * sizeof(struct subgoal_trie_node), Pg_pg_alloc(GLOBAL_pages_sg_node), Pg_str_in_use(GLOBAL_pages_sg_node)); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Subgoal trie nodes:              %10ld bytes (%ld structs in use)\n",  | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_sg_node) * sizeof(struct subgoal_trie_node), Pg_str_in_use(GLOBAL_pages_sg_node)); | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #endif /* USE_PAGES_MALLOC */
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   return Pg_str_in_use(GLOBAL_pages_sg_node) * sizeof(struct subgoal_trie_node); | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  | static inline long show_statistics_answer_trie_nodes(IOSTREAM *out) { | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #ifdef USE_PAGES_MALLOC
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef DEBUG_TABLING
 | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |   pg_hd_ptr pg_hd; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   ans_node_ptr aux_ptr; | 
					
						
							|  |  |  |   long cont = 0; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   pg_hd = Pg_free_pg(GLOBAL_pages_ans_node); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   while (pg_hd) { | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |     aux_ptr = PgHd_free_str(pg_hd); | 
					
						
							|  |  |  |     while (aux_ptr) { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |       cont++; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |       aux_ptr = TrNode_next(aux_ptr); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     pg_hd = PgHd_next(pg_hd); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   TABLING_ERROR_CHECKING(statistics_answer_trie_nodes, Pg_str_free(GLOBAL_pages_ans_node) != cont); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* DEBUG_TABLING */
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Answer trie nodes:               %10ld bytes (%ld pages and %ld structs in use)\n", | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_ans_node) * sizeof(struct answer_trie_node), Pg_pg_alloc(GLOBAL_pages_ans_node), Pg_str_in_use(GLOBAL_pages_ans_node)); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Answer trie nodes:               %10ld bytes (%ld structs in use)\n", | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_ans_node) * sizeof(struct answer_trie_node), Pg_str_in_use(GLOBAL_pages_ans_node)); | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #endif /* USE_PAGES_MALLOC */
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   return Pg_str_in_use(GLOBAL_pages_ans_node) * sizeof(struct answer_trie_node); | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  | static inline long show_statistics_subgoal_trie_hashes(IOSTREAM *out) { | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #ifdef USE_PAGES_MALLOC
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef DEBUG_TABLING
 | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |   pg_hd_ptr pg_hd; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   sg_hash_ptr aux_ptr; | 
					
						
							|  |  |  |   long cont = 0; | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   pg_hd = Pg_free_pg(GLOBAL_pages_sg_hash); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   while (pg_hd) { | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |     aux_ptr = PgHd_free_str(pg_hd); | 
					
						
							|  |  |  |     while (aux_ptr) { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |       cont++; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |       aux_ptr = Hash_next(aux_ptr); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     pg_hd = PgHd_next(pg_hd); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   TABLING_ERROR_CHECKING(statistics_subgoal_trie_hashes, Pg_str_free(GLOBAL_pages_sg_hash) != cont); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* DEBUG_TABLING */
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Subgoal trie hashes:             %10ld bytes (%ld pages and %ld structs in use)\n",  | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_sg_hash) * sizeof(struct subgoal_trie_hash), Pg_pg_alloc(GLOBAL_pages_sg_hash), Pg_str_in_use(GLOBAL_pages_sg_hash)); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Subgoal trie hashes:             %10ld bytes (%ld structs in use)\n",  | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_sg_hash) * sizeof(struct subgoal_trie_hash), Pg_str_in_use(GLOBAL_pages_sg_hash)); | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #endif /* USE_PAGES_MALLOC */
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   return Pg_str_in_use(GLOBAL_pages_sg_hash) * sizeof(struct subgoal_trie_hash); | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  | static inline long show_statistics_answer_trie_hashes(IOSTREAM *out) { | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #ifdef USE_PAGES_MALLOC
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef DEBUG_TABLING
 | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |   pg_hd_ptr pg_hd; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   ans_hash_ptr aux_ptr; | 
					
						
							|  |  |  |   long cont = 0; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   pg_hd = Pg_free_pg(GLOBAL_pages_ans_hash); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   while (pg_hd) { | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |     aux_ptr = PgHd_free_str(pg_hd); | 
					
						
							|  |  |  |     while (aux_ptr) { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |       cont++; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |       aux_ptr = Hash_next(aux_ptr); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     pg_hd = PgHd_next(pg_hd); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   TABLING_ERROR_CHECKING(statistics_answer_trie_hashes, Pg_str_free(GLOBAL_pages_ans_hash) != cont); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* DEBUG_TABLING */
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Answer trie hashes:              %10ld bytes (%ld pages and %ld structs in use)\n",  | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_ans_hash) * sizeof(struct answer_trie_hash), Pg_pg_alloc(GLOBAL_pages_ans_hash), Pg_str_in_use(GLOBAL_pages_ans_hash)); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Answer trie hashes:              %10ld bytes (%ld structs in use)\n",  | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_ans_hash) * sizeof(struct answer_trie_hash), Pg_str_in_use(GLOBAL_pages_ans_hash)); | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #endif /* USE_PAGES_MALLOC */
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   return Pg_str_in_use(GLOBAL_pages_ans_hash) * sizeof(struct answer_trie_hash); | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  | static inline long show_statistics_global_trie_nodes(IOSTREAM *out) { | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #ifdef USE_PAGES_MALLOC
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef DEBUG_TABLING
 | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |   pg_hd_ptr pg_hd; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   gt_node_ptr aux_ptr; | 
					
						
							|  |  |  |   long cont = 0; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   pg_hd = Pg_free_pg(GLOBAL_pages_gt_node); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   while (pg_hd) { | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |     aux_ptr = PgHd_free_str(pg_hd); | 
					
						
							|  |  |  |     while (aux_ptr) { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |       cont++; | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |       aux_ptr = TrNode_next(aux_ptr); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     pg_hd = PgHd_next(pg_hd); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   TABLING_ERROR_CHECKING(statistics_global_trie_nodes, Pg_str_free(GLOBAL_pages_gt_node) != cont); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* DEBUG_TABLING */
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Global trie nodes:               %10ld bytes (%ld pages and %ld structs in use)\n",  | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  | 	  Pg_str_in_use(GLOBAL_pages_gt_node) * sizeof(struct global_trie_node), Pg_pg_alloc(GLOBAL_pages_gt_node), Pg_str_in_use(GLOBAL_pages_gt_node)); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Global trie nodes:               %10ld bytes (%ld structs in use)\n",  | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  | 	  Pg_str_in_use(GLOBAL_pages_gt_node) * sizeof(struct global_trie_node), Pg_str_in_use(GLOBAL_pages_gt_node)); | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #endif /* USE_PAGES_MALLOC */
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   return Pg_str_in_use(GLOBAL_pages_gt_node) * sizeof(struct global_trie_node); | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  | static inline long show_statistics_global_trie_hashes(IOSTREAM *out) { | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #ifdef USE_PAGES_MALLOC
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef DEBUG_TABLING
 | 
					
						
							| 
									
										
										
										
											2011-06-02 17:01:00 +01:00
										 |  |  |   /* suport not yet implemented :(
 | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |   pg_hd_ptr pg_hd; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   gt_hash_ptr aux_ptr; | 
					
						
							|  |  |  |   long cont = 0; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   pg_hd = Pg_free_pg(GLOBAL_pages_gt_hash); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   while (pg_hd) { | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |     aux_ptr = PgHd_free_str(pg_hd); | 
					
						
							|  |  |  |     while (aux_ptr) { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |       cont++; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |       aux_ptr = Hash_next(aux_ptr); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     pg_hd = PgHd_next(pg_hd); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   TABLING_ERROR_CHECKING(statistics_global_trie_hashes, Pg_str_free(GLOBAL_pages_gt_hash) != cont); | 
					
						
							| 
									
										
										
										
											2011-06-02 17:01:00 +01:00
										 |  |  |   */ | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* DEBUG_TABLING */
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Global trie hashes:              %10ld bytes (%ld pages and %ld structs in use)\n", | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_gt_hash) * sizeof(struct global_trie_hash), Pg_pg_alloc(GLOBAL_pages_gt_hash), Pg_str_in_use(GLOBAL_pages_gt_hash)); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Global trie hashes:              %10ld bytes (%ld structs in use)\n", | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_gt_hash) * sizeof(struct global_trie_hash), Pg_str_in_use(GLOBAL_pages_gt_hash)); | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #endif /* USE_PAGES_MALLOC */
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   return Pg_str_in_use(GLOBAL_pages_gt_hash) * sizeof(struct global_trie_hash); | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* TABLING */
 | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef YAPOR
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  | static inline long show_statistics_or_frames(IOSTREAM *out) { | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #ifdef USE_PAGES_MALLOC
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef DEBUG_YAPOR
 | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |   pg_hd_ptr pg_hd; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   or_fr_ptr aux_ptr; | 
					
						
							|  |  |  |   long cont = 0; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   pg_hd = Pg_free_pg(GLOBAL_pages_or_fr ); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   while (pg_hd) { | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |     aux_ptr = PgHd_free_str(pg_hd); | 
					
						
							|  |  |  |     while (aux_ptr) { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |       cont++; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |       aux_ptr = OrFr_next(aux_ptr); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     pg_hd = PgHd_next(pg_hd); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   YAPOR_ERROR_CHECKING(statistics_or_frames, Pg_str_free(GLOBAL_pages_or_fr ) != cont); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* DEBUG_YAPOR */
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Or-frames:                       %10ld bytes (%ld pages and %ld structs in use)\n",  | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_or_fr ) * sizeof(struct or_frame), Pg_pg_alloc(GLOBAL_pages_or_fr ), Pg_str_in_use(GLOBAL_pages_or_fr )); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Or-frames:                       %10ld bytes (%ld structs in use)\n",  | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_or_fr ) * sizeof(struct or_frame), Pg_str_in_use(GLOBAL_pages_or_fr )); | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #endif /* USE_PAGES_MALLOC */
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   return Pg_str_in_use(GLOBAL_pages_or_fr ) * sizeof(struct or_frame); | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  | static inline long show_statistics_query_goal_solution_frames(IOSTREAM *out) { | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #ifdef USE_PAGES_MALLOC
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef DEBUG_YAPOR
 | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |   pg_hd_ptr pg_hd; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   qg_sol_fr_ptr aux_ptr; | 
					
						
							|  |  |  |   long cont = 0; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   pg_hd = Pg_free_pg(GLOBAL_pages_qg_sol_fr ); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   while (pg_hd) { | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |     aux_ptr = PgHd_free_str(pg_hd); | 
					
						
							|  |  |  |     while (aux_ptr) { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |       cont++; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |       aux_ptr = SolFr_next(aux_ptr); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     pg_hd = PgHd_next(pg_hd); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   YAPOR_ERROR_CHECKING(statistics_query_goal_solution_frames, Pg_str_free(GLOBAL_pages_qg_sol_fr ) != cont); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* DEBUG_YAPOR */
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Query goal solution frames:      %10ld bytes (%ld pages and %ld structs in use)\n", | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_qg_sol_fr ) * sizeof(struct query_goal_solution_frame), Pg_pg_alloc(GLOBAL_pages_qg_sol_fr ), Pg_str_in_use(GLOBAL_pages_qg_sol_fr )); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Query goal solution frames:      %10ld bytes (%ld structs in use)\n", | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_qg_sol_fr ) * sizeof(struct query_goal_solution_frame), Pg_str_in_use(GLOBAL_pages_qg_sol_fr )); | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #endif /* USE_PAGES_MALLOC */
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   return Pg_str_in_use(GLOBAL_pages_qg_sol_fr ) * sizeof(struct query_goal_solution_frame); | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  | static inline long show_statistics_query_goal_answer_frames(IOSTREAM *out) { | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #ifdef USE_PAGES_MALLOC
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef DEBUG_YAPOR
 | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |   pg_hd_ptr pg_hd; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   qg_ans_fr_ptr aux_ptr; | 
					
						
							|  |  |  |   long cont = 0; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   pg_hd = Pg_free_pg(GLOBAL_pages_qg_ans_fr); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   while (pg_hd) { | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |     aux_ptr = PgHd_free_str(pg_hd); | 
					
						
							|  |  |  |     while (aux_ptr) { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |       cont++; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |       aux_ptr = AnsFr_next(aux_ptr); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     pg_hd = PgHd_next(pg_hd); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   YAPOR_ERROR_CHECKING(statistics_query_goal_answer_frames, Pg_str_free(GLOBAL_pages_qg_ans_fr) != cont); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* DEBUG_YAPOR */
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Query goal answer frames:        %10ld bytes (%ld pages and %ld structs in use)\n", | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_qg_ans_fr) * sizeof(struct query_goal_answer_frame), Pg_pg_alloc(GLOBAL_pages_qg_ans_fr), Pg_str_in_use(GLOBAL_pages_qg_ans_fr)); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Query goal answer frames:        %10ld bytes (%ld structs in use)\n", | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_qg_ans_fr) * sizeof(struct query_goal_answer_frame), Pg_str_in_use(GLOBAL_pages_qg_ans_fr)); | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #endif /* USE_PAGES_MALLOC */
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   return Pg_str_in_use(GLOBAL_pages_qg_ans_fr) * sizeof(struct query_goal_answer_frame); | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* YAPOR */
 | 
					
						
							| 
									
										
										
										
											2009-09-27 02:31:31 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #if defined(YAPOR) && defined(TABLING)
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  | static inline long show_statistics_suspension_frames(IOSTREAM *out) { | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #ifdef USE_PAGES_MALLOC
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef DEBUG_OPTYAP
 | 
					
						
							| 
									
										
										
										
											2009-09-27 02:31:31 +01:00
										 |  |  |   pg_hd_ptr pg_hd; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   susp_fr_ptr aux_ptr; | 
					
						
							|  |  |  |   long cont = 0; | 
					
						
							| 
									
										
										
										
											2009-09-27 02:31:31 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   pg_hd = Pg_free_pg(GLOBAL_pages_susp_fr); | 
					
						
							| 
									
										
										
										
											2009-09-27 02:31:31 +01:00
										 |  |  |   while (pg_hd) { | 
					
						
							|  |  |  |     aux_ptr = PgHd_free_str(pg_hd); | 
					
						
							|  |  |  |     while (aux_ptr) { | 
					
						
							|  |  |  |       cont++; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |       aux_ptr = SuspFr_next(aux_ptr); | 
					
						
							| 
									
										
										
										
											2009-09-27 02:31:31 +01:00
										 |  |  |     } | 
					
						
							|  |  |  |     pg_hd = PgHd_next(pg_hd); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   OPTYAP_ERROR_CHECKING(statistics_suspension_frames, Pg_str_free(GLOBAL_pages_susp_fr) != cont); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* DEBUG_OPTYAP */
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Suspension frames:               %10ld bytes (%ld pages and %ld structs in use)\n", | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_susp_fr) * sizeof(struct suspension_frame), Pg_pg_alloc(GLOBAL_pages_susp_fr), Pg_str_in_use(GLOBAL_pages_susp_fr)); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Suspension frames:               %10ld bytes (%ld structs in use)\n", | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_susp_fr) * sizeof(struct suspension_frame), Pg_str_in_use(GLOBAL_pages_susp_fr)); | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #endif /* USE_PAGES_MALLOC */
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   return Pg_str_in_use(GLOBAL_pages_susp_fr) * sizeof(struct suspension_frame); | 
					
						
							| 
									
										
										
										
											2009-09-27 02:31:31 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef TABLING_INNER_CUTS
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  | static inline long show_statistics_table_subgoal_solution_frames(IOSTREAM *out) { | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #ifdef USE_PAGES_MALLOC
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef DEBUG_OPTYAP
 | 
					
						
							| 
									
										
										
										
											2009-09-27 02:31:31 +01:00
										 |  |  |   pg_hd_ptr pg_hd; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   tg_sol_fr_ptr aux_ptr; | 
					
						
							|  |  |  |   long cont = 0; | 
					
						
							| 
									
										
										
										
											2009-09-27 02:31:31 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   pg_hd = Pg_free_pg(GLOBAL_pages_tg_sol_fr); | 
					
						
							| 
									
										
										
										
											2009-09-27 02:31:31 +01:00
										 |  |  |   while (pg_hd) { | 
					
						
							|  |  |  |     aux_ptr = PgHd_free_str(pg_hd); | 
					
						
							|  |  |  |     while (aux_ptr) { | 
					
						
							|  |  |  |       cont++; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |       aux_ptr = SolFr_next(aux_ptr); | 
					
						
							| 
									
										
										
										
											2009-09-27 02:31:31 +01:00
										 |  |  |     } | 
					
						
							|  |  |  |     pg_hd = PgHd_next(pg_hd); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   OPTYAP_ERROR_CHECKING(statistics_table_subgoal_solution_frames, Pg_str_free(GLOBAL_pages_tg_sol_fr) != cont); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* DEBUG_OPTYAP */
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Table subgoal solution frames:   %10ld bytes (%ld pages and %ld structs in use)\n", | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_tg_sol_fr) * sizeof(struct table_subgoal_solution_frame), Pg_pg_alloc(GLOBAL_pages_tg_sol_fr), Pg_str_in_use(GLOBAL_pages_tg_sol_fr)); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Table subgoal solution frames:   %10ld bytes (%ld structs in use)\n", | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_tg_sol_fr) * sizeof(struct table_subgoal_solution_frame), Pg_str_in_use(GLOBAL_pages_tg_sol_fr)); | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #endif /* USE_PAGES_MALLOC */
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   return Pg_str_in_use(GLOBAL_pages_tg_sol_fr) * sizeof(struct table_subgoal_solution_frame); | 
					
						
							| 
									
										
										
										
											2009-09-27 02:31:31 +01:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  | static inline long show_statistics_table_subgoal_answer_frames(IOSTREAM *out) { | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #ifdef USE_PAGES_MALLOC
 | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #ifdef DEBUG_OPTYAP
 | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |   pg_hd_ptr pg_hd; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |   tg_ans_fr_ptr aux_ptr; | 
					
						
							|  |  |  |   long cont = 0; | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   pg_hd = Pg_free_pg(GLOBAL_pages_tg_ans_fr); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |   while (pg_hd) { | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  |     aux_ptr = PgHd_free_str(pg_hd); | 
					
						
							|  |  |  |     while (aux_ptr) { | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |       cont++; | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  |       aux_ptr = AnsFr_next(aux_ptr); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  |     } | 
					
						
							|  |  |  |     pg_hd = PgHd_next(pg_hd); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   OPTYAP_ERROR_CHECKING(statistics_table_subgoal_answer_frames, Pg_str_free(GLOBAL_pages_tg_ans_fr) != cont); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* DEBUG_OPTYAP */
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Table subgoal answer frames:     %10ld bytes (%ld pages and %ld structs in use)\n", | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_tg_ans_fr) * sizeof(struct table_subgoal_answer_frame), Pg_pg_alloc(GLOBAL_pages_tg_ans_fr), Pg_str_in_use(GLOBAL_pages_tg_ans_fr)); | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2011-05-25 18:38:46 +01:00
										 |  |  |   Sfprintf(out, "  Table subgoal answer frames:     %10ld bytes (%ld structs in use)\n", | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |           Pg_str_in_use(GLOBAL_pages_tg_ans_fr) * sizeof(struct table_subgoal_answer_frame), Pg_str_in_use(GLOBAL_pages_tg_ans_fr)); | 
					
						
							| 
									
										
										
										
											2011-04-28 09:48:42 +01:00
										 |  |  | #endif /* USE_PAGES_MALLOC */
 | 
					
						
							| 
									
										
										
										
											2011-05-10 11:47:18 +01:00
										 |  |  |   return Pg_str_in_use(GLOBAL_pages_tg_ans_fr) * sizeof(struct table_subgoal_answer_frame); | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2010-04-20 03:59:48 +01:00
										 |  |  | #endif /* TABLING_INNER_CUTS */
 | 
					
						
							| 
									
										
										
										
											2005-07-11 19:17:32 +00:00
										 |  |  | #endif /* YAPOR && TABLING */
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | #endif /* YAPOR || TABLING */
 |