310 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			310 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* 
 | |
|  * io.c for mdb
 | |
|  * all the i/o is here
 | |
|  * NB: Printf()
 | |
|  */
 | |
| #include "mdb.h"
 | |
| #include <stdio.h>
 | |
| #include <stdarg.h>
 | |
| #include <string.h>
 | |
| #include <sys/types.h>
 | |
| #include "proto.h"
 | |
| 
 | |
| #define OUTBUFSIZE	512
 | |
| #define PAGESIZE	24
 | |
| 
 | |
| static int forceupper = FALSE;
 | |
| static int someupper = FALSE;
 | |
| static int stringcount = 0;
 | |
| static char *string_ptr = NULL;	/* stringptr ambiguous at 8th char */
 | |
| static char *stringstart = NULL;
 | |
| 
 | |
| static char outbuf[OUTBUFSIZE];
 | |
| static FILE *cmdfile = stdin;
 | |
| static FILE *outfile = stdout;
 | |
| static FILE *logfile;
 | |
| static int lineno;
 | |
| 
 | |
| int _doprnt(const char *format, va_list ap, FILE *stream );
 | |
| 
 | |
| char *get_cmd(cbuf, csize)
 | |
| char *cbuf;
 | |
| int csize;
 | |
| {
 | |
| char *r;
 | |
| 
 | |
|   fflush(stdout);
 | |
|   if( cmdfile == stdin && outfile == stdout )
 | |
| 	printf("* ");
 | |
|   r = fgets(cbuf, csize, cmdfile);
 | |
|   if ( r == NULL && cmdfile != stdin ) {
 | |
| 	cmdfile = stdin;
 | |
| 	return get_cmd(cbuf, csize);
 | |
|   }
 | |
| 
 | |
|   if ( logfile != NULL ) { 
 | |
| 	fprintf( logfile, "%s", cbuf );		
 | |
| 	lineno++;
 | |
|   }
 | |
| 
 | |
|   return r;
 | |
| }
 | |
| 
 | |
| void openin(s)
 | |
| char *s;
 | |
| {
 | |
| char *t;
 | |
| 
 | |
|   if ((t = strchr(s,'\n')) != NULL) *t = '\0';
 | |
|   if ((t = strchr(s,' ')) != NULL) *t = '\0';
 | |
|   cmdfile = fopen(s,"r");
 | |
|   if (cmdfile == NULL) {
 | |
| 	Printf("Cannot open %s for input\n",s);
 | |
| 	cmdfile = stdin; 
 | |
|   }
 | |
| }
 | |
| 
 | |
| 
 | |
| /* Special version of printf 
 | |
|  * really sprintf()
 | |
|  * from MINIX library
 | |
|  * followed by outstr()
 | |
|  */
 | |
| int Printf(const char *format, ...)
 | |
| {
 | |
| 	va_list ap;
 | |
| 	int retval;
 | |
| #ifndef __NBSD_LIBC
 | |
| 	FILE tmp_stream;
 | |
| 
 | |
| 	va_start(ap, format);
 | |
| 
 | |
| 	tmp_stream._fd     = -1;
 | |
| 	tmp_stream._flags  = _IOWRITE + _IONBF + _IOWRITING;
 | |
| 	tmp_stream._buf    = (unsigned char *) outbuf;
 | |
| 	tmp_stream._ptr    = (unsigned char *) outbuf;
 | |
| 	tmp_stream._count  = 512;
 | |
| 
 | |
| 	retval = _doprnt(format, ap, &tmp_stream);
 | |
| 	putc('\0',&tmp_stream);
 | |
| #else
 | |
| 	va_start(ap, format);
 | |
| 
 | |
| 	retval = vsnprintf(outbuf, OUTBUFSIZE, format, ap);
 | |
| #endif
 | |
| 	va_end(ap);
 | |
| 
 | |
|         outstr(outbuf);
 | |
| 
 | |
| 	return retval;
 | |
| }
 | |
| 
 | |
| /* 
 | |
|  * Set logging options 
 | |
|  */
 | |
| void logging( c, name )
 | |
| int c;
 | |
| char *name;
 | |
| {
 | |
| char *t;
 | |
| 
 | |
|   if ( c == 'q' && logfile != NULL ) {
 | |
| 	fclose(logfile);
 | |
| 	return;
 | |
|   }
 | |
| 
 | |
|   if ((t = strchr(name,'\n')) != NULL) *t = '\0';
 | |
|   if ((t = strchr(name,' ' )) != NULL) *t = '\0';
 | |
|   if ( logfile != NULL ) fclose(logfile);
 | |
|  
 | |
|   if ( strlen(name) > 0 ) {
 | |
| 	logfile = fopen(name,"w");
 | |
| 
 | |
| 	if (logfile == NULL) {
 | |
| 		Printf("Cannot open %s for output\n",name);
 | |
| 		return; 
 | |
| 	}
 | |
| 
 | |
| 	/* Close standard output file for L */
 | |
|   	if ( c == 'L' ) {
 | |
| 		fclose(outfile);
 | |
| 		outfile = NULL;
 | |
|   	}
 | |
|   }
 | |
|   else 
 | |
|   /* Reset */
 | |
|   {
 | |
| 	if ( logfile != NULL ) fclose(logfile);
 | |
| 	outfile = stdout;
 | |
| 	outbyte('\n');
 | |
|   }
 | |
| 
 | |
| }
 | |
