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

📄 sfgetd.c

📁 su 的源代码库
💻 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 + -