* harbour/contrib/libnf/at2.prg
* harbour/contrib/libnf/min2dhm.prg
* harbour/contrib/libnf/ontick.c
* harbour/contrib/libnf/sqzn.prg
* harbour/contrib/libnf/bytexor.prg
* harbour/contrib/libnf/asum.prg
* harbour/contrib/libnf/sleep.prg
* harbour/contrib/libnf/any2any.prg
* harbour/contrib/libnf/origin.c
* harbour/contrib/libnf/mouse.c
* harbour/contrib/libnf/stod.c
* harbour/contrib/libnf/vertmenu.prg
* harbour/contrib/libnf/aredit.prg
* harbour/contrib/libnf/n2color.c
* harbour/contrib/libnf/xbox.prg
* harbour/contrib/libnf/hex2dec.prg
* harbour/contrib/libnf/getver.c
* harbour/contrib/libnf/Makefile
* harbour/contrib/libnf/invclr.prg
* harbour/contrib/libnf/popadder.prg
* harbour/contrib/libnf/d2e.prg
* harbour/contrib/libnf/anomatch.prg
* harbour/contrib/libnf/color2n.c
* harbour/contrib/libnf/datecnfg.prg
* harbour/contrib/libnf/easter.prg
* harbour/contrib/libnf/ntow.prg
* harbour/contrib/libnf/floptst.prg
* harbour/contrib/libnf/pchr.prg
* harbour/contrib/libnf/tbwhile.prg
* harbour/contrib/libnf/e2d.prg
* harbour/contrib/libnf/sysmem.prg
* harbour/contrib/libnf/dfile.prg
* harbour/contrib/libnf/clrsel.prg
+ harbour/contrib/libnf/fttext.c
+ harbour/contrib/libnf/putkey.c
* basic cleanup and syncing with some of xHarbour fixes and extensions.
I'd like to ask Windows users to update non GNU make file
* harbour/source/pp/ppcore.c
+ added support for .T., .F., .Y., .N. in PP and #IF ... / #ELIF ...
expressions. It was reported by Nick Van Dyck on xHarbour devel list
that old PP supported it. I haven't known that old PP suported .T.
and .F. in #IF directive. Please not that there are other diferences
between new PP and the old one in expresions which can be used in
#IF ... / #ELIF directives. New PP supports C like expressions with
support for pseudo functions like defined(), operates on integer
numbers only to not damage 64bit values during conversion to double
and keep C compatible results (the old one used double values) and
is much more restrictive in checking for valid expression.
91 lines
2.1 KiB
Plaintext
91 lines
2.1 KiB
Plaintext
/*
|
|
* File......: D2E.PRG
|
|
* Author....: Gary Baren
|
|
* CIS ID....: 75470,1027
|
|
*
|
|
* This is an original work by Gary Baren and is hereby placed in the
|
|
* public domain.
|
|
*
|
|
* Modification history:
|
|
* ---------------------
|
|
*
|
|
* Rev 1.2 15 Aug 1991 23:05:02 GLENN
|
|
* Forest Belt proofread/edited/cleaned up doc
|
|
*
|
|
* Rev 1.1 14 Jun 1991 19:51:24 GLENN
|
|
* Minor edit to file header
|
|
*
|
|
* Rev 1.0 09 Jun 1991 00:27:06 GLENN
|
|
* Initial revision.
|
|
*
|
|
*/
|
|
|
|
|
|
/* $DOC$
|
|
* $FUNCNAME$
|
|
* FT_D2E()
|
|
* $CATEGORY$
|
|
* Conversion
|
|
* $ONELINER$
|
|
* Convert decimal to scientific notation
|
|
* $SYNTAX$
|
|
* FT_D2E( <nDec>, <nPrecision> ) -> <cNumE>
|
|
* $ARGUMENTS$
|
|
* <nDec> Decimal number to convert
|
|
*
|
|
* <nPrecision> Number of decimal places in result.
|
|
* Defaults to 6 decimal places.
|
|
* $RETURNS$
|
|
* <cNumE> A string representing a number in
|
|
* scientific notation
|
|
* $DESCRIPTION$
|
|
* Given a decimal number and the desired precision,
|
|
* a string representing the equivalent in scientific
|
|
* notation is returned.
|
|
* $EXAMPLES$
|
|
* ? FT_D2E( 12.345, 2 )
|
|
* -> 1.23E1
|
|
*
|
|
* ? FT_D2E( -12.345, 3 )
|
|
* -> -1.235E1
|
|
*
|
|
* ? FT_D2E( 0.00000543, 2 )
|
|
* -> 5.43E-6
|
|
* $SEEALSO$
|
|
* FT_E2D()
|
|
* $END$
|
|
*/
|
|
|
|
#define log10( num ) log( num ) / log( 10 )
|
|
#define DEFAULT_PRECISION 6
|
|
#command DEFAULT <p> TO <val> => <p> := iif( <p> == NIL, <val>, <p> )
|
|
|
|
#ifdef FT_TEST
|
|
function main( cNum, cPrec )
|
|
DEFAULT cPrec TO str( DEFAULT_PRECISION )
|
|
return qout( ft_d2e( val(cNum), val(cPrec) ) )
|
|
#endif
|
|
|
|
function ft_d2e( nDec, nPrecision )
|
|
local nExp, sScn
|
|
DEFAULT nPrecision TO DEFAULT_PRECISION
|
|
|
|
if nDec == 0
|
|
nExp := 0
|
|
elseif abs( nDec ) < 1
|
|
nExp := int( log10( nDec ) ) - 1
|
|
else
|
|
nExp := int( log10( abs(nDec)+0.00001 ) ) && 0.00001 == kludge
|
|
endif && for imprecise logs
|
|
|
|
nDec /= 10 ^ nExp
|
|
|
|
if round( abs(nDec), nPrecision ) >= 10
|
|
nDec /= 10
|
|
nExp++
|
|
endif another kludge for stuff like '999999999'
|
|
|
|
sScn := ltrim( str( nDec, nPrecision + 3, nPrecision ) )
|
|
return( sScn + 'E' + alltrim( str( nExp, 5, 0 ) ) )
|
|
|