| 
									
										
										
										
											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:		checker.yap						 * | 
					
						
							| 
									
										
										
										
											2004-03-19 11:35:42 +00:00
										 |  |  | * comments:	style checker for Prolog				 * | 
					
						
							|  |  |  | *									 * | 
					
						
							| 
									
										
										
										
											2008-03-31 22:56:22 +00:00
										 |  |  | * Last rev:     $Date: 2008-03-31 22:56:22 $,$Author: vsc $						 * | 
					
						
							| 
									
										
										
										
											2004-06-29 19:04:46 +00:00
										 |  |  | * $Log: not supported by cvs2svn $ | 
					
						
							| 
									
										
										
										
											2008-03-31 22:56:22 +00:00
										 |  |  | * Revision 1.23  2007/11/26 23:43:09  vsc | 
					
						
							|  |  |  | * fixes to support threads and assert correctly, even if inefficiently. | 
					
						
							|  |  |  | * | 
					
						
							| 
									
										
										
										
											2007-11-26 23:43:10 +00:00
										 |  |  | * Revision 1.22  2006/11/17 12:10:46  vsc | 
					
						
							|  |  |  | * style_checker was failing on DCGs | 
					
						
							|  |  |  | * | 
					
						
							| 
									
										
										
										
											2006-11-17 12:10:46 +00:00
										 |  |  | * Revision 1.21  2006/03/24 16:26:31  vsc | 
					
						
							|  |  |  | * code review | 
					
						
							|  |  |  | * | 
					
						
							| 
									
										
										
										
											2006-03-24 16:26:31 +00:00
										 |  |  | * Revision 1.20  2005/11/05 23:56:10  vsc | 
					
						
							|  |  |  | * should have meta-predicate definitions for calls, | 
					
						
							|  |  |  | *   multifile and discontiguous. | 
					
						
							|  |  |  | * have discontiguous as a builtin, not just as a | 
					
						
							|  |  |  | *   declaration. | 
					
						
							|  |  |  | * | 
					
						
							| 
									
										
										
										
											2005-11-05 23:56:10 +00:00
										 |  |  | * Revision 1.19  2005/10/28 17:38:50  vsc | 
					
						
							|  |  |  | * sveral updates | 
					
						
							|  |  |  | * | 
					
						
							| 
									
										
										
										
											2005-10-28 17:38:50 +00:00
										 |  |  | * Revision 1.18  2005/04/20 20:06:11  vsc | 
					
						
							|  |  |  | * try to improve error handling and warnings from within consults. | 
					
						
							|  |  |  | * | 
					
						
							| 
									
										
										
										
											2005-04-20 20:06:26 +00:00
										 |  |  | * Revision 1.17  2005/04/20 04:08:20  vsc | 
					
						
							|  |  |  | * fix warnings | 
					
						
							|  |  |  | * | 
					
						
							| 
									
										
										
										
											2005-04-20 04:08:20 +00:00
										 |  |  | * Revision 1.16  2005/01/13 05:47:27  vsc | 
					
						
							|  |  |  | * lgamma broke arithmetic optimisation | 
					
						
							|  |  |  | * integer_y has type y | 
					
						
							|  |  |  | * pass original source to checker (and maybe even use option in parser) | 
					
						
							|  |  |  | * use warning mechanism for checker messages. | 
					
						
							|  |  |  | * | 
					
						
							| 
									
										
										
										
											2005-01-13 05:47:27 +00:00
										 |  |  | * Revision 1.15  2004/06/29 19:12:01  vsc | 
					
						
							|  |  |  | * fix checker messages | 
					
						
							|  |  |  | * | 
					
						
							| 
									
										
										
										
											2004-06-29 19:12:01 +00:00
										 |  |  | * Revision 1.14  2004/06/29 19:04:46  vsc | 
					
						
							|  |  |  | * fix multithreaded version | 
					
						
							|  |  |  | * include new version of Ricardo's profiler | 
					
						
							|  |  |  | * new predicat atomic_concat | 
					
						
							|  |  |  | * allow multithreaded-debugging | 
					
						
							|  |  |  | * small fixes | 
					
						
							|  |  |  | * | 
					
						
							| 
									
										
										
										
											2004-06-29 19:04:46 +00:00
										 |  |  | * Revision 1.13  2004/03/19 11:35:42  vsc | 
					
						
							|  |  |  | * trim_trail for default machine | 
					
						
							|  |  |  | * be more aggressive about try-retry-trust chains. | 
					
						
							|  |  |  | *    - handle cases where block starts with a wait | 
					
						
							|  |  |  | *    - don't use _killed instructions, just let the thing rot by itself. | 
					
						
							|  |  |  | *                                                                  * | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | *									 * | 
					
						
							|  |  |  | *************************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | % | 
					
						
							|  |  |  | % A Small style checker for YAP | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | :- op(1150, fx, multifile). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | style_check(V) :- var(V), !, fail. | 
					
						
							|  |  |  | style_check(all) :- '$syntax_check_mode'(_,on), | 
					
						
							|  |  |  | 	'$syntax_check_single_var'(_,on), | 
					
						
							|  |  |  | 	'$syntax_check_discontiguous'(_,on), | 
					
						
							|  |  |  | 	'$syntax_check_multiple'(_,on). | 
					
						
							|  |  |  | style_check(single_var) :- '$syntax_check_mode'(_,on), | 
					
						
							|  |  |  | 	'$syntax_check_single_var'(_,on). | 
					
						
							| 
									
										
										
										
											2005-10-28 17:38:50 +00:00
										 |  |  | style_check(singleton) :- | 
					
						
							|  |  |  | 	style_check(single_var). | 
					
						
							| 
									
										
										
										
											2004-06-29 19:04:46 +00:00
										 |  |  | style_check(-single_var) :- | 
					
						
							|  |  |  | 	no_style_check(single_var). | 
					
						
							| 
									
										
										
										
											2005-10-28 17:38:50 +00:00
										 |  |  | style_check(-singleton) :- | 
					
						
							|  |  |  | 	no_style_check(single_var). | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | style_check(discontiguous) :- '$syntax_check_mode'(_,on), | 
					
						
							|  |  |  | 	'$syntax_check_discontiguous'(_,on). | 
					
						
							| 
									
										
										
										
											2004-06-29 19:04:46 +00:00
										 |  |  | style_check(-discontiguous) :- | 
					
						
							|  |  |  | 	no_style_check(discontiguous). | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | style_check(multiple) :- '$syntax_check_mode'(_,on), | 
					
						
							|  |  |  | 	'$syntax_check_multiple'(_,on). | 
					
						
							| 
									
										
										
										
											2004-06-29 19:04:46 +00:00
										 |  |  | style_check(-multiple) :- | 
					
						
							|  |  |  | 	no_style_check(multiple). | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | style_check([]). | 
					
						
							|  |  |  | style_check([H|T]) :- style_check(H), style_check(T). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | no_style_check(V) :- var(V), !, fail. | 
					
						
							| 
									
										
										
										
											2001-10-30 16:42:05 +00:00
										 |  |  | no_style_check(all) :- '$syntax_check_mode'(_,off), | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	'$syntax_check_single_var'(_,off), | 
					
						
							|  |  |  | 	'$syntax_check_discontiguous'(_,off), | 
					
						
							|  |  |  | 	'$syntax_check_multiple'(_,off). | 
					
						
							|  |  |  | no_style_check(single_var) :- '$syntax_check_mode'(_,off), | 
					
						
							|  |  |  | 	'$syntax_check_single_var'(_,off). | 
					
						
							|  |  |  | no_style_check(discontiguous) :- '$syntax_check_mode'(_,off), | 
					
						
							|  |  |  | 	'$syntax_check_discontiguous'(_,off). | 
					
						
							|  |  |  | no_style_check(multiple) :- '$syntax_check_mode'(_,on), | 
					
						
							|  |  |  | 	'$syntax_check_multiple'(_,off). | 
					
						
							|  |  |  | no_style_check([]). | 
					
						
							|  |  |  | no_style_check([H|T]) :- no_style_check(H), no_style_check(T). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | '$syntax_check_mode'(O,N) :-  | 
					
						
							|  |  |  | 	'$values'('$syntaxcheckflag',O,N). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | '$syntax_check_single_var'(O,N) :-  | 
					
						
							|  |  |  | 	'$values'('$syntaxchecksinglevar',O,N). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | '$syntax_check_discontiguous'(O,N) :-  | 
					
						
							|  |  |  | 	'$values'('$syntaxcheckdiscontiguous',O,N). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | '$syntax_check_multiple'(O,N) :-  | 
					
						
							|  |  |  | 	'$values'('$syntaxcheckmultiple',O,N). | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-13 19:13:33 +00:00
										 |  |  | % reset current state of style checker. | 
					
						
							|  |  |  | '$init_style_check'(File) :- | 
					
						
							|  |  |  | 	recorded('$predicate_defs','$predicate_defs'(_,_,_,File),R), | 
					
						
							|  |  |  | 	erase(R), | 
					
						
							|  |  |  | 	fail. | 
					
						
							|  |  |  | '$init_style_check'(_). | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-13 19:13:33 +00:00
										 |  |  | % style checker proper.. | 
					
						
							|  |  |  | '$check_term'(T,VL,P,_) :- | 
					
						
							|  |  |  | 	get_value('$syntaxchecksinglevar',on), | 
					
						
							|  |  |  | 	'$singletons_in_clause'(T, VL, Sv), | 
					
						
							|  |  |  | 	Sv = [_|_], | 
					
						
							|  |  |  | 	'$sv_warning'(Sv,T), | 
					
						
							|  |  |  |          fail. | 
					
						
							|  |  |  | '$check_term'(T,_,P,M) :- | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	get_value('$syntaxcheckdiscontiguous',on), | 
					
						
							| 
									
										
										
										
											2002-01-02 16:55:24 +00:00
										 |  |  | 	'$xtract_head'(T,M,NM,_,F,A), | 
					
						
							| 
									
										
										
										
											2010-12-13 19:13:33 +00:00
										 |  |  | 	% should always fail | 
					
						
							|  |  |  | 	'$handle_discontiguous'(F,A,NM), | 
					
						
							|  |  |  | 	fail. | 
					
						
							|  |  |  | '$check_term'(T,_,P,M) :- | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	get_value('$syntaxcheckmultiple',on), | 
					
						
							| 
									
										
										
										
											2002-01-02 16:55:24 +00:00
										 |  |  | 	'$xtract_head'(T,M,NM,_,F,A), | 
					
						
							| 
									
										
										
										
											2010-12-13 19:13:33 +00:00
										 |  |  | 	'$handle_multiple'(F,A,NM),  | 
					
						
							|  |  |  | 	fail. | 
					
						
							|  |  |  | '$check_term'(T,_,_,M) :- | 
					
						
							|  |  |  | 	once((  | 
					
						
							|  |  |  | 	    get_value('$syntaxcheckdiscontiguous',on) | 
					
						
							|  |  |  | 	; | 
					
						
							|  |  |  | 	    get_value('$syntaxcheckmultiple',on) | 
					
						
							|  |  |  | 	)), | 
					
						
							|  |  |  | 	recorded('$reconsulting',File,_), | 
					
						
							|  |  |  | 	'$xtract_head'(T,M,NM,_,F,A), | 
					
						
							|  |  |  | 	\+ ( | 
					
						
							|  |  |  | 	    % allow duplicates if we are not the last predicate to have | 
					
						
							|  |  |  | 	    % been asserted. | 
					
						
							|  |  |  | 	    once(recorded('$predicate_defs','$predicate_defs'(F0,A0,M0,File),_)), | 
					
						
							|  |  |  | 	    F0 = F, A0 = A, M0 = NM | 
					
						
							|  |  |  | 	), | 
					
						
							|  |  |  | 	recorda('$predicate_defs','$predicate_defs'(F,A,NM,File),_), | 
					
						
							|  |  |  | 	fail. | 
					
						
							|  |  |  | '$check_term'(_,_,_,_). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | % | 
					
						
							|  |  |  | % output a list of singleton variables... | 
					
						
							|  |  |  | % | 
					
						
							|  |  |  | '$singletons_in_clause'(T, VL, Sv) :- | 
					
						
							|  |  |  |         % first check which variables are not singleton | 
					
						
							|  |  |  | 	'$non_singletons_in_term'(T,[],V2L), | 
					
						
							|  |  |  |         % bound them | 
					
						
							|  |  |  | 	'$ground_vars'(V2L), | 
					
						
							|  |  |  |         % the remainder which do not start by _ are our target!  | 
					
						
							|  |  |  | 	'$sv_list'(VL, Sv). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | '$ground_vars'([]). | 
					
						
							|  |  |  | '$ground_vars'(ground.V2L) :- | 
					
						
							|  |  |  | 	'$ground_vars'(V2L). | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | '$sv_list'([],[]). | 
					
						
							| 
									
										
										
										
											2010-12-13 19:35:16 +00:00
										 |  |  | '$sv_list'([[95|_]._|T],L) :- !, | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	'$sv_list'(T,L). | 
					
						
							| 
									
										
										
										
											2010-12-13 19:13:33 +00:00
										 |  |  | '$sv_list'([_|V].T,L) :- nonvar(V), !, | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	'$sv_list'(T,L). | 
					
						
							| 
									
										
										
										
											2010-12-13 19:13:33 +00:00
										 |  |  | '$sv_list'([Name|_].T, Name.L) :- | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	'$sv_list'(T,L). | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-13 19:13:33 +00:00
										 |  |  | '$sv_warning'([], _) :- !. | 
					
						
							|  |  |  | '$sv_warning'(SVs, T) :- | 
					
						
							| 
									
										
										
										
											2001-11-15 00:01:43 +00:00
										 |  |  | 	'$current_module'(OM), | 
					
						
							| 
									
										
										
										
											2010-12-13 19:13:33 +00:00
										 |  |  | 	'$xtract_head'(T, OM, M, H, Name, Arity), | 
					
						
							|  |  |  | 	print_message(warning,singletons(SVs,(M:Name/Arity))). | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-01-02 16:55:24 +00:00
										 |  |  | '$xtract_head'(V,M,M,V,call,1) :- var(V), !. | 
					
						
							| 
									
										
										
										
											2001-11-15 00:01:43 +00:00
										 |  |  | '$xtract_head'((H:-_),OM,M,NH,Name,Arity) :- !, | 
					
						
							| 
									
										
										
										
											2001-11-18 21:21:21 +00:00
										 |  |  |         '$xtract_head'(H,OM,M,NH,Name,Arity). | 
					
						
							| 
									
										
										
										
											2001-11-15 00:01:43 +00:00
										 |  |  | '$xtract_head'((H,_),OM,M,H1,Name,Arity) :- !, | 
					
						
							|  |  |  | 	'$xtract_head'(H,OM,M,H1,Name,Arity). | 
					
						
							|  |  |  | '$xtract_head'((H-->_),OM,M,HL,Name,Arity) :- !, | 
					
						
							| 
									
										
										
										
											2006-11-17 12:10:46 +00:00
										 |  |  | 	'$xtract_head'(H,M,OM,_,Name,A1), | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	Arity is A1+2, | 
					
						
							|  |  |  | 	functor(HL,Name,Arity). | 
					
						
							| 
									
										
										
										
											2001-11-15 00:01:43 +00:00
										 |  |  | '$xtract_head'(M:H,_,NM,NH,Name,Arity) :- !, | 
					
						
							|  |  |  | 	'$xtract_head'(H,M,NM,NH,Name,Arity). | 
					
						
							|  |  |  | '$xtract_head'(H,M,M,H,Name,Arity) :- | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	functor(H,Name,Arity). | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-13 19:13:33 +00:00
										 |  |  | % check if a predicate is discontiguous. | 
					
						
							| 
									
										
										
										
											2001-11-15 00:01:43 +00:00
										 |  |  | '$handle_discontiguous'(F,A,M) :- | 
					
						
							| 
									
										
										
										
											2010-12-13 19:13:33 +00:00
										 |  |  | 	recorded('$discontiguous_defs','$df'(F,A,M),_), !, | 
					
						
							|  |  |  | 	fail. | 
					
						
							| 
									
										
										
										
											2008-03-31 22:56:22 +00:00
										 |  |  | '$handle_discontiguous'(F,A,M) :- | 
					
						
							| 
									
										
										
										
											2009-02-10 23:03:25 +00:00
										 |  |  | 	functor(Head, F, A), | 
					
						
							| 
									
										
										
										
											2010-12-13 19:13:33 +00:00
										 |  |  | 	'$is_multifile'(Head, M), !, | 
					
						
							|  |  |  | 	fail. | 
					
						
							| 
									
										
										
										
											2001-11-18 21:21:21 +00:00
										 |  |  | '$handle_discontiguous'(F,A,M) :- | 
					
						
							| 
									
										
										
										
											2010-12-13 19:13:33 +00:00
										 |  |  | 	nb_getval('$consulting_file', FileName), | 
					
						
							|  |  |  | 	% we have been there before | 
					
						
							|  |  |  | 	once(recorded('$predicate_defs','$predicate_defs'(F, A, M, FileName),_)), | 
					
						
							|  |  |  | 	% and we are not  | 
					
						
							|  |  |  | 	\+ ( | 
					
						
							|  |  |  | 	    % the last predicate to have been asserted | 
					
						
							|  |  |  | 	    once(recorded('$predicate_defs','$predicate_defs'(F0,A0,M0,FileName),_)), | 
					
						
							|  |  |  | 	    F0 = F, A0 = A, M0 = M | 
					
						
							|  |  |  | 	), | 
					
						
							|  |  |  | 	print_message(warning,clauses_not_together((M:F/A))), | 
					
						
							|  |  |  |         fail. | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-13 19:13:33 +00:00
										 |  |  | % never complain the second time | 
					
						
							| 
									
										
										
										
											2001-11-18 21:21:21 +00:00
										 |  |  | '$handle_multiple'(F,A,M) :- | 
					
						
							| 
									
										
										
										
											2010-12-13 19:13:33 +00:00
										 |  |  | 	nb_getval('$consulting_file', FileName), | 
					
						
							|  |  |  | 	recorded('$predicate_defs','$predicate_defs'(F,A,M,FileName),_), !. | 
					
						
							|  |  |  | % first time we have a definition | 
					
						
							| 
									
										
										
										
											2001-11-15 00:01:43 +00:00
										 |  |  | '$handle_multiple'(F,A,M) :- | 
					
						
							| 
									
										
										
										
											2010-12-13 19:13:33 +00:00
										 |  |  | 	nb_getval('$consulting_file', FileName0), | 
					
						
							|  |  |  | 	recorded('$predicate_defs','$predicate_defs'(F,A,M,FileName),_), | 
					
						
							|  |  |  | 	FileName \= FileName0, | 
					
						
							|  |  |  | 	'$multiple_has_been_defined'(FileName, F/A, M), !. | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-13 19:13:33 +00:00
										 |  |  | % be careful about these cases. | 
					
						
							|  |  |  | % consult does not count | 
					
						
							|  |  |  | '$multiple_has_been_defined'(_, _, _) :- | 
					
						
							|  |  |  | 	nb_getval('$consulting',true), !.	 | 
					
						
							|  |  |  | % multifile does not count | 
					
						
							| 
									
										
										
										
											2001-11-15 00:01:43 +00:00
										 |  |  | '$multiple_has_been_defined'(_, F/A, M) :- | 
					
						
							|  |  |  | 	functor(S, F, A), | 
					
						
							|  |  |  | 	'$is_multifile'(S, M), !. | 
					
						
							| 
									
										
										
										
											2010-12-13 19:13:33 +00:00
										 |  |  | '$multiple_has_been_defined'(Fil,F/A,M) :- | 
					
						
							|  |  |  | 	% first, clean up all definitions in other files | 
					
						
							|  |  |  | 	% don't forget, we just removed everything. | 
					
						
							|  |  |  | 	recorded('$predicate_defs','$predicate_defs'(F,A,M,FileName),R), | 
					
						
							|  |  |  | 	erase(R), | 
					
						
							|  |  |  | 	fail. | 
					
						
							| 
									
										
										
										
											2005-04-20 04:08:20 +00:00
										 |  |  | '$multiple_has_been_defined'(Fil,P,M) :- | 
					
						
							| 
									
										
										
										
											2010-12-13 19:13:33 +00:00
										 |  |  | 	print_message(warning,defined_elsewhere(M:P,Fil)). | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-11-15 00:01:43 +00:00
										 |  |  | '$multifile'(V, _) :- var(V), !, | 
					
						
							| 
									
										
										
										
											2002-09-09 17:40:12 +00:00
										 |  |  | 	'$do_error'(instantiation_error,multifile(V)). | 
					
						
							| 
									
										
										
										
											2005-10-28 17:38:50 +00:00
										 |  |  | '$multifile'((X,Y), M) :- !, '$multifile'(X, M), '$multifile'(Y, M). | 
					
						
							| 
									
										
										
										
											2001-11-15 00:01:43 +00:00
										 |  |  | '$multifile'(Mod:PredSpec, _) :- !, | 
					
						
							|  |  |  | 	'$multifile'(PredSpec, Mod). | 
					
						
							| 
									
										
										
										
											2010-02-27 23:07:03 +00:00
										 |  |  | '$multifile'(N//A, M) :- !, | 
					
						
							|  |  |  | 	integer(A), | 
					
						
							|  |  |  | 	A1 is A+2, | 
					
						
							|  |  |  | 	'$multifile'(N/A1, M). | 
					
						
							| 
									
										
										
										
											2001-11-15 00:01:43 +00:00
										 |  |  | '$multifile'(N/A, M) :- | 
					
						
							| 
									
										
										
										
											2003-11-26 18:36:35 +00:00
										 |  |  | 	'$add_multifile'(N,A,M), | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	fail. | 
					
						
							| 
									
										
										
										
											2001-11-15 00:01:43 +00:00
										 |  |  | '$multifile'(N/A, M) :- | 
					
						
							|  |  |  |          functor(S,N,A), | 
					
						
							|  |  |  | 	'$is_multifile'(S, M), !. | 
					
						
							|  |  |  | '$multifile'(N/A, M) :- !, | 
					
						
							|  |  |  | 	'$new_multifile'(N,A,M). | 
					
						
							| 
									
										
										
										
											2003-01-20 15:12:45 +00:00
										 |  |  | '$multifile'([H|T], M) :- !, | 
					
						
							|  |  |  | 	'$multifile'(H,M), | 
					
						
							|  |  |  | 	'$multifile'(T,M). | 
					
						
							| 
									
										
										
										
											2001-11-15 00:01:43 +00:00
										 |  |  | '$multifile'(P, M) :- | 
					
						
							| 
									
										
										
										
											2002-09-09 17:40:12 +00:00
										 |  |  | 	'$do_error'(type_error(predicate_indicator,P),multifile(M:P)). | 
					
						
							| 
									
										
										
										
											2001-11-15 00:01:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-11-05 23:56:10 +00:00
										 |  |  | discontiguous(V) :- | 
					
						
							|  |  |  | 	var(V), !, | 
					
						
							|  |  |  | 	'$do_error'(instantiation_error,discontiguous(V)). | 
					
						
							|  |  |  | discontiguous(M:F) :- !, | 
					
						
							|  |  |  | 	'$discontiguous'(F,M). | 
					
						
							|  |  |  | discontiguous(F) :- | 
					
						
							|  |  |  | 	'$current_module'(M), | 
					
						
							|  |  |  | 	'$discontiguous'(F,M). | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2001-11-15 00:01:43 +00:00
										 |  |  | '$discontiguous'(V,M) :- var(V), !, | 
					
						
							| 
									
										
										
										
											2002-09-09 17:40:12 +00:00
										 |  |  | 	'$do_error'(instantiation_error,M:discontiguous(V)). | 
					
						
							| 
									
										
										
										
											2001-11-15 00:01:43 +00:00
										 |  |  | '$discontiguous'((X,Y),M) :- !, | 
					
						
							|  |  |  | 	'$discontiguous'(X,M), | 
					
						
							|  |  |  | 	'$discontiguous'(Y,M). | 
					
						
							|  |  |  | '$discontiguous'(M:A,_) :- !, | 
					
						
							|  |  |  | 	'$discontiguous'(A,M). | 
					
						
							| 
									
										
										
										
											2010-02-27 23:07:03 +00:00
										 |  |  | '$discontiguous'(N//A1, M) :- !, | 
					
						
							|  |  |  | 	integer(A1), !, | 
					
						
							|  |  |  | 	A is A1+2, | 
					
						
							|  |  |  | 	'$discontiguous'(N/A, M). | 
					
						
							| 
									
										
										
										
											2001-11-15 00:01:43 +00:00
										 |  |  | '$discontiguous'(N/A, M) :- !, | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	( recordzifnot('$discontiguous_defs','$df'(N,A,M),_) -> | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	    true | 
					
						
							|  |  |  | 	; | 
					
						
							|  |  |  | 	    true | 
					
						
							|  |  |  | 	). | 
					
						
							| 
									
										
										
										
											2001-11-15 00:01:43 +00:00
										 |  |  | '$discontiguous'(P,M) :- | 
					
						
							| 
									
										
										
										
											2002-09-09 17:40:12 +00:00
										 |  |  | 	'$do_error'(type_error(predicate_indicator,P),M:discontiguous(P)). | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | % | 
					
						
							|  |  |  | % did we declare multifile properly? | 
					
						
							|  |  |  | % | 
					
						
							| 
									
										
										
										
											2001-11-15 00:01:43 +00:00
										 |  |  | '$check_multifile_pred'(Hd, M, _) :- | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	functor(Hd,Na,Ar), | 
					
						
							| 
									
										
										
										
											2007-11-26 23:43:10 +00:00
										 |  |  | 	nb_getval('$consulting_file',F), | 
					
						
							| 
									
										
										
										
											2003-08-27 13:37:10 +00:00
										 |  |  | 	recorded('$multifile_defs','$defined'(F,Na,Ar,M),_), !. | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | % oops, we did not. | 
					
						
							| 
									
										
										
										
											2001-11-15 00:01:43 +00:00
										 |  |  | '$check_multifile_pred'(Hd, M, Fl) :- | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	% so this is not a multi-file predicate any longer. | 
					
						
							|  |  |  | 	functor(Hd,Na,Ar), | 
					
						
							| 
									
										
										
										
											2003-12-04 18:13:04 +00:00
										 |  |  | 	NFl is \(0x20000000) /\ Fl, | 
					
						
							| 
									
										
										
										
											2001-11-15 00:01:43 +00:00
										 |  |  | 	'$flags'(Hd,M,Fl,NFl), | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	'$warn_mfile'(Na,Ar). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | '$warn_mfile'(F,A) :- | 
					
						
							| 
									
										
										
										
											2004-06-29 19:12:01 +00:00
										 |  |  | 	write(user_error,'% Warning: predicate '), | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	write(user_error,F/A), write(user_error,' was a multifile predicate '), | 
					
						
							|  |  |  | 	write(user_error,' (line '), | 
					
						
							|  |  |  | 	'$start_line'(LN), write(user_error,LN), | 
					
						
							| 
									
										
										
										
											2004-06-29 19:12:01 +00:00
										 |  |  | 	write(user_error,')'), | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 	nl(user_error).	 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 |