| 
									
										
										
										
											2011-07-31 02:37:31 +00:00
										 |  |  | /* this file is a part of amp software
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	util.c: created by Andrew Richards | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define AMP_UTIL
 | 
					
						
							|  |  |  | #include "amp.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <stdio.h>
 | 
					
						
							| 
									
										
										
										
											2011-07-31 17:07:17 +00:00
										 |  |  | #include <stdlib.h>
 | 
					
						
							| 
									
										
										
										
											2011-07-31 02:37:31 +00:00
										 |  |  | #include <stdarg.h>
 | 
					
						
							|  |  |  | #include <string.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "audio.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct debugFlags_t debugFlags; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* die - for terminal conditions prints the error message and exits */ | 
					
						
							|  |  |  | /* can not be suppressed with -q,-quiet	*/ | 
					
						
							|  |  |  | void | 
					
						
							|  |  |  | die(char *fmt, ...) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	va_list ap; | 
					
						
							|  |  |  | 	va_start(ap,fmt); | 
					
						
							|  |  |  | 	vfprintf(stderr, fmt, ap); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* warn - for warning messages. Can be suppressed by -q,-quiet			*/ | 
					
						
							|  |  |  | void | 
					
						
							|  |  |  | warn(char *fmt, ...) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	va_list ap; | 
					
						
							|  |  |  | 	va_start(ap,fmt); | 
					
						
							|  |  |  | 	if (!A_QUIET) { | 
					
						
							|  |  |  | 		fprintf(stderr,"Warning: "); | 
					
						
							|  |  |  | 		vfprintf(stderr, fmt, ap); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* msg - for general output. Can be suppressed by -q,-quiet. Output */ | 
					
						
							|  |  |  | /* goes to stderr so it doesn't conflict with stdout output */ | 
					
						
							|  |  |  | void | 
					
						
							|  |  |  | msg(char *fmt, ...) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	va_list ap; | 
					
						
							|  |  |  | 	va_start(ap,fmt); | 
					
						
							|  |  |  |   | 
					
						
							|  |  |  | 	if (!A_QUIET) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 	  if (A_MSG_STDOUT) { | 
					
						
							|  |  |  | 	    vfprintf(stdout, fmt, ap); | 
					
						
							|  |  |  | 	    fflush(stdout); | 
					
						
							|  |  |  | 	  } else { | 
					
						
							|  |  |  | 	    vfprintf(stderr, fmt, ap); | 
					
						
							|  |  |  | 	    fflush(stderr); | 
					
						
							|  |  |  | 	  } | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void | 
					
						
							|  |  |  | debugOptions() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int idx; | 
					
						
							|  |  |  | 	msg("Possible options are: "); | 
					
						
							|  |  |  | 	for(idx=0;debugLookup[idx].name!=0;idx++) | 
					
						
							|  |  |  | 		msg("%s,",debugLookup[idx].name); | 
					
						
							|  |  |  | 	msg("\010 \n"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* debugSetup - if debugging is turned on sets up the debug flags from */ | 
					
						
							|  |  |  | /* the command line arguments */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void | 
					
						
							|  |  |  | debugSetup(char *dbgFlags) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #ifndef DEBUG
 | 
					
						
							|  |  |  | 	warn("Debugging has not been compiled into this version of amp\n"); | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | 	char *ptr; | 
					
						
							|  |  |  | 	int idx; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	memset(&debugFlags,0,sizeof(debugFlags)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	ptr=strtok(dbgFlags,","); | 
					
						
							|  |  |  | 	while(ptr) { | 
					
						
							|  |  |  | 		for(idx=0;debugLookup[idx].name!=0;idx++) { | 
					
						
							|  |  |  | 			if (strcmp(debugLookup[idx].name,ptr)==0) { | 
					
						
							|  |  |  | 				*(debugLookup[idx].var)=1; | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		if (debugLookup[idx].name==0) { | 
					
						
							|  |  |  | 			warn("Debug option, %s, does not exist\n",ptr); | 
					
						
							|  |  |  | 			debugOptions(); | 
					
						
							|  |  |  | 			exit(1); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		ptr=strtok(NULL,","); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	DB(args, | 
					
						
							|  |  |  | 		 for(idx=0;debugLookup[idx].name!=0;idx++)  | 
					
						
							|  |  |  | 			 printf("Flag: %s = %d\n",debugLookup[idx].name,*(debugLookup[idx].var)); | 
					
						
							|  |  |  | 		 ); | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 |