亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? mysnprintf.c

?? FreeWRLduneInputDevice和FreeWRL一起可以讓用戶用帶有6DoF的輸入設備檢索3D VRML/X3D數據。它基于FreeWRL的"/tmp/inpdev"擴展傳感器輸入接口和w
?? C
?? 第 1 頁 / 共 2 頁
字號:
  int caps = 0;    if (max < 0)    max = 0;  uvalue = value;  if(!(flags & DP_F_UNSIGNED))  {    if( value < 0 ) {      signvalue = '-';      uvalue = -value;    }    else      if (flags & DP_F_PLUS)  /* Do a sign (+/i) */	signvalue = '+';    else      if (flags & DP_F_SPACE)	signvalue = ' ';  }    if (flags & DP_F_UP) caps = 1; /* Should characters be upper case? */  do {    convert[place++] =      (caps? "0123456789ABCDEF":"0123456789abcdef")      [uvalue % (unsigned)base  ];    uvalue = (uvalue / (unsigned)base );  } while(uvalue && (place < 20));  if (place == 20) place--;  convert[place] = 0;  zpadlen = max - place;  spadlen = min - MAX (max, place) - (signvalue ? 1 : 0);  if (zpadlen < 0) zpadlen = 0;  if (spadlen < 0) spadlen = 0;  if (flags & DP_F_ZERO)  {    zpadlen = MAX(zpadlen, spadlen);    spadlen = 0;  }  if (flags & DP_F_MINUS)     spadlen = -spadlen; /* Left Justifty */#ifdef DEBUG_SNPRINTF  dprint (1, (debugfile, "zpad: %d, spad: %d, min: %d, max: %d, place: %d\n",      zpadlen, spadlen, min, max, place));#endif  /* Spaces */  while (spadlen > 0)   {    dopr_outch (buffer, currlen, maxlen, ' ');    --spadlen;  }  /* Sign */  if (signvalue)     dopr_outch (buffer, currlen, maxlen, signvalue);  /* Zeros */  if (zpadlen > 0)   {    while (zpadlen > 0)    {      dopr_outch (buffer, currlen, maxlen, '0');      --zpadlen;    }  }  /* Digits */  while (place > 0)     dopr_outch (buffer, currlen, maxlen, convert[--place]);    /* Left Justified spaces */  while (spadlen < 0) {    dopr_outch (buffer, currlen, maxlen, ' ');    ++spadlen;  }}static long double abs_val (long double value){  long double result = value;  if (value < 0)    result = -value;  return result;}static long double mypow10 (int exp){  long double result = 1;  while (exp)  {    result *= 10;    exp--;  }    return result;}#ifdef WIN32static long round (long double value){  long intpart;  intpart = value;  value = value - intpart;  if (value >= 0.5)    intpart++;  return intpart;}#endifstatic void fmtfp (char *buffer, size_t *currlen, size_t maxlen,		   long double fvalue, int min, int max, int flags){  int signvalue = 0;  long double ufvalue;  char iconvert[20];  char fconvert[20];  int iplace = 0;  int fplace = 0;  int padlen = 0; /* amount to pad */  int zpadlen = 0;   int caps = 0;  long intpart;  long fracpart;  long old_fracpart;  int zeros;  int i;  /*    * AIX manpage says the default is 0, but Solaris says the default   * is 6, and sprintf on AIX defaults to 6   */  if (max < 0)    max = 6;  ufvalue = abs_val (fvalue);  if (fvalue < 0)    signvalue = '-';  else    if (flags & DP_F_PLUS)  /* Do a sign (+/i) */      signvalue = '+';    else      if (flags & DP_F_SPACE)	signvalue = ' ';#if 0  if (flags & DP_F_UP) caps = 1; /* Should characters be upper case? */#endif  intpart = ufvalue;  /*    * Sorry, we only support 9 digits past the decimal because of our    * conversion method   */  if (max > 9)    max = 9;  /* We "cheat" by converting the fractional part to integer by   * multiplying by a factor of 10   */    fracpart = (mypow10 (max)) * (ufvalue - intpart);  if (fracpart>0)     {     zeros=fabs(floor(log(ufvalue - intpart)/log(10))+1);     if (zeros>=20)       zeros=20;     }  else     {     fracpart=0;     zeros=0;     }  old_fracpart=fracpart;  if (fracpart >= mypow10 (max))  {    intpart++;    fracpart -= mypow10 (max);  }#ifdef DEBUG_SNPRINTF  dprint (1, (debugfile, "fmtfp: %f =? %d.%d\n", fvalue, intpart, fracpart));#endif  /* Convert integer part */  do {    iconvert[iplace++] =      (caps? "0123456789ABCDEF":"0123456789abcdef")[intpart % 10];    intpart = (intpart / 10);  } while(intpart && (iplace < 20));  if (iplace == 20) iplace--;  iconvert[iplace] = 0;  /* Convert fractional part */  do {    fconvert[fplace++] =      (caps? "0123456789ABCDEF":"0123456789abcdef")[fracpart % 10];    fracpart = (fracpart / 10);  } while(fracpart && (fplace-zeros < 20));  for (i=0;(i<zeros);i++)     fconvert[fplace++]='0';  if (fplace == 20) fplace--;  fconvert[fplace] = 0;  /* -1 for decimal point, another -1 if we are printing a sign */  padlen = min - iplace - max - 1 - ((signvalue) ? 1 : 0);   zpadlen = max - fplace;  if (zpadlen < 0)    zpadlen = 0;  if (padlen < 0)     padlen = 0;  if (flags & DP_F_MINUS)     padlen = -padlen; /* Left Justifty */  if ((flags & DP_F_ZERO) && (padlen > 0))   {    if (signvalue)     {      dopr_outch (buffer, currlen, maxlen, signvalue);      --padlen;      signvalue = 0;    }    while (padlen > 0)    {      dopr_outch (buffer, currlen, maxlen, '0');      --padlen;    }  }  while (padlen > 0)  {    dopr_outch (buffer, currlen, maxlen, ' ');    --padlen;  }  if (signvalue)     dopr_outch (buffer, currlen, maxlen, signvalue);  while (iplace > 0)     dopr_outch (buffer, currlen, maxlen, iconvert[--iplace]);  if (old_fracpart!=0) {     /*      * Decimal point.  This should probably use locale to find the correct      * char to print out.      */     dopr_outch (buffer, currlen, maxlen, '.');        while (fplace > 0)        dopr_outch (buffer, currlen, maxlen, fconvert[--fplace]);        while (zpadlen > 0)     {       dopr_outch (buffer, currlen, maxlen, '0');       --zpadlen;     }        while (padlen < 0)      {       dopr_outch (buffer, currlen, maxlen, ' ');       ++padlen;     }  }}static void dopr_outch (char *buffer, size_t *currlen, size_t maxlen, char c){  if (*currlen < maxlen)    buffer[(*currlen)++] = c;}int myvsnprintf (char *str, size_t count, const char *fmt, va_list args){  str[0] = 0;  dopr(str, count, fmt, args);  return(mystrlen(str));}/* VARARGS3 */#ifdef HAVE_STDARGSint mysnprintf (char *str,size_t count,const char *fmt,...)#elseint mysnprintf (va_alist) va_dcl#endif{#ifndef HAVE_STDARGS  char *str;  size_t count;  char *fmt;#endif  VA_LOCAL_DECL;      VA_START (fmt);  VA_SHIFT (str, char *);  VA_SHIFT (count, size_t );  VA_SHIFT (fmt, char *);  (void) myvsnprintf(str, count, fmt, ap);  VA_END;  return(mystrlen(str));}#ifdef WIN32/* VARARGS3 */#ifdef HAVE_STDARGSint __cdecl msgboxprintf (FILE * f,const char *fmt,...)#elseint __cdecl msgboxprintf (va_alist) va_dcl#endif{#ifndef HAVE_STDARGS  FILE* f;  char *fmt;#endif  char text[1024];  VA_LOCAL_DECL;      VA_START (fmt);  VA_SHIFT (text, char *);  VA_SHIFT (1024, size_t );  VA_SHIFT (fmt, char *);  (void) myvsnprintf(text, 1024, fmt, ap);  VA_END;  MessageBox(NULL,text,"white_dune",MB_ICONINFORMATION);  return(mystrlen(text));}#endifstatic void fmtefp (char *buffer, size_t *currlen, size_t maxlen,		   long double evalue, int min, int max, int flags){  long double fvalue;  int exp;    if (evalue==0)     dopr_outch(buffer, currlen, maxlen, '0');  else     {     exp=floor(log(fabs(evalue))/log(10.0));     if ((exp>2) || (exp<-1))        {        fvalue=evalue*pow(10.0,-(double)exp);          fmtfp (buffer, currlen, maxlen, fvalue, min, max, flags);          dopr_outch(buffer, currlen, maxlen, 'e');        fmtint (buffer,currlen, maxlen,exp,10,min,max,flags);        }     else        fmtfp (buffer, currlen, maxlen, evalue, min, max, flags);     }  }int mywritestr(int filedes,const char *str)  {  int position_written;  int restlength;  restlength=mystrlen(str);  position_written=0;  while (restlength>0)     {     int writereturn;     if ( (writereturn = write(filedes,str+position_written,restlength)) < 0 )        return(-1);     restlength=restlength-writereturn;     position_written=position_written+writereturn;     }  return(0);  }/* VARARGS3 */#ifdef HAVE_STDARGSint mywritef (int filedes,const char *fmt,...)#elseint mywritef (va_alist) va_dcl#endif{   char str[8000];#ifndef HAVE_STDARGS  int filedes;  char *fmt;#endif  VA_LOCAL_DECL;      VA_START (fmt);  VA_SHIFT (filedes, int);  VA_SHIFT (fmt, char *);  (void) myvsnprintf(str,8000, fmt, ap);  VA_END;  /* error, myvsnprintf possibly truncated data */  if (mystrlen(str)>=7999)     return(-2);  return mywritestr(filedes,str);}char* mystrncpy(char* str1,const char *str2,int n)   {   str1[n-1]=0;   if (strlen(str2)==n)      return strncpy(str1,str2,n-1);   else      return strncpy(str1,str2,n);   }#ifdef TEST_SNPRINTF#ifndef LONG_STRING#define LONG_STRING 1024#endif#include <stdio.h>int main (void){  char buf1[LONG_STRING];  char buf2[LONG_STRING];  char *fp_fmt[] = {    "%-1.5f",    "%g",    "%f",    "%-1.5f",    "%1.5f",    "%123.9f",    "%10.5f",    "% 10.5f",    "%+22.9f",    "%+4.9f",    "%01.3f",    "%4f",    "%3.1f",    "%3.2f",    NULL  };  float test_fp_nums[] = { -1, 1, 0.5, 0102.1, 1.0032, 203.9,-1.5, 134.21, 91340.2, 341.1234, 0203.9, 0.96, 0.996,     0.9996, 1.996, 1.003, 4.136, 0};  char *int_fmt[] = {    "%-1.5d",    "%1.5d",    "%123.9d",    "%5.5d",    "%10.5d",    "% 10.5d",    "%+22.33d",    "%01.3d",    "%4d",    NULL  };  long int_nums[] = { -1, 134, 91340, 341, 0203, 0};  int x, y;  int fail = 0;  int num = 0;  printf ("Testing snprintf format codes against system sprintf...\n");  for (x = 0; fp_fmt[x] != NULL ; x++)    {    for (y = 0; test_fp_nums[y] != 0 ; y++)    {      mysnprintf (buf1, sizeof (buf1), fp_fmt[x], test_fp_nums[y]);      sprintf (buf2, fp_fmt[x], test_fp_nums[y]);      if (strcmp (buf1, buf2))      {	printf("snprintf %lf doesn't match Format: %s\n\tsnprintf = %s\n\tsprintf  = %s\n", 	    test_fp_nums[y],fp_fmt[x], buf1, buf2);	fail++;      }    }   mysnprintf (buf1, sizeof (buf1), fp_fmt[x],0);   sprintf (buf2, fp_fmt[x], 0);   if (strcmp (buf1, buf2))   {      printf("snprintf %lf doesn't match Format: %s\n\tsnprintf = %s\n\tsprintf  = %s\n",       test_fp_nums[y],fp_fmt[x], buf1, buf2);      fail++;   }   num++;  }  for (x = 0; int_fmt[x] != NULL ; x++)    for (y = 0; int_nums[y] != 0 ; y++)    {      mysnprintf (buf1, sizeof (buf1), int_fmt[x], int_nums[y]);      sprintf (buf2, int_fmt[x], int_nums[y]);      if (strcmp (buf1, buf2))      {	printf("snprintf doesn't match Format: %s\n\tsnprintf = %s\n\tsprintf  = %s\n", 	    int_fmt[x], buf1, buf2);	fail++;      }      num++;    }  printf ("%d tests failed out of %d.\n", fail, num);}#endif /* SNPRINTF_TEST */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品综合久久久久久| 国产欧美精品一区二区色综合朱莉 | 精品一区二区日韩| 国产精品毛片a∨一区二区三区| 7878成人国产在线观看| 99视频精品全部免费在线| 美女高潮久久久| 亚洲高清免费视频| 国产一二三精品| 欧美人xxxx| av亚洲精华国产精华| 免费在线看一区| 亚洲精选一二三| 国产欧美精品区一区二区三区 | 亚洲色图制服丝袜| 久久综合色8888| 日韩女优视频免费观看| 在线免费观看不卡av| 成人激情文学综合网| 国产在线视频不卡二| 青青草国产精品97视觉盛宴| 一区二区三区在线影院| 亚洲色图都市小说| 国产精品美女久久久久久2018| 337p日本欧洲亚洲大胆色噜噜| 3d成人动漫网站| 欧美日韩日日摸| 欧美写真视频网站| 色系网站成人免费| 精品免费视频.| 在线播放中文字幕一区| 91在线观看美女| 风间由美一区二区av101| 蜜臀99久久精品久久久久久软件| 色综合天天综合在线视频| 处破女av一区二区| 成熟亚洲日本毛茸茸凸凹| 国产成人av电影在线观看| 国产成人精品免费看| 成人免费高清视频在线观看| 亚洲午夜一区二区三区| 亚洲成人中文在线| 午夜欧美电影在线观看| 日本中文在线一区| 老司机午夜精品99久久| 精品一区二区三区欧美| 国产一区视频在线看| 粉嫩久久99精品久久久久久夜| 成人综合在线观看| 91国模大尺度私拍在线视频| 欧美色综合久久| 欧美videofree性高清杂交| 精品国产污污免费网站入口 | 美女视频黄 久久| 九九精品一区二区| 国产99久久久久| 91农村精品一区二区在线| 欧美三级视频在线播放| 日韩精品一区二区三区蜜臀| www成人在线观看| 自拍偷拍亚洲激情| 日韩电影在线一区二区三区| 精品一区二区三区视频在线观看| 高清在线观看日韩| 欧美性猛交xxxxxx富婆| 日韩精品一区二区三区老鸭窝| 国产欧美日韩久久| 亚洲综合在线第一页| 美腿丝袜亚洲综合| 国产成人超碰人人澡人人澡| 日本国产一区二区| 日韩精品一区二区三区老鸭窝| 国产女人18水真多18精品一级做| 亚洲精品ww久久久久久p站| 肉丝袜脚交视频一区二区| 韩国三级中文字幕hd久久精品| aa级大片欧美| 欧美v国产在线一区二区三区| 自拍偷在线精品自拍偷无码专区| 日韩av在线播放中文字幕| 丰满白嫩尤物一区二区| 欧美高清视频在线高清观看mv色露露十八 | 欧美成人a视频| 亚洲精品欧美综合四区| 免费精品视频最新在线| 99精品视频免费在线观看| 日韩视频免费直播| 综合久久久久久久| 国产一区二区三区国产| 欧美午夜片在线观看| 国产亚洲精品bt天堂精选| 香蕉久久一区二区不卡无毒影院| 欧美一级在线观看| 国产精品国产成人国产三级| 久久99久久久久| 在线观看中文字幕不卡| 国产精品天干天干在观线| 蜜臀va亚洲va欧美va天堂| 色婷婷精品大在线视频| 久久精品人人做| 日本免费新一区视频| 日本韩国精品在线| 国产精品久久久久久久久晋中| 麻豆专区一区二区三区四区五区| 色就色 综合激情| 国产精品久久久久久久久久久免费看| 久久www免费人成看片高清| 欧美日韩国产另类不卡| 一区二区三区四区蜜桃| av在线免费不卡| 久久久久亚洲综合| 乱一区二区av| 91精品国产乱码久久蜜臀| 亚洲国产另类av| 91蜜桃婷婷狠狠久久综合9色| 久久久亚洲精品一区二区三区| 麻豆成人在线观看| 欧美一区二区三区在线看| 午夜精品福利一区二区三区蜜桃| 色综合久久综合中文综合网| 亚洲欧洲精品成人久久奇米网| 国产精品中文欧美| 26uuu另类欧美| 国产在线精品一区二区夜色| 欧美一级黄色片| 日韩av在线发布| 欧美一二三在线| 蜜桃久久av一区| 欧美一级xxx| 久久精品久久99精品久久| 日韩午夜激情免费电影| 免费成人在线视频观看| 欧美一区二区三区在线观看视频| 日本成人中文字幕| 欧美一区二区三区在线电影| 男女男精品视频网| 欧美videos大乳护士334| 精品一区二区免费视频| 久久美女艺术照精彩视频福利播放| 久久aⅴ国产欧美74aaa| 久久蜜桃av一区精品变态类天堂| 国产一区二区91| 国产精品欧美一区喷水| 91麻豆国产在线观看| 一区二区三区日韩欧美精品| 欧美日韩一级二级三级| 三级在线观看一区二区| 2020国产精品| 成人黄色片在线观看| 亚洲乱码中文字幕综合| 欧美日韩免费电影| 老司机精品视频线观看86| 久久伊99综合婷婷久久伊| 成人性色生活片| 亚洲精品五月天| 日韩一二三区视频| 国产风韵犹存在线视精品| 国产精品久久久久久久久动漫 | 色老汉一区二区三区| 亚洲一区二区三区激情| 日韩一区二区在线免费观看| 国产成人在线网站| 亚洲视频免费在线| 欧美一区二区三区成人| 国产二区国产一区在线观看| 亚洲人成亚洲人成在线观看图片| 一二三四区精品视频| 日韩欧美亚洲国产另类| 成人网在线播放| 亚洲国产视频网站| 精品国产一二三| 欧美综合欧美视频| 精品亚洲porn| 一区二区三区在线免费| 精品久久久久久无| 日本韩国精品在线| 国产精品中文字幕日韩精品| 亚洲综合色在线| 国产亚洲一区二区三区在线观看| 日本精品视频一区二区三区| 国产综合久久久久影院| 亚洲综合一区在线| 国产欧美一区二区三区在线老狼 | 91精品福利在线一区二区三区| 国产一区不卡视频| 亚洲va天堂va国产va久| 欧美国产欧美综合| 欧美日韩国产另类一区| 成人小视频在线观看| 捆绑调教一区二区三区| 18成人在线视频| 久久蜜桃av一区二区天堂| 欧美美女直播网站| 成人国产精品免费观看| 极品少妇一区二区三区精品视频| 亚洲国产精品久久艾草纯爱| 国产精品理论片| 国产亚洲欧美激情| 欧美一区二区三区不卡| 精品视频在线免费观看|