@magic-xpa/gui 4.1200.0-dev4120.13 → 4.1200.0-dev4120.130

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 (79) hide show
  1. package/fesm2022/magic-xpa-gui.mjs +5712 -249
  2. package/fesm2022/magic-xpa-gui.mjs.map +1 -1
  3. package/index.d.ts +3 -0
  4. package/package.json +2 -4
  5. package/src/GuiEnums.d.ts +3 -0
  6. package/src/gui/GuiMgControl.d.ts +1 -0
  7. package/src/management/gui/MgControlBase.d.ts +0 -1
  8. package/esm2022/index.mjs +0 -71
  9. package/esm2022/magic-xpa-gui.mjs +0 -2
  10. package/esm2022/src/Commands.mjs +0 -184
  11. package/esm2022/src/Events.mjs +0 -425
  12. package/esm2022/src/EventsProcessor.mjs +0 -67
  13. package/esm2022/src/FocusManager.mjs +0 -34
  14. package/esm2022/src/GuiConstants.mjs +0 -68
  15. package/esm2022/src/GuiEnums.mjs +0 -301
  16. package/esm2022/src/GuiEnvironment.mjs +0 -4
  17. package/esm2022/src/IFlowMonitorQueue.mjs +0 -2
  18. package/esm2022/src/Manager.mjs +0 -91
  19. package/esm2022/src/UIBridge.mjs +0 -33
  20. package/esm2022/src/env/IEnvironment.mjs +0 -2
  21. package/esm2022/src/gui/ControlBase.mjs +0 -3
  22. package/esm2022/src/gui/GuiMgControl.mjs +0 -123
  23. package/esm2022/src/gui/GuiMgForm.mjs +0 -4
  24. package/esm2022/src/gui/KeyboardItem.mjs +0 -135
  25. package/esm2022/src/gui/LastFocusedVal.mjs +0 -11
  26. package/esm2022/src/gui/MgValue.mjs +0 -16
  27. package/esm2022/src/gui/PropParentInterface.mjs +0 -2
  28. package/esm2022/src/gui/low/DialogHandler.mjs +0 -7
  29. package/esm2022/src/gui/low/GuiCommand.mjs +0 -68
  30. package/esm2022/src/gui/low/GuiCommandQueue.mjs +0 -35
  31. package/esm2022/src/gui/low/GuiInteractive.mjs +0 -178
  32. package/esm2022/src/gui/low/Style.mjs +0 -20
  33. package/esm2022/src/management/RuntimeContextBase.mjs +0 -42
  34. package/esm2022/src/management/data/BlobType.mjs +0 -281
  35. package/esm2022/src/management/data/DcValues.mjs +0 -214
  36. package/esm2022/src/management/data/DcValuesBuilderBase.mjs +0 -96
  37. package/esm2022/src/management/data/FieldDef.mjs +0 -331
  38. package/esm2022/src/management/data/FieldsTable.mjs +0 -54
  39. package/esm2022/src/management/data/GuiDataViewBase.mjs +0 -88
  40. package/esm2022/src/management/data/GuiFieldBase.mjs +0 -82
  41. package/esm2022/src/management/data/IRecord.mjs +0 -2
  42. package/esm2022/src/management/data/IReferencedObject.mjs +0 -2
  43. package/esm2022/src/management/data/NUM_TYPE.mjs +0 -1739
  44. package/esm2022/src/management/data/ObjectReferenceBase.mjs +0 -48
  45. package/esm2022/src/management/data/ObjectReferencesCollection.mjs +0 -27
  46. package/esm2022/src/management/data/RecordUtils.mjs +0 -361
  47. package/esm2022/src/management/data/VectorType.mjs +0 -612
  48. package/esm2022/src/management/data/VectorTypeBase.mjs +0 -88
  49. package/esm2022/src/management/events/IActionManager.mjs +0 -2
  50. package/esm2022/src/management/events/IGuiEventsManager.mjs +0 -2
  51. package/esm2022/src/management/exp/ExpressionInterface.mjs +0 -244
  52. package/esm2022/src/management/exp/GuiExpressionEvaluator.mjs +0 -305
  53. package/esm2022/src/management/gui/ControlTable.mjs +0 -118
  54. package/esm2022/src/management/gui/DisplayConvertor.mjs +0 -1649
  55. package/esm2022/src/management/gui/FieldValidator.mjs +0 -711
  56. package/esm2022/src/management/gui/GuiControlPropertyAdapter.mjs +0 -24
  57. package/esm2022/src/management/gui/GuiFormPropertyAdapter.mjs +0 -11
  58. package/esm2022/src/management/gui/HebrewDate.mjs +0 -278
  59. package/esm2022/src/management/gui/Helps.mjs +0 -237
  60. package/esm2022/src/management/gui/MgControlBase.mjs +0 -1869
  61. package/esm2022/src/management/gui/MgFormBase.mjs +0 -741
  62. package/esm2022/src/management/gui/PIC.mjs +0 -1185
  63. package/esm2022/src/management/gui/PropDefaults.mjs +0 -230
  64. package/esm2022/src/management/gui/PropInterface.mjs +0 -246
  65. package/esm2022/src/management/gui/PropTable.mjs +0 -221
  66. package/esm2022/src/management/gui/Property.mjs +0 -1362
  67. package/esm2022/src/management/gui/ValidationDetails.mjs +0 -248
  68. package/esm2022/src/management/gui/ValidationDetailsBase.mjs +0 -93
  69. package/esm2022/src/management/gui/WrongFormatException.mjs +0 -29
  70. package/esm2022/src/management/tasks/GuiDataCollection.mjs +0 -4
  71. package/esm2022/src/management/tasks/GuiTaskBase.mjs +0 -511
  72. package/esm2022/src/management/tasks/IMGDataTable.mjs +0 -2
  73. package/esm2022/src/management/tasks/ITask.mjs +0 -2
  74. package/esm2022/src/management/tasks/MgTimer.mjs +0 -21
  75. package/esm2022/src/management/tasks/TaskDefinitionId.mjs +0 -54
  76. package/esm2022/src/management/tasks/TaskDefinitionIdTableSaxHandler.mjs +0 -41
  77. package/esm2022/src/util/MemoryUtil.mjs +0 -35
  78. package/esm2022/src/util/ObjectReference.mjs +0 -36
  79. package/esm2022/src/util/UsernamePasswordCredentials.mjs +0 -52
@@ -1,1739 +0,0 @@
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"]}