@magic-xpa/engine 4.1200.0-dev4120.19 → 4.1200.0-dev4120.191

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 (213) hide show
  1. package/fesm2022/magic-xpa-engine.mjs +11347 -1307
  2. package/fesm2022/magic-xpa-engine.mjs.map +1 -1
  3. package/index.d.ts +4 -0
  4. package/package.json +5 -7
  5. package/src/ClientManager.d.ts +2 -0
  6. package/src/CommandsProcessorBase.d.ts +2 -1
  7. package/src/CommandsProcessorManager.d.ts +2 -1
  8. package/src/ConstInterface.d.ts +7 -0
  9. package/src/bridge/MagicBridge.d.ts +2 -0
  10. package/src/commands/ClientToServer/CachedFileQueryCommand.d.ts +9 -0
  11. package/src/commands/ClientToServer/CommandFactory.d.ts +4 -2
  12. package/src/commands/ClientToServer/ControlItemsRefreshCommand.d.ts +1 -0
  13. package/src/commands/ClientToServer/FetchDataControlValuesEventCommand.d.ts +1 -0
  14. package/src/event/EventHandler.d.ts +5 -0
  15. package/src/event/EventsManager.d.ts +4 -0
  16. package/src/exp/ExpressionEvaluator.d.ts +5 -0
  17. package/src/http/HttpManager.d.ts +2 -1
  18. package/src/http/client/HttpClientAsync.d.ts +2 -2
  19. package/src/http/client/HttpClientBase.d.ts +3 -3
  20. package/src/http/client/HttpClientSync.d.ts +2 -2
  21. package/src/remote/RemoteCommandsProcessor.d.ts +9 -2
  22. package/src/remote/RemoteControlItemsRefreshCommand.d.ts +1 -0
  23. package/src/rt/Operation.d.ts +3 -1
  24. package/src/util/ParamParseResult.d.ts +3 -3
  25. package/esm2022/index.mjs +0 -188
  26. package/esm2022/magic-xpa-engine.mjs +0 -2
  27. package/esm2022/src/AccessHelper.mjs +0 -15
  28. package/esm2022/src/ClientManager.mjs +0 -420
  29. package/esm2022/src/CommandsProcessorBase.mjs +0 -56
  30. package/esm2022/src/CommandsProcessorManager.mjs +0 -26
  31. package/esm2022/src/CommandsTable.mjs +0 -162
  32. package/esm2022/src/ConstInterface.mjs +0 -517
  33. package/esm2022/src/CurrentClientVersion.mjs +0 -2
  34. package/esm2022/src/FlowMonitorInterface.mjs +0 -16
  35. package/esm2022/src/GUIManager.mjs +0 -62
  36. package/esm2022/src/GlobalCommandsManager.mjs +0 -34
  37. package/esm2022/src/GuiEventsProcessor.mjs +0 -156
  38. package/esm2022/src/ICommandsTable.mjs +0 -2
  39. package/esm2022/src/ServerConfig.mjs +0 -122
  40. package/esm2022/src/bridge/IGuiEvent.mjs +0 -20
  41. package/esm2022/src/bridge/MagicBridge.mjs +0 -41
  42. package/esm2022/src/commands/ClientOriginatedCommandTaskTag.mjs +0 -12
  43. package/esm2022/src/commands/ClientToServer/AddUserLocateDataViewCommand.mjs +0 -9
  44. package/esm2022/src/commands/ClientToServer/AddUserRangeDataviewCommand.mjs +0 -9
  45. package/esm2022/src/commands/ClientToServer/AddUserSortDataViewCommand.mjs +0 -9
  46. package/esm2022/src/commands/ClientToServer/BrowserEscEventCommand.mjs +0 -26
  47. package/esm2022/src/commands/ClientToServer/ClientOriginatedCommand.mjs +0 -15
  48. package/esm2022/src/commands/ClientToServer/ClientOriginatedCommandSerializer.mjs +0 -60
  49. package/esm2022/src/commands/ClientToServer/ColumnSortEventCommand.mjs +0 -29
  50. package/esm2022/src/commands/ClientToServer/CommandFactory.mjs +0 -261
  51. package/esm2022/src/commands/ClientToServer/CommandSerializationHelper.mjs +0 -67
  52. package/esm2022/src/commands/ClientToServer/ComputeEventCommand.mjs +0 -26
  53. package/esm2022/src/commands/ClientToServer/ContextTerminationEventCommand.mjs +0 -24
  54. package/esm2022/src/commands/ClientToServer/ContextTimeoutResetCommand.mjs +0 -23
  55. package/esm2022/src/commands/ClientToServer/ControlItemsRefreshCommand.mjs +0 -8
  56. package/esm2022/src/commands/ClientToServer/DataViewOutputCommand.mjs +0 -13
  57. package/esm2022/src/commands/ClientToServer/DataviewCommand.mjs +0 -44
  58. package/esm2022/src/commands/ClientToServer/EvaluateCommand.mjs +0 -40
  59. package/esm2022/src/commands/ClientToServer/EventCommand.mjs +0 -43
  60. package/esm2022/src/commands/ClientToServer/ExecOperCommand.mjs +0 -70
  61. package/esm2022/src/commands/ClientToServer/FetchDataControlValuesEventCommand.mjs +0 -25
  62. package/esm2022/src/commands/ClientToServer/GlobalParamsQueryCommand.mjs +0 -11
  63. package/esm2022/src/commands/ClientToServer/ICommandTaskTag.mjs +0 -2
  64. package/esm2022/src/commands/ClientToServer/IndexChangeEventCommand.mjs +0 -24
  65. package/esm2022/src/commands/ClientToServer/IniputForceWriteCommand.mjs +0 -26
  66. package/esm2022/src/commands/ClientToServer/NonReversibleExitEventCommand.mjs +0 -26
  67. package/esm2022/src/commands/ClientToServer/QueryCommand.mjs +0 -21
  68. package/esm2022/src/commands/ClientToServer/RecomputeCommand.mjs +0 -30
  69. package/esm2022/src/commands/ClientToServer/RefreshEventCommand.mjs +0 -30
  70. package/esm2022/src/commands/ClientToServer/RefreshScreenEventCommand.mjs +0 -27
  71. package/esm2022/src/commands/ClientToServer/RollbackEventCommand.mjs +0 -43
  72. package/esm2022/src/commands/ClientToServer/SelectProgramCommand.mjs +0 -19
  73. package/esm2022/src/commands/ClientToServer/SetTransactionStateDataviewCommand.mjs +0 -9
  74. package/esm2022/src/commands/ClientToServer/SubformOpenEventCommand.mjs +0 -24
  75. package/esm2022/src/commands/ClientToServer/SubformRefreshEventCommand.mjs +0 -27
  76. package/esm2022/src/commands/ClientToServer/TransactionCommand.mjs +0 -34
  77. package/esm2022/src/commands/ClientToServer/UnloadCommand.mjs +0 -18
  78. package/esm2022/src/commands/ClientToServer/WriteMessageToServerLogCommand.mjs +0 -18
  79. package/esm2022/src/commands/DataViewCommandBase.mjs +0 -8
  80. package/esm2022/src/commands/IClientCommand.mjs +0 -2
  81. package/esm2022/src/commands/IClientTargetedCommand.mjs +0 -13
  82. package/esm2022/src/commands/IClientToServerCommandInfo.mjs +0 -2
  83. package/esm2022/src/commands/ServerToClient/AbortCommand.mjs +0 -65
  84. package/esm2022/src/commands/ServerToClient/AddLocateCommand.mjs +0 -22
  85. package/esm2022/src/commands/ServerToClient/AddRangeCommand.mjs +0 -62
  86. package/esm2022/src/commands/ServerToClient/AddSortCommand.mjs +0 -33
  87. package/esm2022/src/commands/ServerToClient/ClientRefreshCommand.mjs +0 -25
  88. package/esm2022/src/commands/ServerToClient/ClientTargetedCommandBase.mjs +0 -24
  89. package/esm2022/src/commands/ServerToClient/EnhancedVerifyCommand.mjs +0 -45
  90. package/esm2022/src/commands/ServerToClient/OpenURLCommand.mjs +0 -221
  91. package/esm2022/src/commands/ServerToClient/ResetLocateCommand.mjs +0 -15
  92. package/esm2022/src/commands/ServerToClient/ResetRangeCommand.mjs +0 -15
  93. package/esm2022/src/commands/ServerToClient/ResetSortCommand.mjs +0 -15
  94. package/esm2022/src/commands/ServerToClient/ResultCommand.mjs +0 -37
  95. package/esm2022/src/commands/ServerToClient/VerifyCommand.mjs +0 -83
  96. package/esm2022/src/commands/ServerToClient/XMLBasedCommandBuilder.mjs +0 -132
  97. package/esm2022/src/communications/IConnectionStateManager.mjs +0 -2
  98. package/esm2022/src/communications/InteractiveCommunicationsFailureHandler.mjs +0 -15
  99. package/esm2022/src/data/DataSourceIdKey.mjs +0 -3
  100. package/esm2022/src/data/DataView.mjs +0 -1613
  101. package/esm2022/src/data/DataViewBase.mjs +0 -4
  102. package/esm2022/src/data/DataviewManager.mjs +0 -28
  103. package/esm2022/src/data/DataviewManagerBase.mjs +0 -15
  104. package/esm2022/src/data/DvCache.mjs +0 -67
  105. package/esm2022/src/data/Field.mjs +0 -646
  106. package/esm2022/src/data/FieldBase.mjs +0 -15
  107. package/esm2022/src/data/FieldsTable.mjs +0 -103
  108. package/esm2022/src/data/IRecordsTable.mjs +0 -2
  109. package/esm2022/src/data/Key.mjs +0 -88
  110. package/esm2022/src/data/Record.mjs +0 -880
  111. package/esm2022/src/data/RecordOutOfDataViewException.mjs +0 -16
  112. package/esm2022/src/data/RecordsTable.mjs +0 -267
  113. package/esm2022/src/data/TaskTransactionManager.mjs +0 -107
  114. package/esm2022/src/data/XMLBasedDcValuesBuilder.mjs +0 -74
  115. package/esm2022/src/enums.mjs +0 -24
  116. package/esm2022/src/env/EnvVariablesTable.mjs +0 -340
  117. package/esm2022/src/env/Environment.mjs +0 -487
  118. package/esm2022/src/env/ILanguageData.mjs +0 -2
  119. package/esm2022/src/env/LanguageData.mjs +0 -227
  120. package/esm2022/src/env/MirrorString.mjs +0 -67
  121. package/esm2022/src/event/ActionManager.mjs +0 -91
  122. package/esm2022/src/event/Event.mjs +0 -1333
  123. package/esm2022/src/event/EventHandler.mjs +0 -766
  124. package/esm2022/src/event/EventHandlerPosition.mjs +0 -204
  125. package/esm2022/src/event/EventsManager.mjs +0 -2988
  126. package/esm2022/src/event/IEventsManager.mjs +0 -7
  127. package/esm2022/src/event/RunTimeEvent.mjs +0 -399
  128. package/esm2022/src/event/RunTimeEventBase.mjs +0 -4
  129. package/esm2022/src/event/UserEventsTable.mjs +0 -47
  130. package/esm2022/src/exp/ExpTable.mjs +0 -57
  131. package/esm2022/src/exp/Expression.mjs +0 -200
  132. package/esm2022/src/exp/ExpressionDict.mjs +0 -727
  133. package/esm2022/src/exp/ExpressionEvaluator.mjs +0 -4206
  134. package/esm2022/src/exp/ExpressionLocalJpn.mjs +0 -314
  135. package/esm2022/src/exp/GlobalParamsTable.mjs +0 -85
  136. package/esm2022/src/exp/YesNoExp.mjs +0 -36
  137. package/esm2022/src/gui/CreatedFormVector.mjs +0 -23
  138. package/esm2022/src/gui/FormsTable.mjs +0 -66
  139. package/esm2022/src/gui/MgControl.mjs +0 -363
  140. package/esm2022/src/gui/MgForm.mjs +0 -1224
  141. package/esm2022/src/http/HttpManager.mjs +0 -97
  142. package/esm2022/src/http/client/HttpClientAsync.mjs +0 -68
  143. package/esm2022/src/http/client/HttpClientBase.mjs +0 -132
  144. package/esm2022/src/http/client/HttpClientEvents.mjs +0 -39
  145. package/esm2022/src/http/client/HttpClientSync.mjs +0 -42
  146. package/esm2022/src/http/client/HttpUtility.mjs +0 -84
  147. package/esm2022/src/http/client/ICommunicationsFailureHandler.mjs +0 -2
  148. package/esm2022/src/remote/AddUserLocateRemoteDataViewCommand.mjs +0 -18
  149. package/esm2022/src/remote/AddUserRangeRemoteDataViewCommand.mjs +0 -18
  150. package/esm2022/src/remote/AddUserSortRemoteDataViewCommand.mjs +0 -18
  151. package/esm2022/src/remote/RemoteCommandsProcessor.mjs +0 -883
  152. package/esm2022/src/remote/RemoteControlItemsRefreshCommand.mjs +0 -25
  153. package/esm2022/src/remote/RemoteDataViewCommandBase.mjs +0 -24
  154. package/esm2022/src/remote/RemoteDataViewCommandFactory.mjs +0 -61
  155. package/esm2022/src/remote/RemoteDataViewCommandUpdateNonModifiable.mjs +0 -16
  156. package/esm2022/src/remote/RemoteDataviewManager.mjs +0 -17
  157. package/esm2022/src/remote/RemoteInitDataViewCommand.mjs +0 -11
  158. package/esm2022/src/remote/ResetUserLocateRemoteDataviewCommand.mjs +0 -17
  159. package/esm2022/src/remote/ResetUserRangeRemoteDataviewCommand.mjs +0 -13
  160. package/esm2022/src/remote/ResetUserSortRemoteDataviewCommand.mjs +0 -16
  161. package/esm2022/src/remote/ServerError.mjs +0 -40
  162. package/esm2022/src/remote/SetTransactionStateRemoteDataViewCommand.mjs +0 -20
  163. package/esm2022/src/rt/Argument.mjs +0 -265
  164. package/esm2022/src/rt/ArgumentsList.mjs +0 -103
  165. package/esm2022/src/rt/Boundary.mjs +0 -152
  166. package/esm2022/src/rt/CompMainPrgTable.mjs +0 -63
  167. package/esm2022/src/rt/DataviewHeaderBase.mjs +0 -98
  168. package/esm2022/src/rt/DataviewHeaderFactory.mjs +0 -7
  169. package/esm2022/src/rt/DataviewHeaders.mjs +0 -53
  170. package/esm2022/src/rt/DataviewHeadersSaxHandler.mjs +0 -38
  171. package/esm2022/src/rt/ExecutionStack.mjs +0 -94
  172. package/esm2022/src/rt/ExecutionStackEntry.mjs +0 -17
  173. package/esm2022/src/rt/HandlersTable.mjs +0 -96
  174. package/esm2022/src/rt/IDataSourceViewDefinition.mjs +0 -2
  175. package/esm2022/src/rt/IDataviewHeader.mjs +0 -2
  176. package/esm2022/src/rt/IResultValue.mjs +0 -2
  177. package/esm2022/src/rt/LastFocusedManager.mjs +0 -65
  178. package/esm2022/src/rt/Operation.mjs +0 -735
  179. package/esm2022/src/rt/OperationTable.mjs +0 -67
  180. package/esm2022/src/rt/Recompute.mjs +0 -355
  181. package/esm2022/src/rt/RecomputeTable.mjs +0 -63
  182. package/esm2022/src/rt/RemoteDataviewHeader.mjs +0 -108
  183. package/esm2022/src/rt/ResultValue.mjs +0 -10
  184. package/esm2022/src/rt/TableCache.mjs +0 -177
  185. package/esm2022/src/rt/TableCacheManager.mjs +0 -67
  186. package/esm2022/src/rt/Transaction.mjs +0 -53
  187. package/esm2022/src/security/UserDetails.mjs +0 -71
  188. package/esm2022/src/tasks/IMGDataCollection.mjs +0 -2
  189. package/esm2022/src/tasks/MGData.mjs +0 -552
  190. package/esm2022/src/tasks/MGDataCollection.mjs +0 -252
  191. package/esm2022/src/tasks/RCTimer.mjs +0 -63
  192. package/esm2022/src/tasks/RemoteTaskService.mjs +0 -45
  193. package/esm2022/src/tasks/Task.mjs +0 -2499
  194. package/esm2022/src/tasks/TaskBase.mjs +0 -83
  195. package/esm2022/src/tasks/TaskServiceBase.mjs +0 -25
  196. package/esm2022/src/tasks/TasksTable.mjs +0 -80
  197. package/esm2022/src/tasks/sort/Sort.mjs +0 -5
  198. package/esm2022/src/tasks/sort/SortCollection.mjs +0 -67
  199. package/esm2022/src/util/ConstUtils.mjs +0 -14
  200. package/esm2022/src/util/FlowMonitorQueue.mjs +0 -451
  201. package/esm2022/src/util/HeapSort.mjs +0 -70
  202. package/esm2022/src/util/IMirrorXML.mjs +0 -2
  203. package/esm2022/src/util/IServerConfig.mjs +0 -2
  204. package/esm2022/src/util/MgBlockingQueue.mjs +0 -2
  205. package/esm2022/src/util/MgPriorityBlockingQueue.mjs +0 -74
  206. package/esm2022/src/util/MgPriorityQueue.mjs +0 -66
  207. package/esm2022/src/util/ParamParseResult.mjs +0 -8
  208. package/esm2022/src/util/PrmMap.mjs +0 -153
  209. package/esm2022/src/util/ReturnResult.mjs +0 -46
  210. package/esm2022/src/util/ReturnResultBase.mjs +0 -18
  211. package/esm2022/src/util/Scrambler.mjs +0 -89
  212. package/esm2022/src/util/UniqueIDUtils.mjs +0 -13
  213. package/esm2022/src/util/cookie.service.mjs +0 -92
