syshelpf.inc 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235
  1. Class Function TFLOATHELPER.IsNan(const AValue: FLOATTYPE): Boolean; overload; inline; static;
  2. begin
  3. Result:=AValue=Nan;
  4. end;
  5. Class Function TFLOATHELPER.IsInfinity(const AValue: FLOATTYPE): Boolean; overload; inline; static;
  6. begin
  7. Result:=(AValue=PositiveInfinity) or (AValue=NegativeInfinity);
  8. end;
  9. Class Function TFLOATHELPER.IsNegativeInfinity(const AValue: FLOATTYPE): Boolean; overload; inline; static;
  10. begin
  11. Result:=AValue=NegativeInfinity;
  12. end;
  13. Class Function TFLOATHELPER.IsPositiveInfinity(const AValue: FLOATTYPE): Boolean; overload; inline; static;
  14. begin
  15. Result:=(AValue=PositiveInfinity);
  16. end;
  17. Class Function TFLOATHELPER.Parse(const AString: string): FLOATTYPE; overload; inline; static;
  18. begin
  19. Result:=StrToFloat(AString,DefaultFormatSettings);
  20. end;
  21. Class Function TFLOATHELPER.Parse(const AString: string; const AFormatSettings: TFormatSettings): FLOATTYPE; overload; inline; static;
  22. begin
  23. Result:=StrToFloat(AString,AFormatSettings);
  24. end;
  25. Class Function TFLOATHELPER.Size: Integer; inline; static;
  26. begin
  27. Result:=SizeOf(FLOATTYPE);
  28. end;
  29. Class Function TFLOATHELPER.ToString(const AValue: FLOATTYPE): string; overload; inline; static;
  30. begin
  31. Result:=FloatToStr(AValue,DefaultFormatSettings);
  32. end;
  33. Class Function TFLOATHELPER.ToString(const AValue: FLOATTYPE; const AFormatSettings: TFormatSettings): string; overload; inline; static;
  34. begin
  35. Result:=FloatToStr(AValue,AFormatSettings);
  36. end;
  37. Class Function TFLOATHELPER.ToString(const AValue: FLOATTYPE; const AFormat: TFloatFormat; const APrecision, ADigits: Integer): string; overload; inline; static;
  38. begin
  39. Result:=FloatToStrF(AValue,AFormat,APrecision,ADigits,DefaultFormatSettings);
  40. end;
  41. Class Function TFLOATHELPER.ToString(const AValue: FLOATTYPE; const AFormat: TFloatFormat; const APrecision, ADigits: Integer; const AFormatSettings: TFormatSettings): string;
  42. overload; inline; static;
  43. begin
  44. Result:=FloatToStrF(AValue,AFormat,APrecision,ADigits,AFormatSettings);
  45. end;
  46. Class Function TFLOATHELPER.TryParse(const AString: string; out AValue: FLOATTYPE): Boolean; overload; inline; static;
  47. begin
  48. Result:=TryStrToFloat(AString,AValue,DefaultFormatSettings);
  49. end;
  50. Class Function TFLOATHELPER.TryParse(const AString: string; out AValue: FLOATTYPE; const AFormatSettings: TFormatSettings): Boolean; overload; inline;
  51. static;
  52. begin
  53. Result:=TryStrToFloat(AString,AValue,AFormatSettings);
  54. end;
  55. Function TFLOATHELPER.GetB(AIndex: Cardinal): Byte;
  56. begin
  57. if (AIndex>=SizeOf(FLOATTYPE)) then
  58. system.Error(reRangeError);
  59. Result:=PByte(@Self)[AIndex];
  60. end;
  61. Function TFLOATHELPER.GetW(AIndex: Cardinal): Word;
  62. begin
  63. if (AIndex>=(SizeOf(FLOATTYPE) div SizeOf(Word))) then
  64. system.Error(reRangeError);
  65. Result:=PWord(@Self)[AIndex];
  66. end;
  67. Function TFLOATHELPER.GetE: QWord; inline;
  68. begin
  69. end;
  70. Function TFLOATHELPER.GetF: QWord; inline;
  71. begin
  72. end;
  73. Function TFLOATHELPER.GetS: Boolean; inline;
  74. begin
  75. end;
  76. procedure TFLOATHELPER.SetB(AIndex: Cardinal; const AValue: Byte);
  77. begin
  78. if (AIndex>=SizeOf(FLOATTYPE)) then
  79. system.Error(reRangeError);
  80. PByte(@Self)[AIndex]:=AValue;
  81. end;
  82. procedure TFLOATHELPER.SetW(AIndex: Cardinal; const AValue: Word);
  83. begin
  84. if (AIndex>=(SizeOf(FLOATTYPE) div SizeOf(Word))) then
  85. system.Error(reRangeError);
  86. PWord(@Self)[AIndex]:=AValue;
  87. end;
  88. procedure TFLOATHELPER.SetE(AValue: QWord);
  89. begin
  90. end;
  91. procedure TFLOATHELPER.SetF(AValue: QWord);
  92. begin
  93. end;
  94. procedure TFLOATHELPER.SetS(AValue: Boolean);
  95. begin
  96. end;
  97. Procedure TFLOATHELPER.BuildUp(const ASignFlag: Boolean; const AMantissa: QWord; const AExponent: Integer);
  98. begin
  99. Self := 0.0;
  100. SetS(ASignFlag);
  101. SetE(AExponent + $3FF);
  102. SetF(AMantissa and $000FFFFFFFFFFFFF);
  103. end;
  104. Function TFLOATHELPER.Exponent: Integer;
  105. var
  106. F,E : QWord;
  107. begin
  108. Result:=0; // Zero, inf, Nan
  109. E:=GetE;
  110. F:=GetF;
  111. if (0<E) and (E<$77FF) then
  112. Result:=E-$3FF
  113. else if (E=0) and (F<>0) then
  114. Result:=-1022
  115. end;
  116. Function TFLOATHELPER.Fraction: Extended;
  117. begin
  118. end;
  119. Function TFLOATHELPER.IsInfinity: Boolean; overload; inline;
  120. begin
  121. Result:=(Self=PositiveInfinity) or (Self=NegativeInfinity);
  122. end;
  123. Function TFLOATHELPER.IsNan: Boolean; overload; inline;
  124. begin
  125. Result:=(Self=Nan);
  126. end;
  127. Function TFLOATHELPER.IsNegativeInfinity: Boolean; overload; inline;
  128. begin
  129. Result:=(Self=NegativeInfinity);
  130. end;
  131. Function TFLOATHELPER.IsPositiveInfinity: Boolean; overload; inline;
  132. begin
  133. Result:=(Self=PositiveInfinity);
  134. end;
  135. Function TFLOATHELPER.Mantissa: QWord;
  136. begin
  137. end;
  138. Function TFLOATHELPER.SpecialType: TFloatSpecial;
  139. begin
  140. if IsNan then
  141. Result:=fsNan
  142. else if IsNegativeInfinity then
  143. Result:=fsNInf
  144. else if IsPositiveInfinity then
  145. Result:=fsInf
  146. end;
  147. Function TFLOATHELPER.ToString(const AFormat: TFloatFormat; const APrecision, ADigits: Integer): string; overload; inline;
  148. begin
  149. Result:=FloatToStrF(Self,AFormat,APrecision,ADigits,DefaultFormatSettings);
  150. end;
  151. Function TFLOATHELPER.ToString(const AFormat: TFloatFormat; const APrecision, ADigits: Integer; const AFormatSettings: TFormatSettings): string; overload; inline;
  152. begin
  153. Result:=FloatToStrF(Self,AFormat,APrecision,ADigits,AFormatSettings);
  154. end;
  155. Function TFLOATHELPER.ToString(const AFormatSettings: TFormatSettings): string; overload; inline;
  156. begin
  157. Result:=FloatToStr(Self,AFormatSettings);
  158. end;
  159. Function TFLOATHELPER.ToString: string; overload; inline;
  160. begin
  161. Result:=FloatToStr(Self,DefaultFormatSettings);
  162. end;