⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 doprntx.c

📁 Support is available from MIPS Technologies Inc. - problems should be addressed to support@mips.co
💻 C
字号:
/************************************************************************ * *  doprntx.c * *  Print formatting functions * * ###################################################################### * * mips_start_of_legal_notice *  * Copyright (c) 2002 MIPS Technologies, Inc. All rights reserved. * * * Unpublished rights (if any) reserved under the Copyright Laws of the * United States of America. * * If this document is provided in source format (i.e., in a modifiable form * such as in FrameMaker or Microsoft Word format), then its use and * distribution is subject to a written agreement with MIPS Technologies, * Inc. ("MIPS Technologies"). UNDER NO CIRCUMSTANCES MAY A DOCUMENT * PROVIDED IN SOURCE FORMAT BE DISTRIBUTED TO A THIRD PARTY WITHOUT THE * EXPRESS WRITTEN CONSENT OF MIPS TECHNOLOGIES. * * This document contains information that is proprietary to MIPS * Technologies. Any copying, reproducing, modifying, or use of this * information (in whole or in part) which is not expressly permitted in * writing by MIPS Technologies or a contractually-authorized third party is * strictly prohibited. At a minimum, this information is protected under * unfair competition and copyright laws. Violations thereof may result in * criminal penalties and fines. * * MIPS Technologies or any contractually-authorized third party reserves * the right to change the information contained in this document to improve * function, design or otherwise. MIPS Technologies does not assume any * liability arising out of the application or use of this information, or * of any error of omission in such information. Any warranties, whether * express, statutory, implied or otherwise, including but not limited to * the implied warranties of merchantability or fitness for a particular * purpose, are excluded. Any license under patent rights or any other * intellectual property rights owned by MIPS Technologies or third parties * shall be conveyed by MIPS Technologies or any contractually-authorized * third party in a separate license agreement between the parties. * * The information contained in this document shall not be exported or * transferred for the purpose of reexporting in violation of any U.S. or * non-U.S. regulation, treaty, Executive Order, law, statute, amendment or * supplement thereto. * * The information contained in this document constitutes one or more of the * following: commercial computer software, commercial computer software * documentation or other commercial items. If the user of this information, * or any related documentation of any kind, including related technical * data or manuals, is an agency, department, or other entity of the United * States government ("Government"), the use, duplication, reproduction, * release, modification, disclosure, or transfer of this information, or * any related documentation of any kind, is restricted in accordance with * Federal Acquisition Regulation 12.212 for civilian agencies and Defense * Federal Acquisition Regulation Supplement 227.7202 for military agencies. * The use of this information by the Government is further restricted in * accordance with the terms of the license agreement(s) and/or applicable * contract terms and conditions covering this information from MIPS *  * mips_end_of_legal_notice *  * ************************************************************************/#include <ctype.h>#include <stdarg.h>#include <yamon_api.h>#define	BUF	32#define CR      0x0D#define LF      0x0A#define	ARG()								\            _ulong =							\	        (flags & SHORTINT) ?					\	            (UINT32)((INT16)((UINT16)va_arg(argp, UINT32))) :	\		    (UINT32)va_arg(argp, UINT32);#define	todigit(c)	((c) - '0')#define	tochar(n)	((n) + '0')/* have to deal with the negative buffer count kludge */#define	NEGATIVE_COUNT_KLUDGE#define	LONGINT		0x01		/* long integer 		*/#define	LONGDBL		0x02		/* long double; unimplemented 	*/#define	SHORTINT	0x04		/* short integer 		*/#define	ALT		0x08		/* alternate form 		*/#define	LADJUST		0x10		/* left adjustment 		*/#define	ZEROPAD		0x20		/* zero (as opposed to blank) pad */#define	HEXPREFIX	0x40		/* add 0x or 0X prefix 		*/int _doprntx(	char 		*fmt0,	va_list 	argp,	void		(*putc)(),	char		**pca){	UINT8 	*fmt;		/* format string 			*/	int 	ch;		/* character from fmt 			*/	int 	cnt;		/* return value accumulator 		*/	int 	n;		/* random handy integer 		*/	char 	*t;		/* buffer pointer */	UINT32 	_ulong;		/* integer arguments %[diouxX] 		*/	int 	base;		/* base for [diouxX] conversion 	*/	int 	dprec;		/* decimal precision in [diouxX] 	*/	int 	fieldsz;	/* field size expanded by sign, etc 	*/	int 	flags;		/* flags as above 			*/	int 	fpprec;		/* `extra' floating precision in [eEfgG]*/	int 	prec;		/* precision from format (%.3d), or -1 	*/	int 	realsz;		/* field size expanded by decimal precision */	int 	size;		/* size of converted field or string 	*/	int 	width;		/* width from format (%8d), or 0 	*/	char	sign;		/* sign prefix (' ', '+', '-', or \0) 	*/	char	*digs;		/* digits for [diouxX] conversion 	*/	char 	buf[BUF];	/* space for %c, %[diouxX], %[eEfgG] 	*/	fmt = (UINT8*)fmt0;	digs = "0123456789abcdef";	for (cnt = 0;; ++fmt) {		for (; (ch = *fmt) && ch != '%';		     ++cnt, ++fmt)		    if(ch!='\n')		      putc(ch, pca);		    else		    { putc(CR, pca); putc(LF, pca); ++cnt; };		if (!ch)			return (cnt);		flags = 0; dprec = 0; fpprec = 0; width = 0;		prec = -1;		sign = '\0';rflag:		switch (*++fmt) {		case ' ':			/*			 * ``If the space and + flags both appear, the space			 * flag will be ignored.''			 *	-- ANSI X3J11			 */			if (!sign)				sign = ' ';			goto rflag;		case '#':			flags |= ALT;			goto rflag;		case '*':			/*			 * ``A negative field width argument is taken as a			 * - flag followed by a  positive field width.''			 *	-- ANSI X3J11			 * They don't exclude field widths read from args.			 */			if ((width = va_arg(argp, int)) >= 0)				goto rflag;			width = -width;			/* FALLTHROUGH */		case '-':			flags |= LADJUST;			goto rflag;		case '+':			sign = '+';			goto rflag;		case '.':			if (*++fmt == '*')				n = va_arg(argp, int);			else {				n = 0;				while (isascii(*fmt) && isdigit(*fmt))					n = 10 * n + todigit(*fmt++);				--fmt;			}			prec = n < 0 ? -1 : n;			goto rflag;		case '0':			/*			 * ``Note that 0 is taken as a flag, not as the			 * beginning of a field width.''			 *	-- ANSI X3J11			 */			flags |= ZEROPAD;			goto rflag;		case '1': case '2': case '3': case '4':		case '5': case '6': case '7': case '8': case '9':			n = 0;			do {				n = 10 * n + todigit(*fmt);			} while (isascii(*++fmt) && isdigit(*fmt));			width = n;			--fmt;			goto rflag;		case 'L':			flags |= LONGDBL;			goto rflag;		case 'h':			flags |= SHORTINT;			goto rflag;		case 'l':			flags |= LONGINT;			goto rflag;		case 'c':			*(t = buf) = va_arg(argp, int);			size = 1;			sign = '\0';			goto pforw;		case 'D':			flags |= LONGINT;			/*FALLTHROUGH*/		case 'd':		case 'i':			ARG();			if ((long)_ulong < 0) {				_ulong = -_ulong;				sign = '-';			}			base = 10;			goto number;		case 'n':			if (flags & LONGINT)				*va_arg(argp, long *) = cnt;			else if (flags & SHORTINT)				*va_arg(argp, short *) = cnt;			else				*va_arg(argp, int *) = cnt;			break;					case 'O':			flags |= LONGINT;			/*FALLTHROUGH*/		case 'o':			ARG();			base = 8;			goto nosign;		case 'p':			/*			 * ``The argument shall be a pointer to void.  The			 * value of the pointer is converted to a sequence			 * of printable characters, in an implementation-			 * defined manner.''			 *	-- ANSI X3J11			 */			/* NOSTRICT */			_ulong = (UINT32)va_arg(argp, void *);			base = 16;			goto nosign;		case 's':			if (!(t = va_arg(argp, char *)))				t = "(null)";			if (prec >= 0) {				/*				 * can't use strlen; can only look for the				 * NUL in the first `prec' characters, and				 * strlen() will go further.				 */				char *p, *memchr();				if ((p = memchr(t, 0, prec))) {					size = p - t;					if (size > prec)						size = prec;				} else					size = prec;			} else				size = strlen(t);			sign = '\0';			goto pforw;		case 'U':			flags |= LONGINT;			/*FALLTHROUGH*/		case 'u':			ARG();			base = 10;			goto nosign;		case 'X':			digs = "0123456789ABCDEF";			/* FALLTHROUGH */		case 'x':			ARG();			base = 16;			/* leading 0x/X only if non-zero */			if (flags & ALT && _ulong != 0)				flags |= HEXPREFIX;			/* unsigned conversions */nosign:			sign = '\0';			/*			 * ``... diouXx conversions ... if a precision is			 * specified, the 0 flag will be ignored.''			 *	-- ANSI X3J11			 */number:			if ((dprec = prec) >= 0)				flags &= ~ZEROPAD;			/*			 * ``The result of converting a zero value with an			 * explicit precision of zero is no characters.''			 *	-- ANSI X3J11			 */			t = buf + BUF;			if (_ulong != 0 || prec != 0) {				do {					*--t = digs[_ulong % base];					_ulong /= base;				} while (_ulong);				digs = "0123456789abcdef";				if (flags & ALT && base == 8 && *t != '0')					*--t = '0'; /* octal leading 0 */			}			size = buf + BUF - t;pforw:			/*			 * All reasonable formats wind up here.  At this point,			 * `t' points to a string which (if not flags&LADJUST)			 * should be padded out to `width' places.  If			 * flags&ZEROPAD, it should first be prefixed by any			 * sign or other prefix; otherwise, it should be blank			 * padded before the prefix is emitted.  After any			 * left-hand padding and prefixing, emit zeroes			 * required by a decimal [diouxX] precision, then print			 * the string proper, then emit zeroes required by any			 * leftover floating precision; finally, if LADJUST,			 * pad with blanks.			 */			/*			 * compute actual size, so we know how much to pad			 * fieldsz excludes decimal prec; realsz includes it			 */			fieldsz = size + fpprec;			if (sign)				fieldsz++;			if (flags & HEXPREFIX)				fieldsz += 2;			realsz = dprec > fieldsz ? dprec : fieldsz;			/* right-adjusting blank padding */			if ((flags & (LADJUST|ZEROPAD)) == 0 && width)				for (n = realsz; n < width; n++)					putc(' ', pca);			/* prefix */			if (sign)				putc(sign, pca);			if (flags & HEXPREFIX) {				putc('0', pca);				putc((char)*fmt, pca);			}			/* right-adjusting zero padding */			if ((flags & (LADJUST|ZEROPAD)) == ZEROPAD)				for (n = realsz; n < width; n++)					putc('0', pca);			/* leading zeroes from decimal precision */			for (n = fieldsz; n < dprec; n++)				putc('0', pca);			/* the string or number proper */			n=size;			while (--n >= 0)			  putc(*t++, pca);			/* trailing f.p. zeroes */			while (--fpprec >= 0)				putc('0', pca);			/* left-adjusting padding (always blank) */			if (flags & LADJUST)				for (n = realsz; n < width; n++)					putc(' ', pca);			/* finally, adjust cnt */			cnt += width > realsz ? width : realsz;			break;		case '\0':	/* "%?" prints ?, unless ? is NULL */			return (cnt);		default:			putc((char)*fmt, pca);			cnt++;		}	}	/* NOTREACHED */}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -