| 
									
										
										
										
											2015-05-03 08:13:28 -04:00
										 |  |  | namespace factor { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | extern bool factor_print_p; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef FACTOR_DEBUG
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-21 10:26:04 -04:00
										 |  |  | // To chop the directory path of the __FILE__ macro.
 | 
					
						
							| 
									
										
										
										
											2015-08-21 01:42:03 -04:00
										 |  |  | inline const char* abbrev_path(const char* path) { | 
					
						
							|  |  |  |   const char* p1 = strrchr(path, '\\'); | 
					
						
							|  |  |  |   const char* p2 = strrchr(path, '/'); | 
					
						
							|  |  |  |   return (p1 > p2 ? p1 : p2) + 1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-03 08:13:28 -04:00
										 |  |  | #define FACTOR_PRINT(x)                                          \
 | 
					
						
							|  |  |  |   do {                                                           \ | 
					
						
							|  |  |  |     if (factor_print_p) {                                        \ | 
					
						
							|  |  |  |       std::cerr                                                  \ | 
					
						
							| 
									
										
										
										
											2015-08-21 01:42:03 -04:00
										 |  |  |           << std::setw(16) << std::left << abbrev_path(__FILE__) \ | 
					
						
							| 
									
										
										
										
											2015-05-03 08:13:28 -04:00
										 |  |  |           << " " << std::setw(4) << std::right << __LINE__       \ | 
					
						
							|  |  |  |           << " " << std::setw(20) << std::left << __FUNCTION__   \ | 
					
						
							|  |  |  |           << " " << x                                            \ | 
					
						
							|  |  |  |           << std::endl;                                          \ | 
					
						
							|  |  |  |     }                                                            \ | 
					
						
							|  |  |  |   } while (0) | 
					
						
							|  |  |  | #define FACTOR_PRINT_MARK FACTOR_PRINT("")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define FACTOR_PRINT(fmt, ...) ((void)0)
 | 
					
						
							|  |  |  | #define FACTOR_PRINT_MARK ((void)0)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2015-08-21 01:42:03 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | } |