@magic-xpa/gui 4.1100.0-dev4110.98 → 4.1100.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (195) hide show
  1. package/README.md +7 -7
  2. package/{esm2020 → esm2022}/index.mjs +71 -71
  3. package/{esm2020 → esm2022}/magic-xpa-gui.mjs +1 -1
  4. package/esm2022/src/Commands.mjs +184 -0
  5. package/esm2022/src/Events.mjs +425 -0
  6. package/{esm2020 → esm2022}/src/EventsProcessor.mjs +66 -66
  7. package/{esm2020 → esm2022}/src/FocusManager.mjs +33 -33
  8. package/esm2022/src/GuiConstants.mjs +68 -0
  9. package/{esm2020 → esm2022}/src/GuiEnums.mjs +301 -300
  10. package/esm2022/src/GuiEnvironment.mjs +4 -0
  11. package/{esm2020 → esm2022}/src/IFlowMonitorQueue.mjs +1 -1
  12. package/esm2022/src/Manager.mjs +91 -0
  13. package/esm2022/src/UIBridge.mjs +33 -0
  14. package/{esm2020 → esm2022}/src/env/IEnvironment.mjs +1 -1
  15. package/{esm2020 → esm2022}/src/gui/ControlBase.mjs +2 -2
  16. package/esm2022/src/gui/GuiMgControl.mjs +123 -0
  17. package/{esm2020 → esm2022}/src/gui/GuiMgForm.mjs +3 -3
  18. package/esm2022/src/gui/KeyboardItem.mjs +135 -0
  19. package/esm2022/src/gui/LastFocusedVal.mjs +11 -0
  20. package/esm2022/src/gui/MgValue.mjs +16 -0
  21. package/{esm2020 → esm2022}/src/gui/PropParentInterface.mjs +1 -1
  22. package/{esm2020 → esm2022}/src/gui/low/DialogHandler.mjs +6 -6
  23. package/esm2022/src/gui/low/GuiCommand.mjs +68 -0
  24. package/esm2022/src/gui/low/GuiCommandQueue.mjs +35 -0
  25. package/esm2022/src/gui/low/GuiInteractive.mjs +178 -0
  26. package/esm2022/src/gui/low/Style.mjs +20 -0
  27. package/esm2022/src/management/RuntimeContextBase.mjs +42 -0
  28. package/esm2022/src/management/data/BlobType.mjs +281 -0
  29. package/esm2022/src/management/data/DcValues.mjs +214 -0
  30. package/{esm2020 → esm2022}/src/management/data/DcValuesBuilderBase.mjs +95 -95
  31. package/esm2022/src/management/data/FieldDef.mjs +331 -0
  32. package/{esm2020 → esm2022}/src/management/data/FieldsTable.mjs +54 -54
  33. package/esm2022/src/management/data/GuiDataViewBase.mjs +88 -0
  34. package/esm2022/src/management/data/GuiFieldBase.mjs +82 -0
  35. package/{esm2020 → esm2022}/src/management/data/IRecord.mjs +1 -1
  36. package/{esm2020 → esm2022}/src/management/data/IReferencedObject.mjs +1 -1
  37. package/esm2022/src/management/data/NUM_TYPE.mjs +1739 -0
  38. package/esm2022/src/management/data/ObjectReferenceBase.mjs +48 -0
  39. package/esm2022/src/management/data/ObjectReferencesCollection.mjs +27 -0
  40. package/{esm2020 → esm2022}/src/management/data/RecordUtils.mjs +360 -360
  41. package/esm2022/src/management/data/VectorType.mjs +612 -0
  42. package/esm2022/src/management/data/VectorTypeBase.mjs +88 -0
  43. package/{esm2020 → esm2022}/src/management/events/IActionManager.mjs +1 -1
  44. package/{esm2020 → esm2022}/src/management/events/IGuiEventsManager.mjs +1 -1
  45. package/esm2022/src/management/exp/ExpressionInterface.mjs +244 -0
  46. package/esm2022/src/management/exp/GuiExpressionEvaluator.mjs +305 -0
  47. package/esm2022/src/management/gui/ControlTable.mjs +118 -0
  48. package/esm2022/src/management/gui/DisplayConvertor.mjs +1649 -0
  49. package/esm2022/src/management/gui/FieldValidator.mjs +711 -0
  50. package/esm2022/src/management/gui/GuiControlPropertyAdapter.mjs +24 -0
  51. package/{esm2020 → esm2022}/src/management/gui/GuiFormPropertyAdapter.mjs +10 -10
  52. package/esm2022/src/management/gui/HebrewDate.mjs +278 -0
  53. package/esm2022/src/management/gui/Helps.mjs +237 -0
  54. package/esm2022/src/management/gui/MgControlBase.mjs +1869 -0
  55. package/esm2022/src/management/gui/MgFormBase.mjs +741 -0
  56. package/esm2022/src/management/gui/PIC.mjs +1185 -0
  57. package/{esm2020 → esm2022}/src/management/gui/PropDefaults.mjs +229 -229
  58. package/{esm2020 → esm2022}/src/management/gui/PropInterface.mjs +246 -245
  59. package/esm2022/src/management/gui/PropTable.mjs +221 -0
  60. package/esm2022/src/management/gui/Property.mjs +1362 -0
  61. package/esm2022/src/management/gui/ValidationDetails.mjs +248 -0
  62. package/{esm2020 → esm2022}/src/management/gui/ValidationDetailsBase.mjs +93 -93
  63. package/{esm2020 → esm2022}/src/management/gui/WrongFormatException.mjs +29 -29
  64. package/esm2022/src/management/tasks/GuiDataCollection.mjs +4 -0
  65. package/esm2022/src/management/tasks/GuiTaskBase.mjs +511 -0
  66. package/{esm2020 → esm2022}/src/management/tasks/IMGDataTable.mjs +1 -1
  67. package/{esm2020 → esm2022}/src/management/tasks/ITask.mjs +1 -1
  68. package/esm2022/src/management/tasks/MgTimer.mjs +21 -0
  69. package/esm2022/src/management/tasks/TaskDefinitionId.mjs +54 -0
  70. package/{esm2020 → esm2022}/src/management/tasks/TaskDefinitionIdTableSaxHandler.mjs +41 -41
  71. package/{esm2020 → esm2022}/src/util/MemoryUtil.mjs +34 -34
  72. package/esm2022/src/util/ObjectReference.mjs +36 -0
  73. package/esm2022/src/util/UsernamePasswordCredentials.mjs +52 -0
  74. package/{fesm2020 → fesm2022}/magic-xpa-gui.mjs +16086 -16095
  75. package/fesm2022/magic-xpa-gui.mjs.map +1 -0
  76. package/index.d.ts +70 -70
  77. package/package.json +6 -12
  78. package/src/Commands.d.ts +40 -40
  79. package/src/Events.d.ts +157 -155
  80. package/src/EventsProcessor.d.ts +13 -13
  81. package/src/FocusManager.d.ts +8 -8
  82. package/src/GuiConstants.d.ts +65 -65
  83. package/src/GuiEnums.d.ts +283 -282
  84. package/src/GuiEnvironment.d.ts +4 -4
  85. package/src/IFlowMonitorQueue.d.ts +3 -3
  86. package/src/Manager.d.ts +26 -26
  87. package/src/UIBridge.d.ts +16 -16
  88. package/src/env/IEnvironment.d.ts +31 -31
  89. package/src/gui/ControlBase.d.ts +4 -4
  90. package/src/gui/GuiMgControl.d.ts +38 -38
  91. package/src/gui/GuiMgForm.d.ts +3 -3
  92. package/src/gui/KeyboardItem.d.ts +18 -18
  93. package/src/gui/LastFocusedVal.d.ts +7 -7
  94. package/src/gui/MgValue.d.ts +15 -15
  95. package/src/gui/PropParentInterface.d.ts +13 -13
  96. package/src/gui/low/DialogHandler.d.ts +4 -4
  97. package/src/gui/low/GuiCommand.d.ts +37 -37
  98. package/src/gui/low/GuiCommandQueue.d.ts +13 -13
  99. package/src/gui/low/GuiInteractive.d.ts +55 -55
  100. package/src/gui/low/Style.d.ts +19 -19
  101. package/src/management/RuntimeContextBase.d.ts +23 -23
  102. package/src/management/data/BlobType.d.ts +29 -29
  103. package/src/management/data/DcValues.d.ts +33 -33
  104. package/src/management/data/DcValuesBuilderBase.d.ts +17 -17
  105. package/src/management/data/FieldDef.d.ts +53 -53
  106. package/src/management/data/FieldsTable.d.ts +16 -16
  107. package/src/management/data/GuiDataViewBase.d.ts +27 -27
  108. package/src/management/data/GuiFieldBase.d.ts +17 -17
  109. package/src/management/data/IRecord.d.ts +12 -12
  110. package/src/management/data/IReferencedObject.d.ts +5 -5
  111. package/src/management/data/NUM_TYPE.d.ts +103 -103
  112. package/src/management/data/ObjectReferenceBase.d.ts +16 -16
  113. package/src/management/data/ObjectReferencesCollection.d.ts +10 -10
  114. package/src/management/data/RecordUtils.d.ts +21 -21
  115. package/src/management/data/VectorType.d.ts +52 -52
  116. package/src/management/data/VectorTypeBase.d.ts +8 -8
  117. package/src/management/events/IActionManager.d.ts +7 -7
  118. package/src/management/events/IGuiEventsManager.d.ts +20 -20
  119. package/src/management/exp/ExpressionInterface.d.ts +242 -242
  120. package/src/management/exp/GuiExpressionEvaluator.d.ts +47 -47
  121. package/src/management/gui/ControlTable.d.ts +28 -28
  122. package/src/management/gui/DisplayConvertor.d.ts +103 -103
  123. package/src/management/gui/FieldValidator.d.ts +35 -35
  124. package/src/management/gui/GuiControlPropertyAdapter.d.ts +40 -40
  125. package/src/management/gui/GuiFormPropertyAdapter.d.ts +17 -17
  126. package/src/management/gui/HebrewDate.d.ts +46 -46
  127. package/src/management/gui/Helps.d.ts +51 -51
  128. package/src/management/gui/MgControlBase.d.ts +225 -223
  129. package/src/management/gui/MgFormBase.d.ts +160 -160
  130. package/src/management/gui/PIC.d.ts +108 -108
  131. package/src/management/gui/PropDefaults.d.ts +7 -7
  132. package/src/management/gui/PropInterface.d.ts +244 -243
  133. package/src/management/gui/PropTable.d.ts +33 -33
  134. package/src/management/gui/Property.d.ts +121 -121
  135. package/src/management/gui/ValidationDetails.d.ts +52 -52
  136. package/src/management/gui/ValidationDetailsBase.d.ts +14 -14
  137. package/src/management/gui/WrongFormatException.d.ts +9 -9
  138. package/src/management/tasks/GuiDataCollection.d.ts +4 -4
  139. package/src/management/tasks/GuiTaskBase.d.ts +150 -150
  140. package/src/management/tasks/IMGDataTable.d.ts +10 -10
  141. package/src/management/tasks/ITask.d.ts +6 -6
  142. package/src/management/tasks/MgTimer.d.ts +8 -8
  143. package/src/management/tasks/TaskDefinitionId.d.ts +16 -16
  144. package/src/management/tasks/TaskDefinitionIdTableSaxHandler.d.ts +7 -7
  145. package/src/util/MemoryUtil.d.ts +6 -6
  146. package/src/util/ObjectReference.d.ts +9 -9
  147. package/src/util/UsernamePasswordCredentials.d.ts +18 -18
  148. package/esm2020/src/Commands.mjs +0 -184
  149. package/esm2020/src/Events.mjs +0 -420
  150. package/esm2020/src/GuiConstants.mjs +0 -68
  151. package/esm2020/src/GuiEnvironment.mjs +0 -4
  152. package/esm2020/src/Manager.mjs +0 -91
  153. package/esm2020/src/UIBridge.mjs +0 -32
  154. package/esm2020/src/gui/GuiMgControl.mjs +0 -125
  155. package/esm2020/src/gui/KeyboardItem.mjs +0 -135
  156. package/esm2020/src/gui/LastFocusedVal.mjs +0 -11
  157. package/esm2020/src/gui/MgValue.mjs +0 -16
  158. package/esm2020/src/gui/low/GuiCommand.mjs +0 -66
  159. package/esm2020/src/gui/low/GuiCommandQueue.mjs +0 -35
  160. package/esm2020/src/gui/low/GuiInteractive.mjs +0 -176
  161. package/esm2020/src/gui/low/Style.mjs +0 -20
  162. package/esm2020/src/management/RuntimeContextBase.mjs +0 -43
  163. package/esm2020/src/management/data/BlobType.mjs +0 -281
  164. package/esm2020/src/management/data/DcValues.mjs +0 -214
  165. package/esm2020/src/management/data/FieldDef.mjs +0 -331
  166. package/esm2020/src/management/data/GuiDataViewBase.mjs +0 -90
  167. package/esm2020/src/management/data/GuiFieldBase.mjs +0 -82
  168. package/esm2020/src/management/data/NUM_TYPE.mjs +0 -1741
  169. package/esm2020/src/management/data/ObjectReferenceBase.mjs +0 -48
  170. package/esm2020/src/management/data/ObjectReferencesCollection.mjs +0 -29
  171. package/esm2020/src/management/data/VectorType.mjs +0 -612
  172. package/esm2020/src/management/data/VectorTypeBase.mjs +0 -88
  173. package/esm2020/src/management/exp/ExpressionInterface.mjs +0 -244
  174. package/esm2020/src/management/exp/GuiExpressionEvaluator.mjs +0 -307
  175. package/esm2020/src/management/gui/ControlTable.mjs +0 -118
  176. package/esm2020/src/management/gui/DisplayConvertor.mjs +0 -1679
  177. package/esm2020/src/management/gui/FieldValidator.mjs +0 -711
  178. package/esm2020/src/management/gui/GuiControlPropertyAdapter.mjs +0 -22
  179. package/esm2020/src/management/gui/HebrewDate.mjs +0 -278
  180. package/esm2020/src/management/gui/Helps.mjs +0 -237
  181. package/esm2020/src/management/gui/MgControlBase.mjs +0 -1858
  182. package/esm2020/src/management/gui/MgFormBase.mjs +0 -741
  183. package/esm2020/src/management/gui/PIC.mjs +0 -1185
  184. package/esm2020/src/management/gui/PropTable.mjs +0 -221
  185. package/esm2020/src/management/gui/Property.mjs +0 -1356
  186. package/esm2020/src/management/gui/ValidationDetails.mjs +0 -248
  187. package/esm2020/src/management/tasks/GuiDataCollection.mjs +0 -4
  188. package/esm2020/src/management/tasks/GuiTaskBase.mjs +0 -510
  189. package/esm2020/src/management/tasks/MgTimer.mjs +0 -21
  190. package/esm2020/src/management/tasks/TaskDefinitionId.mjs +0 -54
  191. package/esm2020/src/util/ObjectReference.mjs +0 -36
  192. package/esm2020/src/util/UsernamePasswordCredentials.mjs +0 -52
  193. package/fesm2015/magic-xpa-gui.mjs +0 -16391
  194. package/fesm2015/magic-xpa-gui.mjs.map +0 -1
  195. package/fesm2020/magic-xpa-gui.mjs.map +0 -1
