📄 sfgetd.c
字号:
/* Copyright (c) Colorado School of Mines, 2006.*//* All rights reserved. */#include "sfhdr.h"/* Read a portably coded double value**** Written by Kiem-Phong Vo*/#if __STD_CSfdouble_t sfgetd(Sfio_t* f)#elseSfdouble_t sfgetd(f)Sfio_t* f;#endif{ reg uchar *s, *ends, c; reg int p, sign, exp; Sfdouble_t v; SFMTXSTART(f,-1.); if((sign = sfgetc(f)) < 0 || (exp = (int)sfgetu(f)) < 0) SFMTXRETURN(f, -1.); if(f->mode != SF_READ && _sfmode(f,SF_READ,0) < 0) SFMTXRETURN(f, -1.); SFLOCK(f,0); v = 0.; for(;;) { /* fast read for data */ if(SFRPEEK(f,s,p) <= 0) { f->flags |= SF_ERROR; v = -1.; goto done; } for(ends = s+p; s < ends; ) { c = *s++; v += SFUVALUE(c); v = ldexpl(v,-SF_PRECIS); if(!(c&SF_MORE)) { f->next = s; goto done; } } f->next = s; }done: v = ldexpl(v,(sign&02) ? -exp : exp); if(sign&01) v = -v; SFOPEN(f,0); SFMTXRETURN(f, v);}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -