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

📄 _xpndfmt.c

📁 上一个上传的有问题,这个是好的。visopsys包括系统内核和GUI的全部SOURCE code ,还包括一些基本的docs文档。里面src子目录对应所有SOURCE code.对于想研究操作系统的朋
💻 C
字号:
// //  Visopsys//  Copyright (C) 1998-2007 J. Andrew McLaughlin//  //  This library is free software; you can redistribute it and/or modify it//  under the terms of the GNU Lesser General Public License as published by//  the Free Software Foundation; either version 2.1 of the License, or (at//  your option) any later version.////  This library is distributed in the hope that it will be useful, but//  WITHOUT ANY WARRANTY; without even the implied warranty of//  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser//  General Public License for more details.////  You should have received a copy of the GNU Lesser General Public License//  along with this library; if not, write to the Free Software Foundation,//  Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.////  _xpndfmt.c//// This function does all the work of expanding the format strings used// by the printf family of functions (and others, if desired)#include <errno.h>#include <stdarg.h>#include <stdlib.h>#include <string.h>#include <sys/cdefs.h>int _xpndfmt(char *output, int outputLen, const char *format, va_list list){  int inCount = 0;  int outCount = 0;  int formatLen = 0;  long long argument = NULL;  int zeroPad = 0;  int leftJust = 0;  int fieldWidth = 0;   int isLong = 0;  int digits = 0;  // How long is the format string?  formatLen = strlen(format);  if (formatLen < 0)    {      errno = formatLen;      return (outCount = 0);    }  if (formatLen > outputLen)    {      errno = ERR_BOUNDS;      return (outCount = 0);    }  formatLen = min(formatLen, MAXSTRINGLENGTH);  // The argument list must already have been initialized using va_start  // Loop through all of the characters in the format string  for (inCount = 0; ((inCount < formatLen) && (outCount < (outputLen - 1))); )    {      if (format[inCount] != '%')	{	  output[outCount++] = format[inCount++];	  continue;	}      else if ((format[inCount] == '%') && (format[inCount + 1] == '%'))	{	  // Copy it, but skip the next one	  output[outCount++] = format[inCount];	  inCount += 2;	  continue;	}      // Move to the next character      inCount += 1;      // Look for a zero digit, which indicates that any field width argument      // is to be zero-padded      if (format[inCount] == '0')	{	  zeroPad = 1;	  inCount += 1;	}      else	zeroPad = 0;      // Look for left-justification (applicable if there's a field-width      // specifier to follow      if (format[inCount] == '-')	{	  leftJust = 1;	  inCount += 1;	}      else	leftJust = 0;      // Look for field length indicator      if ((format[inCount] >= '1') && (format[inCount] <= '9'))	{	  fieldWidth = atoi(format + inCount);	  while ((format[inCount] >= '0') && (format[inCount] <= '9'))   	    inCount++;        }      else	fieldWidth = 0;      // If there's an 'll' qualifier for long values, make note of it      if (format[inCount] == 'l')	{	  inCount += 1;	  if (format[inCount] == 'l')	    {	      isLong = 1;	      inCount += 1;	    }	}      else	isLong = 0;      // We have some format characters.  Get the corresponding argument.      if (isLong)	{	  argument = (long long) va_arg(list, unsigned);	  argument |= (((long long) va_arg(list, unsigned)) << 32);	}      else	argument = va_arg(list, unsigned);      // What is it?      switch(format[inCount])	{	case 'd':	case 'i':	  // This is an integer.  Put the characters for the integer	  // into the destination string          if (fieldWidth)            {	      if (isLong)		digits = _ldigits(argument, 10, 1);	      else		digits = _digits(argument, 10, 1);	      if (!leftJust)		while (digits++ < fieldWidth)		  output[outCount++] = (zeroPad? '0' : ' ');            }	  if (isLong)	    lltoa(argument, (output + outCount));	  else	    itoa(argument, (output + outCount));	  outCount = strlen(output);	  if (fieldWidth && leftJust)	    while (digits++ < fieldWidth)	      output[outCount++] = ' ';	  break;	case 'u':	  // This is an unsigned integer.  Put the characters for	  // the integer into the destination string	  if (fieldWidth)	    {	      if (isLong)		digits = _ldigits(argument, 10, 0);	      else		digits = _digits(argument, 10, 0);	      if (!leftJust)		while (digits++ < fieldWidth)		  output[outCount++] = (zeroPad? '0' : ' ');	    }	  if (isLong)	    ulltoa(argument, (output + outCount));	  else	    utoa(argument, (output + outCount));	  outCount = strlen(output);	  if (fieldWidth && leftJust)	    while (digits++ < fieldWidth)	      output[outCount++] = ' ';	  break;	case 'c':	  // A character.	  output[outCount++] = (char) ((unsigned int) argument);	  break;	case 's':	  // This is a string.  Copy the string from the next argument	  // to the destnation string and increment outCount appropriately	  if (argument)	    {	      strcpy((output + outCount), (char *) ((unsigned) argument));	      outCount += strlen((char *) ((unsigned) argument));	    }	  else	    {	      // Eek.	      strncpy((output + outCount), "(NULL)", 7);	      outCount += 6;	    }	  break;	case 'p':	  // Bit of special stuff for pointer args	  output[outCount++] = '0';	  output[outCount++] = 'x';	  fieldWidth = (2 * sizeof(void *));	  if (isLong)	    digits = _ldigits(argument, 16, 0);	  else	    digits = _digits(argument, 16, 0);	  if (!leftJust)	    while (digits++ < fieldWidth)	      output[outCount++] = '0';	  if (isLong)	    lltoux(argument, (output + outCount));	  else	    itoux(argument, (output + outCount));	  outCount = strlen(output);	  if (fieldWidth && leftJust)	    while (digits++ < fieldWidth)	      output[outCount++] = ' ';	  break;	case 'x':	case 'X':	  if (fieldWidth)	    {	      if (isLong)		digits = _ldigits(argument, 16, 0);	      else		digits = _digits(argument, 16, 0);	      if (!leftJust)		while (digits++ < fieldWidth)		  output[outCount++] = (zeroPad? '0' : ' ');	    }	  if (isLong)	    lltoux(argument, (output + outCount));	  else	    itoux(argument, (output + outCount));	  outCount = strlen(output);	  if (fieldWidth && leftJust)	    while (digits++ < fieldWidth)	      output[outCount++] = ' ';	  break;	default:	  // Umm, we don't know what this is.  Just copy the '%' and	  // the format character to the output stream	  output[outCount++] = format[inCount - 1];	  output[outCount++] = format[inCount];	  break;	}      inCount += 1;    }  output[outCount] = '\0';  // Return the number of characters we wrote  return (outCount);}

⌨️ 快捷键说明

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