@magic-xpa/engine 4.1000.0-dev4100.106 → 4.1000.0-dev4100.107
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/src/CurrentClientVersion.mjs +2 -2
- package/esm2020/src/event/EventHandler.mjs +2 -4
- package/esm2020/src/event/EventHandlerPosition.mjs +5 -1
- package/esm2020/src/util/FlowMonitorQueue.mjs +103 -2
- package/fesm2015/magic-xpa-engine.mjs +106 -5
- package/fesm2015/magic-xpa-engine.mjs.map +1 -1
- package/fesm2020/magic-xpa-engine.mjs +106 -5
- package/fesm2020/magic-xpa-engine.mjs.map +1 -1
- package/package.json +4 -4
- package/src/util/FlowMonitorQueue.d.ts +8 -0
|
@@ -2,6 +2,7 @@ import { InternalInterface, Logger } from "@magic-xpa/utils";
|
|
|
2
2
|
import { ConstInterface } from "../ConstInterface";
|
|
3
3
|
import { AccessHelper } from "../AccessHelper";
|
|
4
4
|
import { isNullOrUndefined } from "@magic-xpa/mscorelib";
|
|
5
|
+
import { FlowMonitorQueue } from "../util/FlowMonitorQueue";
|
|
5
6
|
export class EventHandlerPosition {
|
|
6
7
|
constructor() {
|
|
7
8
|
this._handlerIdx = 0;
|
|
@@ -58,6 +59,9 @@ export class EventHandlerPosition {
|
|
|
58
59
|
case InternalInterface.MG_ACT_REC_SUFFIX:
|
|
59
60
|
case InternalInterface.MG_ACT_CTRL_PREFIX:
|
|
60
61
|
case InternalInterface.MG_ACT_CTRL_SUFFIX: {
|
|
62
|
+
if (this._rtEvt.getInternalCode() == InternalInterface.MG_ACT_REC_PREFIX) {
|
|
63
|
+
FlowMonitorQueue.Instance.addDataViewFlow(this._task);
|
|
64
|
+
}
|
|
61
65
|
if (this._handlerIdx === -1) {
|
|
62
66
|
for (this._handlerIdx = this._handlersTab.getSize() - 1; this._handlerIdx >= 0; this._handlerIdx--) {
|
|
63
67
|
let handler = this._handlersTab.getHandler(this._handlerIdx);
|
|
@@ -197,4 +201,4 @@ EventHandlerPosition.PHASE_CONTROL_SPECIFIC = 1;
|
|
|
197
201
|
EventHandlerPosition.PHASE_CONTROL_NON_SPECIFIC = 2;
|
|
198
202
|
EventHandlerPosition.PHASE_GLOBAL = 3;
|
|
199
203
|
EventHandlerPosition.PHASE_GLOBAL_SPECIFIC = 4;
|
|
200
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"EventHandlerPosition.js","sourceRoot":"","sources":["../../../../../../projects/engine/src/event/EventHandlerPosition.ts"],"names":[],"mappings":"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","sourcesContent":["import {InternalInterface, Logger} from \"@magic-xpa/utils\";\r\nimport {HandlersTable} from \"../rt/HandlersTable\";\r\nimport {RunTimeEvent} from \"./RunTimeEvent\";\r\nimport {Task} from \"../tasks/Task\";\r\nimport {EventHandler} from \"./EventHandler\";\r\nimport {MGData} from \"../tasks/MGData\";\r\nimport {ConstInterface} from \"../ConstInterface\";\r\nimport { AccessHelper } from \"../AccessHelper\";\r\nimport {isNullOrUndefined} from \"@magic-xpa/mscorelib\";\r\n\r\n/// <summary>\r\n///   an object of this class points to the position of an event handler in the\r\n///   chain of the event handlers\r\n/// </summary>\r\nexport class EventHandlerPosition {\r\n  private static PHASE_CONTROL_SPECIFIC: number = 1;\r\n  private static PHASE_CONTROL_NON_SPECIFIC: number = 2;\r\n  private static PHASE_GLOBAL: number = 3;\r\n  private static PHASE_GLOBAL_SPECIFIC: number = 4;\r\n\r\n  private _handlerIdx: number = 0; // the index of the handler within the task\r\n  private _handlersTab: HandlersTable = null;\r\n  private _orgPrevTask: Task = null; // reference to the previous checked task\r\n  private _orgTask: Task = null; // reference to the current checked task\r\n  private _phase: number = 0; // the phase of the search: control specific, control non-specific, global\r\n  private _prevTask: Task = null; // reference to the previous checked task\r\n  private _rtEvt: RunTimeEvent = null; // the event\r\n  private _task: Task = null; // reference to the current checked task\r\n\r\n\r\n  constructor() {\r\n  }\r\n  ///   init the position to start a new chain of search\r\n  init(rtEvent: RunTimeEvent): void {\r\n    this._rtEvt = rtEvent;\r\n    this._task = <Task>this._rtEvt.getTask();\r\n    if (this._task.isMainProg()) {\r\n      this._prevTask = <Task>this._rtEvt.getMainPrgCreator();\r\n      if (this._prevTask !== null && this._prevTask.isMainProg())\r\n        this._prevTask = null;\r\n    }\r\n\r\n    if (rtEvent.getType() === ConstInterface.EVENT_TYPE_USER_FUNC)\r\n      this._phase = EventHandlerPosition.PHASE_CONTROL_NON_SPECIFIC;\r\n    else {\r\n      if (rtEvent.getType() === ConstInterface.EVENT_TYPE_USER_FUNC)\r\n        this._phase = EventHandlerPosition.PHASE_CONTROL_NON_SPECIFIC;\r\n      else\r\n        this._phase = EventHandlerPosition.PHASE_CONTROL_SPECIFIC;\r\n    }\r\n\r\n    this._orgTask = this._task;\r\n    this._orgPrevTask = this._prevTask;\r\n    this._handlersTab = this._task.getHandlersTab();\r\n    if (this._handlersTab === null) {\r\n      this.goUpTaskChain();\r\n    }\r\n\r\n    this._handlerIdx = -1;\r\n  }\r\n\r\n  getNext(evt: RunTimeEvent): EventHandler;\r\n  getNext(): EventHandler;\r\n  getNext(evt?: RunTimeEvent): EventHandler {\r\n    if (!isNullOrUndefined(evt))\r\n      return this.getNext_0(evt);\r\n    else\r\n      return this.getNext_1();\r\n  }\r\n\r\n  ///   changes the current run time event and returns the next event handler\r\n  private getNext_0(evt: RunTimeEvent): EventHandler {\r\n    this._rtEvt = evt;\r\n    return this.getNext();\r\n  }\r\n\r\n  ///   returns the next event handler\r\n  private getNext_1(): EventHandler {\r\n    if (this._handlersTab === null)\r\n      return null;\r\n    if (this._rtEvt.getType() === ConstInterface.EVENT_TYPE_INTERNAL && this._rtEvt.getInternalCode() !== InternalInterface.MG_ACT_VARIABLE) {\r\n      // special treatment for TASK, RECORD and CONTROL level Prefix/Suffix events\r\n      switch (this._rtEvt.getInternalCode()) {\r\n        case InternalInterface.MG_ACT_TASK_PREFIX:\r\n        case InternalInterface.MG_ACT_TASK_SUFFIX:\r\n        case InternalInterface.MG_ACT_REC_PREFIX:\r\n        case InternalInterface.MG_ACT_REC_SUFFIX:\r\n        case InternalInterface.MG_ACT_CTRL_PREFIX:\r\n        case InternalInterface.MG_ACT_CTRL_SUFFIX: {\r\n          if (this._handlerIdx === -1) {\r\n            for (this._handlerIdx = this._handlersTab.getSize() - 1; this._handlerIdx >= 0; this._handlerIdx--) {\r\n              let handler: EventHandler = this._handlersTab.getHandler(this._handlerIdx);\r\n              if ((handler.isNonSpecificHandlerOf(this._rtEvt)) || (handler.isSpecificHandlerOf(this._rtEvt))) {\r\n                return handler;\r\n              }\r\n            }\r\n          }\r\n\r\n          // an event handler was not found or was returned in a previous call to this method\r\n          return null;\r\n        }\r\n\r\n        default:\r\n          // other internal events should continue\r\n          break;\r\n      }\r\n    }\r\n\r\n    while (this.setNextHandlerIdx()) {\r\n      let handler: EventHandler = this._handlersTab.getHandler(this._handlerIdx);\r\n      switch (this._phase) {\r\n        case EventHandlerPosition.PHASE_CONTROL_SPECIFIC:\r\n          if (handler.isSpecificHandlerOf(this._rtEvt))\r\n            return handler;\r\n          continue;\r\n\r\n        case EventHandlerPosition.PHASE_CONTROL_NON_SPECIFIC:\r\n          if (handler.isNonSpecificHandlerOf(this._rtEvt))\r\n            return handler;\r\n          continue;\r\n\r\n        case EventHandlerPosition.PHASE_GLOBAL_SPECIFIC:\r\n          if (handler.isGlobalSpecificHandlerOf(this._rtEvt))\r\n            return handler;\r\n          continue;\r\n\r\n        case EventHandlerPosition.PHASE_GLOBAL:\r\n          if (handler.isGlobalHandlerOf(this._rtEvt))\r\n            return handler;\r\n          continue;\r\n\r\n        default:\r\n          Logger.Instance.WriteExceptionToLogWithMsg(\"in EventHandlerPosition.getNext() invalid phase: \" + this._phase);\r\n          break;\r\n      }\r\n    }\r\n\r\n    return null;\r\n  }\r\n\r\n  ///   returns true if a next handler was found\r\n  private setNextHandlerIdx(): boolean {\r\n\r\n    // the handler idx is (-1) when starting to search in a task\r\n    if (this._handlerIdx < 0)\r\n      this._handlerIdx = this._handlersTab.getSize() - 1;\r\n    else\r\n      this._handlerIdx = this._handlerIdx - 1;\r\n\r\n    if (this._handlerIdx < 0 || this._task.isAborting()) {\r\n      // if there are no more handlers in the task then go up the chain of tasks\r\n      if (this.goUpTaskChain())\r\n        return this.setNextHandlerIdx();\r\n      else // no more tasks in the chain\r\n        return false;\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n  ///   get the next task in the tasks chain and returns false if no task was found.\r\n  ///   this function changes the phase variable accordingly\r\n  private goUpTaskChain(): boolean {\r\n    let mGData: MGData = this._task.getMGData();\r\n    let ctlIdx: number = this._task.getCtlIdx();\r\n\r\n    switch (this._phase) {\r\n      case EventHandlerPosition.PHASE_CONTROL_SPECIFIC:\r\n      case EventHandlerPosition.PHASE_CONTROL_NON_SPECIFIC: {\r\n        // non specific handlers are searched till we hit our main program (inclusive)\r\n        // afterwards we switch to global phase.\r\n        if (!this._task.isMainProg()) {\r\n          this.getParentOrCompMainPrg();\r\n          break;\r\n        }\r\n        else {\r\n          // internal, internal, system and user events may cross component bounderies\r\n          if ((this._rtEvt.getType() === ConstInterface.EVENT_TYPE_PUBLIC ||\r\n               this._rtEvt.getType() === ConstInterface.EVENT_TYPE_INTERNAL ||\r\n               this._rtEvt.getType() === ConstInterface.EVENT_TYPE_SYSTEM ||\r\n               this._rtEvt.getType() === ConstInterface.EVENT_TYPE_USER) && ctlIdx > 0) {\r\n            // load the RT parent of the previous task. If no prevtask exists then we are\r\n            // simply running on the main progs list (for example, when a main prg catches\r\n            // a timer event, no prevtask exists.\r\n            if (this._prevTask === null) {\r\n              this._task = mGData.getNextMainProg(ctlIdx);\r\n              if (this._task === null && ctlIdx > 0)\r\n                this._task = <Task>AccessHelper.mgDataTable.GetMainProgByCtlIdx(-1, AccessHelper.eventsManager.getCompMainPrgTab().getCtlIdx(0));\r\n            }\r\n            else {\r\n              // the component main program that was set in getParentOrCompMainPrg, is now replaced back to the path parent.\r\n              this._task = this._prevTask.PathParentTask;\r\n              this._prevTask = null;\r\n            }\r\n            this._rtEvt.setMainPrgCreator(null); // moving out of a main program to another task\r\n            break;\r\n          }\r\n\r\n          if (this._phase === EventHandlerPosition.PHASE_CONTROL_SPECIFIC) {\r\n            // specific search is over. start the non specific search from the first task.\r\n            this._phase = EventHandlerPosition.PHASE_GLOBAL_SPECIFIC;\r\n          }\r\n          else {\r\n            // here we scan the main progs according to the load sequence (first to last).\r\n            this._phase = EventHandlerPosition.PHASE_GLOBAL;\r\n          }\r\n\r\n          this._task = <Task>AccessHelper.mgDataTable.GetMainProgByCtlIdx(-1, AccessHelper.eventsManager.getCompMainPrgTab().getCtlIdx(0));\r\n          this._rtEvt.setMainPrgCreator(this._task);\r\n          if (this._task === null)\r\n            return false;\r\n          break;\r\n        }\r\n      }\r\n      case EventHandlerPosition.PHASE_GLOBAL_SPECIFIC:\r\n      case EventHandlerPosition.PHASE_GLOBAL: {\r\n        this._task = mGData.getNextMainProg(ctlIdx);\r\n        if (this._task === null) {\r\n          if (this._phase === EventHandlerPosition.PHASE_GLOBAL)\r\n            return false;\r\n\r\n          // specific search is over. start the non specific search from the first task.\r\n          this._phase = EventHandlerPosition.PHASE_CONTROL_NON_SPECIFIC;\r\n          this._task = this._orgTask;\r\n          this._prevTask = this._orgPrevTask;\r\n        }\r\n        break;\r\n      }\r\n      default:\r\n        Logger.Instance.WriteExceptionToLogWithMsg(\"in EventHandlerPosition.goUpTaskChain() invalid phase: \" + this._phase);\r\n        break;\r\n    }\r\n    if (this._task === null)\r\n      return false;\r\n\r\n    this._handlersTab = this._task.getHandlersTab();\r\n    if (this._handlersTab === null)\r\n      return this.goUpTaskChain();\r\n\r\n    this._handlerIdx = -1;\r\n    return true;\r\n  }\r\n\r\n  ///   if the current task and its parent are from different components then\r\n  ///   set the task to the main program of the component of the current task.\r\n  ///   otherwise, set the task to be the parent of the current task\r\n  private getParentOrCompMainPrg(): void {\r\n    let ctlIdx: number = this._task.getCtlIdx();\r\n    this._prevTask = this._task;\r\n\r\n    // Retrieve the task's calling-parent. We need the task who invoked the current task\r\n    // rather than the task's triggering parent.\r\n    // The Path Parent is the parent of that task as if the server had done build path. It is more logical to search using the trigger task tree\r\n    // but since the online/server does not use the trigger tree, we decided not to use it here as well.\r\n    // If the path parent is from a different comp, it means that between curr task and parent there should be a comp main prog.\r\n    let pathParentTask: Task = this._task.PathParentTask;\r\n    if (pathParentTask === null) {\r\n      this._task = null;\r\n      return;\r\n    }\r\n\r\n    // check if the parent task is from another component\r\n    if (ctlIdx !== pathParentTask.getCtlIdx()) {\r\n      // replace the parent task to search with the comp main program. later on, the main prog will be replaced with\r\n      // the real PathParentTask.\r\n      this._rtEvt.setMainPrgCreator(this._task);\r\n      this._task = <Task>AccessHelper.mgDataTable.GetMainProgByCtlIdx(-1, ctlIdx);\r\n    }\r\n    else {\r\n      this._rtEvt.setMainPrgCreator(null);\r\n      this._task = pathParentTask;\r\n    }\r\n  }\r\n}\r\n"]}
|
|
204
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"EventHandlerPosition.js","sourceRoot":"","sources":["../../../../../../projects/engine/src/event/EventHandlerPosition.ts"],"names":[],"mappings":"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","sourcesContent":["import {InternalInterface, Logger} from \"@magic-xpa/utils\";\r\nimport {HandlersTable} from \"../rt/HandlersTable\";\r\nimport {RunTimeEvent} from \"./RunTimeEvent\";\r\nimport {Task} from \"../tasks/Task\";\r\nimport {EventHandler} from \"./EventHandler\";\r\nimport {MGData} from \"../tasks/MGData\";\r\nimport {ConstInterface} from \"../ConstInterface\";\r\nimport { AccessHelper } from \"../AccessHelper\";\r\nimport {isNullOrUndefined} from \"@magic-xpa/mscorelib\";\r\nimport { FlowMonitorQueue } from \"../util/FlowMonitorQueue\";\r\n\r\n/// <summary>\r\n///   an object of this class points to the position of an event handler in the\r\n///   chain of the event handlers\r\n/// </summary>\r\nexport class EventHandlerPosition {\r\n  private static PHASE_CONTROL_SPECIFIC: number = 1;\r\n  private static PHASE_CONTROL_NON_SPECIFIC: number = 2;\r\n  private static PHASE_GLOBAL: number = 3;\r\n  private static PHASE_GLOBAL_SPECIFIC: number = 4;\r\n\r\n  private _handlerIdx: number = 0; // the index of the handler within the task\r\n  private _handlersTab: HandlersTable = null;\r\n  private _orgPrevTask: Task = null; // reference to the previous checked task\r\n  private _orgTask: Task = null; // reference to the current checked task\r\n  private _phase: number = 0; // the phase of the search: control specific, control non-specific, global\r\n  private _prevTask: Task = null; // reference to the previous checked task\r\n  private _rtEvt: RunTimeEvent = null; // the event\r\n  private _task: Task = null; // reference to the current checked task\r\n\r\n\r\n  constructor() {\r\n  }\r\n  ///   init the position to start a new chain of search\r\n  init(rtEvent: RunTimeEvent): void {\r\n    this._rtEvt = rtEvent;\r\n    this._task = <Task>this._rtEvt.getTask();\r\n    if (this._task.isMainProg()) {\r\n      this._prevTask = <Task>this._rtEvt.getMainPrgCreator();\r\n      if (this._prevTask !== null && this._prevTask.isMainProg())\r\n        this._prevTask = null;\r\n    }\r\n\r\n    if (rtEvent.getType() === ConstInterface.EVENT_TYPE_USER_FUNC)\r\n      this._phase = EventHandlerPosition.PHASE_CONTROL_NON_SPECIFIC;\r\n    else {\r\n      if (rtEvent.getType() === ConstInterface.EVENT_TYPE_USER_FUNC)\r\n        this._phase = EventHandlerPosition.PHASE_CONTROL_NON_SPECIFIC;\r\n      else\r\n        this._phase = EventHandlerPosition.PHASE_CONTROL_SPECIFIC;\r\n    }\r\n\r\n    this._orgTask = this._task;\r\n    this._orgPrevTask = this._prevTask;\r\n    this._handlersTab = this._task.getHandlersTab();\r\n    if (this._handlersTab === null) {\r\n      this.goUpTaskChain();\r\n    }\r\n\r\n    this._handlerIdx = -1;\r\n  }\r\n\r\n  getNext(evt: RunTimeEvent): EventHandler;\r\n  getNext(): EventHandler;\r\n  getNext(evt?: RunTimeEvent): EventHandler {\r\n    if (!isNullOrUndefined(evt))\r\n      return this.getNext_0(evt);\r\n    else\r\n      return this.getNext_1();\r\n  }\r\n\r\n  ///   changes the current run time event and returns the next event handler\r\n  private getNext_0(evt: RunTimeEvent): EventHandler {\r\n    this._rtEvt = evt;\r\n    return this.getNext();\r\n  }\r\n\r\n  ///   returns the next event handler\r\n  private getNext_1(): EventHandler {\r\n    if (this._handlersTab === null)\r\n      return null;\r\n    if (this._rtEvt.getType() === ConstInterface.EVENT_TYPE_INTERNAL && this._rtEvt.getInternalCode() !== InternalInterface.MG_ACT_VARIABLE) {\r\n      // special treatment for TASK, RECORD and CONTROL level Prefix/Suffix events\r\n      switch (this._rtEvt.getInternalCode()) {\r\n        case InternalInterface.MG_ACT_TASK_PREFIX:\r\n        case InternalInterface.MG_ACT_TASK_SUFFIX:\r\n        case InternalInterface.MG_ACT_REC_PREFIX:\r\n        case InternalInterface.MG_ACT_REC_SUFFIX:\r\n        case InternalInterface.MG_ACT_CTRL_PREFIX:\r\n        case InternalInterface.MG_ACT_CTRL_SUFFIX: {\r\n          if (this._rtEvt.getInternalCode() == InternalInterface.MG_ACT_REC_PREFIX)\r\n          {\r\n              FlowMonitorQueue.Instance.addDataViewFlow(this._task);\r\n          }\r\n          if (this._handlerIdx === -1) {\r\n            for (this._handlerIdx = this._handlersTab.getSize() - 1; this._handlerIdx >= 0; this._handlerIdx--) {\r\n              let handler: EventHandler = this._handlersTab.getHandler(this._handlerIdx);\r\n              if ((handler.isNonSpecificHandlerOf(this._rtEvt)) || (handler.isSpecificHandlerOf(this._rtEvt))) {\r\n                return handler;\r\n              }\r\n            }\r\n          }\r\n          // an event handler was not found or was returned in a previous call to this method\r\n          return null;\r\n        }\r\n\r\n        default:\r\n          // other internal events should continue\r\n          break;\r\n      }\r\n    }\r\n\r\n    while (this.setNextHandlerIdx()) {\r\n      let handler: EventHandler = this._handlersTab.getHandler(this._handlerIdx);\r\n      switch (this._phase) {\r\n        case EventHandlerPosition.PHASE_CONTROL_SPECIFIC:\r\n          if (handler.isSpecificHandlerOf(this._rtEvt))\r\n            return handler;\r\n          continue;\r\n\r\n        case EventHandlerPosition.PHASE_CONTROL_NON_SPECIFIC:\r\n          if (handler.isNonSpecificHandlerOf(this._rtEvt))\r\n            return handler;\r\n          continue;\r\n\r\n        case EventHandlerPosition.PHASE_GLOBAL_SPECIFIC:\r\n          if (handler.isGlobalSpecificHandlerOf(this._rtEvt))\r\n            return handler;\r\n          continue;\r\n\r\n        case EventHandlerPosition.PHASE_GLOBAL:\r\n          if (handler.isGlobalHandlerOf(this._rtEvt))\r\n            return handler;\r\n          continue;\r\n\r\n        default:\r\n          Logger.Instance.WriteExceptionToLogWithMsg(\"in EventHandlerPosition.getNext() invalid phase: \" + this._phase);\r\n          break;\r\n      }\r\n    }\r\n\r\n    return null;\r\n  }\r\n\r\n  ///   returns true if a next handler was found\r\n  private setNextHandlerIdx(): boolean {\r\n\r\n    // the handler idx is (-1) when starting to search in a task\r\n    if (this._handlerIdx < 0)\r\n      this._handlerIdx = this._handlersTab.getSize() - 1;\r\n    else\r\n      this._handlerIdx = this._handlerIdx - 1;\r\n\r\n    if (this._handlerIdx < 0 || this._task.isAborting()) {\r\n      // if there are no more handlers in the task then go up the chain of tasks\r\n      if (this.goUpTaskChain())\r\n        return this.setNextHandlerIdx();\r\n      else // no more tasks in the chain\r\n        return false;\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n  ///   get the next task in the tasks chain and returns false if no task was found.\r\n  ///   this function changes the phase variable accordingly\r\n  private goUpTaskChain(): boolean {\r\n    let mGData: MGData = this._task.getMGData();\r\n    let ctlIdx: number = this._task.getCtlIdx();\r\n\r\n    switch (this._phase) {\r\n      case EventHandlerPosition.PHASE_CONTROL_SPECIFIC:\r\n      case EventHandlerPosition.PHASE_CONTROL_NON_SPECIFIC: {\r\n        // non specific handlers are searched till we hit our main program (inclusive)\r\n        // afterwards we switch to global phase.\r\n        if (!this._task.isMainProg()) {\r\n          this.getParentOrCompMainPrg();\r\n          break;\r\n        }\r\n        else {\r\n          // internal, internal, system and user events may cross component bounderies\r\n          if ((this._rtEvt.getType() === ConstInterface.EVENT_TYPE_PUBLIC ||\r\n               this._rtEvt.getType() === ConstInterface.EVENT_TYPE_INTERNAL ||\r\n               this._rtEvt.getType() === ConstInterface.EVENT_TYPE_SYSTEM ||\r\n               this._rtEvt.getType() === ConstInterface.EVENT_TYPE_USER) && ctlIdx > 0) {\r\n            // load the RT parent of the previous task. If no prevtask exists then we are\r\n            // simply running on the main progs list (for example, when a main prg catches\r\n            // a timer event, no prevtask exists.\r\n            if (this._prevTask === null) {\r\n              this._task = mGData.getNextMainProg(ctlIdx);\r\n              if (this._task === null && ctlIdx > 0)\r\n                this._task = <Task>AccessHelper.mgDataTable.GetMainProgByCtlIdx(-1, AccessHelper.eventsManager.getCompMainPrgTab().getCtlIdx(0));\r\n            }\r\n            else {\r\n              // the component main program that was set in getParentOrCompMainPrg, is now replaced back to the path parent.\r\n              this._task = this._prevTask.PathParentTask;\r\n              this._prevTask = null;\r\n            }\r\n            this._rtEvt.setMainPrgCreator(null); // moving out of a main program to another task\r\n            break;\r\n          }\r\n\r\n          if (this._phase === EventHandlerPosition.PHASE_CONTROL_SPECIFIC) {\r\n            // specific search is over. start the non specific search from the first task.\r\n            this._phase = EventHandlerPosition.PHASE_GLOBAL_SPECIFIC;\r\n          }\r\n          else {\r\n            // here we scan the main progs according to the load sequence (first to last).\r\n            this._phase = EventHandlerPosition.PHASE_GLOBAL;\r\n          }\r\n\r\n          this._task = <Task>AccessHelper.mgDataTable.GetMainProgByCtlIdx(-1, AccessHelper.eventsManager.getCompMainPrgTab().getCtlIdx(0));\r\n          this._rtEvt.setMainPrgCreator(this._task);\r\n          if (this._task === null)\r\n            return false;\r\n          break;\r\n        }\r\n      }\r\n      case EventHandlerPosition.PHASE_GLOBAL_SPECIFIC:\r\n      case EventHandlerPosition.PHASE_GLOBAL: {\r\n        this._task = mGData.getNextMainProg(ctlIdx);\r\n        if (this._task === null) {\r\n          if (this._phase === EventHandlerPosition.PHASE_GLOBAL)\r\n            return false;\r\n\r\n          // specific search is over. start the non specific search from the first task.\r\n          this._phase = EventHandlerPosition.PHASE_CONTROL_NON_SPECIFIC;\r\n          this._task = this._orgTask;\r\n          this._prevTask = this._orgPrevTask;\r\n        }\r\n        break;\r\n      }\r\n      default:\r\n        Logger.Instance.WriteExceptionToLogWithMsg(\"in EventHandlerPosition.goUpTaskChain() invalid phase: \" + this._phase);\r\n        break;\r\n    }\r\n    if (this._task === null)\r\n      return false;\r\n\r\n    this._handlersTab = this._task.getHandlersTab();\r\n    if (this._handlersTab === null)\r\n      return this.goUpTaskChain();\r\n\r\n    this._handlerIdx = -1;\r\n    return true;\r\n  }\r\n\r\n  ///   if the current task and its parent are from different components then\r\n  ///   set the task to the main program of the component of the current task.\r\n  ///   otherwise, set the task to be the parent of the current task\r\n  private getParentOrCompMainPrg(): void {\r\n    let ctlIdx: number = this._task.getCtlIdx();\r\n    this._prevTask = this._task;\r\n\r\n    // Retrieve the task's calling-parent. We need the task who invoked the current task\r\n    // rather than the task's triggering parent.\r\n    // The Path Parent is the parent of that task as if the server had done build path. It is more logical to search using the trigger task tree\r\n    // but since the online/server does not use the trigger tree, we decided not to use it here as well.\r\n    // If the path parent is from a different comp, it means that between curr task and parent there should be a comp main prog.\r\n    let pathParentTask: Task = this._task.PathParentTask;\r\n    if (pathParentTask === null) {\r\n      this._task = null;\r\n      return;\r\n    }\r\n\r\n    // check if the parent task is from another component\r\n    if (ctlIdx !== pathParentTask.getCtlIdx()) {\r\n      // replace the parent task to search with the comp main program. later on, the main prog will be replaced with\r\n      // the real PathParentTask.\r\n      this._rtEvt.setMainPrgCreator(this._task);\r\n      this._task = <Task>AccessHelper.mgDataTable.GetMainProgByCtlIdx(-1, ctlIdx);\r\n    }\r\n    else {\r\n      this._rtEvt.setMainPrgCreator(null);\r\n      this._task = pathParentTask;\r\n    }\r\n  }\r\n}\r\n"]}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
|
+
import { BlobType, DisplayConvertor, PIC, VectorType } from '@magic-xpa/gui';
|
|
1
2
|
import { DateTime, NString, StringBuilder } from '@magic-xpa/mscorelib';
|
|
2
|
-
import { Constants, DateTimeUtils, InternalInterface, Logger, Queue, XMLConstants, XmlParser } from '@magic-xpa/utils';
|
|
3
|
+
import { Constants, DateTimeUtils, InternalInterface, Logger, Queue, StorageAttribute, XMLConstants, XmlParser } from '@magic-xpa/utils';
|
|
3
4
|
import { FlowMonitorInterface } from '../FlowMonitorInterface';
|
|
4
5
|
import { ConstInterface } from '../ConstInterface';
|
|
5
6
|
export class FlowMonitorQueue {
|
|
@@ -10,7 +11,17 @@ export class FlowMonitorQueue {
|
|
|
10
11
|
this._isRecompute = false;
|
|
11
12
|
this._isTask = false;
|
|
12
13
|
this._isTaskFlow = false;
|
|
14
|
+
this._isDataView = false;
|
|
13
15
|
this.ShouldSerialize = false;
|
|
16
|
+
this.padRight = (string, length, character = ' ') => {
|
|
17
|
+
let result = "";
|
|
18
|
+
let totalLength = length - string.length;
|
|
19
|
+
for (let i = 0; i < totalLength; i++) {
|
|
20
|
+
result = character + result;
|
|
21
|
+
}
|
|
22
|
+
result = result + string;
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
14
25
|
}
|
|
15
26
|
static get Instance() {
|
|
16
27
|
if (FlowMonitorQueue._instance === null)
|
|
@@ -68,6 +79,9 @@ export class FlowMonitorQueue {
|
|
|
68
79
|
case ConstInterface.MG_ATTR_TASKFLW:
|
|
69
80
|
this._isTaskFlow = XmlParser.getBoolean(valueStr);
|
|
70
81
|
break;
|
|
82
|
+
case ConstInterface.MG_TAG_DATAVIEW:
|
|
83
|
+
this._isDataView = XmlParser.getBoolean(valueStr);
|
|
84
|
+
break;
|
|
71
85
|
case ConstInterface.MG_ATTR_RECOMP:
|
|
72
86
|
this._isRecompute = XmlParser.getBoolean(valueStr);
|
|
73
87
|
break;
|
|
@@ -125,6 +139,92 @@ export class FlowMonitorQueue {
|
|
|
125
139
|
Logger.Instance.WriteSupportToLog(taskInfo + ": " + info, true);
|
|
126
140
|
}
|
|
127
141
|
}
|
|
142
|
+
appendVirtualsAndParameters(currentValues) {
|
|
143
|
+
let act = new ActivityItem(this, FlowMonitorQueue.ACT_TASK_FLW, InternalInterface.MG_ACT_REC_PREFIX);
|
|
144
|
+
act.setInfo(currentValues);
|
|
145
|
+
this._queue.put(act);
|
|
146
|
+
}
|
|
147
|
+
addDataViewFlow(task) {
|
|
148
|
+
if (this._isDataView) {
|
|
149
|
+
let fldTab = task.DataView.GetFieldsTab();
|
|
150
|
+
let preparedDisplayString = "";
|
|
151
|
+
let finaldisplayData = "\n";
|
|
152
|
+
let fldValue;
|
|
153
|
+
let data = "";
|
|
154
|
+
for (let i = 0; i < fldTab.getSize(); i++) {
|
|
155
|
+
let fldDef = fldTab.getField(i);
|
|
156
|
+
if (!fldDef.IsEventHandlerField && (fldDef.IsVirtual && !fldDef.VirAsReal) || fldDef.isParam()) {
|
|
157
|
+
fldValue = fldDef.isNull() ? fldDef.getNullValue() : fldDef.getValue(true);
|
|
158
|
+
data = this.getFieldData(fldDef.getType(), fldValue, fldDef.getPicture(), fldDef.getCellsType(), task);
|
|
159
|
+
preparedDisplayString = this.PrepareDisplayString(fldDef.isParam(), fldDef.getVarName(), data, true);
|
|
160
|
+
finaldisplayData = finaldisplayData + preparedDisplayString + "\n";
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
this.appendVirtualsAndParameters(finaldisplayData);
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
getFieldData(Storagetype, data, picture, vecCellType, task) {
|
|
167
|
+
switch (Storagetype) {
|
|
168
|
+
case StorageAttribute.DOTNET:
|
|
169
|
+
data = FlowMonitorQueue.UNPRINTABLE_STR_LOG;
|
|
170
|
+
break;
|
|
171
|
+
case StorageAttribute.BLOB:
|
|
172
|
+
{
|
|
173
|
+
let contentType = BlobType.getContentType(data);
|
|
174
|
+
if (contentType == BlobType.CONTENT_TYPE_ANSI || contentType == BlobType.CONTENT_TYPE_UNICODE)
|
|
175
|
+
data = data != null ? BlobType.getString(data) : "";
|
|
176
|
+
else
|
|
177
|
+
data = FlowMonitorQueue.UNPRINTABLE_STR_LOG;
|
|
178
|
+
}
|
|
179
|
+
break;
|
|
180
|
+
case StorageAttribute.NUMERIC:
|
|
181
|
+
case StorageAttribute.DATE:
|
|
182
|
+
case StorageAttribute.TIME:
|
|
183
|
+
let conv = DisplayConvertor.Instance;
|
|
184
|
+
data = conv.mg2disp(data, " ", new PIC(picture, Storagetype, task.getCompIdx()), false, task.getCompIdx(), false);
|
|
185
|
+
break;
|
|
186
|
+
case StorageAttribute.BLOB_VECTOR:
|
|
187
|
+
let vecOutData;
|
|
188
|
+
if (data == null) {
|
|
189
|
+
vecOutData = "[]";
|
|
190
|
+
}
|
|
191
|
+
else {
|
|
192
|
+
let cellAtt = vecCellType;
|
|
193
|
+
let vector = new VectorType(data);
|
|
194
|
+
if (cellAtt == StorageAttribute.BLOB && !VectorType.validateBlobContents(data))
|
|
195
|
+
vecOutData = "[]";
|
|
196
|
+
else {
|
|
197
|
+
let vecSize = VectorType.getVecSize(data);
|
|
198
|
+
let cellPicture = (cellAtt == StorageAttribute.NUMERIC || cellAtt == StorageAttribute.DATE || cellAtt == StorageAttribute.TIME) ? PIC.buildPicture(cellAtt, vector.getVecCell(1), task.getCompIdx(), true).getFormat() : picture;
|
|
199
|
+
vecOutData = "[";
|
|
200
|
+
for (let i = 0; i < vecSize; i++) {
|
|
201
|
+
vecOutData += this.getFieldData(cellAtt, vector.getVecCell(i + 1), cellPicture, vecCellType, task);
|
|
202
|
+
vecOutData += i < vecSize - 1 ? "," : "]";
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
data = vecOutData;
|
|
207
|
+
break;
|
|
208
|
+
case StorageAttribute.BOOLEAN:
|
|
209
|
+
data = data == "1" ? "TRUE" : "FALSE";
|
|
210
|
+
break;
|
|
211
|
+
}
|
|
212
|
+
return data;
|
|
213
|
+
}
|
|
214
|
+
PrepareDisplayString(mode, name, valueContent, addDoubleQuotes) {
|
|
215
|
+
let str = "";
|
|
216
|
+
let finalStringToDisplay = "";
|
|
217
|
+
if (addDoubleQuotes)
|
|
218
|
+
finalStringToDisplay = finalStringToDisplay + "\"";
|
|
219
|
+
finalStringToDisplay = finalStringToDisplay + name;
|
|
220
|
+
if (addDoubleQuotes)
|
|
221
|
+
finalStringToDisplay = finalStringToDisplay + "\"";
|
|
222
|
+
let paddedName = this.padRight(name, 34);
|
|
223
|
+
let formatOfStringVirtual = `Virtual`;
|
|
224
|
+
let formatOfStringParameter = `Parameter`;
|
|
225
|
+
str = (mode ? formatOfStringParameter : formatOfStringVirtual) + " : " + `${paddedName}` + " : " + `${valueContent}`;
|
|
226
|
+
return str;
|
|
227
|
+
}
|
|
128
228
|
addTaskFlowRec(id, state, taskInfo) {
|
|
129
229
|
if (this._enabled && this._isTaskFlow) {
|
|
130
230
|
let info;
|
|
@@ -289,6 +389,7 @@ export class FlowMonitorQueue {
|
|
|
289
389
|
}
|
|
290
390
|
}
|
|
291
391
|
FlowMonitorQueue._instance = null;
|
|
392
|
+
FlowMonitorQueue.UNPRINTABLE_STR_LOG = "#UNPRINTABLE#";
|
|
292
393
|
FlowMonitorQueue.S_EVENT_STR1 = ">>Starts ";
|
|
293
394
|
FlowMonitorQueue.S_EVENT_STR2 = " Event";
|
|
294
395
|
FlowMonitorQueue.S_EVENT_PROPAGATED = "Event was propagated";
|
|
@@ -345,4 +446,4 @@ class ActivityItem {
|
|
|
345
446
|
message.Append(XMLConstants.TAG_TERM);
|
|
346
447
|
}
|
|
347
448
|
}
|
|
348
|
-
//# 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 {IFlowMonitorQueue} from '@magic-xpa/gui';\r\nimport {DateTime, List, NString, StringBuilder} from '@magic-xpa/mscorelib';\r\nimport {Constants, DateTimeUtils, InternalInterface, Logger, Queue, XMLConstants, XmlParser} from '@magic-xpa/utils';\r\nimport {Operation} from '../rt/Operation';\r\nimport {FlowMonitorInterface} from '../FlowMonitorInterface';\r\nimport {ConstInterface} from '../ConstInterface';\r\n\r\n// @dynamic\r\nexport class FlowMonitorQueue implements IFlowMonitorQueue {\r\n  private static _instance: FlowMonitorQueue = null;\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  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_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  /// <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"]}
|
|
449
|
+
//# 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                  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              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      //if (!mode)\r\n          str = (mode ? formatOfStringParameter : formatOfStringVirtual) + \" : \" +`${paddedName}`+ \" : \"+`${valueContent}`;\r\n      //    str = String.Format(formatOfStringVirtual, name.PadRight(34), valueContent);\r\n     // else\r\n     //     str = String.Format(formatOfStringParameter, name.PadRight(34), valueContent);\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"]}
|