| 
									
										
										
										
											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				 * | 
					
						
							|  |  |  | *									 * | 
					
						
							| 
									
										
										
										
											2016-04-14 12:00:09 +01:00
										 |  |  | * Last rev:     $Date: 2008-03-31 22:56:22 $,$Author: vsc $		 * | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | *									 * | 
					
						
							|  |  |  | *************************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-23 21:39:32 +01:00
										 |  |  | :- system_module( style_checker, [no_style_check/1, | 
					
						
							| 
									
										
										
										
											2014-04-09 12:39:29 +01:00
										 |  |  |         style_check/1], ['$check_term'/5, | 
					
						
							|  |  |  |         '$sv_warning'/2, | 
					
						
							|  |  |  |         '$syntax_check_discontiguous'/2, | 
					
						
							|  |  |  |         '$syntax_check_multiple'/2, | 
					
						
							|  |  |  |         '$syntax_check_single_var'/2]). | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-04 23:58:23 +00:00
										 |  |  | %% @{ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-26 19:14:15 -05:00
										 |  |  | /** | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @defgroup   YAPStyle Checker | 
					
						
							|  |  |  |     @ingroup  YAPCompilerSettings | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-13 00:53:56 -05:00
										 |  |  | YAP implements a style-checker thay currently verifies whether: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 1 named variables occur once in a clause. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 2 clauses from dofferent predicates are mixed together. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 3 clauses for the same predicate occur in different files. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | One can declare a predicate to be discontiguous (see the | 
					
						
							|  |  |  | discontiguous/1 declaration) and/or multifile/1. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* | 
					
						
							| 
									
										
										
										
											2014-07-26 19:14:15 -05:00
										 |  |  | @pred style_check(+ _X_) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Turns on style checking according to the attribute specified by  _X_, | 
					
						
							|  |  |  | which must be one of the following: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     + single_var | 
					
						
							|  |  |  |       Checks single occurrences of named variables in a clause. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     + discontiguous | 
					
						
							|  |  |  |       Checks non-contiguous clauses for the same predicate in a file. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     + multiple | 
					
						
							|  |  |  |       Checks the presence of clauses for the same predicate in more than one | 
					
						
							|  |  |  |       file when the predicate has not been declared as `multifile` | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     + all | 
					
						
							|  |  |  |       Performs style checking for all the cases mentioned above. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | By default, style checking is disabled in YAP unless we are in | 
					
						
							|  |  |  | `sicstus` or `iso` language mode. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The style_check/1 built-in is now deprecated. Please use | 
					
						
							|  |  |  | `set_prolog_flag/1` instead. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-04 23:58:23 +00:00
										 |  |  |   **/ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | % | 
					
						
							|  |  |  | % A Small style checker for YAP | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-24 08:26:31 +01:00
										 |  |  | :- op(1150, fx, [multifile,discontiguous]). | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | style_check(V) :- var(V), !, fail. | 
					
						
							| 
									
										
										
										
											2014-04-23 21:39:32 +01:00
										 |  |  | style_check(V) :- | 
					
						
							| 
									
										
										
										
											2016-06-03 16:54:17 +01:00
										 |  |  | 	\+atom(V), | 
					
						
							|  |  |  | 	\+ is_list(V), | 
					
						
							|  |  |  | 	V \= + _, | 
					
						
							|  |  |  | 	V \= - _, !, | 
					
						
							| 
									
										
										
										
											2014-04-23 21:39:32 +01:00
										 |  |  | 	'$do_error'( type_error('+|-|?(Flag)', V), style_check(V) ). | 
					
						
							|  |  |  | style_check(V) :- | 
					
						
							| 
									
										
										
										
											2016-06-03 16:54:17 +01:00
										 |  |  | 	\+atom(V), | 
					
						
							|  |  |  | 	\+ is_list(V), | 
					
						
							|  |  |  | 	V \= + _, | 
					
						
							|  |  |  | 	V \= + _, !, | 
					
						
							| 
									
										
										
										
											2014-10-07 01:35:41 +01:00
										 |  |  | 	'$do_error'( domain_error(style_name, V), style_check(V) ). | 
					
						
							| 
									
										
										
										
											2016-07-31 10:34:24 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-23 21:39:32 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-03 16:54:17 +01:00
										 |  |  | style_check(all) :- | 
					
						
							|  |  |  | 	style_check( [ singleton, discontiguous, multiple ] ). | 
					
						
							|  |  |  | style_check(+X) :- | 
					
						
							|  |  |  | 	style_check(X). | 
					
						
							|  |  |  | style_check(single_var) :- | 
					
						
							|  |  |  | 	style_check( singleton ). | 
					
						
							|  |  |  | style_check(singleton) :- | 
					
						
							|  |  |  | 	yap_flag( single_var_warnings, true ). | 
					
						
							|  |  |  | style_check(-single_var) :- | 
					
						
							|  |  |  | 	yap_flag( single_var_warnings, false ). | 
					
						
							|  |  |  | style_check(-singleton) :- | 
					
						
							|  |  |  | 	yap_flag( single_var_warnings, false ). | 
					
						
							|  |  |  | style_check(discontiguous) :- | 
					
						
							|  |  |  | 	yap_flag( discontiguous_warnings, true ). | 
					
						
							|  |  |  | style_check(-discontiguous) :- | 
					
						
							|  |  |  | 	yap_flag( discontiguous_warnings, false ). | 
					
						
							|  |  |  | style_check(multiple) :- | 
					
						
							|  |  |  | 	yap_flag( redefine_warnings, true ). | 
					
						
							|  |  |  | style_check(-multiple) :- | 
					
						
							|  |  |  | 	yap_flag( redefine_warnings, false ). | 
					
						
							|  |  |  | style_check(no_effect). | 
					
						
							|  |  |  | style_check(+no_effect) . | 
					
						
							|  |  |  | style_check(-no_effect). | 
					
						
							|  |  |  | style_check(var_branches). | 
					
						
							|  |  |  | style_check(+var_branches) :- | 
					
						
							| 
									
										
										
										
											2014-04-23 21:39:32 +01:00
										 |  |  | 	'$style_checker'( [  var_branches ] ). | 
					
						
							| 
									
										
										
										
											2016-06-03 16:54:17 +01:00
										 |  |  | style_check(-var_branches) :- | 
					
						
							| 
									
										
										
										
											2014-04-23 21:39:32 +01:00
										 |  |  | 	'$style_checker'( [  -var_branches ] ). | 
					
						
							| 
									
										
										
										
											2016-06-03 16:54:17 +01:00
										 |  |  | style_check(atom). | 
					
						
							|  |  |  | style_check(+atom) :- | 
					
						
							| 
									
										
										
										
											2014-04-23 21:39:32 +01:00
										 |  |  | 	'$style_checker'( [  atom ] ). | 
					
						
							| 
									
										
										
										
											2016-06-03 16:54:17 +01:00
										 |  |  | style_check(-atom) :- | 
					
						
							| 
									
										
										
										
											2014-04-23 21:39:32 +01:00
										 |  |  | 	'$style_checker'( [  -atom ] ). | 
					
						
							| 
									
										
										
										
											2016-06-03 16:54:17 +01:00
										 |  |  | style_check(charset) :- | 
					
						
							| 
									
										
										
										
											2014-04-23 21:39:32 +01:00
										 |  |  | 	'$style_checker'( [  charset ] ). | 
					
						
							| 
									
										
										
										
											2016-06-03 16:54:17 +01:00
										 |  |  | style_check(+charset) :- | 
					
						
							| 
									
										
										
										
											2014-04-23 21:39:32 +01:00
										 |  |  | 	'$style_checker'( [  charset ] ). | 
					
						
							| 
									
										
										
										
											2016-06-03 16:54:17 +01:00
										 |  |  | style_check(-charset) :- | 
					
						
							| 
									
										
										
										
											2014-04-23 21:39:32 +01:00
										 |  |  | 	'$style_checker'( [  -charset ] ). | 
					
						
							| 
									
										
										
										
											2016-06-03 16:54:17 +01:00
										 |  |  | style_check('?'(Info) ) :- | 
					
						
							| 
									
										
										
										
											2014-10-07 01:35:41 +01:00
										 |  |  | 	L =  [ singleton, discontiguous, multiple ], | 
					
						
							| 
									
										
										
										
											2014-04-23 21:39:32 +01:00
										 |  |  | 	( lists:member(Style, L ) -> Info = +Style ; Info = -Style ). | 
					
						
							| 
									
										
										
										
											2016-06-03 16:54:17 +01:00
										 |  |  | style_check([]). | 
					
						
							|  |  |  | style_check([H|T]) :- style_check(H), style_check(T). | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-13 00:53:56 -05:00
										 |  |  | /** @pred no_style_check(+ _X_) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Turns off style checking according to the attribute specified by | 
					
						
							|  |  |  |  _X_, which have the same meaning as in style_check/1. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-31 10:34:24 -05:00
										 |  |  | The no_style_check/1 built-in is now deprecated. Please use | 
					
						
							| 
									
										
										
										
											2014-09-13 00:53:56 -05:00
										 |  |  | `set_prolog_flag/1` instead. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | **/ | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | no_style_check(V) :- var(V), !, fail. | 
					
						
							| 
									
										
										
										
											2013-02-04 11:22:42 -06:00
										 |  |  | no_style_check(all) :- | 
					
						
							| 
									
										
										
										
											2014-04-23 21:39:32 +01:00
										 |  |  | 	'$style_checker'( [ -singleton, -discontiguous, -multiple ] ). | 
					
						
							|  |  |  | no_style_check(-single_var) :- | 
					
						
							|  |  |  | 	'$style_checker'( [ -singleton ] ). | 
					
						
							|  |  |  | no_style_check(-singleton) :- | 
					
						
							|  |  |  | 	'$style_checker'( [ -singleton ] ). | 
					
						
							|  |  |  | no_style_check(-discontiguous) :- | 
					
						
							| 
									
										
										
										
											2014-08-04 09:45:30 -05:00
										 |  |  | 	'$style_checker'( [ -discontiguous ] ). | 
					
						
							| 
									
										
										
										
											2014-04-23 21:39:32 +01:00
										 |  |  | no_style_check(-multiple) :- | 
					
						
							|  |  |  | 	'$style_checker'( [  -multiple ] ). | 
					
						
							| 
									
										
										
										
											2001-04-09 19:54:03 +00:00
										 |  |  | no_style_check([]). | 
					
						
							|  |  |  | no_style_check([H|T]) :- no_style_check(H), no_style_check(T). | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-26 19:14:15 -05:00
										 |  |  | /** @pred discontiguous(+ _G_) is iso | 
					
						
							|  |  |  |     Avoid warnings from the sytax checker. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Declare that the predicate _G_ or list of predicates are discontiguous | 
					
						
							|  |  |  | procedures, that is, clauses for discontigous procedures may be | 
					
						
							|  |  |  | separated by clauses from other procedures. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-31 10:34:24 -05:00
										 |  |  | discontiguous(P) :- '$discontiguous'(P). | 
					
						
							| 
									
										
										
										
											2014-07-26 19:14:15 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* | 
					
						
							|  |  |  | @} | 
					
						
							|  |  |  | */ |