@@ -0,0 +1,1739 @@
1
+ import { Int32, NNumber, NString, NumberStyles, StringBuilder } from '@magic-xpa/mscorelib';
2
+ import { Constants, PICInterface, Randomizer, StorageAttribute, UtilStrByteMode } from '@magic-xpa/utils';
3
+ import { PIC } from '../gui/PIC';
4
+ import { Events } from '../../Events';
5
+ import { GuiEnvironment } from '../../GuiEnvironment';
6
+ export class NUM_TYPE {
7
+ static INT_ZERO_HEX = "00000000";
8
+ static NO_ROOM = -1;
9
+ static ZERO_FILL = -2;
10
+ static NUM_SIZE = 20;
11
+ static NUM_LONG_TYPE = -1;
12
+ static EXP_BIAS = 64;
13
+ static SIGN_MASK = -128;
14
+ COMMACHAR = ',';
15
+ DECIMALCHAR = '.';
16
+ SIGNIFICANT_NUM_SIZE = 0;
17
+ _data = new Int8Array(NUM_TYPE.NUM_SIZE);
18
+ set Data(value) {
19
+ this._data = value;
20
+ }
21
+ get Data() {
22
+ return this._data;
23
+ }
24
+ constructor(recordHexStrOrByteValOrDecStrOrNumFrom, offsetOrPic, lengthOrCompIdx) {
25
+ if (arguments.length === 0) {
26
+ this.constructor_0();
27
+ return;
28
+ }
29
+ if (arguments.length === 1 && (recordHexStrOrByteValOrDecStrOrNumFrom === null || recordHexStrOrByteValOrDecStrOrNumFrom.constructor === String)) {
30
+ this.constructor_1(recordHexStrOrByteValOrDecStrOrNumFrom);
31
+ return;
32
+ }
33
+ if (arguments.length === 3 && (recordHexStrOrByteValOrDecStrOrNumFrom === null || recordHexStrOrByteValOrDecStrOrNumFrom instanceof Int8Array) && (offsetOrPic === null || offsetOrPic.constructor === Number) && (lengthOrCompIdx === null || lengthOrCompIdx.constructor === Number)) {
34
+ this.constructor_2(recordHexStrOrByteValOrDecStrOrNumFrom, offsetOrPic, lengthOrCompIdx);
35
+ return;
36
+ }
37
+ if (arguments.length === 1 && (recordHexStrOrByteValOrDecStrOrNumFrom === null || recordHexStrOrByteValOrDecStrOrNumFrom instanceof Int8Array)) {
38
+ this.constructor_3(recordHexStrOrByteValOrDecStrOrNumFrom);
39
+ return;
40
+ }
41
+ if (arguments.length === 3 && (recordHexStrOrByteValOrDecStrOrNumFrom === null || recordHexStrOrByteValOrDecStrOrNumFrom.constructor === String) && (offsetOrPic === null || offsetOrPic instanceof PIC) && (lengthOrCompIdx === null || lengthOrCompIdx.constructor === Number)) {
42
+ this.constructor_4(recordHexStrOrByteValOrDecStrOrNumFrom, offsetOrPic, lengthOrCompIdx);
43
+ return;
44
+ }
45
+ this.constructor_5(recordHexStrOrByteValOrDecStrOrNumFrom);
46
+ }
47
+ constructor_0() {
48
+ this.initConst();
49
+ this.NUM_ZERO();
50
+ }
51
+ constructor_1(recordHexStr) {
52
+ let i = 0;
53
+ let twoDigits;
54
+ this.initConst();
55
+ try {
56
+ for (i = 0; i < this.SIGNIFICANT_NUM_SIZE; i = i + 1) {
57
+ twoDigits = recordHexStr.substr(i * 2, 2);
58
+ this._data[i] = NUM_TYPE.toSByte(NNumber.Parse(twoDigits, NumberStyles.HexNumber));
59
+ }
60
+ }
61
+ catch (ex) {
62
+ Events.WriteWarningToLog(ex);
63
+ this.NUM_ZERO();
64
+ }
65
+ }
66
+ constructor_2(byteVal, offset, length) {
67
+ this.constructor_0();
68
+ for (let i = 0; i < length; i = i + 1) {
69
+ this._data[i] = byteVal[i + offset];
70
+ }
71
+ }
72
+ constructor_3(byteVal) {
73
+ this.constructor_2(byteVal, 0, byteVal.length);
74
+ }
75
+ constructor_4(decStr, pic, compIdx) {
76
+ this.constructor_0();
77
+ this.from_a(decStr, pic, compIdx);
78
+ }
79
+ constructor_5(numFrom) {
80
+ this.initConst();
81
+ this._data = new Int8Array(numFrom._data.length);
82
+ for (let _ai = 0; _ai < this._data.length; ++_ai)
83
+ this._data[_ai] = numFrom._data[_ai];
84
+ }
85
+ toDisplayValue(pic) {
86
+ return this.to_a(pic);
87
+ }
88
+ initConst() {
89
+ let env = GuiEnvironment.Environment;
90
+ this.DECIMALCHAR = env.GetDecimal();
91
+ this.COMMACHAR = env.GetThousands();
92
+ this.SIGNIFICANT_NUM_SIZE = env.GetSignificantNumSize();
93
+ }
94
+ toXMLrecord() {
95
+ let hexStr = new StringBuilder(this.SIGNIFICANT_NUM_SIZE * 2);
96
+ let num;
97
+ if (this.NUM_IS_LONG())
98
+ num = 5;
99
+ else
100
+ num = this.SIGNIFICANT_NUM_SIZE;
101
+ for (let i = 0; i < this.SIGNIFICANT_NUM_SIZE; i++) {
102
+ if (i < num)
103
+ hexStr.Append(('0' + (this._data[i] & 0xFF).toString(16)).slice(-2));
104
+ else
105
+ hexStr.Append("00");
106
+ }
107
+ return hexStr.ToString().toUpperCase();
108
+ }
109
+ from_a(Alpha, pic, compIdx) {
110
+ let i;
111
+ let idx;
112
+ let dec;
113
+ let decs;
114
+ let digit;
115
+ let len;
116
+ let no_pic;
117
+ let Pos;
118
+ let SType;
119
+ let SPart;
120
+ let Signed;
121
+ let buf;
122
+ let mask = "";
123
+ let c;
124
+ let NgtvPrmt;
125
+ let Scan = "";
126
+ let Pbuf = "";
127
+ let is_negative;
128
+ let negStr;
129
+ let negPref;
130
+ let posPref;
131
+ let negSuff;
132
+ let posSuff;
133
+ let specialValNewPolicy = GuiEnvironment.Environment.GetSpecialValNewPolicy();
134
+ no_pic = (pic == null);
135
+ len = 0;
136
+ SType = false;
137
+ SPart = false;
138
+ if (!no_pic) {
139
+ mask = pic.getMask();
140
+ if (!specialValNewPolicy)
141
+ if (Alpha.length > pic.getMaskSize())
142
+ Alpha = Alpha.substr(0, pic.getMaskSize());
143
+ NgtvPrmt = pic.isNegative();
144
+ if (NgtvPrmt) {
145
+ negPref = pic.getNegPref_();
146
+ posPref = pic.getPosPref_();
147
+ negSuff = pic.getNegSuff_();
148
+ posSuff = pic.getPosSuff_();
149
+ if (negPref.length === posPref.length) {
150
+ if (negPref.length === 0 || negPref === posPref)
151
+ SPart = false;
152
+ else
153
+ SPart = true;
154
+ }
155
+ else
156
+ SPart = true;
157
+ if (SPart)
158
+ negStr = negPref;
159
+ else
160
+ negStr = negSuff;
161
+ if (negStr.length === 0)
162
+ SType = true;
163
+ else
164
+ SType = false;
165
+ if (SType)
166
+ Scan = (SPart ? posPref : posSuff);
167
+ else
168
+ Scan = (SPart ? negPref : negSuff);
169
+ len = Scan.length;
170
+ }
171
+ }
172
+ else {
173
+ pic = new PIC("", StorageAttribute.NUMERIC, compIdx);
174
+ NgtvPrmt = false;
175
+ }
176
+ dec = false;
177
+ decs = 0;
178
+ digit = 0;
179
+ Signed = 0;
180
+ for (idx = 0; idx < Alpha.length;) {
181
+ if (no_pic || (specialValNewPolicy && idx >= pic.getMaskSize()) || mask[idx] === String.fromCharCode(PICInterface.PIC_N)) {
182
+ c = Alpha[idx];
183
+ if (specialValNewPolicy) {
184
+ if (dec && decs === pic.getDec()) {
185
+ break;
186
+ }
187
+ }
188
+ if (UtilStrByteMode.isDigit(c)) {
189
+ digit++;
190
+ Pbuf += c;
191
+ if (dec)
192
+ decs++;
193
+ }
194
+ else if (c === this.DECIMALCHAR) {
195
+ Pbuf += this.DECIMALCHAR;
196
+ dec = true;
197
+ }
198
+ else if (c !== this.COMMACHAR) {
199
+ if (NgtvPrmt && Signed === 0) {
200
+ Signed = 1;
201
+ for (i = idx, Pos = 0; i <= Alpha.length && Pos < len; i++) {
202
+ if (no_pic || mask[i] === String.fromCharCode(PICInterface.PIC_N)) {
203
+ c = Alpha[i];
204
+ if (c !== Scan[Pos]) {
205
+ if (c === '-' && !SType)
206
+ break;
207
+ if (c === '+' && SType)
208
+ break;
209
+ Signed = -1;
210
+ break;
211
+ }
212
+ Pos++;
213
+ }
214
+ }
215
+ if (Pos > 0 && Pos < len)
216
+ Signed = -1;
217
+ }
218
+ else {
219
+ if (idx === 0) {
220
+ if (pic.getNegPref_().length > 0)
221
+ if (Alpha.startsWith(pic.getNegPref_())) {
222
+ idx += pic.getNegPref_().length;
223
+ continue;
224
+ }
225
+ if (pic.getPosPref_().length > 0)
226
+ if (Alpha.startsWith(pic.getPosPref_())) {
227
+ idx += pic.getPosPref_().length;
228
+ continue;
229
+ }
230
+ }
231
+ else {
232
+ if (pic.getNegSuff_().length > 0)
233
+ if (Alpha.endsWith(pic.getNegSuff_())) {
234
+ idx += pic.getNegSuff_().length;
235
+ continue;
236
+ }
237
+ if (pic.getPosSuff_().length > 0)
238
+ if (Alpha.endsWith(pic.getPosSuff_())) {
239
+ idx += pic.getPosSuff_().length;
240
+ continue;
241
+ }
242
+ }
243
+ }
244
+ }
245
+ }
246
+ idx++;
247
+ }
248
+ if (Signed === 0 && SType)
249
+ Signed = 1;
250
+ is_negative = (Signed === 1 && !SType) || (Signed !== 1 && SType);
251
+ if (decs > 0 || digit > 9) {
252
+ buf = (is_negative ? '-' : ' ') + Pbuf;
253
+ this.num_4_a_std(buf);
254
+ }
255
+ else
256
+ this.NUM_4_LONG((is_negative ? -1 : 1) * this.a_2_long(Pbuf));
257
+ }
258
+ num_4_a_std(str) {
259
+ let digstr = "";
260
+ let diglen = 0;
261
+ let wholes = 0;
262
+ let decs = 0;
263
+ let isDec = false;
264
+ let isminus = false;
265
+ let pos;
266
+ for (pos = 0; pos < str.length; pos++) {
267
+ let c = str.charAt(pos);
268
+ if (UtilStrByteMode.isDigit(c)) {
269
+ if (diglen > 0 || c !== '0') {
270
+ diglen++;
271
+ digstr = digstr + c;
272
+ if (!isDec)
273
+ wholes++;
274
+ }
275
+ else if (isDec)
276
+ decs = decs + 1;
277
+ }
278
+ else if (c === this.DECIMALCHAR)
279
+ isDec = true;
280
+ else if (c === '-')
281
+ isminus = true;
282
+ }
283
+ this.NUM_ZERO();
284
+ if (diglen === 0)
285
+ return;
286
+ if (((wholes + decs) & 1) > 0) {
287
+ this._data[1] = NUM_TYPE.toSByte(digstr.charCodeAt(0) - '0'.charCodeAt(0));
288
+ pos = 1;
289
+ }
290
+ else
291
+ pos = 0;
292
+ let numptr = 1 + pos;
293
+ diglen = Math.min(diglen, (this.SIGNIFICANT_NUM_SIZE - 1) * 2 - pos);
294
+ while (pos < diglen) {
295
+ let digit1 = NUM_TYPE.toSByte((digstr.charCodeAt(pos++) - '0'.charCodeAt(0)));
296
+ let digit2 = NUM_TYPE.toSByte(((pos < diglen)
297
+ ? (digstr.charCodeAt(pos++) - '0'.charCodeAt(0))
298
+ : '\0'.charCodeAt(0)));
299
+ this._data[numptr++] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(digit1) * 10 + NUM_TYPE.toUByte(digit2));
300
+ }
301
+ if (wholes > 0)
302
+ this._data[0] = NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + ((wholes + 1) >> 1));
303
+ else
304
+ this._data[0] = NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS - (decs >> 1));
305
+ if (isminus)
306
+ this._data[0] |= NUM_TYPE.SIGN_MASK;
307
+ }
308
+ NUM_4_LONG(longVal) {
309
+ let hexStr;
310
+ this.NUM_ZERO();
311
+ if (longVal !== 0) {
312
+ if (longVal < 0)
313
+ longVal = (0xFFFFFFFF + longVal + 1);
314
+ hexStr = longVal.toString(16);
315
+ if (longVal > 0)
316
+ hexStr = NUM_TYPE.INT_ZERO_HEX.substr(hexStr.length) + hexStr;
317
+ this._data[1] = NUM_TYPE.toSByte(parseInt(hexStr.substr(6, (8) - (6)), 16));
318
+ this._data[2] = NUM_TYPE.toSByte(parseInt(hexStr.substr(4, (6) - (4)), 16));
319
+ this._data[3] = NUM_TYPE.toSByte(parseInt(hexStr.substr(2, (4) - (2)), 16));
320
+ this._data[4] = NUM_TYPE.toSByte(parseInt(hexStr.substr(0, (2) - (0)), 16));
321
+ }
322
+ }
323
+ a_2_long(str) {
324
+ let n = 0;
325
+ for (let pos = 0; pos < str.length; pos++) {
326
+ if (UtilStrByteMode.isDigit(str.charAt(pos))) {
327
+ n = n * 10;
328
+ n = n + str.charCodeAt(pos) - '0'.charCodeAt(0);
329
+ }
330
+ }
331
+ return n;
332
+ }
333
+ to_a(pic) {
334
+ return this.to_a_pic(pic);
335
+ }
336
+ to_a_pic(pic) {
337
+ let buf = new Array(128);
338
+ let remains;
339
+ let sign_n;
340
+ let pref_len;
341
+ let suff_len;
342
+ let pref_str;
343
+ let suff_str;
344
+ let str_pos;
345
+ let str_len;
346
+ let out_pos;
347
+ let out_buf;
348
+ let tmp_out_buf;
349
+ let pad;
350
+ let left;
351
+ let pfill;
352
+ let mask_chars;
353
+ let len;
354
+ let res;
355
+ let i;
356
+ let isOut;
357
+ let outVal;
358
+ len = pic.getMaskSize();
359
+ sign_n = (pic.isNegative() && this.num_is_neg() ? false : true);
360
+ pref_len = (sign_n ? pic.getPosPref_().length : pic.getNegPref_().length);
361
+ suff_len = (sign_n ? pic.getPosSuff_().length : pic.getNegSuff_().length);
362
+ left = pic.isLeft();
363
+ pfill = pic.padFill();
364
+ mask_chars = pic.getMaskChars();
365
+ outVal = NString.ToCharArray(pic.getMask().substr(0, len));
366
+ out_buf = ((left || (mask_chars > 0)) ? buf : outVal);
367
+ if (left) {
368
+ for (i = 0; i < out_buf.length; i++)
369
+ out_buf[i] = '0'.toLowerCase();
370
+ }
371
+ isOut = ((left || (mask_chars > 0)) ? false : true);
372
+ str_pos = pref_len;
373
+ str_len = len - pref_len - suff_len;
374
+ tmp_out_buf = out_buf.slice(str_pos, out_buf.length);
375
+ if (this.NUM_IS_LONG())
376
+ remains = this.num_l_2_str(this.NUM_LONG(), tmp_out_buf, str_len, pic);
377
+ else
378
+ remains = this.to_str(tmp_out_buf, str_len, pic);
379
+ for (i = str_pos; i < out_buf.length; i++)
380
+ out_buf[i] = tmp_out_buf[i - str_pos];
381
+ tmp_out_buf = null;
382
+ if (remains < mask_chars) {
383
+ res = new Array(len);
384
+ for (i = 0; i < len; i++)
385
+ res[i] = (remains === NUM_TYPE.ZERO_FILL ? pic.getZeroPad() : '*');
386
+ return NString.FromChars(res);
387
+ }
388
+ if (mask_chars > 0) {
389
+ remains -= mask_chars;
390
+ str_pos += mask_chars;
391
+ str_len -= mask_chars;
392
+ }
393
+ if (pfill) {
394
+ pad = pic.getPad();
395
+ if (left) {
396
+ for (i = 0; i < remains; i++)
397
+ out_buf[str_pos + str_len + i] = pad;
398
+ str_pos += remains;
399
+ }
400
+ else {
401
+ for (i = 0; i < remains; i++)
402
+ out_buf[str_pos + i] = pad;
403
+ }
404
+ }
405
+ else {
406
+ pad = ' ';
407
+ str_pos += remains;
408
+ str_len -= remains;
409
+ }
410
+ if (suff_len > 0) {
411
+ suff_str = sign_n ? pic.getPosSuff_() : pic.getNegSuff_();
412
+ if (suff_len === 1)
413
+ out_buf[str_pos + str_len] = suff_str[0];
414
+ else {
415
+ for (i = 0; i < suff_len; i++)
416
+ out_buf[str_pos + str_len + i] = suff_str[i];
417
+ }
418
+ str_len += suff_len;
419
+ }
420
+ if (pref_len > 0) {
421
+ str_pos -= pref_len;
422
+ str_len += pref_len;
423
+ pref_str = sign_n ? pic.getPosPref_() : pic.getNegPref_();
424
+ if (pref_len === 1)
425
+ out_buf[str_pos] = pref_str[0];
426
+ else
427
+ for (i = 0; i < pref_len; i++)
428
+ out_buf[str_pos + i] = pref_str[i];
429
+ }
430
+ if (!pfill) {
431
+ let outBufLen = out_buf.length;
432
+ if (left) {
433
+ for (i = 0; i < remains && (str_pos + str_len + i < outBufLen); i++)
434
+ out_buf[str_pos + str_len + i] = pad;
435
+ }
436
+ else {
437
+ str_pos -= remains;
438
+ for (i = 0; i < remains && (str_pos + i < outBufLen); i++)
439
+ out_buf[str_pos + i] = pad;
440
+ }
441
+ }
442
+ if (isOut)
443
+ return NString.FromChars(out_buf);
444
+ if (mask_chars === 0) {
445
+ if (str_pos + len > out_buf.length)
446
+ len = out_buf.length - str_pos;
447
+ return NString.FromChars(out_buf, str_pos, len);
448
+ }
449
+ for (out_pos = 0; out_pos < len && str_pos < out_buf.length; out_pos++)
450
+ if (outVal[out_pos] === String.fromCharCode(PICInterface.PIC_N))
451
+ outVal[out_pos] = out_buf[str_pos++];
452
+ return NString.FromChars(outVal);
453
+ }
454
+ num_l_2_str(num, str, len, pic) {
455
+ let commas;
456
+ let digits;
457
+ let i;
458
+ let decs;
459
+ let j;
460
+ if (num < 0)
461
+ num = -num;
462
+ commas = pic.withComa();
463
+ decs = Math.min(pic.getDec(), len - 1);
464
+ if (decs > 0)
465
+ len -= (decs + 1);
466
+ i = len;
467
+ if (num === 0 && !pic.decInFirstPos()) {
468
+ if (pic.zeroFill())
469
+ return (NUM_TYPE.ZERO_FILL);
470
+ if (len === 0)
471
+ return (NUM_TYPE.NO_ROOM);
472
+ if (i > str.length)
473
+ i = str.length;
474
+ str[--i] = '0';
475
+ }
476
+ if (decs > 0) {
477
+ str[len] = this.DECIMALCHAR;
478
+ for (j = 0; j < decs; j++)
479
+ str[len + 1 + j] = '0';
480
+ }
481
+ digits = 0;
482
+ for (; num > 0; num = Math.floor(num / 10)) {
483
+ i--;
484
+ if (commas) {
485
+ if (digits === 3) {
486
+ if (i < 0)
487
+ return (NUM_TYPE.NO_ROOM);
488
+ digits = 0;
489
+ str[i--] = this.COMMACHAR;
490
+ }
491
+ digits++;
492
+ }
493
+ if (i < 0)
494
+ return (NUM_TYPE.NO_ROOM);
495
+ str[i] = ((num % 10).toString());
496
+ }
497
+ return i;
498
+ }
499
+ to_str(str, len, pic) {
500
+ let tmp;
501
+ let commas;
502
+ let digits;
503
+ let decpos;
504
+ let last;
505
+ let first;
506
+ let j;
507
+ let i;
508
+ let decs;
509
+ let num_char;
510
+ commas = pic.withComa();
511
+ decs = pic.getDec();
512
+ if (decs >= len)
513
+ decs = len - 1;
514
+ tmp = new NUM_TYPE(this);
515
+ tmp.round(decs);
516
+ if (tmp.NUM_IS_LONG())
517
+ return tmp.num_l_2_str(tmp.NUM_LONG(), str, len, pic);
518
+ if (pic.zeroFill() && tmp._data[0] === 0)
519
+ return (NUM_TYPE.ZERO_FILL);
520
+ i = len - 1;
521
+ digits = 0;
522
+ decpos = ((tmp._data[0] & ~NUM_TYPE.SIGN_MASK) - NUM_TYPE.EXP_BIAS + 1) * 2;
523
+ last = decpos - 1 + decs;
524
+ first = decpos - 1;
525
+ if (first > 2)
526
+ first = (tmp._data[1] < 10) ? 3 : 2;
527
+ for (j = last; j >= first; j--) {
528
+ if (i < 0)
529
+ return (NUM_TYPE.NO_ROOM);
530
+ if (commas && (j < decpos)) {
531
+ if (digits === 3) {
532
+ digits = 0;
533
+ str[i--] = this.COMMACHAR;
534
+ }
535
+ digits++;
536
+ }
537
+ if (i < 0)
538
+ return (NUM_TYPE.NO_ROOM);
539
+ if ((j < 2) || (j >= this.SIGNIFICANT_NUM_SIZE * 2))
540
+ str[i--] = '0';
541
+ else {
542
+ if (i < 0)
543
+ return (NUM_TYPE.NO_ROOM);
544
+ num_char = tmp._data[j >> 1];
545
+ str[i--] = (((j & 1) !== 0) ? (num_char % 10) : (Math.floor(num_char / 10))).toString();
546
+ }
547
+ if (j === decpos) {
548
+ if (i < 0)
549
+ return (NUM_TYPE.NO_ROOM);
550
+ str[i--] = this.DECIMALCHAR;
551
+ if (i < 0 && pic.decInFirstPos())
552
+ return (0);
553
+ }
554
+ }
555
+ return (i + 1);
556
+ }
557
+ static add(num1, num2) {
558
+ let sign1;
559
+ let sign2;
560
+ let l;
561
+ let l1;
562
+ let l2;
563
+ let SIGNIFICANT_NUM_SIZE;
564
+ if (num1 === null || num2 === null)
565
+ return null;
566
+ SIGNIFICANT_NUM_SIZE = GuiEnvironment.Environment.GetSignificantNumSize();
567
+ let tmpres = new NUM_TYPE();
568
+ let res = new NUM_TYPE();
569
+ let operData = new OperData();
570
+ if (num1.NUM_IS_LONG()) {
571
+ if (num2.NUM_IS_LONG()) {
572
+ l = l1 = num1.NUM_LONG();
573
+ if (l < 0)
574
+ l = -l;
575
+ if (l < 0x40000000) {
576
+ l = l2 = num2.NUM_LONG();
577
+ if (l < 0)
578
+ l = -l;
579
+ if (l < 0x40000000) {
580
+ l1 += l2;
581
+ res.NUM_4_LONG(l1);
582
+ return res;
583
+ }
584
+ }
585
+ num2.num_4_std_long();
586
+ }
587
+ num1.num_4_std_long();
588
+ }
589
+ else if (num2.NUM_IS_LONG())
590
+ num2.num_4_std_long();
591
+ sign1 = NUM_TYPE.toSByte(num1._data[0] & NUM_TYPE.SIGN_MASK);
592
+ operData.NUM_Exp1_ = NUM_TYPE.toSByte(num1._data[0] & ~NUM_TYPE.SIGN_MASK);
593
+ sign2 = NUM_TYPE.toSByte(num2._data[0] & NUM_TYPE.SIGN_MASK);
594
+ operData.NUM_Exp2_ = NUM_TYPE.toSByte(num2._data[0] & ~NUM_TYPE.SIGN_MASK);
595
+ operData.NUM_Diff_ = (operData.NUM_Exp1_ - operData.NUM_Exp2_);
596
+ let cmpval = operData.NUM_Diff_;
597
+ if (cmpval === 0) {
598
+ cmpval = NUM_TYPE.toUByte(num1._data[1]) - NUM_TYPE.toUByte(num2._data[1]);
599
+ if (cmpval === 0)
600
+ cmpval = NUM_TYPE.memcmp(num1, 2, num2, 2, SIGNIFICANT_NUM_SIZE - 2);
601
+ }
602
+ if (cmpval >= 0) {
603
+ if (sign1 === sign2)
604
+ tmpres = NUM_TYPE.add_pos(num1, num2, operData);
605
+ else
606
+ tmpres = NUM_TYPE.sub_pos(num1, num2, operData);
607
+ if (tmpres._data[0] !== 0)
608
+ tmpres._data[0] = NUM_TYPE.toSByte(tmpres._data[0] | sign1);
609
+ }
610
+ else {
611
+ let exp = operData.NUM_Exp1_;
612
+ operData.NUM_Exp1_ = operData.NUM_Exp2_;
613
+ operData.NUM_Exp2_ = exp;
614
+ operData.NUM_Diff_ = -operData.NUM_Diff_;
615
+ if (sign1 === sign2)
616
+ tmpres = NUM_TYPE.add_pos(num2, num1, operData);
617
+ else
618
+ tmpres = NUM_TYPE.sub_pos(num2, num1, operData);
619
+ if (tmpres._data[0] !== 0)
620
+ tmpres._data[0] |= sign2;
621
+ }
622
+ return tmpres;
623
+ }
624
+ static sub(num1, num2) {
625
+ if (num1 === null || num2 === null)
626
+ return null;
627
+ let tmpres = new NUM_TYPE();
628
+ let res = new NUM_TYPE();
629
+ let operData = new OperData();
630
+ if (num1.NUM_IS_LONG()) {
631
+ if (num2.NUM_IS_LONG()) {
632
+ let l;
633
+ let l1 = l = num1.NUM_LONG();
634
+ if (l < 0)
635
+ l = -l;
636
+ if (l < 0x40000000) {
637
+ let l2 = l = num2.NUM_LONG();
638
+ if (l < 0)
639
+ l = -l;
640
+ if (l < 0x40000000) {
641
+ l1 -= l2;
642
+ res.NUM_4_LONG(l1);
643
+ return res;
644
+ }
645
+ }
646
+ num2.num_4_std_long();
647
+ }
648
+ num1.num_4_std_long();
649
+ }
650
+ else if (num2.NUM_IS_LONG())
651
+ num2.num_4_std_long();
652
+ let sign1 = NUM_TYPE.toSByte(num1._data[0] & NUM_TYPE.SIGN_MASK);
653
+ operData.NUM_Exp1_ = NUM_TYPE.toSByte(num1._data[0] & ~NUM_TYPE.SIGN_MASK);
654
+ let sign2 = NUM_TYPE.toSByte(num2._data[0] & NUM_TYPE.SIGN_MASK);
655
+ operData.NUM_Exp2_ = NUM_TYPE.toSByte(num2._data[0] & ~NUM_TYPE.SIGN_MASK);
656
+ operData.NUM_Diff_ = (operData.NUM_Exp1_ - operData.NUM_Exp2_);
657
+ let cmpval = operData.NUM_Diff_;
658
+ if (cmpval === 0) {
659
+ cmpval = NUM_TYPE.toUByte(num1._data[1]) - NUM_TYPE.toUByte(num2._data[1]);
660
+ if (cmpval === 0)
661
+ cmpval = NUM_TYPE.memcmp(num1, 2, num2, 2, GuiEnvironment.Environment.GetSignificantNumSize() - 2);
662
+ }
663
+ if (cmpval >= 0) {
664
+ if (sign1 === sign2)
665
+ tmpres = NUM_TYPE.sub_pos(num1, num2, operData);
666
+ else
667
+ tmpres = NUM_TYPE.add_pos(num1, num2, operData);
668
+ }
669
+ else {
670
+ let exp = operData.NUM_Exp1_;
671
+ operData.NUM_Exp1_ = operData.NUM_Exp2_;
672
+ operData.NUM_Exp2_ = exp;
673
+ operData.NUM_Diff_ = -operData.NUM_Diff_;
674
+ if (sign1 === sign2) {
675
+ tmpres = NUM_TYPE.sub_pos(num2, num1, operData);
676
+ sign1 ^= (NUM_TYPE.SIGN_MASK);
677
+ }
678
+ else
679
+ tmpres = NUM_TYPE.add_pos(num2, num1, operData);
680
+ }
681
+ if (tmpres._data[0] !== 0)
682
+ tmpres._data[0] |= sign1;
683
+ return tmpres;
684
+ }
685
+ static mul(num1, num2) {
686
+ let fullres = new Int8Array(38);
687
+ let pwr;
688
+ let len1;
689
+ let len2;
690
+ let pos1;
691
+ let pos2;
692
+ let pos;
693
+ let digit1;
694
+ let prod;
695
+ let carry;
696
+ let l;
697
+ let l1;
698
+ let l2;
699
+ let SIGNIFICANT_NUM_SIZE;
700
+ if (num1 === null || num2 === null)
701
+ return null;
702
+ SIGNIFICANT_NUM_SIZE = GuiEnvironment.Environment.GetSignificantNumSize();
703
+ let res = new NUM_TYPE();
704
+ let operData = new OperData();
705
+ let i;
706
+ let tmpByte;
707
+ if (num1.NUM_IS_LONG()) {
708
+ if (num2.NUM_IS_LONG()) {
709
+ l = l1 = num1.NUM_LONG();
710
+ if (l < 0)
711
+ l = -l;
712
+ if (l < 0xB000) {
713
+ l = l2 = num2.NUM_LONG();
714
+ if (l < 0)
715
+ l = -l;
716
+ if (l < 0xB000) {
717
+ l1 = l1 * l2;
718
+ res.NUM_4_LONG(l1);
719
+ return res;
720
+ }
721
+ }
722
+ num2.num_4_std_long();
723
+ }
724
+ num1.num_4_std_long();
725
+ }
726
+ else if (num2.NUM_IS_LONG())
727
+ num2.num_4_std_long();
728
+ operData.NUM_Exp1_ = NUM_TYPE.toSByte(num1._data[0] & ~NUM_TYPE.SIGN_MASK);
729
+ operData.NUM_Exp2_ = NUM_TYPE.toSByte(num2._data[0] & ~NUM_TYPE.SIGN_MASK);
730
+ if (operData.NUM_Exp1_ === 0 || operData.NUM_Exp2_ === 0) {
731
+ res.NUM_ZERO();
732
+ return res;
733
+ }
734
+ for (len1 = SIGNIFICANT_NUM_SIZE - 1; num1._data[len1] === 0; len1--) {
735
+ }
736
+ for (len2 = SIGNIFICANT_NUM_SIZE - 1; num2._data[len2] === 0; len2--) {
737
+ }
738
+ for (i = 0; i < (NUM_TYPE.NUM_SIZE - 1) * 2; i++)
739
+ fullres[i] = 0;
740
+ pos = 0;
741
+ for (pos1 = len1; pos1 > 0; pos1--) {
742
+ pos = pos1 + len2 - 1;
743
+ digit1 = num1._data[pos1];
744
+ carry = 0;
745
+ for (pos2 = len2; pos2 > 0; pos2--) {
746
+ prod = NUM_TYPE.toUByte(digit1) * NUM_TYPE.toUByte(num2._data[pos2]) + carry;
747
+ carry = Math.floor(prod / 100);
748
+ fullres[pos] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(fullres[pos]) + prod % 100);
749
+ tmpByte = fullres[pos];
750
+ pos--;
751
+ if (NUM_TYPE.toUByte(tmpByte) >= 100) {
752
+ fullres[pos + 1] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(fullres[pos + 1]) - 100);
753
+ carry++;
754
+ }
755
+ }
756
+ fullres[pos] = NUM_TYPE.toSByte(carry);
757
+ }
758
+ pwr = NUM_TYPE.toUByte(operData.NUM_Exp1_) - NUM_TYPE.EXP_BIAS + (NUM_TYPE.toUByte(operData.NUM_Exp2_) - NUM_TYPE.EXP_BIAS);
759
+ if (fullres[0] === 0) {
760
+ pos++;
761
+ pwr--;
762
+ }
763
+ if ((num1._data[0] & NUM_TYPE.SIGN_MASK) === (num2._data[0] & NUM_TYPE.SIGN_MASK))
764
+ res._data[0] = 0;
765
+ else
766
+ res._data[0] = NUM_TYPE.SIGN_MASK;
767
+ res._data[0] |= NUM_TYPE.toSByte(pwr + NUM_TYPE.EXP_BIAS);
768
+ for (i = 0; i < SIGNIFICANT_NUM_SIZE - 1; i++)
769
+ res._data[1 + i] = fullres[pos + i];
770
+ return res;
771
+ }
772
+ static mod(num1, num2) {
773
+ if (num1 === null || num2 === null)
774
+ return null;
775
+ let res = new NUM_TYPE();
776
+ if (num2.num_is_zero()) {
777
+ res.NUM_ZERO();
778
+ return res;
779
+ }
780
+ if (num1.NUM_IS_LONG())
781
+ num1.num_4_std_long();
782
+ if (num2.NUM_IS_LONG())
783
+ num2.num_4_std_long();
784
+ res = NUM_TYPE.div(num1, num2);
785
+ res.num_trunc(0);
786
+ res = NUM_TYPE.mul(res, num2);
787
+ res = NUM_TYPE.sub(num1, res);
788
+ return res;
789
+ }
790
+ static div(num1, num2) {
791
+ let dividend = new Int8Array((NUM_TYPE.NUM_SIZE - 1) * 2);
792
+ let divisor = new Int8Array(NUM_TYPE.NUM_SIZE);
793
+ let pwr;
794
+ let len1;
795
+ let len2;
796
+ let pos1;
797
+ let pos2;
798
+ let pos;
799
+ let quot;
800
+ let prod;
801
+ let carry;
802
+ let SIGNIFICANT_NUM_SIZE;
803
+ if (num1 === null || num2 === null)
804
+ return null;
805
+ SIGNIFICANT_NUM_SIZE = GuiEnvironment.Environment.GetSignificantNumSize();
806
+ let res = new NUM_TYPE();
807
+ let operData = new OperData();
808
+ let i;
809
+ let tmpByte;
810
+ if (num1.NUM_IS_LONG())
811
+ num1.num_4_std_long();
812
+ if (num2.NUM_IS_LONG())
813
+ num2.num_4_std_long();
814
+ operData.NUM_Exp1_ = NUM_TYPE.toSByte(num1._data[0] & ~NUM_TYPE.SIGN_MASK);
815
+ operData.NUM_Exp2_ = NUM_TYPE.toSByte(num2._data[0] & ~NUM_TYPE.SIGN_MASK);
816
+ if (operData.NUM_Exp1_ === 0 || operData.NUM_Exp2_ === 0) {
817
+ res.NUM_ZERO();
818
+ return res;
819
+ }
820
+ for (len1 = SIGNIFICANT_NUM_SIZE - 1; num1._data[len1] === 0; len1--) {
821
+ }
822
+ for (len2 = SIGNIFICANT_NUM_SIZE - 1; num2._data[len2] === 0; len2--) {
823
+ }
824
+ pos = (NUM_TYPE.memcmp(num1, 1, num2, 1, len2) < 0) ? 0 : 1;
825
+ for (i = 0; i < (NUM_TYPE.NUM_SIZE - 1) * 2; i++)
826
+ dividend[i] = 0;
827
+ for (i = 0; i < len1; i++)
828
+ dividend[pos + i] = num1._data[1 + i];
829
+ for (i = 0; i < len2; i++)
830
+ divisor[1 + i] = num2._data[1 + i];
831
+ res.NUM_SET_ZERO();
832
+ pwr = NUM_TYPE.toUByte(operData.NUM_Exp1_) - NUM_TYPE.toUByte(operData.NUM_Exp2_) + pos;
833
+ res._data[0] = NUM_TYPE.toSByte(pwr + NUM_TYPE.EXP_BIAS);
834
+ if ((num1._data[0] & NUM_TYPE.SIGN_MASK) !== (num2._data[0] & NUM_TYPE.SIGN_MASK))
835
+ res._data[0] |= NUM_TYPE.SIGN_MASK;
836
+ quot = Math.floor(100 / (NUM_TYPE.toUByte(divisor[1]) + 1));
837
+ if (quot > 1) {
838
+ carry = 0;
839
+ for (pos2 = len2; pos2 > 0; pos2--) {
840
+ prod = quot * NUM_TYPE.toUByte(divisor[pos2]) + carry;
841
+ carry = Math.floor(prod / 100);
842
+ divisor[pos2] = NUM_TYPE.toSByte(prod % 100);
843
+ }
844
+ carry = 0;
845
+ for (pos1 = len1 + pos - 1; pos1 >= 0; pos1--) {
846
+ prod = quot * NUM_TYPE.toUByte(dividend[pos1]) + carry;
847
+ carry = Math.floor(prod / 100);
848
+ dividend[pos1] = NUM_TYPE.toSByte(prod % 100);
849
+ }
850
+ }
851
+ for (pos1 = 1; pos1 < SIGNIFICANT_NUM_SIZE; pos1++) {
852
+ quot = NUM_TYPE.toUByte(dividend[pos1 - 1]) * 100 + Math.floor(NUM_TYPE.toUByte(dividend[pos1]) / NUM_TYPE.toUByte(divisor[1]));
853
+ if (quot >= 100)
854
+ quot = 99;
855
+ if (quot !== 0) {
856
+ pos = pos1 + len2 - 1;
857
+ carry = 0;
858
+ for (pos2 = len2; pos2 > 0; pos2--) {
859
+ prod = quot * NUM_TYPE.toUByte(divisor[pos2]) + carry;
860
+ carry = Math.floor(prod / 100);
861
+ dividend[pos] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(dividend[pos]) - prod % 100);
862
+ tmpByte = dividend[pos];
863
+ pos--;
864
+ if (tmpByte < 0) {
865
+ dividend[pos + 1] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(dividend[pos + 1]) + 100);
866
+ carry++;
867
+ }
868
+ }
869
+ dividend[pos] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(dividend[pos]) - carry);
870
+ while (dividend[pos] < 0) {
871
+ quot--;
872
+ pos = pos1 + len2 - 1;
873
+ for (pos2 = len2; pos2 > 0; pos2--) {
874
+ dividend[pos] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(dividend[pos]) + NUM_TYPE.toUByte(divisor[pos2]));
875
+ tmpByte = dividend[pos];
876
+ pos--;
877
+ if (NUM_TYPE.toUByte(tmpByte) >= 100) {
878
+ dividend[pos + 1] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(dividend[pos + 1]) - 100);
879
+ dividend[pos] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(dividend[pos]) + 1);
880
+ }
881
+ }
882
+ }
883
+ }
884
+ res._data[pos1] = NUM_TYPE.toSByte(quot);
885
+ }
886
+ return res;
887
+ }
888
+ static num_cmp(num1, num2) {
889
+ let sign1;
890
+ let sign2;
891
+ let cmpval;
892
+ let l1;
893
+ let l2;
894
+ let tmp;
895
+ let SIGNIFICANT_NUM_SIZE;
896
+ if (num1 == null || num2 == null)
897
+ return Int32.MinValue;
898
+ SIGNIFICANT_NUM_SIZE = GuiEnvironment.Environment.GetSignificantNumSize();
899
+ if (num1.NUM_IS_LONG()) {
900
+ if (num2.NUM_IS_LONG()) {
901
+ l1 = num1.NUM_LONG();
902
+ l2 = num2.NUM_LONG();
903
+ if (l1 >= 0 && l2 >= 0) {
904
+ tmp = l1 - l2;
905
+ if (tmp === 0)
906
+ return (0);
907
+ if (tmp > 0)
908
+ return (1);
909
+ return (-1);
910
+ }
911
+ num2.num_4_std_long();
912
+ }
913
+ num1.num_4_std_long();
914
+ }
915
+ else if (num2.NUM_IS_LONG())
916
+ num2.num_4_std_long();
917
+ sign1 = NUM_TYPE.toSByte(num1._data[0] & NUM_TYPE.SIGN_MASK);
918
+ sign2 = NUM_TYPE.toSByte(num2._data[0] & NUM_TYPE.SIGN_MASK);
919
+ cmpval = (sign1 === sign2)
920
+ ? NUM_TYPE.memcmp(num1, 0, num2, 0, SIGNIFICANT_NUM_SIZE)
921
+ : 1;
922
+ if (sign1 !== 0)
923
+ cmpval = -cmpval;
924
+ return (cmpval);
925
+ }
926
+ static numHexStrIsLong(numHexStr) {
927
+ return numHexStr.substr(0, 2) === "FF";
928
+ }
929
+ NUM_ZERO() {
930
+ this.setZero(true);
931
+ }
932
+ NUM_SET_ZERO() {
933
+ this.setZero(false);
934
+ }
935
+ num_is_neg() {
936
+ if (this.NUM_IS_LONG())
937
+ return ((this._data[4] & 0x80) !== 0);
938
+ return ((this._data[0] & NUM_TYPE.SIGN_MASK) !== 0);
939
+ }
940
+ num_is_zero() {
941
+ if (this.NUM_IS_LONG())
942
+ return (this.NUM_LONG() === 0);
943
+ return (this._data[0] === 0);
944
+ }
945
+ num_neg() {
946
+ let l;
947
+ if (this.NUM_IS_LONG()) {
948
+ l = -this.NUM_LONG();
949
+ this.NUM_4_LONG(l);
950
+ return;
951
+ }
952
+ if (this._data[0] !== 0)
953
+ this._data[0] ^= NUM_TYPE.SIGN_MASK;
954
+ }
955
+ NUM_IS_LONG() {
956
+ return this._data[0] === NUM_TYPE.NUM_LONG_TYPE;
957
+ }
958
+ NUM_LONG() {
959
+ if (this._data[1] === 0 && this._data[2] === 0 && this._data[3] === 0 && this._data[4] === -128)
960
+ return Int32.MinValue;
961
+ let dataview = new DataView(this._data.buffer);
962
+ return dataview.getInt32(1, true);
963
+ }
964
+ round(decs) {
965
+ let addval;
966
+ if (this.NUM_IS_LONG())
967
+ return;
968
+ addval = new NUM_TYPE();
969
+ addval._data[0] = NUM_TYPE.toSByte((this._data[0] & NUM_TYPE.SIGN_MASK) | (NUM_TYPE.EXP_BIAS - (decs >> 1)));
970
+ addval._data[1] = NUM_TYPE.toSByte((decs & 1) !== 0 ? 5 : 50);
971
+ let temp = NUM_TYPE.add(this, addval);
972
+ this._data = new Int8Array(temp._data.length);
973
+ this._data = temp._data;
974
+ this.num_trunc(decs);
975
+ }
976
+ dbRound(whole) {
977
+ let addval;
978
+ let pwr;
979
+ let num_diff;
980
+ let i;
981
+ if (this.NUM_IS_LONG())
982
+ return;
983
+ addval = new NUM_TYPE();
984
+ addval._data[0] = NUM_TYPE.toSByte((this._data[0] & NUM_TYPE.SIGN_MASK) | (NUM_TYPE.EXP_BIAS + ((whole + 1) >> 1)));
985
+ addval._data[1] = NUM_TYPE.toSByte(((whole & 1) !== 0) ? 5 : 50);
986
+ let temp = NUM_TYPE.add(this, addval);
987
+ this._data = new Int8Array(temp._data.length);
988
+ for (let _ai = 0; _ai < this._data.length; ++_ai)
989
+ this._data[_ai] = temp._data[_ai];
990
+ pwr = (this._data[0] & ~NUM_TYPE.SIGN_MASK) - NUM_TYPE.EXP_BIAS;
991
+ if ((num_diff = pwr - ((whole + 1) >> 1)) >= 0) {
992
+ if ((whole & 1) !== 0) {
993
+ this._data[1 + num_diff] = NUM_TYPE.toSByte(this._data[1 + num_diff] - this._data[1 + num_diff] % 10);
994
+ num_diff++;
995
+ }
996
+ for (i = 0; i < this.SIGNIFICANT_NUM_SIZE - (1 + num_diff); i++)
997
+ this._data[1 + num_diff + i] = 0;
998
+ }
999
+ else
1000
+ this.NUM_SET_ZERO();
1001
+ }
1002
+ num_trunc(decs) {
1003
+ let pwr;
1004
+ let num_diff;
1005
+ let i;
1006
+ if (this.NUM_IS_LONG())
1007
+ return;
1008
+ pwr = (this._data[0] & ~NUM_TYPE.SIGN_MASK) - NUM_TYPE.EXP_BIAS;
1009
+ if ((num_diff = this.SIGNIFICANT_NUM_SIZE - 1 - pwr - ((decs + 1) >> 1)) < 0)
1010
+ return;
1011
+ if ((num_diff < this.SIGNIFICANT_NUM_SIZE - 1) && ((decs & 1) !== 0)) {
1012
+ this._data[this.SIGNIFICANT_NUM_SIZE - 1 - num_diff] =
1013
+ NUM_TYPE.toSByte(this._data[this.SIGNIFICANT_NUM_SIZE - 1 - num_diff] - this._data[this.SIGNIFICANT_NUM_SIZE - 1 - num_diff] % 10);
1014
+ if (this._data[this.SIGNIFICANT_NUM_SIZE - 1 - num_diff] === 0)
1015
+ num_diff++;
1016
+ }
1017
+ if (num_diff >= this.SIGNIFICANT_NUM_SIZE - 1) {
1018
+ this.NUM_ZERO();
1019
+ return;
1020
+ }
1021
+ for (i = 0; i < num_diff; i++)
1022
+ this._data[this.SIGNIFICANT_NUM_SIZE - num_diff + i] = 0;
1023
+ }
1024
+ num_4_std_long() {
1025
+ let slong;
1026
+ slong = this.NUM_LONG();
1027
+ if (slong >= 0)
1028
+ this.num_4_ulong(slong);
1029
+ else {
1030
+ this.num_4_ulong(-slong);
1031
+ this._data[0] |= NUM_TYPE.SIGN_MASK;
1032
+ }
1033
+ }
1034
+ num_4_ulong(data) {
1035
+ let pwr;
1036
+ let pos;
1037
+ let i;
1038
+ this.NUM_SET_ZERO();
1039
+ pos = pwr = 5;
1040
+ while (data > 0) {
1041
+ this._data[pos--] = NUM_TYPE.toSByte(data % 100);
1042
+ data = Math.floor(data / 100);
1043
+ }
1044
+ if (pos < pwr) {
1045
+ if (pos > 0) {
1046
+ for (i = 0; i < pwr - pos; i++)
1047
+ this._data[1 + i] = this._data[1 + pos + i];
1048
+ for (i = 0; i < pos; i++)
1049
+ this._data[pwr - pos + 1 + i] = 0;
1050
+ }
1051
+ this._data[0] = NUM_TYPE.toSByte(pwr - pos + NUM_TYPE.EXP_BIAS);
1052
+ }
1053
+ }
1054
+ NUM_2_LONG() {
1055
+ if (this.NUM_IS_LONG())
1056
+ return this.NUM_LONG();
1057
+ else
1058
+ return this.num_2_long();
1059
+ }
1060
+ NUM_2_ULONG() {
1061
+ if (this.NUM_IS_LONG())
1062
+ return this.NUM_LONG();
1063
+ else
1064
+ return this.num_2_ulong();
1065
+ }
1066
+ num_2_long() {
1067
+ let slong;
1068
+ let sign;
1069
+ sign = this._data[0] & NUM_TYPE.SIGN_MASK;
1070
+ this._data[0] &= NUM_TYPE.toSByte(~NUM_TYPE.SIGN_MASK);
1071
+ if (sign !== 0) {
1072
+ if (NUM_TYPE.memcmp(this, 0, NUM_TYPE.MinLONG(), 0, this.SIGNIFICANT_NUM_SIZE) > 0)
1073
+ return 0;
1074
+ }
1075
+ else {
1076
+ if (NUM_TYPE.memcmp(this, 0, NUM_TYPE.MaxLONG(), 0, this.SIGNIFICANT_NUM_SIZE) > 0)
1077
+ return 0;
1078
+ }
1079
+ slong = this.num_2_ulong();
1080
+ if (sign !== 0) {
1081
+ slong = -slong;
1082
+ this._data[0] |= NUM_TYPE.toSByte(sign);
1083
+ }
1084
+ return (slong);
1085
+ }
1086
+ num_2_ulong() {
1087
+ let val;
1088
+ let pwr;
1089
+ let pos;
1090
+ let last;
1091
+ pwr = this._data[0] - NUM_TYPE.EXP_BIAS;
1092
+ if (pwr > 5)
1093
+ return (0);
1094
+ last = (pwr === 5);
1095
+ if (last)
1096
+ pwr = 4;
1097
+ val = 0;
1098
+ for (pos = 1; pos <= pwr; pos++)
1099
+ val = val * 100 + NUM_TYPE.toUByte(this._data[pos]);
1100
+ if (last)
1101
+ if (val <= Math.floor((0xFFFFFFFF - NUM_TYPE.toUByte(this._data[5])) / 100))
1102
+ val = val * 100 + NUM_TYPE.toUByte(this._data[5]);
1103
+ else
1104
+ val = 0;
1105
+ return (val);
1106
+ }
1107
+ static add_pos(num1, num2, operData) {
1108
+ let len1;
1109
+ let len2;
1110
+ let len;
1111
+ let pos;
1112
+ let num1ptr;
1113
+ let resptr;
1114
+ let i;
1115
+ let SIGNIFICANT_NUM_SIZE;
1116
+ if (num1 == null || num2 == null)
1117
+ return null;
1118
+ SIGNIFICANT_NUM_SIZE = GuiEnvironment.Environment.GetSignificantNumSize();
1119
+ let res = new NUM_TYPE();
1120
+ if (operData.NUM_Exp2_ === 0 || (operData.NUM_Diff_ >= SIGNIFICANT_NUM_SIZE - 1)) {
1121
+ res = new NUM_TYPE(num1);
1122
+ res._data[0] = operData.NUM_Exp1_;
1123
+ return res;
1124
+ }
1125
+ len1 = 1;
1126
+ for (i = SIGNIFICANT_NUM_SIZE - 2; i > 0; i -= 2) {
1127
+ if (num1.SHRT_IS_ZERO(i))
1128
+ continue;
1129
+ else {
1130
+ len1 = i + 1;
1131
+ break;
1132
+ }
1133
+ }
1134
+ if (num1._data[len1] === 0)
1135
+ len1--;
1136
+ len2 = 1;
1137
+ for (i = SIGNIFICANT_NUM_SIZE - 2; i > 0; i -= 2) {
1138
+ if (num2.SHRT_IS_ZERO(i))
1139
+ continue;
1140
+ else {
1141
+ len2 = i + 1;
1142
+ break;
1143
+ }
1144
+ }
1145
+ if (num2._data[len2] === 0)
1146
+ len2--;
1147
+ if ((len = Math.max(len1, len2 + operData.NUM_Diff_)) > SIGNIFICANT_NUM_SIZE - 1)
1148
+ len = SIGNIFICANT_NUM_SIZE - 1;
1149
+ res.NUM_SET_ZERO();
1150
+ num1ptr = operData.NUM_Diff_;
1151
+ resptr = operData.NUM_Diff_;
1152
+ for (pos = len - operData.NUM_Diff_; pos > 0; pos--) {
1153
+ res._data[resptr + pos] =
1154
+ NUM_TYPE.toSByte(NUM_TYPE.toUByte(res._data[resptr + pos]) + NUM_TYPE.toUByte(num1._data[num1ptr + pos]) + NUM_TYPE.toUByte(num2._data[pos]));
1155
+ if (NUM_TYPE.toUByte(res._data[resptr + pos]) >= 100) {
1156
+ res._data[resptr + pos] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(res._data[resptr + pos]) - 100);
1157
+ res._data[resptr + pos - 1] = 1;
1158
+ }
1159
+ }
1160
+ for (pos = operData.NUM_Diff_; pos > 0; pos--) {
1161
+ res._data[pos] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(res._data[pos]) + NUM_TYPE.toUByte(num1._data[pos]));
1162
+ if (NUM_TYPE.toUByte(res._data[pos]) >= 100) {
1163
+ res._data[pos] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(res._data[pos]) - 100);
1164
+ res._data[pos - 1] = 1;
1165
+ }
1166
+ }
1167
+ if (res._data[0] !== 0) {
1168
+ for (pos = Math.min(len, SIGNIFICANT_NUM_SIZE - 2); pos >= 0; pos--)
1169
+ res._data[pos + 1] = res._data[pos];
1170
+ operData.NUM_Exp1_++;
1171
+ }
1172
+ res._data[0] = operData.NUM_Exp1_;
1173
+ return res;
1174
+ }
1175
+ static sub_pos(num1, num2, operData) {
1176
+ let len1;
1177
+ let len2;
1178
+ let len;
1179
+ let pos;
1180
+ let num1ptr;
1181
+ let resptr;
1182
+ let i;
1183
+ let SIGNIFICANT_NUM_SIZE;
1184
+ if (num1 == null || num2 == null)
1185
+ return null;
1186
+ SIGNIFICANT_NUM_SIZE = GuiEnvironment.Environment.GetSignificantNumSize();
1187
+ let res = new NUM_TYPE();
1188
+ let j;
1189
+ if (operData.NUM_Exp2_ === 0 || (operData.NUM_Diff_ >= SIGNIFICANT_NUM_SIZE - 1)) {
1190
+ res = new NUM_TYPE(num1);
1191
+ res._data[0] = operData.NUM_Exp1_;
1192
+ return res;
1193
+ }
1194
+ len1 = 1;
1195
+ for (i = SIGNIFICANT_NUM_SIZE - 2; i > 0; i -= 2) {
1196
+ if (num1.SHRT_IS_ZERO(i))
1197
+ continue;
1198
+ else {
1199
+ len1 = i + 1;
1200
+ break;
1201
+ }
1202
+ }
1203
+ if (num1._data[len1] === 0)
1204
+ len1--;
1205
+ len2 = 1;
1206
+ for (i = SIGNIFICANT_NUM_SIZE - 2; i > 0; i -= 2) {
1207
+ if (num2.SHRT_IS_ZERO(i))
1208
+ continue;
1209
+ else {
1210
+ len2 = i + 1;
1211
+ break;
1212
+ }
1213
+ }
1214
+ if (num2._data[len2] === 0)
1215
+ len2--;
1216
+ if ((len = Math.max(len1, len2 + operData.NUM_Diff_)) > SIGNIFICANT_NUM_SIZE - 1)
1217
+ len = SIGNIFICANT_NUM_SIZE - 1;
1218
+ res.NUM_SET_ZERO();
1219
+ num1ptr = operData.NUM_Diff_;
1220
+ resptr = operData.NUM_Diff_;
1221
+ for (pos = len - operData.NUM_Diff_; pos > 0; pos--) {
1222
+ res._data[resptr + pos] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(res._data[resptr + pos]) + NUM_TYPE.toUByte(num1._data[num1ptr + pos]) - NUM_TYPE.toUByte(num2._data[pos]));
1223
+ if (res._data[resptr + pos] < 0) {
1224
+ res._data[resptr + pos] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(res._data[resptr + pos]) + 100);
1225
+ res._data[resptr + pos - 1] = NUM_TYPE.toSByte(0xFF);
1226
+ }
1227
+ }
1228
+ for (pos = operData.NUM_Diff_; pos > 0; pos--) {
1229
+ res._data[pos] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(res._data[pos]) + NUM_TYPE.toUByte(num1._data[pos]));
1230
+ if (res._data[pos] < 0) {
1231
+ res._data[pos] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(res._data[pos]) + 100);
1232
+ res._data[pos - 1] = NUM_TYPE.toSByte(0xFF);
1233
+ }
1234
+ }
1235
+ while ((++pos <= len) && res._data[pos] === 0) {
1236
+ }
1237
+ if (pos <= len) {
1238
+ operData.NUM_Diff_ = pos - 1;
1239
+ if (operData.NUM_Diff_ > 0) {
1240
+ for (j = 0; j < len - operData.NUM_Diff_; j++)
1241
+ res._data[1 + j] = res._data[pos + j];
1242
+ for (j = 0; j < operData.NUM_Diff_; j++)
1243
+ res._data[len - operData.NUM_Diff_ + 1 + j] = 0;
1244
+ }
1245
+ res._data[0] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(operData.NUM_Exp1_) - operData.NUM_Diff_);
1246
+ }
1247
+ return res;
1248
+ }
1249
+ num_fix(wholes) {
1250
+ let pwr;
1251
+ let num_diff;
1252
+ if (this.NUM_IS_LONG())
1253
+ this.num_4_std_long();
1254
+ pwr = (this._data[0] & ~NUM_TYPE.SIGN_MASK) - NUM_TYPE.EXP_BIAS;
1255
+ if ((num_diff = pwr - ((wholes + 1) >> 1)) < 0)
1256
+ return;
1257
+ if (num_diff < this.SIGNIFICANT_NUM_SIZE - 1) {
1258
+ if ((wholes & 1) === 1)
1259
+ this._data[1 + num_diff] = NUM_TYPE.toSByte(this._data[1 + num_diff] % 10);
1260
+ while ((num_diff < this.SIGNIFICANT_NUM_SIZE - 1) && this._data[1 + num_diff] === 0)
1261
+ num_diff++;
1262
+ }
1263
+ if (num_diff >= this.SIGNIFICANT_NUM_SIZE - 1) {
1264
+ this.NUM_ZERO();
1265
+ return;
1266
+ }
1267
+ if (num_diff > 0) {
1268
+ let i;
1269
+ for (i = 0; i < this.SIGNIFICANT_NUM_SIZE - 1 - num_diff; i++)
1270
+ this._data[1 + i] = this._data[1 + num_diff + i];
1271
+ for (i = 0; i < num_diff; i++)
1272
+ this._data[this.SIGNIFICANT_NUM_SIZE - num_diff + i] = 0;
1273
+ this._data[0] = NUM_TYPE.toSByte(this._data[0] - NUM_TYPE.toSByte(num_diff));
1274
+ }
1275
+ }
1276
+ SHRT_IS_ZERO(pos) {
1277
+ return this._data[pos] === 0 && this._data[pos + 1] === 0;
1278
+ }
1279
+ setZero(asLong) {
1280
+ let i;
1281
+ for (i = 0; i < NUM_TYPE.NUM_SIZE; i++)
1282
+ this._data[i] = 0;
1283
+ if (asLong)
1284
+ this._data[0] = NUM_TYPE.NUM_LONG_TYPE;
1285
+ }
1286
+ static memcmp(num1, pos1, num2, pos2, len) {
1287
+ let i = 0;
1288
+ while (i < len && num1._data[pos1] === num2._data[pos2] && pos1 < NUM_TYPE.NUM_SIZE && pos2 < NUM_TYPE.NUM_SIZE) {
1289
+ i++;
1290
+ pos1++;
1291
+ pos2++;
1292
+ }
1293
+ if (i === len)
1294
+ return 0;
1295
+ else if (this.toUByte(num1._data[pos1]) < this.toUByte(num2._data[pos2]))
1296
+ return -1;
1297
+ else
1298
+ return 1;
1299
+ }
1300
+ static toUByte(byteVal) {
1301
+ let val = byteVal;
1302
+ if (byteVal < 0)
1303
+ val = 256 + byteVal;
1304
+ return val;
1305
+ }
1306
+ static toSByte(unsignedVal) {
1307
+ let val = 0;
1308
+ if (unsignedVal > Constants.SByteMaxValue)
1309
+ val = (unsignedVal - 256);
1310
+ else
1311
+ val = unsignedVal;
1312
+ return val;
1313
+ }
1314
+ static MaxLONG() {
1315
+ let nUM_TYPE = new NUM_TYPE();
1316
+ nUM_TYPE._data[0] = NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 5);
1317
+ nUM_TYPE._data[1] = 21;
1318
+ nUM_TYPE._data[2] = 47;
1319
+ nUM_TYPE._data[3] = 48;
1320
+ nUM_TYPE._data[4] = 36;
1321
+ nUM_TYPE._data[5] = 47;
1322
+ return nUM_TYPE;
1323
+ }
1324
+ static MinLONG() {
1325
+ let num = new NUM_TYPE();
1326
+ num._data[0] = NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 5);
1327
+ num._data[1] = 21;
1328
+ num._data[2] = 47;
1329
+ num._data[3] = 48;
1330
+ num._data[4] = 36;
1331
+ num._data[5] = 48;
1332
+ return num;
1333
+ }
1334
+ to_double() {
1335
+ return this.storage_mg_2_float(8);
1336
+ }
1337
+ storage_mg_2_float(len) {
1338
+ let sign_pos;
1339
+ let sign;
1340
+ let compnum = new NUM_TYPE();
1341
+ let tmpnum = new NUM_TYPE();
1342
+ let divnum = new NUM_TYPE();
1343
+ let pwr;
1344
+ let bits;
1345
+ let exp;
1346
+ let long1 = 0;
1347
+ let long2 = 0;
1348
+ let fltOut = 0;
1349
+ let cout = new Int8Array([0, 0, 0, 0, 0, 0, 0, 0]);
1350
+ let Num2Pwr23_ = new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 4), 8, 38, 86, 8]);
1351
+ let Num2Pwr52_ = new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 8), 45, 3, 59, 96, 27, 37, 4, 96]);
1352
+ let base_Num16Pwrs = [
1353
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 1), 1]),
1354
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 1), 16]),
1355
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 2), 2, 56]),
1356
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 2), 40, 96]),
1357
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 3), 6, 55, 36]),
1358
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 4), 1, 4, 85, 76]),
1359
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 4), 16, 77, 72, 16]),
1360
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 5), 2, 68, 43, 54, 56]),
1361
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 5), 42, 94, 96, 72, 96]),
1362
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 6), 6, 87, 19, 47, 67, 36]),
1363
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 7), 1, 9, 95, 11, 62, 77, 76]),
1364
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 7), 17, 59, 21, 86, 4, 44, 16]),
1365
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 8), 2, 81, 47, 49, 76, 71, 6, 56]),
1366
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 8), 45, 3, 59, 96, 27, 37, 4, 96]),
1367
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 9), 7, 20, 57, 59, 40, 37, 92, 79, 36])
1368
+ ];
1369
+ let base_Num2Pwrs = [
1370
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 1), 1]),
1371
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 1), 2]),
1372
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 1), 4]),
1373
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 1), 8])
1374
+ ];
1375
+ if (this.NUM_IS_LONG())
1376
+ this.num_4_std_long();
1377
+ if (this._data[0] === 0)
1378
+ return 0;
1379
+ sign = NUM_TYPE.toSByte(this._data[0] & NUM_TYPE.SIGN_MASK);
1380
+ this._data[0] = NUM_TYPE.toSByte(this._data[0] & (~NUM_TYPE.SIGN_MASK));
1381
+ if (len === 4) {
1382
+ bits = 24;
1383
+ compnum = new NUM_TYPE(Num2Pwr23_);
1384
+ }
1385
+ else {
1386
+ bits = 53;
1387
+ compnum = new NUM_TYPE(Num2Pwr52_);
1388
+ }
1389
+ pwr = (this._data[0] - NUM_TYPE.EXP_BIAS) << 1;
1390
+ if (pwr < 0)
1391
+ exp = pwr * 3 + Math.floor((pwr + 1) / 3);
1392
+ else
1393
+ exp = pwr * 3 + Math.floor((pwr + 2) / 3);
1394
+ pwr = bits - exp;
1395
+ if (pwr < 0) {
1396
+ pwr = -pwr;
1397
+ tmpnum = NUM_TYPE.div(this, new NUM_TYPE(base_Num16Pwrs[pwr >> 2]));
1398
+ tmpnum = NUM_TYPE.div(tmpnum, new NUM_TYPE(base_Num2Pwrs[pwr & 3]));
1399
+ }
1400
+ else {
1401
+ tmpnum = this;
1402
+ while (pwr >= 60) {
1403
+ tmpnum = NUM_TYPE.mul(tmpnum, new NUM_TYPE(base_Num16Pwrs[14]));
1404
+ pwr -= 56;
1405
+ }
1406
+ tmpnum = NUM_TYPE.mul(tmpnum, new NUM_TYPE(base_Num16Pwrs[pwr >> 2]));
1407
+ tmpnum = NUM_TYPE.mul(tmpnum, new NUM_TYPE(base_Num2Pwrs[pwr & 3]));
1408
+ }
1409
+ while (NUM_TYPE.num_cmp(tmpnum, compnum) < 0) {
1410
+ exp--;
1411
+ tmpnum = NUM_TYPE.add(tmpnum, tmpnum);
1412
+ }
1413
+ if (len === 4) {
1414
+ long1 = tmpnum.num_2_ulong();
1415
+ }
1416
+ else {
1417
+ divnum = NUM_TYPE.div(tmpnum, new NUM_TYPE(base_Num16Pwrs[8]));
1418
+ divnum.num_trunc(0);
1419
+ long1 = divnum.num_2_ulong();
1420
+ divnum = NUM_TYPE.mul(divnum, new NUM_TYPE(base_Num16Pwrs[8]));
1421
+ divnum = NUM_TYPE.sub(tmpnum, divnum);
1422
+ long2 = divnum.num_2_ulong();
1423
+ }
1424
+ sign_pos = len - 1;
1425
+ if (len === 4) {
1426
+ exp += 126;
1427
+ cout[3] = NUM_TYPE.toSByte(exp >> 1);
1428
+ cout[2] = NUM_TYPE.toSByte((this.LO_CHAR(this.HI_SHRT(long1)) & 0x7F) | ((exp & 0x01) << 7));
1429
+ cout[1] = NUM_TYPE.toSByte(this.HI_CHAR(this.LO_SHRT(long1)));
1430
+ cout[0] = NUM_TYPE.toSByte(this.LO_CHAR(this.LO_SHRT(long1)));
1431
+ }
1432
+ else {
1433
+ exp += 1022;
1434
+ cout[7] = NUM_TYPE.toSByte(exp >> 4);
1435
+ cout[6] = NUM_TYPE.toSByte((this.LO_CHAR(this.HI_SHRT(long1)) & 0x0F) | ((exp & 0x0F) << 4));
1436
+ cout[5] = NUM_TYPE.toSByte(this.HI_CHAR(this.LO_SHRT(long1)));
1437
+ cout[4] = NUM_TYPE.toSByte(this.LO_CHAR(this.LO_SHRT(long1)));
1438
+ cout[3] = NUM_TYPE.toSByte(this.HI_CHAR(this.HI_SHRT(long2)));
1439
+ cout[2] = NUM_TYPE.toSByte(this.LO_CHAR(this.HI_SHRT(long2)));
1440
+ cout[1] = NUM_TYPE.toSByte(this.HI_CHAR(this.LO_SHRT(long2)));
1441
+ cout[0] = NUM_TYPE.toSByte(this.LO_CHAR(this.LO_SHRT(long2)));
1442
+ }
1443
+ if (sign !== 0) {
1444
+ cout[sign_pos] |= NUM_TYPE.SIGN_MASK;
1445
+ this._data[0] |= NUM_TYPE.SIGN_MASK;
1446
+ }
1447
+ fltOut = this.sbyteArr_2_Double(cout);
1448
+ return fltOut;
1449
+ }
1450
+ LO_CHAR(n) {
1451
+ return n & 255;
1452
+ }
1453
+ HI_CHAR(n) {
1454
+ return (n & 65280) >> 8;
1455
+ }
1456
+ LO_SHRT(n) {
1457
+ return (n & 65535);
1458
+ }
1459
+ HI_SHRT(n) {
1460
+ return ((n & -65536) >> 16);
1461
+ }
1462
+ static MK_SHRT(c1, c2) {
1463
+ let strInt = (c1 << 8 | c2).toString();
1464
+ return NNumber.Parse(strInt);
1465
+ }
1466
+ static MK_LONG(s1, s2) {
1467
+ let l1 = s1;
1468
+ let l2 = s2;
1469
+ let strLng = (l1 << 16 | l2).toString();
1470
+ return NNumber.Parse(strLng);
1471
+ }
1472
+ sbyteArr_2_Double(array) {
1473
+ let dataview = new DataView(array.buffer);
1474
+ return dataview.getFloat64(0, true);
1475
+ }
1476
+ static double_2_sbyteArray(d) {
1477
+ let buffer = new ArrayBuffer(8);
1478
+ let dataview = new DataView(buffer);
1479
+ dataview.setFloat64(0, d, true);
1480
+ return (new Int8Array(dataview.buffer));
1481
+ }
1482
+ static eval_op_pwr(num1, num2) {
1483
+ let d0;
1484
+ let d1;
1485
+ if (num1 == null || num2 == null)
1486
+ return null;
1487
+ if (num2.NUM_IS_LONG() && !num2.num_is_neg()) {
1488
+ d1 = num2.to_double();
1489
+ let result = NUM_TYPE.from_double(1);
1490
+ for (let i = 0; i < d1; i++)
1491
+ result = this.mul(result, num1);
1492
+ return result;
1493
+ }
1494
+ else {
1495
+ d0 = num1.to_double();
1496
+ d1 = num2.to_double();
1497
+ if (d0 < 0.0 && d1 !== d1)
1498
+ d0 = 0.0;
1499
+ else if (d0 !== 0.0)
1500
+ d0 = Math.pow(d0, d1);
1501
+ }
1502
+ return NUM_TYPE.from_double(d0);
1503
+ }
1504
+ static from_double(d0) {
1505
+ let array = NUM_TYPE.double_2_sbyteArray(d0);
1506
+ return NUM_TYPE.storage_mg_4_float(8, array);
1507
+ }
1508
+ static storage_mg_4_float(len, inp) {
1509
+ let cinp;
1510
+ let sign;
1511
+ let tmp1;
1512
+ let exp;
1513
+ let bias;
1514
+ let long1;
1515
+ let long2;
1516
+ cinp = new Array(inp.length);
1517
+ for (tmp1 = 0; tmp1 < inp.length; tmp1++)
1518
+ cinp[tmp1] = NUM_TYPE.toUByte(inp[tmp1]);
1519
+ sign = cinp[len - 1];
1520
+ if (len === 4) {
1521
+ exp = ((cinp[2] >> 7) | ((cinp[3] & 0x7F) << 1));
1522
+ bias = 150;
1523
+ long1 = 0;
1524
+ long2 = NUM_TYPE.MK_LONG(NUM_TYPE.MK_SHRT(0, cinp[2] | 0x80), NUM_TYPE.MK_SHRT(cinp[1], cinp[0]));
1525
+ }
1526
+ else {
1527
+ exp = (((cinp[7] & 0x7F) << 4) | (cinp[6] >> 4));
1528
+ bias = 1075;
1529
+ long1 = NUM_TYPE.MK_LONG(NUM_TYPE.MK_SHRT(0, (cinp[6] & 0x0F) | 0x10), NUM_TYPE.MK_SHRT(cinp[5], cinp[4]));
1530
+ long2 = NUM_TYPE.MK_LONG(NUM_TYPE.MK_SHRT(cinp[3], cinp[2]), NUM_TYPE.MK_SHRT(cinp[1], cinp[0]));
1531
+ }
1532
+ return NUM_TYPE.storage_num_4_fld_flt(long1, long2, 18, sign, bias, exp);
1533
+ }
1534
+ static storage_num_4_fld_flt(long1, long2, dec, sign, bias, expr) {
1535
+ let base_Num16Pwrs = [
1536
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 1), 1]),
1537
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 1), 16]),
1538
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 2), 2, 56]),
1539
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 2), 40, 96]),
1540
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 3), 6, 55, 36]),
1541
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 4), 1, 4, 85, 76]),
1542
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 4), 16, 77, 72, 16]),
1543
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 5), 2, 68, 43, 54, 56]),
1544
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 5), 42, 94, 96, 72, 96]),
1545
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 6), 6, 87, 19, 47, 67, 36]),
1546
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 7), 1, 9, 95, 11, 62, 77, 76]),
1547
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 7), 17, 59, 21, 86, 4, 44, 16]),
1548
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 8), 2, 81, 47, 49, 76, 71, 6, 56]),
1549
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 8), 45, 3, 59, 96, 27, 37, 4, 96]),
1550
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 9), 7, 20, 57, 59, 40, 37, 92, 79, 36])
1551
+ ];
1552
+ let base_Num2Pwrs = [
1553
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 1), 1]),
1554
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 1), 2]),
1555
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 1), 4]),
1556
+ new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 1), 8])
1557
+ ];
1558
+ let tmpnum = new NUM_TYPE();
1559
+ let outVal = new NUM_TYPE();
1560
+ let exp = expr;
1561
+ if (exp === 0) {
1562
+ outVal.NUM_ZERO();
1563
+ return outVal;
1564
+ }
1565
+ outVal.num_4_ulong(long2);
1566
+ if (long1 !== 0) {
1567
+ tmpnum.num_4_ulong(long1);
1568
+ tmpnum = NUM_TYPE.mul(tmpnum, new NUM_TYPE(base_Num16Pwrs[8]));
1569
+ outVal = NUM_TYPE.add(tmpnum, outVal);
1570
+ }
1571
+ exp = (exp - bias);
1572
+ if (exp < 0) {
1573
+ exp = -exp;
1574
+ while (exp >= 60) {
1575
+ outVal = NUM_TYPE.div(outVal, new NUM_TYPE(base_Num16Pwrs[14]));
1576
+ exp -= 56;
1577
+ }
1578
+ tmpnum = NUM_TYPE.mul(new NUM_TYPE(base_Num16Pwrs[exp >> 2]), new NUM_TYPE(base_Num2Pwrs[exp & 3]));
1579
+ outVal = NUM_TYPE.div(outVal, tmpnum);
1580
+ }
1581
+ else {
1582
+ if (exp >= 60) {
1583
+ outVal.NUM_ZERO();
1584
+ return outVal;
1585
+ }
1586
+ tmpnum = NUM_TYPE.mul(new NUM_TYPE(base_Num16Pwrs[exp >> 2]), new NUM_TYPE(base_Num2Pwrs[exp & 3]));
1587
+ outVal = NUM_TYPE.mul(outVal, tmpnum);
1588
+ }
1589
+ if ((sign & 0x80) !== 0)
1590
+ outVal._data[0] = outVal._data[0] | NUM_TYPE.SIGN_MASK;
1591
+ outVal.round(dec);
1592
+ return outVal;
1593
+ }
1594
+ static eval_op_log(val1) {
1595
+ if (val1 == null)
1596
+ return null;
1597
+ let resVal = new NUM_TYPE();
1598
+ let d = val1.to_double();
1599
+ if (d > 0.0)
1600
+ resVal = NUM_TYPE.from_double(Math.log(d));
1601
+ else
1602
+ resVal.NUM_ZERO();
1603
+ return resVal;
1604
+ }
1605
+ static eval_op_exp(val1) {
1606
+ let resVal;
1607
+ if (val1 === null)
1608
+ return null;
1609
+ let d = val1.to_double();
1610
+ resVal = NUM_TYPE.from_double(Math.exp(d));
1611
+ return resVal;
1612
+ }
1613
+ static eval_op_abs(val1) {
1614
+ if (val1 === null)
1615
+ return null;
1616
+ let resVal = new NUM_TYPE(val1);
1617
+ resVal.num_abs();
1618
+ return resVal;
1619
+ }
1620
+ static eval_op_sin(val1) {
1621
+ if (val1 === null)
1622
+ return null;
1623
+ let resVal = new NUM_TYPE();
1624
+ let d = val1.to_double();
1625
+ resVal = NUM_TYPE.from_double(Math.sin(d));
1626
+ return resVal;
1627
+ }
1628
+ static eval_op_cos(val1) {
1629
+ if (val1 === null)
1630
+ return null;
1631
+ let resVal = new NUM_TYPE();
1632
+ let d = val1.to_double();
1633
+ resVal = NUM_TYPE.from_double(Math.cos(d));
1634
+ return resVal;
1635
+ }
1636
+ static eval_op_tan(val1) {
1637
+ if (val1 == null)
1638
+ return null;
1639
+ let resVal = new NUM_TYPE();
1640
+ let d = val1.to_double();
1641
+ resVal = NUM_TYPE.from_double(Math.tan(d));
1642
+ return resVal;
1643
+ }
1644
+ static eval_op_asin(val1) {
1645
+ if (val1 === null)
1646
+ return null;
1647
+ let resVal = new NUM_TYPE();
1648
+ let d = val1.to_double();
1649
+ if (d <= 1.0 && d >= -1.0)
1650
+ resVal = NUM_TYPE.from_double(Math.asin(d));
1651
+ else
1652
+ resVal = NUM_TYPE.from_double(0.0);
1653
+ return resVal;
1654
+ }
1655
+ static eval_op_acos(val1) {
1656
+ if (val1 === null)
1657
+ return null;
1658
+ let resVal = new NUM_TYPE();
1659
+ let d = val1.to_double();
1660
+ if (d <= 1.0 && d >= -1.0)
1661
+ resVal = NUM_TYPE.from_double(Math.acos(d));
1662
+ else
1663
+ resVal = NUM_TYPE.from_double(0.0);
1664
+ return resVal;
1665
+ }
1666
+ static eval_op_atan(val1) {
1667
+ if (val1 === null)
1668
+ return null;
1669
+ let resVal = new NUM_TYPE();
1670
+ let d = val1.to_double();
1671
+ resVal = NUM_TYPE.from_double(Math.atan(d));
1672
+ return resVal;
1673
+ }
1674
+ num_abs() {
1675
+ let l;
1676
+ if (this.NUM_IS_LONG()) {
1677
+ l = this.NUM_LONG();
1678
+ if (l < 0)
1679
+ l = -l;
1680
+ this.NUM_4_LONG(l);
1681
+ return;
1682
+ }
1683
+ this._data[0] &= NUM_TYPE.toSByte(~NUM_TYPE.SIGN_MASK);
1684
+ }
1685
+ static eval_op_rand(val1) {
1686
+ if (val1 === null)
1687
+ return null;
1688
+ let rand_initialized = Randomizer.get_initialized();
1689
+ let rand_mod;
1690
+ let rand_mul;
1691
+ let rand_seed;
1692
+ let tmp_num = new NUM_TYPE();
1693
+ if (!rand_initialized) {
1694
+ Randomizer.set_initialized();
1695
+ rand_mod = new NUM_TYPE();
1696
+ rand_mul = new NUM_TYPE();
1697
+ rand_seed = new NUM_TYPE();
1698
+ rand_mod.num_4_a_std("100000007");
1699
+ rand_mul.num_4_a_std("75000007");
1700
+ rand_seed.num_4_a_std("12345678");
1701
+ Randomizer.set_mod(rand_mod.to_double());
1702
+ Randomizer.set_mul(rand_mul.to_double());
1703
+ Randomizer.set_seed(rand_seed.to_double());
1704
+ }
1705
+ else {
1706
+ rand_mod = NUM_TYPE.from_double(Randomizer.get_mod());
1707
+ rand_mul = NUM_TYPE.from_double(Randomizer.get_mul());
1708
+ rand_seed = NUM_TYPE.from_double(Randomizer.get_seed());
1709
+ }
1710
+ if (!val1.num_is_zero()) {
1711
+ if (val1.num_is_neg())
1712
+ rand_seed.NUM_4_LONG(NUM_TYPE.hash_rand());
1713
+ else
1714
+ rand_seed = new NUM_TYPE(val1);
1715
+ }
1716
+ else {
1717
+ if (rand_seed.num_is_neg()) {
1718
+ tmp_num.NUM_4_LONG(-1);
1719
+ rand_seed = NUM_TYPE.mul(rand_seed, tmp_num);
1720
+ }
1721
+ }
1722
+ rand_seed = NUM_TYPE.mul(rand_seed, rand_mul);
1723
+ rand_seed = NUM_TYPE.mod(rand_seed, rand_mod);
1724
+ tmp_num = NUM_TYPE.div(rand_seed, rand_mod);
1725
+ Randomizer.set_mod(rand_mod.to_double());
1726
+ Randomizer.set_mul(rand_mul.to_double());
1727
+ Randomizer.set_seed(rand_seed.to_double());
1728
+ return tmp_num;
1729
+ }
1730
+ static hash_rand() {
1731
+ return ((new Date().getMilliseconds()) ^ Math.random() * 12345678);
1732
+ }
1733
+ }
1734
+ export class OperData {
1735
+ NUM_Diff_ = 0;
1736
+ NUM_Exp1_ = 0;
1737
+ NUM_Exp2_ = 0;
1738
+ }
1739
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"NUM_TYPE.js","sourceRoot":"","sources":["../../../../../../../projects/gui/src/management/data/NUM_TYPE.ts"],"names":[],"mappings":"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","sourcesContent":["import {  Int32, NNumber, NString, NumberStyles, StringBuilder } from '@magic-xpa/mscorelib';\r\nimport { Constants, PICInterface, Randomizer, StorageAttribute, UtilStrByteMode } from '@magic-xpa/utils';\r\nimport { PIC } from '../gui/PIC';\r\nimport { IEnvironment } from '../../env/IEnvironment';\r\nimport { Events } from '../../Events';\r\nimport { GuiEnvironment } from '../../GuiEnvironment';\r\n\r\n///   This class handles a Magic Number the identical way it's represented in Magic.\r\n///   Most of the methods in this class were copied from the C++ sources of Magic,\r\n///   in order to keep the exact logic used in order to implement all the functionality\r\n///   expected, which means that the exact methods names and variables names where used\r\n///   in order to make future debugging more easyer.\r\n///   Notice a long data type that is used in Magic C++ sources, is represented in java\r\n///   by the int data type.\r\n/// </summary>\r\n/// <author>  Alon Bar-Nes\r\n/// </author>\r\n\r\nexport class NUM_TYPE {\r\n  // --------------------------------------------------------------------------\r\n  // Constants\r\n  // --------------------------------------------------------------------------\r\n  static INT_ZERO_HEX: string = \"00000000\";\r\n  static NO_ROOM: number = -1;\r\n  static ZERO_FILL: number = -2;\r\n  static NUM_SIZE: number = 20;\r\n  static NUM_LONG_TYPE: number = -1;\r\n  static EXP_BIAS: number = 64;\r\n  static SIGN_MASK: number = -128;\r\n\r\n  COMMACHAR: string = ',';\r\n  DECIMALCHAR: string = '.';\r\n  private SIGNIFICANT_NUM_SIZE: number = 0;\r\n  private _data: Int8Array = new Int8Array(NUM_TYPE.NUM_SIZE);\r\n\r\n  set Data(value: Int8Array) {\r\n    this._data = value;\r\n  }\r\n\r\n  get Data(): Int8Array {\r\n    return this._data;\r\n  }\r\n\r\n  // --------------------------------------------------------------------------\r\n  // Constructor list\r\n  // --------------------------------------------------------------------------\r\n\r\n  constructor();\r\n  constructor(recordHexStr: string);\r\n  constructor(byteVal: Int8Array, offset: number, length: number);\r\n  constructor(byteVal: Int8Array);\r\n  constructor(decStr: string, pic: PIC, compIdx: number);\r\n  constructor(numFrom: NUM_TYPE);\r\n  constructor(recordHexStrOrByteValOrDecStrOrNumFrom?: any, offsetOrPic?: any, lengthOrCompIdx?: number) {\r\n    if (arguments.length === 0) {\r\n      this.constructor_0();\r\n      return;\r\n    }\r\n    if (arguments.length === 1 && (recordHexStrOrByteValOrDecStrOrNumFrom === null || recordHexStrOrByteValOrDecStrOrNumFrom.constructor === String)) {\r\n      this.constructor_1(recordHexStrOrByteValOrDecStrOrNumFrom);\r\n      return;\r\n    }\r\n    if (arguments.length === 3 && (recordHexStrOrByteValOrDecStrOrNumFrom === null || recordHexStrOrByteValOrDecStrOrNumFrom instanceof Int8Array) && (offsetOrPic === null || offsetOrPic.constructor === Number) && (lengthOrCompIdx === null || lengthOrCompIdx.constructor === Number)) {\r\n      this.constructor_2(recordHexStrOrByteValOrDecStrOrNumFrom, offsetOrPic, lengthOrCompIdx);\r\n      return;\r\n    }\r\n    if (arguments.length === 1 && (recordHexStrOrByteValOrDecStrOrNumFrom === null || recordHexStrOrByteValOrDecStrOrNumFrom instanceof Int8Array)) {\r\n      this.constructor_3(recordHexStrOrByteValOrDecStrOrNumFrom);\r\n      return;\r\n    }\r\n    if (arguments.length === 3 && (recordHexStrOrByteValOrDecStrOrNumFrom === null || recordHexStrOrByteValOrDecStrOrNumFrom.constructor === String) && (offsetOrPic === null || offsetOrPic instanceof PIC) && (lengthOrCompIdx === null || lengthOrCompIdx.constructor === Number)) {\r\n      this.constructor_4(recordHexStrOrByteValOrDecStrOrNumFrom, offsetOrPic, lengthOrCompIdx);\r\n      return;\r\n    }\r\n    this.constructor_5(recordHexStrOrByteValOrDecStrOrNumFrom);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Default constructor. Set value to 0\r\n  /// </summary>\r\n  private constructor_0(): void {\r\n    this.initConst();\r\n    this.NUM_ZERO();\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Creates a Magic Number from a string got from the XML record value. The\r\n  ///   String is 40 characters long in an hexa representation.\r\n  /// </summary>\r\n  /// <param name = \"recordHexStr\">  Magic number in hex format, 40 characters long\r\n  /// </param>\r\n  private constructor_1(recordHexStr: string): void {\r\n    let i: number = 0;\r\n    let twoDigits: string;\r\n    this.initConst();\r\n\r\n    try {\r\n      for (i = 0; i < this.SIGNIFICANT_NUM_SIZE; i = i + 1) {\r\n        twoDigits = recordHexStr.substr( i * 2, 2);\r\n        this._data[i] = NUM_TYPE.toSByte(NNumber.Parse(twoDigits, NumberStyles.HexNumber));\r\n      }\r\n    }\r\n    catch (ex) {\r\n      Events.WriteWarningToLog(ex);\r\n\r\n      this.NUM_ZERO();\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Creates a Magic Number from array of bytes. Used from the expression evaluator\r\n  ///   when a Magic Number value apears within an expression.\r\n  /// </summary>\r\n  /// <param name = \"byteVal\">  Array of bytes representing a Magic Number</param>\r\n  /// <param name = \"offset\">   Index of the first byte </param>\r\n  /// <param name = \"length\">   Number of bytes to use </param>\r\n  private constructor_2(byteVal: Int8Array, offset: number, length: number): void {\r\n    this.constructor_0();\r\n    for (let i: number = 0; i < length; i = i + 1) {\r\n      this._data[i] = byteVal[i + offset];\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Creates a Magic Number from array of bytes\r\n  /// </summary>\r\n  private constructor_3(byteVal: Int8Array): void {\r\n    this.constructor_2(byteVal, 0, byteVal.length);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Creates a Magic Number from a decimal for number and its picture\r\n  /// </summary>\r\n  /// <param name = \"decStr\">  The number in a string decimal format </param>\r\n  /// <param name = \"pic\">     The picture format to be used </param>\r\n  private constructor_4(decStr: string, pic: PIC, compIdx: number): void {\r\n    this.constructor_0();\r\n    this.from_a(decStr, pic, compIdx);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Creates a Magic Number from a Magic Number\r\n  /// </summary>\r\n  /// <param name = \"numFrom\">  The source Magic Number </param>\r\n  private constructor_5(numFrom: NUM_TYPE): void {\r\n    this.initConst();\r\n    this._data = new Int8Array(numFrom._data.length);\r\n    for (let _ai: number = 0; _ai < this._data.length; ++_ai)\r\n      this._data[_ai] = numFrom._data[_ai];\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Build a decimal string from the number stored in a Magic Number.\r\n  ///   The string is build from the picture provided as a parameter.\r\n  /// </summary>\r\n  /// <param name = \"pic\">The picture to use for building the display string\r\n  /// </param>\r\n  /// <returns> The decimal form of the Magic Number in the specified format\r\n  /// </returns>\r\n  toDisplayValue(pic: PIC): string {\r\n    return this.to_a(pic);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   init constants of the class\r\n  /// </summary>\r\n  private initConst(): void {\r\n    let env: IEnvironment = GuiEnvironment.Environment;\r\n    this.DECIMALCHAR = env.GetDecimal();\r\n    this.COMMACHAR = env.GetThousands();\r\n    this.SIGNIFICANT_NUM_SIZE = env.GetSignificantNumSize();\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Build an hexadecimal string from the Magic Number for the data record in\r\n  ///   the XML tag (to be sent to the Magic Server). The length of this string\r\n  ///   will allways be two times the length of the Magic Numbers (in bytes)\r\n  ///   because every byte in the Magic Number will be translated to two\r\n  ///   character hexadecimal string.\r\n  /// </summary>\r\n  /// <returns> the hexadecimal string\r\n  /// </returns>\r\n  toXMLrecord(): string {\r\n    let hexStr: StringBuilder = new StringBuilder(this.SIGNIFICANT_NUM_SIZE * 2);\r\n    let num: number;\r\n\r\n    if (this.NUM_IS_LONG())\r\n      num = 5;\r\n    else\r\n      num = this.SIGNIFICANT_NUM_SIZE;\r\n\r\n    for (let i: number = 0; i < this.SIGNIFICANT_NUM_SIZE; i++) {\r\n      if (i < num)\r\n        hexStr.Append(('0' + (this._data[i] & 0xFF).toString(16)).slice(-2));\r\n      else\r\n        hexStr.Append(\"00\");\r\n    }\r\n\r\n    return hexStr.ToString().toUpperCase();\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Transforming a decimal string number to a Magic Number using the format\r\n  ///   provided.\r\n  /// </summary>\r\n  /// <param name = \"Alpha\">  The number is decimal string form\r\n  /// </param>\r\n  /// <param name = \"pic\">    The picture fomat to use for the extracting the number\r\n  /// </param>\r\n  private from_a(Alpha: string, pic: PIC, compIdx: number): void {\r\n    let i: number;\r\n    let idx: number;\r\n    let dec: boolean;\r\n    let decs: number;\r\n    let digit: number;\r\n    let len: number;\r\n    let no_pic: boolean;\r\n    let Pos: number;\r\n    let SType: boolean;\r\n    let SPart: boolean;\r\n    let Signed: number;\r\n    let buf: string;\r\n    let mask: string = \"\";\r\n    let c: string;\r\n    let NgtvPrmt: boolean;\r\n    let Scan: string = \"\";\r\n    let Pbuf: string = \"\";\r\n    let is_negative: boolean;\r\n    let negStr: string;\r\n    let negPref: string;\r\n    let posPref: string;\r\n    let negSuff: string;\r\n    let posSuff: string;\r\n    let specialValNewPolicy: boolean = GuiEnvironment.Environment.GetSpecialValNewPolicy();\r\n\r\n    // Parse the picture format\r\n    no_pic = (pic == null);\r\n    len = 0;\r\n    SType = false;  // PIC_PSTV : true, PIC_NGTV: false\r\n    SPart = false;  // PIC_PREF : true, PIC_SUF : false\r\n\r\n    if (!no_pic) {\r\n      mask = pic.getMask();\r\n      if (!specialValNewPolicy)\r\n        if (Alpha.length > pic.getMaskSize())\r\n          Alpha = Alpha.substr(0, pic.getMaskSize());\r\n      NgtvPrmt = pic.isNegative();\r\n      if (NgtvPrmt) {\r\n        negPref = pic.getNegPref_();\r\n        posPref = pic.getPosPref_();\r\n        negSuff = pic.getNegSuff_();\r\n        posSuff = pic.getPosSuff_();\r\n\r\n        if (negPref.length === posPref.length) {\r\n          if (negPref.length === 0 || negPref === posPref)\r\n            SPart = false;\r\n          // PIC_SUF\r\n          else SPart = true; // PIC_PREF\r\n        }\r\n        else SPart = true; // PIC_PREF\r\n\r\n        if (SPart)\r\n          negStr = negPref;\r\n        else\r\n          negStr = negSuff;\r\n\r\n        if (negStr.length === 0)\r\n          SType = true;\r\n        // PIC_POSITIVE\r\n        else\r\n          SType = false; // PIC_NEGATIVE\r\n\r\n        if (SType)\r\n          Scan = (SPart ? posPref : posSuff);\r\n        else\r\n          Scan = (SPart ? negPref : negSuff);\r\n        len = Scan.length;\r\n      }\r\n    }\r\n    else {\r\n      pic = new PIC(\"\", StorageAttribute.NUMERIC, compIdx);\r\n      NgtvPrmt = false;\r\n    }\r\n\r\n    // Localize variables and flags\r\n    dec = false;\r\n    decs = 0;\r\n    digit = 0;\r\n    Signed = 0;\r\n\r\n    // SpecialValNewPolicy = Y\r\n    // Loop on input string of numbers and match them against the picture mask\r\n    // It may happen that the picture mask is smaller than received number string\r\n    // For example, if the string received is '1234.56' whereas picture is '2.1'\r\n    // then the characters to parse from the input string is '1234.5' i.e. # digits\r\n    // specified in picture before the decimal should be ignored. Parsing should\r\n    // continue till # of digits after decimal point in picture match with those in\r\n    // the input string or the end of the string\r\n    for (idx = 0; idx < Alpha.length; ) {\r\n      // As mentioned above, continue parsing even if mask length as exhausted by checking\r\n      // idx >= pic.mask_size. However, as long as mask length is valid, match the mask\r\n      if (no_pic || (specialValNewPolicy && idx >= pic.getMaskSize())  || mask[idx] === String.fromCharCode(PICInterface.PIC_N)) {\r\n        c = Alpha[idx];\r\n        if (specialValNewPolicy)\r\n        {\r\n          // stop parsing if # of decs already reached\r\n          if (dec && decs === pic.getDec())\r\n          {\r\n            // Finally, stop parsing on matching required no. of decimal digits\r\n            break;\r\n          }\r\n        }\r\n        if (UtilStrByteMode.isDigit(c)) {\r\n          digit++;\r\n          Pbuf += c;\r\n          if (dec)\r\n            decs++;\r\n        }\r\n        else if (c === this.DECIMALCHAR) {\r\n          Pbuf += this.DECIMALCHAR;\r\n          dec = true;\r\n        }\r\n        else if (c !== this.COMMACHAR) {\r\n          if (NgtvPrmt && Signed === 0) {\r\n            Signed = 1;\r\n            for (i = idx, Pos = 0; i <= Alpha.length && Pos < len; i++) {\r\n              if (no_pic || mask[i] === String.fromCharCode(PICInterface.PIC_N)) {\r\n                c = Alpha[i];\r\n                if (c !== Scan[Pos]) {\r\n                  if (c === '-' && !SType)\r\n                    break;\r\n                  if (c === '+' && SType)\r\n                    break;\r\n                  Signed = -1;\r\n                  break;\r\n                }\r\n                Pos++;\r\n              }\r\n            }\r\n            if (Pos > 0 && Pos < len)\r\n              Signed = -1;\r\n          }\r\n          else {\r\n            // QCR # 309623 : If prefix/suffix strings contains digits in it, it is considered as part of data.\r\n            // In order to avoid it skip the prefix / suffix strings while extracting the data part to build NUM_TYPE.\r\n            if (idx === 0) {\r\n              if (pic.getNegPref_().length > 0)\r\n                if (Alpha.startsWith(pic.getNegPref_())) {\r\n                  idx += pic.getNegPref_().length;\r\n                  continue;\r\n                }\r\n              if (pic.getPosPref_().length > 0)\r\n                if (Alpha.startsWith(pic.getPosPref_())) {\r\n                  idx += pic.getPosPref_().length;\r\n                  continue;\r\n                }\r\n            }\r\n            else {\r\n              if (pic.getNegSuff_().length > 0)\r\n                if (Alpha.endsWith(pic.getNegSuff_())) {\r\n                  idx += pic.getNegSuff_().length;\r\n                  continue;\r\n                }\r\n              if (pic.getPosSuff_().length > 0)\r\n                if (Alpha.endsWith(pic.getPosSuff_())) {\r\n                  idx += pic.getPosSuff_().length;\r\n                  continue;\r\n                }\r\n            }\r\n          }\r\n        }\r\n      }\r\n      idx++;\r\n    }\r\n\r\n    if (Signed === 0 && SType)\r\n      Signed = 1;\r\n\r\n    // Return result of decoded digits\r\n    is_negative = (Signed === 1 && !SType) || (Signed !== 1 && SType);\r\n    if (decs > 0 || digit > 9) {\r\n      buf = (is_negative ? '-' : ' ') + Pbuf;\r\n      this.num_4_a_std(buf);\r\n    }\r\n    else\r\n      this.NUM_4_LONG((is_negative ? -1 : 1) * this.a_2_long(Pbuf));\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Extracting a non long number from a decimal string number (numbers with\r\n  ///   decimal point, etc...)\r\n  /// </summary>\r\n  /// <param name = \"str\">  The decimal string number\r\n  /// </param>\r\n  num_4_a_std(str: string): void {\r\n    let digstr: string = \"\";\r\n    let diglen: number = 0;\r\n    let wholes: number = 0;\r\n    let decs: number = 0;\r\n    let isDec: boolean = false;\r\n    let isminus: boolean = false;\r\n    let pos: number;\r\n\r\n    for (pos = 0; pos < str.length; pos++) {\r\n      let c: string = str.charAt(pos);\r\n      if (UtilStrByteMode.isDigit(c)) {\r\n        if (diglen > 0 || c !== '0') {\r\n          diglen++;\r\n          digstr = digstr + c;\r\n          if (!isDec)\r\n            wholes++;\r\n        }\r\n        else if (isDec)\r\n          decs = decs + 1;\r\n      }\r\n      else if (c === this.DECIMALCHAR)\r\n        isDec = true;\r\n      else if (c === '-')\r\n        isminus = true;\r\n    }\r\n\r\n    this.NUM_ZERO();\r\n    if (diglen === 0)\r\n      return;\r\n\r\n    if (((wholes + decs) & 1) > 0) {\r\n      this._data[1] = NUM_TYPE.toSByte(digstr.charCodeAt(0) - '0'.charCodeAt(0));\r\n      pos = 1;\r\n    }\r\n    else\r\n      pos = 0;\r\n\r\n    let numptr: number = 1 + pos;\r\n    diglen = Math.min(diglen, (this.SIGNIFICANT_NUM_SIZE - 1) * 2 - pos);\r\n    while (pos < diglen) {\r\n      let digit1: number = NUM_TYPE.toSByte((digstr.charCodeAt(pos++) - '0'.charCodeAt(0)));\r\n      let digit2: number = NUM_TYPE.toSByte(((pos < diglen)\r\n        ? (digstr.charCodeAt(pos++) - '0'.charCodeAt(0))\r\n        : '\\0'.charCodeAt(0)));\r\n      this._data[numptr++] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(digit1) * 10 + NUM_TYPE.toUByte(digit2));\r\n    }\r\n\r\n    if (wholes > 0)\r\n      this._data[0] = NUM_TYPE.toSByte(<number>NUM_TYPE.EXP_BIAS + ((wholes + 1) >> 1));\r\n    else\r\n      this._data[0] = NUM_TYPE.toSByte(<number>NUM_TYPE.EXP_BIAS - (decs >> 1));\r\n\r\n    if (isminus)\r\n      this._data[0] |= NUM_TYPE.SIGN_MASK;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Translating a long value into an internal Magic Number form\r\n  /// </summary>\r\n  /// <param name = \"longVal\">  The number to be kept\r\n  /// </param>\r\n  NUM_4_LONG(longVal: number): void {\r\n    let hexStr: string;\r\n    this.NUM_ZERO();\r\n\r\n    if (longVal !== 0) {\r\n      if (longVal < 0)\r\n        longVal = (0xFFFFFFFF + longVal + 1);\r\n\r\n      hexStr = longVal.toString(16);\r\n      if (longVal > 0)\r\n        hexStr = NUM_TYPE.INT_ZERO_HEX.substr(hexStr.length) + hexStr;\r\n\r\n      this._data[1] = NUM_TYPE.toSByte(parseInt(hexStr.substr(6, (8) - (6)), 16));\r\n      this._data[2] = NUM_TYPE.toSByte(parseInt(hexStr.substr(4, (6) - (4)), 16));\r\n      this._data[3] = NUM_TYPE.toSByte(parseInt(hexStr.substr(2, (4) - (2)), 16));\r\n      this._data[4] = NUM_TYPE.toSByte(parseInt(hexStr.substr(0, (2) - (0)), 16));\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Getting a long value from a decimal string representing a long value\r\n  /// </summary>\r\n  /// <param name = \"str\">  the string representing a long value\r\n  /// </param>\r\n  /// <returns> the long number\r\n  /// </returns>\r\n  a_2_long(str: string): number {\r\n    let n: number = 0;\r\n    for (let pos: number = 0; pos < str.length; pos++) {\r\n      if (UtilStrByteMode.isDigit(str.charAt(pos))) {\r\n        n = n * 10;\r\n        n = n + str.charCodeAt(pos) - '0'.charCodeAt(0);\r\n      }\r\n    }\r\n    return n;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Activating the process of building a decimal string by the format indicated\r\n  /// </summary>\r\n  /// <param name = \"pic\">a numeric picture to use for building the display string\r\n  /// </param>\r\n  to_a(pic: PIC): string {\r\n    return this.to_a_pic(pic);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Performs the process of building a decimal string by the picture provided\r\n  /// </summary>\r\n  /// <param name = \"pic\">  the picture class holding the information about the picture\r\n  /// </param>\r\n  /// <returns> the string form of the Magic Number\r\n  /// </returns>\r\n  protected to_a_pic(pic: PIC): string {\r\n    let buf: string[] = new Array<string>(128);\r\n    let remains: number;\r\n    let sign_n: boolean;\r\n    let pref_len: number;\r\n    let suff_len: number;\r\n    let pref_str: String;\r\n    let suff_str: String;\r\n    let str_pos: number;\r\n    let str_len: number;\r\n    let out_pos: number;\r\n    let out_buf: string[];\r\n    let tmp_out_buf: string[];\r\n    let pad: string;\r\n    let left: boolean;\r\n    let pfill: boolean;\r\n    let mask_chars: number;\r\n    let len: number;\r\n    let res: string[];\r\n    let i: number;\r\n    let isOut: boolean;\r\n    let outVal: string[];\r\n\r\n    len = pic.getMaskSize();\r\n\r\n    // Set signs of number\r\n    sign_n = (pic.isNegative() && this.num_is_neg() ? false : true);\r\n\r\n    pref_len = (sign_n ? pic.getPosPref_().length : pic.getNegPref_().length); // pic_sign[PIC_PREF].len;\r\n    suff_len = (sign_n ? pic.getPosSuff_().length : pic.getNegSuff_().length); // pic_sign[PIC_SUFF].len;\r\n\r\n    left = pic.isLeft();\r\n    pfill = pic.padFill();\r\n    mask_chars = pic.getMaskChars();\r\n    outVal = NString.ToCharArray(pic.getMask().substr(0, len));\r\n    out_buf = ((left || (mask_chars > 0)) ? buf : outVal);\r\n    if (left)\r\n    {\r\n      for (i=0; i < out_buf.length; i++ )\r\n        out_buf[i] = (<string>'0'.toLowerCase());\r\n    }\r\n    isOut = ((left || (mask_chars > 0)) ? false : true);\r\n\r\n    // Convert to string\r\n    str_pos = pref_len;\r\n    str_len = len - pref_len - suff_len;\r\n    tmp_out_buf = out_buf.slice(str_pos, out_buf.length);\r\n    if (this.NUM_IS_LONG())\r\n      remains = this.num_l_2_str(this.NUM_LONG(), tmp_out_buf, str_len, pic);\r\n    else\r\n        remains = this.to_str(tmp_out_buf, str_len, pic);\r\n\r\n    for (i = str_pos; i < out_buf.length; i++)\r\n        out_buf[i] = tmp_out_buf[i - str_pos];\r\n    tmp_out_buf = null;\r\n\r\n    if (remains < mask_chars) {\r\n        res = new Array(len);\r\n      for (i = 0; i < len; i++)\r\n        res[i] = (remains === NUM_TYPE.ZERO_FILL ? pic.getZeroPad() : '*');\r\n      return NString.FromChars(res);\r\n    }\r\n\r\n    if (mask_chars > 0) {\r\n      remains -= mask_chars;\r\n      str_pos += mask_chars;\r\n      str_len -= mask_chars;\r\n    }\r\n\r\n    // take care of pad after and before number\r\n    if (pfill) {\r\n      pad = pic.getPad();\r\n      if (left) {\r\n        for (i = 0; i < remains; i++)\r\n          out_buf [str_pos + str_len + i] = pad;\r\n        str_pos += remains;\r\n      }\r\n      else {\r\n        for (i = 0; i < remains; i++)\r\n          out_buf[str_pos + i] = pad;\r\n      }\r\n    }\r\n    else {\r\n      pad = ' ';\r\n      str_pos += remains;\r\n      str_len -= remains;\r\n    }\r\n\r\n    // take care of suffix and prefix\r\n    if (suff_len > 0) {\r\n      suff_str = sign_n ? pic.getPosSuff_() : pic.getNegSuff_();\r\n      if (suff_len === 1)\r\n        out_buf[str_pos + str_len] = suff_str[0];\r\n      else {\r\n        for (i = 0; i < suff_len; i++)\r\n          out_buf[str_pos + str_len + i] = suff_str[i];\r\n      }\r\n      str_len += suff_len;\r\n    }\r\n    if (pref_len > 0) {\r\n      str_pos -= pref_len;\r\n      str_len += pref_len;\r\n      pref_str = sign_n ? pic.getPosPref_() : pic.getNegPref_();\r\n      if (pref_len === 1)\r\n          out_buf[str_pos] = pref_str[0];\r\n      else\r\n        for (i = 0; i < pref_len; i++)\r\n          out_buf[str_pos + i] = pref_str[i];\r\n    }\r\n\r\n    // str_pos now points to beginning of result str\r\n    // take care of final pad after and before number\r\n    if (!pfill) {\r\n      let outBufLen: number = out_buf.length;\r\n\r\n      if (left) {\r\n        for (i = 0; i < remains && (str_pos + str_len + i < outBufLen); i++)\r\n          out_buf[str_pos + str_len + i] = pad;\r\n      }\r\n      else {\r\n        str_pos -= remains;\r\n\r\n        for (i = 0; i < remains && (str_pos + i < outBufLen); i++)\r\n          out_buf[str_pos + i] = pad;\r\n      }\r\n    }\r\n\r\n    // result built, finish\r\n    if (isOut)\r\n      return NString.FromChars(out_buf);\r\n\r\n    // Copy result to output buffer\r\n    if (mask_chars === 0) {\r\n      if (str_pos + len > out_buf.length)\r\n        len = out_buf.length - str_pos;\r\n      return NString.FromChars(out_buf, str_pos,  len);\r\n    }\r\n\r\n    for (out_pos = 0; out_pos < len && str_pos < out_buf.length; out_pos++)\r\n      if (outVal[out_pos] === String.fromCharCode(PICInterface.PIC_N))\r\n        outVal[out_pos] = out_buf[str_pos++];\r\n\r\n    return NString.FromChars(outVal);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Bulding the basic decimal string number from a long value (without\r\n  ///   the special picture features).\r\n  /// </summary>\r\n  /// <param name = \"num\">  The number to be translated\r\n  /// </param>\r\n  /// <param name = \"str\">  The mask to use for building the string number\r\n  /// </param>\r\n  /// <len>    len   the len to use in the str char array </len>\r\n  /// <param name = \"pic\">  The picture class holding the information about the picture\r\n  /// </param>\r\n  /// <returns> the length of the result string\r\n  /// </returns>\r\n  protected num_l_2_str(num: number, str: string[], len: number, pic: PIC): number {\r\n    let commas: boolean;\r\n    let digits: number;\r\n    let i: number;\r\n    let decs: number;\r\n    let j: number;\r\n\r\n    if (num < 0)\r\n      num = -num;\r\n    commas = pic.withComa();\r\n    decs = Math.min(pic.getDec(), len - 1);\r\n    if (decs > 0)\r\n      len -= (decs + 1);\r\n    i = len;\r\n\r\n    // 26/11/97 Shay Z. Bug #770526 - If The decimal point is the first\r\n    // in the picture's format - assume that the input value is legal !!\r\n    if (num === 0 && !pic.decInFirstPos()) {\r\n      if (pic.zeroFill())\r\n        return (NUM_TYPE.ZERO_FILL);\r\n      if (len === 0)\r\n        return (NUM_TYPE.NO_ROOM);\r\n\r\n      if (i > str.length)\r\n        i = str.length;\r\n\r\n      str[--i] = '0';\r\n    }\r\n\r\n    if (decs > 0) {\r\n        str[len] = this.DECIMALCHAR;\r\n      for (j = 0; j < decs; j++)\r\n        str[len + 1 + j] = '0';\r\n    }\r\n\r\n    digits = 0;\r\n    for (; num > 0; num = Math.floor(num / 10)) {\r\n      i--;\r\n      if (commas) {\r\n        if (digits === 3) {\r\n          if (i < 0)\r\n            return (NUM_TYPE.NO_ROOM);\r\n          digits = 0;\r\n          str[i--] = this.COMMACHAR;\r\n        }\r\n        digits++;\r\n      }\r\n      if (i < 0)\r\n        return (NUM_TYPE.NO_ROOM);\r\n      str[i] = ((num % 10).toString());\r\n    }\r\n\r\n    return i;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Bulding the basic decimal string number from a non long value (without\r\n  ///   the special picture features).\r\n  /// </summary>\r\n  /// <param name = \"str\">  The mask to use for building the string number\r\n  /// </param>\r\n  /// <len>    len   the len to use in the str char array </len>\r\n  /// <param name = \"pic\">  The picture class holding the information about the picture\r\n  /// </param>\r\n  /// <returns> the length of the result string\r\n  /// </returns>\r\n  protected to_str(str: string[], len: number, pic: PIC): number {\r\n    let tmp: NUM_TYPE;\r\n    let commas: boolean;\r\n    let digits: number;\r\n    let decpos: number;\r\n    let last: number;\r\n    let first: number;\r\n    let j: number;\r\n    let i: number;\r\n    let decs: number;\r\n    let num_char: number;\r\n\r\n    commas = pic.withComa();\r\n    decs = pic.getDec();\r\n    if (decs >= len)\r\n      decs = len - 1;\r\n\r\n    tmp = new NUM_TYPE(this);\r\n    tmp.round(decs);\r\n    if (tmp.NUM_IS_LONG())\r\n      return tmp.num_l_2_str(tmp.NUM_LONG(), str, len, pic);\r\n\r\n    if (pic.zeroFill() && tmp._data[0] === 0)\r\n      return (NUM_TYPE.ZERO_FILL);\r\n\r\n    i = len - 1;\r\n    digits = 0;\r\n    decpos = ((tmp._data[0] & ~NUM_TYPE.SIGN_MASK) - NUM_TYPE.EXP_BIAS + 1) * 2;\r\n    last = decpos - 1 + decs;\r\n    first = decpos - 1;\r\n    if (first > 2)\r\n      first = (tmp._data[1] < 10) ? 3 : 2;\r\n\r\n    for (j = last; j >= first; j--) {\r\n      if (i < 0)\r\n        return (NUM_TYPE.NO_ROOM);\r\n\r\n      if (commas && (j < decpos)) {\r\n        if (digits === 3) {\r\n          digits = 0;\r\n          str[i--] = this.COMMACHAR;\r\n        }\r\n        digits++;\r\n      }\r\n\r\n      // JPN:15/08/1996 Yama (JpnID:ZA0815001)\r\n      // When Format=\"N12C\" and num is bigger than 12 digits.\r\n      // MAGIC crushes. Because the var i becomes negative.\r\n      if (i < 0)\r\n        return (NUM_TYPE.NO_ROOM);\r\n\r\n      if ((j < 2) || (j >= this.SIGNIFICANT_NUM_SIZE * 2))\r\n        str[i--] = '0';\r\n      else {\r\n        if (i < 0)\r\n          return (NUM_TYPE.NO_ROOM);\r\n        num_char = tmp._data[j >> 1];\r\n        str[i--] = (((j & 1) !== 0) ? (num_char % 10) : (Math.floor(num_char / 10))).toString();\r\n      }\r\n\r\n      if (j === decpos) {\r\n        if (i < 0)\r\n          return (NUM_TYPE.NO_ROOM);\r\n        str[i--] = this.DECIMALCHAR;\r\n\r\n        // 26/11/97 Shay Z. Bug #770526 - If The decimal point is the first\r\n        // in the picture's format - assume that the input value is legal !\r\n        if (i < 0 && pic.decInFirstPos())\r\n          return (0);\r\n      }\r\n    }\r\n\r\n    return (i + 1);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Performing an Add operation on two magic numbers\r\n  /// </summary>\r\n  /// <param name = \"num1\">  the first number\r\n  /// </param>\r\n  /// <param name = \"num2\">  the first number\r\n  /// </param>\r\n  /// <returns> the result\r\n  /// </returns>\r\n  static add(num1: NUM_TYPE, num2: NUM_TYPE): NUM_TYPE {\r\n    let sign1: number;\r\n    let sign2: number;\r\n    let l: number;\r\n    let l1: number;\r\n    let l2: number;\r\n    let SIGNIFICANT_NUM_SIZE: number;\r\n    // null values\r\n    if (num1 === null || num2 === null)\r\n      return null;\r\n\r\n    SIGNIFICANT_NUM_SIZE = GuiEnvironment.Environment.GetSignificantNumSize();\r\n    let tmpres: NUM_TYPE = new NUM_TYPE();\r\n    let res: NUM_TYPE = new NUM_TYPE();\r\n    let operData: OperData = new OperData();\r\n    if (num1.NUM_IS_LONG()) {\r\n      if (num2.NUM_IS_LONG()) {\r\n\r\n        l = l1 = num1.NUM_LONG();\r\n        if (l < 0)\r\n          l = -l;\r\n\r\n        if (l < 0x40000000) {\r\n          l = l2 = num2.NUM_LONG();\r\n          if (l < 0)\r\n            l = -l;\r\n          if (l < 0x40000000) {\r\n            l1 += l2;\r\n            res.NUM_4_LONG(l1);\r\n            return res;\r\n          }\r\n        }\r\n        num2.num_4_std_long();\r\n      }\r\n      num1.num_4_std_long();\r\n    }\r\n    else if (num2.NUM_IS_LONG())\r\n      num2.num_4_std_long();\r\n\r\n    sign1 = NUM_TYPE.toSByte(num1._data[0] & NUM_TYPE.SIGN_MASK);\r\n    operData.NUM_Exp1_ = NUM_TYPE.toSByte(num1._data[0] & ~NUM_TYPE.SIGN_MASK);\r\n    sign2 = NUM_TYPE.toSByte(num2._data[0] & NUM_TYPE.SIGN_MASK);\r\n    operData.NUM_Exp2_ = NUM_TYPE.toSByte(num2._data[0] & ~NUM_TYPE.SIGN_MASK);\r\n    operData.NUM_Diff_ = <number>(operData.NUM_Exp1_ - operData.NUM_Exp2_);\r\n\r\n    let cmpval: number = operData.NUM_Diff_;\r\n    if (cmpval === 0) {\r\n      cmpval = NUM_TYPE.toUByte(num1._data[1]) - NUM_TYPE.toUByte(num2._data[1]);\r\n      if (cmpval === 0)\r\n        cmpval = NUM_TYPE.memcmp(num1, 2, num2, 2, SIGNIFICANT_NUM_SIZE - 2);\r\n    }\r\n\r\n    if (cmpval >= 0) {\r\n      if (sign1 === sign2)\r\n        tmpres = NUM_TYPE.add_pos(num1, num2, operData);\r\n      else\r\n        tmpres = NUM_TYPE.sub_pos(num1, num2, operData);\r\n\r\n      if (tmpres._data[0] !== 0)\r\n        tmpres._data[0] = NUM_TYPE.toSByte(tmpres._data[0] | sign1);\r\n    }\r\n    else {\r\n      let exp: number = operData.NUM_Exp1_;\r\n      operData.NUM_Exp1_ = operData.NUM_Exp2_;\r\n      operData.NUM_Exp2_ = exp;\r\n      operData.NUM_Diff_ = -operData.NUM_Diff_;\r\n\r\n      if (sign1 === sign2)\r\n        tmpres = NUM_TYPE.add_pos(num2, num1, operData);\r\n      else\r\n        tmpres = NUM_TYPE.sub_pos(num2, num1, operData);\r\n\r\n      if (tmpres._data[0] !== 0)\r\n        tmpres._data[0] |= sign2;\r\n    }\r\n\r\n    return tmpres;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Performing a Subtract operation on two magic numbers\r\n  /// </summary>\r\n  /// <param name = \"num1\">  the first number\r\n  /// </param>\r\n  /// <param name = \"num2\">  the first number\r\n  /// </param>\r\n  /// <returns> the result\r\n  /// </returns>\r\n  static sub(num1: NUM_TYPE, num2: NUM_TYPE): NUM_TYPE {\r\n    // null values\r\n    if (num1 === null || num2 === null)\r\n      return null;\r\n\r\n    let tmpres: NUM_TYPE = new NUM_TYPE();\r\n    let res: NUM_TYPE = new NUM_TYPE();\r\n    let operData: OperData = new OperData();\r\n\r\n    if (num1.NUM_IS_LONG()) {\r\n      if (num2.NUM_IS_LONG()) {\r\n        let l: number;\r\n        let l1: number = l = num1.NUM_LONG();\r\n        if (l < 0)\r\n          l = -l;\r\n        if (l < 0x40000000) {\r\n          let l2: number = l = num2.NUM_LONG();\r\n          if (l < 0)\r\n            l = -l;\r\n          if (l < 0x40000000) {\r\n            l1 -= l2;\r\n            res.NUM_4_LONG(l1);\r\n            return res;\r\n          }\r\n        }\r\n        num2.num_4_std_long();\r\n      }\r\n      num1.num_4_std_long();\r\n    }\r\n    else if (num2.NUM_IS_LONG())\r\n      num2.num_4_std_long();\r\n\r\n    let sign1: number = NUM_TYPE.toSByte(num1._data[0] & NUM_TYPE.SIGN_MASK);\r\n    operData.NUM_Exp1_ = NUM_TYPE.toSByte(num1._data[0] & ~NUM_TYPE.SIGN_MASK);\r\n    let sign2: number = NUM_TYPE.toSByte(num2._data[0] & NUM_TYPE.SIGN_MASK);\r\n    operData.NUM_Exp2_ = NUM_TYPE.toSByte(num2._data[0] & ~NUM_TYPE.SIGN_MASK);\r\n    operData.NUM_Diff_ = <number>(operData.NUM_Exp1_ - operData.NUM_Exp2_);\r\n\r\n    let cmpval: number = operData.NUM_Diff_;\r\n    if (cmpval === 0) {\r\n      cmpval = NUM_TYPE.toUByte(num1._data[1]) - NUM_TYPE.toUByte(num2._data[1]);\r\n      if (cmpval === 0)\r\n        cmpval = NUM_TYPE.memcmp(num1, 2, num2, 2, GuiEnvironment.Environment.GetSignificantNumSize() - 2);\r\n    }\r\n\r\n    if (cmpval >= 0) {\r\n      if (sign1 === sign2)\r\n        tmpres = NUM_TYPE.sub_pos(num1, num2, operData);\r\n      else\r\n        tmpres = NUM_TYPE.add_pos(num1, num2, operData);\r\n\r\n    }\r\n    else {\r\n      let exp: number = operData.NUM_Exp1_;\r\n      operData.NUM_Exp1_ = operData.NUM_Exp2_;\r\n      operData.NUM_Exp2_ = exp;\r\n      operData.NUM_Diff_ = -operData.NUM_Diff_;\r\n      if (sign1 === sign2) {\r\n        tmpres = NUM_TYPE.sub_pos(num2, num1, operData);\r\n        sign1 ^= (NUM_TYPE.SIGN_MASK);\r\n      }\r\n      else\r\n        tmpres = NUM_TYPE.add_pos(num2, num1, operData);\r\n    }\r\n\r\n    if (tmpres._data[0] !== 0)\r\n      tmpres._data[0] |= sign1;\r\n\r\n    return tmpres;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Performing a Multiply operation on two magic numbers\r\n  /// </summary>\r\n  /// <param name = \"num1\">  the first number\r\n  /// </param>\r\n  /// <param name = \"num2\">  the first number\r\n  /// </param>\r\n  /// <returns> the result\r\n  /// </returns>\r\n  static mul(num1: NUM_TYPE, num2: NUM_TYPE): NUM_TYPE {\r\n\r\n    let fullres: Int8Array = new Int8Array(38);\r\n    let pwr: number;\r\n    let len1: number;\r\n    let len2: number;\r\n    let pos1: number;\r\n    let pos2: number;\r\n    let pos: number;\r\n    let digit1: number;\r\n    let prod: number;\r\n    let carry: number;\r\n    let l: number;\r\n    let l1: number;\r\n    let l2: number;\r\n    let SIGNIFICANT_NUM_SIZE: number;\r\n\r\n    // null values\r\n    if (num1 === null || num2 === null)\r\n      return null;\r\n\r\n    SIGNIFICANT_NUM_SIZE = GuiEnvironment.Environment.GetSignificantNumSize();\r\n\r\n    let res: NUM_TYPE = new NUM_TYPE();\r\n    let operData: OperData = new OperData();\r\n    let i: number;\r\n    let tmpByte: number;\r\n\r\n    if (num1.NUM_IS_LONG()) {\r\n      if (num2.NUM_IS_LONG()) {\r\n        l = l1 = num1.NUM_LONG();\r\n        if (l < 0)\r\n          l = -l;\r\n        if (l < 0xB000) {\r\n          l = l2 = num2.NUM_LONG();\r\n          if (l < 0)\r\n            l = -l;\r\n          if (l < 0xB000) {\r\n            l1 = l1 * l2;\r\n            res.NUM_4_LONG(l1);\r\n            return res;\r\n          }\r\n        }\r\n        num2.num_4_std_long();\r\n      }\r\n      num1.num_4_std_long();\r\n    }\r\n    else if (num2.NUM_IS_LONG())\r\n        num2.num_4_std_long();\r\n\r\n    operData.NUM_Exp1_ = NUM_TYPE.toSByte(num1._data[0] & ~NUM_TYPE.SIGN_MASK);\r\n    operData.NUM_Exp2_ = NUM_TYPE.toSByte(num2._data[0] & ~NUM_TYPE.SIGN_MASK);\r\n    if (operData.NUM_Exp1_ === 0 || operData.NUM_Exp2_ === 0) {\r\n      res.NUM_ZERO();\r\n      return res;\r\n    }\r\n\r\n    for (len1 = SIGNIFICANT_NUM_SIZE - 1;\r\n         num1._data[len1] === 0;\r\n         len1--) {\r\n    }\r\n    for (len2 = SIGNIFICANT_NUM_SIZE - 1;\r\n         num2._data[len2] === 0;\r\n         len2--) {\r\n    }\r\n\r\n    for (i = 0; i < (NUM_TYPE.NUM_SIZE - 1) * 2; i++)\r\n      fullres[i] = 0;\r\n\r\n    pos = 0;\r\n    for (pos1 = len1; pos1 > 0; pos1--) {\r\n      pos = pos1 + len2 - 1;\r\n      digit1 = num1._data[pos1];\r\n      carry = 0;\r\n\r\n      for (pos2 = len2; pos2 > 0; pos2--) {\r\n        prod = NUM_TYPE.toUByte(digit1) * NUM_TYPE.toUByte(num2._data[pos2]) + carry;\r\n        carry = Math.floor(prod / 100);\r\n        fullres[pos] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(fullres[pos]) + prod % 100);\r\n        tmpByte = fullres[pos];\r\n        pos--;\r\n        if (NUM_TYPE.toUByte(tmpByte) >= 100) {\r\n          fullres[pos + 1] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(fullres[pos + 1]) - 100);\r\n          carry++;\r\n        }\r\n      }\r\n      fullres[pos] = NUM_TYPE.toSByte(carry);\r\n    }\r\n\r\n    pwr = NUM_TYPE.toUByte(operData.NUM_Exp1_) - NUM_TYPE.EXP_BIAS + (NUM_TYPE.toUByte(operData.NUM_Exp2_) - NUM_TYPE.EXP_BIAS);\r\n    if (fullres[0] === 0) {\r\n      pos++;\r\n      pwr--;\r\n    }\r\n\r\n    if ((num1._data[0] & NUM_TYPE.SIGN_MASK) === (num2._data[0] & NUM_TYPE.SIGN_MASK))\r\n      res._data[0] = 0;\r\n    else\r\n      res._data[0] = NUM_TYPE.SIGN_MASK;\r\n\r\n    res._data[0] |= NUM_TYPE.toSByte(pwr + NUM_TYPE.EXP_BIAS);\r\n    for (i = 0; i < SIGNIFICANT_NUM_SIZE - 1; i++)\r\n      res._data[1 + i] = fullres[pos + i];\r\n\r\n    return res;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Performing a Mod operation on two magic numbers\r\n  /// </summary>\r\n  /// <param name = \"num1\">  the first number\r\n  /// </param>\r\n  /// <param name = \"num2\">  the first number\r\n  /// </param>\r\n  /// <returns> the result\r\n  /// </returns>\r\n  static mod(num1: NUM_TYPE, num2: NUM_TYPE): NUM_TYPE {\r\n    // null values\r\n    if (num1 === null || num2 === null)\r\n      return null;\r\n\r\n    let res: NUM_TYPE = new NUM_TYPE();\r\n    if (num2.num_is_zero()) {\r\n      res.NUM_ZERO();\r\n      return res;\r\n    }\r\n\r\n    if (num1.NUM_IS_LONG())\r\n      num1.num_4_std_long();\r\n\r\n    if (num2.NUM_IS_LONG())\r\n      num2.num_4_std_long();\r\n\r\n    res = NUM_TYPE.div(num1, num2);\r\n    res.num_trunc(0);\r\n    res = NUM_TYPE.mul(res, num2);\r\n    res = NUM_TYPE.sub(num1, res);\r\n\r\n    return res;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Performing a Divide operation on two magic numbers\r\n  /// </summary>\r\n  /// <param name = \"num1\">  the first number\r\n  /// </param>\r\n  /// <param name = \"num2\">  the first number\r\n  /// </param>\r\n  /// <returns> the result\r\n  /// </returns>\r\n  static div(num1: NUM_TYPE, num2: NUM_TYPE): NUM_TYPE {\r\n    let dividend: Int8Array = new Int8Array((NUM_TYPE.NUM_SIZE - 1) * 2);\r\n    let divisor: Int8Array = new Int8Array(NUM_TYPE.NUM_SIZE);\r\n    let pwr: number;\r\n    let len1: number;\r\n    let len2: number;\r\n    let pos1: number;\r\n    let pos2: number;\r\n    let pos: number;\r\n    let quot: number;\r\n    let prod: number;\r\n    let carry: number;\r\n    let SIGNIFICANT_NUM_SIZE: number;\r\n\r\n    // null values\r\n    if (num1 === null || num2 === null)\r\n      return null;\r\n\r\n    SIGNIFICANT_NUM_SIZE = GuiEnvironment.Environment.GetSignificantNumSize();\r\n\r\n    let res: NUM_TYPE = new NUM_TYPE();\r\n    let operData: OperData = new OperData();\r\n    let i: number;\r\n    let tmpByte: number;\r\n\r\n    if (num1.NUM_IS_LONG())\r\n      num1.num_4_std_long();\r\n    if (num2.NUM_IS_LONG())\r\n      num2.num_4_std_long();\r\n\r\n    operData.NUM_Exp1_ = NUM_TYPE.toSByte(num1._data[0] & ~NUM_TYPE.SIGN_MASK);\r\n    operData.NUM_Exp2_ = NUM_TYPE.toSByte(num2._data[0] & ~NUM_TYPE.SIGN_MASK);\r\n    if (operData.NUM_Exp1_ === 0 || operData.NUM_Exp2_ === 0) {\r\n      res.NUM_ZERO();\r\n      return res;\r\n    }\r\n\r\n    for (len1 = SIGNIFICANT_NUM_SIZE - 1;\r\n         num1._data[len1] === 0;\r\n         len1--) {\r\n    }\r\n    for (len2 = SIGNIFICANT_NUM_SIZE - 1;\r\n         num2._data[len2] === 0;\r\n         len2--) {\r\n    }\r\n\r\n    pos = (NUM_TYPE.memcmp(num1, 1, num2, 1, len2) < 0) ? 0 : 1;\r\n    for (i = 0; i < (NUM_TYPE.NUM_SIZE - 1) * 2; i++)\r\n      dividend[i] = 0;\r\n\r\n    for (i = 0; i < len1; i++)\r\n      dividend[pos + i] = num1._data[1 + i];\r\n\r\n    for (i = 0; i < len2; i++)\r\n      divisor[1 + i] = num2._data[1 + i];\r\n\r\n    res.NUM_SET_ZERO();\r\n    pwr = NUM_TYPE.toUByte(operData.NUM_Exp1_) - NUM_TYPE.toUByte(operData.NUM_Exp2_) + pos;\r\n    res._data[0] = NUM_TYPE.toSByte(pwr + NUM_TYPE.EXP_BIAS);\r\n    if ((num1._data[0] & NUM_TYPE.SIGN_MASK) !== (num2._data[0] & NUM_TYPE.SIGN_MASK))\r\n      res._data[0] |= NUM_TYPE.SIGN_MASK;\r\n\r\n    // normalize dividend & divisor\r\n    quot = Math.floor(100 / (NUM_TYPE.toUByte(divisor[1]) + 1));\r\n    if (quot > 1) {\r\n      carry = 0;\r\n      for (pos2 = len2; pos2 > 0; pos2--) {\r\n        prod = quot * NUM_TYPE.toUByte(divisor[pos2]) + carry;\r\n        carry = Math.floor(prod / 100);\r\n        divisor[pos2] = NUM_TYPE.toSByte(prod % 100);\r\n      }\r\n\r\n      carry = 0;\r\n      for (pos1 = len1 + pos - 1; pos1 >= 0; pos1--) {\r\n        prod = quot * NUM_TYPE.toUByte(dividend[pos1]) + carry;\r\n        carry = Math.floor(prod / 100);\r\n        dividend[pos1] = NUM_TYPE.toSByte(prod % 100);\r\n      }\r\n    }\r\n\r\n    // divide dividend by divisor\r\n    for (pos1 = 1; pos1 < SIGNIFICANT_NUM_SIZE; pos1++) {\r\n      quot = NUM_TYPE.toUByte(dividend[pos1 - 1]) * 100 + Math.floor(NUM_TYPE.toUByte(dividend[pos1]) / NUM_TYPE.toUByte(divisor[1]));\r\n      if (quot >= 100)\r\n        quot = 99;\r\n\r\n      if (quot !== 0) {\r\n        // multiply divisor by quotient, and subtract from dividend\r\n        pos = pos1 + len2 - 1;\r\n        carry = 0;\r\n        for (pos2 = len2; pos2 > 0; pos2--) {\r\n          prod = quot * NUM_TYPE.toUByte(divisor[pos2]) + carry;\r\n          carry = Math.floor(prod / 100);\r\n          dividend[pos] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(dividend[pos]) - prod % 100);\r\n          tmpByte = dividend[pos];\r\n          pos--;\r\n          if (tmpByte < 0) {\r\n            dividend[pos + 1] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(dividend[pos + 1]) + 100);\r\n            carry++;\r\n          }\r\n        }\r\n        dividend[pos] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(dividend[pos]) - carry);\r\n\r\n        // decrement quotient, and add back divisor to dividend\r\n        while (dividend[pos] < 0) {\r\n          quot--;\r\n          pos = pos1 + len2 - 1;\r\n          for (pos2 = len2; pos2 > 0; pos2--) {\r\n            dividend[pos] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(dividend[pos]) + NUM_TYPE.toUByte(divisor[pos2]));\r\n            tmpByte = dividend[pos];\r\n            pos--;\r\n            if (NUM_TYPE.toUByte(tmpByte) >= 100) {\r\n              dividend[pos + 1] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(dividend[pos + 1]) - 100);\r\n              dividend[pos] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(dividend[pos]) + 1);\r\n            }\r\n          }\r\n        }\r\n      }\r\n      res._data[pos1] = NUM_TYPE.toSByte(quot);\r\n    }\r\n\r\n    return res;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Compare two magic numbers\r\n  /// </summary>\r\n  /// <param name = \"num1\">  The first number\r\n  /// </param>\r\n  /// <param name = \"num2\">  The second number\r\n  /// </param>\r\n  /// <returns> 0 if num1=num2, 1 if num1>num2 or -1 if num1<num2\r\n  /// </returns>\r\n  static num_cmp(num1: NUM_TYPE, num2: NUM_TYPE): number {\r\n    let sign1: number;\r\n    let sign2: number;\r\n    let cmpval: number;\r\n    let l1: number;\r\n    let l2: number;\r\n    let tmp: number;\r\n    let SIGNIFICANT_NUM_SIZE: number;\r\n\r\n    if (num1 == null || num2 == null)\r\n      return Int32.MinValue;\r\n\r\n    SIGNIFICANT_NUM_SIZE = GuiEnvironment.Environment.GetSignificantNumSize();\r\n\r\n    if (num1.NUM_IS_LONG()) {\r\n      if (num2.NUM_IS_LONG()) {\r\n        l1 = num1.NUM_LONG();\r\n        l2 = num2.NUM_LONG();\r\n        if (l1 >= 0 && l2 >= 0) {\r\n          tmp = l1 - l2;\r\n          if (tmp === 0)\r\n            return (0);\r\n          if (tmp > 0)\r\n            return (1);\r\n          return (-1);\r\n    }\r\n            num2.num_4_std_long();\r\n          }\r\n        num1.num_4_std_long();\r\n      }\r\n    else if (num2.NUM_IS_LONG())\r\n          num2.num_4_std_long();\r\n\r\n    sign1 = NUM_TYPE.toSByte(num1._data[0] & NUM_TYPE.SIGN_MASK);\r\n    sign2 = NUM_TYPE.toSByte(num2._data[0] & NUM_TYPE.SIGN_MASK);\r\n    cmpval = (sign1 === sign2)\r\n      ? NUM_TYPE.memcmp(num1, 0, num2, 0, SIGNIFICANT_NUM_SIZE)\r\n      : 1;\r\n    if (sign1 !== 0)\r\n      cmpval = -cmpval;\r\n    return (cmpval);\r\n        }\r\n\r\n  /// <summary>\r\n  ///   Check if the given hex string represents a long number.\r\n  /// </summary>\r\n  /// <param name = \"numHexStr\">  The hex string to check.\r\n  /// </param>\r\n  /// <returns> true, if the string represents a 'long' number in NUM_TYPE.\r\n  /// </returns>\r\n  static numHexStrIsLong(numHexStr: string): boolean {\r\n    return numHexStr.substr(0, 2) === \"FF\";\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Zeroes the Magic Number as a long zero\r\n  /// </summary>\r\n  NUM_ZERO(): void {\r\n    this.setZero(true);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Zeroes the Magic Number (all bytes will set to 0)\r\n  /// </summary>\r\n  NUM_SET_ZERO(): void {\r\n    this.setZero(false);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Getting indication for the sign of the Magic Number\r\n  /// </summary>\r\n  /// <returns> true in the number is negative, false if positive\r\n  /// </returns>\r\n  num_is_neg(): boolean {\r\n    if (this.NUM_IS_LONG())\r\n      return ((this._data[4] & 0x80) !== 0);\r\n    return ((this._data[0] & NUM_TYPE.SIGN_MASK) !== 0);\r\n    }\r\n\r\n  /// <summary>\r\n  ///   Getting indication if the Magic Number is ZERO (all bytes equals to 0)\r\n  /// </summary>\r\n  /// <returns> true in the number is ZERO, false if positive\r\n  /// </returns>\r\n  num_is_zero(): boolean {\r\n    if (this.NUM_IS_LONG())\r\n      return (this.NUM_LONG() === 0);\r\n    return (this._data[0] === 0);\r\n    }\r\n\r\n  /// <summary>\r\n  ///   Changing sign of Magic Number\r\n  /// </summary>\r\n  num_neg(): void {\r\n    let l: number;\r\n\r\n    if (this.NUM_IS_LONG()) {\r\n      l = -this.NUM_LONG();\r\n      this.NUM_4_LONG(l);\r\n      return;\r\n    }\r\n    if (this._data[0] !== 0)\r\n      this._data[0] ^= NUM_TYPE.SIGN_MASK;\r\n      }\r\n\r\n  /// <summary>\r\n  ///   Is the number kept in in the NUM_TYPE is a long number?\r\n  /// </summary>\r\n  /// <returns> true in the number is long, false if not\r\n  /// </returns>\r\n  NUM_IS_LONG(): boolean {\r\n    return this._data[0] === NUM_TYPE.NUM_LONG_TYPE;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Get the long value from the NUM_TYPE.\r\n  ///   THIS FUNCTION MUST BE WRITTEN DIFERENTLY!\r\n  /// </summary>\r\n  /// <returns> the long number\r\n  /// </returns>\r\n  NUM_LONG(): number {\r\n    if (this._data[1] === 0 && this._data[2] === 0 && this._data[3] === 0 && this._data[4] === -128)\r\n      return Int32.MinValue;\r\n\r\n    let dataview = new DataView(this._data.buffer);\r\n    return dataview.getInt32(1, true);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Rounds the NUM_TYPE number\r\n  /// </summary>\r\n  /// <param name = \"decs\">  number of digits after to decimal point to round to\r\n  /// </param>\r\n  round(decs: number): void {\r\n\r\n    let addval: NUM_TYPE;\r\n\r\n    if (this.NUM_IS_LONG())\r\n      return;\r\n\r\n    addval = new NUM_TYPE();\r\n    addval._data[0] = NUM_TYPE.toSByte((this._data[0] & NUM_TYPE.SIGN_MASK) | (NUM_TYPE.EXP_BIAS - (decs >> 1)));\r\n    addval._data[1] = NUM_TYPE.toSByte((decs & 1) !== 0 ? 5 : 50);\r\n\r\n    let temp: NUM_TYPE = NUM_TYPE.add(this, addval);\r\n    this._data = new Int8Array(temp._data.length);\r\n\r\n    this._data = temp._data;\r\n      this.num_trunc(decs);\r\n    }\r\n\r\n  /// <summary>\r\n  ///   Returns a numeric expression, rounded to the specified number of decimal places\r\n  /// </summary>\r\n  /// <param name = \"whole\">the number of decimal places to which the numeric expression is rounded\r\n  /// </param>\r\n  dbRound(whole: number): void {\r\n    let addval: NUM_TYPE;\r\n    let pwr: number;\r\n    let num_diff: number;\r\n    let i: number;\r\n\r\n    if (this.NUM_IS_LONG())\r\n      return;\r\n\r\n    // Add 5 (in the corresponding to whole position)\r\n    addval = new NUM_TYPE();\r\n    addval._data[0] = NUM_TYPE.toSByte((this._data[0] & NUM_TYPE.SIGN_MASK) | (NUM_TYPE.EXP_BIAS + ((whole + 1) >> 1)));\r\n    addval._data[1] = NUM_TYPE.toSByte(((whole & 1) !== 0) ? 5 : 50);\r\n\r\n    let temp: NUM_TYPE = NUM_TYPE.add(this, addval);\r\n    this._data = new Int8Array(temp._data.length);\r\n\r\n      for (let _ai: number = 0; _ai < this._data.length; ++_ai)\r\n      this._data[_ai] = temp._data[_ai];\r\n\r\n    // Put 0 in the end of the number\r\n    pwr = (this._data[0] & ~NUM_TYPE.SIGN_MASK) - NUM_TYPE.EXP_BIAS;\r\n\r\n    if ((num_diff = pwr - ((whole + 1) >> 1)) >= 0) {\r\n      if ((whole & 1) !== 0) {\r\n        this._data[1 + num_diff] = NUM_TYPE.toSByte(this._data[1 + num_diff] - this._data[1 + num_diff] % 10);\r\n        num_diff++;\r\n        }\r\n      for (i = 0;\r\n           i < this.SIGNIFICANT_NUM_SIZE - (1 + num_diff);\r\n           i++)\r\n        this._data[1 + num_diff + i] = 0;\r\n        }\r\n    else\r\n        this.NUM_SET_ZERO();\r\n      }\r\n\r\n  /// <summary>\r\n  ///   Truncates the NUM_TYPE number\r\n  /// </summary>\r\n  /// <param name = \"decs\">  number of digits after to decimal point to have\r\n  /// </param>\r\n  num_trunc(decs: number): void {\r\n    let pwr: number;\r\n    let num_diff: number;\r\n    let i: number;\r\n\r\n    if (this.NUM_IS_LONG())\r\n      return;\r\n\r\n    pwr = (this._data[0] & ~NUM_TYPE.SIGN_MASK) - NUM_TYPE.EXP_BIAS;\r\n    if ((num_diff = this.SIGNIFICANT_NUM_SIZE - 1 - pwr - ((decs + 1) >> 1)) < 0)\r\n      return;\r\n    if ((num_diff < this.SIGNIFICANT_NUM_SIZE - 1) && ((decs & 1) !== 0)) {\r\n      this._data[this.SIGNIFICANT_NUM_SIZE - 1 - num_diff] =\r\n        NUM_TYPE.toSByte(this._data[this.SIGNIFICANT_NUM_SIZE - 1 - num_diff] - this._data[this.SIGNIFICANT_NUM_SIZE - 1 - num_diff] % 10);\r\n      if (this._data[this.SIGNIFICANT_NUM_SIZE - 1 - num_diff] === 0)\r\n        num_diff++;\r\n          }\r\n    if (num_diff >= this.SIGNIFICANT_NUM_SIZE - 1) {\r\n          this.NUM_ZERO();\r\n      return;\r\n        }\r\n    for (i = 0;\r\n         i < num_diff;\r\n         i++)\r\n      this._data[this.SIGNIFICANT_NUM_SIZE - num_diff + i] = 0;\r\n          }\r\n\r\n  /// <summary>\r\n  ///   Converts a Magic number from std long\r\n  /// </summary>\r\n  /// <param name = \"num\">  The number to be translated\r\n  /// </param>\r\n  num_4_std_long(): void {\r\n    let slong: number;\r\n\r\n    slong = this.NUM_LONG();\r\n    if (slong >= 0)\r\n      this.num_4_ulong(slong);\r\n    else {\r\n      this.num_4_ulong(-slong);\r\n      this._data[0] |= NUM_TYPE.SIGN_MASK;\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Converts a Magic number from ulong\r\n  /// </summary>\r\n  /// <param name = \"num\">  The number to be translated\r\n  /// </param>\r\n  num_4_ulong(data: number): void {\r\n    let pwr: number;\r\n    let pos: number;\r\n    let i: number;\r\n\r\n    this.NUM_SET_ZERO();\r\n    pos = pwr = 5;\r\n    while (data > 0) {\r\n      this._data[pos--] = NUM_TYPE.toSByte(data % 100);\r\n      data = Math.floor(data / 100);\r\n    }\r\n    if (pos < pwr) {\r\n      if (pos > 0) {\r\n        for (i = 0; i < pwr - pos; i++)\r\n          this._data[1 + i] = this._data[1 + pos + i];\r\n        for (i = 0; i < pos; i++)\r\n          this._data[pwr - pos + 1 + i] = 0;\r\n        }\r\n      this._data[0] = NUM_TYPE.toSByte(pwr - pos + NUM_TYPE.EXP_BIAS);\r\n        }\r\n      }\r\n\r\n  /// <summary>\r\n  ///   Get the long value from a Magic Number\r\n  /// </summary>\r\n  /// <returns> the long value of the number\r\n  /// </returns>\r\n  NUM_2_LONG(): number {\r\n    if (this.NUM_IS_LONG())\r\n      return this.NUM_LONG();\r\n    else\r\n      return this.num_2_long();\r\n    }\r\n\r\n  /// <summary>\r\n  ///   Get the Ulong value from a Magic Number\r\n  /// </summary>\r\n  /// <returns> the long value of the number\r\n  /// </returns>\r\n  NUM_2_ULONG(): number {\r\n    if (this.NUM_IS_LONG())\r\n      return this.NUM_LONG();\r\n    else\r\n      return this.num_2_ulong();\r\n    }\r\n\r\n  /// <summary>\r\n  ///   Get the long value from a non long Magic Number\r\n  /// </summary>\r\n  /// <returns> the long value of the number\r\n  /// </returns>\r\n  num_2_long(): number {\r\n    let slong: number;\r\n    let sign: number;\r\n\r\n    sign = this._data[0] & NUM_TYPE.SIGN_MASK;\r\n    this._data[0] &= NUM_TYPE.toSByte(~NUM_TYPE.SIGN_MASK);\r\n    if (sign !== 0) {\r\n      if (NUM_TYPE.memcmp(this, 0, NUM_TYPE.MinLONG(), 0, this.SIGNIFICANT_NUM_SIZE) > 0)\r\n        return 0;\r\n      }\r\n    else {\r\n      if (NUM_TYPE.memcmp(this, 0, NUM_TYPE.MaxLONG(), 0, this.SIGNIFICANT_NUM_SIZE) > 0)\r\n        return 0;\r\n      }\r\n    slong = this.num_2_ulong();\r\n    if (sign !== 0) {\r\n      slong = -slong;\r\n      this._data[0] |= NUM_TYPE.toSByte(sign);\r\n    }\r\n    return (slong);\r\n    }\r\n\r\n  /// <summary>\r\n  ///   Get the ulong value from a non long Magic Number\r\n  /// </summary>\r\n  /// <returns> the ulong value of the number\r\n  /// </returns>\r\n  num_2_ulong(): number {\r\n    let val: number;\r\n    let pwr: number;\r\n    let pos: number;\r\n    let last: boolean;\r\n\r\n    pwr = this._data[0] - NUM_TYPE.EXP_BIAS;\r\n    if (pwr > 5)\r\n      return (0);\r\n    last = (pwr === 5);\r\n    if (last)\r\n      pwr = 4;\r\n\r\n    val = 0;\r\n    for (pos = 1; pos <= pwr; pos++)\r\n      val = val * 100 + NUM_TYPE.toUByte(this._data[pos]);\r\n\r\n    if (last)\r\n      if (val <= Math.floor((0xFFFFFFFF - NUM_TYPE.toUByte(this._data[5])) / 100))\r\n        val = val * 100 + NUM_TYPE.toUByte(this._data[5]);\r\n      else\r\n        val = 0;\r\n    return (val);\r\n    }\r\n\r\n  /// <summary>\r\n  ///   Perform the actuall add operation\r\n  /// </summary>\r\n  /// <param name = \"num1\">      The first number\r\n  /// </param>\r\n  /// <param name = \"num2\">      The second number\r\n  /// </param>\r\n  /// <param name = \"operData\">  Information for performing the operation\r\n  /// </param>\r\n  /// <returns> The two numbers added\r\n  /// </returns>\r\n  static add_pos(num1: NUM_TYPE, num2: NUM_TYPE, operData: OperData): NUM_TYPE {\r\n    let len1: number;\r\n    let len2: number;\r\n    let len: number;\r\n    let pos: number;\r\n    let num1ptr: number;\r\n    let resptr: number;\r\n    let i: number;\r\n    let SIGNIFICANT_NUM_SIZE: number;\r\n\r\n    // null values\r\n    if (num1 == null || num2 == null)\r\n      return null;\r\n    SIGNIFICANT_NUM_SIZE = GuiEnvironment.Environment.GetSignificantNumSize();\r\n\r\n    let res: NUM_TYPE = new NUM_TYPE();\r\n\r\n    if (operData.NUM_Exp2_ === 0 || (operData.NUM_Diff_ >= SIGNIFICANT_NUM_SIZE - 1)) {\r\n      res = new NUM_TYPE(num1);\r\n      res._data[0] = operData.NUM_Exp1_;\r\n      return res;\r\n    }\r\n\r\n    len1 = 1;\r\n    for (i = SIGNIFICANT_NUM_SIZE - 2; i > 0; i -= 2) {\r\n      if (num1.SHRT_IS_ZERO(i))\r\n        continue;\r\n    else {\r\n        len1 = i + 1;\r\n            break;\r\n          }\r\n        }\r\n\r\n    if (num1._data[len1] === 0)\r\n      len1--;\r\n\r\n    len2 = 1;\r\n    for (i = SIGNIFICANT_NUM_SIZE - 2; i > 0; i -= 2) {\r\n      if (num2.SHRT_IS_ZERO(i))\r\n        continue;\r\n      else {\r\n        len2 = i + 1;\r\n            break;\r\n          }\r\n        }\r\n\r\n    if (num2._data[len2] === 0)\r\n      len2--;\r\n\r\n    if ((len = Math.max(len1, len2 + operData.NUM_Diff_)) > SIGNIFICANT_NUM_SIZE - 1)\r\n      len = SIGNIFICANT_NUM_SIZE - 1;\r\n\r\n    res.NUM_SET_ZERO();\r\n    num1ptr = operData.NUM_Diff_;\r\n    resptr = operData.NUM_Diff_;\r\n    for (pos = len - operData.NUM_Diff_; pos > 0; pos--) {\r\n      res._data[resptr + pos] =\r\n        NUM_TYPE.toSByte(NUM_TYPE.toUByte(res._data[resptr + pos]) + NUM_TYPE.toUByte(num1._data[num1ptr + pos]) + NUM_TYPE.toUByte(num2._data[pos]));\r\n      if (NUM_TYPE.toUByte(res._data[resptr + pos]) >= 100) {\r\n        res._data[resptr + pos] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(res._data[resptr + pos]) - 100);\r\n        res._data[resptr + pos - 1] = 1;\r\n        }\r\n        }\r\n    for (pos = operData.NUM_Diff_; pos > 0; pos--) {\r\n      res._data[pos] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(res._data[pos]) + NUM_TYPE.toUByte(num1._data[pos]));\r\n      if (NUM_TYPE.toUByte(res._data[pos]) >= 100) {\r\n        res._data[pos] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(res._data[pos]) - 100);\r\n        res._data[pos - 1] = 1;\r\n          }\r\n        }\r\n    if (res._data[0] !== 0) {\r\n      for (pos = Math.min(len, SIGNIFICANT_NUM_SIZE - 2); pos >= 0; pos--)\r\n        res._data[pos + 1] = res._data[pos];\r\n      operData.NUM_Exp1_++;\r\n          }\r\n    res._data[0] = operData.NUM_Exp1_;\r\n\r\n    return res;\r\n        }\r\n\r\n  /// <summary>\r\n  ///   Perform the actuall sub operation\r\n  /// </summary>\r\n  /// <param name = \"num1\">      The first number\r\n  /// </param>\r\n  /// <param name = \"num2\">      The second number\r\n  /// </param>\r\n  /// <param name = \"operData\">  Information for performing the operation\r\n  /// </param>\r\n  /// <returns> The result of the subtraction operation\r\n  /// </returns>\r\n  static sub_pos(num1: NUM_TYPE, num2: NUM_TYPE, operData: OperData): NUM_TYPE {\r\n    let len1: number;\r\n    let len2: number;\r\n    let len: number;\r\n    let pos: number;\r\n    let num1ptr: number;\r\n    let resptr: number;\r\n    let i: number;\r\n    let SIGNIFICANT_NUM_SIZE: number;\r\n\r\n    // null values\r\n    if (num1 == null || num2 == null)\r\n      return null;\r\n\r\n    SIGNIFICANT_NUM_SIZE = GuiEnvironment.Environment.GetSignificantNumSize();\r\n\r\n    let res: NUM_TYPE = new NUM_TYPE();\r\n    let j: number;\r\n\r\n    if (operData.NUM_Exp2_ === 0 || (operData.NUM_Diff_ >= SIGNIFICANT_NUM_SIZE - 1)) {\r\n      res = new NUM_TYPE(num1);\r\n      res._data[0] = operData.NUM_Exp1_;\r\n      return res;\r\n    }\r\n\r\n    len1 = 1;\r\n    for (i = SIGNIFICANT_NUM_SIZE - 2; i > 0; i -= 2) {\r\n      if (num1.SHRT_IS_ZERO(i))\r\n        continue;\r\n    else {\r\n        len1 = i + 1;\r\n            break;\r\n          }\r\n        }\r\n\r\n    if (num1._data[len1] === 0)\r\n      len1--;\r\n\r\n    len2 = 1;\r\n    for (i = SIGNIFICANT_NUM_SIZE - 2; i > 0; i -= 2) {\r\n      if (num2.SHRT_IS_ZERO(i))\r\n        continue;\r\n      else {\r\n        len2 = i + 1;\r\n            break;\r\n          }\r\n        }\r\n\r\n    if (num2._data[len2] === 0)\r\n      len2--;\r\n\r\n    if ((len = Math.max(len1, len2 + operData.NUM_Diff_)) > SIGNIFICANT_NUM_SIZE - 1)\r\n      len = SIGNIFICANT_NUM_SIZE - 1;\r\n\r\n    res.NUM_SET_ZERO();\r\n    num1ptr = operData.NUM_Diff_;\r\n    resptr = operData.NUM_Diff_;\r\n    for (pos = len - operData.NUM_Diff_; pos > 0; pos--) {\r\n\r\n      res._data[resptr + pos] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(res._data[resptr + pos]) + NUM_TYPE.toUByte(num1._data[num1ptr + pos]) - NUM_TYPE.toUByte(num2._data[pos]));\r\n      if (res._data[resptr + pos] < 0) {\r\n        res._data[resptr + pos] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(res._data[resptr + pos]) + 100);\r\n        res._data[resptr + pos - 1] = NUM_TYPE.toSByte(0xFF); // 255\r\n        }\r\n            }\r\n    for (pos = operData.NUM_Diff_; pos > 0; pos--) {\r\n      res._data[pos] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(res._data[pos]) + NUM_TYPE.toUByte(num1._data[pos]));\r\n      if (res._data[pos] < 0) {\r\n        res._data[pos] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(res._data[pos]) + 100);\r\n        res._data[pos - 1] = NUM_TYPE.toSByte(0xFF); // 255\r\n            }\r\n          }\r\n    while ((++pos <= len) && res._data[pos] === 0) {\r\n        }\r\n    if (pos <= len) {\r\n      operData.NUM_Diff_ = pos - 1;\r\n      if (operData.NUM_Diff_ > 0) {\r\n        for (j = 0; j < len - operData.NUM_Diff_; j++)\r\n          res._data[1 + j] = res._data[pos + j];\r\n        for (j = 0; j < operData.NUM_Diff_; j++)\r\n          res._data[len - operData.NUM_Diff_ + 1 + j] = 0;\r\n      }\r\n      res._data[0] = NUM_TYPE.toSByte(NUM_TYPE.toUByte(operData.NUM_Exp1_) - operData.NUM_Diff_);\r\n    }\r\n\r\n    return res;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Perform the actual  FIX operation with whole part of the number\r\n  /// </summary>\r\n  /// <param name = \"wholes\">number of needed whole digits\r\n  /// </param>\r\n  num_fix(wholes: number): void {\r\n    let pwr: number;\r\n    let num_diff: number;\r\n\r\n    if (this.NUM_IS_LONG())\r\n      this.num_4_std_long();\r\n    pwr = (this._data[0] & ~NUM_TYPE.SIGN_MASK) - NUM_TYPE.EXP_BIAS;\r\n\r\n    if ((num_diff = pwr - ((wholes + 1) >> 1)) < 0)\r\n      return;\r\n    if (num_diff < this.SIGNIFICANT_NUM_SIZE - 1) {\r\n      if ((wholes & 1) === 1)\r\n        this._data[1 + num_diff] = NUM_TYPE.toSByte(this._data[1 + num_diff] % 10);\r\n      while ((num_diff < this.SIGNIFICANT_NUM_SIZE - 1) && this._data[1 + num_diff] === 0)\r\n        num_diff++;\r\n      }\r\n    if (num_diff >= this.SIGNIFICANT_NUM_SIZE - 1) {\r\n        this.NUM_ZERO();\r\n      return;\r\n      }\r\n    if (num_diff > 0) {\r\n      let i: number;\r\n      for (i = 0; i < this.SIGNIFICANT_NUM_SIZE - 1 - num_diff; i++)\r\n        this._data[1 + i] = this._data[1 + num_diff + i];\r\n\r\n      for (i = 0; i < num_diff; i++)\r\n        this._data[this.SIGNIFICANT_NUM_SIZE - num_diff + i] = 0;\r\n      this._data[0] = NUM_TYPE.toSByte(this._data[0] - NUM_TYPE.toSByte(num_diff));\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  ///   check if byte on specific position is zero or 0xFF\r\n  /// </summary>\r\n  /// <param name = \"position\">in NUM to be checked\r\n  /// </param>\r\n  /// <returns> is the byte zero\r\n  /// </returns>\r\n  SHRT_IS_ZERO(pos: number): boolean {\r\n    return this._data[pos] === 0 && this._data[pos + 1] === 0;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Zero a Magic Number. If the number should contain a long zero, the first\r\n  ///   byte is set to NUM_LONG_TYPE.\r\n  /// </summary>\r\n  /// <param name = \"asLong\">  set the Magic Number to contain a long zero value\r\n  /// </param>\r\n  private setZero(asLong: boolean): void {\r\n    let i: number;\r\n\r\n    for (i = 0; i < NUM_TYPE.NUM_SIZE; i++)\r\n      this._data[i] = 0;\r\n\r\n    if (asLong)\r\n      this._data[0] = NUM_TYPE.NUM_LONG_TYPE;\r\n    }\r\n\r\n  /// <summary>\r\n  ///   Compare two Magic Numbers\r\n  /// </summary>\r\n  /// <param name = \"num1\">  The first number\r\n  /// </param>\r\n  /// <param name = \"pos1\">  The position of num1 to compare from\r\n  /// </param>\r\n  /// <param name = \"num2\">  The second number\r\n  /// </param>\r\n  /// <param name = \"pos3\">  The position of num2 to compare from\r\n  /// </param>\r\n  /// <returns> 0 if identical, 1 if num1>num2, -1 if num1<num2\r\n  /// </returns>\r\n  private static memcmp(num1: NUM_TYPE, pos1: number, num2: NUM_TYPE, pos2: number, len: number): number {\r\n    let i: number = 0;\r\n\r\n    while (i < len && num1._data[pos1] === num2._data[pos2] && pos1 < NUM_TYPE.NUM_SIZE && pos2 < NUM_TYPE.NUM_SIZE) {\r\n      i++;\r\n      pos1++;\r\n      pos2++;\r\n    }\r\n\r\n    if (i === len)\r\n      return 0;\r\n    else if (this.toUByte(num1._data[pos1]) < this.toUByte(num2._data[pos2]))\r\n      return -1;\r\n    else\r\n      return 1;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Get a unsigned value from a byte\r\n  /// </summary>\r\n  /// <param name = \"byteVal\">  A signed byte value\r\n  /// </param>\r\n  /// <returns> the unsigned value of the byte\r\n  /// </returns>\r\n  static toUByte(byteVal: number): number {\r\n    let val: number = byteVal;\r\n\r\n    if (byteVal < 0)\r\n      val = 256 + byteVal;\r\n\r\n    return val;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Get a signed byte value from a unsigned val\r\n  /// </summary>\r\n  /// <param name = \"signedVal\">  An unsigned byte value (as an integer)\r\n  /// </param>\r\n  /// <returns> the signed value as a byte\r\n  /// </returns>\r\n  static toSByte(unsignedVal: number): number {\r\n    let val: number = 0;\r\n\r\n    if (unsignedVal > Constants.SByteMaxValue)\r\n      val = (unsignedVal - 256);\r\n    else\r\n      val = unsignedVal;\r\n\r\n    return val;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Get the maximum long number in NUM_TYPE std format\r\n  /// </summary>\r\n  static MaxLONG(): NUM_TYPE {\r\n    let nUM_TYPE: NUM_TYPE = new NUM_TYPE();\r\n    nUM_TYPE._data[0] = NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 5);\r\n    nUM_TYPE._data[1] = 21;\r\n    nUM_TYPE._data[2] = 47;\r\n    nUM_TYPE._data[3] = 48;\r\n    nUM_TYPE._data[4] = 36;\r\n    nUM_TYPE._data[5] = 47;\r\n    return nUM_TYPE;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Get the minimum long number in NUM_TYPE std format\r\n  /// </summary>\r\n  static MinLONG(): NUM_TYPE {\r\n    let num: NUM_TYPE = new NUM_TYPE();\r\n    num._data[0] = NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 5);\r\n    num._data[1] = 21;\r\n    num._data[2] = 47;\r\n    num._data[3] = 48;\r\n    num._data[4] = 36;\r\n    num._data[5] = 48;\r\n    return num;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Get double number from Magic NUM_TYPE\r\n  /// </summary>\r\n  to_double(): number {\r\n    return this.storage_mg_2_float(8); // Length of double is 8 byte\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Get double number from Magic NUM_TYPE\r\n  /// </summary>\r\n  /// <param name = \"len\">of byte of needed number - USE 8\r\n  /// </param>\r\n  private storage_mg_2_float(len: number): number {\r\n    let sign_pos: number;\r\n    let sign: number;\r\n    let compnum: NUM_TYPE = new NUM_TYPE();\r\n    let tmpnum: NUM_TYPE = new NUM_TYPE();\r\n    let divnum: NUM_TYPE = new NUM_TYPE();\r\n    let pwr: number;\r\n    let bits: number;\r\n    let exp: number;\r\n    let long1: number = 0;\r\n    let long2: number = 0;\r\n    let fltOut: number = 0;\r\n    let cout: Int8Array = new Int8Array([0, 0, 0, 0, 0, 0, 0, 0]);\r\n    let Num2Pwr23_: Int8Array = new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 4), 8, 38, 86, 8]);\r\n    let Num2Pwr52_: Int8Array = new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 8), 45, 3, 59, 96, 27, 37, 4, 96]);\r\n    let base_Num16Pwrs: Int8Array[] = [\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 1), 1]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 1), 16]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 2), 2, 56]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 2), 40, 96]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 3), 6, 55, 36]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 4), 1, 4, 85, 76]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 4), 16, 77, 72, 16]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 5), 2, 68, 43, 54, 56]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 5), 42, 94, 96, 72, 96]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 6), 6, 87, 19, 47, 67, 36]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 7), 1, 9, 95, 11, 62, 77, 76]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 7), 17, 59, 21, 86, 4, 44, 16]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 8), 2, 81, 47, 49, 76, 71, 6, 56]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 8), 45, 3, 59, 96, 27, 37, 4, 96]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 9), 7, 20, 57, 59, 40, 37, 92, 79, 36])\r\n    ];\r\n\r\n    let base_Num2Pwrs: Int8Array[] = [\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 1), 1]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 1), 2]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 1), 4]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 1), 8])\r\n      ];\r\n\r\n    if (this.NUM_IS_LONG())\r\n      this.num_4_std_long();\r\n    if (this._data[0] === 0)\r\n      return 0;\r\n    sign = NUM_TYPE.toSByte(this._data[0] & NUM_TYPE.SIGN_MASK);\r\n    this._data[0] = NUM_TYPE.toSByte(this._data[0] & <number>(~NUM_TYPE.SIGN_MASK));\r\n    if (len === 4) {\r\n      bits = 24;\r\n      compnum = new NUM_TYPE(Num2Pwr23_);\r\n    }\r\n    else {\r\n      bits = 53;\r\n      compnum = new NUM_TYPE(Num2Pwr52_);\r\n    }\r\n    pwr = (this._data[0] - NUM_TYPE.EXP_BIAS) << 1;\r\n    if (pwr < 0)\r\n      exp = pwr * 3 + Math.floor((pwr + 1) / 3);\r\n    else exp = pwr * 3 + Math.floor((pwr + 2) / 3);\r\n    pwr = bits - exp;\r\n    if (pwr < 0) {\r\n      pwr = -pwr;\r\n      tmpnum = NUM_TYPE.div(this, new NUM_TYPE(base_Num16Pwrs[pwr >> 2]));\r\n      tmpnum = NUM_TYPE.div(tmpnum, new NUM_TYPE(base_Num2Pwrs[pwr & 3]));\r\n    }\r\n    else {\r\n      tmpnum = this;\r\n      while (pwr >= 60) {\r\n        tmpnum = NUM_TYPE.mul(tmpnum, new NUM_TYPE(base_Num16Pwrs[14]));\r\n        pwr -= 56;\r\n      }\r\n      tmpnum = NUM_TYPE.mul(tmpnum, new NUM_TYPE(base_Num16Pwrs[pwr >> 2]));\r\n      tmpnum = NUM_TYPE.mul(tmpnum, new NUM_TYPE(base_Num2Pwrs[pwr & 3]));\r\n    }\r\n    while (NUM_TYPE.num_cmp(tmpnum, compnum) < 0) {\r\n      exp--;\r\n      tmpnum = NUM_TYPE.add(tmpnum, tmpnum);\r\n    }\r\n    if (len === 4) {\r\n      long1 = tmpnum.num_2_ulong();\r\n    }\r\n    else {\r\n      divnum = NUM_TYPE.div(tmpnum, new NUM_TYPE(base_Num16Pwrs[8]));\r\n      divnum.num_trunc(0);\r\n      long1 = divnum.num_2_ulong();\r\n      divnum = NUM_TYPE.mul(divnum, new NUM_TYPE(base_Num16Pwrs[8]));\r\n      divnum = NUM_TYPE.sub(tmpnum, divnum);\r\n      long2 = divnum.num_2_ulong();\r\n    }\r\n    sign_pos = len - 1;\r\n    if (len === 4) {\r\n      exp += 126;\r\n      cout[3] = NUM_TYPE.toSByte(exp >> 1);\r\n      cout[2] = NUM_TYPE.toSByte((this.LO_CHAR(this.HI_SHRT(long1)) & 0x7F) | ((exp & 0x01) << 7));\r\n      cout[1] = NUM_TYPE.toSByte(this.HI_CHAR(this.LO_SHRT(long1)));\r\n      cout[0] = NUM_TYPE.toSByte(this.LO_CHAR(this.LO_SHRT(long1)));\r\n    }\r\n    else {\r\n      exp += 1022;\r\n      cout[7] = NUM_TYPE.toSByte(exp >> 4);\r\n\r\n      cout[6] = NUM_TYPE.toSByte((this.LO_CHAR(this.HI_SHRT(long1)) & 0x0F) | ((exp & 0x0F) << 4));\r\n\r\n      cout[5] = NUM_TYPE.toSByte(this.HI_CHAR(this.LO_SHRT(long1)));\r\n\r\n      cout[4] = NUM_TYPE.toSByte(this.LO_CHAR(this.LO_SHRT(long1)));\r\n      cout[3] = NUM_TYPE.toSByte(this.HI_CHAR(this.HI_SHRT(long2)));\r\n      cout[2] = NUM_TYPE.toSByte(this.LO_CHAR(this.HI_SHRT(long2)));\r\n      cout[1] = NUM_TYPE.toSByte(this.HI_CHAR(this.LO_SHRT(long2)));\r\n      cout[0] = NUM_TYPE.toSByte(this.LO_CHAR(this.LO_SHRT(long2)));\r\n    }\r\n    if (sign !== 0) {\r\n      cout[sign_pos] |= NUM_TYPE.SIGN_MASK;\r\n      this._data[0] |= NUM_TYPE.SIGN_MASK;\r\n    }\r\n    fltOut = this.sbyteArr_2_Double(cout);\r\n    return fltOut;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Bit_Wise mask : Leave last byte in number\r\n  /// </summary>\r\n  private LO_CHAR(n: number): number {\r\n    return n & 255;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Bit_Wise mask : Leave byte before last\r\n  /// </summary>\r\n  private HI_CHAR(n: number): number {\r\n    return (n & 65280) >> 8;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Bit_Wise mask : Leave 2 last bytes\r\n  /// </summary>\r\n  private LO_SHRT(n: number): number {\r\n    return <number>(n & 65535);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Bit_Wise mask\r\n  /// </summary>\r\n  private HI_SHRT(n: number): number {\r\n    return <number>((n & -65536) >> 16);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Bit_Wise mask\r\n  /// </summary>\r\n  private static MK_SHRT(c1: number, c2: number): number {\r\n    let strInt: string = (c1 << 8 | c2).toString();\r\n    return NNumber.Parse(strInt);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Bit_Wise mask\r\n  /// </summary>\r\n  private static MK_LONG(s1: number, s2: number): number {\r\n    let l1: number = <number>s1;\r\n    let l2: number = <number>s2;\r\n    let strLng: string = (l1 << 16 | l2).toString();\r\n    return NNumber.Parse(strLng);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   get the double from array of bytes\r\n  /// </summary>\r\n  /// <param name = \"array\">of bytes, inner representation of the double\r\n  /// </param>\r\n  /// <returns> double\r\n  /// </returns>\r\n  private sbyteArr_2_Double(array: Int8Array): number {\r\n    let dataview = new DataView(array.buffer);\r\n    return dataview.getFloat64(0, true);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   get byte array for double (8 bytes in Java)\r\n  /// </summary>\r\n  /// <param name = \"double\">to get its byte representation\r\n  /// </param>\r\n  /// <returns> byte array\r\n  /// </returns>\r\n  private static double_2_sbyteArray(d: number): Int8Array {\r\n    let buffer = new ArrayBuffer(8);\r\n    let dataview = new DataView(buffer);\r\n    dataview.setFloat64(0, d, true);\r\n    return (new Int8Array(dataview.buffer));\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Performing an Power operation on two magic numbers Val1^Val2\r\n  /// </summary>\r\n  /// <param name = \"num1\">  the first number - number\r\n  /// </param>\r\n  /// <param name = \"num2\">  the first number - power\r\n  /// </param>\r\n  /// <returns> the result\r\n  /// </returns>\r\n  static eval_op_pwr(num1: NUM_TYPE, num2: NUM_TYPE): NUM_TYPE {\r\n    let d0: number;\r\n    let d1: number;\r\n\r\n    // null values\r\n    if (num1 == null || num2 == null)\r\n      return null;\r\n\r\n    // If second operator is an integer (which is so in most of the cases)\r\n    // and it is not -ve, then calculate power using simple multiplication\r\n    // There is a problem in from_double as it doesn't return exact\r\n    // values (for example, passing 1.002441 in num to from_double would\r\n    // return 1.00244099999999). btw, this problem exists even in Visual studio's\r\n    // watch window (try typing 1.002441 in Name column of watch window).\r\n    if (num2.NUM_IS_LONG() && !num2.num_is_neg()) {\r\n      d1 = num2.to_double();\r\n      let result: NUM_TYPE = NUM_TYPE.from_double(1);\r\n      for (let i: number = 0; i < d1; i++)\r\n        result = this.mul(result, num1);\r\n      return result;\r\n        }\r\n        else {\r\n      d0 = num1.to_double();\r\n      d1 = num2.to_double();\r\n      if (d0 < 0.0 && d1 !== <number> d1)\r\n        d0 = 0.0;\r\n      /* pwr (0.0, 0.0) -> error */\r\n      /* ----------------------- */\r\n      else if (d0 !== 0.0)\r\n        d0 = Math.pow(d0, d1);\r\n    }\r\n\r\n    return NUM_TYPE.from_double(d0);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   translate double to NUM_TYPE\r\n  /// </summary>\r\n  /// <param name = \"double\">to translate\r\n  /// </param>\r\n  /// <returns> NUM_TYPE of the double\r\n  /// </returns>\r\n  static from_double(d0: number): NUM_TYPE {\r\n    let array: Int8Array = NUM_TYPE.double_2_sbyteArray(d0);\r\n    return NUM_TYPE.storage_mg_4_float(8, array);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   translate byte array  to NUM_TYPE\r\n  /// </summary>\r\n  /// <param name = \"len\">of the needed number(8)\r\n  /// </param>\r\n  /// <param name = \"byte\">array mask\r\n  /// </param>\r\n  /// <returns> NUM_TYPE for the needed attributes\r\n  /// </returns>\r\n  private static storage_mg_4_float(len: number, inp: Int8Array): NUM_TYPE {\r\n    let cinp: number[];\r\n    let sign: number;\r\n    let tmp1: number;\r\n    let exp: number;\r\n    let bias: number;\r\n    let long1: number;\r\n    let long2: number;\r\n\r\n    cinp = new Array<number>(inp.length);\r\n    for (tmp1 = 0;\r\n         tmp1 < inp.length;\r\n         tmp1++)\r\n      cinp[tmp1] = NUM_TYPE.toUByte(inp[tmp1]);\r\n\r\n    sign = cinp[len - 1];\r\n    if (len === 4) {\r\n      exp = <number>((cinp[2] >> 7) | ((cinp[3] & 0x7F) << 1));\r\n      bias = 150; // 126 + (1 + 23);\r\n      long1 = 0;\r\n      long2 = NUM_TYPE.MK_LONG(NUM_TYPE.MK_SHRT(0, cinp[2] | 0x80), NUM_TYPE.MK_SHRT(cinp[1], cinp[0]));\r\n    }\r\n    else {\r\n      exp = <number>(((cinp[7] & 0x7F) << 4) | (cinp[6] >> 4));\r\n      bias = 1075; // 1022 + (1 + 20 + 32);\r\n      long1 = NUM_TYPE.MK_LONG(NUM_TYPE.MK_SHRT(0, (cinp[6] & 0x0F) | 0x10), NUM_TYPE.MK_SHRT(cinp[5], cinp[4]));\r\n      long2 = NUM_TYPE.MK_LONG(NUM_TYPE.MK_SHRT(cinp[3], cinp[2]), NUM_TYPE.MK_SHRT(cinp[1], cinp[0]));\r\n    }\r\n    return NUM_TYPE.storage_num_4_fld_flt(long1, long2, 18, sign, bias, exp);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   translate byte array  to NUM_TYPE (like in Magic Souce code).\r\n  /// </summary>\r\n  private static storage_num_4_fld_flt(long1: number, long2: number, dec: number, sign: number, bias: number, expr: number): NUM_TYPE {\r\n    let base_Num16Pwrs: Int8Array[] = [\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 1), 1]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 1), 16]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 2), 2, 56]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 2), 40, 96]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 3), 6, 55, 36]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 4), 1, 4, 85, 76]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 4), 16, 77, 72, 16]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 5), 2, 68, 43, 54, 56]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 5), 42, 94, 96, 72, 96]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 6), 6, 87, 19, 47, 67, 36]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 7), 1, 9, 95, 11, 62, 77, 76]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 7), 17, 59, 21, 86, 4, 44, 16]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 8), 2, 81, 47, 49, 76, 71, 6, 56]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 8), 45, 3, 59, 96, 27, 37, 4, 96]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 9), 7, 20, 57, 59, 40, 37, 92, 79, 36])\r\n    ];\r\n\r\n    let base_Num2Pwrs: Int8Array[] = [\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 1), 1]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 1), 2]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 1), 4]),\r\n      new Int8Array([NUM_TYPE.toSByte(NUM_TYPE.EXP_BIAS + 1), 8])\r\n    ];\r\n    let tmpnum: NUM_TYPE = new NUM_TYPE();\r\n    let outVal: NUM_TYPE = new NUM_TYPE();\r\n    let exp: number = <number>expr;\r\n    if (exp === 0) {\r\n      outVal.NUM_ZERO();\r\n      return outVal;\r\n    }\r\n    outVal.num_4_ulong(long2);\r\n    if (long1 !== 0) {\r\n      tmpnum.num_4_ulong(long1);\r\n      tmpnum = NUM_TYPE.mul(tmpnum, new NUM_TYPE(base_Num16Pwrs[8]));\r\n      outVal = NUM_TYPE.add(tmpnum, outVal);\r\n    }\r\n    exp = <number>(exp - bias);\r\n    if (exp < 0) {\r\n      exp = -exp;\r\n      while (exp >= 60) {\r\n        outVal = NUM_TYPE.div(outVal, new NUM_TYPE(base_Num16Pwrs[14]));\r\n        exp -= 56;\r\n      }\r\n      tmpnum = NUM_TYPE.mul(new NUM_TYPE(base_Num16Pwrs[exp >> 2]),\r\n        new NUM_TYPE(base_Num2Pwrs[exp & 3]));\r\n      outVal = NUM_TYPE.div(outVal, tmpnum);\r\n    }\r\n    else {\r\n      if (exp >= 60) {\r\n        outVal.NUM_ZERO();\r\n        return outVal;\r\n      }\r\n      tmpnum = NUM_TYPE.mul(new NUM_TYPE(base_Num16Pwrs[exp >> 2]),\r\n        new NUM_TYPE(base_Num2Pwrs[exp & 3]));\r\n      outVal = NUM_TYPE.mul(outVal, tmpnum);\r\n    }\r\n    if ((sign & 0x80) !== 0)\r\n      outVal._data[0] = outVal._data[0] | NUM_TYPE.SIGN_MASK;\r\n    outVal.round(dec);\r\n    return outVal;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Mathematical functions implementation\r\n  /// </summary>\r\n  static eval_op_log(val1: NUM_TYPE): NUM_TYPE {\r\n    if (val1 == null)\r\n      return null;\r\n    let resVal: NUM_TYPE = new NUM_TYPE();\r\n    let d: number = val1.to_double();\r\n\r\n    if (d > 0.0)\r\n      resVal = NUM_TYPE.from_double(Math.log(d));\r\n    else\r\n      resVal.NUM_ZERO();\r\n    return resVal;\r\n  }\r\n\r\n  static eval_op_exp(val1: NUM_TYPE): NUM_TYPE {\r\n    let resVal: NUM_TYPE;\r\n\r\n    if (val1 === null)\r\n      return null;\r\n      let d: number = val1.to_double();\r\n    resVal = NUM_TYPE.from_double(Math.exp(d));\r\n    return resVal;\r\n  }\r\n\r\n  static eval_op_abs(val1: NUM_TYPE): NUM_TYPE {\r\n    if (val1 === null)\r\n      return null;\r\n    let resVal: NUM_TYPE = new NUM_TYPE(val1);\r\n    resVal.num_abs();\r\n    return resVal;\r\n  }\r\n\r\n  static eval_op_sin(val1: NUM_TYPE): NUM_TYPE {\r\n    if (val1 === null)\r\n      return null;\r\n    let resVal: NUM_TYPE = new NUM_TYPE();\r\n    let d: number = val1.to_double();\r\n    resVal = NUM_TYPE.from_double(Math.sin(d));\r\n    return resVal;\r\n  }\r\n\r\n  static eval_op_cos(val1: NUM_TYPE): NUM_TYPE {\r\n    if (val1 === null)\r\n      return null;\r\n    let resVal: NUM_TYPE = new NUM_TYPE();\r\n      let d: number = val1.to_double();\r\n    resVal = NUM_TYPE.from_double(Math.cos(d));\r\n    return resVal;\r\n  }\r\n\r\n  static eval_op_tan(val1: NUM_TYPE): NUM_TYPE {\r\n    if (val1 == null)\r\n      return null;\r\n    let resVal: NUM_TYPE = new NUM_TYPE();\r\n    let d: number = val1.to_double();\r\n    resVal = NUM_TYPE.from_double(Math.tan(d));\r\n    return resVal;\r\n  }\r\n\r\n  static eval_op_asin(val1: NUM_TYPE): NUM_TYPE {\r\n    if (val1 === null)\r\n      return null;\r\n    let resVal: NUM_TYPE = new NUM_TYPE();\r\n    let d: number = val1.to_double();\r\n    if (d <= 1.0 && d >= -1.0)\r\n      resVal = NUM_TYPE.from_double(Math.asin(d));\r\n    else\r\n      resVal = NUM_TYPE.from_double(0.0);\r\n    return resVal;\r\n  }\r\n\r\n  static eval_op_acos(val1: NUM_TYPE): NUM_TYPE {\r\n    if (val1 === null)\r\n      return null;\r\n    let resVal: NUM_TYPE = new NUM_TYPE();\r\n    let d: number = val1.to_double();\r\n\r\n    if (d <= 1.0 && d >= -1.0)\r\n      resVal = NUM_TYPE.from_double(Math.acos(d));\r\n    else\r\n      resVal = NUM_TYPE.from_double(0.0);\r\n    return resVal;\r\n  }\r\n\r\n  static eval_op_atan(val1: NUM_TYPE): NUM_TYPE {\r\n    if (val1 === null)\r\n      return null;\r\n    let resVal: NUM_TYPE = new NUM_TYPE();\r\n      let d: number = val1.to_double();\r\n    resVal = NUM_TYPE.from_double(Math.atan(d));\r\n    return resVal;\r\n  }\r\n\r\n  num_abs(): void {\r\n    let l: number;\r\n    if (this.NUM_IS_LONG()) {\r\n      l = this.NUM_LONG();\r\n      if (l < 0)\r\n        l = -l;\r\n      this.NUM_4_LONG(l);\r\n      return;\r\n    }\r\n    this._data[0] &= NUM_TYPE.toSByte(~NUM_TYPE.SIGN_MASK);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Randomal Math function\r\n  /// </summary>\r\n  static eval_op_rand(val1: NUM_TYPE): NUM_TYPE {\r\n    if (val1 === null)\r\n      return null;\r\n\r\n    let rand_initialized: boolean = Randomizer.get_initialized();\r\n    let rand_mod: NUM_TYPE;\r\n    let rand_mul: NUM_TYPE;\r\n    let rand_seed: NUM_TYPE;\r\n\r\n    let tmp_num: NUM_TYPE = new NUM_TYPE();\r\n\r\n    if (!rand_initialized) {\r\n      Randomizer.set_initialized(); // set to true\r\n      rand_mod = new NUM_TYPE();\r\n      rand_mul = new NUM_TYPE();\r\n      rand_seed = new NUM_TYPE();\r\n      rand_mod.num_4_a_std(\"100000007\");\r\n      rand_mul.num_4_a_std(\"75000007\");\r\n      rand_seed.num_4_a_std(\"12345678\");\r\n\r\n      Randomizer.set_mod(rand_mod.to_double());\r\n      Randomizer.set_mul(rand_mul.to_double());\r\n      Randomizer.set_seed(rand_seed.to_double());\r\n        }\r\n        else {\r\n      rand_mod = NUM_TYPE.from_double(Randomizer.get_mod());\r\n      rand_mul = NUM_TYPE.from_double(Randomizer.get_mul());\r\n      rand_seed = NUM_TYPE.from_double(Randomizer.get_seed());\r\n        }\r\n\r\n    if (!val1.num_is_zero()) {\r\n      if (val1.num_is_neg())\r\n        rand_seed.NUM_4_LONG(NUM_TYPE.hash_rand());\r\n      else\r\n        rand_seed = new NUM_TYPE(val1);\r\n      }\r\n      else {\r\n      if (rand_seed.num_is_neg()) {\r\n        tmp_num.NUM_4_LONG(-1);\r\n        rand_seed = NUM_TYPE.mul(rand_seed, tmp_num);\r\n      }\r\n    }\r\n\r\n    rand_seed = NUM_TYPE.mul(rand_seed, rand_mul);\r\n    rand_seed = NUM_TYPE.mod(rand_seed, rand_mod);\r\n    tmp_num = NUM_TYPE.div(rand_seed, rand_mod);\r\n    // reset globals variables\r\n    Randomizer.set_mod(rand_mod.to_double());\r\n    Randomizer.set_mul(rand_mul.to_double());\r\n    Randomizer.set_seed(rand_seed.to_double());\r\n    return tmp_num;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   get a random value to use as the ctl encription  key\r\n  /// </summary>\r\n  private static hash_rand(): number {\r\n    return ((new Date().getMilliseconds()) ^ Math.random() * 12345678);\r\n    // let array: number[] = new Array<number>(100);\r\n    // for (let _ai: number = 0; _ai < array.length; ++_ai)\r\n    //   array[_ai] = 0;\r\n    // new Random().NextBytes(array);\r\n    // return <number>(Misc.getSystemMilliseconds() ^ NUM_TYPE.hash_str_new(array));\r\n  }\r\n}\r\n\r\nexport class OperData {\r\n  NUM_Diff_: number = 0;\r\n  NUM_Exp1_: number = 0;\r\n  NUM_Exp2_: number = 0;\r\n}\r\n\r\n"]}