@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.
- package/fesm2022/magic-xpa-gui.mjs +5712 -249
- package/fesm2022/magic-xpa-gui.mjs.map +1 -1
- package/index.d.ts +3 -0
- package/package.json +2 -4
- package/src/GuiEnums.d.ts +3 -0
- package/src/gui/GuiMgControl.d.ts +1 -0
- package/src/management/gui/MgControlBase.d.ts +0 -1
- package/esm2022/index.mjs +0 -71
- package/esm2022/magic-xpa-gui.mjs +0 -2
- package/esm2022/src/Commands.mjs +0 -184
- package/esm2022/src/Events.mjs +0 -425
- package/esm2022/src/EventsProcessor.mjs +0 -67
- package/esm2022/src/FocusManager.mjs +0 -34
- package/esm2022/src/GuiConstants.mjs +0 -68
- package/esm2022/src/GuiEnums.mjs +0 -301
- package/esm2022/src/GuiEnvironment.mjs +0 -4
- package/esm2022/src/IFlowMonitorQueue.mjs +0 -2
- package/esm2022/src/Manager.mjs +0 -91
- package/esm2022/src/UIBridge.mjs +0 -33
- package/esm2022/src/env/IEnvironment.mjs +0 -2
- package/esm2022/src/gui/ControlBase.mjs +0 -3
- package/esm2022/src/gui/GuiMgControl.mjs +0 -123
- package/esm2022/src/gui/GuiMgForm.mjs +0 -4
- package/esm2022/src/gui/KeyboardItem.mjs +0 -135
- package/esm2022/src/gui/LastFocusedVal.mjs +0 -11
- package/esm2022/src/gui/MgValue.mjs +0 -16
- package/esm2022/src/gui/PropParentInterface.mjs +0 -2
- package/esm2022/src/gui/low/DialogHandler.mjs +0 -7
- package/esm2022/src/gui/low/GuiCommand.mjs +0 -68
- package/esm2022/src/gui/low/GuiCommandQueue.mjs +0 -35
- package/esm2022/src/gui/low/GuiInteractive.mjs +0 -178
- package/esm2022/src/gui/low/Style.mjs +0 -20
- package/esm2022/src/management/RuntimeContextBase.mjs +0 -42
- package/esm2022/src/management/data/BlobType.mjs +0 -281
- package/esm2022/src/management/data/DcValues.mjs +0 -214
- package/esm2022/src/management/data/DcValuesBuilderBase.mjs +0 -96
- package/esm2022/src/management/data/FieldDef.mjs +0 -331
- package/esm2022/src/management/data/FieldsTable.mjs +0 -54
- package/esm2022/src/management/data/GuiDataViewBase.mjs +0 -88
- package/esm2022/src/management/data/GuiFieldBase.mjs +0 -82
- package/esm2022/src/management/data/IRecord.mjs +0 -2
- package/esm2022/src/management/data/IReferencedObject.mjs +0 -2
- package/esm2022/src/management/data/NUM_TYPE.mjs +0 -1739
- package/esm2022/src/management/data/ObjectReferenceBase.mjs +0 -48
- package/esm2022/src/management/data/ObjectReferencesCollection.mjs +0 -27
- package/esm2022/src/management/data/RecordUtils.mjs +0 -361
- package/esm2022/src/management/data/VectorType.mjs +0 -612
- package/esm2022/src/management/data/VectorTypeBase.mjs +0 -88
- package/esm2022/src/management/events/IActionManager.mjs +0 -2
- package/esm2022/src/management/events/IGuiEventsManager.mjs +0 -2
- package/esm2022/src/management/exp/ExpressionInterface.mjs +0 -244
- package/esm2022/src/management/exp/GuiExpressionEvaluator.mjs +0 -305
- package/esm2022/src/management/gui/ControlTable.mjs +0 -118
- package/esm2022/src/management/gui/DisplayConvertor.mjs +0 -1649
- package/esm2022/src/management/gui/FieldValidator.mjs +0 -711
- package/esm2022/src/management/gui/GuiControlPropertyAdapter.mjs +0 -24
- package/esm2022/src/management/gui/GuiFormPropertyAdapter.mjs +0 -11
- package/esm2022/src/management/gui/HebrewDate.mjs +0 -278
- package/esm2022/src/management/gui/Helps.mjs +0 -237
- package/esm2022/src/management/gui/MgControlBase.mjs +0 -1869
- package/esm2022/src/management/gui/MgFormBase.mjs +0 -741
- package/esm2022/src/management/gui/PIC.mjs +0 -1185
- package/esm2022/src/management/gui/PropDefaults.mjs +0 -230
- package/esm2022/src/management/gui/PropInterface.mjs +0 -246
- package/esm2022/src/management/gui/PropTable.mjs +0 -221
- package/esm2022/src/management/gui/Property.mjs +0 -1362
- package/esm2022/src/management/gui/ValidationDetails.mjs +0 -248
- package/esm2022/src/management/gui/ValidationDetailsBase.mjs +0 -93
- package/esm2022/src/management/gui/WrongFormatException.mjs +0 -29
- package/esm2022/src/management/tasks/GuiDataCollection.mjs +0 -4
- package/esm2022/src/management/tasks/GuiTaskBase.mjs +0 -511
- package/esm2022/src/management/tasks/IMGDataTable.mjs +0 -2
- package/esm2022/src/management/tasks/ITask.mjs +0 -2
- package/esm2022/src/management/tasks/MgTimer.mjs +0 -21
- package/esm2022/src/management/tasks/TaskDefinitionId.mjs +0 -54
- package/esm2022/src/management/tasks/TaskDefinitionIdTableSaxHandler.mjs +0 -41
- package/esm2022/src/util/MemoryUtil.mjs +0 -35
- package/esm2022/src/util/ObjectReference.mjs +0 -36
- 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"]}
|