| 
 | |
| /* Output system error string */
 | |
| void do_error(m)
 | |
| char *m;
 | |
| {
 | |
|     outstr(m);
 | |
|     outstr(": ");
 | |
|     outstr(strerror(errno));   
 | |
|     outstr("\n");
 | |
| }
 | |
| 
 | |
| void closestring()
 | |
| {
 | |
| /* close string device */
 | |
| 
 | |
|     stringcount = 0;
 | |
|     stringstart = string_ptr = NULL;
 | |
| }
 | |
| 
 | |
| int mytolower(ch)
 | |
| int ch;
 | |
| {
 | |
| /* convert char to lower case */
 | |
| 
 | |
|     if (ch >= 'A' && ch <= 'Z')
 | |
| 	ch += 'a' - 'A';
 | |
|     return ch;
 | |
| }
 | |
| 
 | |
| 
 | |
| void openstring(string)
 | |
| char *string;
 | |
| {
 | |
| /* open string device */
 | |
| 
 | |
|     stringcount = 0;
 | |
|     stringstart = string_ptr = string;
 | |
| }
 | |
| 
 | |
| void outbyte(byte)
 | |
| int byte;
 | |
| {
 | |
| /* print char to currently open output devices */
 | |
| 
 | |
|     if (forceupper && byte >= 'a' && byte <= 'z')
 | |
| 	byte += 'A' - 'a';
 | |
|     if (string_ptr != NULL)
 | |
|     {
 | |
| 	if ((*string_ptr++ = byte) == '\t')
 | |
| 	    stringcount = 8 * (stringcount / 8 + 1);
 | |
| 	else
 | |
| 	    ++stringcount;
 | |
|     }
 | |
|     else 
 | |
|     {
 | |
| 	if ( paging && byte == '\n' ) {
 | |
| 		lineno++;		
 | |
| 		if ( lineno >= PAGESIZE) {
 | |
| 			if ( cmdfile == stdin ) {
 | |
| 			     printf("\nMore...any key to continue");
 | |
| 			     fgets( outbuf, OUTBUFSIZE-1, cmdfile );
 | |
| 		     	}
 | |
| 		}
 | |
| 		lineno = 0;
 | |
| 	}
 | |
| 
 | |
| 	if ( outfile != NULL )  
 | |
| 		putc(byte,outfile);
 | |
| 	/* Do not log CR */
 | |
| 	if ( logfile != NULL && byte != '\r' ) 	
 | |
| 		putc(byte,logfile); 
 | |
|     }
 | |
| }
 | |
| 
 | |
| 
 | |
| void outcomma()
 | |
| {
 | |
| /* print comma */
 | |
| 
 | |
|     outbyte(',');
 | |
| }
 | |
| 
 | |
| static char hexdigits[] = "0123456789ABCDEF";
 | |
| void outh4(num)
 | |
| unsigned num;
 | |
| {
 | |
| /* print 4 bits hex */
 | |
| 
 | |
|     outbyte(hexdigits[num % 16]);
 | |
| }
 | |
| 
 | |
| void outh8(num)
 | |
| unsigned num;
 | |
| {
 | |
| /* print 8 bits hex */
 | |
| 
 | |
|     outh4(num / 16);
 | |
|     outh4(num);
 | |
| }
 | |
| 
 | |
| void outh16(num)
 | |
| unsigned num;
 | |
| {
 | |
| /* print 16 bits hex */
 | |
| 
 | |
|     outh8(num / 256);
 | |
|     outh8(num);
 | |
| }
 | |
| 
 | |
| void outh32(num)
 | |
| unsigned num;
 | |
| {
 | |
| /* print 32 bits hex */
 | |
| 
 | |
|     outh16((u16_t) (num >> 16));
 | |
|     outh16((u16_t) num);
 | |
| }
 | |
| 
 | |
| void outspace()
 | |
| {
 | |
| /* print space */
 | |
| 
 | |
|     outbyte(' ');
 | |
| }
 | |
| 
 | |
| void outstr(s)
 | |
| register char *s;
 | |
| {
 | |
| /* print string */
 | |
| 
 | |
|     while (*s)
 | |
| 	outbyte(*s++);
 | |
| }
 | |
| 
 | |
| void outtab()
 | |
| {
 | |
| /* print tab */
 | |
| 
 | |
|     outbyte('\t');
 | |
| }
 | |
| 
 | |
| void outustr(s)
 | |
| register char *s;
 | |
| {
 | |
| /* print string, perhaps converting case to upper */
 | |
| 
 | |
|     forceupper = someupper;
 | |
|     while (*s)
 | |
| 	outbyte(*s++);
 | |
|     forceupper = FALSE;
 | |
| }
 | |
| 
 | |
| 
 | |
| int stringpos()
 | |
| {
 | |
| /* return current offset of string device */
 | |
| 
 | |
|     return string_ptr - stringstart;
 | |
| }
 | |
| 
 | |
| int stringtab()
 | |
| {
 | |
| /* return current "tab" spot of string device */
 | |
| 
 | |
|     return stringcount;
 | |
| }
 | |
| 
 | 