@@ -1,451 +0,0 @@
1
- import { BlobType, DisplayConvertor, PIC, VectorType } from '@magic-xpa/gui';
2
- import { DateTime, NString, StringBuilder } from '@magic-xpa/mscorelib';
3
- import { Constants, DateTimeUtils, InternalInterface, Logger, Queue, StorageAttribute, XMLConstants, XmlParser } from '@magic-xpa/utils';
4
- import { FlowMonitorInterface } from '../FlowMonitorInterface';
5
- import { ConstInterface } from '../ConstInterface';
6
- export class FlowMonitorQueue {
7
- static _instance = null;
8
- static UNPRINTABLE_STR_LOG = "#UNPRINTABLE#";
9
- static S_EVENT_STR1 = ">>Starts ";
10
- static S_EVENT_STR2 = " Event";
11
- static S_EVENT_PROPAGATED = "Event was propagated";
12
- static E_EVENT_STR = "<<Ends Event";
13
- static S_RECPRF_STR = "Starts Record Prefix";
14
- static E_RECPRF_STR = "Ends Record Prefix";
15
- static S_RECSUF_STR = "Starts Record Suffix";
16
- static E_RECSUF_STR = "Ends Record Suffix";
17
- static S_TASKSUF_STR = "Starts Task Suffix";
18
- static E_TASKSUF_STR = "Ends Task Suffix";
19
- static S_TASKPRF_STR = "Starts Task Prefix";
20
- static E_TASKPRF_STR = "Ends Task Prefix";
21
- static S_CTRLPRF_STR = "Starts Control Prefix - ";
22
- static E_CTRLPRF_STR = "Ends Control Prefix - ";
23
- static S_CTRLSUF_STR = "Starts Control Suffix - ";
24
- static E_CTRLSUF_STR = "Ends Control Suffix - ";
25
- static S_HANDLER_STR = "Starts handling event {0}";
26
- static E_HANDLER_STR = "Ends handling event {0}";
27
- static S_CTRLVER_STR = "Starts Control Verification for Control - ";
28
- static E_CTRLVER_STR = "Ends Control Verification for Control - ";
29
- static RECOMP_STR = "Recomputes - ";
30
- static S_VARIABLE_STR = "Starts Variable Change - ";
31
- static E_VARIABLE_STR = "Ends Variable Change - ";
32
- static VARIABLE_REASON_STR = " - Reason - Previous value";
33
- static FLW_PERFIX = "Flow - ";
34
- static ACT_TASK = 'T';
35
- static ACT_TASK_FLW = 'F';
36
- static ACT_RECOMPUTE = 'R';
37
- static ACT_FLW_OPER = 'T';
38
- static LongTimePattern = "HH:mm:ss:SSS";
39
- _queue = new Queue();
40
- _enabled = false;
41
- _isFlowOperation = false;
42
- _isRecompute = false;
43
- _isTask = false;
44
- _isTaskFlow = false;
45
- _isDataView = false;
46
- ShouldSerialize = false;
47
- static get Instance() {
48
- if (FlowMonitorQueue._instance === null)
49
- FlowMonitorQueue._instance = new FlowMonitorQueue();
50
- return FlowMonitorQueue._instance;
51
- }
52
- addTaskCngMode(newTaskMode, taskInfo) {
53
- let info = "Task Mode Change - ";
54
- if (this._enabled && this._isTask) {
55
- let activityItem = new ActivityItem(this, FlowMonitorQueue.ACT_TASK, FlowMonitorInterface.FLWMTR_CHNG_MODE);
56
- switch (newTaskMode) {
57
- case Constants.TASK_MODE_MODIFY:
58
- info += "Modify";
59
- break;
60
- case Constants.TASK_MODE_CREATE:
61
- info += "Create";
62
- break;
63
- case Constants.TASK_MODE_DELETE:
64
- info += "Delete";
65
- break;
66
- case Constants.TASK_MODE_QUERY:
67
- info += "Query";
68
- break;
69
- default:
70
- info = null;
71
- break;
72
- }
73
- activityItem.setInfo(info);
74
- this._queue.put(activityItem);
75
- Logger.Instance.WriteSupportToLog(taskInfo + ": " + info, true);
76
- }
77
- }
78
- fillData(parser) {
79
- let endContext = parser.getXMLdata().indexOf("/>", parser.getCurrIndex());
80
- if (endContext !== -1 && endContext < parser.getXMLdata().length) {
81
- let tag = parser.getXMLsubstring(endContext);
82
- parser.add2CurrIndex(tag.indexOf("flwmtr_config") + "flwmtr_config".length);
83
- let tokens = XmlParser.getTokens(parser.getXMLsubstring(endContext), XMLConstants.XML_ATTR_DELIM);
84
- Logger.Instance.WriteDevToLog("in FlowMonitorQueue.FillData: " + tokens.toString());
85
- this.initElements(tokens);
86
- parser.setCurrIndex(endContext + XMLConstants.TAG_TERM.length);
87
- return;
88
- }
89
- Logger.Instance.WriteExceptionToLogWithMsg("in FlowMonitorQueue.FillData() out of string bounds");
90
- }
91
- initElements(tokensVector) {
92
- for (let j = 0; j < tokensVector.length; j = j + 2) {
93
- let attribute = tokensVector.get_Item(j);
94
- let valueStr = tokensVector.get_Item(j + 1);
95
- Logger.Instance.WriteDevToLog(attribute + " value: " + valueStr);
96
- switch (attribute) {
97
- case ConstInterface.MG_ATTR_TASK:
98
- this._isTask = XmlParser.getBoolean(valueStr);
99
- break;
100
- case ConstInterface.MG_ATTR_TASKFLW:
101
- this._isTaskFlow = XmlParser.getBoolean(valueStr);
102
- break;
103
- case ConstInterface.MG_TAG_DATAVIEW:
104
- this._isDataView = XmlParser.getBoolean(valueStr);
105
- break;
106
- case ConstInterface.MG_ATTR_RECOMP:
107
- this._isRecompute = XmlParser.getBoolean(valueStr);
108
- break;
109
- case ConstInterface.MG_ATTR_FLWOP:
110
- this._isFlowOperation = XmlParser.getBoolean(valueStr);
111
- break;
112
- case ConstInterface.MG_ATTR_ENABLED:
113
- this.enable(XmlParser.getBoolean(valueStr));
114
- break;
115
- default:
116
- Logger.Instance.WriteExceptionToLogWithMsg("in FlowMonitorQueue.initElements(): unknown attribute: " + attribute);
117
- break;
118
- }
119
- }
120
- }
121
- buildXML(message) {
122
- if (!this._queue.isEmpty() && this.ShouldSerialize) {
123
- message.Append(XMLConstants.START_TAG + ConstInterface.MG_TAG_FLWMTR_MSG + XMLConstants.TAG_CLOSE);
124
- while (!this._queue.isEmpty()) {
125
- let currAct = this._queue.get();
126
- currAct.buildXML(message);
127
- }
128
- message.Append("</" + ConstInterface.MG_TAG_FLWMTR_MSG + XMLConstants.TAG_CLOSE);
129
- }
130
- }
131
- isEmpty() {
132
- return this._queue.isEmpty();
133
- }
134
- enable(value) {
135
- let wasEnabled = this._enabled;
136
- this._enabled = value;
137
- this.ShouldSerialize = this._enabled;
138
- return wasEnabled;
139
- }
140
- addTaskEvent(triggeredBy, state, taskInfo) {
141
- if (this._enabled && this._isTask) {
142
- let act = new ActivityItem(this, FlowMonitorQueue.ACT_TASK, FlowMonitorInterface.FLWMTR_EVENT);
143
- let info;
144
- switch (state) {
145
- case FlowMonitorInterface.FLWMTR_START:
146
- info = FlowMonitorQueue.S_EVENT_STR1 + triggeredBy + FlowMonitorQueue.S_EVENT_STR2;
147
- break;
148
- case FlowMonitorInterface.FLWMTR_END:
149
- info = FlowMonitorQueue.E_EVENT_STR + triggeredBy;
150
- break;
151
- case FlowMonitorInterface.FLWMTR_PROPAGATE:
152
- info = FlowMonitorQueue.S_EVENT_PROPAGATED;
153
- break;
154
- default:
155
- info = null;
156
- break;
157
- }
158
- act.setInfo(info);
159
- this._queue.put(act);
160
- Logger.Instance.WriteSupportToLog(taskInfo + ": " + info, true);
161
- }
162
- }
163
- appendVirtualsAndParameters(currentValues) {
164
- let act = new ActivityItem(this, FlowMonitorQueue.ACT_TASK_FLW, InternalInterface.MG_ACT_REC_PREFIX);
165
- act.setInfo(currentValues);
166
- this._queue.put(act);
167
- }
168
- addDataViewFlow(task) {
169
- if (this._isDataView) {
170
- let fldTab = task.DataView.GetFieldsTab();
171
- let preparedDisplayString = "";
172
- let finaldisplayData = "\n";
173
- let fldValue;
174
- let data = "";
175
- for (let i = 0; i < fldTab.getSize(); i++) {
176
- let fldDef = fldTab.getField(i);
177
- if (!fldDef.IsEventHandlerField && (fldDef.IsVirtual && !fldDef.VirAsReal) || fldDef.isParam()) {
178
- fldValue = fldDef.isNull() ? fldDef.getNullValue() : fldDef.getValue(true);
179
- data = this.getFieldData(fldDef.getType(), fldValue, fldDef.getPicture(), fldDef.getCellsType(), task);
180
- preparedDisplayString = this.PrepareDisplayString(fldDef.isParam(), fldDef.getVarName(), data, true);
181
- finaldisplayData = finaldisplayData + preparedDisplayString + "\n";
182
- }
183
- }
184
- this.appendVirtualsAndParameters(finaldisplayData);
185
- }
186
- }
187
- getFieldData(Storagetype, data, picture, vecCellType, task) {
188
- switch (Storagetype) {
189
- case StorageAttribute.DOTNET:
190
- data = FlowMonitorQueue.UNPRINTABLE_STR_LOG;
191
- break;
192
- case StorageAttribute.BLOB:
193
- {
194
- if (BlobType.isValidBlob(data)) {
195
- let contentType = BlobType.getContentType(data);
196
- if (contentType == BlobType.CONTENT_TYPE_ANSI || contentType == BlobType.CONTENT_TYPE_UNICODE)
197
- data = data != null ? BlobType.getString(data) : "";
198
- else
199
- data = FlowMonitorQueue.UNPRINTABLE_STR_LOG;
200
- }
201
- else
202
- data = "";
203
- }
204
- break;
205
- case StorageAttribute.NUMERIC:
206
- case StorageAttribute.DATE:
207
- case StorageAttribute.TIME:
208
- let conv = DisplayConvertor.Instance;
209
- data = conv.mg2disp(data, " ", new PIC(picture, Storagetype, task.getCompIdx()), false, task.getCompIdx(), false);
210
- break;
211
- case StorageAttribute.BLOB_VECTOR:
212
- let vecOutData;
213
- if (data == null) {
214
- vecOutData = "[]";
215
- }
216
- else {
217
- let cellAtt = vecCellType;
218
- let vector = new VectorType(data);
219
- if (cellAtt == StorageAttribute.BLOB && !VectorType.validateBlobContents(data))
220
- vecOutData = "[]";
221
- else {
222
- let vecSize = VectorType.getVecSize(data);
223
- let cellPicture = (cellAtt == StorageAttribute.NUMERIC || cellAtt == StorageAttribute.DATE || cellAtt == StorageAttribute.TIME) ? PIC.buildPicture(cellAtt, vector.getVecCell(1), task.getCompIdx(), true).getFormat() : picture;
224
- vecOutData = "[";
225
- for (let i = 0; i < vecSize; i++) {
226
- vecOutData += this.getFieldData(cellAtt, vector.getVecCell(i + 1), cellPicture, vecCellType, task);
227
- vecOutData += i < vecSize - 1 ? "," : "]";
228
- }
229
- }
230
- }
231
- data = vecOutData;
232
- break;
233
- case StorageAttribute.BOOLEAN:
234
- data = data == "1" ? "TRUE" : "FALSE";
235
- break;
236
- }
237
- return data;
238
- }
239
- PrepareDisplayString(mode, name, valueContent, addDoubleQuotes) {
240
- let str = "";
241
- let finalStringToDisplay = "";
242
- if (addDoubleQuotes)
243
- finalStringToDisplay = finalStringToDisplay + "\"";
244
- finalStringToDisplay = finalStringToDisplay + name;
245
- if (addDoubleQuotes)
246
- finalStringToDisplay = finalStringToDisplay + "\"";
247
- let paddedName = this.padRight(name, 34);
248
- let formatOfStringVirtual = `Virtual`;
249
- let formatOfStringParameter = `Parameter`;
250
- str = (mode ? formatOfStringParameter : formatOfStringVirtual) + " : " + `${paddedName}` + " : " + `${valueContent.trim()}`;
251
- return str;
252
- }
253
- padRight = (string, length, character = ' ') => {
254
- let result = "";
255
- let totalLength = length - string.length;
256
- for (let i = 0; i < totalLength; i++) {
257
- result = character + result;
258
- }
259
- result = result + string;
260
- return result;
261
- };
262
- addTaskFlowRec(id, state, taskInfo) {
263
- if (this._enabled && this._isTaskFlow) {
264
- let info;
265
- switch (id) {
266
- case InternalInterface.MG_ACT_REC_PREFIX:
267
- info = state === FlowMonitorInterface.FLWMTR_START
268
- ? FlowMonitorQueue.S_RECPRF_STR
269
- : FlowMonitorQueue.E_RECPRF_STR;
270
- id = FlowMonitorInterface.FLWMTR_PREFIX;
271
- break;
272
- case InternalInterface.MG_ACT_REC_SUFFIX:
273
- info = state === FlowMonitorInterface.FLWMTR_START
274
- ? FlowMonitorQueue.S_RECSUF_STR
275
- : FlowMonitorQueue.E_RECSUF_STR;
276
- id = FlowMonitorInterface.FLWMTR_SUFFIX;
277
- break;
278
- case InternalInterface.MG_ACT_TASK_PREFIX:
279
- info = state === FlowMonitorInterface.FLWMTR_START
280
- ? FlowMonitorQueue.S_TASKPRF_STR
281
- : FlowMonitorQueue.E_TASKPRF_STR;
282
- id = FlowMonitorInterface.FLWMTR_PREFIX;
283
- break;
284
- case InternalInterface.MG_ACT_TASK_SUFFIX:
285
- info = state === FlowMonitorInterface.FLWMTR_START
286
- ? FlowMonitorQueue.S_TASKSUF_STR
287
- : FlowMonitorQueue.E_TASKSUF_STR;
288
- id = FlowMonitorInterface.FLWMTR_SUFFIX;
289
- break;
290
- default:
291
- info = null;
292
- break;
293
- }
294
- let act = new ActivityItem(this, FlowMonitorQueue.ACT_TASK_FLW, id);
295
- act.setInfo(info);
296
- this._queue.put(act);
297
- Logger.Instance.WriteSupportToLog(taskInfo + ": " + info, true);
298
- }
299
- }
300
- addTaskFlowFld(id, fldName, state, taskInfo) {
301
- this.addTaskFlowCtrl(id, fldName, state, taskInfo);
302
- }
303
- addTaskFlowCtrl(id, ctrlName, state, taskInfo) {
304
- if (this._enabled && this._isTaskFlow) {
305
- let info;
306
- switch (id) {
307
- case InternalInterface.MG_ACT_VARIABLE:
308
- info = state === FlowMonitorInterface.FLWMTR_START
309
- ? FlowMonitorQueue.S_VARIABLE_STR
310
- : FlowMonitorQueue.E_VARIABLE_STR;
311
- id = FlowMonitorInterface.FLWMTR_VARCHG_VALUE;
312
- break;
313
- case InternalInterface.MG_ACT_CTRL_PREFIX:
314
- info = state === FlowMonitorInterface.FLWMTR_START
315
- ? FlowMonitorQueue.S_CTRLPRF_STR
316
- : FlowMonitorQueue.E_CTRLPRF_STR;
317
- id = FlowMonitorInterface.FLWMTR_CTRL_PREFIX;
318
- break;
319
- case InternalInterface.MG_ACT_CTRL_SUFFIX:
320
- info = state === FlowMonitorInterface.FLWMTR_START
321
- ? FlowMonitorQueue.S_CTRLSUF_STR
322
- : FlowMonitorQueue.E_CTRLSUF_STR;
323
- id = FlowMonitorInterface.FLWMTR_CTRL_SUFFIX;
324
- break;
325
- case InternalInterface.MG_ACT_CTRL_VERIFICATION:
326
- info = state === FlowMonitorInterface.FLWMTR_START
327
- ? FlowMonitorQueue.S_CTRLVER_STR
328
- : FlowMonitorQueue.E_CTRLVER_STR;
329
- id = FlowMonitorInterface.FLWMTR_CTRL_SUFFIX;
330
- break;
331
- default:
332
- info = null;
333
- break;
334
- }
335
- let act = new ActivityItem(this, FlowMonitorQueue.ACT_TASK_FLW, id);
336
- if (info !== null) {
337
- info = info + ctrlName;
338
- if (id === FlowMonitorInterface.FLWMTR_VARCHG_VALUE && state === FlowMonitorInterface.FLWMTR_START)
339
- info = info + FlowMonitorQueue.VARIABLE_REASON_STR;
340
- act.setInfo(info);
341
- Logger.Instance.WriteSupportToLog(taskInfo + ": " + info, true);
342
- }
343
- this._queue.put(act);
344
- }
345
- }
346
- addTaskFlowHandler(handlerId, state, taskInfo) {
347
- if (this._enabled && this._isTaskFlow) {
348
- let act = new ActivityItem(this, FlowMonitorQueue.ACT_TASK_FLW, FlowMonitorInterface.FLWMTR_TSK_HANDLER);
349
- let info;
350
- switch (state) {
351
- case FlowMonitorInterface.FLWMTR_START:
352
- info = NString.Format(FlowMonitorQueue.S_HANDLER_STR, handlerId);
353
- break;
354
- case FlowMonitorInterface.FLWMTR_END:
355
- info = NString.Format(FlowMonitorQueue.E_HANDLER_STR, handlerId);
356
- break;
357
- default:
358
- info = null;
359
- break;
360
- }
361
- if (info !== null) {
362
- act.setInfo(info);
363
- Logger.Instance.WriteSupportToLog(taskInfo + ": " + info, true);
364
- }
365
- this._queue.put(act);
366
- }
367
- }
368
- addRecompute(triggeredByVarName, taskInfo) {
369
- if (this._enabled && this._isRecompute) {
370
- let act = new ActivityItem(this, FlowMonitorQueue.ACT_RECOMPUTE, FlowMonitorInterface.FLWMTR_RECOMP);
371
- let info = FlowMonitorQueue.RECOMP_STR + triggeredByVarName;
372
- act.setInfo(info);
373
- this._queue.put(act);
374
- Logger.Instance.WriteSupportToLog(taskInfo + ": " + info, true);
375
- }
376
- }
377
- async addFlowFieldOperation(oper, bExecuted, taskInfo) {
378
- if (this._enabled && this._isFlowOperation) {
379
- let act = new ActivityItem(this, FlowMonitorQueue.ACT_FLW_OPER, FlowMonitorInterface.FLWMTR_DATA_OPER);
380
- let buffer = new StringBuilder(FlowMonitorQueue.FLW_PERFIX);
381
- await oper.AddFlowDescription(buffer);
382
- buffer.Append(' ');
383
- if (!bExecuted)
384
- buffer.Append("[Not Executed]");
385
- let info = buffer.ToString();
386
- act.setInfo(info);
387
- this._queue.put(act);
388
- Logger.Instance.WriteSupportToLog(taskInfo + ": " + info, true);
389
- }
390
- }
391
- addFlowOperationUpdate(state, taskInfo) {
392
- if (this._enabled && this._isFlowOperation) {
393
- let act = new ActivityItem(this, FlowMonitorQueue.ACT_FLW_OPER, FlowMonitorInterface.FLWMTR_DATA_OPER);
394
- let info;
395
- if (state === FlowMonitorInterface.FLWMTR_START)
396
- info = "Starts Update";
397
- else
398
- info = "Ends Update";
399
- act.setInfo(info);
400
- this._queue.put(act);
401
- Logger.Instance.WriteSupportToLog(taskInfo + ": " + info, true);
402
- }
403
- }
404
- addFlowVerifyInfo(info, taskInfo) {
405
- this.addFlowInfo(info, taskInfo);
406
- }
407
- addFlowInvokeOsInfo(info, taskInfo) {
408
- this.addFlowInfo(info, taskInfo);
409
- }
410
- addFlowInfo(info, taskInfo) {
411
- if (!this._enabled)
412
- return;
413
- let act = new ActivityItem(this, FlowMonitorQueue.ACT_FLW_OPER, FlowMonitorInterface.FLWMTR_DATA_OPER);
414
- let buffer = new StringBuilder("");
415
- if (!(info === "")) {
416
- buffer.Append(" >> INFORMATION >> ");
417
- buffer.Append(info);
418
- }
419
- let newInfo = buffer.ToString();
420
- act.setInfo(newInfo);
421
- this._queue.put(act);
422
- Logger.Instance.WriteSupportToLog(taskInfo + ": " + newInfo, true);
423
- }
424
- }
425
- class ActivityItem {
426
- _id = 0;
427
- _type = null;
428
- _info = null;
429
- _time = null;
430
- constructor(enclosingInstance, type, id) {
431
- this._type = type;
432
- this._id = id;
433
- this.setTime();
434
- }
435
- setTime() {
436
- this._time = DateTimeUtils.ToString(DateTime.Now, FlowMonitorQueue.LongTimePattern, Logger.Instance);
437
- }
438
- setInfo(info_) {
439
- this._info = ((info_ !== null) ? XmlParser.escape(info_) : info_);
440
- }
441
- buildXML(message) {
442
- message.Append(XMLConstants.START_TAG + ConstInterface.MG_TAG_FLWMTR_ACT);
443
- message.Append(" " + XMLConstants.MG_ATTR_TYPE + "=\"" + this._type + "\"");
444
- message.Append(" " + XMLConstants.MG_ATTR_ID + "=\"" + this._id + "\"");
445
- if (this._info != null)
446
- message.Append(" " + ConstInterface.MG_ATTR_INFO + "=\"" + this._info + "\"");
447
- message.Append(" " + ConstInterface.MG_ATTR_TIME + "=\"" + this._time + "\"");
448
- message.Append(XMLConstants.TAG_TERM);
449
- }
450
- }
451
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"FlowMonitorQueue.js","sourceRoot":"","sources":["../../../../../../projects/engine/src/util/FlowMonitorQueue.ts"],"names":[],"mappings":"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","sourcesContent":["import {BlobType, DisplayConvertor, FieldsTable, IFlowMonitorQueue, PIC, VectorType} from '@magic-xpa/gui';\r\nimport {DateTime, List, NString, StringBuilder} from '@magic-xpa/mscorelib';\r\nimport {Constants, DateTimeUtils, InternalInterface, Logger, Queue, StorageAttribute, XMLConstants, XmlParser} from '@magic-xpa/utils';\r\nimport {Operation} from '../rt/Operation';\r\nimport {FlowMonitorInterface} from '../FlowMonitorInterface';\r\nimport {ConstInterface} from '../ConstInterface';\r\nimport { Task } from '../tasks/Task';\r\nimport { Field } from '../data/Field';\r\n\r\n// @dynamic\r\nexport class FlowMonitorQueue implements IFlowMonitorQueue {\r\n  private static _instance: FlowMonitorQueue = null;\r\n  private static UNPRINTABLE_STR_LOG: string = \"#UNPRINTABLE#\";\r\n  private static S_EVENT_STR1: string = \">>Starts \";\r\n  private static S_EVENT_STR2: string = \" Event\";\r\n  private static S_EVENT_PROPAGATED: string = \"Event was propagated\";\r\n  private static E_EVENT_STR: string = \"<<Ends Event\";\r\n\r\n  private static S_RECPRF_STR: string = \"Starts Record Prefix\";\r\n  private static E_RECPRF_STR: string = \"Ends Record Prefix\";\r\n  private static S_RECSUF_STR: string = \"Starts Record Suffix\";\r\n  private static E_RECSUF_STR: string = \"Ends Record Suffix\";\r\n  private static S_TASKSUF_STR: string = \"Starts Task Suffix\";\r\n  private static E_TASKSUF_STR: string = \"Ends Task Suffix\";\r\n  private static S_TASKPRF_STR: string = \"Starts Task Prefix\";\r\n  private static E_TASKPRF_STR: string = \"Ends Task Prefix\";\r\n  private static S_CTRLPRF_STR: string = \"Starts Control Prefix - \";\r\n  private static E_CTRLPRF_STR: string = \"Ends Control Prefix - \";\r\n  private static S_CTRLSUF_STR: string = \"Starts Control Suffix - \";\r\n  private static E_CTRLSUF_STR: string = \"Ends Control Suffix - \";\r\n  private static S_HANDLER_STR: string = \"Starts handling event {0}\";\r\n  private static E_HANDLER_STR: string = \"Ends handling event {0}\";\r\n  private static S_CTRLVER_STR: string = \"Starts Control Verification for Control - \";\r\n  private static E_CTRLVER_STR: string = \"Ends Control Verification for Control - \";\r\n  private static RECOMP_STR: string = \"Recomputes - \";\r\n  private static S_VARIABLE_STR: string = \"Starts Variable Change - \";\r\n  private static E_VARIABLE_STR: string = \"Ends Variable Change - \";\r\n  private static VARIABLE_REASON_STR: string = \" - Reason - Previous value\";\r\n\r\n\r\n  private static FLW_PERFIX: string = \"Flow - \";\r\n\r\n  private static ACT_TASK: string = 'T';\r\n  private static ACT_TASK_FLW: string = 'F';\r\n  private static ACT_RECOMPUTE: string = 'R';\r\n  private static ACT_FLW_OPER: string = 'T';\r\n\r\n  static LongTimePattern = \"HH:mm:ss:SSS\";\r\n  private _queue: Queue<ActivityItem> = new Queue<ActivityItem>();\r\n  private _enabled: boolean = false;\r\n  private _isFlowOperation: boolean = false;\r\n  private _isRecompute: boolean = false;\r\n  private _isTask: boolean = false;\r\n  private _isTaskFlow: boolean = false;\r\n  private _isDataView: boolean = false;\r\n  ShouldSerialize: boolean = false;\r\n\r\n  static get Instance(): FlowMonitorQueue {\r\n    if (FlowMonitorQueue._instance === null)\r\n      FlowMonitorQueue._instance = new FlowMonitorQueue();\r\n\r\n    return FlowMonitorQueue._instance;\r\n  }\r\n\r\n  addTaskCngMode(newTaskMode: string, taskInfo: string): void {\r\n    let info: string = \"Task Mode Change - \";\r\n    if (this._enabled && this._isTask) {\r\n      let activityItem: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_TASK, FlowMonitorInterface.FLWMTR_CHNG_MODE);\r\n\r\n      switch (newTaskMode) {\r\n        case Constants.TASK_MODE_MODIFY:\r\n          info += \"Modify\";\r\n          break;\r\n\r\n\r\n        case Constants.TASK_MODE_CREATE:\r\n          info += \"Create\";\r\n          break;\r\n\r\n\r\n        case Constants.TASK_MODE_DELETE:\r\n          info += \"Delete\";\r\n          break;\r\n\r\n\r\n        case Constants.TASK_MODE_QUERY:\r\n          info += \"Query\";\r\n          break;\r\n\r\n\r\n        default:\r\n          info = null;\r\n          break;\r\n      }\r\n\r\n      activityItem.setInfo(info);\r\n      this._queue.put(activityItem);\r\n\r\n      Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  ///   parse the data\r\n  /// </summary>\r\n  fillData(parser: XmlParser): void {\r\n    let endContext: number = parser.getXMLdata().indexOf(\"/>\", parser.getCurrIndex());\r\n    if (endContext !== -1 && endContext < parser.getXMLdata().length) {\r\n      // find last position of its tag\r\n      let tag: string = parser.getXMLsubstring(endContext);\r\n      parser.add2CurrIndex(tag.indexOf(\"flwmtr_config\") + \"flwmtr_config\".length);\r\n\r\n      let tokens: List<string> = XmlParser.getTokens(parser.getXMLsubstring(endContext), XMLConstants.XML_ATTR_DELIM);\r\n      Logger.Instance.WriteDevToLog(\"in FlowMonitorQueue.FillData: \" + tokens.toString());\r\n\r\n      this.initElements(tokens);\r\n      parser.setCurrIndex(endContext + XMLConstants.TAG_TERM.length); // to delete \"/>\" too\r\n      return;\r\n    }\r\n    Logger.Instance.WriteExceptionToLogWithMsg(\"in  FlowMonitorQueue.FillData() out of string bounds\");\r\n  }\r\n\r\n  /// <summary>\r\n  ///   parse the XML data\r\n  /// </summary>\r\n  /// <param name = \"tokensVector\">attribute/value/...attribute/value/ vector</param>\r\n  private initElements(tokensVector: List<string>): void {\r\n\r\n    for (let j: number = 0; j < tokensVector.length; j = j + 2) {\r\n      let attribute: string = <string>tokensVector.get_Item(j);\r\n      let valueStr: string = <string>tokensVector.get_Item(j + 1);\r\n      Logger.Instance.WriteDevToLog(attribute + \" value: \" + valueStr);\r\n\r\n      switch (attribute) {\r\n        case ConstInterface.MG_ATTR_TASK:\r\n          this._isTask = XmlParser.getBoolean(valueStr);\r\n          break;\r\n\r\n        case ConstInterface.MG_ATTR_TASKFLW:\r\n          this._isTaskFlow = XmlParser.getBoolean(valueStr);\r\n          break;\r\n\r\n        case ConstInterface.MG_TAG_DATAVIEW:\r\n          this._isDataView = XmlParser.getBoolean(valueStr);\r\n          break;\r\n\r\n        case ConstInterface.MG_ATTR_RECOMP:\r\n          this._isRecompute = XmlParser.getBoolean(valueStr);\r\n          break;\r\n\r\n        case ConstInterface.MG_ATTR_FLWOP:\r\n          this._isFlowOperation = XmlParser.getBoolean(valueStr);\r\n          break;\r\n\r\n        case ConstInterface.MG_ATTR_ENABLED:\r\n          this.enable(XmlParser.getBoolean(valueStr));\r\n          break;\r\n\r\n        default:\r\n          Logger.Instance.WriteExceptionToLogWithMsg(\"in FlowMonitorQueue.initElements(): unknown  attribute: \" + attribute);\r\n          break;\r\n      }\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  ///   build XML and empty the inner queue\r\n  /// </summary>\r\n  buildXML(message: StringBuilder): void {\r\n    if (!this._queue.isEmpty() && this.ShouldSerialize) {\r\n      message.Append(XMLConstants.START_TAG + ConstInterface.MG_TAG_FLWMTR_MSG + XMLConstants.TAG_CLOSE);\r\n\r\n      while (!this._queue.isEmpty()) {\r\n        let currAct: ActivityItem = <ActivityItem>this._queue.get();\r\n        currAct.buildXML(message);\r\n      } // fill activities\r\n\r\n      message.Append(\"</\" + ConstInterface.MG_TAG_FLWMTR_MSG + XMLConstants.TAG_CLOSE);\r\n    } // the queue is not empty\r\n  }\r\n\r\n  /// <summary>\r\n  ///   is the Flow Monitor Queue empty\r\n  /// </summary>\r\n  isEmpty(): boolean {\r\n    return this._queue.isEmpty();\r\n  }\r\n\r\n  /// <summary>\r\n  ///   enable the flow monitor\r\n  /// </summary>\r\n  /// <returns>the previous state (enabled/disabled)</returns>\r\n  enable(value: boolean): boolean {\r\n    let wasEnabled: boolean = this._enabled;\r\n    this._enabled = value;\r\n    this.ShouldSerialize = this._enabled;\r\n    return wasEnabled;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   add Activities to the queue\r\n  /// </summary>\r\n  /// <param name = \"triggeredBy\"></param>\r\n  /// <param name = \"state\">of the event task activitie</param>\r\n  addTaskEvent(triggeredBy: string, state: number, taskInfo: string): void {\r\n    if (this._enabled && this._isTask) {\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_TASK, FlowMonitorInterface.FLWMTR_EVENT);\r\n\r\n      let info: string;\r\n      switch (state) {\r\n        case FlowMonitorInterface.FLWMTR_START:\r\n          info = FlowMonitorQueue.S_EVENT_STR1 + triggeredBy + FlowMonitorQueue.S_EVENT_STR2;\r\n          break;\r\n\r\n        case FlowMonitorInterface.FLWMTR_END:\r\n          info = FlowMonitorQueue.E_EVENT_STR + triggeredBy;\r\n          break;\r\n\r\n        case FlowMonitorInterface.FLWMTR_PROPAGATE:\r\n          info = FlowMonitorQueue.S_EVENT_PROPAGATED;\r\n          break;\r\n\r\n        default:\r\n          info = null;\r\n          break;\r\n      }\r\n\r\n      act.setInfo(info);\r\n      this._queue.put(act);\r\n\r\n      Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n    }\r\n  }\r\n\r\n  private appendVirtualsAndParameters(currentValues: string) : void\r\n  {\r\n    let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_TASK_FLW, InternalInterface.MG_ACT_REC_PREFIX);\r\n    act.setInfo(currentValues);\r\n    this._queue.put(act);\r\n  }\r\n\r\n  // /// <summary>\r\n  // ///   add virtual and parameter information and send it to server on record prefix\r\n  // /// </summary>\r\n  // /// <param name = \"task\">\r\n  // /// </param>\r\n  addDataViewFlow(task: Task) : void\r\n  { \r\n      if (this._isDataView)\r\n      {\r\n          let fldTab: FieldsTable = task.DataView.GetFieldsTab();\r\n          let preparedDisplayString: string = \"\";\r\n          let finaldisplayData: string = \"\\n\";\r\n          let fldValue: string;\r\n          let data: string = \"\";\r\n          for (let i: number = 0; i < fldTab.getSize(); i++)\r\n          {\r\n              let fldDef: Field = <Field>fldTab.getField(i);\r\n              if (!fldDef.IsEventHandlerField && (fldDef.IsVirtual && !fldDef.VirAsReal) || fldDef.isParam())\r\n              {\r\n                  fldValue = fldDef.isNull() ? fldDef.getNullValue() : fldDef.getValue(true);\r\n                  data = this.getFieldData(fldDef.getType(), fldValue, fldDef.getPicture(), fldDef.getCellsType(), task);\r\n                  preparedDisplayString = this.PrepareDisplayString(fldDef.isParam(), fldDef.getVarName(), data, true);\r\n                  finaldisplayData = finaldisplayData + preparedDisplayString + \"\\n\";\r\n              }\r\n          }\r\n          this.appendVirtualsAndParameters(finaldisplayData);\r\n      }\r\n   }\r\n\r\n  // /// <summary>\r\n  // ///   Get virtuals and parameter values.\r\n  // /// </summary>\r\n  // /// <param name = \"Storagetype\"></param>\r\n  // /// <param name = \"data\"></param>\r\n  // /// <param name = \"picture\"></param>\r\n  // /// <param name = \"vecCellType\"></param>\r\n  // /// <param name = \"task\"></param>\r\n  // /// </param>\r\n  private getFieldData(Storagetype: StorageAttribute, data: string, picture: string, vecCellType: StorageAttribute, task: Task): string\r\n  {\r\n      switch (Storagetype)\r\n      {\r\n          case StorageAttribute.DOTNET:\r\n              data = FlowMonitorQueue.UNPRINTABLE_STR_LOG;\r\n              break;\r\n\r\n          case StorageAttribute.BLOB:\r\n              {\r\n                if(BlobType.isValidBlob(data))\r\n                {\r\n                  let contentType: string = BlobType.getContentType(data);\r\n                  if (contentType == BlobType.CONTENT_TYPE_ANSI || contentType == BlobType.CONTENT_TYPE_UNICODE)\r\n                      data = data != null ? BlobType.getString(data) : \"\";\r\n                  else\r\n                      data = FlowMonitorQueue.UNPRINTABLE_STR_LOG;\r\n                }\r\n                else\r\n                  data = \"\";\r\n              }\r\n              break;\r\n\r\n          case StorageAttribute.NUMERIC:\r\n          case StorageAttribute.DATE:\r\n          case StorageAttribute.TIME:\r\n              let conv: DisplayConvertor= DisplayConvertor.Instance;\r\n              data = conv.mg2disp(data, \" \", new PIC(picture, Storagetype, task.getCompIdx()), false, task.getCompIdx(), false);\r\n              break;\r\n\r\n          case StorageAttribute.BLOB_VECTOR:\r\n              let vecOutData: string;\r\n              if (data == null)\r\n              {\r\n                  vecOutData = \"[]\";\r\n              }\r\n              else\r\n              {\r\n                  let cellAtt: StorageAttribute = vecCellType;\r\n                  let vector: VectorType = new VectorType(data);\r\n                  if (cellAtt == StorageAttribute.BLOB && !VectorType.validateBlobContents(data))\r\n                      vecOutData = \"[]\";\r\n                  else\r\n                  {\r\n                      let vecSize: number = VectorType.getVecSize(data);\r\n                      let cellPicture: string = (cellAtt == StorageAttribute.NUMERIC || cellAtt == StorageAttribute.DATE || cellAtt == StorageAttribute.TIME) ? PIC.buildPicture(cellAtt, vector.getVecCell(1), task.getCompIdx(), true).getFormat() : picture;\r\n                      vecOutData = \"[\";\r\n                      for (let i : number = 0; i < vecSize; i++)\r\n                      {\r\n                          vecOutData += this.getFieldData(cellAtt, vector.getVecCell(i + 1), cellPicture, vecCellType, task);\r\n                          vecOutData += i < vecSize - 1 ? \",\" : \"]\";\r\n                      }\r\n                  }\r\n              }\r\n              data = vecOutData;\r\n              break;\r\n\r\n          case StorageAttribute.BOOLEAN:\r\n              data = data == \"1\" ? \"TRUE\" : \"FALSE\";\r\n              break;\r\n      }\r\n      return data;\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Prepare display string that will be sent to the server on record prefix.\r\n  /// </summary>\r\n  /// <param name = \"mode\"></param>\r\n  /// <param name = \"name\"></param>\r\n  /// <param name = \"valueContent\"></param>\r\n  /// <param name = \"addDoubleQuotes\"></param>\r\n  /// </param>\r\n  private PrepareDisplayString(mode: boolean, name: string, valueContent: string, addDoubleQuotes: boolean): string\r\n  {\r\n      let  str: string = \"\";\r\n      let finalStringToDisplay: string = \"\";\r\n      if (addDoubleQuotes)\r\n          finalStringToDisplay = finalStringToDisplay + \"\\\"\";\r\n      finalStringToDisplay = finalStringToDisplay + name;\r\n      if (addDoubleQuotes)\r\n          finalStringToDisplay = finalStringToDisplay + \"\\\"\";\r\n\r\n      let paddedName = this.padRight(name,34);\r\n      let formatOfStringVirtual:string = `Virtual` ;//: ${paddedName} : ${valueContent}`;\r\n      let formatOfStringParameter: string = `Parameter`;//` : ${paddedName} : ${valueContent}`;\r\n     \r\n      str = (mode ? formatOfStringParameter : formatOfStringVirtual) + \" : \" +`${paddedName}`+ \" : \"+`${valueContent.trim()}`;\r\n\r\n      return str;\r\n  }\r\n\r\n   private padRight = (string: string, length: number, character: string = ' '): string => {\r\n    let result = \"\";\r\n    let totalLength = length - string.length;\r\n    for (let i = 0; i < totalLength; i++) {\r\n      result = character + result;\r\n    }\r\n    result = result + string;\r\n    return result;\r\n  };\r\n  /// <summary>\r\n  ///   add task flow for record prefix or sufix\r\n  /// </summary>\r\n  /// <param name = \"id\">is FLWMTR_PREFIX or FLWMTR_SUFFIX\r\n  /// </param>\r\n  /// <param name = \"state\">of the event task activitie\r\n  /// </param>\r\n  addTaskFlowRec(id: number, state: number, taskInfo: string): void {\r\n    if (this._enabled && this._isTaskFlow) {\r\n      let info: string;\r\n\r\n      switch (id) {\r\n        case InternalInterface.MG_ACT_REC_PREFIX:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_RECPRF_STR\r\n            : FlowMonitorQueue.E_RECPRF_STR;\r\n          id = FlowMonitorInterface.FLWMTR_PREFIX;\r\n          break;\r\n\r\n        case InternalInterface.MG_ACT_REC_SUFFIX:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_RECSUF_STR\r\n            : FlowMonitorQueue.E_RECSUF_STR;\r\n          id = FlowMonitorInterface.FLWMTR_SUFFIX;\r\n          break;\r\n\r\n        case InternalInterface.MG_ACT_TASK_PREFIX:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_TASKPRF_STR\r\n            : FlowMonitorQueue.E_TASKPRF_STR;\r\n          id = FlowMonitorInterface.FLWMTR_PREFIX;\r\n          break;\r\n\r\n        case InternalInterface.MG_ACT_TASK_SUFFIX:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_TASKSUF_STR\r\n            : FlowMonitorQueue.E_TASKSUF_STR;\r\n          id = FlowMonitorInterface.FLWMTR_SUFFIX;\r\n          break;\r\n\r\n        default:\r\n          info = null;\r\n          break;\r\n      }\r\n\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_TASK_FLW, id);\r\n      act.setInfo(info);\r\n      this._queue.put(act);\r\n\r\n      Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n    }\r\n  }\r\n\r\n  /// <param name = \"id\">is MG_ACT_VARIABLE</param>\r\n  /// <param name = \"fldName\"></param>\r\n  /// <param name = \"state\">of the event task activitie</param>\r\n  addTaskFlowFld(id: number, fldName: string, state: number, taskInfo: string): void {\r\n    this.addTaskFlowCtrl(id, fldName, state, taskInfo);\r\n  }\r\n\r\n  /// <param name = \"id\">is FLWMTR_CTRL_PREFIX or FLWMTR_CTRL_SUFFIX</param>\r\n  /// <param name = \"ctrlName\"></param>\r\n  /// <param name = \"state\">of the event task activitie</param>\r\n  addTaskFlowCtrl(id: number, ctrlName: string, state: number, taskInfo: string): void {\r\n    if (this._enabled && this._isTaskFlow) {\r\n      let info: string;\r\n\r\n      switch (id) {\r\n        case InternalInterface.MG_ACT_VARIABLE:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_VARIABLE_STR\r\n            : FlowMonitorQueue.E_VARIABLE_STR;\r\n          id = FlowMonitorInterface.FLWMTR_VARCHG_VALUE;\r\n          break;\r\n\r\n        case InternalInterface.MG_ACT_CTRL_PREFIX:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_CTRLPRF_STR\r\n            : FlowMonitorQueue.E_CTRLPRF_STR;\r\n          id = FlowMonitorInterface.FLWMTR_CTRL_PREFIX;\r\n          break;\r\n\r\n\r\n        case InternalInterface.MG_ACT_CTRL_SUFFIX:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_CTRLSUF_STR\r\n            : FlowMonitorQueue.E_CTRLSUF_STR;\r\n          id = FlowMonitorInterface.FLWMTR_CTRL_SUFFIX;\r\n          break;\r\n\r\n        case InternalInterface.MG_ACT_CTRL_VERIFICATION:\r\n          info = state === FlowMonitorInterface.FLWMTR_START\r\n            ? FlowMonitorQueue.S_CTRLVER_STR\r\n            : FlowMonitorQueue.E_CTRLVER_STR;\r\n          id = FlowMonitorInterface.FLWMTR_CTRL_SUFFIX;\r\n          break;\r\n\r\n        default:\r\n          info = null;\r\n          break;\r\n      }\r\n\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_TASK_FLW, id);\r\n      if (info !== null) {\r\n        info = info + ctrlName;\r\n        if (id === FlowMonitorInterface.FLWMTR_VARCHG_VALUE && state === FlowMonitorInterface.FLWMTR_START)\r\n          info = info + FlowMonitorQueue.VARIABLE_REASON_STR;\r\n        act.setInfo(info);\r\n        Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n      }\r\n      this._queue.put(act);\r\n    }\r\n  }\r\n\r\n  /// <param name = \"handlerId\">isid of the handler\r\n  /// </param>\r\n  /// <param name = \"state\">of the event task activitie\r\n  /// </param>\r\n  addTaskFlowHandler(handlerId: string, state: number, taskInfo: string): void {\r\n    if (this._enabled && this._isTaskFlow) {\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_TASK_FLW, FlowMonitorInterface.FLWMTR_TSK_HANDLER);\r\n      let info: string;\r\n\r\n      switch (state) {\r\n        case FlowMonitorInterface.FLWMTR_START:\r\n          info = NString.Format(FlowMonitorQueue.S_HANDLER_STR, handlerId);\r\n          break;\r\n\r\n        case FlowMonitorInterface.FLWMTR_END:\r\n          info = NString.Format(FlowMonitorQueue.E_HANDLER_STR, handlerId);\r\n          break;\r\n\r\n        default:\r\n          info = null;\r\n          break;\r\n      }\r\n\r\n      if (info !== null) {\r\n        // BRK_LEVEL_HANDLER_INTERNAL,BRK_LEVEL_HANDLER_SYSTEM,BRK_LEVEL_HANDLER_TIMER\r\n        // BRK_LEVEL_HANDLER_EXPRESSION,BRK_LEVEL_HANDLER_ERROR,BRK_LEVEL_HANDLER_USER\r\n        act.setInfo(info);\r\n        Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n      }\r\n      this._queue.put(act);\r\n    }\r\n  }\r\n\r\n  /// <param name = \"triggeredByVarName\">var name , has triggered Recompute\r\n  /// </param>\r\n  addRecompute(triggeredByVarName: string, taskInfo: string): void {\r\n    if (this._enabled && this._isRecompute) {\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_RECOMPUTE, FlowMonitorInterface.FLWMTR_RECOMP);\r\n      let info = FlowMonitorQueue.RECOMP_STR + triggeredByVarName;\r\n      act.setInfo(info);\r\n      this._queue.put(act);\r\n\r\n      Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n    }\r\n  }\r\n\r\n  /// <summary>\r\n  ///   Add a field flow operation activity item.\r\n  /// </summary>\r\n  /// <param name = \"oper\">The operation being logged.</param>\r\n  /// <param name = \"bExecuted\">Will the operation be executed.</param>\r\n  async addFlowFieldOperation(oper: Operation, bExecuted: boolean, taskInfo: string): Promise<void> {\r\n    if (this._enabled && this._isFlowOperation) {\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_FLW_OPER, FlowMonitorInterface.FLWMTR_DATA_OPER);\r\n      let buffer: StringBuilder = new StringBuilder(FlowMonitorQueue.FLW_PERFIX);\r\n      await oper.AddFlowDescription(buffer);\r\n      buffer.Append(' ');\r\n\r\n\r\n      if (!bExecuted)\r\n        buffer.Append(\"[Not Executed]\");\r\n\r\n      let info = buffer.ToString();\r\n      act.setInfo(info);\r\n      this._queue.put(act);\r\n\r\n      Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n    }\r\n  }\r\n\r\n  /// <param name = \"state\">of the update\r\n  /// </param>\r\n  addFlowOperationUpdate(state: number, taskInfo: string): void {\r\n    if (this._enabled && this._isFlowOperation) {\r\n      let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_FLW_OPER, FlowMonitorInterface.FLWMTR_DATA_OPER); // MG_OPER_UPDATE\r\n      let info: string;\r\n      if (state === FlowMonitorInterface.FLWMTR_START)\r\n        info = \"Starts Update\";\r\n      else\r\n        info =  \"Ends Update\";\r\n\r\n      act.setInfo(info);\r\n      this._queue.put(act);\r\n\r\n      Logger.Instance.WriteSupportToLog(taskInfo +\": \" + info, true);\r\n    }\r\n  }\r\n\r\n  /// <param name = \"info\">string passed to status line verify action</param>\r\n  addFlowVerifyInfo(info: string, taskInfo: string): void {\r\n    this.addFlowInfo(info, taskInfo);\r\n  }\r\n\r\n  /// <param name = \"info\">string added to flow monitor queue for InvokeOs</param>\r\n  addFlowInvokeOsInfo(info: string, taskInfo: string): void {\r\n    this.addFlowInfo(info, taskInfo);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   user string passed to status line for actions\r\n  /// </summary>\r\n  /// <param name = \"info\">\r\n  /// </param>\r\n  private addFlowInfo(info: string, taskInfo: string): void {\r\n    if (!this._enabled)\r\n      return;\r\n\r\n    let act: ActivityItem = new ActivityItem(this, FlowMonitorQueue.ACT_FLW_OPER, FlowMonitorInterface.FLWMTR_DATA_OPER);\r\n    let buffer: StringBuilder = new StringBuilder(\"\");\r\n\r\n    if (!(info === \"\")) {\r\n      buffer.Append(\" >> INFORMATION >> \");\r\n      buffer.Append(info);\r\n    }\r\n    let newInfo = buffer.ToString();\r\n    act.setInfo(newInfo);\r\n    this._queue.put(act);\r\n\r\n    Logger.Instance.WriteSupportToLog(taskInfo +\": \" + newInfo, true);\r\n  }\r\n}\r\n\r\n/// <summary>\r\n///   all information about current Activity\r\n/// </summary>\r\nclass ActivityItem {\r\n  private _id: number = 0;\r\n  private _type: string = null; // ACTY_TASK|ACT_TASK_FLW|ACT_DATAVIEW|ACT_RECOMPUTE|ACT_FLW_OPER\r\n  private _info: string = null;\r\n  private _time: string = null;\r\n\r\n  constructor(enclosingInstance: FlowMonitorQueue, type: string, id: number) {\r\n    this._type = type;\r\n    this._id = id;\r\n    this.setTime();\r\n  }\r\n\r\n  /// <summary>\r\n  ///   save current time in the needed format\r\n  /// </summary>\r\n  private setTime(): void {\r\n    this._time = DateTimeUtils.ToString(DateTime.Now, FlowMonitorQueue.LongTimePattern, Logger.Instance);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   set added information for the activity\r\n  /// </summary>\r\n  setInfo(info_: string): void {\r\n    this._info = ((info_ !== null) ? XmlParser.escape(info_) : info_);\r\n  }\r\n\r\n  /// <summary>\r\n  ///   build XML string for the activity item\r\n  /// </summary>\r\n  buildXML(message: StringBuilder): void {\r\n    message.Append(XMLConstants.START_TAG + ConstInterface.MG_TAG_FLWMTR_ACT);\r\n    message.Append(\" \" + XMLConstants.MG_ATTR_TYPE + \"=\\\"\" + this._type + \"\\\"\");\r\n    message.Append(\" \" + XMLConstants.MG_ATTR_ID + \"=\\\"\" + this._id + \"\\\"\");\r\n    if (this._info != null)\r\n      message.Append(\" \" + ConstInterface.MG_ATTR_INFO + \"=\\\"\" + this._info + \"\\\"\");\r\n    message.Append(\" \" + ConstInterface.MG_ATTR_TIME + \"=\\\"\" + this._time + \"\\\"\");\r\n    message.Append(XMLConstants.TAG_TERM);\r\n  }\r\n}\r\n"]}
@@ -1,70 +0,0 @@
1
- export class HeapSort {
2
- static left(i) {
3
- return 2 * i + 1;
4
- }
5
- static right(i) {
6
- return 2 * i + 2;
7
- }
8
- static sort(array) {
9
- let sortsize = array.length;
10
- let temp;
11
- let largest, i, l, r;
12
- if (sortsize <= 1)
13
- return;
14
- let top = sortsize - 1;
15
- let t = Math.floor(sortsize / 2);
16
- do {
17
- t = t - 1;
18
- largest = t;
19
- do {
20
- i = largest;
21
- l = HeapSort.left(largest);
22
- r = HeapSort.right(largest);
23
- if (l <= top) {
24
- if (array[l].CompareTo(array[i]) > 0)
25
- largest = l;
26
- }
27
- if (r <= top) {
28
- if (array[r].CompareTo(array[largest]) > 0)
29
- largest = r;
30
- }
31
- if (largest !== i) {
32
- temp = array[largest];
33
- array[largest] = array[i];
34
- array[i] = temp;
35
- }
36
- } while (largest !== i);
37
- } while (t > 0);
38
- t = sortsize;
39
- do {
40
- top = top - 1;
41
- t = t - 1;
42
- let here = t;
43
- temp = array[here];
44
- array[here] = array[0];
45
- array[0] = temp;
46
- largest = 0;
47
- do {
48
- i = largest;
49
- l = HeapSort.left(largest);
50
- r = HeapSort.right(largest);
51
- if (l <= top) {
52
- if (array[l].CompareTo(array[i]) > 0) {
53
- largest = l;
54
- }
55
- }
56
- if (r <= top) {
57
- if (array[r].CompareTo(array[largest]) > 0) {
58
- largest = r;
59
- }
60
- }
61
- if (largest !== i) {
62
- temp = array[largest];
63
- array[largest] = array[i];
64
- array[i] = temp;
65
- }
66
- } while (largest !== i);
67
- } while (t > 1);
68
- }
69
- }
70
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSGVhcFNvcnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbmdpbmUvc3JjL3V0aWwvSGVhcFNvcnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBS0EsTUFBTSxPQUFPLFFBQVE7SUFDWCxNQUFNLENBQUMsSUFBSSxDQUFDLENBQVM7UUFDM0IsT0FBTyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNuQixDQUFDO0lBRU8sTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFTO1FBQzVCLE9BQU8sQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDbkIsQ0FBQztJQUtELE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBb0I7UUFDOUIsSUFBSSxRQUFRLEdBQVcsS0FBSyxDQUFDLE1BQU0sQ0FBQztRQUNwQyxJQUFJLElBQWlCLENBQUM7UUFDdEIsSUFBSSxPQUFlLEVBQUUsQ0FBUyxFQUFFLENBQVMsRUFBRSxDQUFTLENBQUM7UUFFckQsSUFBSSxRQUFRLElBQUksQ0FBQztZQUNmLE9BQU87UUFFVCxJQUFJLEdBQUcsR0FBVyxRQUFRLEdBQUcsQ0FBQyxDQUFDO1FBQy9CLElBQUksQ0FBQyxHQUFXLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxHQUFHLENBQUMsQ0FBQyxDQUFDO1FBRXpDLEdBQUc7WUFDRCxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUNWLE9BQU8sR0FBRyxDQUFDLENBQUM7WUFJWixHQUFHO2dCQUNELENBQUMsR0FBRyxPQUFPLENBQUM7Z0JBQ1osQ0FBQyxHQUFHLFFBQVEsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7Z0JBQzNCLENBQUMsR0FBRyxRQUFRLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO2dCQUU1QixJQUFJLENBQUMsSUFBSSxHQUFHLEVBQUU7b0JBQ1osSUFBSSxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUM7d0JBQ2xDLE9BQU8sR0FBRyxDQUFDLENBQUM7aUJBQ2Y7Z0JBQ0QsSUFBSSxDQUFDLElBQUksR0FBRyxFQUFFO29CQUNaLElBQUksS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUMsR0FBRyxDQUFDO3dCQUN4QyxPQUFPLEdBQUcsQ0FBQyxDQUFDO2lCQUNmO2dCQUNELElBQUksT0FBTyxLQUFLLENBQUMsRUFBRTtvQkFDakIsSUFBSSxHQUFHLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztvQkFDdEIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztvQkFDMUIsS0FBSyxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQztpQkFDakI7YUFDRixRQUNNLE9BQU8sS0FBSyxDQUFDLEVBQUU7U0FDdkIsUUFDTSxDQUFDLEdBQUcsQ0FBQyxFQUFFO1FBRWQsQ0FBQyxHQUFHLFFBQVEsQ0FBQztRQUViLEdBQUc7WUFDRCxHQUFHLEdBQUcsR0FBRyxHQUFHLENBQUMsQ0FBQztZQUNkLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBRVYsSUFBSSxJQUFJLEdBQVcsQ0FBQyxDQUFDO1lBRXJCLElBQUksR0FBRyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDbkIsS0FBSyxDQUFDLElBQUksQ0FBQyxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUN2QixLQUFLLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDO1lBRWhCLE9BQU8sR0FBRyxDQUFDLENBQUM7WUFFWixHQUFHO2dCQUNELENBQUMsR0FBRyxPQUFPLENBQUM7Z0JBQ1osQ0FBQyxHQUFHLFFBQVEsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7Z0JBQzNCLENBQUMsR0FBRyxRQUFRLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO2dCQUU1QixJQUFJLENBQUMsSUFBSSxHQUFHLEVBQUU7b0JBQ1osSUFBSSxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsRUFBRTt3QkFDcEMsT0FBTyxHQUFHLENBQUMsQ0FBQztxQkFDYjtpQkFDRjtnQkFDRCxJQUFJLENBQUMsSUFBSSxHQUFHLEVBQUU7b0JBQ1osSUFBSSxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxHQUFHLENBQUMsRUFBRTt3QkFDMUMsT0FBTyxHQUFHLENBQUMsQ0FBQztxQkFDYjtpQkFDRjtnQkFDRCxJQUFJLE9BQU8sS0FBSyxDQUFDLEVBQUU7b0JBQ2pCLElBQUksR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7b0JBQ3RCLEtBQUssQ0FBQyxPQUFPLENBQUMsR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUM7b0JBQzFCLEtBQUssQ0FBQyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUM7aUJBQ2pCO2FBQ0YsUUFDTSxPQUFPLEtBQUssQ0FBQyxFQUFFO1NBQ3ZCLFFBQ00sQ0FBQyxHQUFHLENBQUMsRUFBRTtJQUNoQixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0lDb21wYXJhYmxlfSBmcm9tIFwiQG1hZ2ljLXhwYS9tc2NvcmVsaWJcIjtcclxuXHJcbi8vLyA8c3VtbWFyeT5DbGFzcyBmb3IgSkFWQSAxLjEgY29udGFpbmluZyBzdGF0aWMgbWV0aG9kcyB0byBzb3J0IGFuIGFyYml0cmFyeSBhcnJheVxyXG4vLy8gb2YgSkFWQSBvYmplY3RzIHdoaWNoIGltcGxlbWVudCB0aGUgSUNvbXBhcmFibGUgaW50ZXJmYWNlLlxyXG4vLy8gPC9zdW1tYXJ5PlxyXG5leHBvcnQgY2xhc3MgSGVhcFNvcnQge1xyXG4gIHByaXZhdGUgc3RhdGljIGxlZnQoaTogbnVtYmVyKTogbnVtYmVyIHtcclxuICAgIHJldHVybiAyICogaSArIDE7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIHN0YXRpYyByaWdodChpOiBudW1iZXIpOiBudW1iZXIge1xyXG4gICAgcmV0dXJuIDIgKiBpICsgMjtcclxuICB9XHJcblxyXG4gIC8vLyA8c3VtbWFyeT5Tb3J0IGFycmF5LCByZWFycmFuZ2luZyB0aGUgZW50cmllcyBpbiBhcnJheSB0byBiZSBpblxyXG4gIC8vLyBzb3J0ZWQgb3JkZXIuXHJcbiAgLy8vIDwvc3VtbWFyeT5cclxuICBzdGF0aWMgc29ydChhcnJheTogSUNvbXBhcmFibGVbXSk6IHZvaWQge1xyXG4gICAgbGV0IHNvcnRzaXplOiBudW1iZXIgPSBhcnJheS5sZW5ndGg7XHJcbiAgICBsZXQgdGVtcDogSUNvbXBhcmFibGU7XHJcbiAgICBsZXQgbGFyZ2VzdDogbnVtYmVyLCBpOiBudW1iZXIsIGw6IG51bWJlciwgcjogbnVtYmVyO1xyXG5cclxuICAgIGlmIChzb3J0c2l6ZSA8PSAxKVxyXG4gICAgICByZXR1cm47XHJcblxyXG4gICAgbGV0IHRvcDogbnVtYmVyID0gc29ydHNpemUgLSAxO1xyXG4gICAgbGV0IHQ6IG51bWJlciA9IE1hdGguZmxvb3Ioc29ydHNpemUgLyAyKTtcclxuXHJcbiAgICBkbyB7XHJcbiAgICAgIHQgPSB0IC0gMTtcclxuICAgICAgbGFyZ2VzdCA9IHQ7XHJcblxyXG4gICAgICAvKiBoZWFwaWZ5ICovXHJcblxyXG4gICAgICBkbyB7XHJcbiAgICAgICAgaSA9IGxhcmdlc3Q7XHJcbiAgICAgICAgbCA9IEhlYXBTb3J0LmxlZnQobGFyZ2VzdCk7XHJcbiAgICAgICAgciA9IEhlYXBTb3J0LnJpZ2h0KGxhcmdlc3QpO1xyXG5cclxuICAgICAgICBpZiAobCA8PSB0b3ApIHtcclxuICAgICAgICAgIGlmIChhcnJheVtsXS5Db21wYXJlVG8oYXJyYXlbaV0pID4gMClcclxuICAgICAgICAgICAgbGFyZ2VzdCA9IGw7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGlmIChyIDw9IHRvcCkge1xyXG4gICAgICAgICAgaWYgKGFycmF5W3JdLkNvbXBhcmVUbyhhcnJheVtsYXJnZXN0XSkgPiAwKVxyXG4gICAgICAgICAgICBsYXJnZXN0ID0gcjtcclxuICAgICAgICB9XHJcbiAgICAgICAgaWYgKGxhcmdlc3QgIT09IGkpIHtcclxuICAgICAgICAgIHRlbXAgPSBhcnJheVtsYXJnZXN0XTtcclxuICAgICAgICAgIGFycmF5W2xhcmdlc3RdID0gYXJyYXlbaV07XHJcbiAgICAgICAgICBhcnJheVtpXSA9IHRlbXA7XHJcbiAgICAgICAgfVxyXG4gICAgICB9XHJcbiAgICAgIHdoaWxlIChsYXJnZXN0ICE9PSBpKTtcclxuICAgIH1cclxuICAgIHdoaWxlICh0ID4gMCk7XHJcblxyXG4gICAgdCA9IHNvcnRzaXplO1xyXG5cclxuICAgIGRvIHtcclxuICAgICAgdG9wID0gdG9wIC0gMTtcclxuICAgICAgdCA9IHQgLSAxO1xyXG5cclxuICAgICAgbGV0IGhlcmU6IG51bWJlciA9IHQ7XHJcblxyXG4gICAgICB0ZW1wID0gYXJyYXlbaGVyZV07XHJcbiAgICAgIGFycmF5W2hlcmVdID0gYXJyYXlbMF07XHJcbiAgICAgIGFycmF5WzBdID0gdGVtcDtcclxuXHJcbiAgICAgIGxhcmdlc3QgPSAwO1xyXG5cclxuICAgICAgZG8ge1xyXG4gICAgICAgIGkgPSBsYXJnZXN0O1xyXG4gICAgICAgIGwgPSBIZWFwU29ydC5sZWZ0KGxhcmdlc3QpO1xyXG4gICAgICAgIHIgPSBIZWFwU29ydC5yaWdodChsYXJnZXN0KTtcclxuXHJcbiAgICAgICAgaWYgKGwgPD0gdG9wKSB7XHJcbiAgICAgICAgICBpZiAoYXJyYXlbbF0uQ29tcGFyZVRvKGFycmF5W2ldKSA+IDApIHtcclxuICAgICAgICAgICAgbGFyZ2VzdCA9IGw7XHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGlmIChyIDw9IHRvcCkge1xyXG4gICAgICAgICAgaWYgKGFycmF5W3JdLkNvbXBhcmVUbyhhcnJheVtsYXJnZXN0XSkgPiAwKSB7XHJcbiAgICAgICAgICAgIGxhcmdlc3QgPSByO1xyXG4gICAgICAgICAgfVxyXG4gICAgICAgIH1cclxuICAgICAgICBpZiAobGFyZ2VzdCAhPT0gaSkge1xyXG4gICAgICAgICAgdGVtcCA9IGFycmF5W2xhcmdlc3RdO1xyXG4gICAgICAgICAgYXJyYXlbbGFyZ2VzdF0gPSBhcnJheVtpXTtcclxuICAgICAgICAgIGFycmF5W2ldID0gdGVtcDtcclxuICAgICAgICB9XHJcbiAgICAgIH1cclxuICAgICAgd2hpbGUgKGxhcmdlc3QgIT09IGkpO1xyXG4gICAgfVxyXG4gICAgd2hpbGUgKHQgPiAxKTtcclxuICB9XHJcbn1cclxuXHJcbiJdfQ==