101 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Prolog
		
	
	
	
	
	
			
		
		
	
	
			101 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Prolog
		
	
	
	
	
	
| /*  $Id$
 | |
| 
 | |
|     Part of SWI-Prolog
 | |
| 
 | |
|     Author:        Jan Wielemaker
 | |
|     E-mail:        wielemak@science.uva.nl
 | |
|     WWW:           http://www.swi-prolog.org
 | |
|     Copyright (C): 1985-2005, University of Amsterdam
 | |
| 
 | |
|     This program is free software; you can redistribute it and/or
 | |
|     modify it under the terms of the GNU General Public License
 | |
|     as published by the Free Software Foundation; either version 2
 | |
|     of the License, or (at your option) any later version.
 | |
| 
 | |
|     This program is distributed in the hope that it will be useful,
 | |
|     but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|     GNU General Public License for more details.
 | |
| 
 | |
|     You should have received a copy of the GNU Lesser General Public
 | |
|     License along with this library; if not, write to the Free Software
 | |
|     Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 | |
| 
 | |
|     As a special exception, if you link this library with other files,
 | |
|     compiled with a Free Software compiler, to produce an executable, this
 | |
|     library does not by itself cause the resulting executable to be covered
 | |
|     by the GNU General Public License. This exception does not however
 | |
|     invalidate any other reasons why the executable file might be covered by
 | |
|     the GNU General Public License.
 | |
| */
 | |
| 
 | |
| :- module(http_error,
 | |
| 	  [
 | |
| 	  ]).
 | |
| :- use_module(library(debug)).
 | |
| :- use_module(library(prolog_stack)).
 | |
| 
 | |
| /** <module> Decorate uncaught exceptions with stack-trace
 | |
| 
 | |
| This module decorates uncaught exceptions of the user code with a full
 | |
| stack-trace. It is based on a hook introduced in SWI-Prolog 5.6.5.
 | |
| Please note that although loading this module greatly simplifies
 | |
| debugging, it also provides clues for hackers on how to compromise your
 | |
| site. The more information you give them, the easier it is to break into
 | |
| your server!
 | |
| 
 | |
| To use this file, simply load it.
 | |
| 
 | |
| @author	Jan Wielemaker
 | |
| */
 | |
| 
 | |
| :- multifile
 | |
| 	user:prolog_exception_hook/4.
 | |
| :- dynamic
 | |
| 	user:prolog_exception_hook/4.
 | |
| 
 | |
| guard(httpd_wrapper:call_handler/6).	% old version
 | |
| guard(httpd_wrapper:wrapper/5).
 | |
| guard(httpd_wrapper:handler_with_output_to/5).
 | |
| 
 | |
| user:prolog_exception_hook(error(E, context(Ctx0,Msg)),
 | |
| 			   error(E, context(prolog_stack(Stack),Msg)),
 | |
| 			   Fr, Guard) :-
 | |
| 	Guard \== none,
 | |
| 	prolog_frame_attribute(Guard, predicate_indicator, Goal),
 | |
| 	debug(http_error, 'Got exception ~p (Ctx0=~p, Catcher=~p)',
 | |
| 	      [E, Ctx0, Goal]),
 | |
| 	guard(Goal),
 | |
| 	get_prolog_backtrace(Fr, 50, Stack0),
 | |
| 	debug(http_error, 'Stack = ~w', [Stack0]),
 | |
| 	clean_stack(Stack0, Stack).
 | |
| 
 | |
| clean_stack([], []).
 | |
| clean_stack([H|_], [H]) :-
 | |
| 	guard_frame(H), !.
 | |
| clean_stack([H|T0], [H|T]) :-
 | |
| 	clean_stack(T0, T).
 | |
| 
 | |
| guard_frame(frame(_,clause(ClauseRef, _))) :-
 | |
| 	nth_clause(M:Head, _, ClauseRef),
 | |
| 	functor(Head, Name, Arity),
 | |
| 	guard(M:Name/Arity).
 | |
| 
 | |
| 
 | |
| 		 /*******************************
 | |
| 		 *	     MESSAGES		*
 | |
| 		 *******************************/
 | |
| 
 | |
| :- multifile
 | |
| 	prolog:message/3.
 | |
| 
 | |
| prolog:message(error(Error, context(Stack, Message))) -->
 | |
| 	{ is_stack(Stack, Frames) }, !,
 | |
| 	'$messages':translate_message(error(Error, context(_, Message))),
 | |
| 	[ nl, 'In:', nl ],
 | |
| 	prolog_stack:message(Frames).
 | |
| 
 | |
| is_stack(Stack, Frames) :-
 | |
| 	nonvar(Stack),
 | |
| 	Stack = prolog_stack(Frames).
 |