@magic-xpa/gui 4.1100.0-dev4110.99 → 4.1101.0-dev4111.271

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