| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | /************************************************************************* | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | *	 YAP Prolog 							 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | *	Yap Prolog was developed at NCCUP - Universidade do Porto	 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | * Copyright L.Damas, V.S.Costa and Universidade do Porto 1985-1997	 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | ************************************************************************** | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | * File:		debug.pl						 * | 
					
						
							|  |  |  | * Last rev:								 * | 
					
						
							|  |  |  | * mods:									 * | 
					
						
							| 
									
										
										
										
											2013-10-29 12:43:31 +00:00
										 |  |  | * comments:	YAP debugger						 * | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | *									 * | 
					
						
							|  |  |  | *************************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-09 12:39:29 +01:00
										 |  |  | :- system_module( '$_debug', [debug/0, | 
					
						
							|  |  |  |         debugging/0, | 
					
						
							|  |  |  |         leash/1, | 
					
						
							|  |  |  |         nodebug/0, | 
					
						
							|  |  |  |         (nospy)/1, | 
					
						
							|  |  |  |         nospyall/0, | 
					
						
							|  |  |  |         notrace/0, | 
					
						
							|  |  |  |         (spy)/1, | 
					
						
							|  |  |  |         trace/0], ['$do_spy'/4, | 
					
						
							|  |  |  |         '$init_debugger'/0, | 
					
						
							|  |  |  |         '$skipeol'/1]). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :- use_system_module( '$_boot', ['$find_goal_definition'/4, | 
					
						
							|  |  |  |         '$system_catch'/4]). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :- use_system_module( '$_errors', ['$Error'/1, | 
					
						
							|  |  |  |         '$do_error'/2]). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :- use_system_module( '$_init', ['$system_module'/1]). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :- use_system_module( '$_modules', ['$meta_expansion'/6]). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :- use_system_module( '$_preds', ['$clause'/4]). | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | /*----------------------------------------------------------------------------- | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			Debugging / creating spy points | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | -----------------------------------------------------------------------------*/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :- op(900,fx,[spy,nospy]). | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-10-29 12:43:31 +00:00
										 |  |  | '$init_debugger' :- | 
					
						
							| 
									
										
										
										
											2013-10-30 12:57:33 +00:00
										 |  |  |         '$nb_getval'('$trace', _, fail), !. | 
					
						
							| 
									
										
										
										
											2013-10-29 12:43:31 +00:00
										 |  |  | '$init_debugger' :- | 
					
						
							|  |  |  | 	nb_setval('$trace',off), | 
					
						
							|  |  |  | 	nb_setval('$if_skip_mode',no_skip), | 
					
						
							| 
									
										
										
										
											2013-12-08 23:16:22 +00:00
										 |  |  | 	nb_setval('$spy_glist',[]), | 
					
						
							| 
									
										
										
										
											2013-10-29 12:43:31 +00:00
										 |  |  | 	nb_setval('$spy_gn',1), | 
					
						
							|  |  |  | 	nb_setval('$debug_run',off), | 
					
						
							| 
									
										
										
										
											2013-12-11 09:34:43 +00:00
										 |  |  | 	nb_setval('$debug_jump',false). | 
					
						
							| 
									
										
										
										
											2013-10-29 12:43:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-06-23 17:24:20 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-13 08:42:57 +00:00
										 |  |  |  % First part : setting and reseting spy points | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  % $suspy does most of the work | 
					
						
							|  |  |  |  '$suspy'(V,S,M) :- var(V) , !, | 
					
						
							|  |  |  | 	 '$do_error'(instantiation_error,M:spy(V,S)). | 
					
						
							|  |  |  |  '$suspy'((M:S),P,_) :- !, | 
					
						
							|  |  |  |      '$suspy'(S,P,M). | 
					
						
							|  |  |  |  '$suspy'([],_,_) :- !. | 
					
						
							|  |  |  |  '$suspy'([F|L],S,M) :- !, ( '$suspy'(F,S,M) ; '$suspy'(L,S,M) ). | 
					
						
							|  |  |  |  '$suspy'(F/N,S,M) :- !, | 
					
						
							|  |  |  | 	 functor(T,F,N), | 
					
						
							|  |  |  | 	 '$do_suspy'(S, F, N, T, M). | 
					
						
							|  |  |  |  '$suspy'(A,S,M) :- atom(A), !, | 
					
						
							|  |  |  | 	 '$suspy_predicates_by_name'(A,S,M). | 
					
						
							|  |  |  |  '$suspy'(P,spy,M) :- !, | 
					
						
							|  |  |  | 	  '$do_error'(domain_error(predicate_spec,P),spy(M:P)). | 
					
						
							|  |  |  |  '$suspy'(P,nospy,M) :- | 
					
						
							|  |  |  | 	  '$do_error'(domain_error(predicate_spec,P),nospy(M:P)). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  '$suspy_predicates_by_name'(A,S,M) :- | 
					
						
							|  |  |  | 	 % just check one such predicate exists | 
					
						
							|  |  |  | 	 ( | 
					
						
							|  |  |  | 	   current_predicate(A,M:_) | 
					
						
							|  |  |  | 	 -> | 
					
						
							|  |  |  | 	  M = EM, | 
					
						
							|  |  |  | 	  A = NA | 
					
						
							| 
									
										
										
										
											2002-06-01 01:46:06 +00:00
										 |  |  | 	 ; | 
					
						
							| 
									
										
										
										
											2013-12-13 08:42:57 +00:00
										 |  |  | 	  recorded('$import','$import'(EM,M,GA,_,A,_),_), | 
					
						
							|  |  |  | 	  functor(GA,NA,_) | 
					
						
							|  |  |  | 	 ), | 
					
						
							|  |  |  | 	 !, | 
					
						
							|  |  |  | 	 '$do_suspy_predicates_by_name'(NA,S,EM). | 
					
						
							|  |  |  |  '$suspy_predicates_by_name'(A,spy,M) :- !, | 
					
						
							|  |  |  | 	 print_message(warning,no_match(spy(M:A))). | 
					
						
							|  |  |  |  '$suspy_predicates_by_name'(A,nospy,M) :- | 
					
						
							|  |  |  | 	 print_message(warning,no_match(nospy(M:A))). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  '$do_suspy_predicates_by_name'(A,S,M) :- | 
					
						
							|  |  |  | 	 current_predicate(A,M:T), | 
					
						
							|  |  |  | 	 functor(T,A,N), | 
					
						
							|  |  |  | 	 '$do_suspy'(S, A, N, T, M). | 
					
						
							|  |  |  |  '$do_suspy_predicates_by_name'(A, S, M) :- | 
					
						
							|  |  |  | 	 recorded('$import','$import'(EM,M,T0,_,A,N),_), | 
					
						
							|  |  |  | 	 functor(T0,A0,N0), | 
					
						
							|  |  |  | 	 '$do_suspy'(S, A0, N0, T, EM). | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-13 08:42:57 +00:00
										 |  |  |  % | 
					
						
							|  |  |  |  % protect against evil arguments. | 
					
						
							|  |  |  |  % | 
					
						
							|  |  |  |  '$do_suspy'(S, F, N, T, M) :- | 
					
						
							|  |  |  | 	 recorded('$import','$import'(EM,M,T0,_,F,N),_), !, | 
					
						
							|  |  |  | 	 functor(T0, F0, N0), | 
					
						
							|  |  |  | 	 '$do_suspy'(S, F0, N0, T, EM). | 
					
						
							|  |  |  |  '$do_suspy'(S, F, N, T, M) :- | 
					
						
							|  |  |  | 	  '$undefined'(T,M), !, | 
					
						
							|  |  |  | 	  ( S = spy -> | 
					
						
							|  |  |  | 	      print_message(warning,no_match(spy(M:F/N))) | 
					
						
							|  |  |  | 	  ; | 
					
						
							|  |  |  | 	      print_message(warning,no_match(nospy(M:F/N))) | 
					
						
							|  |  |  | 	  ). | 
					
						
							|  |  |  |  '$do_suspy'(S, F, N, T, M) :- | 
					
						
							|  |  |  | 	  '$system_predicate'(T,M), | 
					
						
							|  |  |  | 	 '$flags'(T,M,F,F), | 
					
						
							|  |  |  | 	 F /\ 0x118dd080 =\= 0, | 
					
						
							|  |  |  | 	  ( S = spy -> | 
					
						
							|  |  |  | 	      '$do_error'(permission_error(access,private_procedure,T),spy(M:F/N)) | 
					
						
							|  |  |  | 	  ; | 
					
						
							|  |  |  | 	      '$do_error'(permission_error(access,private_procedure,T),nospy(M:F/N)) | 
					
						
							|  |  |  | 	  ). | 
					
						
							|  |  |  |  '$do_suspy'(S, F, N, T, M) :- | 
					
						
							|  |  |  | 	  '$undefined'(T,M), !, | 
					
						
							|  |  |  | 	  ( S = spy -> | 
					
						
							|  |  |  | 	      print_message(warning,no_match(spy(M:F/N))) | 
					
						
							|  |  |  | 	  ; | 
					
						
							|  |  |  | 	      print_message(warning,no_match(nospy(M:F/N))) | 
					
						
							|  |  |  | 	  ). | 
					
						
							|  |  |  |  '$do_suspy'(S,F,N,T,M) :- | 
					
						
							|  |  |  | 	 '$suspy2'(S,F,N,T,M). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  '$suspy2'(spy,F,N,T,M) :-  | 
					
						
							|  |  |  | 	 recorded('$spy','$spy'(T,M),_), !, | 
					
						
							|  |  |  | 	 print_message(informational,breakp(bp(debugger,plain,M:T,M:F/N,N),add,already)). | 
					
						
							|  |  |  |  '$suspy2'(spy,F,N,T,M) :- !, | 
					
						
							|  |  |  | 	 recorda('$spy','$spy'(T,M),_),  | 
					
						
							|  |  |  | 	 '$set_spy'(T,M), | 
					
						
							|  |  |  | 	 print_message(informational,breakp(bp(debugger,plain,M:T,M:F/N,N),add,ok)). | 
					
						
							|  |  |  |  '$suspy2'(nospy,F,N,T,M) :-  | 
					
						
							|  |  |  | 	 recorded('$spy','$spy'(T,M),R), !, | 
					
						
							|  |  |  | 	 erase(R), | 
					
						
							|  |  |  | 	 '$rm_spy'(T,M), | 
					
						
							|  |  |  | 	 print_message(informational,breakp(bp(debugger,plain,M:T,M:F/N,N),remove,last)). | 
					
						
							|  |  |  |  '$suspy2'(nospy,F,N,_,M) :- | 
					
						
							|  |  |  | 	 print_message(informational,breakp(no,breakpoint_for,M:F/N)). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  '$pred_being_spied'(G, M) :- | 
					
						
							|  |  |  | 	 recorded('$spy','$spy'(G,M),_), !. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  spy Spec :- | 
					
						
							|  |  |  | 	 '$init_debugger', | 
					
						
							|  |  |  | 	 prolog:debug_action_hook(spy(Spec)), !. | 
					
						
							|  |  |  |  spy L :- | 
					
						
							|  |  |  | 	 '$current_module'(M), | 
					
						
							|  |  |  | 	 '$suspy'(L, spy, M), fail. | 
					
						
							|  |  |  |  spy _ :- debug. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  nospy Spec :- | 
					
						
							|  |  |  | 	 '$init_debugger', | 
					
						
							|  |  |  | 	 prolog:debug_action_hook(nospy(Spec)), !. | 
					
						
							|  |  |  |  nospy L :- | 
					
						
							|  |  |  | 	 '$current_module'(M), | 
					
						
							|  |  |  | 	 '$suspy'(L, nospy, M), fail. | 
					
						
							|  |  |  |  nospy _. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  nospyall :- | 
					
						
							|  |  |  | 	 '$init_debugger', | 
					
						
							|  |  |  | 	 prolog:debug_action_hook(nospyall), !. | 
					
						
							|  |  |  |  nospyall :- | 
					
						
							|  |  |  | 	 recorded('$spy','$spy'(T,M),_), functor(T,F,N), '$suspy'(F/N,nospy,M), fail. | 
					
						
							|  |  |  |  nospyall. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  % debug mode -> debug flag = 1 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  debug :- | 
					
						
							|  |  |  | 	 '$init_debugger', | 
					
						
							|  |  |  | 	 ( nb_getval('$spy_gn',L) -> true ; nb_setval('$spy_gn',1) ), | 
					
						
							|  |  |  | 	 '$start_debugging'(on), | 
					
						
							|  |  |  | 	 print_message(informational,debug(debug)). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  '$start_debugging'(Mode) :- | 
					
						
							|  |  |  | 	 (Mode == on -> | 
					
						
							|  |  |  | 	  '$swi_set_prolog_flag'(debug, true) | 
					
						
							|  |  |  | 	 ; | 
					
						
							|  |  |  | 	  '$swi_set_prolog_flag'(debug, false) | 
					
						
							|  |  |  | 	 ), | 
					
						
							|  |  |  | 	 nb_setval('$debug_run',off), | 
					
						
							|  |  |  | 	 nb_setval('$debug_jump',false). | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-13 08:42:57 +00:00
										 |  |  |  nodebug :- | 
					
						
							|  |  |  | 	 '$init_debugger', | 
					
						
							|  |  |  | 	 '$swi_set_prolog_flag'(debug, false), | 
					
						
							|  |  |  | 	 nb_setval('$trace',off), | 
					
						
							|  |  |  | 	 print_message(informational,debug(off)). | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-13 08:42:57 +00:00
										 |  |  |   % | 
					
						
							|  |  |  |   % remove any debugging info after an abort. | 
					
						
							|  |  |  |   % | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-19 00:04:26 +00:00
										 |  |  | trace :- | 
					
						
							| 
									
										
										
										
											2013-12-13 08:42:57 +00:00
										 |  |  | 	 '$init_debugger', | 
					
						
							| 
									
										
										
										
											2013-10-29 12:43:31 +00:00
										 |  |  | 	'$nb_getval'('$trace', on, fail), !. | 
					
						
							| 
									
										
										
										
											2001-08-08 21:17:27 +00:00
										 |  |  | trace :- | 
					
						
							| 
									
										
										
										
											2013-03-03 20:26:48 -06:00
										 |  |  | 	nb_setval('$trace',on), | 
					
						
							|  |  |  | 	'$start_debugging'(on), | 
					
						
							|  |  |  | 	print_message(informational,debug(trace)), | 
					
						
							|  |  |  | 	'$creep'. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | notrace :- | 
					
						
							| 
									
										
										
										
											2013-10-29 12:43:31 +00:00
										 |  |  | 	'$init_debugger', | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 	nodebug. | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*----------------------------------------------------------------------------- | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				leash | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | -----------------------------------------------------------------------------*/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | leash(X) :- var(X), | 
					
						
							| 
									
										
										
										
											2002-09-09 17:40:12 +00:00
										 |  |  | 	'$do_error'(instantiation_error,leash(X)). | 
					
						
							| 
									
										
										
										
											2002-06-01 01:46:06 +00:00
										 |  |  | leash(X) :- | 
					
						
							| 
									
										
										
										
											2013-10-29 12:43:31 +00:00
										 |  |  | 	'$init_debugger', | 
					
						
							| 
									
										
										
										
											2002-06-01 01:46:06 +00:00
										 |  |  | 	'$leashcode'(X,Code), | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	set_value('$leash',Code), | 
					
						
							| 
									
										
										
										
											2002-06-01 01:46:06 +00:00
										 |  |  | 	'$show_leash'(informational,Code), !. | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | leash(X) :- | 
					
						
							| 
									
										
										
										
											2002-09-09 17:40:12 +00:00
										 |  |  | 	'$do_error'(type_error(leash_mode,X),leash(X)). | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-06-01 01:46:06 +00:00
										 |  |  | '$show_leash'(Msg,0) :- | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  | 	print_message(Msg,leash([])). | 
					
						
							| 
									
										
										
										
											2002-06-01 01:46:06 +00:00
										 |  |  | '$show_leash'(Msg,Code) :- | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 	'$check_leash_bit'(Code,0x8,L3,call,LF), | 
					
						
							|  |  |  | 	'$check_leash_bit'(Code,0x4,L2,exit,L3), | 
					
						
							|  |  |  | 	'$check_leash_bit'(Code,0x2,L1,redo,L2), | 
					
						
							|  |  |  | 	'$check_leash_bit'(Code,0x1,[],fail,L1), | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  | 	print_message(Msg,leash(LF)). | 
					
						
							| 
									
										
										
										
											2002-06-01 01:46:06 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | '$check_leash_bit'(Code,Bit,L0,_,L0) :- Bit /\ Code =:= 0, !. | 
					
						
							|  |  |  | '$check_leash_bit'(_,_,L0,Name,[Name|L0]). | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | '$leashcode'(full,0xf) :- !. | 
					
						
							|  |  |  | '$leashcode'(on,0xf) :- !. | 
					
						
							|  |  |  | '$leashcode'(half,0xb) :- !. | 
					
						
							|  |  |  | '$leashcode'(loose,0x8) :- !. | 
					
						
							|  |  |  | '$leashcode'(off,0x0) :- !. | 
					
						
							|  |  |  | '$leashcode'(none,0x0) :- !. | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | %'$leashcode'([L|M],Code) :- !, '$leashcode_list'([L|M],Code). | 
					
						
							| 
									
										
										
										
											2002-06-01 01:46:06 +00:00
										 |  |  | '$leashcode'([L|M],Code) :- !, | 
					
						
							|  |  |  | 	'$list2Code'([L|M],Code). | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | '$leashcode'(N,N) :- integer(N), N >= 0, N =< 0xf. | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | '$list2Code'(V,_) :- var(V), !, | 
					
						
							| 
									
										
										
										
											2002-09-09 17:40:12 +00:00
										 |  |  | 	'$do_error'(instantiation_error,leash(V)). | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | '$list2Code'([],0) :- !. | 
					
						
							|  |  |  | '$list2Code'([V|L],_) :- var(V), !, | 
					
						
							| 
									
										
										
										
											2002-09-09 17:40:12 +00:00
										 |  |  | 	'$do_error'(instantiation_error,leash([V|L])). | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | '$list2Code'([call|L],N) :- '$list2Code'(L,N1), N is 0x8 + N1. | 
					
						
							|  |  |  | '$list2Code'([exit|L],N) :- '$list2Code'(L,N1), N is 0x4 + N1. | 
					
						
							|  |  |  | '$list2Code'([redo|L],N) :- '$list2Code'(L,N1), N is 0x2 + N1. | 
					
						
							|  |  |  | '$list2Code'([fail|L],N) :- '$list2Code'(L,N1), N is 0x1 + N1. | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*----------------------------------------------------------------------------- | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				debugging | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | -----------------------------------------------------------------------------*/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-06 15:10:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-31 22:56:22 +00:00
										 |  |  | debugging :- | 
					
						
							| 
									
										
										
										
											2013-10-29 12:43:31 +00:00
										 |  |  | 	'$init_debugger', | 
					
						
							| 
									
										
										
										
											2008-03-31 22:56:22 +00:00
										 |  |  | 	prolog:debug_action_hook(nospyall), !. | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | debugging :- | 
					
						
							| 
									
										
										
										
											2013-10-31 13:16:27 +00:00
										 |  |  | 	( '$swi_current_prolog_flag'(debug, true) -> | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  | 	    print_message(help,debug(debug)) | 
					
						
							| 
									
										
										
										
											2002-06-01 01:46:06 +00:00
										 |  |  | 	    ; | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  | 	    print_message(help,debug(off)) | 
					
						
							| 
									
										
										
										
											2002-06-01 01:46:06 +00:00
										 |  |  | 	), | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	findall(M:(N/A),(recorded('$spy','$spy'(T,M),_),functor(T,N,A)),L), | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  | 	print_message(help,breakpoints(L)), | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	get_value('$leash',Leash), | 
					
						
							| 
									
										
										
										
											2002-06-01 01:46:06 +00:00
										 |  |  | 	'$show_leash'(help,Leash). | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*----------------------------------------------------------------------------- | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				spy | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | -----------------------------------------------------------------------------*/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | % ok, I may have a spy point for this goal, or not. | 
					
						
							|  |  |  | %  if I do, I should check what mode I am in. | 
					
						
							|  |  |  | % Goal/Mode          Have Spy     Not Spied | 
					
						
							|  |  |  | % Creep                 Stop        Stop | 
					
						
							|  |  |  | % Leap                  Stop        Create CP | 
					
						
							|  |  |  | % Skip               Create CP     Create CP | 
					
						
							|  |  |  | % FastLeap              Stop        Ignore | 
					
						
							|  |  |  | % FastIgnore           Ignore       Ignore | 
					
						
							|  |  |  |      | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | %	flag		description		initial possible values | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | %	spy_gn		goal number		1	1... | 
					
						
							| 
									
										
										
										
											2001-08-08 21:17:27 +00:00
										 |  |  | %	spy_trace	trace		0	0, 1 | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | %	spy_skip	leap			off	Num (stop level) | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | %	debug_prompt	stop at spy points	on	on,off | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | % a flip-flop is also used | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | %	when 1 spying is enabled *(the same as spy stop). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | %'$spy'(G) :- write(user_error,'$spy'(G)), nl, fail. | 
					
						
							|  |  |  | % | 
					
						
							|  |  |  | % handle suspended goals | 
					
						
							| 
									
										
										
										
											2001-09-12 15:52:28 +00:00
										 |  |  | % take care with hidden goals. | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | % | 
					
						
							| 
									
										
										
										
											2001-09-12 15:52:28 +00:00
										 |  |  | % $spy may be called from user code, so be careful. | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | '$spy'([Mod|G]) :- | 
					
						
							| 
									
										
										
										
											2013-10-31 13:16:27 +00:00
										 |  |  | 	'$swi_current_prolog_flag'(debug, false), !, | 
					
						
							| 
									
										
										
										
											2008-10-24 14:26:44 +01:00
										 |  |  | 	'$execute_nonstop'(G,Mod). | 
					
						
							| 
									
										
										
										
											2001-11-15 00:01:43 +00:00
										 |  |  | '$spy'([Mod|G]) :- | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	CP is '$last_choice_pt',	 | 
					
						
							| 
									
										
										
										
											2013-02-08 10:36:45 -06:00
										 |  |  | 	'$do_spy'(G, Mod, CP, spy). | 
					
						
							| 
									
										
										
										
											2003-11-27 21:47:44 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | % last argument to do_spy says that we are at the end of a context. It | 
					
						
							|  |  |  | % is required to know whether we are controlled by the debugger. | 
					
						
							| 
									
										
										
										
											2013-02-13 09:06:06 -06:00
										 |  |  | %'$do_spy'(V, M, CP, Flag) :- | 
					
						
							|  |  |  | %	writeln('$do_spy'(V, M, CP, Flag)), fail. | 
					
						
							| 
									
										
										
										
											2013-02-08 10:36:45 -06:00
										 |  |  | '$do_spy'(V, M, CP, Flag) :- | 
					
						
							|  |  |  | 	var(V), !, | 
					
						
							|  |  |  | 	'$do_spy'(call(V), M, CP, Flag). | 
					
						
							|  |  |  | '$do_spy'(!, _, CP, _) :- | 
					
						
							|  |  |  | 	!, '$$cut_by'(CP). | 
					
						
							|  |  |  | '$do_spy'('$cut_by'(M), _, _, _) :- | 
					
						
							|  |  |  | 	!, '$$cut_by'(M). | 
					
						
							| 
									
										
										
										
											2003-11-27 21:47:44 +00:00
										 |  |  | '$do_spy'(true, _, _, _) :- !. | 
					
						
							| 
									
										
										
										
											2005-02-08 04:05:39 +00:00
										 |  |  | %'$do_spy'(fail, _, _, _) :- !, fail. | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | '$do_spy'(M:G, _, CP, CalledFromDebugger) :- !, | 
					
						
							|  |  |  | 	'$do_spy'(G, M, CP, CalledFromDebugger). | 
					
						
							|  |  |  | '$do_spy'((A,B), M, CP, CalledFromDebugger) :- !, | 
					
						
							| 
									
										
										
										
											2013-02-13 09:06:06 -06:00
										 |  |  | 	'$do_spy'(A, M, CP, debugger), | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | 	'$do_spy'(B, M, CP, CalledFromDebugger). | 
					
						
							|  |  |  | '$do_spy'((T->A;B), M, CP, CalledFromDebugger) :- !, | 
					
						
							| 
									
										
										
										
											2013-02-13 09:06:06 -06:00
										 |  |  | 	( '$do_spy'(T, M, CP, debugger) -> '$do_spy'(A, M, CP, CalledFromDebugger) | 
					
						
							| 
									
										
										
										
											2003-01-29 14:47:17 +00:00
										 |  |  | 	; | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | 	  '$do_spy'(B, M, CP, CalledFromDebugger) | 
					
						
							| 
									
										
										
										
											2003-01-29 14:47:17 +00:00
										 |  |  | 	). | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | '$do_spy'((T->A|B), M, CP, CalledFromDebugger) :- !, | 
					
						
							| 
									
										
										
										
											2013-02-13 09:06:06 -06:00
										 |  |  | 	( '$do_spy'(T, M, CP, debugger) -> 	'$do_spy'(A, M, CP, CalledFromDebugger) | 
					
						
							| 
									
										
										
										
											2003-01-29 14:47:17 +00:00
										 |  |  | 	; | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | 	  '$do_spy'(B, M, CP, CalledFromDebugger) | 
					
						
							| 
									
										
										
										
											2003-01-29 14:47:17 +00:00
										 |  |  | 	). | 
					
						
							| 
									
										
										
										
											2013-02-13 09:06:06 -06:00
										 |  |  | '$do_spy'((T->A), M, CP, CalledFromDebugger) :- !, | 
					
						
							|  |  |  | 	( '$do_spy'(T, M, CP, debugger) -> '$do_spy'(A, M, CP,  CalledFromDebugger) ). | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | '$do_spy'((A;B), M, CP, CalledFromDebugger) :- !, | 
					
						
							| 
									
										
										
										
											2005-02-08 04:05:39 +00:00
										 |  |  | 	( | 
					
						
							| 
									
										
										
										
											2013-02-08 10:36:45 -06:00
										 |  |  | 	  '$do_spy'(A, M, CP, CalledFromDebugger) | 
					
						
							| 
									
										
										
										
											2003-01-29 14:47:17 +00:00
										 |  |  | 	; | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | 	  '$do_spy'(B, M, CP, CalledFromDebugger) | 
					
						
							| 
									
										
										
										
											2003-01-29 14:47:17 +00:00
										 |  |  | 	). | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | '$do_spy'((A|B), M, CP, CalledFromDebugger) :- !, | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	( | 
					
						
							| 
									
										
										
										
											2013-02-08 10:36:45 -06:00
										 |  |  | 	  '$do_spy'(A, M, CP, CalledFromDebugger) | 
					
						
							| 
									
										
										
										
											2003-01-29 14:47:17 +00:00
										 |  |  | 	; | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | 	  '$do_spy'(B, M, CP, CalledFromDebugger) | 
					
						
							| 
									
										
										
										
											2003-01-29 14:47:17 +00:00
										 |  |  | 	). | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | '$do_spy'((\+G), M, CP, CalledFromDebugger) :- !, | 
					
						
							|  |  |  | 	\+ '$do_spy'(G, M, CP, CalledFromDebugger). | 
					
						
							|  |  |  | '$do_spy'((not(G)), M, CP, CalledFromDebugger) :- !, | 
					
						
							|  |  |  | 	\+ '$do_spy'(G, M, CP, CalledFromDebugger). | 
					
						
							|  |  |  | '$do_spy'(G, Module, _, CalledFromDebugger) :- | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  |         nb_getval('$spy_gn',L),		/* get goal no.			*/ | 
					
						
							|  |  |  | 	L1 is L+1,			/* bump it			*/ | 
					
						
							|  |  |  | 	nb_setval('$spy_gn',L1),	/* and save it globaly		*/ | 
					
						
							|  |  |  |         b_getval('$spy_glist',History),	/* get goal list		*/ | 
					
						
							| 
									
										
										
										
											2010-01-25 10:21:21 +00:00
										 |  |  | 	b_setval('$spy_glist',[info(L,Module,G,_Retry,_Det,_HasFoundAnswers)|History]),	/* and update it		*/ | 
					
						
							| 
									
										
										
										
											2013-02-08 10:36:45 -06:00
										 |  |  | 	'$loop_spy'(L, G, Module, CalledFromDebugger).	 | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | % we are skipping, so we can just call the goal, | 
					
						
							|  |  |  | % while leaving the minimal structure in place. | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | '$loop_spy'(GoalNumber, G, Module, CalledFromDebugger) :- | 
					
						
							| 
									
										
										
										
											2013-02-13 09:06:06 -06:00
										 |  |  | 	'$current_choice_point'(CP), | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | 	'$system_catch'('$loop_spy2'(GoalNumber, G, Module, CalledFromDebugger, CP), | 
					
						
							| 
									
										
										
										
											2009-04-22 16:13:08 -05:00
										 |  |  | 		    Module, error(Event,Context), | 
					
						
							|  |  |  | 		    '$loop_spy_event'(error(Event,Context), GoalNumber, G, Module, CalledFromDebugger)). | 
					
						
							| 
									
										
										
										
											2004-01-29 13:37:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | % handle weird things happening in the debugger.		     | 
					
						
							| 
									
										
										
										
											2009-11-04 00:10:27 +00:00
										 |  |  | '$loop_spy_event'('$pass'(Event), _, _, _, _) :- !, | 
					
						
							|  |  |  | 	throw(Event). | 
					
						
							| 
									
										
										
										
											2009-04-22 16:13:08 -05:00
										 |  |  | '$loop_spy_event'(error('$retry_spy'(G0),_), GoalNumber, G, Module, CalledFromDebugger) :- | 
					
						
							| 
									
										
										
										
											2009-11-04 00:10:27 +00:00
										 |  |  | 	G0 >= GoalNumber, !, | 
					
						
							|  |  |  | 	'$loop_spy'(GoalNumber, G, Module, CalledFromDebugger). | 
					
						
							| 
									
										
										
										
											2009-04-22 16:13:08 -05:00
										 |  |  | '$loop_spy_event'(error('$retry_spy'(GoalNumber),_), _, _, _, _) :- !, | 
					
						
							| 
									
										
										
										
											2009-11-04 00:10:27 +00:00
										 |  |  | 	throw(error('$retry_spy'(GoalNumber),[])). | 
					
						
							| 
									
										
										
										
											2009-04-22 16:13:08 -05:00
										 |  |  | '$loop_spy_event'(error('$fail_spy'(G0),_), GoalNumber, G, Module, CalledFromDebugger) :- | 
					
						
							| 
									
										
										
										
											2009-11-04 00:10:27 +00:00
										 |  |  | 	G0 >= GoalNumber, !, | 
					
						
							|  |  |  | 	'$loop_fail'(GoalNumber, G, Module, CalledFromDebugger). | 
					
						
							| 
									
										
										
										
											2009-04-22 16:13:08 -05:00
										 |  |  | '$loop_spy_event'(error('$fail_spy'(GoalNumber),_), _, _, _, _) :- !, | 
					
						
							| 
									
										
										
										
											2009-11-04 00:10:27 +00:00
										 |  |  | 	throw(error('$fail_spy'(GoalNumber),[])). | 
					
						
							| 
									
										
										
										
											2009-04-22 16:13:08 -05:00
										 |  |  | '$loop_spy_event'(error('$done_spy'(G0),_), GoalNumber, G, _, CalledFromDebugger) :- | 
					
						
							| 
									
										
										
										
											2009-11-04 00:10:27 +00:00
										 |  |  | 	G0 >= GoalNumber, !, | 
					
						
							| 
									
										
										
										
											2013-02-08 10:36:45 -06:00
										 |  |  | 	'$continue_debugging'(zip, CalledFromDebugger). | 
					
						
							| 
									
										
										
										
											2009-04-22 16:13:08 -05:00
										 |  |  | '$loop_spy_event'(error('$done_spy'(GoalNumber),_), _, _, _, _) :- !, | 
					
						
							| 
									
										
										
										
											2009-11-04 00:10:27 +00:00
										 |  |  | 	throw(error('$done_spy'(GoalNumber),[])). | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | '$loop_spy_event'(Event, GoalNumber, G, Module, CalledFromDebugger) :- | 
					
						
							| 
									
										
										
										
											2009-11-04 00:10:27 +00:00
										 |  |  | 	'$debug_error'(Event), | 
					
						
							|  |  |  | 	'$system_catch'( | 
					
						
							|  |  |  | 		     ('$trace'(exception(Event),G,Module,GoalNumber,_),fail), | 
					
						
							| 
									
										
										
										
											2009-04-22 16:13:08 -05:00
										 |  |  | 		     Module, | 
					
						
							|  |  |  | 		     error(NewEvent,NewContext), | 
					
						
							|  |  |  | 		     '$loop_spy_event'(error(NewEvent,NewContext), GoalNumber, G, Module, CalledFromDebugger) | 
					
						
							|  |  |  | 		    ). | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-11-26 02:57:25 +00:00
										 |  |  | '$debug_error'(Event) :- | 
					
						
							|  |  |  | 	'$Error'(Event), fail. | 
					
						
							|  |  |  | '$debug_error'(_). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-01-24 14:20:04 +00:00
										 |  |  | % just fail here, don't really need to call debugger, the user knows what he | 
					
						
							|  |  |  | % wants to do | 
					
						
							| 
									
										
										
										
											2013-02-08 10:36:45 -06:00
										 |  |  | '$loop_fail'(_GoalNumber, _G, _Module, CalledFromDebugger) :- | 
					
						
							|  |  |  | 	'$continue_debugging'(fail, CalledFromDebugger), | 
					
						
							| 
									
										
										
										
											2007-01-24 14:20:04 +00:00
										 |  |  | 	fail. | 
					
						
							| 
									
										
										
										
											2003-11-27 21:47:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | % if we are in  | 
					
						
							| 
									
										
										
										
											2014-02-19 00:04:26 +00:00
										 |  |  | '$loop_spy2'(GoalNumber, G, Module, CalledFromDebugger, CP) :-  | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | /* the following choice point is where the predicate is  called */ | 
					
						
							| 
									
										
										
										
											2010-01-25 10:21:21 +00:00
										 |  |  | 	   b_getval('$spy_glist',[Info|_]),	/* get goal list		*/ | 
					
						
							|  |  |  | 	   Info = info(_,_,_,Retry,Det,false), | 
					
						
							| 
									
										
										
										
											2009-11-17 00:09:23 +00:00
										 |  |  | 	   ( | 
					
						
							|  |  |  | 	    /* call port */ | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	    '$enter_goal'(GoalNumber, G, Module), | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | 	    '$spycall'(G, Module, CalledFromDebugger, Retry), | 
					
						
							| 
									
										
										
										
											2013-02-13 09:06:06 -06:00
										 |  |  | 	    % make sure we are in system mode when running the debugger. | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 	    ( | 
					
						
							|  |  |  | 	      '$debugger_deterministic_goal'(G) -> | 
					
						
							|  |  |  | 	      Det=true | 
					
						
							|  |  |  | 	    ; | 
					
						
							|  |  |  | 	      Det=false | 
					
						
							|  |  |  | 	    ), | 
					
						
							| 
									
										
										
										
											2013-02-08 10:36:45 -06:00
										 |  |  | 	    /* go execute the continuation	*/ | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	    ( | 
					
						
							| 
									
										
										
										
											2013-02-08 10:36:45 -06:00
										 |  |  | 	       /* exit port */ | 
					
						
							|  |  |  | 	       Retry = false, | 
					
						
							| 
									
										
										
										
											2010-01-25 10:21:21 +00:00
										 |  |  | 	       /* found an answer, so it can redo */ | 
					
						
							|  |  |  | 	       nb_setarg(6, Info, true), | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 	      '$show_trace'(exit,G,Module,GoalNumber,Det),	/* output message at exit	*/ | 
					
						
							| 
									
										
										
										
											2005-10-18 17:04:43 +00:00
										 |  |  | 	       /* exit port */ | 
					
						
							| 
									
										
										
										
											2006-03-06 14:04:57 +00:00
										 |  |  | 	       /* get rid of deterministic computations */ | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 	      ( | 
					
						
							|  |  |  | 		Det == true | 
					
						
							|  |  |  | 		-> | 
					
						
							| 
									
										
										
										
											2006-12-30 03:25:47 +00:00
										 |  |  | 		'$$cut_by'(CP) | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 		; | 
					
						
							|  |  |  | 		true | 
					
						
							|  |  |  | 	      ), | 
					
						
							| 
									
										
										
										
											2013-02-08 10:36:45 -06:00
										 |  |  | 	      '$continue_debugging'(exit, CalledFromDebugger)	    | 
					
						
							|  |  |  | 	     ; | 
					
						
							| 
									
										
										
										
											2013-02-13 09:06:06 -06:00
										 |  |  | 	       % make sure we are in system mode when running the debugger. | 
					
						
							| 
									
										
										
										
											2005-10-18 17:04:43 +00:00
										 |  |  | 		/* backtracking from exit				*/ | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	        /* we get here when we want to redo a goal		*/ | 
					
						
							| 
									
										
										
										
											2005-10-18 17:04:43 +00:00
										 |  |  | 		/* redo port */ | 
					
						
							| 
									
										
										
										
											2010-01-25 10:21:21 +00:00
										 |  |  | 	      ( | 
					
						
							| 
									
										
										
										
											2013-02-08 10:36:45 -06:00
										 |  |  | 	         arg(6, Info, true) | 
					
						
							| 
									
										
										
										
											2010-01-25 10:21:21 +00:00
										 |  |  | 	      -> | 
					
						
							|  |  |  | 	        '$show_trace'(redo,G,Module,GoalNumber,_), /* inform user_error		*/ | 
					
						
							|  |  |  | 	        nb_setarg(6, Info, false) | 
					
						
							|  |  |  | 	       ; | 
					
						
							|  |  |  | 	         true | 
					
						
							|  |  |  | 	      ), | 
					
						
							| 
									
										
										
										
											2013-02-08 10:36:45 -06:00
										 |  |  | 	     '$continue_debugging'(fail, CalledFromDebugger), | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | 	     fail			/* to backtrack to spycalls	*/ | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	     ) | 
					
						
							| 
									
										
										
										
											2002-12-13 20:00:41 +00:00
										 |  |  | 	  ; | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 	    '$show_trace'(fail,G,Module,GoalNumber,_), /* inform at fail port		*/ | 
					
						
							| 
									
										
										
										
											2013-02-08 10:36:45 -06:00
										 |  |  | 	    '$continue_debugging'(fail, CalledFromDebugger), | 
					
						
							| 
									
										
										
										
											2005-10-18 17:04:43 +00:00
										 |  |  | 	    /* fail port */ | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	    fail | 
					
						
							| 
									
										
										
										
											2002-12-11 16:08:35 +00:00
										 |  |  | 	). | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | '$enter_goal'(GoalNumber, G, Module) :- | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  |     '$zip'(GoalNumber, G, Module), !. | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | '$enter_goal'(GoalNumber, G, Module) :- | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  |     '$trace'(call, G, Module, GoalNumber, _). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | '$show_trace'(_, G, Module, GoalNumber,_) :- | 
					
						
							|  |  |  | 	'$zip'(GoalNumber, G, Module), !. | 
					
						
							|  |  |  | '$show_trace'(P,G,Module,GoalNumber,Deterministic) :- | 
					
						
							|  |  |  | 	'$trace'(P,G,Module,GoalNumber,Deterministic). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | % | 
					
						
							|  |  |  | % skip a goal or a port | 
					
						
							|  |  |  | % | 
					
						
							|  |  |  | '$zip'(GoalNumber, G, Module) :- | 
					
						
							|  |  |  |     nb_getval('$debug_run',StopPoint), | 
					
						
							|  |  |  |     % zip mode off, we cannot zip | 
					
						
							|  |  |  |     StopPoint \= off, | 
					
						
							|  |  |  |     ( | 
					
						
							|  |  |  |       % skip spy points (eg, s). | 
					
						
							|  |  |  |       StopPoint == spy | 
					
						
							|  |  |  |     -> | 
					
						
							|  |  |  |       \+ '$pred_being_spied'(G, Module) | 
					
						
							|  |  |  |     ; | 
					
						
							|  |  |  |       % skip goals (eg, l). | 
					
						
							|  |  |  |       number(StopPoint) | 
					
						
							|  |  |  |     -> | 
					
						
							|  |  |  |       StopPoint < GoalNumber | 
					
						
							|  |  |  |     ). | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | %  | 
					
						
							| 
									
										
										
										
											2007-01-24 14:20:04 +00:00
										 |  |  | '$spycall'(G, M, _, _) :- | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | 	nb_getval('$debug_jump',true), | 
					
						
							| 
									
										
										
										
											2006-12-14 09:15:18 +00:00
										 |  |  | 	!, | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | 	'$execute_nonstop'(G,M). | 
					
						
							| 
									
										
										
										
											2007-01-24 14:20:04 +00:00
										 |  |  | '$spycall'(G, M, _, _) :- | 
					
						
							| 
									
										
										
										
											2013-02-08 10:36:45 -06:00
										 |  |  |         ( | 
					
						
							|  |  |  | 	 '$system_predicate'(G,M) | 
					
						
							|  |  |  | 	; | 
					
						
							|  |  |  | 	 '$system_module'(M) | 
					
						
							|  |  |  | 	), | 
					
						
							|  |  |  | 	!, | 
					
						
							| 
									
										
										
										
											2014-02-19 00:04:26 +00:00
										 |  |  | 	( '$is_metapredicate'(G, M) | 
					
						
							|  |  |  | 	   -> | 
					
						
							|  |  |  | 	  '$meta_expansion'(G,M,M,M,G1,[]), | 
					
						
							|  |  |  | 	  '$creep'(G1, M) | 
					
						
							| 
									
										
										
										
											2013-02-08 10:36:45 -06:00
										 |  |  | 	; | 
					
						
							| 
									
										
										
										
											2014-02-19 00:04:26 +00:00
										 |  |  | 	'$execute'(M:G) | 
					
						
							| 
									
										
										
										
											2013-02-08 10:36:45 -06:00
										 |  |  | 	). | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | '$spycall'(G, M, _, _) :- | 
					
						
							| 
									
										
										
										
											2007-03-26 15:18:43 +00:00
										 |  |  |         '$tabled_predicate'(G,M), | 
					
						
							|  |  |  | 	 !, | 
					
						
							| 
									
										
										
										
											2013-02-08 10:36:45 -06:00
										 |  |  | 	'$continue_debugging_goal'(no, '$execute_nonstop'(G,M)). | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | '$spycall'(G, M, CalledFromDebugger, InRedo) :- | 
					
						
							| 
									
										
										
										
											2014-02-19 00:04:26 +00:00
										 |  |  | 	'$is_metapredicate'(G, M), !, | 
					
						
							|  |  |  | 	'$meta_expansion'(G,M,M,M,G1,[]), | 
					
						
							|  |  |  | 	'$spycall_expanded'(G1, M, CalledFromDebugger, InRedo). | 
					
						
							|  |  |  | '$spycall'(G, M, CalledFromDebugger, InRedo) :- | 
					
						
							|  |  |  | 	'$spycall_expanded'(G, M, CalledFromDebugger, InRedo). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | '$spycall_expanded'(G, M, CalledFromDebugger, InRedo) :- | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	'$flags'(G,M,F,F), | 
					
						
							| 
									
										
										
										
											2011-07-22 14:10:55 +01:00
										 |  |  | 	F /\ 0x08402000 =\= 0, !, % dynamic procedure, logical semantics, or source | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	% use the interpreter | 
					
						
							|  |  |  | 	CP is '$last_choice_pt', | 
					
						
							| 
									
										
										
										
											2009-03-26 08:12:24 +00:00
										 |  |  | 	'$clause'(G, M, Cl, _), | 
					
						
							| 
									
										
										
										
											2009-04-16 16:33:49 -05:00
										 |  |  | 	% I may backtrack to here from far away | 
					
						
							| 
									
										
										
										
											2013-02-13 09:06:06 -06:00
										 |  |  | 	( '$do_spy'(Cl, M, CP, debugger) ; InRedo = true ). | 
					
						
							| 
									
										
										
										
											2014-02-19 00:04:26 +00:00
										 |  |  | '$spycall_expanded'(G, M, CalledFromDebugger, InRedo) :- | 
					
						
							| 
									
										
										
										
											2005-10-21 16:09:03 +00:00
										 |  |  | 	'$undefined'(G, M), !, | 
					
						
							| 
									
										
										
										
											2010-12-03 12:40:30 +00:00
										 |  |  | 	'$find_goal_definition'(M, G, NM, Goal), | 
					
						
							|  |  |  | 	'$spycall'(Goal, NM, CalledFromDebugger, InRedo). | 
					
						
							| 
									
										
										
										
											2014-02-19 00:04:26 +00:00
										 |  |  | '$spycall_expanded'(G, M, _, InRedo) :- | 
					
						
							| 
									
										
										
										
											2004-01-29 13:37:10 +00:00
										 |  |  | 	% I lost control here. | 
					
						
							| 
									
										
										
										
											2005-08-02 03:09:52 +00:00
										 |  |  | 	CP is '$last_choice_pt', | 
					
						
							| 
									
										
										
										
											2006-03-24 16:26:31 +00:00
										 |  |  | 	'$static_clause'(G,M,_,R), | 
					
						
							| 
									
										
										
										
											2009-04-16 16:33:49 -05:00
										 |  |  | 	% I may backtrack to here from far away | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | 	( | 
					
						
							| 
									
										
										
										
											2013-02-08 10:36:45 -06:00
										 |  |  | 	 '$continue_debugging_goal'(no, '$execute_clause'(G, M, R, CP)) | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | 	; | 
					
						
							|  |  |  | 	 InRedo = true | 
					
						
							|  |  |  | 	). | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-13 08:42:57 +00:00
										 |  |  | % | 
					
						
							|  |  |  | % execute a built-in in creep mode | 
					
						
							|  |  |  | % | 
					
						
							|  |  |  | '$creep'(G,M) :- | 
					
						
							| 
									
										
										
										
											2013-02-08 10:36:45 -06:00
										 |  |  | 	( | 
					
						
							| 
									
										
										
										
											2013-02-13 09:06:06 -06:00
										 |  |  | 	 '$$save_by'(CP1), | 
					
						
							| 
									
										
										
										
											2013-12-13 08:42:57 +00:00
										 |  |  | 	 '$creep', | 
					
						
							| 
									
										
										
										
											2013-02-08 10:36:45 -06:00
										 |  |  | 	 '$execute_nonstop'(G,M), | 
					
						
							| 
									
										
										
										
											2013-02-13 09:06:06 -06:00
										 |  |  | 	 '$$save_by'(CP2), | 
					
						
							| 
									
										
										
										
											2013-12-13 08:42:57 +00:00
										 |  |  | 	 (CP1 == CP2 -> ! ; ( true ; '$creep', fail ) ), | 
					
						
							|  |  |  | 	  '$stop_creeping' | 
					
						
							| 
									
										
										
										
											2013-02-08 10:36:45 -06:00
										 |  |  | 	; | 
					
						
							|  |  |  | 	  fail | 
					
						
							|  |  |  | 	). | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-03-26 15:18:43 +00:00
										 |  |  | '$tabled_predicate'(G,M) :- | 
					
						
							|  |  |  | 	'$flags'(G,M,F,F), | 
					
						
							|  |  |  | 	F /\ 0x00000040 =\= 0. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-13 09:06:06 -06:00
										 |  |  | %'$trace'(P,G,Module,L,Deterministic) :- | 
					
						
							|  |  |  | %	'$nb_getval'('$system_mode',On,fail), writeln(On), fail. | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | '$trace'(P,G,Module,L,Deterministic) :- | 
					
						
							|  |  |  | 	% at this point we are done with leap or skip | 
					
						
							|  |  |  | 	nb_setval('$debug_run',off), | 
					
						
							|  |  |  | 	% make sure we run this code outside debugging mode. | 
					
						
							| 
									
										
										
										
											2013-10-31 13:16:27 +00:00
										 |  |  | 	'$swi_set_prolog_flag'(debug, false), | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 	repeat, | 
					
						
							|  |  |  | 	'$trace_msg'(P,G,Module,L,Deterministic), | 
					
						
							|  |  |  | 	(  | 
					
						
							| 
									
										
										
										
											2007-10-08 23:02:16 +00:00
										 |  |  | 	  '$unleashed'(P) -> | 
					
						
							|  |  |  | 	  '$action'(10,P,L,G,Module,Debug), | 
					
						
							|  |  |  | 	  put_code(user_error, 10) | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 	  ; | 
					
						
							|  |  |  | 	  write(user_error,' ? '), get0(user_input,C), | 
					
						
							|  |  |  | 	  '$action'(C,P,L,G,Module,Debug) | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | 	), | 
					
						
							|  |  |  | 	(Debug = on | 
					
						
							|  |  |  | 	-> | 
					
						
							| 
									
										
										
										
											2013-10-31 13:16:27 +00:00
										 |  |  | 	 '$swi_set_prolog_flag'(debug, true) | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | 	; | 
					
						
							|  |  |  | 	 Debug = zip | 
					
						
							|  |  |  | 	-> | 
					
						
							| 
									
										
										
										
											2013-10-31 13:16:27 +00:00
										 |  |  | 	 '$swi_set_prolog_flag'(debug, true) | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | 	; | 
					
						
							| 
									
										
										
										
											2013-10-31 13:16:27 +00:00
										 |  |  | 	 '$swi_set_prolog_flag'(debug, false) | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | 	), | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 	!. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | '$trace_msg'(P,G,Module,L,Deterministic) :- | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	flush_output(user_output), | 
					
						
							|  |  |  | 	flush_output(user_error), | 
					
						
							| 
									
										
										
										
											2009-11-04 00:10:27 +00:00
										 |  |  | 	functor(P,P0,_), | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 	(P = exit, Deterministic \= true -> Det = '?' ; Det = ' '), | 
					
						
							|  |  |  | 	('$pred_being_spied'(G,Module) -> CSPY = '*' ; CSPY = ' '), | 
					
						
							| 
									
										
										
										
											2006-03-24 16:26:31 +00:00
										 |  |  | % vsc: fix this | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 		%		( SL = L -> SLL = '>' ; SLL = ' '), | 
					
						
							|  |  |  | 	SLL = ' ', | 
					
						
							|  |  |  | 	( Module\=prolog, | 
					
						
							| 
									
										
										
										
											2009-11-17 00:13:54 +00:00
										 |  |  | 	  Module\=user | 
					
						
							|  |  |  | 	-> | 
					
						
							|  |  |  | 	    GW = Module:G | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 	; | 
					
						
							| 
									
										
										
										
											2009-11-17 00:13:54 +00:00
										 |  |  | 	    GW = G	   | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 	), | 
					
						
							| 
									
										
										
										
											2009-11-17 00:23:22 +00:00
										 |  |  | 	format(user_error,'~a~a~a       (~d)    ~q:',[Det,CSPY,SLL,L,P0]), | 
					
						
							| 
									
										
										
										
											2009-11-17 00:13:54 +00:00
										 |  |  | 	'$debugger_write'(user_error,GW). | 
					
						
							| 
									
										
										
										
											2005-07-06 15:10:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | '$unleashed'(call) :- get_value('$leash',L), L /\ 2'1000 =:= 0. %' | 
					
						
							|  |  |  | '$unleashed'(exit) :- get_value('$leash',L), L /\ 2'0100 =:= 0. %' | 
					
						
							|  |  |  | '$unleashed'(redo) :- get_value('$leash',L), L /\ 2'0010 =:= 0. %' | 
					
						
							|  |  |  | '$unleashed'(fail) :- get_value('$leash',L), L /\ 2'0001 =:= 0. %' | 
					
						
							| 
									
										
										
										
											2002-01-10 18:01:14 +00:00
										 |  |  | % the same as fail. | 
					
						
							| 
									
										
										
										
											2009-11-04 00:10:27 +00:00
										 |  |  | '$unleashed'(exception(_)) :- get_value('$leash',L), L /\ 2'0001 =:= 0.  %' | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-01-10 18:01:14 +00:00
										 |  |  | '$debugger_write'(Stream, G) :- | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	recorded('$print_options','$debugger'(OUT),_), !, | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	write_term(Stream, G, OUT). | 
					
						
							| 
									
										
										
										
											2002-01-10 18:01:14 +00:00
										 |  |  | '$debugger_write'(Stream, G) :- | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	writeq(Stream, G). | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-11 12:06:27 -06:00
										 |  |  | '$action'(13,P,CallNumber,G,Module,Zip) :- !,	% newline 	creep | 
					
						
							|  |  |  | 	get0(user_input,C), | 
					
						
							|  |  |  | 	'$action'(C,P,CallNumber,G,Module,Zip). | 
					
						
							| 
									
										
										
										
											2009-11-04 12:29:09 +00:00
										 |  |  | '$action'(10,_,_,_,_,on) :- !,			% newline 	creep | 
					
						
							| 
									
										
										
										
											2008-10-13 15:40:05 +01:00
										 |  |  | 	nb_setval('$debug_jump',false). | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | '$action'(0'!,_,_,_,_,_) :- !,			% ! 'g		execute | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	read(user,G), | 
					
						
							|  |  |  | 	% don't allow yourself to be caught by creep. | 
					
						
							| 
									
										
										
										
											2013-10-31 13:16:27 +00:00
										 |  |  | 	'$swi_current_prolog_flag'(debug, OldDeb), | 
					
						
							| 
									
										
										
										
											2013-11-04 22:31:43 +00:00
										 |  |  | 	 '$swi_set_prolog_flag'(debug, false), | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	( '$execute'(G) -> true ; true), | 
					
						
							| 
									
										
										
										
											2013-10-31 13:16:27 +00:00
										 |  |  | 	'$swi_set_prolog_flag'(debug, OldDeb), | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | %	'$skipeol'(0'!),                        % ' | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	fail. | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | '$action'(0'<,_,_,_,_,_) :- !,			% <'Depth | 
					
						
							| 
									
										
										
										
											2002-01-02 03:54:15 +00:00
										 |  |  | 	'$new_deb_depth', | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	'$skipeol'(0'<), | 
					
						
							| 
									
										
										
										
											2002-01-02 03:54:15 +00:00
										 |  |  | 	fail. | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | '$action'(0'^,_,_,G,_,_) :- !,			% ' | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	'$print_deb_sterm'(G), | 
					
						
							|  |  |  | 	'$skipeol'(0'^), | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	fail. | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | '$action'(0'a,_,_,_,_,off) :- !,		% 'a		abort | 
					
						
							| 
									
										
										
										
											2006-03-06 14:04:57 +00:00
										 |  |  | 	'$skipeol'(0'a), | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	abort. | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | '$action'(0'b,_,_,_,_,_) :- !,			% 'b		break | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	'$skipeol'(0'b), | 
					
						
							|  |  |  | 	break, | 
					
						
							|  |  |  | 	fail. | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | '$action'(0'A,_,_,_,_,_) :- !,			% 'b		break | 
					
						
							| 
									
										
										
										
											2006-03-06 14:04:57 +00:00
										 |  |  | 	'$skipeol'(0'A), | 
					
						
							| 
									
										
										
										
											2014-04-06 17:05:17 +01:00
										 |  |  | 	'$hacks':'$stack_dump', | 
					
						
							| 
									
										
										
										
											2006-03-06 14:04:57 +00:00
										 |  |  | 	fail. | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | '$action'(0'c,_,_,_,_,on) :- !,			% 'c		creep | 
					
						
							| 
									
										
										
										
											2008-10-10 00:39:24 +01:00
										 |  |  | 	'$skipeol'(0'c), | 
					
						
							|  |  |  | 	nb_setval('$debug_jump',false). | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | '$action'(0'e,_,_,_,_,_) :- !,			% 'e		exit | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	'$skipeol'(0'e), | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	halt. | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | '$action'(0'f,_,CallId,_,_,_) :- !,		% 'f		fail | 
					
						
							| 
									
										
										
										
											2009-04-22 11:31:31 -05:00
										 |  |  | 	'$scan_number'(0'f, CallId, GoalId),    %'f | 
					
						
							| 
									
										
										
										
											2009-04-22 16:13:08 -05:00
										 |  |  | 	throw(error('$fail_spy'(GoalId),[])). | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | '$action'(0'h,_,_,_,_,_) :- !,			% 'h		help | 
					
						
							| 
									
										
										
										
											2002-01-18 04:24:10 +00:00
										 |  |  | 	'$action_help', | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	'$skipeol'(104), | 
					
						
							|  |  |  | 	fail. | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | '$action'(0'?,_,_,_,_,_) :- !,			% '?		help | 
					
						
							| 
									
										
										
										
											2002-01-18 04:24:10 +00:00
										 |  |  | 	'$action_help', | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	'$skipeol'(104), | 
					
						
							|  |  |  | 	fail. | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | '$action'(0'p,_,_,G,Module,_) :- !,		% 'p		print | 
					
						
							| 
									
										
										
										
											2002-04-26 19:29:22 +00:00
										 |  |  | 	((Module = prolog ; Module = user) -> | 
					
						
							|  |  |  | 	    print(user_error,G), nl(user_error) | 
					
						
							|  |  |  | 	; | 
					
						
							|  |  |  | 	    print(user_error,Module:G), nl(user_error) | 
					
						
							|  |  |  | 	), | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	'$skipeol'(0'p), | 
					
						
							|  |  |  | 	fail. | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | '$action'(0'd,_,_,G,Module,_) :- !,		% 'd		display | 
					
						
							| 
									
										
										
										
											2002-04-26 19:29:22 +00:00
										 |  |  | 	((Module = prolog ; Module = user) -> | 
					
						
							|  |  |  | 	    display(user_error,G), nl(user_error) | 
					
						
							|  |  |  | 	; | 
					
						
							|  |  |  | 	    display(user_error,Module:G), nl(user_error) | 
					
						
							|  |  |  | 	), | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	'$skipeol'(0'd), | 
					
						
							|  |  |  | 	fail. | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | '$action'(0'l,_,_,_,_,on) :- !,			% 'l		leap | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	'$skipeol'(0'l), | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | 	nb_setval('$debug_run',spy), | 
					
						
							|  |  |  | 	nb_setval('$debug_jump',false). | 
					
						
							|  |  |  | '$action'(0'z,_,_,_,_,zip) :- !,		% 'z		zip, fast leap | 
					
						
							|  |  |  | 	'$skipeol'(0'z),			% 'z | 
					
						
							|  |  |  | 	nb_setval('$debug_run',spy), | 
					
						
							|  |  |  | 	nb_setval('$debug_jump',true). | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 	% skip first call (for current goal), | 
					
						
							|  |  |  | 	% stop next time. | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | '$action'(0'k,_,_,_,_,zip) :- !,		% 'k		zip, fast leap | 
					
						
							|  |  |  | 	'$skipeol'(0'k),			% ' | 
					
						
							|  |  |  | 	nb_setval('$debug_run',spy), | 
					
						
							|  |  |  | 	nb_setval('$debug_jump',true). | 
					
						
							| 
									
										
										
										
											2003-11-27 21:47:44 +00:00
										 |  |  | 	% skip first call (for current goal), | 
					
						
							|  |  |  | 	% stop next time. | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | '$action'(0'n,_,_,_,_,off) :- !,			% 'n		nodebug | 
					
						
							|  |  |  | 	'$skipeol'(0'n),				% ' | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 	% tell debugger never to stop. | 
					
						
							|  |  |  |         nb_setval('$debug_run', -1), | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | 	nb_setval('$debug_jump',true), | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 	nodebug. | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | '$action'(0'r,_,CallId,_,_,_) :- !,		        % 'r		retry | 
					
						
							|  |  |  |         '$scan_number'(0'r,CallId,ScanNumber),		% ' | 
					
						
							| 
									
										
										
										
											2013-10-31 13:16:27 +00:00
										 |  |  | 	'$swi_set_prolog_flag'(debug, true), | 
					
						
							| 
									
										
										
										
											2009-04-22 16:13:08 -05:00
										 |  |  | 	throw(error('$retry_spy'(ScanNumber),[])). | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | '$action'(0's,P,CallNumber,_,_,on) :- !,		% 's		skip | 
					
						
							|  |  |  | 	'$skipeol'(0's),				% '		 | 
					
						
							| 
									
										
										
										
											2002-05-10 15:04:03 +00:00
										 |  |  | 	( (P=call; P=redo) -> | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | 	  nb_setval('$debug_run',CallNumber), | 
					
						
							|  |  |  | 	  nb_setval('$debug_jump',false) | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	; | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | 	    '$ilgl'(0's)				% ' | 
					
						
							| 
									
										
										
										
											2002-05-10 15:04:03 +00:00
										 |  |  | 	). | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | '$action'(0't,P,CallNumber,_,_,zip) :- !,		% 't		fast skip | 
					
						
							|  |  |  | 	'$skipeol'(0't),				% ' | 
					
						
							| 
									
										
										
										
											2002-05-10 15:04:03 +00:00
										 |  |  | 	( (P=call; P=redo) -> | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | 	  nb_setval('$debug_run',CallNumber), | 
					
						
							|  |  |  | 	  nb_setval('$debug_jump',true) | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 	; | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | 	    '$ilgl'(0't)				% ' | 
					
						
							| 
									
										
										
										
											2002-05-10 15:04:03 +00:00
										 |  |  | 	). | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | '$action'(0'+,_,_,G,M,_) :- !,			% '+		spy this | 
					
						
							| 
									
										
										
										
											2002-04-26 19:29:22 +00:00
										 |  |  | 	functor(G,F,N), spy(M:(F/N)), | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | 	'$skipeol'(0'+),			% ' | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	fail. | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | '$action'(0'-,_,_,G,M,_) :- !,			% '-		nospy this | 
					
						
							| 
									
										
										
										
											2002-04-26 19:29:22 +00:00
										 |  |  | 	functor(G,F,N), nospy(M:(F/N)), | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | 	'$skipeol'(0'-),			% ' | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	fail. | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | '$action'(0'g,_,_,_,_,_) :- !,			% 'g		ancestors | 
					
						
							|  |  |  |         '$scan_number'(0'g,-1,HowMany),         % ' | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  |         '$show_ancestors'(HowMany), | 
					
						
							|  |  |  | 	fail. | 
					
						
							|  |  |  | '$action'(C,_,_,_,_,_) :- | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	'$skipeol'(C), | 
					
						
							|  |  |  | 	'$ilgl'(C), | 
					
						
							|  |  |  | 	fail. | 
					
						
							| 
									
										
										
										
											2002-01-18 04:24:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-08 10:36:45 -06:00
										 |  |  | % first argument is exit, zip or fail | 
					
						
							|  |  |  | % second is creep, meta_creep, spy, or debugger | 
					
						
							| 
									
										
										
										
											2013-02-13 09:06:06 -06:00
										 |  |  | %'$continue_debugging'(Exit, Debugger) :- | 
					
						
							|  |  |  | %	writeln('$continue_debugging'(Exit, Debugger)), fail. | 
					
						
							|  |  |  | % that's what follows | 
					
						
							|  |  |  | '$continue_debugging'(_, debugger) :- !. | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | % do not need to debug! | 
					
						
							| 
									
										
										
										
											2013-02-13 09:06:06 -06:00
										 |  |  | % go back to original sequence. | 
					
						
							| 
									
										
										
										
											2013-12-13 08:42:57 +00:00
										 |  |  | '$continue_debugging'(zip, _) :- !. | 
					
						
							| 
									
										
										
										
											2013-02-13 09:06:06 -06:00
										 |  |  | '$continue_debugging'(_, creep) :- !, | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | 	'$creep'. | 
					
						
							| 
									
										
										
										
											2013-12-13 08:42:57 +00:00
										 |  |  | '$continue_debugging'(fail, _) :- !. | 
					
						
							|  |  |  | '$continue_debugging'(_, _). | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-11-27 21:47:44 +00:00
										 |  |  | % if we are in the interpreter, don't need to care about forcing a trace, do we? | 
					
						
							| 
									
										
										
										
											2013-02-13 09:06:06 -06:00
										 |  |  | '$continue_debugging_goal'(yes,G) :- !, | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | 	'$execute_dgoal'(G). | 
					
						
							|  |  |  | % do not need to debug! | 
					
						
							| 
									
										
										
										
											2013-02-13 09:06:06 -06:00
										 |  |  | '$continue_debugging_goal'(_,G) :- | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 	'nb_getval'('$debug_run',Zip), | 
					
						
							| 
									
										
										
										
											2012-10-19 18:13:48 +01:00
										 |  |  |         (Zip == nodebug ;  number(Zip) ; Zip == spy ), !, | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | 	'$execute_dgoal'(G). | 
					
						
							| 
									
										
										
										
											2013-02-13 09:06:06 -06:00
										 |  |  | '$continue_debugging_goal'(_,G) :- | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | 	'$execute_creep_dgoal'(G). | 
					
						
							| 
									
										
										
										
											2005-02-08 04:05:39 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | '$execute_dgoal'('$execute_nonstop'(G,M)) :- | 
					
						
							| 
									
										
										
										
											2013-03-03 20:26:48 -06:00
										 |  |  | 	 '$execute_nonstop'(G,M). | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | '$execute_dgoal'('$execute_clause'(G, M, R, CP)) :- | 
					
						
							| 
									
										
										
										
											2013-03-03 20:26:48 -06:00
										 |  |  | 	 '$execute_clause'(G, M, R, CP). | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | '$execute_creep_dgoal'('$execute_nonstop'(G,M)) :- | 
					
						
							| 
									
										
										
										
											2013-02-08 10:36:45 -06:00
										 |  |  | 	'$creep', | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | 	'$execute_nonstop'(G,M). | 
					
						
							|  |  |  | '$execute_creep_dgoal'('$execute_clause'(G, M, R, CP)) :- | 
					
						
							| 
									
										
										
										
											2013-02-08 10:36:45 -06:00
										 |  |  | 	'$creep', | 
					
						
							| 
									
										
										
										
											2008-08-30 02:39:36 +01:00
										 |  |  | 	'$execute_clause'(G, M, R, CP). | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | '$show_ancestors'(HowMany) :- | 
					
						
							|  |  |  | 	b_getval('$spy_glist',[_|History]), | 
					
						
							|  |  |  | 	( | 
					
						
							|  |  |  | 	  History == [] | 
					
						
							|  |  |  | 	-> | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  | 	  print_message(help, ancestors([])) | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 	; | 
					
						
							|  |  |  | 	  '$show_ancestors'(History,HowMany), | 
					
						
							|  |  |  | 	  nl(user_error) | 
					
						
							|  |  |  | 	). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | '$show_ancestors'([],_). | 
					
						
							|  |  |  | '$show_ancestors'([_|_],0) :- !. | 
					
						
							| 
									
										
										
										
											2010-01-25 10:21:21 +00:00
										 |  |  | '$show_ancestors'([info(L,M,G,Retry,Det,_Exited)|History],HowMany) :- | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 	'$show_ancestor'(L,M,G,Retry,Det,HowMany,HowMany1), | 
					
						
							|  |  |  | 	'$show_ancestors'(History,HowMany1). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | % skip exit port, we're looking at true ancestors | 
					
						
							|  |  |  | '$show_ancestor'(_,_,_,_,Det,HowMany,HowMany) :- | 
					
						
							|  |  |  | 	nonvar(Det), !. | 
					
						
							|  |  |  | % look at retry | 
					
						
							| 
									
										
										
										
											2007-01-24 14:20:04 +00:00
										 |  |  | '$show_ancestor'(GoalNumber, M, G, Retry, _, HowMany, HowMany1) :- | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 	nonvar(Retry), !, | 
					
						
							|  |  |  | 	HowMany1 is HowMany-1, | 
					
						
							|  |  |  | 	'$trace_msg'(redo, G, M, GoalNumber, _), nl(user_error). | 
					
						
							| 
									
										
										
										
											2007-01-24 14:20:04 +00:00
										 |  |  | '$show_ancestor'(GoalNumber, M, G, _, _, HowMany, HowMany1) :- | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 	HowMany1 is HowMany-1, | 
					
						
							|  |  |  | 	'$trace_msg'(call, G, M, GoalNumber, _), nl(user_error). | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-01-18 04:24:10 +00:00
										 |  |  | '$action_help' :- | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 	format(user_error,'newline  creep       a       abort~n', []), | 
					
						
							|  |  |  | 	format(user_error,'c        creep       e       exit~n', []), | 
					
						
							|  |  |  | 	format(user_error,'f Goal   fail        h       help~n', []), | 
					
						
							|  |  |  | 	format(user_error,'l        leap        r Goal  retry~n', []), | 
					
						
							|  |  |  | 	format(user_error,'s        skip        t       fastskip~n', []), | 
					
						
							|  |  |  | 	format(user_error,'q        quasiskip   k       quasileap~n', []), | 
					
						
							|  |  |  | 	format(user_error,'b        break       n       no debug~n', []), | 
					
						
							|  |  |  | 	format(user_error,'p        print       d       display~n', []), | 
					
						
							|  |  |  | 	format(user_error,'<D       depth D     <       full term~n', []), | 
					
						
							|  |  |  | 	format(user_error,'+        spy this    -       nospy this~n', []), | 
					
						
							|  |  |  | 	format(user_error,'^        view subg   ^^      view using~n', []), | 
					
						
							|  |  |  | 	format(user_error,'A        choices     g [N]   ancestors~n', []), | 
					
						
							|  |  |  | 	format(user_error,'! g execute goal~n', []). | 
					
						
							| 
									
										
										
										
											2002-01-18 04:24:10 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | '$ilgl'(C) :- | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  | 	print_message(warning, trace_command(C)), | 
					
						
							|  |  |  | 	print_message(help, trace_help), | 
					
						
							| 
									
										
										
										
											2004-07-15 15:47:08 +00:00
										 |  |  | 	fail. | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | '$skipeol'(10) :- !. | 
					
						
							|  |  |  | '$skipeol'(_) :- get0(user,C), '$skipeol'(C). | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | '$scan_number'(_, _, Nb) :- | 
					
						
							|  |  |  | 	get0(user,C), | 
					
						
							|  |  |  | 	'$scan_number2'(C, Nb), !. | 
					
						
							|  |  |  | '$scan_number'(_, CallId, CallId). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | '$scan_number2'(10, _) :- !, fail. | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | '$scan_number2'(0' , Nb) :- !, % ' | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	get0(user,C), | 
					
						
							|  |  |  | 	'$scan_number2'(C , Nb). | 
					
						
							| 
									
										
										
										
											2008-09-02 03:48:02 +01:00
										 |  |  | '$scan_number2'(0'	, Nb) :- !, %' | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	get0(user,C), | 
					
						
							|  |  |  | 	'$scan_number2'(C, Nb). | 
					
						
							|  |  |  | '$scan_number2'(C, Nb) :- | 
					
						
							|  |  |  | 	'$scan_number3'(C, 0, Nb). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | '$scan_number3'(10,  Nb, Nb) :- !, Nb > 0. | 
					
						
							|  |  |  | '$scan_number3'( C, Nb0, Nb) :- | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 	C >= "0", C =< "9", | 
					
						
							|  |  |  | 	NbI is Nb0*10+(C-"0"), | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	get0(user, NC), | 
					
						
							|  |  |  | 	'$scan_number3'( NC, NbI, Nb). | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | '$print_deb_sterm'(G) :- | 
					
						
							|  |  |  | 	'$get_sterm_list'(L), !, | 
					
						
							|  |  |  | 	'$deb_get_sterm_in_g'(L,G,A), | 
					
						
							|  |  |  | 	recorda('$debug_sub_skel',L,_), | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 	format(user_error,'~n~w~n~n',[A]). | 
					
						
							| 
									
										
										
										
											2001-10-30 16:42:05 +00:00
										 |  |  | '$print_deb_sterm'(_) :- '$skipeol'(94). | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | '$get_sterm_list'(L) :- | 
					
						
							|  |  |  | 	get0(user_input,C), | 
					
						
							|  |  |  | 	'$deb_inc_in_sterm_oldie'(C,L0,CN), | 
					
						
							|  |  |  | 	'$get_sterm_list'(L0,CN,0,L). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | '$deb_inc_in_sterm_oldie'(94,L0,CN) :- !, | 
					
						
							|  |  |  | 	get0(user_input,CN), | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	( recorded('$debug_sub_skel',L0,_) -> true ; | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	  CN = [] ). | 
					
						
							|  |  |  | '$deb_inc_in_sterm_oldie'(C,[],C). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | '$get_sterm_list'(L0,C,N,L) :- | 
					
						
							| 
									
										
										
										
											2003-12-27 00:38:53 +00:00
										 |  |  | 	( C =:= "^", N =\= 0 -> get0(CN), | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 				'$get_sterm_list'([N|L0],CN,0,L) ; | 
					
						
							|  |  |  | 	  C >= "0", C =< "9" -> NN is 10*N+C-"0", get0(CN), | 
					
						
							|  |  |  | 				'$get_sterm_list'(L0,CN,NN,L); | 
					
						
							|  |  |  | 	  C =:= 10 -> (N =:= 0 -> L = L0 ; L=[N|L0]) ). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | '$deb_get_sterm_in_g'([],G,G). | 
					
						
							|  |  |  | '$deb_get_sterm_in_g'([H|T],G,A) :- | 
					
						
							|  |  |  | 	'$deb_get_sterm_in_g'(T,G,A1), | 
					
						
							|  |  |  | 	arg(H,A1,A). | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-01-02 03:54:15 +00:00
										 |  |  | '$new_deb_depth' :- | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	get0(user_input,C), | 
					
						
							| 
									
										
										
										
											2002-11-20 20:01:33 +00:00
										 |  |  | 	'$get_deb_depth'(C,D), | 
					
						
							|  |  |  | 	'$set_deb_depth'(D). | 
					
						
							| 
									
										
										
										
											2002-01-02 03:54:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-20 20:01:33 +00:00
										 |  |  | '$get_deb_depth'(10,10) :-  !. % default depth is 0 | 
					
						
							|  |  |  | '$get_deb_depth'(C,XF) :- | 
					
						
							|  |  |  | 	'$get_deb_depth_char_by_char'(C,0,XF). | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-20 20:01:33 +00:00
										 |  |  | '$get_deb_depth_char_by_char'(10,X,X) :- !. | 
					
						
							|  |  |  | '$get_deb_depth_char_by_char'(C,X0,XF) :- | 
					
						
							|  |  |  | 	C >= "0", C =< "9", !, | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	XI is X0*10+C-"0", | 
					
						
							| 
									
										
										
										
											2002-11-20 20:01:33 +00:00
										 |  |  | 	get0(user_input,NC), | 
					
						
							|  |  |  | 	'$get_deb_depth_char_by_char'(NC,XI,XF). | 
					
						
							|  |  |  | % reset when given garbage. | 
					
						
							|  |  |  | '$get_deb_depth_char_by_char'(C,_,10) :- '$skipeol'(C). | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-01-02 03:54:15 +00:00
										 |  |  | '$set_deb_depth'(D) :- | 
					
						
							|  |  |  | 	recorded('$print_options','$debugger'(L),R), !, | 
					
						
							|  |  |  | 	'$delete_if_there'(L, max_depth(_), LN), | 
					
						
							|  |  |  | 	erase(R), | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	recorda('$print_options','$debugger'([max_depth(D)|LN]),_). | 
					
						
							| 
									
										
										
										
											2002-01-02 03:54:15 +00:00
										 |  |  | '$set_deb_depth'(D) :- | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	recorda('$print_options','$debugger'([quoted(true),numbervars(true),portrayed(true),max_depth(D)]),_). | 
					
						
							| 
									
										
										
										
											2002-01-02 03:54:15 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | '$delete_if_there'([], _, []). | 
					
						
							|  |  |  | '$delete_if_there'([T|L], T, LN) :- !, | 
					
						
							|  |  |  | 	'$delete_if_there'(L, T, LN). | 
					
						
							|  |  |  | '$delete_if_there'([Q|L], T, [Q|LN]) :- | 
					
						
							|  |  |  | 	'$delete_if_there'(L, T, LN). | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-03-06 14:04:57 +00:00
										 |  |  | '$debugger_deterministic_goal'(G) :- | 
					
						
							| 
									
										
										
										
											2007-01-24 14:20:04 +00:00
										 |  |  | 	yap_hacks:current_choicepoints(CPs0), | 
					
						
							|  |  |  | %	$cps(CPs0), | 
					
						
							|  |  |  | 	'$debugger_skip_traces'(CPs0,CPs1), | 
					
						
							|  |  |  | 	'$debugger_skip_loop_spy2'(CPs1,CPs2), | 
					
						
							|  |  |  | 	'$debugger_skip_spycall'(CPs2,CPs3), | 
					
						
							|  |  |  | 	'$debugger_skip_loop_spy2'(CPs3,[Catch|_]), | 
					
						
							| 
									
										
										
										
											2007-01-24 10:01:40 +00:00
										 |  |  | 	yap_hacks:choicepoint(Catch,_,prolog,'$catch',3,'$catch'(_,'$loop_spy_event'(_,_,G,_,_),_),_). | 
					
						
							| 
									
										
										
										
											2006-03-06 14:04:57 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | '$cps'([CP|CPs]) :- | 
					
						
							| 
									
										
										
										
											2007-01-24 14:20:04 +00:00
										 |  |  |     yap_hacks:choicepoint(CP,A,B,C,D,E,F), | 
					
						
							|  |  |  |     write(A:B:C:D:E:F),nl, | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  |     '$cps'(CPs). | 
					
						
							|  |  |  | '$cps'([]). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-01-24 14:20:04 +00:00
										 |  |  | '$debugger_skip_spycall'([CP|CPs],CPs1) :- | 
					
						
							|  |  |  | 	yap_hacks:choicepoint(CP,_,prolog,'$spycall',4,(_;_),_), !, | 
					
						
							|  |  |  | 	'$debugger_skip_spycall'(CPs,CPs1). | 
					
						
							|  |  |  | '$debugger_skip_spycall'(CPs,CPs). | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | '$debugger_skip_traces'([CP|CPs],CPs1) :- | 
					
						
							| 
									
										
										
										
											2007-01-24 10:01:40 +00:00
										 |  |  | 	yap_hacks:choicepoint(CP,_,prolog,'$trace',4,(_;_),_), !, | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 	'$debugger_skip_traces'(CPs,CPs1). | 
					
						
							|  |  |  | '$debugger_skip_traces'(CPs,CPs). | 
					
						
							| 
									
										
										
										
											2006-03-06 14:04:57 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | '$debugger_skip_loop_spy2'([CP|CPs],CPs1) :- | 
					
						
							| 
									
										
										
										
											2007-01-24 10:01:40 +00:00
										 |  |  | 	yap_hacks:choicepoint(CP,_,prolog,'$loop_spy2',5,(_;_),_), !, | 
					
						
							| 
									
										
										
										
											2006-12-13 16:10:26 +00:00
										 |  |  | 	'$debugger_skip_loop_spy2'(CPs,CPs1). | 
					
						
							|  |  |  | '$debugger_skip_loop_spy2'(CPs,CPs). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 |