mirror of
				https://github.com/SEPPDROID/Digital-Research-Source-Code.git
				synced 2025-10-25 09:24:19 +00:00 
			
		
		
		
	Upload
Digital Research
This commit is contained in:
		
							
								
								
									
										76
									
								
								CPM OPERATING SYSTEMS/CPM 68K/1.0X SOURCES/v102a/libf/etoa.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										76
									
								
								CPM OPERATING SYSTEMS/CPM 68K/1.0X SOURCES/v102a/libf/etoa.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,76 @@ | ||||
| /* | ||||
|  *	Ftoa routine with rounding | ||||
|  */ | ||||
| #include <portab.h> | ||||
| BYTE	*etoa(x,str,prec) | ||||
| FLOAT	 x;					/* Arg to convert	*/ | ||||
| BYTE	*str;					/* -> Output area	*/ | ||||
| WORD	 prec;					/* # digits right of dp */ | ||||
| { | ||||
| REG	WORD	ie,i,k,ndig;			/* Temps		*/ | ||||
| 	BYTE	*savstr;			/* Copy	of str to return*/ | ||||
| 	DOUBLE	y;				/* Temp for rounding	*/ | ||||
| 	 | ||||
| 	savstr = str;				/* Preserve for later	*/ | ||||
| 	ndig = (prec <= 0) ? 1 : ((prec > 22) ? 23 : prec+1); | ||||
| 	ie = 0; | ||||
| 	if(x < 0)				/* Fix for negative	*/ | ||||
| 	{ | ||||
| 	  *str++ = '-'; | ||||
| 	   x = -x;				/* Negate		*/ | ||||
| 	} | ||||
| /* | ||||
|  *	Normalize x to the range 0.0 <= x < 10.0 | ||||
|  */ | ||||
| 	if(x > 0.0) | ||||
| 	{ | ||||
| 	  while (x < 1.0) | ||||
| 	  { | ||||
| 	     x *= 10.0; | ||||
| 	     ie--; | ||||
| 	  } | ||||
| 	} | ||||
| 	while(x >= 10.0) | ||||
| 	{ | ||||
| 	  x /= 10.0; | ||||
| 	  ie++; | ||||
| 	} | ||||
|  | ||||
| /* | ||||
|  *	Now round. | ||||
|  */ | ||||
| 	for(y=i=1; i < ndig; i++) | ||||
| 		y = y / 10.0;		/* Compute round amount	*/ | ||||
| 	x += (y / 2.0);			/* Round by 1/2 lsb	*/ | ||||
| 	if(x >= 10.0) 			/* Did we push it over 10? */ | ||||
| 	{ | ||||
| 	  x = 1.0; | ||||
| 	  ie++; | ||||
| 	} | ||||
| /* | ||||
|  *	Now convert result | ||||
|  */ | ||||
|  | ||||
| 	for(i=0; i<ndig; i++) | ||||
| 	{ | ||||
| 		k = x;				/* Truncate	*/ | ||||
| 		*str++ = k + '0';		/* ASCIIfy	*/ | ||||
| 		if(i == 0)			/* Locate decimal point*/ | ||||
| 			*str++ = '.'; | ||||
| 		x -= (y=k); | ||||
| 		x *= 10.0; | ||||
| 	} | ||||
| /* | ||||
|  *	Now output exponent | ||||
|  */ | ||||
| 	*str++ = 'E'; | ||||
| 	if(ie < 0) | ||||
| 	{ | ||||
| 		ie = -ie;			/* Negate	*/ | ||||
| 		*str++ = '-'; | ||||
| 	} | ||||
| 	*str++ = ie/10 + '0';			/* Drop in 1st digit*/ | ||||
| 	*str++ = ie%10 + '0';			/*     and 2nd digit*/ | ||||
| 	*str++ = '\0'; | ||||
| 	return(savstr); | ||||
| } | ||||
		Reference in New Issue
	
	Block a user