syshelpf.inc 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227
  1. Class Function TFLOATHELPER.IsNan(const AValue: FLOATTYPE): Boolean; overload; inline; static;
  2. begin
  3. Result:=TFloatRec(AValue).SpecialType=fsNan;
  4. end;
  5. Class Function TFLOATHELPER.IsInfinity(const AValue: FLOATTYPE): Boolean; overload; inline; static;
  6. begin
  7. Result:=TFloatRec(AValue).SpecialType in [fsInf,fsNinf];
  8. end;
  9. Class Function TFLOATHELPER.IsNegativeInfinity(const AValue: FLOATTYPE): Boolean; overload; inline; static;
  10. begin
  11. Result:=TFloatRec(AValue).SpecialType=fsNinf;
  12. end;
  13. Class Function TFLOATHELPER.IsPositiveInfinity(const AValue: FLOATTYPE): Boolean; overload; inline; static;
  14. begin
  15. Result:=TFloatRec(AValue).SpecialType=fsInf;
  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. Result:=TFloatRec(Self).Exp;
  70. end;
  71. Function TFLOATHELPER.GetF: QWord; inline;
  72. begin
  73. Result:=TFloatRec(Self).Frac;
  74. end;
  75. Function TFLOATHELPER.GetS: Boolean; inline;
  76. begin
  77. Result:=TFloatRec(Self).Sign;
  78. end;
  79. procedure TFLOATHELPER.SetB(AIndex: Cardinal; const AValue: Byte);
  80. begin
  81. if (AIndex>=SizeOf(FLOATTYPE)) then
  82. system.Error(reRangeError);
  83. PByte(@Self)[AIndex]:=AValue;
  84. end;
  85. procedure TFLOATHELPER.SetW(AIndex: Cardinal; const AValue: Word);
  86. begin
  87. if (AIndex>=(SizeOf(FLOATTYPE) div SizeOf(Word))) then
  88. system.Error(reRangeError);
  89. PWord(@Self)[AIndex]:=AValue;
  90. end;
  91. procedure TFLOATHELPER.SetE(AValue: QWord);
  92. begin
  93. TFloatRec(Self).Exp:=AValue;
  94. end;
  95. procedure TFLOATHELPER.SetF(AValue: QWord);
  96. begin
  97. TFloatRec(Self).Frac:=AValue;
  98. end;
  99. procedure TFLOATHELPER.SetS(AValue: Boolean);
  100. begin
  101. TFloatRec(Self).Sign:=AValue;
  102. end;
  103. Procedure TFLOATHELPER.BuildUp(const ASignFlag: Boolean; const AMantissa: QWord; const AExponent: Integer);
  104. begin
  105. TFloatRec(Self).BuildUp(ASignFlag, AMantissa, AExponent);
  106. end;
  107. Function TFLOATHELPER.Exponent: Integer;
  108. begin
  109. Result:=TFloatRec(Self).Exponent;
  110. end;
  111. Function TFLOATHELPER.Fraction: Extended;
  112. begin
  113. Result:=TFloatRec(Self).Fraction;
  114. end;
  115. Function TFLOATHELPER.IsInfinity: Boolean; overload; inline;
  116. begin
  117. Result:=TFloatRec(Self).SpecialType in [fsInf,fsNinf];
  118. end;
  119. Function TFLOATHELPER.IsNan: Boolean; overload; inline;
  120. begin
  121. Result:=TFloatRec(Self).SpecialType=fsNan;
  122. end;
  123. Function TFLOATHELPER.IsNegativeInfinity: Boolean; overload; inline;
  124. begin
  125. Result:=TFloatRec(Self).SpecialType=fsNinf;
  126. end;
  127. Function TFLOATHELPER.IsPositiveInfinity: Boolean; overload; inline;
  128. begin
  129. Result:=TFloatRec(Self).SpecialType=fsInf;
  130. end;
  131. Function TFLOATHELPER.Mantissa: QWord;
  132. begin
  133. Result:=TFLoatRec(Self).Mantissa(True);
  134. end;
  135. Function TFLOATHELPER.SpecialType: TFloatSpecial;
  136. begin
  137. Result:=TFLoatRec(Self).SpecialType;
  138. end;
  139. Function TFLOATHELPER.ToString(const AFormat: TFloatFormat; const APrecision, ADigits: Integer): string; overload; inline;
  140. begin
  141. Result:=FloatToStrF(Self,AFormat,APrecision,ADigits,DefaultFormatSettings);
  142. end;
  143. Function TFLOATHELPER.ToString(const AFormat: TFloatFormat; const APrecision, ADigits: Integer; const AFormatSettings: TFormatSettings): string; overload; inline;
  144. begin
  145. Result:=FloatToStrF(Self,AFormat,APrecision,ADigits,AFormatSettings);
  146. end;
  147. Function TFLOATHELPER.ToString(const AFormatSettings: TFormatSettings): string; overload; inline;
  148. begin
  149. Result:=FloatToStr(Self,AFormatSettings);
  150. end;
  151. Function TFLOATHELPER.ToString: string; overload; inline;
  152. begin
  153. Result:=FloatToStr(Self,DefaultFormatSettings);
  154. end;