| 
									
										
										
										
											2008-02-22 15:08:37 +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:		utilities for messing around in YAP internals.		 * | 
					
						
							|  |  |  | * comments:	error messages for YAP					 * | 
					
						
							|  |  |  | *									 * | 
					
						
							| 
									
										
										
										
											2008-03-24 23:48:47 +00:00
										 |  |  | * Last rev:     $Date: 2008-03-24 23:48:47 $,$Author: vsc $						 * | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  | *									 * | 
					
						
							|  |  |  | *									 * | 
					
						
							|  |  |  | *************************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :- module('$hacks', | 
					
						
							|  |  |  | 	  [display_stack_info/4, | 
					
						
							|  |  |  | 	   display_stack_info/6, | 
					
						
							|  |  |  | 	   display_pc/3, | 
					
						
							|  |  |  | 	   code_location/3]). | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-29 10:29:24 +01:00
										 |  |  | prolog:'$stack_dump' :- | 
					
						
							|  |  |  | 	yap_hacks:current_choicepoints(CPs), | 
					
						
							|  |  |  | 	yap_hacks:current_continuations([Env|Envs]), | 
					
						
							|  |  |  | 	yap_hacks:continuation(Env,_,ContP,_), | 
					
						
							|  |  |  | 	length(CPs, LCPs), | 
					
						
							|  |  |  | 	length(Envs, LEnvs), | 
					
						
							|  |  |  | 	format(user_error,'~n~n~tStack Dump~t~40+~n~nAddress~tChoiceP~16+ Clause          Goal~n',[LCPs,LEnvs]), | 
					
						
							|  |  |  | 	display_stack_info(CPs, Envs, 20, ContP, StackInfo, []), | 
					
						
							|  |  |  | 	run_formats(StackInfo, user_error). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | run_formats([], _). | 
					
						
							|  |  |  | run_formats([Com-Args|StackInfo], Stream) :- | 
					
						
							|  |  |  | 	format(Stream, Com, Args), | 
					
						
							| 
									
										
										
										
											2014-02-09 10:47:44 +00:00
										 |  |  | 	run_formats(StackInfo, Stream). | 
					
						
							| 
									
										
										
										
											2010-04-29 10:29:24 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  | display_stack_info(CPs,Envs,Lim,PC) :- | 
					
						
							|  |  |  | 	display_stack_info(CPs,Envs,Lim,CP,Lines,[]), | 
					
						
							|  |  |  | 	flush_output(user_output), | 
					
						
							|  |  |  | 	flush_output(user_error), | 
					
						
							|  |  |  | 	print_message_lines(user_error, '', Lines). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | code_location(Info,Where,Location) :- | 
					
						
							|  |  |  | 	integer(Where) , !, | 
					
						
							|  |  |  | 	'$pred_for_code'(Where,Name,Arity,Mod,Clause), | 
					
						
							|  |  |  | 	construct_code(Clause,Name,Arity,Mod,Info,Location). | 
					
						
							| 
									
										
										
										
											2013-02-13 09:06:06 -06:00
										 |  |  | code_location(Ixnfo,_,Info). | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | construct_code(-1,Name,Arity,Mod,Where,Location) :- !, | 
					
						
							|  |  |  | 	number_codes(Arity,ArityCode), | 
					
						
							|  |  |  | 	atom_codes(ArityAtom,ArityCode), | 
					
						
							|  |  |  | 	atom_concat([Where,' at ',Mod,':',Name,'/',ArityAtom,' at indexing code'],Location). | 
					
						
							|  |  |  | construct_code(0,_,_,_,Location,Location) :- !. | 
					
						
							|  |  |  | construct_code(Cl,Name,Arity,Mod,Where,Location) :- | 
					
						
							|  |  |  | 	number_codes(Arity,ArityCode), | 
					
						
							|  |  |  | 	atom_codes(ArityAtom,ArityCode), | 
					
						
							|  |  |  | 	number_codes(Cl,ClCode), | 
					
						
							|  |  |  | 	atom_codes(ClAtom,ClCode), | 
					
						
							|  |  |  | 	atom_concat([Where,' at ',Mod,':',Name,'/',ArityAtom,' (clause ',ClAtom,')'],Location). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | '$prepare_loc'(Info,Where,Location) :- integer(Where), !, | 
					
						
							|  |  |  | 	'$pred_for_code'(Where,Name,Arity,Mod,Clause), | 
					
						
							|  |  |  | 	'$construct_code'(Clause,Name,Arity,Mod,Info,Location). | 
					
						
							|  |  |  | '$prepare_loc'(Info,_,Info). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | display_pc(PC) --> | 
					
						
							|  |  |  | 	{ integer(PC) }, | 
					
						
							|  |  |  | 	{ '$pred_for_code'(PC,Name,Arity,Mod,Clause) }, | 
					
						
							|  |  |  | 	pc_code(Clause,Name,Arity,Mod). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | pc_code(-1,Name,Arity,Mod) --> !, | 
					
						
							|  |  |  | 	[ ' indexing code of ~a:~q/~d' - [Mod,Name,Arity] ]. | 
					
						
							|  |  |  | pc_code(Cl,Name,Arity,Mod) --> | 
					
						
							|  |  |  | 	{ Cl > 0 }, | 
					
						
							|  |  |  | 	[ ' clause ~d of ~a:~q/~d' - [Cl,Mod,Name,Arity] ]. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | display_stack_info(_,_,0,_) --> !. | 
					
						
							|  |  |  | display_stack_info([],[],_,_) --> []. | 
					
						
							|  |  |  | display_stack_info([CP|CPs],[],I,_) --> | 
					
						
							|  |  |  | 	show_lone_cp(CP), | 
					
						
							|  |  |  | 	{ I1 is I-1 }, | 
					
						
							|  |  |  | 	display_stack_info(CPs,[],I1,_). | 
					
						
							|  |  |  | display_stack_info([],[Env|Envs],I,Cont) --> | 
					
						
							|  |  |  | 	show_env(Env, Cont, NCont), | 
					
						
							|  |  |  | 	{ I1 is I-1 }, | 
					
						
							|  |  |  | 	display_stack_info([], Envs, I1, NCont). | 
					
						
							|  |  |  | display_stack_info([CP|LCPs],[Env|LEnvs],I,Cont) --> | 
					
						
							| 
									
										
										
										
											2008-03-24 23:48:47 +00:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 	 yap_hacks:continuation(Env, _, NCont, CB), | 
					
						
							|  |  |  | 	 I1 is I-1 | 
					
						
							|  |  |  | 	}, | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  | 	( { CP == Env, CB < CP } -> | 
					
						
							|  |  |  | 	    % if we follow choice-point and we cut to before choice-point | 
					
						
							|  |  |  | 	    % we are the same goal | 
					
						
							| 
									
										
										
										
											2010-04-29 10:29:24 +01:00
										 |  |  | 	   show_cp(CP, ''), % | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  |            display_stack_info(LCPs, LEnvs, I1, NCont) | 
					
						
							|  |  |  | 	; | 
					
						
							|  |  |  |           { CP > Env } -> | 
					
						
							| 
									
										
										
										
											2010-04-29 10:29:24 +01:00
										 |  |  | 	   show_cp(CP, ' < '), | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  | 	   display_stack_info(LCPs,[Env|LEnvs],I1,Cont) | 
					
						
							|  |  |  | 	; | 
					
						
							|  |  |  | 	   show_env(Env,Cont,NCont), | 
					
						
							|  |  |  | 	   display_stack_info([CP|LCPs],LEnvs,I1,NCont) | 
					
						
							|  |  |  | 	). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | show_cp(CP, Continuation) --> | 
					
						
							| 
									
										
										
										
											2008-03-17 18:31:16 +00:00
										 |  |  | 	{ yap_hacks:choicepoint(CP, Addr, Mod, Name, Arity, Goal, ClNo) }, | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  | 	( { Goal = (_;_) } | 
					
						
							|  |  |  |           -> | 
					
						
							| 
									
										
										
										
											2010-04-29 10:29:24 +01:00
										 |  |  | 	  { scratch_goal(Name,Arity,Mod,Caller) }, | 
					
						
							|  |  |  | 	  [ '0x~16r~t*~16+ ~d~16+ ~q ~n'- | 
					
						
							|  |  |  | 		[Addr, ClNo, Caller] ] | 
					
						
							|  |  |  | 	   | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  | 	    ; | 
					
						
							| 
									
										
										
										
											2010-04-29 10:29:24 +01:00
										 |  |  | 	  [ '0x~16r~t *~16+~a ~d~16+ ~q:' - | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  | 		[Addr, Continuation, ClNo, Mod]] | 
					
						
							|  |  |  | 	), | 
					
						
							| 
									
										
										
										
											2010-04-29 10:29:24 +01:00
										 |  |  | 	{ prolog_flag( debugger_print_options, Opts) }, | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  | 	{clean_goal(Goal,Mod,G)}, | 
					
						
							| 
									
										
										
										
											2008-08-25 15:20:18 +01:00
										 |  |  | 	['~@.~n' -  write_term(G,Opts)]. | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | show_env(Env,Cont,NCont) --> | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2008-03-17 18:31:16 +00:00
										 |  |  | 	 yap_hacks:continuation(Env, Addr, NCont, _), | 
					
						
							| 
									
										
										
										
											2013-02-08 10:36:45 -06:00
										 |  |  | 	format('0x~16r 0x~16r~n',[Env,NCont]), | 
					
						
							| 
									
										
										
										
											2008-03-17 18:31:16 +00:00
										 |  |  | 	 yap_hacks:cp_to_predicate(Cont, Mod, Name, Arity, ClId) | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  | 	}, | 
					
						
							| 
									
										
										
										
											2010-04-29 10:29:24 +01:00
										 |  |  |         [ '0x~16r~t  ~16+ ~d~16+ ~q:' - | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  | 		[Addr, ClId, Mod] ], | 
					
						
							|  |  |  | 	{scratch_goal(Name, Arity, Mod, G)}, | 
					
						
							| 
									
										
										
										
											2010-04-29 10:29:24 +01:00
										 |  |  | 	{ prolog_flag( debugger_print_options, Opts) }, | 
					
						
							| 
									
										
										
										
											2008-08-25 15:20:18 +01:00
										 |  |  | 	['~@.~n' - write_term(G,Opts)]. | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | clean_goal(G,Mod,NG) :- | 
					
						
							|  |  |  | 	beautify_hidden_goal(G,Mod,[NG],[]), !. | 
					
						
							|  |  |  | clean_goal(G,_,G). | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-29 10:29:24 +01:00
										 |  |  | scratch_goal(N,0,Mod,Mod:N) :- | 
					
						
							|  |  |  | 	!. | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  | scratch_goal(N,A,Mod,NG) :- | 
					
						
							|  |  |  | 	list_of_qmarks(A,L), | 
					
						
							|  |  |  | 	G=..[N|L], | 
					
						
							| 
									
										
										
										
											2008-03-17 18:31:16 +00:00
										 |  |  | 	( | 
					
						
							|  |  |  | 	  beautify_hidden_goal(G,Mod,[NG],[]) | 
					
						
							|  |  |  | 	; | 
					
						
							|  |  |  | 	  G = NG | 
					
						
							|  |  |  | 	), | 
					
						
							|  |  |  | 	!. | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-17 18:31:16 +00:00
										 |  |  | list_of_qmarks(0,[]) :- !. | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  | list_of_qmarks(I,[?|L]) :- | 
					
						
							|  |  |  | 	I1 is I-1, | 
					
						
							|  |  |  | 	list_of_qmarks(I1,L). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | beautify_hidden_goal('$yes_no'(G,Query), prolog) --> | 
					
						
							|  |  |  | 	!, | 
					
						
							|  |  |  | 	{ Call =.. [(?), G] }, | 
					
						
							|  |  |  | 	[Call]. | 
					
						
							|  |  |  | beautify_hidden_goal('$do_yes_no'(G,Mod), prolog) --> | 
					
						
							|  |  |  | 	[Mod:G]. | 
					
						
							|  |  |  | beautify_hidden_goal('$query'(G,VarList), prolog) --> | 
					
						
							|  |  |  | 	[query(G,VarList)]. | 
					
						
							|  |  |  | beautify_hidden_goal('$enter_top_level', prolog) --> | 
					
						
							|  |  |  | 	['TopLevel']. | 
					
						
							|  |  |  | % The user should never know these exist. | 
					
						
							|  |  |  | beautify_hidden_goal('$csult'(Files,Mod),prolog) --> | 
					
						
							|  |  |  | 	[reconsult(Mod:Files)]. | 
					
						
							|  |  |  | beautify_hidden_goal('$use_module'(Files,Mod,Is),prolog) --> | 
					
						
							|  |  |  | 	[use_module(Mod,Files,Is)]. | 
					
						
							| 
									
										
										
										
											2008-10-23 22:17:45 +01:00
										 |  |  | beautify_hidden_goal('$continue_with_command'(reconsult,V,P,G,Source),prolog) --> | 
					
						
							|  |  |  | 	['Assert'(G,V,P,Source)]. | 
					
						
							|  |  |  | beautify_hidden_goal('$continue_with_command'(consult,V,P,G,Source),prolog) --> | 
					
						
							|  |  |  | 	['Assert'(G,V,P,Source)]. | 
					
						
							|  |  |  | beautify_hidden_goal('$continue_with_command'(top,V,P,G,_),prolog) --> | 
					
						
							|  |  |  | 	['Query'(G,V,P)]. | 
					
						
							|  |  |  | beautify_hidden_goal('$continue_with_command'(Command,V,P,G,Source),prolog) --> | 
					
						
							|  |  |  | 	['TopLevel'(Command,G,V,P,Source)]. | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  | beautify_hidden_goal('$spycall'(G,M,InControl,Redo),prolog) --> | 
					
						
							|  |  |  | 	['DebuggerCall'(M:G, InControl, Redo)]. | 
					
						
							|  |  |  | beautify_hidden_goal('$do_spy'(Goal, Mod, CP, InControl),prolog) --> | 
					
						
							|  |  |  | 	['DebuggerCall'(Mod:Goal, InControl)]. | 
					
						
							|  |  |  | beautify_hidden_goal('$system_catch'(G,Mod,Exc,Handler),prolog) --> | 
					
						
							|  |  |  | 	[catch(Mod:G, Exc, Handler)]. | 
					
						
							|  |  |  | beautify_hidden_goal('$catch'(G,Exc,Handler),prolog) --> | 
					
						
							|  |  |  | 	[catch(G, Exc, Handler)]. | 
					
						
							| 
									
										
										
										
											2008-10-23 22:17:45 +01:00
										 |  |  | beautify_hidden_goal('$execute_command'(Query,V,P,Option,Source),prolog) --> | 
					
						
							|  |  |  | 	[toplevel_query(Query, V, P, Option, Source)]. | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  | beautify_hidden_goal('$process_directive'(Gs,_,Mod),prolog) --> | 
					
						
							|  |  |  | 	[(:- Mod:Gs)]. | 
					
						
							|  |  |  | beautify_hidden_goal('$loop'(Stream,Option),prolog) --> | 
					
						
							|  |  |  | 	[execute_load_file(Stream, consult=Option)]. | 
					
						
							|  |  |  | beautify_hidden_goal('$load_files'(Files,Opts,?),prolog) --> | 
					
						
							|  |  |  | 	[load_files(Files,Opts)]. | 
					
						
							|  |  |  | beautify_hidden_goal('$load_files'(_,_,Name),prolog) --> | 
					
						
							|  |  |  | 	[Name]. | 
					
						
							|  |  |  | beautify_hidden_goal('$reconsult'(Files,Mod),prolog) --> | 
					
						
							|  |  |  | 	[reconsult(Mod:Files)]. | 
					
						
							|  |  |  | beautify_hidden_goal('$undefp'([M|G]),prolog) --> | 
					
						
							|  |  |  | 	['CallUndefined'(Mod:G)]. | 
					
						
							|  |  |  | beautify_hidden_goal('$undefp'(?),prolog) --> | 
					
						
							|  |  |  | 	['CallUndefined'(?:?)]. | 
					
						
							|  |  |  | beautify_hidden_goal(repeat,prolog) --> | 
					
						
							|  |  |  | 	[repeat]. | 
					
						
							|  |  |  | beautify_hidden_goal('$recorded_with_key'(A,B,C),prolog) --> | 
					
						
							|  |  |  | 	recorded(A,B,C). | 
					
						
							|  |  |  | beautify_hidden_goal('$findall_with_common_vars'(Templ,Gen,Answ),prolog) --> | 
					
						
							|  |  |  | 	[findall(Templ,Gen,Answ)]. | 
					
						
							|  |  |  | beautify_hidden_goal('$bagof'(Templ,Gen,Answ),prolog) --> | 
					
						
							|  |  |  | 	[bagof(Templ,Gen,Answ)]. | 
					
						
							|  |  |  | beautify_hidden_goal('$setof'(Templ,Gen,Answ),prolog) --> | 
					
						
							|  |  |  | 	[setof(Templ,Gen,Answ)]. | 
					
						
							|  |  |  | beautify_hidden_goal('$findall'(T,G,S,A),prolog) --> | 
					
						
							|  |  |  | 	[findall(T,G,S,A)]. | 
					
						
							|  |  |  | beautify_hidden_goal('$listing'(G,M,_Stream),prolog) --> | 
					
						
							|  |  |  | 	[listing(M:G)]. | 
					
						
							|  |  |  | beautify_hidden_goal('$call'(G,CP,?,M),prolog) --> | 
					
						
							|  |  |  | 	[call(M:G)]. | 
					
						
							|  |  |  | beautify_hidden_goal('$call'(G,CP,G0,M),prolog) --> | 
					
						
							|  |  |  | 	[call(M:G0)]. | 
					
						
							|  |  |  | beautify_hidden_goal('$current_predicate'(M,Na,Ar),prolog) --> | 
					
						
							|  |  |  | 	[current_predicate(M,Na/Ar)]. | 
					
						
							| 
									
										
										
										
											2012-06-12 14:50:36 +01:00
										 |  |  | beautify_hidden_goal('$current_predicate_for_atom'(Name,M,Ar),prolog) --> | 
					
						
							|  |  |  | 	{ functor(P, Name, Ar) }, | 
					
						
							|  |  |  | 	[current_predicate(Name,M:P)]. | 
					
						
							| 
									
										
										
										
											2008-02-22 15:08:37 +00:00
										 |  |  | beautify_hidden_goal('$list_clauses'(Stream,M,Pred),prolog) --> | 
					
						
							|  |  |  | 	[listing(M:Pred)]. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 |